Commit a6410aa
fix(drawings): copy S3 storage on duplicate so the original can be deleted
POST /drawings/:id/duplicate previously copied elements/appState/files
verbatim, including the dataURLs that point at the *original*
drawing's S3 prefix (`/api/files/origId/fileId` or
`https://.../excalidash/owner/origId/fileId.ext`). The duplicate's
images therefore pointed at storage owned by the original. Deleting
the original then ran the new prefix-scoped S3 cleanup and silently
broke every image in the duplicate.
Now the duplicate handler does a server-side CopyObject for every
S3File row of the original under the new drawingId path, writes a
fresh (newDrawingId, fileId) S3File row, and rewrites the dataURLs
in the new drawing's files JSON to match the new drawing id. Each
drawing — original and duplicate — owns its own storage from the
moment of duplication, so DELETE /drawings/:origId can no longer
strand the duplicate.
Adds a bucket-internal copyS3Object() helper to s3.ts (uses S3
CopyObject; no download/re-upload).
Change-Id: If57d006fce8964fe04e702680e96866a3ec3b6f0
Co-developed-by: Claude <noreply@anthropic.com>
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>1 parent a98133b commit a6410aa
2 files changed
Lines changed: 99 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| 8 | + | |
8 | 9 | | |
9 | 10 | | |
10 | 11 | | |
| |||
705 | 706 | | |
706 | 707 | | |
707 | 708 | | |
| 709 | + | |
| 710 | + | |
| 711 | + | |
| 712 | + | |
| 713 | + | |
| 714 | + | |
| 715 | + | |
| 716 | + | |
| 717 | + | |
| 718 | + | |
| 719 | + | |
| 720 | + | |
| 721 | + | |
| 722 | + | |
| 723 | + | |
| 724 | + | |
| 725 | + | |
| 726 | + | |
| 727 | + | |
| 728 | + | |
| 729 | + | |
| 730 | + | |
| 731 | + | |
| 732 | + | |
| 733 | + | |
| 734 | + | |
| 735 | + | |
| 736 | + | |
| 737 | + | |
| 738 | + | |
| 739 | + | |
| 740 | + | |
| 741 | + | |
| 742 | + | |
| 743 | + | |
| 744 | + | |
| 745 | + | |
| 746 | + | |
| 747 | + | |
| 748 | + | |
| 749 | + | |
| 750 | + | |
| 751 | + | |
| 752 | + | |
| 753 | + | |
| 754 | + | |
| 755 | + | |
| 756 | + | |
| 757 | + | |
| 758 | + | |
| 759 | + | |
| 760 | + | |
| 761 | + | |
| 762 | + | |
| 763 | + | |
| 764 | + | |
| 765 | + | |
| 766 | + | |
| 767 | + | |
| 768 | + | |
| 769 | + | |
| 770 | + | |
| 771 | + | |
| 772 | + | |
| 773 | + | |
| 774 | + | |
| 775 | + | |
| 776 | + | |
| 777 | + | |
| 778 | + | |
708 | 779 | | |
709 | 780 | | |
710 | 781 | | |
711 | 782 | | |
712 | 783 | | |
713 | 784 | | |
714 | 785 | | |
715 | | - | |
| 786 | + | |
716 | 787 | | |
717 | 788 | | |
718 | 789 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
| 11 | + | |
11 | 12 | | |
12 | 13 | | |
13 | 14 | | |
| |||
233 | 234 | | |
234 | 235 | | |
235 | 236 | | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
236 | 263 | | |
237 | 264 | | |
238 | 265 | | |
| |||
0 commit comments