teknium1
c4b8f5efee
fix(kanban): harden corrupt-db backup against CodeQL path-injection findings
...
Path.resolve() before any I/O and confine backup writes to the resolved
parent directory. Adds explicit parent-equality assertions so static
analyzers see the containment guarantee, and walks WAL/SHM sidecars
through the same resolved-parent path so accidental .. segments are
collapsed before shutil.copy2.
Functionally equivalent to the original PR; preserves the corrupt bytes
to <db>.corrupt.<ts>.bak in the same directory, still raises
KanbanDbCorruptError from connect(). E2E with Stefan's exact hex header
+ malformed pages still passes. 163/163 kanban tests still pass.
2026-05-23 05:51:33 -07:00
..
2026-05-22 14:17:40 -07:00
2026-05-16 02:58:57 -07:00
2026-05-07 06:16:23 -07:00
2026-05-08 14:27:40 -07:00
2026-05-18 20:10:52 -07:00
2026-05-22 15:16:15 -07:00
2026-05-18 10:14:38 -07:00
2026-05-11 11:13:25 -07:00
2026-05-15 14:45:43 -07:00
2026-05-19 22:34:05 -07:00
2026-05-18 21:38:05 -07:00
2026-04-14 16:11:37 -07:00
2026-05-11 11:13:25 -07:00
2026-05-11 11:13:25 -07:00
2026-04-13 16:32:04 -07:00
2026-05-13 22:54:21 -07:00
2026-05-11 11:13:25 -07:00
2026-05-15 02:31:30 -07:00
2026-05-17 02:29:41 -07:00
2026-03-30 17:07:21 -07:00
2026-05-22 14:21:41 -07:00
2026-05-13 09:34:15 -07:00
2026-05-21 14:10:34 -07:00
2026-05-11 11:13:25 -07:00
2026-05-18 17:39:50 +00:00
2026-05-11 11:13:25 -07:00
2026-05-21 23:40:58 -07:00
2026-05-03 11:42:20 -07:00
2026-03-26 01:34:27 -07:00
2026-05-18 16:34:24 +05:30
2026-05-11 11:13:25 -07:00
2026-05-20 09:18:23 -07:00
2026-05-21 14:18:02 -07:00
2026-05-22 03:32:58 -07:00
2026-05-23 05:24:57 -07:00
2026-05-23 05:24:57 -07:00
2026-05-23 02:30:41 -07:00
2026-05-22 14:21:41 -07:00
2026-05-16 23:05:27 -07:00
2026-05-11 11:13:25 -07:00
2026-05-13 22:31:11 -07:00
2026-05-23 05:51:33 -07:00
2026-05-18 20:26:02 -07:00
2026-05-18 20:47:01 -07:00
2026-05-18 20:15:20 -07:00
2026-05-18 21:10:12 -07:00
2026-05-18 21:39:03 -07:00
2026-04-11 17:23:36 -07:00
2026-05-23 02:39:09 -07:00
2026-05-15 01:43:54 -07:00
2026-05-14 07:59:38 -07:00
2026-05-20 09:18:23 -07:00
2026-05-08 14:27:40 -07:00
2026-05-06 09:08:33 -07:00
2026-05-19 10:57:35 -07:00
2026-05-16 02:24:48 -07:00
2026-05-06 10:05:29 -07:00
2026-05-23 05:24:57 -07:00
2026-05-07 07:18:21 -07:00
2026-04-29 21:56:51 -07:00
2026-05-22 19:50:32 -07:00
2026-05-17 04:04:15 -07:00
2026-05-23 02:39:09 -07:00
2026-05-21 14:18:02 -07:00
2026-05-21 14:18:02 -07:00
2026-05-21 14:18:02 -07:00
2026-05-18 14:31:37 -07:00
2026-05-09 12:48:14 -07:00
2026-05-11 11:13:25 -07:00
2026-05-08 14:27:40 -07:00
2026-05-21 07:48:53 -07:00
2026-05-21 14:10:34 -07:00
2026-05-12 01:02:25 -07:00
2026-05-16 23:00:58 -05:00
2026-05-17 02:29:41 -07:00
2026-05-23 02:39:09 -07:00
2026-04-29 04:03:03 -07:00
2026-05-21 14:18:02 -07:00
2026-05-18 20:05:23 -07:00
2026-05-08 17:01:12 -07:00
2026-05-17 11:35:57 -07:00
2026-05-11 11:13:25 -07:00
2026-05-19 14:25:10 -07:00
2026-05-19 22:34:05 -07:00
2026-05-23 02:39:09 -07:00
2026-05-18 20:05:47 -07:00
2026-04-29 07:22:33 -07:00
2026-05-06 15:49:59 -07:00
2026-05-23 01:43:52 -07:00
2026-05-11 11:13:25 -07:00
2026-05-20 09:18:23 -07:00