Commit 4dd9fee
committed
Add database merge functionality
Implement full database merge support following KeePassXC's conceptual
algorithm with UUID-based matching and timestamp-based conflict resolution.
Features:
- MergeMode.STANDARD: Add and update entries/groups (safe default)
- MergeMode.SYNCHRONIZE: Also apply deletions from source
- Timestamp-based conflict resolution (newer modification wins)
- Losing version preserved in winner's history
- Location change tracking via location_changed timestamp
- Binary deduplication by SHA-256 hash
- Custom icon merging by UUID
- Recycle bin exclusion during merge
- DeletedObjects support for SYNCHRONIZE mode
Public API:
- Database.merge(source, mode=MergeMode.STANDARD) -> MergeResult
- MergeMode enum (STANDARD, SYNCHRONIZE)
- MergeResult dataclass with change counts and summary()
- MergeError exception for merge failures
- DeletedObject dataclass for tracking deletions
Includes 31 comprehensive tests covering basic merges, conflicts,
groups, history, binaries, custom icons, location changes, and
synchronize mode deletions.
Closes #541 parent cbdde30 commit 4dd9fee
File tree
5 files changed
+1297
-1
lines changed- src/kdbxtool
- tests
5 files changed
+1297
-1
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
42 | 42 | | |
43 | 43 | | |
44 | 44 | | |
| 45 | + | |
45 | 46 | | |
46 | 47 | | |
47 | 48 | | |
| |||
52 | 53 | | |
53 | 54 | | |
54 | 55 | | |
| 56 | + | |
55 | 57 | | |
56 | 58 | | |
57 | 59 | | |
| |||
79 | 81 | | |
80 | 82 | | |
81 | 83 | | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
82 | 88 | | |
83 | 89 | | |
84 | 90 | | |
| |||
103 | 109 | | |
104 | 110 | | |
105 | 111 | | |
| 112 | + | |
106 | 113 | | |
107 | 114 | | |
108 | 115 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
21 | 21 | | |
22 | 22 | | |
23 | 23 | | |
24 | | - | |
| 24 | + | |
25 | 25 | | |
26 | 26 | | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
27 | 30 | | |
28 | 31 | | |
29 | 32 | | |
| |||
170 | 173 | | |
171 | 174 | | |
172 | 175 | | |
| 176 | + | |
173 | 177 | | |
174 | 178 | | |
175 | 179 | | |
| |||
307 | 311 | | |
308 | 312 | | |
309 | 313 | | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
310 | 353 | | |
311 | 354 | | |
312 | 355 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
317 | 317 | | |
318 | 318 | | |
319 | 319 | | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
0 commit comments