Dusk1e
5f26d60860
fix(tools): prevent command argument injection and path traversal in checkpoint manager
...
This commit addresses a security vulnerability where unsanitized user inputs for commit_hash and file_path were passed directly to git commands in CheckpointManager.restore() and diff(). It validates commit hashes to be strictly hexadecimal characters without leading dashes (preventing flag injection like '--patch') and enforces file paths to stay within the working directory via root resolution. Regression tests test_restore_rejects_argument_injection, test_restore_rejects_invalid_hex_chars, and test_restore_rejects_path_traversal were added.
2026-04-11 14:25:13 -07:00
..
2026-02-26 03:20:08 +03:00
2026-03-23 07:43:12 -07:00
2026-04-11 02:03:20 -07:00
2026-04-08 17:23:15 -07:00
2026-04-10 03:44:43 -07:00
2026-04-09 13:17:06 -07:00
2026-04-10 03:44:43 -07:00
2026-04-07 08:40:22 -04:00
2026-04-08 13:44:58 -07:00
2026-03-17 02:02:57 -07:00
2026-03-28 17:25:04 -07:00
2026-04-10 13:05:44 -07:00
2026-04-10 13:05:44 -07:00
2026-04-11 14:02:46 -07:00
2026-04-01 12:03:56 -07:00
2026-03-31 10:40:13 -07:00
2026-04-11 02:58:48 -07:00
2026-04-11 14:25:13 -07:00
2026-02-27 03:29:26 -05:00
2026-04-10 21:15:47 -07:00
2026-04-11 14:02:58 -07:00
2026-04-10 03:44:43 -07:00
2026-03-27 04:03:00 -07:00
2026-04-10 03:44:43 -07:00
2026-02-26 13:55:54 +03:00
2026-03-17 01:40:02 -07:00
2026-04-08 17:23:15 -07:00
2026-03-02 04:34:21 -08:00
2026-03-26 14:50:26 -07:00
2026-04-10 21:16:53 -07:00
2026-04-09 13:17:06 -07:00
2026-03-10 20:45:13 -07:00
2026-04-10 03:44:43 -07:00
2026-04-10 21:16:53 -07:00
2026-04-10 16:47:44 -07:00
2026-03-31 12:53:19 -07:00
2026-04-01 00:50:08 -07:00
2026-04-10 03:01:46 -07:00
2026-04-10 21:14:32 -07:00
2026-04-08 17:23:15 -07:00
2026-03-23 07:43:12 -07:00
2026-03-17 02:22:12 -07:00
2026-03-14 11:27:02 -07:00
2026-04-10 16:47:44 -07:00
2026-03-04 18:34:16 +03:00
2026-03-01 11:53:50 +03:00
2026-03-13 02:51:51 -07:00
2026-03-27 15:28:19 -07:00
2026-03-23 22:45:55 -07:00
2026-04-09 16:24:53 -07:00
2026-04-07 17:19:07 -07:00
2026-04-11 02:03:20 -07:00
2026-04-08 17:23:15 -07:00
2026-04-09 13:17:06 -07:00
2026-04-07 08:40:22 -04:00
2026-03-29 15:52:54 -07:00
2026-04-05 22:08:00 -07:00
2026-04-04 10:18:57 -07:00
2026-04-10 16:47:44 -07:00
2026-04-10 03:44:35 -07:00
2026-04-04 10:18:57 -07:00
2026-04-02 20:54:27 -07:00
2026-04-03 13:10:11 -07:00
2026-03-14 07:53:56 -07:00
2026-04-08 17:23:15 -07:00
2026-04-10 03:01:46 -07:00
2026-04-11 13:46:16 -07:00
2026-04-05 12:46:07 -07:00
2026-03-17 02:34:35 -07:00
2026-04-10 16:47:44 -07:00
2026-04-11 13:46:16 -07:00
2026-03-20 14:54:25 -07:00
2026-03-27 07:49:44 -07:00
2026-03-10 17:09:51 -07:00
2026-03-17 02:02:57 -07:00
2026-04-09 13:17:06 -07:00
2026-04-10 03:20:05 -07:00
2026-03-26 14:35:31 -07:00
2026-03-16 19:01:39 +03:00
2026-04-10 03:44:43 -07:00
2026-04-01 04:19:19 -07:00
2026-04-11 13:59:52 -07:00
2026-04-01 04:19:19 -07:00
2026-03-04 05:30:43 -08:00
2026-03-02 02:00:09 -08:00
2026-03-26 13:40:21 -07:00
2026-03-14 23:15:04 -07:00
2026-04-10 03:44:43 -07:00
2026-04-11 01:21:20 -07:00
2026-03-28 17:52:32 -07:00
2026-04-10 03:01:46 -07:00
2026-03-04 17:23:23 +03:00
2026-03-21 17:10:17 -07:00
2026-04-04 16:57:24 -07:00
2026-04-10 02:58:54 -07:00
2026-04-08 21:37:51 -07:00
2026-03-31 08:48:54 +09:00
2026-03-29 21:51:44 -07:00
2026-04-09 16:24:53 -07:00
2026-03-30 13:28:10 +09:00
2026-04-09 02:50:07 -07:00
2026-04-08 17:23:15 -07:00
2026-03-16 23:39:41 -07:00
2026-03-08 23:07:38 +03:00
2026-04-11 02:58:48 -07:00
2026-04-07 17:19:07 -07:00
2026-04-09 16:24:53 -07:00
2026-04-10 03:27:30 -07:00
2026-03-31 03:10:01 -07:00
2026-04-11 01:56:55 -07:00
2026-03-23 15:40:42 -07:00
2026-04-11 11:53:04 -07:00
2026-03-14 14:27:21 +03:00
2026-04-09 16:24:53 -07:00
2026-04-11 03:13:23 -07:00
2026-03-31 08:48:54 +09:00
2026-04-09 13:17:06 -07:00
2026-03-30 08:10:14 -07:00
2026-03-01 01:54:27 +03:00
2026-02-26 13:30:55 +03:00
2026-04-10 03:38:44 -07:00
2026-04-10 16:51:44 -07:00