obsidian-accomplishments-mcp 0.1.10 → 0.1.11

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.
Files changed (269) hide show
  1. package/README.md +154 -182
  2. package/dist/index.js +207 -38
  3. package/dist/index.js.map +1 -1
  4. package/dist/integration.test.d.ts +8 -0
  5. package/dist/integration.test.d.ts.map +1 -0
  6. package/dist/integration.test.js +979 -0
  7. package/dist/integration.test.js.map +1 -0
  8. package/dist/models/types.d.ts +1 -2
  9. package/dist/models/types.d.ts.map +1 -1
  10. package/dist/models/types.js.map +1 -1
  11. package/dist/models/v2-types.d.ts +460 -0
  12. package/dist/models/v2-types.d.ts.map +1 -0
  13. package/dist/models/v2-types.js +137 -0
  14. package/dist/models/v2-types.js.map +1 -0
  15. package/dist/models/v2-types.test.d.ts +5 -0
  16. package/dist/models/v2-types.test.d.ts.map +1 -0
  17. package/dist/models/v2-types.test.js +133 -0
  18. package/dist/models/v2-types.test.js.map +1 -0
  19. package/dist/parsers/canvas-parser.d.ts +1 -1
  20. package/dist/parsers/canvas-parser.d.ts.map +1 -1
  21. package/dist/parsers/canvas-parser.js +1 -1
  22. package/dist/parsers/canvas-parser.js.map +1 -1
  23. package/dist/parsers/markdown-parser.js +9 -9
  24. package/dist/parsers/markdown-parser.js.map +1 -1
  25. package/dist/services/v2/archive-manager.d.ts +96 -0
  26. package/dist/services/v2/archive-manager.d.ts.map +1 -0
  27. package/dist/services/v2/archive-manager.js +281 -0
  28. package/dist/services/v2/archive-manager.js.map +1 -0
  29. package/dist/services/v2/canvas-manager.d.ts +155 -0
  30. package/dist/services/v2/canvas-manager.d.ts.map +1 -0
  31. package/dist/services/v2/canvas-manager.js +540 -0
  32. package/dist/services/v2/canvas-manager.js.map +1 -0
  33. package/dist/services/v2/canvas-manager.test.d.ts +5 -0
  34. package/dist/services/v2/canvas-manager.test.d.ts.map +1 -0
  35. package/dist/services/v2/canvas-manager.test.js +327 -0
  36. package/dist/services/v2/canvas-manager.test.js.map +1 -0
  37. package/dist/services/v2/cascade-manager.d.ts +54 -0
  38. package/dist/services/v2/cascade-manager.d.ts.map +1 -0
  39. package/dist/services/v2/cascade-manager.js +220 -0
  40. package/dist/services/v2/cascade-manager.js.map +1 -0
  41. package/dist/services/v2/cycle-detector.d.ts +76 -0
  42. package/dist/services/v2/cycle-detector.d.ts.map +1 -0
  43. package/dist/services/v2/cycle-detector.js +183 -0
  44. package/dist/services/v2/cycle-detector.js.map +1 -0
  45. package/dist/services/v2/cycle-detector.test.d.ts +7 -0
  46. package/dist/services/v2/cycle-detector.test.d.ts.map +1 -0
  47. package/dist/services/v2/cycle-detector.test.js +125 -0
  48. package/dist/services/v2/cycle-detector.test.js.map +1 -0
  49. package/dist/services/v2/entity-parser.d.ts +54 -0
  50. package/dist/services/v2/entity-parser.d.ts.map +1 -0
  51. package/dist/services/v2/entity-parser.js +418 -0
  52. package/dist/services/v2/entity-parser.js.map +1 -0
  53. package/dist/services/v2/entity-parser.test.d.ts +5 -0
  54. package/dist/services/v2/entity-parser.test.d.ts.map +1 -0
  55. package/dist/services/v2/entity-parser.test.js +637 -0
  56. package/dist/services/v2/entity-parser.test.js.map +1 -0
  57. package/dist/services/v2/entity-serializer.d.ts +94 -0
  58. package/dist/services/v2/entity-serializer.d.ts.map +1 -0
  59. package/dist/services/v2/entity-serializer.js +583 -0
  60. package/dist/services/v2/entity-serializer.js.map +1 -0
  61. package/dist/services/v2/entity-serializer.test.d.ts +5 -0
  62. package/dist/services/v2/entity-serializer.test.d.ts.map +1 -0
  63. package/dist/services/v2/entity-serializer.test.js +241 -0
  64. package/dist/services/v2/entity-serializer.test.js.map +1 -0
  65. package/dist/services/v2/entity-validator.d.ts +65 -0
  66. package/dist/services/v2/entity-validator.d.ts.map +1 -0
  67. package/dist/services/v2/entity-validator.js +573 -0
  68. package/dist/services/v2/entity-validator.js.map +1 -0
  69. package/dist/services/v2/entity-validator.test.d.ts +5 -0
  70. package/dist/services/v2/entity-validator.test.d.ts.map +1 -0
  71. package/dist/services/v2/entity-validator.test.js +519 -0
  72. package/dist/services/v2/entity-validator.test.js.map +1 -0
  73. package/dist/services/v2/file-manager.d.ts +73 -0
  74. package/dist/services/v2/file-manager.d.ts.map +1 -0
  75. package/dist/services/v2/file-manager.js +310 -0
  76. package/dist/services/v2/file-manager.js.map +1 -0
  77. package/dist/services/v2/file-manager.test.d.ts +5 -0
  78. package/dist/services/v2/file-manager.test.d.ts.map +1 -0
  79. package/dist/services/v2/file-manager.test.js +339 -0
  80. package/dist/services/v2/file-manager.test.js.map +1 -0
  81. package/dist/services/v2/index-manager.d.ts +68 -0
  82. package/dist/services/v2/index-manager.d.ts.map +1 -0
  83. package/dist/services/v2/index-manager.js +228 -0
  84. package/dist/services/v2/index-manager.js.map +1 -0
  85. package/dist/services/v2/index-manager.test.d.ts +5 -0
  86. package/dist/services/v2/index-manager.test.d.ts.map +1 -0
  87. package/dist/services/v2/index-manager.test.js +386 -0
  88. package/dist/services/v2/index-manager.test.js.map +1 -0
  89. package/dist/services/v2/index-service.d.ts +82 -0
  90. package/dist/services/v2/index-service.d.ts.map +1 -0
  91. package/dist/services/v2/index-service.js +274 -0
  92. package/dist/services/v2/index-service.js.map +1 -0
  93. package/dist/services/v2/index-service.test.d.ts +5 -0
  94. package/dist/services/v2/index-service.test.d.ts.map +1 -0
  95. package/dist/services/v2/index-service.test.js +117 -0
  96. package/dist/services/v2/index-service.test.js.map +1 -0
  97. package/dist/services/v2/lifecycle-manager.d.ts +59 -0
  98. package/dist/services/v2/lifecycle-manager.d.ts.map +1 -0
  99. package/dist/services/v2/lifecycle-manager.js +310 -0
  100. package/dist/services/v2/lifecycle-manager.js.map +1 -0
  101. package/dist/services/v2/lifecycle-manager.test.d.ts +5 -0
  102. package/dist/services/v2/lifecycle-manager.test.d.ts.map +1 -0
  103. package/dist/services/v2/lifecycle-manager.test.js +141 -0
  104. package/dist/services/v2/lifecycle-manager.test.js.map +1 -0
  105. package/dist/services/v2/path-resolver.d.ts +64 -0
  106. package/dist/services/v2/path-resolver.d.ts.map +1 -0
  107. package/dist/services/v2/path-resolver.js +174 -0
  108. package/dist/services/v2/path-resolver.js.map +1 -0
  109. package/dist/services/v2/progress-computer.d.ts +46 -0
  110. package/dist/services/v2/progress-computer.d.ts.map +1 -0
  111. package/dist/services/v2/progress-computer.js +200 -0
  112. package/dist/services/v2/progress-computer.js.map +1 -0
  113. package/dist/services/v2/search-service.d.ts +68 -0
  114. package/dist/services/v2/search-service.d.ts.map +1 -0
  115. package/dist/services/v2/search-service.js +194 -0
  116. package/dist/services/v2/search-service.js.map +1 -0
  117. package/dist/services/v2/transitive-dependency-remover.d.ts +54 -0
  118. package/dist/services/v2/transitive-dependency-remover.d.ts.map +1 -0
  119. package/dist/services/v2/transitive-dependency-remover.js +156 -0
  120. package/dist/services/v2/transitive-dependency-remover.js.map +1 -0
  121. package/dist/services/v2/transitive-dependency-remover.test.d.ts +7 -0
  122. package/dist/services/v2/transitive-dependency-remover.test.d.ts.map +1 -0
  123. package/dist/services/v2/transitive-dependency-remover.test.js +119 -0
  124. package/dist/services/v2/transitive-dependency-remover.test.js.map +1 -0
  125. package/dist/services/v2/v2-runtime.d.ts +374 -0
  126. package/dist/services/v2/v2-runtime.d.ts.map +1 -0
  127. package/dist/services/v2/v2-runtime.js +1908 -0
  128. package/dist/services/v2/v2-runtime.js.map +1 -0
  129. package/dist/services/v2/v2-runtime.test.d.ts +5 -0
  130. package/dist/services/v2/v2-runtime.test.d.ts.map +1 -0
  131. package/dist/services/v2/v2-runtime.test.js +658 -0
  132. package/dist/services/v2/v2-runtime.test.js.map +1 -0
  133. package/dist/services/v2/workstream-normalizer.d.ts +59 -0
  134. package/dist/services/v2/workstream-normalizer.d.ts.map +1 -0
  135. package/dist/services/v2/workstream-normalizer.js +137 -0
  136. package/dist/services/v2/workstream-normalizer.js.map +1 -0
  137. package/dist/services/v2/workstream-normalizer.test.d.ts +7 -0
  138. package/dist/services/v2/workstream-normalizer.test.d.ts.map +1 -0
  139. package/dist/services/v2/workstream-normalizer.test.js +130 -0
  140. package/dist/services/v2/workstream-normalizer.test.js.map +1 -0
  141. package/dist/test-runner.d.ts +4 -1
  142. package/dist/test-runner.d.ts.map +1 -1
  143. package/dist/test-runner.js +44 -249
  144. package/dist/test-runner.js.map +1 -1
  145. package/dist/tools/batch-operations-tools.d.ts +54 -0
  146. package/dist/tools/batch-operations-tools.d.ts.map +1 -0
  147. package/dist/tools/batch-operations-tools.js +370 -0
  148. package/dist/tools/batch-operations-tools.js.map +1 -0
  149. package/dist/tools/decision-document-tools.d.ts +78 -0
  150. package/dist/tools/decision-document-tools.d.ts.map +1 -0
  151. package/dist/tools/decision-document-tools.js +260 -0
  152. package/dist/tools/decision-document-tools.js.map +1 -0
  153. package/dist/tools/entity-management-tools.d.ts +79 -0
  154. package/dist/tools/entity-management-tools.d.ts.map +1 -0
  155. package/dist/tools/entity-management-tools.js +851 -0
  156. package/dist/tools/entity-management-tools.js.map +1 -0
  157. package/dist/tools/entity-management-tools.test.d.ts +5 -0
  158. package/dist/tools/entity-management-tools.test.d.ts.map +1 -0
  159. package/dist/tools/entity-management-tools.test.js +530 -0
  160. package/dist/tools/entity-management-tools.test.js.map +1 -0
  161. package/dist/tools/index.d.ts +15 -331
  162. package/dist/tools/index.d.ts.map +1 -1
  163. package/dist/tools/index.js +510 -47
  164. package/dist/tools/index.js.map +1 -1
  165. package/dist/tools/index.test.d.ts +8 -0
  166. package/dist/tools/index.test.d.ts.map +1 -0
  167. package/dist/tools/index.test.js +429 -0
  168. package/dist/tools/index.test.js.map +1 -0
  169. package/dist/tools/project-understanding-tools.d.ts +75 -0
  170. package/dist/tools/project-understanding-tools.d.ts.map +1 -0
  171. package/dist/tools/project-understanding-tools.js +751 -0
  172. package/dist/tools/project-understanding-tools.js.map +1 -0
  173. package/dist/tools/search-navigation-tools.d.ts +77 -0
  174. package/dist/tools/search-navigation-tools.d.ts.map +1 -0
  175. package/dist/tools/search-navigation-tools.js +379 -0
  176. package/dist/tools/search-navigation-tools.js.map +1 -0
  177. package/dist/tools/tool-types.d.ts +703 -0
  178. package/dist/tools/tool-types.d.ts.map +1 -0
  179. package/dist/tools/tool-types.js +7 -0
  180. package/dist/tools/tool-types.js.map +1 -0
  181. package/dist/utils/config.d.ts +0 -4
  182. package/dist/utils/config.d.ts.map +1 -1
  183. package/dist/utils/config.js +2 -19
  184. package/dist/utils/config.js.map +1 -1
  185. package/package.json +16 -1
  186. package/dist/services/accomplishment-service.d.ts +0 -33
  187. package/dist/services/accomplishment-service.d.ts.map +0 -1
  188. package/dist/services/accomplishment-service.js +0 -296
  189. package/dist/services/accomplishment-service.js.map +0 -1
  190. package/dist/services/canvas-service.d.ts +0 -96
  191. package/dist/services/canvas-service.d.ts.map +0 -1
  192. package/dist/services/canvas-service.js +0 -231
  193. package/dist/services/canvas-service.js.map +0 -1
  194. package/dist/services/context-doc-service.d.ts +0 -70
  195. package/dist/services/context-doc-service.d.ts.map +0 -1
  196. package/dist/services/context-doc-service.js +0 -229
  197. package/dist/services/context-doc-service.js.map +0 -1
  198. package/dist/services/dependency-service.d.ts +0 -22
  199. package/dist/services/dependency-service.d.ts.map +0 -1
  200. package/dist/services/dependency-service.js +0 -99
  201. package/dist/services/dependency-service.js.map +0 -1
  202. package/dist/services/status-indicator-service.d.ts +0 -40
  203. package/dist/services/status-indicator-service.d.ts.map +0 -1
  204. package/dist/services/status-indicator-service.js +0 -173
  205. package/dist/services/status-indicator-service.js.map +0 -1
  206. package/dist/services/task-service.d.ts +0 -32
  207. package/dist/services/task-service.d.ts.map +0 -1
  208. package/dist/services/task-service.js +0 -152
  209. package/dist/services/task-service.js.map +0 -1
  210. package/dist/test-real-vault.d.ts +0 -6
  211. package/dist/test-real-vault.d.ts.map +0 -1
  212. package/dist/test-real-vault.js +0 -30
  213. package/dist/test-real-vault.js.map +0 -1
  214. package/dist/tools/batch-operations.d.ts +0 -246
  215. package/dist/tools/batch-operations.d.ts.map +0 -1
  216. package/dist/tools/batch-operations.js +0 -235
  217. package/dist/tools/batch-operations.js.map +0 -1
  218. package/dist/tools/get-accomplishment.d.ts +0 -42
  219. package/dist/tools/get-accomplishment.d.ts.map +0 -1
  220. package/dist/tools/get-accomplishment.js +0 -93
  221. package/dist/tools/get-accomplishment.js.map +0 -1
  222. package/dist/tools/get-accomplishments-graph.d.ts +0 -26
  223. package/dist/tools/get-accomplishments-graph.d.ts.map +0 -1
  224. package/dist/tools/get-accomplishments-graph.js +0 -137
  225. package/dist/tools/get-accomplishments-graph.js.map +0 -1
  226. package/dist/tools/get-blocked-items.d.ts +0 -15
  227. package/dist/tools/get-blocked-items.d.ts.map +0 -1
  228. package/dist/tools/get-blocked-items.js +0 -73
  229. package/dist/tools/get-blocked-items.js.map +0 -1
  230. package/dist/tools/get-current-work.d.ts +0 -15
  231. package/dist/tools/get-current-work.d.ts.map +0 -1
  232. package/dist/tools/get-current-work.js +0 -68
  233. package/dist/tools/get-current-work.js.map +0 -1
  234. package/dist/tools/get-project-status.d.ts +0 -26
  235. package/dist/tools/get-project-status.d.ts.map +0 -1
  236. package/dist/tools/get-project-status.js +0 -98
  237. package/dist/tools/get-project-status.js.map +0 -1
  238. package/dist/tools/get-ready-to-start.d.ts +0 -15
  239. package/dist/tools/get-ready-to-start.d.ts.map +0 -1
  240. package/dist/tools/get-ready-to-start.js +0 -47
  241. package/dist/tools/get-ready-to-start.js.map +0 -1
  242. package/dist/tools/list-accomplishments.d.ts +0 -42
  243. package/dist/tools/list-accomplishments.d.ts.map +0 -1
  244. package/dist/tools/list-accomplishments.js +0 -40
  245. package/dist/tools/list-accomplishments.js.map +0 -1
  246. package/dist/tools/manage-accomplishment.d.ts +0 -147
  247. package/dist/tools/manage-accomplishment.d.ts.map +0 -1
  248. package/dist/tools/manage-accomplishment.js +0 -153
  249. package/dist/tools/manage-accomplishment.js.map +0 -1
  250. package/dist/tools/manage-dependency.d.ts +0 -41
  251. package/dist/tools/manage-dependency.d.ts.map +0 -1
  252. package/dist/tools/manage-dependency.js +0 -66
  253. package/dist/tools/manage-dependency.js.map +0 -1
  254. package/dist/tools/manage-task.d.ts +0 -119
  255. package/dist/tools/manage-task.d.ts.map +0 -1
  256. package/dist/tools/manage-task.js +0 -126
  257. package/dist/tools/manage-task.js.map +0 -1
  258. package/dist/tools/reconcile-canvas.d.ts +0 -33
  259. package/dist/tools/reconcile-canvas.d.ts.map +0 -1
  260. package/dist/tools/reconcile-canvas.js +0 -41
  261. package/dist/tools/reconcile-canvas.js.map +0 -1
  262. package/dist/tools/set-work-focus.d.ts +0 -48
  263. package/dist/tools/set-work-focus.d.ts.map +0 -1
  264. package/dist/tools/set-work-focus.js +0 -78
  265. package/dist/tools/set-work-focus.js.map +0 -1
  266. package/dist/tools/sync-dependencies.d.ts +0 -33
  267. package/dist/tools/sync-dependencies.d.ts.map +0 -1
  268. package/dist/tools/sync-dependencies.js +0 -144
  269. package/dist/tools/sync-dependencies.js.map +0 -1
@@ -0,0 +1,82 @@
1
+ /**
2
+ * V2 Index Service
3
+ *
4
+ * Provides in-memory indexing for fast entity lookups.
5
+ * Implements primary index, secondary indexes, and relationship graph.
6
+ */
7
+ import { EntityId, EntityType, EntityStatus, EntityMetadata, Priority, VaultPath, CanvasPath } from '../../models/v2-types.js';
8
+ /** Secondary indexes for efficient filtering */
9
+ export interface SecondaryIndexes {
10
+ by_type: Map<EntityType, Set<EntityId>>;
11
+ by_status: Map<EntityStatus, Set<EntityId>>;
12
+ by_workstream: Map<string, Set<EntityId>>;
13
+ by_parent: Map<EntityId, Set<EntityId>>;
14
+ by_canvas: Map<CanvasPath, Set<EntityId>>;
15
+ archived: Set<EntityId>;
16
+ in_progress: Set<EntityId>;
17
+ by_priority: Map<Priority, Set<EntityId>>;
18
+ }
19
+ export type RelationshipType = 'blocks' | 'blocked_by' | 'implements' | 'implemented_by' | 'supersedes' | 'superseded_by' | 'parent_of' | 'child_of' | 'previous_version' | 'next_version';
20
+ export interface RelationshipGraph {
21
+ forward: Map<EntityId, Map<RelationshipType, Set<EntityId>>>;
22
+ reverse: Map<EntityId, Map<RelationshipType, Set<EntityId>>>;
23
+ }
24
+ export interface FileMappings {
25
+ path_to_id: Map<VaultPath, EntityId>;
26
+ id_to_path: Map<EntityId, VaultPath>;
27
+ file_mtimes: Map<VaultPath, number>;
28
+ }
29
+ export declare class ProjectIndex {
30
+ private primary;
31
+ private secondary;
32
+ private relationships;
33
+ private files;
34
+ private version;
35
+ private lastRebuild;
36
+ constructor();
37
+ private createEmptySecondaryIndexes;
38
+ private createEmptyRelationshipGraph;
39
+ private createEmptyFileMappings;
40
+ get(id: EntityId): EntityMetadata | undefined;
41
+ has(id: EntityId): boolean;
42
+ getAllIds(): EntityId[];
43
+ getAll(): EntityMetadata[];
44
+ get size(): number;
45
+ getVersion(): number;
46
+ set(metadata: EntityMetadata): void;
47
+ delete(id: EntityId): boolean;
48
+ /** Remove a stale path mapping without deleting the entity (for duplicate cleanup) */
49
+ removePathMapping(path: VaultPath): void;
50
+ clear(): void;
51
+ private addToSetIndex;
52
+ private removeFromSetIndex;
53
+ private addToSecondaryIndexes;
54
+ private removeFromSecondaryIndexes;
55
+ private removeFromRelationships;
56
+ /**
57
+ * Remove only forward relationships for an entity (relationships where this entity is the source).
58
+ * This is used when re-indexing an entity's relationships without losing relationships
59
+ * where this entity is the target (e.g., parent_of relationships from children).
60
+ *
61
+ * @param excludeTypes - Relationship types to exclude from removal. Use this to preserve
62
+ * relationships that are "owned" by other entities (e.g., parent_of
63
+ * is owned by children, not parents).
64
+ */
65
+ removeForwardRelationships(id: EntityId, excludeTypes?: RelationshipType[]): void;
66
+ private getReverseRelationType;
67
+ getByType(type: EntityType): EntityMetadata[];
68
+ getByStatus(status: EntityStatus): EntityMetadata[];
69
+ getByWorkstream(workstream: string): EntityMetadata[];
70
+ getByParent(parentId: EntityId): EntityMetadata[];
71
+ getByCanvas(canvasPath: CanvasPath): EntityMetadata[];
72
+ getArchived(): EntityMetadata[];
73
+ getInProgress(): EntityMetadata[];
74
+ addRelationship(from: EntityId, type: RelationshipType, to: EntityId): void;
75
+ getRelated(id: EntityId, type: RelationshipType): EntityId[];
76
+ getRelatedReverse(id: EntityId, type: RelationshipType): EntityId[];
77
+ getIdByPath(path: VaultPath): EntityId | undefined;
78
+ getPathById(id: EntityId): VaultPath | undefined;
79
+ getFileMtime(path: VaultPath): number | undefined;
80
+ getAllPaths(): VaultPath[];
81
+ }
82
+ //# sourceMappingURL=index-service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-service.d.ts","sourceRoot":"","sources":["../../../src/services/v2/index-service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,274 @@
1
+ /**
2
+ * V2 Index Service
3
+ *
4
+ * Provides in-memory indexing for fast entity lookups.
5
+ * Implements primary index, secondary indexes, and relationship graph.
6
+ */
7
+ // =============================================================================
8
+ // Project Index Class
9
+ // =============================================================================
10
+ export class ProjectIndex {
11
+ primary = new Map();
12
+ secondary;
13
+ relationships;
14
+ files;
15
+ version = 0;
16
+ lastRebuild = 0;
17
+ constructor() {
18
+ this.secondary = this.createEmptySecondaryIndexes();
19
+ this.relationships = this.createEmptyRelationshipGraph();
20
+ this.files = this.createEmptyFileMappings();
21
+ }
22
+ createEmptySecondaryIndexes() {
23
+ return {
24
+ by_type: new Map(),
25
+ by_status: new Map(),
26
+ by_workstream: new Map(),
27
+ by_parent: new Map(),
28
+ by_canvas: new Map(),
29
+ archived: new Set(),
30
+ in_progress: new Set(),
31
+ by_priority: new Map(),
32
+ };
33
+ }
34
+ createEmptyRelationshipGraph() {
35
+ return { forward: new Map(), reverse: new Map() };
36
+ }
37
+ createEmptyFileMappings() {
38
+ return {
39
+ path_to_id: new Map(),
40
+ id_to_path: new Map(),
41
+ file_mtimes: new Map(),
42
+ };
43
+ }
44
+ // Primary Index Operations
45
+ get(id) { return this.primary.get(id); }
46
+ has(id) { return this.primary.has(id); }
47
+ getAllIds() { return Array.from(this.primary.keys()); }
48
+ getAll() { return Array.from(this.primary.values()); }
49
+ get size() { return this.primary.size; }
50
+ getVersion() { return this.version; }
51
+ set(metadata) {
52
+ const existing = this.primary.get(metadata.id);
53
+ if (existing)
54
+ this.removeFromSecondaryIndexes(existing);
55
+ this.primary.set(metadata.id, metadata);
56
+ this.addToSecondaryIndexes(metadata);
57
+ this.files.path_to_id.set(metadata.vault_path, metadata.id);
58
+ this.files.id_to_path.set(metadata.id, metadata.vault_path);
59
+ this.files.file_mtimes.set(metadata.vault_path, metadata.file_mtime);
60
+ this.version++;
61
+ }
62
+ delete(id) {
63
+ const metadata = this.primary.get(id);
64
+ if (!metadata)
65
+ return false;
66
+ this.primary.delete(id);
67
+ this.removeFromSecondaryIndexes(metadata);
68
+ this.files.path_to_id.delete(metadata.vault_path);
69
+ this.files.id_to_path.delete(id);
70
+ this.files.file_mtimes.delete(metadata.vault_path);
71
+ this.removeFromRelationships(id);
72
+ this.version++;
73
+ return true;
74
+ }
75
+ /** Remove a stale path mapping without deleting the entity (for duplicate cleanup) */
76
+ removePathMapping(path) {
77
+ this.files.path_to_id.delete(path);
78
+ this.files.file_mtimes.delete(path);
79
+ this.version++;
80
+ }
81
+ clear() {
82
+ this.primary.clear();
83
+ this.secondary = this.createEmptySecondaryIndexes();
84
+ this.relationships = this.createEmptyRelationshipGraph();
85
+ this.files = this.createEmptyFileMappings();
86
+ this.version++;
87
+ this.lastRebuild = Date.now();
88
+ }
89
+ // Helper to add to set-based index
90
+ addToSetIndex(map, key, id) {
91
+ let set = map.get(key);
92
+ if (!set) {
93
+ set = new Set();
94
+ map.set(key, set);
95
+ }
96
+ set.add(id);
97
+ }
98
+ // Helper to remove from set-based index
99
+ removeFromSetIndex(map, key, id) {
100
+ const set = map.get(key);
101
+ if (set) {
102
+ set.delete(id);
103
+ if (set.size === 0)
104
+ map.delete(key);
105
+ }
106
+ }
107
+ addToSecondaryIndexes(metadata) {
108
+ this.addToSetIndex(this.secondary.by_type, metadata.type, metadata.id);
109
+ this.addToSetIndex(this.secondary.by_status, metadata.status, metadata.id);
110
+ this.addToSetIndex(this.secondary.by_workstream, metadata.workstream, metadata.id);
111
+ if (metadata.parent_id)
112
+ this.addToSetIndex(this.secondary.by_parent, metadata.parent_id, metadata.id);
113
+ this.addToSetIndex(this.secondary.by_canvas, metadata.canvas_source, metadata.id);
114
+ if (metadata.archived)
115
+ this.secondary.archived.add(metadata.id);
116
+ if (metadata.in_progress)
117
+ this.secondary.in_progress.add(metadata.id);
118
+ if (metadata.priority)
119
+ this.addToSetIndex(this.secondary.by_priority, metadata.priority, metadata.id);
120
+ }
121
+ removeFromSecondaryIndexes(metadata) {
122
+ this.removeFromSetIndex(this.secondary.by_type, metadata.type, metadata.id);
123
+ this.removeFromSetIndex(this.secondary.by_status, metadata.status, metadata.id);
124
+ this.removeFromSetIndex(this.secondary.by_workstream, metadata.workstream, metadata.id);
125
+ if (metadata.parent_id)
126
+ this.removeFromSetIndex(this.secondary.by_parent, metadata.parent_id, metadata.id);
127
+ this.removeFromSetIndex(this.secondary.by_canvas, metadata.canvas_source, metadata.id);
128
+ this.secondary.archived.delete(metadata.id);
129
+ this.secondary.in_progress.delete(metadata.id);
130
+ if (metadata.priority)
131
+ this.removeFromSetIndex(this.secondary.by_priority, metadata.priority, metadata.id);
132
+ }
133
+ removeFromRelationships(id) {
134
+ // Remove all forward relationships
135
+ const forwardRels = this.relationships.forward.get(id);
136
+ if (forwardRels) {
137
+ for (const [relType, targets] of forwardRels) {
138
+ for (const target of targets) {
139
+ const reverseRels = this.relationships.reverse.get(target);
140
+ if (reverseRels) {
141
+ const reverseType = this.getReverseRelationType(relType);
142
+ reverseRels.get(reverseType)?.delete(id);
143
+ }
144
+ }
145
+ }
146
+ this.relationships.forward.delete(id);
147
+ }
148
+ // Remove all reverse relationships
149
+ const reverseRels = this.relationships.reverse.get(id);
150
+ if (reverseRels) {
151
+ for (const [relType, sources] of reverseRels) {
152
+ for (const source of sources) {
153
+ const forwardRels = this.relationships.forward.get(source);
154
+ if (forwardRels) {
155
+ const forwardType = this.getReverseRelationType(relType);
156
+ forwardRels.get(forwardType)?.delete(id);
157
+ }
158
+ }
159
+ }
160
+ this.relationships.reverse.delete(id);
161
+ }
162
+ }
163
+ /**
164
+ * Remove only forward relationships for an entity (relationships where this entity is the source).
165
+ * This is used when re-indexing an entity's relationships without losing relationships
166
+ * where this entity is the target (e.g., parent_of relationships from children).
167
+ *
168
+ * @param excludeTypes - Relationship types to exclude from removal. Use this to preserve
169
+ * relationships that are "owned" by other entities (e.g., parent_of
170
+ * is owned by children, not parents).
171
+ */
172
+ removeForwardRelationships(id, excludeTypes) {
173
+ const forwardRels = this.relationships.forward.get(id);
174
+ if (forwardRels) {
175
+ const excludeSet = new Set(excludeTypes || []);
176
+ for (const [relType, targets] of forwardRels) {
177
+ // Skip excluded relationship types
178
+ if (excludeSet.has(relType))
179
+ continue;
180
+ for (const target of targets) {
181
+ const reverseRels = this.relationships.reverse.get(target);
182
+ if (reverseRels) {
183
+ const reverseType = this.getReverseRelationType(relType);
184
+ reverseRels.get(reverseType)?.delete(id);
185
+ }
186
+ }
187
+ forwardRels.delete(relType);
188
+ }
189
+ // Only delete the forward map if it's empty
190
+ if (forwardRels.size === 0) {
191
+ this.relationships.forward.delete(id);
192
+ }
193
+ }
194
+ }
195
+ getReverseRelationType(type) {
196
+ const reverseMap = {
197
+ 'blocks': 'blocked_by', 'blocked_by': 'blocks',
198
+ 'implements': 'implemented_by', 'implemented_by': 'implements',
199
+ 'supersedes': 'superseded_by', 'superseded_by': 'supersedes',
200
+ 'parent_of': 'child_of', 'child_of': 'parent_of',
201
+ 'previous_version': 'next_version', 'next_version': 'previous_version',
202
+ };
203
+ return reverseMap[type];
204
+ }
205
+ // Secondary Index Query Methods
206
+ getByType(type) {
207
+ const ids = this.secondary.by_type.get(type);
208
+ return ids ? Array.from(ids).map(id => this.primary.get(id)).filter(Boolean) : [];
209
+ }
210
+ getByStatus(status) {
211
+ const ids = this.secondary.by_status.get(status);
212
+ return ids ? Array.from(ids).map(id => this.primary.get(id)).filter(Boolean) : [];
213
+ }
214
+ getByWorkstream(workstream) {
215
+ const ids = this.secondary.by_workstream.get(workstream);
216
+ return ids ? Array.from(ids).map(id => this.primary.get(id)).filter(Boolean) : [];
217
+ }
218
+ getByParent(parentId) {
219
+ const ids = this.secondary.by_parent.get(parentId);
220
+ return ids ? Array.from(ids).map(id => this.primary.get(id)).filter(Boolean) : [];
221
+ }
222
+ getByCanvas(canvasPath) {
223
+ const ids = this.secondary.by_canvas.get(canvasPath);
224
+ return ids ? Array.from(ids).map(id => this.primary.get(id)).filter(Boolean) : [];
225
+ }
226
+ getArchived() {
227
+ return Array.from(this.secondary.archived).map(id => this.primary.get(id)).filter(Boolean);
228
+ }
229
+ getInProgress() {
230
+ return Array.from(this.secondary.in_progress).map(id => this.primary.get(id)).filter(Boolean);
231
+ }
232
+ // Relationship Operations
233
+ addRelationship(from, type, to) {
234
+ // Add forward relationship
235
+ let forwardRels = this.relationships.forward.get(from);
236
+ if (!forwardRels) {
237
+ forwardRels = new Map();
238
+ this.relationships.forward.set(from, forwardRels);
239
+ }
240
+ let targets = forwardRels.get(type);
241
+ if (!targets) {
242
+ targets = new Set();
243
+ forwardRels.set(type, targets);
244
+ }
245
+ targets.add(to);
246
+ // Add reverse relationship
247
+ const reverseType = this.getReverseRelationType(type);
248
+ let reverseRels = this.relationships.reverse.get(to);
249
+ if (!reverseRels) {
250
+ reverseRels = new Map();
251
+ this.relationships.reverse.set(to, reverseRels);
252
+ }
253
+ let sources = reverseRels.get(reverseType);
254
+ if (!sources) {
255
+ sources = new Set();
256
+ reverseRels.set(reverseType, sources);
257
+ }
258
+ sources.add(from);
259
+ }
260
+ getRelated(id, type) {
261
+ const rels = this.relationships.forward.get(id);
262
+ return rels?.get(type) ? Array.from(rels.get(type)) : [];
263
+ }
264
+ getRelatedReverse(id, type) {
265
+ const rels = this.relationships.reverse.get(id);
266
+ return rels?.get(type) ? Array.from(rels.get(type)) : [];
267
+ }
268
+ // File Mapping Operations
269
+ getIdByPath(path) { return this.files.path_to_id.get(path); }
270
+ getPathById(id) { return this.files.id_to_path.get(id); }
271
+ getFileMtime(path) { return this.files.file_mtimes.get(path); }
272
+ getAllPaths() { return Array.from(this.files.path_to_id.keys()); }
273
+ }
274
+ //# sourceMappingURL=index-service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-service.js","sourceRoot":"","sources":["../../../src/services/v2/index-service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Tests for V2 Index Service
3
+ */
4
+ export {};
5
+ //# sourceMappingURL=index-service.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-service.test.d.ts","sourceRoot":"","sources":["../../../src/services/v2/index-service.test.ts"],"names":[],"mappings":"AAAA;;GAEG"}
@@ -0,0 +1,117 @@
1
+ /**
2
+ * Tests for V2 Index Service
3
+ */
4
+ import { describe, it, expect, beforeEach } from 'vitest';
5
+ import { ProjectIndex } from './index-service.js';
6
+ describe('ProjectIndex', () => {
7
+ let index;
8
+ const createMockMetadata = (overrides = {}) => ({
9
+ id: 'M-001',
10
+ type: 'milestone',
11
+ title: 'Test Milestone',
12
+ workstream: 'engineering',
13
+ status: 'In Progress',
14
+ archived: false,
15
+ in_progress: true,
16
+ parent_id: undefined,
17
+ children_count: 0,
18
+ vault_path: '/vault/accomplishments/milestones/M-001.md',
19
+ canvas_source: '/vault/canvas.canvas',
20
+ updated_at: '2024-01-15T00:00:00Z',
21
+ file_mtime: Date.now(),
22
+ ...overrides,
23
+ });
24
+ beforeEach(() => {
25
+ index = new ProjectIndex();
26
+ });
27
+ describe('Primary Index Operations', () => {
28
+ it('should start empty', () => {
29
+ expect(index.size).toBe(0);
30
+ expect(index.getAllIds()).toEqual([]);
31
+ });
32
+ it('should add and retrieve metadata', () => {
33
+ const metadata = createMockMetadata();
34
+ index.set(metadata);
35
+ expect(index.size).toBe(1);
36
+ expect(index.has('M-001')).toBe(true);
37
+ expect(index.get('M-001')).toEqual(metadata);
38
+ });
39
+ it('should update existing metadata', () => {
40
+ const metadata1 = createMockMetadata({ title: 'Original' });
41
+ const metadata2 = createMockMetadata({ title: 'Updated' });
42
+ index.set(metadata1);
43
+ index.set(metadata2);
44
+ expect(index.size).toBe(1);
45
+ expect(index.get('M-001')?.title).toBe('Updated');
46
+ });
47
+ it('should delete metadata', () => {
48
+ const metadata = createMockMetadata();
49
+ index.set(metadata);
50
+ const deleted = index.delete('M-001');
51
+ expect(deleted).toBe(true);
52
+ expect(index.size).toBe(0);
53
+ expect(index.has('M-001')).toBe(false);
54
+ });
55
+ it('should return false when deleting non-existent entity', () => {
56
+ const deleted = index.delete('M-999');
57
+ expect(deleted).toBe(false);
58
+ });
59
+ it('should clear all data', () => {
60
+ index.set(createMockMetadata({ id: 'M-001' }));
61
+ index.set(createMockMetadata({ id: 'M-002' }));
62
+ index.clear();
63
+ expect(index.size).toBe(0);
64
+ });
65
+ it('should increment version on changes', () => {
66
+ const v0 = index.getVersion();
67
+ index.set(createMockMetadata());
68
+ const v1 = index.getVersion();
69
+ index.delete('M-001');
70
+ const v2 = index.getVersion();
71
+ expect(v1).toBeGreaterThan(v0);
72
+ expect(v2).toBeGreaterThan(v1);
73
+ });
74
+ });
75
+ describe('Secondary Index Operations', () => {
76
+ it('should index by type', () => {
77
+ index.set(createMockMetadata({ id: 'M-001', type: 'milestone' }));
78
+ index.set(createMockMetadata({ id: 'S-001', type: 'story' }));
79
+ index.set(createMockMetadata({ id: 'M-002', type: 'milestone' }));
80
+ const milestones = index.getByType('milestone');
81
+ const stories = index.getByType('story');
82
+ expect(milestones).toHaveLength(2);
83
+ expect(stories).toHaveLength(1);
84
+ });
85
+ it('should index by status', () => {
86
+ index.set(createMockMetadata({ id: 'M-001', status: 'In Progress' }));
87
+ index.set(createMockMetadata({ id: 'M-002', status: 'Completed' }));
88
+ const inProgress = index.getByStatus('In Progress');
89
+ const completed = index.getByStatus('Completed');
90
+ expect(inProgress).toHaveLength(1);
91
+ expect(completed).toHaveLength(1);
92
+ });
93
+ it('should index by workstream', () => {
94
+ index.set(createMockMetadata({ id: 'M-001', workstream: 'engineering' }));
95
+ index.set(createMockMetadata({ id: 'M-002', workstream: 'product' }));
96
+ const engineering = index.getByWorkstream('engineering');
97
+ const product = index.getByWorkstream('product');
98
+ expect(engineering).toHaveLength(1);
99
+ expect(product).toHaveLength(1);
100
+ });
101
+ it('should track archived entities', () => {
102
+ index.set(createMockMetadata({ id: 'M-001', archived: false }));
103
+ index.set(createMockMetadata({ id: 'M-002', archived: true }));
104
+ const archived = index.getArchived();
105
+ expect(archived).toHaveLength(1);
106
+ expect(archived[0].id).toBe('M-002');
107
+ });
108
+ it('should track in-progress entities', () => {
109
+ index.set(createMockMetadata({ id: 'M-001', in_progress: true }));
110
+ index.set(createMockMetadata({ id: 'M-002', in_progress: false }));
111
+ const inProgress = index.getInProgress();
112
+ expect(inProgress).toHaveLength(1);
113
+ expect(inProgress[0].id).toBe('M-001');
114
+ });
115
+ });
116
+ });
117
+ //# sourceMappingURL=index-service.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-service.test.js","sourceRoot":"","sources":["../../../src/services/v2/index-service.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * V2 Lifecycle Manager
3
+ *
4
+ * Manages entity status transitions with validation, conditions, and side effects.
5
+ */
6
+ import { Entity, EntityId, EntityType, EntityStatus } from '../../models/v2-types.js';
7
+ export interface TransitionRule {
8
+ from: EntityStatus;
9
+ to: EntityStatus;
10
+ action: string;
11
+ conditions?: string[];
12
+ side_effects?: string[];
13
+ }
14
+ export interface TransitionResult {
15
+ entity_id: EntityId;
16
+ old_status: EntityStatus;
17
+ new_status: EntityStatus;
18
+ side_effects: string[];
19
+ }
20
+ export interface ConditionResult {
21
+ met: boolean;
22
+ reason?: string;
23
+ }
24
+ /**
25
+ * Manages entity lifecycle transitions.
26
+ */
27
+ export declare class LifecycleManager {
28
+ private transitions;
29
+ private getIncompleteBlockers;
30
+ private getChildren;
31
+ private getParent;
32
+ constructor();
33
+ /** Set callback for getting incomplete blockers */
34
+ setBlockerCallback(fn: (id: EntityId) => EntityId[]): void;
35
+ /** Set callback for getting children */
36
+ setChildrenCallback(fn: (id: EntityId, type?: EntityType) => Entity[]): void;
37
+ /** Set callback for getting parent */
38
+ setParentCallback(fn: (id: EntityId) => Entity | undefined): void;
39
+ /** Check if a transition is allowed */
40
+ canTransition(entity: Entity, newStatus: EntityStatus): {
41
+ allowed: boolean;
42
+ reason?: string;
43
+ };
44
+ /** Execute a status transition */
45
+ transition(entity: Entity, newStatus: EntityStatus): Promise<TransitionResult>;
46
+ /** Get available transitions for an entity */
47
+ getAvailableTransitions(entity: Entity): {
48
+ action: string;
49
+ to: EntityStatus;
50
+ }[];
51
+ private checkCondition;
52
+ private executeSideEffect;
53
+ private getRule;
54
+ /** Check if a status is considered complete */
55
+ isComplete(status: EntityStatus): boolean;
56
+ /** Get the initial status for an entity type */
57
+ getInitialStatus(type: EntityType): EntityStatus;
58
+ }
59
+ //# sourceMappingURL=lifecycle-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lifecycle-manager.d.ts","sourceRoot":"","sources":["../../../src/services/v2/lifecycle-manager.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EACL,MAAM,EACN,QAAQ,EACR,UAAU,EACV,YAAY,EAab,MAAM,0BAA0B,CAAC;AAMlC,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,YAAY,CAAC;IACnB,EAAE,EAAE,YAAY,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;CACzB;AAED,MAAM,WAAW,gBAAgB;IAC/B,SAAS,EAAE,QAAQ,CAAC;IACpB,UAAU,EAAE,YAAY,CAAC;IACzB,UAAU,EAAE,YAAY,CAAC;IACzB,YAAY,EAAE,MAAM,EAAE,CAAC;CACxB;AAED,MAAM,WAAW,eAAe;IAC9B,GAAG,EAAE,OAAO,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AA4DD;;GAEG;AACH,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,WAAW,CAAoC;IAGvD,OAAO,CAAC,qBAAqB,CAA0C;IACvE,OAAO,CAAC,WAAW,CAA2D;IAC9E,OAAO,CAAC,SAAS,CAAyD;;IAiB1E,mDAAmD;IACnD,kBAAkB,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,QAAQ,KAAK,QAAQ,EAAE,GAAG,IAAI;IAI1D,wCAAwC;IACxC,mBAAmB,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,UAAU,KAAK,MAAM,EAAE,GAAG,IAAI;IAI5E,sCAAsC;IACtC,iBAAiB,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,QAAQ,KAAK,MAAM,GAAG,SAAS,GAAG,IAAI;IAQjE,uCAAuC;IACvC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,GAAG;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;IA2B7F,kCAAkC;IAC5B,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,GAAG,OAAO,CAAC,gBAAgB,CAAC;IA8BpF,8CAA8C;IAC9C,uBAAuB,CAAC,MAAM,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,YAAY,CAAA;KAAE,EAAE;IAkB/E,OAAO,CAAC,cAAc;YA0FR,iBAAiB;IAuD/B,OAAO,CAAC,OAAO;IAKf,+CAA+C;IAC/C,UAAU,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO;IAIzC,gDAAgD;IAChD,gBAAgB,CAAC,IAAI,EAAE,UAAU,GAAG,YAAY;CAcjD"}