Affaan Mustafa
ff4a565613
fix(clv2): harden registry writes and project deletion ( #2294 , #2297 )
...
Two security-priority fixes in continuous-learning-v2/scripts/instinct-cli.py:
- #2294 : _write_registry wrote projects.json without the advisory lock that
_update_registry holds, so concurrent 'projects delete/gc/merge' could race an
observe-time update and corrupt the registry. Extract the lock into a shared
_registry_lock() context manager and use it in both writers.
- #2297 : _remove_project_storage called shutil.rmtree on PROJECTS_DIR/project_id
with no containment check. Add defense-in-depth: resolve the path and refuse to
delete anything that is not strictly inside PROJECTS_DIR (or is the root
itself), so a relaxed validator or future caller can never cause an
arbitrary-directory delete.
Adds 5 pytest regression tests (atomic write under lock, contained delete,
missing-dir no-op, traversal refused, root refused). Node integration suite
(tests/scripts/instinct-cli-projects.test.js) green 9/9.
2026-06-21 21:49:33 -04:00
..
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 17:58:57 +05:30
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:58:42 +02:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-15 14:21:28 -04:00
2026-06-11 21:12:21 +09:00
2026-06-15 14:09:17 -04:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:58:42 +02:00
2026-06-11 21:58:42 +02:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-21 21:49:33 -04:00
2026-06-11 21:12:21 +09:00
2026-06-18 16:49:58 -04:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-16 02:15:43 -04:00
2026-06-11 21:12:21 +09:00
2026-02-24 14:39:25 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-16 09:17:18 +08:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-04-05 13:30:55 -07:00
2026-06-11 21:12:21 +09:00
2026-06-07 13:26:45 +08:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-02-24 14:39:25 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 11:39:26 -04:00
2026-06-11 21:12:21 +09:00
2026-05-12 01:47:05 -04:00
2026-05-12 01:47:05 -04:00
2026-06-07 16:05:28 +08:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-04-02 17:09:21 -07:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-15 14:09:17 -04:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-15 14:09:17 -04:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-15 14:09:17 -04:00
2026-06-11 21:12:21 +09:00
2026-02-24 14:39:25 +09:00
2026-06-11 21:12:21 +09:00
2026-02-17 17:04:31 +02:00
2026-06-07 12:43:04 -04:00
2026-06-15 14:09:17 -04:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-15 14:09:17 -04:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00
2026-03-29 21:21:18 -04:00
2026-06-11 21:12:21 +09:00
2026-06-12 19:14:31 +08:00
2026-06-15 14:09:17 -04:00
2026-06-11 21:12:21 +09:00
2026-06-11 21:12:21 +09:00