opentasks 0.0.6 → 0.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +68 -0
- package/dist/__tests__/cli-tools.test.d.ts +8 -0
- package/dist/__tests__/cli-tools.test.d.ts.map +1 -0
- package/dist/__tests__/cli-tools.test.js +546 -0
- package/dist/__tests__/cli-tools.test.js.map +1 -0
- package/dist/__tests__/cli.test.d.ts +5 -0
- package/dist/__tests__/cli.test.d.ts.map +1 -0
- package/dist/__tests__/cli.test.js +77 -0
- package/dist/__tests__/cli.test.js.map +1 -0
- package/dist/__tests__/p1-p3-gaps.test.d.ts +2 -0
- package/dist/__tests__/p1-p3-gaps.test.d.ts.map +1 -0
- package/dist/__tests__/p1-p3-gaps.test.js +463 -0
- package/dist/__tests__/p1-p3-gaps.test.js.map +1 -0
- package/dist/cli.d.ts +1 -0
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +64 -0
- package/dist/cli.js.map +1 -1
- package/dist/client/__tests__/client-crud.test.d.ts +7 -0
- package/dist/client/__tests__/client-crud.test.d.ts.map +1 -0
- package/dist/client/__tests__/client-crud.test.js +404 -0
- package/dist/client/__tests__/client-crud.test.js.map +1 -0
- package/dist/client/__tests__/client.test.d.ts +5 -0
- package/dist/client/__tests__/client.test.d.ts.map +1 -0
- package/dist/client/__tests__/client.test.js +518 -0
- package/dist/client/__tests__/client.test.js.map +1 -0
- package/dist/client/client.d.ts +47 -1
- package/dist/client/client.d.ts.map +1 -1
- package/dist/client/client.js +71 -0
- package/dist/client/client.js.map +1 -1
- package/dist/client/index.d.ts +1 -1
- package/dist/client/index.d.ts.map +1 -1
- package/dist/config/__tests__/defaults.test.d.ts +2 -0
- package/dist/config/__tests__/defaults.test.d.ts.map +1 -0
- package/dist/config/__tests__/defaults.test.js +57 -0
- package/dist/config/__tests__/defaults.test.js.map +1 -0
- package/dist/config/__tests__/env.test.d.ts +2 -0
- package/dist/config/__tests__/env.test.d.ts.map +1 -0
- package/dist/config/__tests__/env.test.js +136 -0
- package/dist/config/__tests__/env.test.js.map +1 -0
- package/dist/config/__tests__/index.test.d.ts +2 -0
- package/dist/config/__tests__/index.test.d.ts.map +1 -0
- package/dist/config/__tests__/index.test.js +113 -0
- package/dist/config/__tests__/index.test.js.map +1 -0
- package/dist/config/__tests__/loader.test.d.ts +2 -0
- package/dist/config/__tests__/loader.test.d.ts.map +1 -0
- package/dist/config/__tests__/loader.test.js +128 -0
- package/dist/config/__tests__/loader.test.js.map +1 -0
- package/dist/config/__tests__/merge.test.d.ts +2 -0
- package/dist/config/__tests__/merge.test.d.ts.map +1 -0
- package/dist/config/__tests__/merge.test.js +79 -0
- package/dist/config/__tests__/merge.test.js.map +1 -0
- package/dist/config/__tests__/schema.test.d.ts +2 -0
- package/dist/config/__tests__/schema.test.d.ts.map +1 -0
- package/dist/config/__tests__/schema.test.js +300 -0
- package/dist/config/__tests__/schema.test.js.map +1 -0
- package/dist/config/schema.d.ts +178 -4
- package/dist/config/schema.d.ts.map +1 -1
- package/dist/config/schema.js +109 -7
- package/dist/config/schema.js.map +1 -1
- package/dist/context-files/context-files.d.ts +72 -0
- package/dist/context-files/context-files.d.ts.map +1 -0
- package/dist/context-files/context-files.js +145 -0
- package/dist/context-files/context-files.js.map +1 -0
- package/dist/context-files/index.d.ts +16 -0
- package/dist/context-files/index.d.ts.map +1 -0
- package/dist/context-files/index.js +14 -0
- package/dist/context-files/index.js.map +1 -0
- package/dist/context-files/resolver.d.ts +43 -0
- package/dist/context-files/resolver.d.ts.map +1 -0
- package/dist/context-files/resolver.js +127 -0
- package/dist/context-files/resolver.js.map +1 -0
- package/dist/context-files/types.d.ts +94 -0
- package/dist/context-files/types.d.ts.map +1 -0
- package/dist/context-files/types.js +10 -0
- package/dist/context-files/types.js.map +1 -0
- package/dist/context-files/watcher-integration.d.ts +47 -0
- package/dist/context-files/watcher-integration.d.ts.map +1 -0
- package/dist/context-files/watcher-integration.js +47 -0
- package/dist/context-files/watcher-integration.js.map +1 -0
- package/dist/core/__tests__/conditional-redirects.test.d.ts +2 -0
- package/dist/core/__tests__/conditional-redirects.test.d.ts.map +1 -0
- package/dist/core/__tests__/conditional-redirects.test.js +83 -0
- package/dist/core/__tests__/conditional-redirects.test.js.map +1 -0
- package/dist/core/__tests__/connections.test.d.ts +2 -0
- package/dist/core/__tests__/connections.test.d.ts.map +1 -0
- package/dist/core/__tests__/connections.test.js +158 -0
- package/dist/core/__tests__/connections.test.js.map +1 -0
- package/dist/core/__tests__/hash.test.d.ts +2 -0
- package/dist/core/__tests__/hash.test.d.ts.map +1 -0
- package/dist/core/__tests__/hash.test.js +139 -0
- package/dist/core/__tests__/hash.test.js.map +1 -0
- package/dist/core/__tests__/id.test.d.ts +2 -0
- package/dist/core/__tests__/id.test.d.ts.map +1 -0
- package/dist/core/__tests__/id.test.js +142 -0
- package/dist/core/__tests__/id.test.js.map +1 -0
- package/dist/core/__tests__/location.test.d.ts +2 -0
- package/dist/core/__tests__/location.test.d.ts.map +1 -0
- package/dist/core/__tests__/location.test.js +77 -0
- package/dist/core/__tests__/location.test.js.map +1 -0
- package/dist/core/__tests__/merge-driver.test.d.ts +2 -0
- package/dist/core/__tests__/merge-driver.test.d.ts.map +1 -0
- package/dist/core/__tests__/merge-driver.test.js +218 -0
- package/dist/core/__tests__/merge-driver.test.js.map +1 -0
- package/dist/core/__tests__/redirects.test.d.ts +2 -0
- package/dist/core/__tests__/redirects.test.d.ts.map +1 -0
- package/dist/core/__tests__/redirects.test.js +123 -0
- package/dist/core/__tests__/redirects.test.js.map +1 -0
- package/dist/core/__tests__/resolve-location-target.test.d.ts +8 -0
- package/dist/core/__tests__/resolve-location-target.test.d.ts.map +1 -0
- package/dist/core/__tests__/resolve-location-target.test.js +303 -0
- package/dist/core/__tests__/resolve-location-target.test.js.map +1 -0
- package/dist/core/__tests__/uri.test.d.ts +2 -0
- package/dist/core/__tests__/uri.test.d.ts.map +1 -0
- package/dist/core/__tests__/uri.test.js +159 -0
- package/dist/core/__tests__/uri.test.js.map +1 -0
- package/dist/core/__tests__/worktree.test.d.ts +2 -0
- package/dist/core/__tests__/worktree.test.d.ts.map +1 -0
- package/dist/core/__tests__/worktree.test.js +120 -0
- package/dist/core/__tests__/worktree.test.js.map +1 -0
- package/dist/core/merge-driver.d.ts +5 -0
- package/dist/core/merge-driver.d.ts.map +1 -1
- package/dist/core/merge-driver.js +35 -0
- package/dist/core/merge-driver.js.map +1 -1
- package/dist/daemon/__tests__/flush.test.d.ts +5 -0
- package/dist/daemon/__tests__/flush.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/flush.test.js +213 -0
- package/dist/daemon/__tests__/flush.test.js.map +1 -0
- package/dist/daemon/__tests__/integration.test.d.ts +7 -0
- package/dist/daemon/__tests__/integration.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/integration.test.js +276 -0
- package/dist/daemon/__tests__/integration.test.js.map +1 -0
- package/dist/daemon/__tests__/ipc.test.d.ts +5 -0
- package/dist/daemon/__tests__/ipc.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/ipc.test.js +314 -0
- package/dist/daemon/__tests__/ipc.test.js.map +1 -0
- package/dist/daemon/__tests__/lifecycle.test.d.ts +5 -0
- package/dist/daemon/__tests__/lifecycle.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/lifecycle.test.js +301 -0
- package/dist/daemon/__tests__/lifecycle.test.js.map +1 -0
- package/dist/daemon/__tests__/lock.test.d.ts +5 -0
- package/dist/daemon/__tests__/lock.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/lock.test.js +192 -0
- package/dist/daemon/__tests__/lock.test.js.map +1 -0
- package/dist/daemon/__tests__/methods/graph.test.d.ts +5 -0
- package/dist/daemon/__tests__/methods/graph.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/methods/graph.test.js +309 -0
- package/dist/daemon/__tests__/methods/graph.test.js.map +1 -0
- package/dist/daemon/__tests__/methods/provider.test.d.ts +7 -0
- package/dist/daemon/__tests__/methods/provider.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/methods/provider.test.js +181 -0
- package/dist/daemon/__tests__/methods/provider.test.js.map +1 -0
- package/dist/daemon/__tests__/methods/tools.test.d.ts +5 -0
- package/dist/daemon/__tests__/methods/tools.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/methods/tools.test.js +587 -0
- package/dist/daemon/__tests__/methods/tools.test.js.map +1 -0
- package/dist/daemon/__tests__/multi-location.test.d.ts +8 -0
- package/dist/daemon/__tests__/multi-location.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/multi-location.test.js +669 -0
- package/dist/daemon/__tests__/multi-location.test.js.map +1 -0
- package/dist/daemon/__tests__/registry.test.d.ts +5 -0
- package/dist/daemon/__tests__/registry.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/registry.test.js +208 -0
- package/dist/daemon/__tests__/registry.test.js.map +1 -0
- package/dist/daemon/__tests__/watcher.test.d.ts +5 -0
- package/dist/daemon/__tests__/watcher.test.d.ts.map +1 -0
- package/dist/daemon/__tests__/watcher.test.js +234 -0
- package/dist/daemon/__tests__/watcher.test.js.map +1 -0
- package/dist/daemon/index.d.ts +6 -4
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +3 -2
- package/dist/daemon/index.js.map +1 -1
- package/dist/daemon/ipc.d.ts.map +1 -1
- package/dist/daemon/ipc.js +8 -1
- package/dist/daemon/ipc.js.map +1 -1
- package/dist/daemon/lifecycle.d.ts.map +1 -1
- package/dist/daemon/lifecycle.js +138 -25
- package/dist/daemon/lifecycle.js.map +1 -1
- package/dist/daemon/location-state.d.ts +12 -6
- package/dist/daemon/location-state.d.ts.map +1 -1
- package/dist/daemon/location-state.js +50 -20
- package/dist/daemon/location-state.js.map +1 -1
- package/dist/daemon/methods/__tests__/graph.test.d.ts +5 -0
- package/dist/daemon/methods/__tests__/graph.test.d.ts.map +1 -0
- package/dist/daemon/methods/__tests__/graph.test.js +274 -0
- package/dist/daemon/methods/__tests__/graph.test.js.map +1 -0
- package/dist/daemon/methods/__tests__/provider.test.d.ts +5 -0
- package/dist/daemon/methods/__tests__/provider.test.d.ts.map +1 -0
- package/dist/daemon/methods/__tests__/provider.test.js +184 -0
- package/dist/daemon/methods/__tests__/provider.test.js.map +1 -0
- package/dist/daemon/methods/__tests__/tools.test.d.ts +5 -0
- package/dist/daemon/methods/__tests__/tools.test.d.ts.map +1 -0
- package/dist/daemon/methods/__tests__/tools.test.js +295 -0
- package/dist/daemon/methods/__tests__/tools.test.js.map +1 -0
- package/dist/daemon/methods/context-files.d.ts +14 -0
- package/dist/daemon/methods/context-files.d.ts.map +1 -0
- package/dist/daemon/methods/context-files.js +95 -0
- package/dist/daemon/methods/context-files.js.map +1 -0
- package/dist/daemon/methods/provider.d.ts.map +1 -1
- package/dist/daemon/methods/provider.js +15 -0
- package/dist/daemon/methods/provider.js.map +1 -1
- package/dist/daemon/methods/tools.d.ts +1 -1
- package/dist/daemon/methods/tools.d.ts.map +1 -1
- package/dist/daemon/methods/tools.js +3 -2
- package/dist/daemon/methods/tools.js.map +1 -1
- package/dist/daemon/sessionlog-linker.d.ts +71 -0
- package/dist/daemon/sessionlog-linker.d.ts.map +1 -0
- package/dist/daemon/sessionlog-linker.js +472 -0
- package/dist/daemon/sessionlog-linker.js.map +1 -0
- package/dist/daemon/sessionlog-watcher.d.ts +79 -0
- package/dist/daemon/sessionlog-watcher.d.ts.map +1 -0
- package/dist/daemon/sessionlog-watcher.js +289 -0
- package/dist/daemon/sessionlog-watcher.js.map +1 -0
- package/dist/graph/__tests__/EdgeTypeRegistry.test.d.ts +2 -0
- package/dist/graph/__tests__/EdgeTypeRegistry.test.d.ts.map +1 -0
- package/dist/graph/__tests__/EdgeTypeRegistry.test.js +212 -0
- package/dist/graph/__tests__/EdgeTypeRegistry.test.js.map +1 -0
- package/dist/graph/__tests__/FederatedGraph.test.d.ts +2 -0
- package/dist/graph/__tests__/FederatedGraph.test.d.ts.map +1 -0
- package/dist/graph/__tests__/FederatedGraph.test.js +661 -0
- package/dist/graph/__tests__/FederatedGraph.test.js.map +1 -0
- package/dist/graph/__tests__/GraphologyAdapter.test.d.ts +2 -0
- package/dist/graph/__tests__/GraphologyAdapter.test.d.ts.map +1 -0
- package/dist/graph/__tests__/GraphologyAdapter.test.js +326 -0
- package/dist/graph/__tests__/GraphologyAdapter.test.js.map +1 -0
- package/dist/graph/__tests__/HydratingFederatedGraph.test.d.ts +2 -0
- package/dist/graph/__tests__/HydratingFederatedGraph.test.d.ts.map +1 -0
- package/dist/graph/__tests__/HydratingFederatedGraph.test.js +587 -0
- package/dist/graph/__tests__/HydratingFederatedGraph.test.js.map +1 -0
- package/dist/graph/__tests__/debounce.test.d.ts +5 -0
- package/dist/graph/__tests__/debounce.test.d.ts.map +1 -0
- package/dist/graph/__tests__/debounce.test.js +195 -0
- package/dist/graph/__tests__/debounce.test.js.map +1 -0
- package/dist/graph/__tests__/edge-cases.test.d.ts +8 -0
- package/dist/graph/__tests__/edge-cases.test.d.ts.map +1 -0
- package/dist/graph/__tests__/edge-cases.test.js +472 -0
- package/dist/graph/__tests__/edge-cases.test.js.map +1 -0
- package/dist/graph/__tests__/expansion.test.d.ts +2 -0
- package/dist/graph/__tests__/expansion.test.d.ts.map +1 -0
- package/dist/graph/__tests__/expansion.test.js +105 -0
- package/dist/graph/__tests__/expansion.test.js.map +1 -0
- package/dist/graph/__tests__/provider-store.test.d.ts +5 -0
- package/dist/graph/__tests__/provider-store.test.d.ts.map +1 -0
- package/dist/graph/__tests__/provider-store.test.js +791 -0
- package/dist/graph/__tests__/provider-store.test.js.map +1 -0
- package/dist/graph/__tests__/query.test.d.ts +5 -0
- package/dist/graph/__tests__/query.test.d.ts.map +1 -0
- package/dist/graph/__tests__/query.test.js +774 -0
- package/dist/graph/__tests__/query.test.js.map +1 -0
- package/dist/graph/__tests__/store.test.d.ts +5 -0
- package/dist/graph/__tests__/store.test.d.ts.map +1 -0
- package/dist/graph/__tests__/store.test.js +489 -0
- package/dist/graph/__tests__/store.test.js.map +1 -0
- package/dist/graph/__tests__/sync.test.d.ts +5 -0
- package/dist/graph/__tests__/sync.test.d.ts.map +1 -0
- package/dist/graph/__tests__/sync.test.js +129 -0
- package/dist/graph/__tests__/sync.test.js.map +1 -0
- package/dist/graph/__tests__/validation.test.d.ts +2 -0
- package/dist/graph/__tests__/validation.test.d.ts.map +1 -0
- package/dist/graph/__tests__/validation.test.js +521 -0
- package/dist/graph/__tests__/validation.test.js.map +1 -0
- package/dist/graph/index.d.ts +1 -1
- package/dist/graph/index.d.ts.map +1 -1
- package/dist/graph/index.js.map +1 -1
- package/dist/graph/provider-store.d.ts +78 -4
- package/dist/graph/provider-store.d.ts.map +1 -1
- package/dist/graph/provider-store.js +579 -55
- package/dist/graph/provider-store.js.map +1 -1
- package/dist/graph/store.d.ts.map +1 -1
- package/dist/graph/store.js +3 -0
- package/dist/graph/store.js.map +1 -1
- package/dist/graph/types.d.ts +16 -0
- package/dist/graph/types.d.ts.map +1 -1
- package/dist/graph/types.js.map +1 -1
- package/dist/index.d.ts +4 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9 -3
- package/dist/index.js.map +1 -1
- package/dist/materialization/git-archive-store.js +2 -2
- package/dist/materialization/git-archive-store.js.map +1 -1
- package/dist/materialization/git-remote-store.js +2 -2
- package/dist/materialization/git-remote-store.js.map +1 -1
- package/dist/materialization/snapshot.js +4 -4
- package/dist/materialization/snapshot.js.map +1 -1
- package/dist/mcp/index.d.ts +8 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +8 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/server.d.ts +39 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +677 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/stdio.d.ts +14 -0
- package/dist/mcp/stdio.d.ts.map +1 -0
- package/dist/mcp/stdio.js +19 -0
- package/dist/mcp/stdio.js.map +1 -0
- package/dist/providers/__tests__/beads.test.d.ts +5 -0
- package/dist/providers/__tests__/beads.test.d.ts.map +1 -0
- package/dist/providers/__tests__/beads.test.js +591 -0
- package/dist/providers/__tests__/beads.test.js.map +1 -0
- package/dist/providers/__tests__/claude-tasks.test.d.ts +5 -0
- package/dist/providers/__tests__/claude-tasks.test.d.ts.map +1 -0
- package/dist/providers/__tests__/claude-tasks.test.js +392 -0
- package/dist/providers/__tests__/claude-tasks.test.js.map +1 -0
- package/dist/providers/__tests__/from-config.test.d.ts +5 -0
- package/dist/providers/__tests__/from-config.test.d.ts.map +1 -0
- package/dist/providers/__tests__/from-config.test.js +152 -0
- package/dist/providers/__tests__/from-config.test.js.map +1 -0
- package/dist/providers/__tests__/materialization.test.d.ts +5 -0
- package/dist/providers/__tests__/materialization.test.d.ts.map +1 -0
- package/dist/providers/__tests__/materialization.test.js +407 -0
- package/dist/providers/__tests__/materialization.test.js.map +1 -0
- package/dist/providers/__tests__/native.test.d.ts +5 -0
- package/dist/providers/__tests__/native.test.d.ts.map +1 -0
- package/dist/providers/__tests__/native.test.js +566 -0
- package/dist/providers/__tests__/native.test.js.map +1 -0
- package/dist/providers/__tests__/registry.test.d.ts +5 -0
- package/dist/providers/__tests__/registry.test.d.ts.map +1 -0
- package/dist/providers/__tests__/registry.test.js +183 -0
- package/dist/providers/__tests__/registry.test.js.map +1 -0
- package/dist/providers/beads.d.ts.map +1 -1
- package/dist/providers/beads.js +17 -1
- package/dist/providers/beads.js.map +1 -1
- package/dist/providers/claude-tasks-fs.d.ts +22 -0
- package/dist/providers/claude-tasks-fs.d.ts.map +1 -0
- package/dist/providers/claude-tasks-fs.js +158 -0
- package/dist/providers/claude-tasks-fs.js.map +1 -0
- package/dist/providers/claude-tasks.d.ts +13 -4
- package/dist/providers/claude-tasks.d.ts.map +1 -1
- package/dist/providers/claude-tasks.js +318 -5
- package/dist/providers/claude-tasks.js.map +1 -1
- package/dist/providers/from-config.d.ts.map +1 -1
- package/dist/providers/from-config.js +35 -17
- package/dist/providers/from-config.js.map +1 -1
- package/dist/providers/global.d.ts.map +1 -1
- package/dist/providers/global.js +5 -0
- package/dist/providers/global.js.map +1 -1
- package/dist/providers/index.d.ts +6 -4
- package/dist/providers/index.d.ts.map +1 -1
- package/dist/providers/index.js +4 -3
- package/dist/providers/index.js.map +1 -1
- package/dist/providers/map.d.ts.map +1 -1
- package/dist/providers/map.js +5 -0
- package/dist/providers/map.js.map +1 -1
- package/dist/providers/materialization.d.ts +23 -5
- package/dist/providers/materialization.d.ts.map +1 -1
- package/dist/providers/materialization.js +95 -4
- package/dist/providers/materialization.js.map +1 -1
- package/dist/providers/native.d.ts.map +1 -1
- package/dist/providers/native.js +5 -0
- package/dist/providers/native.js.map +1 -1
- package/dist/providers/sessionlog.d.ts +81 -0
- package/dist/providers/sessionlog.d.ts.map +1 -0
- package/dist/providers/sessionlog.js +478 -0
- package/dist/providers/sessionlog.js.map +1 -0
- package/dist/providers/sudocode.d.ts.map +1 -1
- package/dist/providers/sudocode.js +17 -1
- package/dist/providers/sudocode.js.map +1 -1
- package/dist/providers/traits/Reconcilable.d.ts +57 -0
- package/dist/providers/traits/Reconcilable.d.ts.map +1 -0
- package/dist/providers/traits/Reconcilable.js +18 -0
- package/dist/providers/traits/Reconcilable.js.map +1 -0
- package/dist/providers/traits/__tests__/RelationshipQueryable.test.d.ts +2 -0
- package/dist/providers/traits/__tests__/RelationshipQueryable.test.d.ts.map +1 -0
- package/dist/providers/traits/__tests__/RelationshipQueryable.test.js +169 -0
- package/dist/providers/traits/__tests__/RelationshipQueryable.test.js.map +1 -0
- package/dist/providers/traits/__tests__/TaskManageable.test.d.ts +2 -0
- package/dist/providers/traits/__tests__/TaskManageable.test.d.ts.map +1 -0
- package/dist/providers/traits/__tests__/TaskManageable.test.js +172 -0
- package/dist/providers/traits/__tests__/TaskManageable.test.js.map +1 -0
- package/dist/providers/traits/index.d.ts +2 -0
- package/dist/providers/traits/index.d.ts.map +1 -1
- package/dist/providers/traits/index.js +1 -0
- package/dist/providers/traits/index.js.map +1 -1
- package/dist/providers/types.d.ts +63 -0
- package/dist/providers/types.d.ts.map +1 -1
- package/dist/providers/types.js +22 -0
- package/dist/providers/types.js.map +1 -1
- package/dist/schema/__tests__/validation.test.d.ts +2 -0
- package/dist/schema/__tests__/validation.test.d.ts.map +1 -0
- package/dist/schema/__tests__/validation.test.js +241 -0
- package/dist/schema/__tests__/validation.test.js.map +1 -0
- package/dist/schema/edges.d.ts +3 -3
- package/dist/schema/edges.d.ts.map +1 -1
- package/dist/sessionlog/agent/agents/claude-code.d.ts +76 -0
- package/dist/sessionlog/agent/agents/claude-code.d.ts.map +1 -0
- package/dist/sessionlog/agent/agents/claude-code.js +759 -0
- package/dist/sessionlog/agent/agents/claude-code.js.map +1 -0
- package/dist/sessionlog/agent/agents/cursor.d.ts +35 -0
- package/dist/sessionlog/agent/agents/cursor.d.ts.map +1 -0
- package/dist/sessionlog/agent/agents/cursor.js +294 -0
- package/dist/sessionlog/agent/agents/cursor.js.map +1 -0
- package/dist/sessionlog/agent/agents/gemini-cli.d.ts +62 -0
- package/dist/sessionlog/agent/agents/gemini-cli.d.ts.map +1 -0
- package/dist/sessionlog/agent/agents/gemini-cli.js +462 -0
- package/dist/sessionlog/agent/agents/gemini-cli.js.map +1 -0
- package/dist/sessionlog/agent/agents/opencode.d.ts +100 -0
- package/dist/sessionlog/agent/agents/opencode.d.ts.map +1 -0
- package/dist/sessionlog/agent/agents/opencode.js +423 -0
- package/dist/sessionlog/agent/agents/opencode.js.map +1 -0
- package/dist/sessionlog/agent/registry.d.ts +54 -0
- package/dist/sessionlog/agent/registry.d.ts.map +1 -0
- package/dist/sessionlog/agent/registry.js +123 -0
- package/dist/sessionlog/agent/registry.js.map +1 -0
- package/dist/sessionlog/agent/session-types.d.ts +45 -0
- package/dist/sessionlog/agent/session-types.d.ts.map +1 -0
- package/dist/sessionlog/agent/session-types.js +50 -0
- package/dist/sessionlog/agent/session-types.js.map +1 -0
- package/dist/sessionlog/agent/types.d.ts +126 -0
- package/dist/sessionlog/agent/types.d.ts.map +1 -0
- package/dist/sessionlog/agent/types.js +39 -0
- package/dist/sessionlog/agent/types.js.map +1 -0
- package/dist/sessionlog/commands/clean.d.ts +40 -0
- package/dist/sessionlog/commands/clean.d.ts.map +1 -0
- package/dist/sessionlog/commands/clean.js +105 -0
- package/dist/sessionlog/commands/clean.js.map +1 -0
- package/dist/sessionlog/commands/disable.d.ts +23 -0
- package/dist/sessionlog/commands/disable.d.ts.map +1 -0
- package/dist/sessionlog/commands/disable.js +57 -0
- package/dist/sessionlog/commands/disable.js.map +1 -0
- package/dist/sessionlog/commands/doctor.d.ts +43 -0
- package/dist/sessionlog/commands/doctor.d.ts.map +1 -0
- package/dist/sessionlog/commands/doctor.js +97 -0
- package/dist/sessionlog/commands/doctor.js.map +1 -0
- package/dist/sessionlog/commands/enable.d.ts +31 -0
- package/dist/sessionlog/commands/enable.d.ts.map +1 -0
- package/dist/sessionlog/commands/enable.js +102 -0
- package/dist/sessionlog/commands/enable.js.map +1 -0
- package/dist/sessionlog/commands/explain.d.ts +69 -0
- package/dist/sessionlog/commands/explain.d.ts.map +1 -0
- package/dist/sessionlog/commands/explain.js +185 -0
- package/dist/sessionlog/commands/explain.js.map +1 -0
- package/dist/sessionlog/commands/reset.d.ts +23 -0
- package/dist/sessionlog/commands/reset.d.ts.map +1 -0
- package/dist/sessionlog/commands/reset.js +68 -0
- package/dist/sessionlog/commands/reset.js.map +1 -0
- package/dist/sessionlog/commands/resume.d.ts +42 -0
- package/dist/sessionlog/commands/resume.d.ts.map +1 -0
- package/dist/sessionlog/commands/resume.js +134 -0
- package/dist/sessionlog/commands/resume.js.map +1 -0
- package/dist/sessionlog/commands/rewind.d.ts +40 -0
- package/dist/sessionlog/commands/rewind.d.ts.map +1 -0
- package/dist/sessionlog/commands/rewind.js +155 -0
- package/dist/sessionlog/commands/rewind.js.map +1 -0
- package/dist/sessionlog/commands/status.d.ts +54 -0
- package/dist/sessionlog/commands/status.d.ts.map +1 -0
- package/dist/sessionlog/commands/status.js +95 -0
- package/dist/sessionlog/commands/status.js.map +1 -0
- package/dist/sessionlog/config.d.ts +40 -0
- package/dist/sessionlog/config.d.ts.map +1 -0
- package/dist/sessionlog/config.js +126 -0
- package/dist/sessionlog/config.js.map +1 -0
- package/dist/sessionlog/git-operations.d.ts +173 -0
- package/dist/sessionlog/git-operations.d.ts.map +1 -0
- package/dist/sessionlog/git-operations.js +399 -0
- package/dist/sessionlog/git-operations.js.map +1 -0
- package/dist/sessionlog/hooks/git-hooks.d.ts +22 -0
- package/dist/sessionlog/hooks/git-hooks.d.ts.map +1 -0
- package/dist/sessionlog/hooks/git-hooks.js +145 -0
- package/dist/sessionlog/hooks/git-hooks.js.map +1 -0
- package/dist/sessionlog/hooks/lifecycle.d.ts +21 -0
- package/dist/sessionlog/hooks/lifecycle.d.ts.map +1 -0
- package/dist/sessionlog/hooks/lifecycle.js +179 -0
- package/dist/sessionlog/hooks/lifecycle.js.map +1 -0
- package/dist/sessionlog/index.d.ts +69 -0
- package/dist/sessionlog/index.d.ts.map +1 -0
- package/dist/sessionlog/index.js +154 -0
- package/dist/sessionlog/index.js.map +1 -0
- package/dist/sessionlog/security/redaction.d.ts +35 -0
- package/dist/sessionlog/security/redaction.d.ts.map +1 -0
- package/dist/sessionlog/security/redaction.js +221 -0
- package/dist/sessionlog/security/redaction.js.map +1 -0
- package/dist/sessionlog/session/state-machine.d.ts +90 -0
- package/dist/sessionlog/session/state-machine.d.ts.map +1 -0
- package/dist/sessionlog/session/state-machine.js +347 -0
- package/dist/sessionlog/session/state-machine.js.map +1 -0
- package/dist/sessionlog/store/checkpoint-store.d.ts +47 -0
- package/dist/sessionlog/store/checkpoint-store.d.ts.map +1 -0
- package/dist/sessionlog/store/checkpoint-store.js +309 -0
- package/dist/sessionlog/store/checkpoint-store.js.map +1 -0
- package/dist/sessionlog/store/native-store.d.ts +21 -0
- package/dist/sessionlog/store/native-store.d.ts.map +1 -0
- package/dist/sessionlog/store/native-store.js +162 -0
- package/dist/sessionlog/store/native-store.js.map +1 -0
- package/dist/sessionlog/store/provider-types.d.ts +78 -0
- package/dist/sessionlog/store/provider-types.d.ts.map +1 -0
- package/dist/sessionlog/store/provider-types.js +12 -0
- package/dist/sessionlog/store/provider-types.js.map +1 -0
- package/dist/sessionlog/store/session-store.d.ts +28 -0
- package/dist/sessionlog/store/session-store.d.ts.map +1 -0
- package/dist/sessionlog/store/session-store.js +187 -0
- package/dist/sessionlog/store/session-store.js.map +1 -0
- package/dist/sessionlog/strategy/attribution.d.ts +39 -0
- package/dist/sessionlog/strategy/attribution.d.ts.map +1 -0
- package/dist/sessionlog/strategy/attribution.js +227 -0
- package/dist/sessionlog/strategy/attribution.js.map +1 -0
- package/dist/sessionlog/strategy/common.d.ts +60 -0
- package/dist/sessionlog/strategy/common.d.ts.map +1 -0
- package/dist/sessionlog/strategy/common.js +162 -0
- package/dist/sessionlog/strategy/common.js.map +1 -0
- package/dist/sessionlog/strategy/content-overlap.d.ts +33 -0
- package/dist/sessionlog/strategy/content-overlap.d.ts.map +1 -0
- package/dist/sessionlog/strategy/content-overlap.js +168 -0
- package/dist/sessionlog/strategy/content-overlap.js.map +1 -0
- package/dist/sessionlog/strategy/manual-commit.d.ts +35 -0
- package/dist/sessionlog/strategy/manual-commit.d.ts.map +1 -0
- package/dist/sessionlog/strategy/manual-commit.js +732 -0
- package/dist/sessionlog/strategy/manual-commit.js.map +1 -0
- package/dist/sessionlog/strategy/types.d.ts +163 -0
- package/dist/sessionlog/strategy/types.d.ts.map +1 -0
- package/dist/sessionlog/strategy/types.js +49 -0
- package/dist/sessionlog/strategy/types.js.map +1 -0
- package/dist/sessionlog/summarize/claude-generator.d.ts +25 -0
- package/dist/sessionlog/summarize/claude-generator.d.ts.map +1 -0
- package/dist/sessionlog/summarize/claude-generator.js +87 -0
- package/dist/sessionlog/summarize/claude-generator.js.map +1 -0
- package/dist/sessionlog/summarize/summarize.d.ts +52 -0
- package/dist/sessionlog/summarize/summarize.d.ts.map +1 -0
- package/dist/sessionlog/summarize/summarize.js +335 -0
- package/dist/sessionlog/summarize/summarize.js.map +1 -0
- package/dist/sessionlog/types.d.ts +298 -0
- package/dist/sessionlog/types.d.ts.map +1 -0
- package/dist/sessionlog/types.js +104 -0
- package/dist/sessionlog/types.js.map +1 -0
- package/dist/sessionlog/utils/chunk-files.d.ts +25 -0
- package/dist/sessionlog/utils/chunk-files.d.ts.map +1 -0
- package/dist/sessionlog/utils/chunk-files.js +47 -0
- package/dist/sessionlog/utils/chunk-files.js.map +1 -0
- package/dist/sessionlog/utils/commit-message.d.ts +11 -0
- package/dist/sessionlog/utils/commit-message.d.ts.map +1 -0
- package/dist/sessionlog/utils/commit-message.js +54 -0
- package/dist/sessionlog/utils/commit-message.js.map +1 -0
- package/dist/sessionlog/utils/detect-agent.d.ts +19 -0
- package/dist/sessionlog/utils/detect-agent.d.ts.map +1 -0
- package/dist/sessionlog/utils/detect-agent.js +34 -0
- package/dist/sessionlog/utils/detect-agent.js.map +1 -0
- package/dist/sessionlog/utils/hook-managers.d.ts +24 -0
- package/dist/sessionlog/utils/hook-managers.d.ts.map +1 -0
- package/dist/sessionlog/utils/hook-managers.js +87 -0
- package/dist/sessionlog/utils/hook-managers.js.map +1 -0
- package/dist/sessionlog/utils/ide-tags.d.ts +12 -0
- package/dist/sessionlog/utils/ide-tags.d.ts.map +1 -0
- package/dist/sessionlog/utils/ide-tags.js +30 -0
- package/dist/sessionlog/utils/ide-tags.js.map +1 -0
- package/dist/sessionlog/utils/paths.d.ts +32 -0
- package/dist/sessionlog/utils/paths.d.ts.map +1 -0
- package/dist/sessionlog/utils/paths.js +55 -0
- package/dist/sessionlog/utils/paths.js.map +1 -0
- package/dist/sessionlog/utils/preview-rewind.d.ts +23 -0
- package/dist/sessionlog/utils/preview-rewind.d.ts.map +1 -0
- package/dist/sessionlog/utils/preview-rewind.js +63 -0
- package/dist/sessionlog/utils/preview-rewind.js.map +1 -0
- package/dist/sessionlog/utils/rewind-conflict.d.ts +52 -0
- package/dist/sessionlog/utils/rewind-conflict.d.ts.map +1 -0
- package/dist/sessionlog/utils/rewind-conflict.js +79 -0
- package/dist/sessionlog/utils/rewind-conflict.js.map +1 -0
- package/dist/sessionlog/utils/shadow-branch.d.ts +53 -0
- package/dist/sessionlog/utils/shadow-branch.d.ts.map +1 -0
- package/dist/sessionlog/utils/shadow-branch.js +97 -0
- package/dist/sessionlog/utils/shadow-branch.js.map +1 -0
- package/dist/sessionlog/utils/string-utils.d.ts +24 -0
- package/dist/sessionlog/utils/string-utils.d.ts.map +1 -0
- package/dist/sessionlog/utils/string-utils.js +47 -0
- package/dist/sessionlog/utils/string-utils.js.map +1 -0
- package/dist/sessionlog/utils/todo-extract.d.ts +52 -0
- package/dist/sessionlog/utils/todo-extract.d.ts.map +1 -0
- package/dist/sessionlog/utils/todo-extract.js +167 -0
- package/dist/sessionlog/utils/todo-extract.js.map +1 -0
- package/dist/sessionlog/utils/trailers.d.ts +36 -0
- package/dist/sessionlog/utils/trailers.d.ts.map +1 -0
- package/dist/sessionlog/utils/trailers.js +149 -0
- package/dist/sessionlog/utils/trailers.js.map +1 -0
- package/dist/sessionlog/utils/transcript-parse.d.ts +57 -0
- package/dist/sessionlog/utils/transcript-parse.d.ts.map +1 -0
- package/dist/sessionlog/utils/transcript-parse.js +126 -0
- package/dist/sessionlog/utils/transcript-parse.js.map +1 -0
- package/dist/sessionlog/utils/transcript-timestamp.d.ts +22 -0
- package/dist/sessionlog/utils/transcript-timestamp.d.ts.map +1 -0
- package/dist/sessionlog/utils/transcript-timestamp.js +56 -0
- package/dist/sessionlog/utils/transcript-timestamp.js.map +1 -0
- package/dist/sessionlog/utils/tree-ops.d.ts +47 -0
- package/dist/sessionlog/utils/tree-ops.d.ts.map +1 -0
- package/dist/sessionlog/utils/tree-ops.js +145 -0
- package/dist/sessionlog/utils/tree-ops.js.map +1 -0
- package/dist/sessionlog/utils/tty.d.ts +25 -0
- package/dist/sessionlog/utils/tty.d.ts.map +1 -0
- package/dist/sessionlog/utils/tty.js +70 -0
- package/dist/sessionlog/utils/tty.js.map +1 -0
- package/dist/sessionlog/utils/validation.d.ts +31 -0
- package/dist/sessionlog/utils/validation.d.ts.map +1 -0
- package/dist/sessionlog/utils/validation.js +59 -0
- package/dist/sessionlog/utils/validation.js.map +1 -0
- package/dist/sessionlog/utils/worktree.d.ts +16 -0
- package/dist/sessionlog/utils/worktree.d.ts.map +1 -0
- package/dist/sessionlog/utils/worktree.js +50 -0
- package/dist/sessionlog/utils/worktree.js.map +1 -0
- package/dist/storage/__tests__/atomic-write.test.d.ts +5 -0
- package/dist/storage/__tests__/atomic-write.test.d.ts.map +1 -0
- package/dist/storage/__tests__/atomic-write.test.js +170 -0
- package/dist/storage/__tests__/atomic-write.test.js.map +1 -0
- package/dist/storage/__tests__/file-lock.test.d.ts +2 -0
- package/dist/storage/__tests__/file-lock.test.d.ts.map +1 -0
- package/dist/storage/__tests__/file-lock.test.js +89 -0
- package/dist/storage/__tests__/file-lock.test.js.map +1 -0
- package/dist/storage/__tests__/jsonl.test.d.ts +2 -0
- package/dist/storage/__tests__/jsonl.test.d.ts.map +1 -0
- package/dist/storage/__tests__/jsonl.test.js +228 -0
- package/dist/storage/__tests__/jsonl.test.js.map +1 -0
- package/dist/storage/__tests__/locked-writer.test.d.ts +2 -0
- package/dist/storage/__tests__/locked-writer.test.d.ts.map +1 -0
- package/dist/storage/__tests__/locked-writer.test.js +109 -0
- package/dist/storage/__tests__/locked-writer.test.js.map +1 -0
- package/dist/storage/__tests__/sqlite.test.d.ts +2 -0
- package/dist/storage/__tests__/sqlite.test.d.ts.map +1 -0
- package/dist/storage/__tests__/sqlite.test.js +470 -0
- package/dist/storage/__tests__/sqlite.test.js.map +1 -0
- package/dist/storage/sqlite-schema.d.ts.map +1 -1
- package/dist/storage/sqlite-schema.js +2 -0
- package/dist/storage/sqlite-schema.js.map +1 -1
- package/dist/storage/sqlite.d.ts.map +1 -1
- package/dist/storage/sqlite.js +18 -4
- package/dist/storage/sqlite.js.map +1 -1
- package/dist/tools/__tests__/annotate.test.d.ts +5 -0
- package/dist/tools/__tests__/annotate.test.d.ts.map +1 -0
- package/dist/tools/__tests__/annotate.test.js +314 -0
- package/dist/tools/__tests__/annotate.test.js.map +1 -0
- package/dist/tools/__tests__/link.test.d.ts +5 -0
- package/dist/tools/__tests__/link.test.d.ts.map +1 -0
- package/dist/tools/__tests__/link.test.js +245 -0
- package/dist/tools/__tests__/link.test.js.map +1 -0
- package/dist/tools/__tests__/query.test.d.ts +5 -0
- package/dist/tools/__tests__/query.test.d.ts.map +1 -0
- package/dist/tools/__tests__/query.test.js +288 -0
- package/dist/tools/__tests__/query.test.js.map +1 -0
- package/dist/tools/__tests__/task.test.d.ts +5 -0
- package/dist/tools/__tests__/task.test.d.ts.map +1 -0
- package/dist/tools/__tests__/task.test.js +178 -0
- package/dist/tools/__tests__/task.test.js.map +1 -0
- package/dist/tools/index.d.ts +1 -1
- package/dist/tools/index.d.ts.map +1 -1
- package/dist/tools/index.js.map +1 -1
- package/dist/tools/query.d.ts +2 -1
- package/dist/tools/query.d.ts.map +1 -1
- package/dist/tools/query.js +217 -7
- package/dist/tools/query.js.map +1 -1
- package/dist/tools/types.d.ts +57 -0
- package/dist/tools/types.d.ts.map +1 -1
- package/dist/tools/types.js.map +1 -1
- package/dist/tracking/claude-task-reconstructor.d.ts +41 -0
- package/dist/tracking/claude-task-reconstructor.d.ts.map +1 -0
- package/dist/tracking/claude-task-reconstructor.js +91 -0
- package/dist/tracking/claude-task-reconstructor.js.map +1 -0
- package/dist/tracking/plan-mode-tracker.d.ts +20 -0
- package/dist/tracking/plan-mode-tracker.d.ts.map +1 -0
- package/dist/tracking/plan-mode-tracker.js +35 -0
- package/dist/tracking/plan-mode-tracker.js.map +1 -0
- package/dist/tracking/transcript-extractor.d.ts +3 -3
- package/dist/tracking/transcript-extractor.d.ts.map +1 -1
- package/dist/tracking/transcript-extractor.js +1 -1
- package/dist/tracking/transcript-extractor.js.map +1 -1
- package/package.json +3 -1
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Context Files — Types
|
|
3
|
+
*
|
|
4
|
+
* Metadata schema for context nodes that reference files in the codebase.
|
|
5
|
+
* A context-file node stores a lightweight pointer to a repo file plus
|
|
6
|
+
* versioning info (commit SHA, content hash). The actual file content is
|
|
7
|
+
* resolved on access rather than duplicated into the graph store.
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* Metadata fields added to a context node that references a codebase file.
|
|
11
|
+
*
|
|
12
|
+
* These live inside `node.metadata` alongside any other metadata.
|
|
13
|
+
*/
|
|
14
|
+
export interface ContextFileMetadata {
|
|
15
|
+
/** Marker — distinguishes context-file nodes from plain context nodes */
|
|
16
|
+
context_file: true;
|
|
17
|
+
/** Repo-relative path to the file (e.g. "src/auth/middleware.ts", "docs/arch.md") */
|
|
18
|
+
context_file_path: string;
|
|
19
|
+
/**
|
|
20
|
+
* File type hint.
|
|
21
|
+
* - "markdown" for .md files
|
|
22
|
+
* - "code" for source files
|
|
23
|
+
* - "text" for other text files
|
|
24
|
+
*/
|
|
25
|
+
context_file_type: ContextFileType;
|
|
26
|
+
/** Git commit SHA when the file was last synced/captured */
|
|
27
|
+
context_file_commit?: string;
|
|
28
|
+
/** SHA-256 hash of the file content at the synced commit */
|
|
29
|
+
context_file_content_hash?: string;
|
|
30
|
+
/** ISO 8601 timestamp of last sync from file */
|
|
31
|
+
context_file_synced_at?: string;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* File type classification
|
|
35
|
+
*/
|
|
36
|
+
export type ContextFileType = 'markdown' | 'code' | 'text';
|
|
37
|
+
/**
|
|
38
|
+
* Result of resolving a context file's content.
|
|
39
|
+
*/
|
|
40
|
+
export interface ContextFileResolution {
|
|
41
|
+
/** The resolved file content */
|
|
42
|
+
content: string;
|
|
43
|
+
/** Commit SHA the content was read from (HEAD if worktree) */
|
|
44
|
+
commit: string;
|
|
45
|
+
/** SHA-256 of the resolved content */
|
|
46
|
+
contentHash: string;
|
|
47
|
+
/** Whether content differs from what was captured (hash mismatch) */
|
|
48
|
+
drifted: boolean;
|
|
49
|
+
/** Repo-relative file path */
|
|
50
|
+
filePath: string;
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Drift detection result for a context-file node.
|
|
54
|
+
*/
|
|
55
|
+
export interface DriftResult {
|
|
56
|
+
/** Whether the file has changed since the node was synced */
|
|
57
|
+
drifted: boolean;
|
|
58
|
+
/** Current commit SHA (HEAD) */
|
|
59
|
+
currentCommit: string;
|
|
60
|
+
/** Commit SHA stored in the node */
|
|
61
|
+
capturedCommit?: string;
|
|
62
|
+
/** Current content hash */
|
|
63
|
+
currentHash: string;
|
|
64
|
+
/** Content hash stored in the node */
|
|
65
|
+
capturedHash?: string;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Input for creating a context-file node.
|
|
69
|
+
*/
|
|
70
|
+
export interface CreateContextFileInput {
|
|
71
|
+
/** Repo-relative file path */
|
|
72
|
+
filePath: string;
|
|
73
|
+
/**
|
|
74
|
+
* Optional title. If omitted, derived from the file path
|
|
75
|
+
* (e.g. "src/auth/middleware.ts" → "auth/middleware.ts")
|
|
76
|
+
*/
|
|
77
|
+
title?: string;
|
|
78
|
+
/** Optional tags */
|
|
79
|
+
tags?: string[];
|
|
80
|
+
/** Optional priority */
|
|
81
|
+
priority?: number;
|
|
82
|
+
/**
|
|
83
|
+
* Pin to a specific commit SHA. If omitted, uses current HEAD.
|
|
84
|
+
*/
|
|
85
|
+
commit?: string;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Options for syncing a context-file node with the current file state.
|
|
89
|
+
*/
|
|
90
|
+
export interface SyncContextFileOptions {
|
|
91
|
+
/** Force sync even if content hash hasn't changed */
|
|
92
|
+
force?: boolean;
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/context-files/types.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH;;;;GAIG;AACH,MAAM,WAAW,mBAAmB;IAClC,yEAAyE;IACzE,YAAY,EAAE,IAAI,CAAC;IAEnB,qFAAqF;IACrF,iBAAiB,EAAE,MAAM,CAAC;IAE1B;;;;;OAKG;IACH,iBAAiB,EAAE,eAAe,CAAC;IAEnC,4DAA4D;IAC5D,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAE7B,4DAA4D;IAC5D,yBAAyB,CAAC,EAAE,MAAM,CAAC;IAEnC,gDAAgD;IAChD,sBAAsB,CAAC,EAAE,MAAM,CAAC;CACjC;AAED;;GAEG;AACH,MAAM,MAAM,eAAe,GAAG,UAAU,GAAG,MAAM,GAAG,MAAM,CAAC;AAM3D;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,gCAAgC;IAChC,OAAO,EAAE,MAAM,CAAC;IAEhB,8DAA8D;IAC9D,MAAM,EAAE,MAAM,CAAC;IAEf,sCAAsC;IACtC,WAAW,EAAE,MAAM,CAAC;IAEpB,qEAAqE;IACrE,OAAO,EAAE,OAAO,CAAC;IAEjB,8BAA8B;IAC9B,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,6DAA6D;IAC7D,OAAO,EAAE,OAAO,CAAC;IAEjB,gCAAgC;IAChC,aAAa,EAAE,MAAM,CAAC;IAEtB,oCAAoC;IACpC,cAAc,CAAC,EAAE,MAAM,CAAC;IAExB,2BAA2B;IAC3B,WAAW,EAAE,MAAM,CAAC;IAEpB,sCAAsC;IACtC,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAMD;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACrC,8BAA8B;IAC9B,QAAQ,EAAE,MAAM,CAAC;IAEjB;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf,oBAAoB;IACpB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAEhB,wBAAwB;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACrC,qDAAqD;IACrD,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Context Files — Types
|
|
3
|
+
*
|
|
4
|
+
* Metadata schema for context nodes that reference files in the codebase.
|
|
5
|
+
* A context-file node stores a lightweight pointer to a repo file plus
|
|
6
|
+
* versioning info (commit SHA, content hash). The actual file content is
|
|
7
|
+
* resolved on access rather than duplicated into the graph store.
|
|
8
|
+
*/
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/context-files/types.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Context Files — Watcher Integration
|
|
3
|
+
*
|
|
4
|
+
* Bridges the daemon file watcher with context-file nodes.
|
|
5
|
+
* When a watched file changes, marks the corresponding context-file node
|
|
6
|
+
* as potentially drifted so callers can decide whether to re-sync.
|
|
7
|
+
*/
|
|
8
|
+
import type { FileChangeEvent, ChangeHandler } from '../daemon/watcher.js';
|
|
9
|
+
import type { GraphStore } from '../graph/store.js';
|
|
10
|
+
import type { Node } from '../schema/index.js';
|
|
11
|
+
/**
|
|
12
|
+
* Options for the context-file watcher handler.
|
|
13
|
+
*/
|
|
14
|
+
export interface ContextFileWatcherOptions {
|
|
15
|
+
/** The graph store to query for context-file nodes */
|
|
16
|
+
store: GraphStore;
|
|
17
|
+
/**
|
|
18
|
+
* Root of the repository (to compute repo-relative paths).
|
|
19
|
+
* The watcher emits absolute paths; we compare against
|
|
20
|
+
* `context_file_path` which is repo-relative.
|
|
21
|
+
*/
|
|
22
|
+
repoRoot: string;
|
|
23
|
+
/**
|
|
24
|
+
* Callback invoked when a context-file node's source file changes.
|
|
25
|
+
* Receives the node and the change event.
|
|
26
|
+
*/
|
|
27
|
+
onDrift?: (node: Node, event: FileChangeEvent) => void;
|
|
28
|
+
/**
|
|
29
|
+
* Auto-sync context-file nodes when their source file changes.
|
|
30
|
+
* Default: false (only fires onDrift callback).
|
|
31
|
+
*/
|
|
32
|
+
autoSync?: boolean;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Create a ChangeHandler that reacts to context-file source changes.
|
|
36
|
+
*
|
|
37
|
+
* Wire this into the daemon file watcher:
|
|
38
|
+
* ```ts
|
|
39
|
+
* const handler = createContextFileChangeHandler({ store, repoRoot });
|
|
40
|
+
* fileWatcher.onchange(handler);
|
|
41
|
+
* ```
|
|
42
|
+
*
|
|
43
|
+
* The handler scans context-file nodes for any whose `context_file_path`
|
|
44
|
+
* matches the changed file, then fires the onDrift callback.
|
|
45
|
+
*/
|
|
46
|
+
export declare function createContextFileChangeHandler(options: ContextFileWatcherOptions): ChangeHandler;
|
|
47
|
+
//# sourceMappingURL=watcher-integration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watcher-integration.d.ts","sourceRoot":"","sources":["../../src/context-files/watcher-integration.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC3E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AAI/C;;GAEG;AACH,MAAM,WAAW,yBAAyB;IACxC,sDAAsD;IACtD,KAAK,EAAE,UAAU,CAAC;IAElB;;;;OAIG;IACH,QAAQ,EAAE,MAAM,CAAC;IAEjB;;;OAGG;IACH,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,eAAe,KAAK,IAAI,CAAC;IAEvD;;;OAGG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,8BAA8B,CAC5C,OAAO,EAAE,yBAAyB,GACjC,aAAa,CA0Bf"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Context Files — Watcher Integration
|
|
3
|
+
*
|
|
4
|
+
* Bridges the daemon file watcher with context-file nodes.
|
|
5
|
+
* When a watched file changes, marks the corresponding context-file node
|
|
6
|
+
* as potentially drifted so callers can decide whether to re-sync.
|
|
7
|
+
*/
|
|
8
|
+
import { isContextFileNode, getContextFileMetadata } from './context-files.js';
|
|
9
|
+
import * as path from 'node:path';
|
|
10
|
+
/**
|
|
11
|
+
* Create a ChangeHandler that reacts to context-file source changes.
|
|
12
|
+
*
|
|
13
|
+
* Wire this into the daemon file watcher:
|
|
14
|
+
* ```ts
|
|
15
|
+
* const handler = createContextFileChangeHandler({ store, repoRoot });
|
|
16
|
+
* fileWatcher.onchange(handler);
|
|
17
|
+
* ```
|
|
18
|
+
*
|
|
19
|
+
* The handler scans context-file nodes for any whose `context_file_path`
|
|
20
|
+
* matches the changed file, then fires the onDrift callback.
|
|
21
|
+
*/
|
|
22
|
+
export function createContextFileChangeHandler(options) {
|
|
23
|
+
const { store, repoRoot, onDrift } = options;
|
|
24
|
+
return async (event) => {
|
|
25
|
+
// Only react to file additions and changes (not unlinks for now)
|
|
26
|
+
if (event.type === 'unlink')
|
|
27
|
+
return;
|
|
28
|
+
// Compute repo-relative path from the absolute watcher path
|
|
29
|
+
const repoRelative = path.relative(repoRoot, event.path);
|
|
30
|
+
// Find context-file nodes that reference this file
|
|
31
|
+
const contextNodes = await store.query.nodes({ type: 'context' });
|
|
32
|
+
for (const node of contextNodes) {
|
|
33
|
+
if (!isContextFileNode(node))
|
|
34
|
+
continue;
|
|
35
|
+
const meta = getContextFileMetadata(node);
|
|
36
|
+
if (!meta)
|
|
37
|
+
continue;
|
|
38
|
+
// Normalize for comparison (forward slashes)
|
|
39
|
+
const metaPath = meta.context_file_path.split(path.sep).join('/');
|
|
40
|
+
const eventPath = repoRelative.split(path.sep).join('/');
|
|
41
|
+
if (metaPath === eventPath) {
|
|
42
|
+
onDrift?.(node, event);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=watcher-integration.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watcher-integration.js","sourceRoot":"","sources":["../../src/context-files/watcher-integration.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAKH,OAAO,EAAE,iBAAiB,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAC/E,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AA6BlC;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,8BAA8B,CAC5C,OAAkC;IAElC,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAE7C,OAAO,KAAK,EAAE,KAAsB,EAAE,EAAE;QACtC,iEAAiE;QACjE,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ;YAAE,OAAO;QAEpC,4DAA4D;QAC5D,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAEzD,mDAAmD;QACnD,MAAM,YAAY,GAAG,MAAM,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;QAClE,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE,CAAC;YAChC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;gBAAE,SAAS;YACvC,MAAM,IAAI,GAAG,sBAAsB,CAAC,IAAI,CAAC,CAAC;YAC1C,IAAI,CAAC,IAAI;gBAAE,SAAS;YAEpB,6CAA6C;YAC7C,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAClE,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAEzD,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;gBAC3B,OAAO,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conditional-redirects.test.d.ts","sourceRoot":"","sources":["../../../src/core/__tests__/conditional-redirects.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { evaluateConditions, findConditionalRedirectRule, } from '../conditional-redirects.js';
|
|
3
|
+
describe('evaluateConditions', () => {
|
|
4
|
+
it('returns true for no conditions', () => {
|
|
5
|
+
expect(evaluateConditions(undefined, { role: 'worker' })).toBe(true);
|
|
6
|
+
});
|
|
7
|
+
it('returns true for empty conditions', () => {
|
|
8
|
+
expect(evaluateConditions({}, { role: 'worker' })).toBe(true);
|
|
9
|
+
});
|
|
10
|
+
it('matches role condition', () => {
|
|
11
|
+
expect(evaluateConditions({ role: 'worker' }, { role: 'worker' })).toBe(true);
|
|
12
|
+
expect(evaluateConditions({ role: 'worker' }, { role: 'manager' })).toBe(false);
|
|
13
|
+
});
|
|
14
|
+
it('matches branch condition', () => {
|
|
15
|
+
expect(evaluateConditions({ branch: 'feature-*' }, { role: 'worker', branch: 'feature-auth' })).toBe(true);
|
|
16
|
+
expect(evaluateConditions({ branch: 'feature-*' }, { role: 'worker', branch: 'main' })).toBe(false);
|
|
17
|
+
});
|
|
18
|
+
it('matches exact branch', () => {
|
|
19
|
+
expect(evaluateConditions({ branch: 'main' }, { role: 'worker', branch: 'main' })).toBe(true);
|
|
20
|
+
expect(evaluateConditions({ branch: 'main' }, { role: 'worker', branch: 'develop' })).toBe(false);
|
|
21
|
+
});
|
|
22
|
+
it('returns false when branch condition set but no branch in context', () => {
|
|
23
|
+
expect(evaluateConditions({ branch: 'main' }, { role: 'worker' })).toBe(false);
|
|
24
|
+
});
|
|
25
|
+
it('matches combined role + branch', () => {
|
|
26
|
+
expect(evaluateConditions({ role: 'worker', branch: 'feature-*' }, { role: 'worker', branch: 'feature-auth' })).toBe(true);
|
|
27
|
+
expect(evaluateConditions({ role: 'worker', branch: 'feature-*' }, { role: 'manager', branch: 'feature-auth' })).toBe(false);
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
describe('findConditionalRedirectRule', () => {
|
|
31
|
+
const rules = [
|
|
32
|
+
{
|
|
33
|
+
operations: ['write'],
|
|
34
|
+
pattern: 's-*',
|
|
35
|
+
target: 'opentasks://specs/',
|
|
36
|
+
priority: 50,
|
|
37
|
+
fallback: 'error',
|
|
38
|
+
when: { role: 'worker' },
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
operations: ['read'],
|
|
42
|
+
pattern: '*',
|
|
43
|
+
target: 'opentasks://main/',
|
|
44
|
+
priority: 100,
|
|
45
|
+
fallback: 'local',
|
|
46
|
+
when: { branch: 'feature-*' },
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
operations: ['read', 'write'],
|
|
50
|
+
pattern: '*',
|
|
51
|
+
target: 'opentasks://default/',
|
|
52
|
+
priority: 200,
|
|
53
|
+
fallback: 'local',
|
|
54
|
+
},
|
|
55
|
+
];
|
|
56
|
+
it('matches rule with role condition', () => {
|
|
57
|
+
const ctx = { role: 'worker', branch: 'main' };
|
|
58
|
+
const rule = findConditionalRedirectRule('write', 's-abc', rules, ctx);
|
|
59
|
+
expect(rule?.target).toBe('opentasks://specs/');
|
|
60
|
+
});
|
|
61
|
+
it('skips rule when role doesnt match', () => {
|
|
62
|
+
const ctx = { role: 'manager', branch: 'main' };
|
|
63
|
+
const rule = findConditionalRedirectRule('write', 's-abc', rules, ctx);
|
|
64
|
+
// Should fall through to the default rule
|
|
65
|
+
expect(rule?.target).toBe('opentasks://default/');
|
|
66
|
+
});
|
|
67
|
+
it('matches rule with branch condition', () => {
|
|
68
|
+
const ctx = { role: 'standalone', branch: 'feature-auth' };
|
|
69
|
+
const rule = findConditionalRedirectRule('read', 'i-abc', rules, ctx);
|
|
70
|
+
expect(rule?.target).toBe('opentasks://main/');
|
|
71
|
+
});
|
|
72
|
+
it('skips branch rule when branch doesnt match', () => {
|
|
73
|
+
const ctx = { role: 'standalone', branch: 'main' };
|
|
74
|
+
const rule = findConditionalRedirectRule('read', 'i-abc', rules, ctx);
|
|
75
|
+
expect(rule?.target).toBe('opentasks://default/');
|
|
76
|
+
});
|
|
77
|
+
it('matches unconditional fallback', () => {
|
|
78
|
+
const ctx = { role: 'standalone' };
|
|
79
|
+
const rule = findConditionalRedirectRule('read', 'i-abc', rules, ctx);
|
|
80
|
+
expect(rule?.target).toBe('opentasks://default/');
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
//# sourceMappingURL=conditional-redirects.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conditional-redirects.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/conditional-redirects.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connections.test.d.ts","sourceRoot":"","sources":["../../../src/core/__tests__/connections.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
+
import * as fs from 'node:fs';
|
|
3
|
+
import * as path from 'node:path';
|
|
4
|
+
import * as os from 'node:os';
|
|
5
|
+
import { createConnection, checkConnectionHealth, addConnection, removeConnection, findConnection, checkAllConnectionHealth, } from '../connections.js';
|
|
6
|
+
let tmpDir;
|
|
7
|
+
function setupLocation(name, hash) {
|
|
8
|
+
const dir = path.join(tmpDir, name, '.opentasks');
|
|
9
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
10
|
+
fs.writeFileSync(path.join(dir, 'config.json'), JSON.stringify({
|
|
11
|
+
version: '1.0',
|
|
12
|
+
location: {
|
|
13
|
+
hash,
|
|
14
|
+
uuid: '550e8400-e29b-41d4-a716-446655440000',
|
|
15
|
+
name,
|
|
16
|
+
},
|
|
17
|
+
}));
|
|
18
|
+
return dir;
|
|
19
|
+
}
|
|
20
|
+
beforeEach(() => {
|
|
21
|
+
tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), 'opentasks-test-'));
|
|
22
|
+
});
|
|
23
|
+
afterEach(() => {
|
|
24
|
+
fs.rmSync(tmpDir, { recursive: true, force: true });
|
|
25
|
+
});
|
|
26
|
+
describe('createConnection', () => {
|
|
27
|
+
it('reads target config and creates connection', () => {
|
|
28
|
+
const targetDir = setupLocation('other-repo', 'k7m2x9p4');
|
|
29
|
+
const baseDir = path.join(tmpDir, 'my-repo', '.opentasks');
|
|
30
|
+
fs.mkdirSync(baseDir, { recursive: true });
|
|
31
|
+
const connection = createConnection(targetDir, 'peer', baseDir);
|
|
32
|
+
expect(connection.hash).toBe('k7m2x9p4');
|
|
33
|
+
expect(connection.name).toBe('other-repo');
|
|
34
|
+
expect(connection.role).toBe('peer');
|
|
35
|
+
});
|
|
36
|
+
it('throws on non-existent target', () => {
|
|
37
|
+
expect(() => createConnection('/nonexistent/.opentasks')).toThrow('Cannot read config');
|
|
38
|
+
});
|
|
39
|
+
it('throws on target without location identity', () => {
|
|
40
|
+
const dir = path.join(tmpDir, 'bad', '.opentasks');
|
|
41
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
42
|
+
fs.writeFileSync(path.join(dir, 'config.json'), JSON.stringify({}));
|
|
43
|
+
expect(() => createConnection(dir)).toThrow('No valid location identity');
|
|
44
|
+
});
|
|
45
|
+
it('uses absolute path when no basePath provided', () => {
|
|
46
|
+
const targetDir = setupLocation('target', 'abc12345');
|
|
47
|
+
const connection = createConnection(targetDir);
|
|
48
|
+
expect(path.isAbsolute(connection.path)).toBe(true);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
describe('checkConnectionHealth', () => {
|
|
52
|
+
it('returns reachable for valid connection', () => {
|
|
53
|
+
const targetDir = setupLocation('target', 'abc12345');
|
|
54
|
+
const connection = {
|
|
55
|
+
hash: 'abc12345',
|
|
56
|
+
path: targetDir,
|
|
57
|
+
role: 'peer',
|
|
58
|
+
name: 'target',
|
|
59
|
+
};
|
|
60
|
+
const status = checkConnectionHealth(connection);
|
|
61
|
+
expect(status.health).toBe('reachable');
|
|
62
|
+
expect(status.error).toBeUndefined();
|
|
63
|
+
});
|
|
64
|
+
it('returns unreachable for non-existent path', () => {
|
|
65
|
+
const connection = {
|
|
66
|
+
hash: 'abc12345',
|
|
67
|
+
path: '/nonexistent/.opentasks',
|
|
68
|
+
role: 'peer',
|
|
69
|
+
name: 'missing',
|
|
70
|
+
};
|
|
71
|
+
const status = checkConnectionHealth(connection);
|
|
72
|
+
expect(status.health).toBe('unreachable');
|
|
73
|
+
expect(status.error).toContain('does not exist');
|
|
74
|
+
});
|
|
75
|
+
it('returns hash-mismatch when hash changed', () => {
|
|
76
|
+
const targetDir = setupLocation('target', 'different');
|
|
77
|
+
const connection = {
|
|
78
|
+
hash: 'abc12345',
|
|
79
|
+
path: targetDir,
|
|
80
|
+
role: 'peer',
|
|
81
|
+
name: 'target',
|
|
82
|
+
};
|
|
83
|
+
const status = checkConnectionHealth(connection);
|
|
84
|
+
expect(status.health).toBe('hash-mismatch');
|
|
85
|
+
expect(status.error).toContain('Expected hash abc12345');
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
describe('addConnection', () => {
|
|
89
|
+
it('adds a new connection', () => {
|
|
90
|
+
const existing = [];
|
|
91
|
+
const newConn = {
|
|
92
|
+
hash: 'abc12345',
|
|
93
|
+
path: '/some/path',
|
|
94
|
+
role: 'peer',
|
|
95
|
+
name: 'new',
|
|
96
|
+
};
|
|
97
|
+
const result = addConnection(existing, newConn);
|
|
98
|
+
expect(result).toHaveLength(1);
|
|
99
|
+
expect(result[0]).toEqual(newConn);
|
|
100
|
+
});
|
|
101
|
+
it('replaces existing connection with same hash', () => {
|
|
102
|
+
const existing = [
|
|
103
|
+
{ hash: 'abc12345', path: '/old/path', role: 'peer', name: 'old' },
|
|
104
|
+
];
|
|
105
|
+
const newConn = {
|
|
106
|
+
hash: 'abc12345',
|
|
107
|
+
path: '/new/path',
|
|
108
|
+
role: 'parent',
|
|
109
|
+
name: 'updated',
|
|
110
|
+
};
|
|
111
|
+
const result = addConnection(existing, newConn);
|
|
112
|
+
expect(result).toHaveLength(1);
|
|
113
|
+
expect(result[0].path).toBe('/new/path');
|
|
114
|
+
expect(result[0].role).toBe('parent');
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
describe('removeConnection', () => {
|
|
118
|
+
it('removes by hash', () => {
|
|
119
|
+
const connections = [
|
|
120
|
+
{ hash: 'aaa11111', path: '/a', role: 'peer', name: 'a' },
|
|
121
|
+
{ hash: 'bbb22222', path: '/b', role: 'peer', name: 'b' },
|
|
122
|
+
];
|
|
123
|
+
const result = removeConnection(connections, 'aaa11111');
|
|
124
|
+
expect(result).toHaveLength(1);
|
|
125
|
+
expect(result[0].hash).toBe('bbb22222');
|
|
126
|
+
});
|
|
127
|
+
it('returns unchanged list if hash not found', () => {
|
|
128
|
+
const connections = [
|
|
129
|
+
{ hash: 'aaa11111', path: '/a', role: 'peer', name: 'a' },
|
|
130
|
+
];
|
|
131
|
+
const result = removeConnection(connections, 'notfound');
|
|
132
|
+
expect(result).toHaveLength(1);
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
describe('findConnection', () => {
|
|
136
|
+
it('finds by hash', () => {
|
|
137
|
+
const connections = [
|
|
138
|
+
{ hash: 'aaa11111', path: '/a', role: 'peer', name: 'a' },
|
|
139
|
+
{ hash: 'bbb22222', path: '/b', role: 'peer', name: 'b' },
|
|
140
|
+
];
|
|
141
|
+
expect(findConnection(connections, 'bbb22222')?.name).toBe('b');
|
|
142
|
+
expect(findConnection(connections, 'notfound')).toBeUndefined();
|
|
143
|
+
});
|
|
144
|
+
});
|
|
145
|
+
describe('checkAllConnectionHealth', () => {
|
|
146
|
+
it('returns status for all connections', () => {
|
|
147
|
+
const targetDir = setupLocation('target', 'abc12345');
|
|
148
|
+
const connections = [
|
|
149
|
+
{ hash: 'abc12345', path: targetDir, role: 'peer', name: 'target' },
|
|
150
|
+
{ hash: 'xyz99999', path: '/nonexistent', role: 'peer', name: 'missing' },
|
|
151
|
+
];
|
|
152
|
+
const statuses = checkAllConnectionHealth(connections);
|
|
153
|
+
expect(statuses).toHaveLength(2);
|
|
154
|
+
expect(statuses[0].health).toBe('reachable');
|
|
155
|
+
expect(statuses[1].health).toBe('unreachable');
|
|
156
|
+
});
|
|
157
|
+
});
|
|
158
|
+
//# sourceMappingURL=connections.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connections.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/connections.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hash.test.d.ts","sourceRoot":"","sources":["../../../src/core/__tests__/hash.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { sha256, computeContentHash, contentEqual } from '../hash.js';
|
|
3
|
+
describe('sha256', () => {
|
|
4
|
+
it('produces consistent hash for same input', () => {
|
|
5
|
+
const hash1 = sha256('hello world');
|
|
6
|
+
const hash2 = sha256('hello world');
|
|
7
|
+
expect(hash1).toBe(hash2);
|
|
8
|
+
});
|
|
9
|
+
it('produces different hash for different input', () => {
|
|
10
|
+
const hash1 = sha256('hello');
|
|
11
|
+
const hash2 = sha256('world');
|
|
12
|
+
expect(hash1).not.toBe(hash2);
|
|
13
|
+
});
|
|
14
|
+
it('produces 64-character hex string', () => {
|
|
15
|
+
const hash = sha256('test');
|
|
16
|
+
expect(hash).toHaveLength(64);
|
|
17
|
+
expect(hash).toMatch(/^[0-9a-f]{64}$/);
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
describe('computeContentHash', () => {
|
|
21
|
+
const baseNode = {
|
|
22
|
+
id: 's-a2b3',
|
|
23
|
+
uuid: '550e8400-e29b-41d4-a716-446655440000',
|
|
24
|
+
type: 'spec',
|
|
25
|
+
title: 'Test Spec',
|
|
26
|
+
content: 'Some content',
|
|
27
|
+
created_at: '2025-01-26T10:00:00Z',
|
|
28
|
+
updated_at: '2025-01-26T10:00:00Z',
|
|
29
|
+
};
|
|
30
|
+
it('produces consistent hash for same content', () => {
|
|
31
|
+
const hash1 = computeContentHash(baseNode);
|
|
32
|
+
const hash2 = computeContentHash(baseNode);
|
|
33
|
+
expect(hash1).toBe(hash2);
|
|
34
|
+
});
|
|
35
|
+
it('excludes non-substantive fields', () => {
|
|
36
|
+
const node1 = { ...baseNode };
|
|
37
|
+
const node2 = {
|
|
38
|
+
...baseNode,
|
|
39
|
+
id: 's-different',
|
|
40
|
+
uuid: 'different-uuid',
|
|
41
|
+
created_at: '2025-01-27T10:00:00Z',
|
|
42
|
+
updated_at: '2025-01-27T10:00:00Z',
|
|
43
|
+
claimed_by: 'agent-1',
|
|
44
|
+
claimed_at: '2025-01-27T10:00:00Z',
|
|
45
|
+
};
|
|
46
|
+
expect(computeContentHash(node1)).toBe(computeContentHash(node2));
|
|
47
|
+
});
|
|
48
|
+
it('includes substantive fields', () => {
|
|
49
|
+
const node1 = { ...baseNode };
|
|
50
|
+
const node2 = { ...baseNode, title: 'Different Title' };
|
|
51
|
+
const node3 = { ...baseNode, content: 'Different content' };
|
|
52
|
+
const node4 = { ...baseNode, priority: 1 };
|
|
53
|
+
expect(computeContentHash(node1)).not.toBe(computeContentHash(node2));
|
|
54
|
+
expect(computeContentHash(node1)).not.toBe(computeContentHash(node3));
|
|
55
|
+
expect(computeContentHash(node1)).not.toBe(computeContentHash(node4));
|
|
56
|
+
});
|
|
57
|
+
it('handles tags consistently (sorted)', () => {
|
|
58
|
+
const node1 = { ...baseNode, tags: ['b', 'a', 'c'] };
|
|
59
|
+
const node2 = { ...baseNode, tags: ['a', 'b', 'c'] };
|
|
60
|
+
const node3 = { ...baseNode, tags: ['c', 'a', 'b'] };
|
|
61
|
+
expect(computeContentHash(node1)).toBe(computeContentHash(node2));
|
|
62
|
+
expect(computeContentHash(node1)).toBe(computeContentHash(node3));
|
|
63
|
+
});
|
|
64
|
+
it('includes issue-specific fields', () => {
|
|
65
|
+
const issue1 = {
|
|
66
|
+
...baseNode,
|
|
67
|
+
type: 'issue',
|
|
68
|
+
status: 'open',
|
|
69
|
+
assignee: 'user1',
|
|
70
|
+
};
|
|
71
|
+
const issue2 = {
|
|
72
|
+
...baseNode,
|
|
73
|
+
type: 'issue',
|
|
74
|
+
status: 'open',
|
|
75
|
+
assignee: 'user2',
|
|
76
|
+
};
|
|
77
|
+
expect(computeContentHash(issue1)).not.toBe(computeContentHash(issue2));
|
|
78
|
+
});
|
|
79
|
+
it('includes feedback-specific fields', () => {
|
|
80
|
+
const feedback1 = {
|
|
81
|
+
...baseNode,
|
|
82
|
+
type: 'feedback',
|
|
83
|
+
target_id: 's-target1',
|
|
84
|
+
feedback_type: 'comment',
|
|
85
|
+
};
|
|
86
|
+
const feedback2 = {
|
|
87
|
+
...baseNode,
|
|
88
|
+
type: 'feedback',
|
|
89
|
+
target_id: 's-target2',
|
|
90
|
+
feedback_type: 'comment',
|
|
91
|
+
};
|
|
92
|
+
expect(computeContentHash(feedback1)).not.toBe(computeContentHash(feedback2));
|
|
93
|
+
});
|
|
94
|
+
it('includes external-specific fields', () => {
|
|
95
|
+
const external1 = {
|
|
96
|
+
...baseNode,
|
|
97
|
+
type: 'external',
|
|
98
|
+
uri: 'jira://PROJ-123',
|
|
99
|
+
source: 'jira',
|
|
100
|
+
materialized: false,
|
|
101
|
+
};
|
|
102
|
+
const external2 = {
|
|
103
|
+
...baseNode,
|
|
104
|
+
type: 'external',
|
|
105
|
+
uri: 'jira://PROJ-456',
|
|
106
|
+
source: 'jira',
|
|
107
|
+
materialized: false,
|
|
108
|
+
};
|
|
109
|
+
expect(computeContentHash(external1)).not.toBe(computeContentHash(external2));
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
describe('contentEqual', () => {
|
|
113
|
+
const baseNode = {
|
|
114
|
+
id: 's-a2b3',
|
|
115
|
+
uuid: '550e8400-e29b-41d4-a716-446655440000',
|
|
116
|
+
type: 'spec',
|
|
117
|
+
title: 'Test Spec',
|
|
118
|
+
content: 'Some content',
|
|
119
|
+
created_at: '2025-01-26T10:00:00Z',
|
|
120
|
+
updated_at: '2025-01-26T10:00:00Z',
|
|
121
|
+
};
|
|
122
|
+
it('returns true for equal content', () => {
|
|
123
|
+
const node1 = { ...baseNode };
|
|
124
|
+
const node2 = {
|
|
125
|
+
...baseNode,
|
|
126
|
+
id: 's-different',
|
|
127
|
+
uuid: 'different',
|
|
128
|
+
created_at: 'different',
|
|
129
|
+
updated_at: 'different',
|
|
130
|
+
};
|
|
131
|
+
expect(contentEqual(node1, node2)).toBe(true);
|
|
132
|
+
});
|
|
133
|
+
it('returns false for different content', () => {
|
|
134
|
+
const node1 = { ...baseNode };
|
|
135
|
+
const node2 = { ...baseNode, title: 'Different' };
|
|
136
|
+
expect(contentEqual(node1, node2)).toBe(false);
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
//# sourceMappingURL=hash.test.js.map
|