Commit e8d95d1
feat: change manifest PK from local_path to asset_resource
Replace PK (asset_id, zone_id, local_path) with
(asset_id, zone_id, asset_resource) where asset_resource is the Apple
iCloud resource field prefix (e.g. resOriginal, resOriginalVidCompl).
This makes local_path an updateable column, so config changes like
toggling --keep-unicode-in-filenames update the existing manifest row
instead of creating a duplicate.
- Add asset_resource column (schema v3)
- Add version_to_resource() mapping in version_size.py
- Update all manifest.lookup/upsert/remove calls in base.py
- Migration: v0/v1/v2 DBs get asset_resource via ALTER + table rebuild
- 7 new unit tests for asset_resource PK behaviour
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>1 parent 2635da7 commit e8d95d1
File tree
6 files changed
+236
-57
lines changed- src
- icloudpd
- pyicloud_ipd
- tests
6 files changed
+236
-57
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
92 | 92 | | |
93 | 93 | | |
94 | 94 | | |
95 | | - | |
| 95 | + | |
96 | 96 | | |
97 | 97 | | |
98 | 98 | | |
| |||
128 | 128 | | |
129 | 129 | | |
130 | 130 | | |
| 131 | + | |
131 | 132 | | |
132 | 133 | | |
133 | 134 | | |
| |||
140 | 141 | | |
141 | 142 | | |
142 | 143 | | |
143 | | - | |
| 144 | + | |
144 | 145 | | |
145 | 146 | | |
146 | 147 | | |
| |||
874 | 875 | | |
875 | 876 | | |
876 | 877 | | |
877 | | - | |
878 | | - | |
| 878 | + | |
| 879 | + | |
| 880 | + | |
879 | 881 | | |
880 | 882 | | |
881 | 883 | | |
| |||
1000 | 1002 | | |
1001 | 1003 | | |
1002 | 1004 | | |
| 1005 | + | |
1003 | 1006 | | |
1004 | 1007 | | |
1005 | 1008 | | |
1006 | 1009 | | |
1007 | 1010 | | |
1008 | | - | |
| 1011 | + | |
1009 | 1012 | | |
1010 | 1013 | | |
1011 | 1014 | | |
1012 | 1015 | | |
| 1016 | + | |
1013 | 1017 | | |
1014 | 1018 | | |
1015 | 1019 | | |
| |||
1039 | 1043 | | |
1040 | 1044 | | |
1041 | 1045 | | |
| 1046 | + | |
1042 | 1047 | | |
1043 | 1048 | | |
1044 | 1049 | | |
| |||
1059 | 1064 | | |
1060 | 1065 | | |
1061 | 1066 | | |
| 1067 | + | |
1062 | 1068 | | |
1063 | 1069 | | |
1064 | 1070 | | |
| |||
1075 | 1081 | | |
1076 | 1082 | | |
1077 | 1083 | | |
| 1084 | + | |
1078 | 1085 | | |
1079 | 1086 | | |
1080 | 1087 | | |
| |||
1151 | 1158 | | |
1152 | 1159 | | |
1153 | 1160 | | |
| 1161 | + | |
1154 | 1162 | | |
1155 | 1163 | | |
1156 | 1164 | | |
| |||
1170 | 1178 | | |
1171 | 1179 | | |
1172 | 1180 | | |
| 1181 | + | |
1173 | 1182 | | |
1174 | 1183 | | |
1175 | 1184 | | |
| |||
1200 | 1209 | | |
1201 | 1210 | | |
1202 | 1211 | | |
1203 | | - | |
| 1212 | + | |
1204 | 1213 | | |
1205 | 1214 | | |
1206 | 1215 | | |
| |||
1219 | 1228 | | |
1220 | 1229 | | |
1221 | 1230 | | |
1222 | | - | |
| 1231 | + | |
1223 | 1232 | | |
1224 | 1233 | | |
1225 | 1234 | | |
1226 | 1235 | | |
| 1236 | + | |
1227 | 1237 | | |
1228 | 1238 | | |
1229 | 1239 | | |
| |||
1245 | 1255 | | |
1246 | 1256 | | |
1247 | 1257 | | |
| 1258 | + | |
1248 | 1259 | | |
1249 | 1260 | | |
1250 | 1261 | | |
| |||
1263 | 1274 | | |
1264 | 1275 | | |
1265 | 1276 | | |
| 1277 | + | |
1266 | 1278 | | |
1267 | 1279 | | |
1268 | 1280 | | |
| |||
1277 | 1289 | | |
1278 | 1290 | | |
1279 | 1291 | | |
| 1292 | + | |
1280 | 1293 | | |
1281 | 1294 | | |
1282 | 1295 | | |
| |||
1315 | 1328 | | |
1316 | 1329 | | |
1317 | 1330 | | |
| 1331 | + | |
1318 | 1332 | | |
1319 | 1333 | | |
1320 | 1334 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| 13 | + | |
13 | 14 | | |
14 | 15 | | |
15 | 16 | | |
| |||
25 | 26 | | |
26 | 27 | | |
27 | 28 | | |
| 29 | + | |
28 | 30 | | |
29 | 31 | | |
30 | 32 | | |
| |||
88 | 90 | | |
89 | 91 | | |
90 | 92 | | |
| 93 | + | |
91 | 94 | | |
92 | 95 | | |
93 | 96 | | |
| |||
125 | 128 | | |
126 | 129 | | |
127 | 130 | | |
128 | | - | |
| 131 | + | |
129 | 132 | | |
130 | 133 | | |
131 | 134 | | |
| |||
224 | 227 | | |
225 | 228 | | |
226 | 229 | | |
| 230 | + | |
227 | 231 | | |
228 | 232 | | |
229 | 233 | | |
| |||
232 | 236 | | |
233 | 237 | | |
234 | 238 | | |
235 | | - | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
236 | 243 | | |
237 | 244 | | |
238 | 245 | | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
239 | 261 | | |
240 | 262 | | |
241 | 263 | | |
| |||
272 | 294 | | |
273 | 295 | | |
274 | 296 | | |
275 | | - | |
| 297 | + | |
276 | 298 | | |
277 | 299 | | |
278 | 300 | | |
279 | | - | |
280 | | - | |
| 301 | + | |
| 302 | + | |
281 | 303 | | |
282 | 304 | | |
283 | 305 | | |
| |||
300 | 322 | | |
301 | 323 | | |
302 | 324 | | |
| 325 | + | |
303 | 326 | | |
304 | 327 | | |
305 | 328 | | |
| |||
333 | 356 | | |
334 | 357 | | |
335 | 358 | | |
336 | | - | |
| 359 | + | |
337 | 360 | | |
338 | 361 | | |
339 | 362 | | |
| |||
402 | 425 | | |
403 | 426 | | |
404 | 427 | | |
405 | | - | |
| 428 | + | |
406 | 429 | | |
407 | 430 | | |
408 | 431 | | |
409 | 432 | | |
410 | | - | |
| 433 | + | |
411 | 434 | | |
412 | | - | |
| 435 | + | |
413 | 436 | | |
414 | 437 | | |
415 | 438 | | |
416 | 439 | | |
417 | 440 | | |
418 | 441 | | |
419 | | - | |
| 442 | + | |
420 | 443 | | |
421 | 444 | | |
422 | 445 | | |
| |||
456 | 479 | | |
457 | 480 | | |
458 | 481 | | |
459 | | - | |
| 482 | + | |
460 | 483 | | |
461 | 484 | | |
462 | | - | |
463 | | - | |
| 485 | + | |
| 486 | + | |
464 | 487 | | |
465 | 488 | | |
466 | 489 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
210 | 210 | | |
211 | 211 | | |
212 | 212 | | |
213 | | - | |
214 | | - | |
| 213 | + | |
215 | 214 | | |
216 | 215 | | |
217 | 216 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
22 | 22 | | |
23 | 23 | | |
24 | 24 | | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
0 commit comments