@jagilber-org/index-server 1.22.0

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 (372) hide show
  1. package/CHANGELOG.md +1354 -0
  2. package/CODE_OF_CONDUCT.md +49 -0
  3. package/CONTRIBUTING.md +99 -0
  4. package/LICENSE +21 -0
  5. package/README.md +228 -0
  6. package/SECURITY.md +50 -0
  7. package/dist/config/configUtils.d.ts +11 -0
  8. package/dist/config/configUtils.js +87 -0
  9. package/dist/config/dashboardConfig.d.ts +46 -0
  10. package/dist/config/dashboardConfig.js +67 -0
  11. package/dist/config/defaultValues.d.ts +63 -0
  12. package/dist/config/defaultValues.js +72 -0
  13. package/dist/config/dirConstants.d.ts +18 -0
  14. package/dist/config/dirConstants.js +29 -0
  15. package/dist/config/featureConfig.d.ts +61 -0
  16. package/dist/config/featureConfig.js +121 -0
  17. package/dist/config/runtimeConfig.d.ts +151 -0
  18. package/dist/config/runtimeConfig.js +380 -0
  19. package/dist/config/serverConfig.d.ts +90 -0
  20. package/dist/config/serverConfig.js +167 -0
  21. package/dist/dashboard/analytics/AnalyticsEngine.d.ts +142 -0
  22. package/dist/dashboard/analytics/AnalyticsEngine.js +373 -0
  23. package/dist/dashboard/analytics/BusinessIntelligence.d.ts +187 -0
  24. package/dist/dashboard/analytics/BusinessIntelligence.js +594 -0
  25. package/dist/dashboard/client/admin.html +2175 -0
  26. package/dist/dashboard/client/chunks/mermaid-layout-elk.esm.min/chunk-SP2CHFBE.mjs +1 -0
  27. package/dist/dashboard/client/chunks/mermaid-layout-elk.esm.min/render-T6MDALS3.mjs +27 -0
  28. package/dist/dashboard/client/css/admin.css +1587 -0
  29. package/dist/dashboard/client/js/admin.auth.js +179 -0
  30. package/dist/dashboard/client/js/admin.boot.js +359 -0
  31. package/dist/dashboard/client/js/admin.config.js +196 -0
  32. package/dist/dashboard/client/js/admin.embeddings.js +426 -0
  33. package/dist/dashboard/client/js/admin.graph.js +615 -0
  34. package/dist/dashboard/client/js/admin.instances.js +120 -0
  35. package/dist/dashboard/client/js/admin.instructions.js +579 -0
  36. package/dist/dashboard/client/js/admin.logs.js +113 -0
  37. package/dist/dashboard/client/js/admin.maintenance.js +393 -0
  38. package/dist/dashboard/client/js/admin.messaging.js +636 -0
  39. package/dist/dashboard/client/js/admin.monitor.js +184 -0
  40. package/dist/dashboard/client/js/admin.overview.js +221 -0
  41. package/dist/dashboard/client/js/admin.performance.js +61 -0
  42. package/dist/dashboard/client/js/admin.sessions.js +292 -0
  43. package/dist/dashboard/client/js/admin.sqlite.js +373 -0
  44. package/dist/dashboard/client/js/admin.utils.js +49 -0
  45. package/dist/dashboard/client/js/chart.umd.js +14 -0
  46. package/dist/dashboard/client/js/elk.bundled.js +6696 -0
  47. package/dist/dashboard/client/js/marked.umd.js +74 -0
  48. package/dist/dashboard/client/js/mermaid.min.js +3022 -0
  49. package/dist/dashboard/client/mermaid-layout-elk.esm.min.mjs +1 -0
  50. package/dist/dashboard/export/DataExporter.d.ts +169 -0
  51. package/dist/dashboard/export/DataExporter.js +737 -0
  52. package/dist/dashboard/export/exporters/csvExporter.d.ts +11 -0
  53. package/dist/dashboard/export/exporters/csvExporter.js +47 -0
  54. package/dist/dashboard/export/exporters/exportTypes.d.ts +89 -0
  55. package/dist/dashboard/export/exporters/exportTypes.js +5 -0
  56. package/dist/dashboard/export/exporters/jsonExporter.d.ts +7 -0
  57. package/dist/dashboard/export/exporters/jsonExporter.js +23 -0
  58. package/dist/dashboard/export/exporters/xmlExporter.d.ts +17 -0
  59. package/dist/dashboard/export/exporters/xmlExporter.js +176 -0
  60. package/dist/dashboard/integration/APIIntegration.d.ts +41 -0
  61. package/dist/dashboard/integration/APIIntegration.js +95 -0
  62. package/dist/dashboard/security/SecurityMonitor.d.ts +167 -0
  63. package/dist/dashboard/security/SecurityMonitor.js +560 -0
  64. package/dist/dashboard/server/AdminPanel.d.ts +195 -0
  65. package/dist/dashboard/server/AdminPanel.js +861 -0
  66. package/dist/dashboard/server/AdminPanelConfig.d.ts +42 -0
  67. package/dist/dashboard/server/AdminPanelConfig.js +80 -0
  68. package/dist/dashboard/server/AdminPanelState.d.ts +47 -0
  69. package/dist/dashboard/server/AdminPanelState.js +215 -0
  70. package/dist/dashboard/server/ApiRoutes.d.ts +17 -0
  71. package/dist/dashboard/server/ApiRoutes.js +184 -0
  72. package/dist/dashboard/server/DashboardServer.d.ts +49 -0
  73. package/dist/dashboard/server/DashboardServer.js +160 -0
  74. package/dist/dashboard/server/FileMetricsStorage.d.ts +49 -0
  75. package/dist/dashboard/server/FileMetricsStorage.js +196 -0
  76. package/dist/dashboard/server/HttpTransport.d.ts +23 -0
  77. package/dist/dashboard/server/HttpTransport.js +116 -0
  78. package/dist/dashboard/server/InstanceManager.d.ts +53 -0
  79. package/dist/dashboard/server/InstanceManager.js +295 -0
  80. package/dist/dashboard/server/KnowledgeStore.d.ts +35 -0
  81. package/dist/dashboard/server/KnowledgeStore.js +105 -0
  82. package/dist/dashboard/server/LeaderElection.d.ts +81 -0
  83. package/dist/dashboard/server/LeaderElection.js +268 -0
  84. package/dist/dashboard/server/MetricsCollector.d.ts +200 -0
  85. package/dist/dashboard/server/MetricsCollector.js +810 -0
  86. package/dist/dashboard/server/SessionPersistenceManager.d.ts +88 -0
  87. package/dist/dashboard/server/SessionPersistenceManager.js +458 -0
  88. package/dist/dashboard/server/ThinClient.d.ts +64 -0
  89. package/dist/dashboard/server/ThinClient.js +237 -0
  90. package/dist/dashboard/server/WebSocketManager.d.ts +161 -0
  91. package/dist/dashboard/server/WebSocketManager.js +448 -0
  92. package/dist/dashboard/server/httpLifecycle.d.ts +17 -0
  93. package/dist/dashboard/server/httpLifecycle.js +35 -0
  94. package/dist/dashboard/server/legacyDashboardHtml.d.ts +9 -0
  95. package/dist/dashboard/server/legacyDashboardHtml.js +618 -0
  96. package/dist/dashboard/server/legacyDashboardStyles.d.ts +5 -0
  97. package/dist/dashboard/server/legacyDashboardStyles.js +490 -0
  98. package/dist/dashboard/server/metricsAggregation.d.ts +252 -0
  99. package/dist/dashboard/server/metricsAggregation.js +210 -0
  100. package/dist/dashboard/server/metricsSerializer.d.ts +25 -0
  101. package/dist/dashboard/server/metricsSerializer.js +195 -0
  102. package/dist/dashboard/server/middleware/ensureLoadedMiddleware.d.ts +25 -0
  103. package/dist/dashboard/server/middleware/ensureLoadedMiddleware.js +24 -0
  104. package/dist/dashboard/server/routes/admin.routes.d.ts +16 -0
  105. package/dist/dashboard/server/routes/admin.routes.js +574 -0
  106. package/dist/dashboard/server/routes/adminAuth.d.ts +4 -0
  107. package/dist/dashboard/server/routes/adminAuth.js +46 -0
  108. package/dist/dashboard/server/routes/alerts.routes.d.ts +7 -0
  109. package/dist/dashboard/server/routes/alerts.routes.js +91 -0
  110. package/dist/dashboard/server/routes/api.feedback.routes.d.ts +73 -0
  111. package/dist/dashboard/server/routes/api.feedback.routes.js +171 -0
  112. package/dist/dashboard/server/routes/api.instructions.routes.d.ts +101 -0
  113. package/dist/dashboard/server/routes/api.instructions.routes.js +213 -0
  114. package/dist/dashboard/server/routes/api.usage.routes.d.ts +57 -0
  115. package/dist/dashboard/server/routes/api.usage.routes.js +374 -0
  116. package/dist/dashboard/server/routes/embeddings.routes.d.ts +6 -0
  117. package/dist/dashboard/server/routes/embeddings.routes.js +246 -0
  118. package/dist/dashboard/server/routes/graph.routes.d.ts +6 -0
  119. package/dist/dashboard/server/routes/graph.routes.js +279 -0
  120. package/dist/dashboard/server/routes/index.d.ts +39 -0
  121. package/dist/dashboard/server/routes/index.js +229 -0
  122. package/dist/dashboard/server/routes/instances.routes.d.ts +6 -0
  123. package/dist/dashboard/server/routes/instances.routes.js +35 -0
  124. package/dist/dashboard/server/routes/instructions.routes.d.ts +8 -0
  125. package/dist/dashboard/server/routes/instructions.routes.js +268 -0
  126. package/dist/dashboard/server/routes/knowledge.routes.d.ts +6 -0
  127. package/dist/dashboard/server/routes/knowledge.routes.js +80 -0
  128. package/dist/dashboard/server/routes/logs.routes.d.ts +6 -0
  129. package/dist/dashboard/server/routes/logs.routes.js +166 -0
  130. package/dist/dashboard/server/routes/messaging.routes.d.ts +16 -0
  131. package/dist/dashboard/server/routes/messaging.routes.js +307 -0
  132. package/dist/dashboard/server/routes/metrics.routes.d.ts +10 -0
  133. package/dist/dashboard/server/routes/metrics.routes.js +335 -0
  134. package/dist/dashboard/server/routes/scripts.routes.d.ts +9 -0
  135. package/dist/dashboard/server/routes/scripts.routes.js +84 -0
  136. package/dist/dashboard/server/routes/sqlite.routes.d.ts +9 -0
  137. package/dist/dashboard/server/routes/sqlite.routes.js +570 -0
  138. package/dist/dashboard/server/routes/status.routes.d.ts +7 -0
  139. package/dist/dashboard/server/routes/status.routes.js +179 -0
  140. package/dist/dashboard/server/routes/synthetic.routes.d.ts +7 -0
  141. package/dist/dashboard/server/routes/synthetic.routes.js +197 -0
  142. package/dist/dashboard/server/routes/tools.routes.d.ts +6 -0
  143. package/dist/dashboard/server/routes/tools.routes.js +47 -0
  144. package/dist/dashboard/server/routes/usage.routes.d.ts +6 -0
  145. package/dist/dashboard/server/routes/usage.routes.js +26 -0
  146. package/dist/dashboard/server/wsInit.d.ts +16 -0
  147. package/dist/dashboard/server/wsInit.js +35 -0
  148. package/dist/externalClientLib.d.ts +1 -0
  149. package/dist/externalClientLib.js +2 -0
  150. package/dist/minimal/index.d.ts +1 -0
  151. package/dist/minimal/index.js +140 -0
  152. package/dist/models/SessionPersistence.d.ts +115 -0
  153. package/dist/models/SessionPersistence.js +66 -0
  154. package/dist/models/instruction.d.ts +46 -0
  155. package/dist/models/instruction.js +2 -0
  156. package/dist/perf/benchmark.d.ts +1 -0
  157. package/dist/perf/benchmark.js +50 -0
  158. package/dist/portableClientWrapper.d.ts +1 -0
  159. package/dist/portableClientWrapper.js +2 -0
  160. package/dist/schemas/index.d.ts +132 -0
  161. package/dist/schemas/index.js +372 -0
  162. package/dist/scripts/runPerformanceBaseline.d.ts +1 -0
  163. package/dist/scripts/runPerformanceBaseline.js +17 -0
  164. package/dist/server/backgroundServicesStartup.d.ts +3 -0
  165. package/dist/server/backgroundServicesStartup.js +51 -0
  166. package/dist/server/handshakeManager.d.ts +25 -0
  167. package/dist/server/handshakeManager.js +470 -0
  168. package/dist/server/index-server.d.ts +38 -0
  169. package/dist/server/index-server.js +620 -0
  170. package/dist/server/multiInstanceStartup.d.ts +6 -0
  171. package/dist/server/multiInstanceStartup.js +132 -0
  172. package/dist/server/registry.d.ts +44 -0
  173. package/dist/server/registry.js +236 -0
  174. package/dist/server/sdkServer.d.ts +8 -0
  175. package/dist/server/sdkServer.js +299 -0
  176. package/dist/server/shutdownGuard.d.ts +41 -0
  177. package/dist/server/shutdownGuard.js +52 -0
  178. package/dist/server/startupDiagnostics.d.ts +2 -0
  179. package/dist/server/startupDiagnostics.js +33 -0
  180. package/dist/server/thin-client.d.ts +22 -0
  181. package/dist/server/thin-client.js +111 -0
  182. package/dist/server/transport.d.ts +41 -0
  183. package/dist/server/transport.js +312 -0
  184. package/dist/server/transportFactory.d.ts +21 -0
  185. package/dist/server/transportFactory.js +429 -0
  186. package/dist/services/atomicFs.d.ts +22 -0
  187. package/dist/services/atomicFs.js +103 -0
  188. package/dist/services/auditLog.d.ts +38 -0
  189. package/dist/services/auditLog.js +142 -0
  190. package/dist/services/autoBackup.d.ts +14 -0
  191. package/dist/services/autoBackup.js +171 -0
  192. package/dist/services/autoSplit.d.ts +32 -0
  193. package/dist/services/autoSplit.js +113 -0
  194. package/dist/services/backupZip.d.ts +25 -0
  195. package/dist/services/backupZip.js +112 -0
  196. package/dist/services/bootstrapGating.d.ts +123 -0
  197. package/dist/services/bootstrapGating.js +221 -0
  198. package/dist/services/canonical.d.ts +23 -0
  199. package/dist/services/canonical.js +65 -0
  200. package/dist/services/categoryRules.d.ts +7 -0
  201. package/dist/services/categoryRules.js +37 -0
  202. package/dist/services/classificationService.d.ts +42 -0
  203. package/dist/services/classificationService.js +168 -0
  204. package/dist/services/embeddingService.d.ts +62 -0
  205. package/dist/services/embeddingService.js +264 -0
  206. package/dist/services/errors.d.ts +22 -0
  207. package/dist/services/errors.js +31 -0
  208. package/dist/services/featureFlags.d.ts +25 -0
  209. package/dist/services/featureFlags.js +89 -0
  210. package/dist/services/features.d.ts +13 -0
  211. package/dist/services/features.js +35 -0
  212. package/dist/services/handlers/instructions.add.d.ts +1 -0
  213. package/dist/services/handlers/instructions.add.js +510 -0
  214. package/dist/services/handlers/instructions.groom.d.ts +1 -0
  215. package/dist/services/handlers/instructions.groom.js +575 -0
  216. package/dist/services/handlers/instructions.import.d.ts +1 -0
  217. package/dist/services/handlers/instructions.import.js +205 -0
  218. package/dist/services/handlers/instructions.patch.d.ts +1 -0
  219. package/dist/services/handlers/instructions.patch.js +121 -0
  220. package/dist/services/handlers/instructions.query.d.ts +159 -0
  221. package/dist/services/handlers/instructions.query.js +469 -0
  222. package/dist/services/handlers/instructions.reload.d.ts +1 -0
  223. package/dist/services/handlers/instructions.reload.js +13 -0
  224. package/dist/services/handlers/instructions.remove.d.ts +1 -0
  225. package/dist/services/handlers/instructions.remove.js +122 -0
  226. package/dist/services/handlers/instructions.shared.d.ts +32 -0
  227. package/dist/services/handlers/instructions.shared.js +91 -0
  228. package/dist/services/handlers.activation.d.ts +1 -0
  229. package/dist/services/handlers.activation.js +203 -0
  230. package/dist/services/handlers.bootstrap.d.ts +1 -0
  231. package/dist/services/handlers.bootstrap.js +38 -0
  232. package/dist/services/handlers.dashboardConfig.d.ts +34 -0
  233. package/dist/services/handlers.dashboardConfig.js +110 -0
  234. package/dist/services/handlers.diagnostics.d.ts +1 -0
  235. package/dist/services/handlers.diagnostics.js +64 -0
  236. package/dist/services/handlers.feedback.d.ts +15 -0
  237. package/dist/services/handlers.feedback.js +389 -0
  238. package/dist/services/handlers.gates.d.ts +1 -0
  239. package/dist/services/handlers.gates.js +47 -0
  240. package/dist/services/handlers.graph.d.ts +53 -0
  241. package/dist/services/handlers.graph.js +231 -0
  242. package/dist/services/handlers.help.d.ts +1 -0
  243. package/dist/services/handlers.help.js +119 -0
  244. package/dist/services/handlers.instructionSchema.d.ts +1 -0
  245. package/dist/services/handlers.instructionSchema.js +227 -0
  246. package/dist/services/handlers.instructions.d.ts +8 -0
  247. package/dist/services/handlers.instructions.js +14 -0
  248. package/dist/services/handlers.instructionsDiagnostics.d.ts +1 -0
  249. package/dist/services/handlers.instructionsDiagnostics.js +14 -0
  250. package/dist/services/handlers.integrity.d.ts +1 -0
  251. package/dist/services/handlers.integrity.js +35 -0
  252. package/dist/services/handlers.manifest.d.ts +1 -0
  253. package/dist/services/handlers.manifest.js +24 -0
  254. package/dist/services/handlers.messaging.d.ts +12 -0
  255. package/dist/services/handlers.messaging.js +203 -0
  256. package/dist/services/handlers.metrics.d.ts +1 -0
  257. package/dist/services/handlers.metrics.js +43 -0
  258. package/dist/services/handlers.promote.d.ts +1 -0
  259. package/dist/services/handlers.promote.js +326 -0
  260. package/dist/services/handlers.prompt.d.ts +1 -0
  261. package/dist/services/handlers.prompt.js +7 -0
  262. package/dist/services/handlers.search.d.ts +69 -0
  263. package/dist/services/handlers.search.js +669 -0
  264. package/dist/services/handlers.testPrimitive.d.ts +1 -0
  265. package/dist/services/handlers.testPrimitive.js +5 -0
  266. package/dist/services/handlers.trace.d.ts +1 -0
  267. package/dist/services/handlers.trace.js +35 -0
  268. package/dist/services/handlers.usage.d.ts +1 -0
  269. package/dist/services/handlers.usage.js +11 -0
  270. package/dist/services/hotScore.d.ts +137 -0
  271. package/dist/services/hotScore.js +244 -0
  272. package/dist/services/indexContext.d.ts +117 -0
  273. package/dist/services/indexContext.js +989 -0
  274. package/dist/services/indexLoader.d.ts +44 -0
  275. package/dist/services/indexLoader.js +920 -0
  276. package/dist/services/indexRepository.d.ts +32 -0
  277. package/dist/services/indexRepository.js +71 -0
  278. package/dist/services/indexingService.d.ts +1 -0
  279. package/dist/services/indexingService.js +2 -0
  280. package/dist/services/instructions.dispatcher.d.ts +1 -0
  281. package/dist/services/instructions.dispatcher.js +231 -0
  282. package/dist/services/logPrefix.d.ts +1 -0
  283. package/dist/services/logPrefix.js +30 -0
  284. package/dist/services/logger.d.ts +52 -0
  285. package/dist/services/logger.js +268 -0
  286. package/dist/services/manifestManager.d.ts +82 -0
  287. package/dist/services/manifestManager.js +200 -0
  288. package/dist/services/messaging/agentMailbox.d.ts +60 -0
  289. package/dist/services/messaging/agentMailbox.js +353 -0
  290. package/dist/services/messaging/messagingPersistence.d.ts +20 -0
  291. package/dist/services/messaging/messagingPersistence.js +111 -0
  292. package/dist/services/messaging/messagingTypes.d.ts +150 -0
  293. package/dist/services/messaging/messagingTypes.js +66 -0
  294. package/dist/services/ownershipService.d.ts +1 -0
  295. package/dist/services/ownershipService.js +36 -0
  296. package/dist/services/performanceBaseline.d.ts +19 -0
  297. package/dist/services/performanceBaseline.js +210 -0
  298. package/dist/services/preflight.d.ts +12 -0
  299. package/dist/services/preflight.js +79 -0
  300. package/dist/services/promptReviewService.d.ts +44 -0
  301. package/dist/services/promptReviewService.js +101 -0
  302. package/dist/services/responseEnvelope.d.ts +6 -0
  303. package/dist/services/responseEnvelope.js +25 -0
  304. package/dist/services/seedBootstrap.d.ts +34 -0
  305. package/dist/services/seedBootstrap.js +259 -0
  306. package/dist/services/storage/factory.d.ts +17 -0
  307. package/dist/services/storage/factory.js +35 -0
  308. package/dist/services/storage/hashUtils.d.ts +11 -0
  309. package/dist/services/storage/hashUtils.js +35 -0
  310. package/dist/services/storage/index.d.ts +12 -0
  311. package/dist/services/storage/index.js +18 -0
  312. package/dist/services/storage/jsonFileStore.d.ts +32 -0
  313. package/dist/services/storage/jsonFileStore.js +241 -0
  314. package/dist/services/storage/migrationEngine.d.ts +35 -0
  315. package/dist/services/storage/migrationEngine.js +93 -0
  316. package/dist/services/storage/sqliteMessageStore.d.ts +53 -0
  317. package/dist/services/storage/sqliteMessageStore.js +146 -0
  318. package/dist/services/storage/sqliteSchema.d.ts +12 -0
  319. package/dist/services/storage/sqliteSchema.js +123 -0
  320. package/dist/services/storage/sqliteStore.d.ts +42 -0
  321. package/dist/services/storage/sqliteStore.js +361 -0
  322. package/dist/services/storage/sqliteUsageStore.d.ts +35 -0
  323. package/dist/services/storage/sqliteUsageStore.js +94 -0
  324. package/dist/services/storage/types.d.ts +171 -0
  325. package/dist/services/storage/types.js +12 -0
  326. package/dist/services/toolHandlers.d.ts +23 -0
  327. package/dist/services/toolHandlers.js +50 -0
  328. package/dist/services/toolRegistry.d.ts +20 -0
  329. package/dist/services/toolRegistry.js +490 -0
  330. package/dist/services/toolRegistry.zod.d.ts +10 -0
  331. package/dist/services/toolRegistry.zod.js +325 -0
  332. package/dist/services/tracing.d.ts +26 -0
  333. package/dist/services/tracing.js +260 -0
  334. package/dist/services/usageBuckets.d.ts +161 -0
  335. package/dist/services/usageBuckets.js +364 -0
  336. package/dist/services/validationService.d.ts +38 -0
  337. package/dist/services/validationService.js +125 -0
  338. package/dist/utils/BufferRing.d.ts +203 -0
  339. package/dist/utils/BufferRing.js +551 -0
  340. package/dist/utils/BufferRingExamples.d.ts +55 -0
  341. package/dist/utils/BufferRingExamples.js +188 -0
  342. package/dist/utils/envUtils.d.ts +42 -0
  343. package/dist/utils/envUtils.js +80 -0
  344. package/dist/utils/memoryMonitor.d.ts +83 -0
  345. package/dist/utils/memoryMonitor.js +275 -0
  346. package/dist/versioning/schemaVersion.d.ts +6 -0
  347. package/dist/versioning/schemaVersion.js +94 -0
  348. package/package.json +139 -0
  349. package/schemas/README.md +13 -0
  350. package/schemas/feedback-entry.schema.json +27 -0
  351. package/schemas/graph-export-v2.schema.json +60 -0
  352. package/schemas/index-server.code-schema.json +40670 -0
  353. package/schemas/instruction.schema.json +262 -0
  354. package/schemas/json-schema/SessionPersistence-persisted-admin-session.schema.json +54 -0
  355. package/schemas/json-schema/SessionPersistence-persisted-session-history-entry.schema.json +51 -0
  356. package/schemas/json-schema/SessionPersistence-persisted-web-socket-connection.schema.json +54 -0
  357. package/schemas/json-schema/SessionPersistence-session-persistence-config.schema.json +110 -0
  358. package/schemas/json-schema/SessionPersistence-session-persistence-data.schema.json +229 -0
  359. package/schemas/json-schema/SessionPersistence-session-persistence-manifest.schema.json +109 -0
  360. package/schemas/json-schema/SessionPersistence-session-persistence-metadata.schema.json +55 -0
  361. package/schemas/json-schema/instruction-audience-scope.schema.json +14 -0
  362. package/schemas/json-schema/instruction-content-type.schema.json +17 -0
  363. package/schemas/json-schema/instruction-instruction-entry.schema.json +210 -0
  364. package/schemas/json-schema/instruction-requirement-level.schema.json +16 -0
  365. package/schemas/manifest.json +78 -0
  366. package/schemas/manifest.schema.json +33 -0
  367. package/schemas/usage-batch.schema.json +16 -0
  368. package/schemas/usage-buckets.schema.json +30 -0
  369. package/schemas/usage-event.schema.json +17 -0
  370. package/scripts/copy-dashboard-assets.mjs +170 -0
  371. package/scripts/dist/README.md +15 -0
  372. package/scripts/setup-hooks.cjs +28 -0
@@ -0,0 +1,469 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.instructionActions = void 0;
7
+ const fs_1 = __importDefault(require("fs"));
8
+ const path_1 = __importDefault(require("path"));
9
+ const registry_1 = require("../../server/registry");
10
+ const indexContext_1 = require("../indexContext");
11
+ const bootstrapGating_1 = require("../bootstrapGating");
12
+ const classificationService_1 = require("../classificationService");
13
+ const features_1 = require("../features");
14
+ const runtimeConfig_1 = require("../../config/runtimeConfig");
15
+ const tracing_1 = require("../tracing");
16
+ const handlers_search_1 = require("../handlers.search");
17
+ const instructions_shared_1 = require("./instructions.shared");
18
+ // Legacy individual instruction handlers removed in favor of unified dispatcher (index_dispatch).
19
+ // Internal implementation functions retained below for dispatcher direct invocation.
20
+ exports.instructionActions = {
21
+ list: (p) => {
22
+ let st = (0, indexContext_1.ensureLoaded)();
23
+ const originalHash = st.hash;
24
+ let items = st.list;
25
+ if (p?.category) {
26
+ const c = p.category.toLowerCase();
27
+ items = items.filter(i => i.categories.includes(c));
28
+ }
29
+ if (p?.contentType) {
30
+ const ct = p.contentType;
31
+ items = items.filter(i => (i.contentType || 'instruction') === ct);
32
+ }
33
+ let attemptedReload = false;
34
+ const attemptedLate = false;
35
+ if (p?.expectId) {
36
+ const idx = items.findIndex(i => i.id === p.expectId);
37
+ if (idx > 0) {
38
+ const target = items[idx];
39
+ items = [target, ...items.slice(0, idx), ...items.slice(idx + 1)];
40
+ }
41
+ }
42
+ if (p?.expectId) {
43
+ try {
44
+ const inIndex = st.byId.has(p.expectId);
45
+ if (!inIndex) {
46
+ attemptedReload = true;
47
+ (0, indexContext_1.invalidate)();
48
+ st = (0, indexContext_1.ensureLoaded)();
49
+ items = st.list;
50
+ if (p.category) {
51
+ const c2 = p.category.toLowerCase();
52
+ items = items.filter(i => i.categories.includes(c2));
53
+ }
54
+ if (st.byId.has(p.expectId)) {
55
+ const idx2 = items.findIndex(i => i.id === p.expectId);
56
+ if (idx2 > 0) {
57
+ const target2 = items[idx2];
58
+ items = [target2, ...items.slice(0, idx2), ...items.slice(idx2 + 1)];
59
+ }
60
+ }
61
+ }
62
+ }
63
+ catch { /* ignore repair errors */ }
64
+ }
65
+ if ((0, instructions_shared_1.traceVisibility)()) {
66
+ try {
67
+ const idsSample = items.slice(0, 5).map(i => i.id);
68
+ const expectId = p?.expectId;
69
+ const expectinIndex = expectId ? st.byId.has(expectId) : undefined;
70
+ (0, tracing_1.emitTrace)('[trace:list]', { total: st.list.length, filtered: items.length, sample: idsSample, expectId, expectinIndex, attemptedReload, attemptedLate, originalHash, finalHash: st.hash });
71
+ }
72
+ catch { /* ignore */ }
73
+ }
74
+ const totalCount = items.length;
75
+ // Apply offset/limit pagination when provided via REST bridge callers
76
+ const offset = typeof p?.offset === 'number' && p.offset > 0 ? p.offset : 0;
77
+ if (offset > 0) {
78
+ items = items.slice(offset);
79
+ }
80
+ if (typeof p?.limit === 'number' && p.limit > 0) {
81
+ items = items.slice(0, p.limit);
82
+ }
83
+ const resp = (0, instructions_shared_1.limitResponseSize)({ hash: st.hash, count: totalCount, items });
84
+ return resp;
85
+ },
86
+ listScoped: (p) => {
87
+ const st = (0, indexContext_1.ensureLoaded)();
88
+ const userId = p.userId?.toLowerCase();
89
+ const workspaceId = p.workspaceId?.toLowerCase();
90
+ const teamIds = (p.teamIds || []).map(t => t.toLowerCase());
91
+ const all = st.list;
92
+ const matchUser = userId ? all.filter(e => (e.userId || '').toLowerCase() === userId) : [];
93
+ if (matchUser.length)
94
+ return { hash: st.hash, count: matchUser.length, scope: 'user', items: matchUser };
95
+ const matchWorkspace = workspaceId ? all.filter(e => (e.workspaceId || '').toLowerCase() === workspaceId) : [];
96
+ if (matchWorkspace.length)
97
+ return { hash: st.hash, count: matchWorkspace.length, scope: 'workspace', items: matchWorkspace };
98
+ const teamSet = new Set(teamIds);
99
+ const matchTeams = teamIds.length ? all.filter(e => Array.isArray(e.teamIds) && e.teamIds.some(t => teamSet.has(t.toLowerCase()))) : [];
100
+ if (matchTeams.length)
101
+ return { hash: st.hash, count: matchTeams.length, scope: 'team', items: matchTeams };
102
+ const audienceAll = all.filter(e => e.audience === 'all');
103
+ return { hash: st.hash, count: audienceAll.length, scope: 'all', items: audienceAll };
104
+ },
105
+ get: (p) => {
106
+ const st = (0, indexContext_1.ensureLoaded)();
107
+ const item = st.byId.get(p.id);
108
+ if (!item && (0, runtimeConfig_1.getRuntimeConfig)().instructions.strictVisibility) {
109
+ const enhanced = exports.instructionActions.getEnhanced({ id: p.id });
110
+ if (enhanced.item)
111
+ return { hash: enhanced.hash || st.hash, item: enhanced.item };
112
+ }
113
+ if ((0, instructions_shared_1.traceVisibility)()) {
114
+ const dir = (0, indexContext_1.getInstructionsDir)();
115
+ (0, tracing_1.emitTrace)('[trace:get]', { dir, id: p.id, found: !!item, total: st.list.length, strict: (0, runtimeConfig_1.getRuntimeConfig)().instructions.strictVisibility });
116
+ (0, instructions_shared_1.traceInstructionVisibility)(p.id, item ? 'get-found' : 'get-not-found');
117
+ if (!item)
118
+ (0, instructions_shared_1.traceEnvSnapshot)('get-not-found');
119
+ }
120
+ return item ? { hash: st.hash, item } : { notFound: true, id: p.id, hint: `No instruction found with id "${p.id}". Use action="search" with q="<keyword>" to find valid ids, or action="list" to see all.`, example: { action: 'get', id: 'valid-instruction-id' } };
121
+ },
122
+ getEnhanced: (p) => {
123
+ let st = (0, indexContext_1.ensureLoaded)();
124
+ let item = st.byId.get(p.id);
125
+ if (item)
126
+ return { hash: st.hash, item };
127
+ // Not in current in-memory index — force reload from store (covers SQLite and JSON)
128
+ let repaired = false;
129
+ try {
130
+ (0, instructions_shared_1.traceInstructionVisibility)(p.id, 'getEnhanced-start');
131
+ (0, indexContext_1.invalidate)();
132
+ st = (0, indexContext_1.ensureLoaded)();
133
+ item = st.byId.get(p.id);
134
+ if (item) {
135
+ repaired = true;
136
+ }
137
+ if (!repaired) {
138
+ (0, features_1.incrementCounter)('instructions:getLateMaterializeNotFound');
139
+ }
140
+ }
141
+ catch { /* swallow */ }
142
+ if ((0, instructions_shared_1.traceVisibility)()) {
143
+ (0, tracing_1.emitTrace)('[trace:get:late-materialize]', { id: p.id, repaired });
144
+ }
145
+ (0, instructions_shared_1.traceInstructionVisibility)(p.id, 'getEnhanced-end', { repaired, finalFound: !!item });
146
+ return item ? { hash: st.hash, item } : { notFound: true };
147
+ },
148
+ search: async (p) => {
149
+ const providedKeywords = Array.isArray(p.keywords)
150
+ ? p.keywords.filter((keyword) => typeof keyword === 'string' && keyword.trim().length > 0)
151
+ : [];
152
+ const keywords = providedKeywords.length > 0
153
+ ? providedKeywords
154
+ : (typeof p.q === 'string' && p.q.trim().length > 0 ? [p.q] : []);
155
+ const searchResult = await (0, handlers_search_1.handleInstructionsSearch)({
156
+ keywords,
157
+ mode: p.mode,
158
+ limit: p.limit,
159
+ includeCategories: p.includeCategories ?? true,
160
+ caseSensitive: p.caseSensitive,
161
+ contentType: p.contentType,
162
+ });
163
+ const st = (0, indexContext_1.ensureLoaded)();
164
+ const items = searchResult.results
165
+ .map(result => st.byId.get(result.instructionId))
166
+ .filter((item) => !!item);
167
+ if ((0, instructions_shared_1.traceVisibility)()) {
168
+ const dir = (0, indexContext_1.getInstructionsDir)();
169
+ const sample = items.slice(0, 5).map(i => i.id);
170
+ (0, tracing_1.emitTrace)('[trace:search]', { dir, q: keywords.join(' '), matches: items.length, sample });
171
+ }
172
+ return {
173
+ hash: st.hash,
174
+ count: items.length,
175
+ totalMatches: searchResult.totalMatches,
176
+ items,
177
+ results: searchResult.results,
178
+ query: searchResult.query,
179
+ autoTokenized: searchResult.autoTokenized,
180
+ hints: searchResult.hints,
181
+ };
182
+ },
183
+ diff: (p) => {
184
+ const st = (0, indexContext_1.ensureLoaded)();
185
+ const clientHash = p.clientHash;
186
+ const known = p.known;
187
+ if (!known && clientHash && clientHash === st.hash)
188
+ return { upToDate: true, hash: st.hash };
189
+ if (known) {
190
+ const map = new Map();
191
+ for (const k of known) {
192
+ if (k && k.id && !map.has(k.id))
193
+ map.set(k.id, k.sourceHash);
194
+ }
195
+ const added = [];
196
+ const updated = [];
197
+ const removed = [];
198
+ for (const e of st.list) {
199
+ const prev = map.get(e.id);
200
+ if (prev === undefined)
201
+ added.push(e);
202
+ else if (prev !== e.sourceHash)
203
+ updated.push(e);
204
+ }
205
+ for (const id of map.keys()) {
206
+ if (!st.byId.has(id))
207
+ removed.push(id);
208
+ }
209
+ if (!added.length && !updated.length && !removed.length && clientHash === st.hash)
210
+ return { upToDate: true, hash: st.hash };
211
+ return { hash: st.hash, added, updated, removed };
212
+ }
213
+ if (!clientHash || clientHash !== st.hash)
214
+ return { hash: st.hash, changed: st.list };
215
+ return { upToDate: true, hash: st.hash };
216
+ },
217
+ export: (p) => {
218
+ const st = (0, indexContext_1.ensureLoaded)();
219
+ let items = st.list;
220
+ if (p?.ids?.length) {
221
+ const want = new Set(p.ids);
222
+ items = items.filter(i => want.has(i.id));
223
+ }
224
+ if (p?.metaOnly) {
225
+ items = items.map(i => ({ ...i, body: '' }));
226
+ }
227
+ return (0, instructions_shared_1.limitResponseSize)({ hash: st.hash, count: items.length, items });
228
+ },
229
+ query: (p) => {
230
+ const st = (0, indexContext_1.ensureLoaded)();
231
+ if ((0, instructions_shared_1.traceVisibility)()) {
232
+ try {
233
+ (0, tracing_1.emitTrace)('[trace:query:start]', { pid: process.pid, dir: (0, indexContext_1.getInstructionsDir)(), keys: Object.keys(p || {}), categoriesAny: p.categoriesAny, categoriesAll: p.categoriesAll, excludeCategories: p.excludeCategories });
234
+ }
235
+ catch { /* ignore */ }
236
+ }
237
+ const norm = (arr) => Array.from(new Set((arr || []).filter(x => typeof x === 'string' && x.trim()).map(x => x.toLowerCase())));
238
+ const catsAll = norm(p.categoriesAll);
239
+ const catsAny = norm(p.categoriesAny);
240
+ const catsEx = norm(p.excludeCategories);
241
+ const tierSet = new Set((p.priorityTiers || []).filter(t => ['P1', 'P2', 'P3', 'P4'].includes(String(t))));
242
+ const reqSet = new Set((p.requirements || []).filter(r => ['mandatory', 'critical', 'recommended', 'optional', 'deprecated'].includes(String(r))));
243
+ const prMin = typeof p.priorityMin === 'number' ? p.priorityMin : undefined;
244
+ const prMax = typeof p.priorityMax === 'number' ? p.priorityMax : undefined;
245
+ const text = (p.text || '').toLowerCase().trim();
246
+ let items = st.list;
247
+ const instructionsCfg = (0, runtimeConfig_1.getRuntimeConfig)().instructions;
248
+ const diagActive = instructionsCfg.traceQueryDiag && (catsAll.length || catsAny.length || catsEx.length || text.length);
249
+ const stages = [];
250
+ const pushStage = (stage, note) => { if (diagActive)
251
+ stages.push({ stage, count: items.length, note }); };
252
+ if (diagActive)
253
+ pushStage('loaded');
254
+ let preFilterSample;
255
+ if (diagActive) {
256
+ preFilterSample = items.slice(0, 25).map(i => i.id);
257
+ }
258
+ const preCount = items.length;
259
+ if (catsAll.length) {
260
+ items = items.filter(e => catsAll.every(c => e.categories.includes(c)));
261
+ pushStage('catsAll');
262
+ }
263
+ if (catsAny.length) {
264
+ const before = items.length;
265
+ items = items.filter(e => e.categories.some(c => catsAny.includes(c)));
266
+ pushStage('catsAny', before !== items.length ? undefined : 'no-change');
267
+ }
268
+ if (catsEx.length) {
269
+ items = items.filter(e => !e.categories.some(c => catsEx.includes(c)));
270
+ pushStage('catsEx');
271
+ }
272
+ if (p?.contentType) {
273
+ const ct = p.contentType;
274
+ items = items.filter(i => (i.contentType || 'instruction') === ct);
275
+ pushStage('contentType');
276
+ }
277
+ if (prMin !== undefined) {
278
+ items = items.filter(e => e.priority >= prMin);
279
+ pushStage('prMin');
280
+ }
281
+ if (prMax !== undefined) {
282
+ items = items.filter(e => e.priority <= prMax);
283
+ pushStage('prMax');
284
+ }
285
+ if (tierSet.size) {
286
+ items = items.filter(e => e.priorityTier && tierSet.has(e.priorityTier));
287
+ pushStage('tiers');
288
+ }
289
+ if (reqSet.size) {
290
+ items = items.filter(e => reqSet.has(e.requirement));
291
+ pushStage('requirements');
292
+ }
293
+ if (text) {
294
+ items = items.filter(e => e.title.toLowerCase().includes(text) || e.body.toLowerCase().includes(text) || (e.semanticSummary || '').toLowerCase().includes(text));
295
+ pushStage('text');
296
+ }
297
+ try {
298
+ const recent = st._recentAdds;
299
+ if (recent) {
300
+ const now = Date.now();
301
+ const GRACE = 300;
302
+ for (const [id, meta] of Object.entries(recent)) {
303
+ if (now - meta.ts > GRACE)
304
+ continue;
305
+ if (items.some(e => e.id === id))
306
+ continue;
307
+ const catMatchAll = !catsAll.length || catsAll.every(c => meta.categories.includes(c));
308
+ const catMatchAny = !catsAny.length || meta.categories.some(c => catsAny.includes(c));
309
+ const catExcluded = catsEx.length && meta.categories.some(c => catsEx.includes(c));
310
+ if (catMatchAll && catMatchAny && !catExcluded) {
311
+ const injected = st.byId.get(id);
312
+ if (injected) {
313
+ items = items.concat([injected]);
314
+ if ((0, instructions_shared_1.traceVisibility)())
315
+ (0, tracing_1.emitTrace)('[trace:query:recent-add-injected]', { id, graceMs: now - meta.ts });
316
+ }
317
+ }
318
+ }
319
+ }
320
+ }
321
+ catch { /* ignore fallback */ }
322
+ const total = items.length;
323
+ const limit = Math.min(Math.max((p.limit ?? 100), 1), 1000);
324
+ const offset = Math.max((p.offset ?? 0), 0);
325
+ const paged = items.slice(offset, offset + limit);
326
+ if ((0, instructions_shared_1.traceVisibility)()) {
327
+ const sample = paged.slice(0, 5).map(i => i.id);
328
+ (0, tracing_1.emitTrace)('[trace:query]', { applied: { catsAll, catsAny, catsEx, prMin, prMax, tiers: [...tierSet], requirements: [...reqSet], text: text || undefined }, preCount, total, returned: paged.length, sample });
329
+ if (diagActive) {
330
+ const suspicious = paged.length === 0 || paged.length < Math.min(3, preCount);
331
+ if (suspicious) {
332
+ const categoryDiagnostics = {};
333
+ for (const c of catsAny) {
334
+ let present = 0;
335
+ let passed = 0;
336
+ const sampleIds = [];
337
+ for (const e of st.list) {
338
+ if (e.categories.includes(c)) {
339
+ present++;
340
+ if (items.includes(e)) {
341
+ passed++;
342
+ if (sampleIds.length < 5)
343
+ sampleIds.push(e.id);
344
+ }
345
+ }
346
+ }
347
+ categoryDiagnostics[c] = { present, passedAllFilters: passed, sampleIds };
348
+ }
349
+ (0, tracing_1.emitTrace)('[trace:query:diag]', { preFilterSample, stages, categoryDiagnostics, finalReturned: paged.length, totalAfterFilters: total, preCount });
350
+ }
351
+ }
352
+ }
353
+ return { hash: st.hash, total, count: paged.length, offset, limit, items: paged, applied: { catsAll, catsAny, catsEx, prMin, prMax, tiers: [...tierSet], requirements: [...reqSet], text: text || undefined } };
354
+ },
355
+ categories: (_p) => {
356
+ const st = (0, indexContext_1.ensureLoaded)();
357
+ const counts = new Map();
358
+ for (const e of st.list) {
359
+ for (const c of e.categories) {
360
+ counts.set(c, (counts.get(c) || 0) + 1);
361
+ }
362
+ }
363
+ const categories = [...counts.entries()].sort((a, b) => a[0].localeCompare(b[0])).map(([name, count]) => ({ name, count }));
364
+ return { count: categories.length, categories };
365
+ },
366
+ dir: () => {
367
+ const dir = (0, indexContext_1.getInstructionsDir)();
368
+ const st = (0, indexContext_1.ensureLoaded)();
369
+ const files = st.list.map(e => `${e.id}.json`).sort();
370
+ return { dir, filesCount: files.length, files };
371
+ }
372
+ };
373
+ // Deep inspection (diagnostics) — reads from store, not disk
374
+ (0, registry_1.registerHandler)('index_inspect', (p) => {
375
+ const id = p.id;
376
+ if (!id)
377
+ return { error: 'missing id' };
378
+ const st = (0, indexContext_1.ensureLoaded)();
379
+ const entry = st.byId.get(id);
380
+ if (!entry)
381
+ return { id, exists: false, fileMissing: true };
382
+ let schemaErrors;
383
+ let classificationIssues;
384
+ let normalized;
385
+ try {
386
+ const rec = entry;
387
+ const missing = [];
388
+ if (!rec.id)
389
+ missing.push('missing id');
390
+ if (!rec.title)
391
+ missing.push('missing title');
392
+ if (!rec.body)
393
+ missing.push('missing body');
394
+ if (missing.length)
395
+ schemaErrors = missing.join(', ');
396
+ const classifier = new classificationService_1.ClassificationService();
397
+ if (!schemaErrors) {
398
+ classificationIssues = classifier.validate(rec);
399
+ if (!classificationIssues.length) {
400
+ normalized = classifier.normalize(rec);
401
+ }
402
+ }
403
+ }
404
+ catch (err) {
405
+ schemaErrors = err.message;
406
+ }
407
+ return { id, exists: true, schemaErrors, classificationIssues, normalized, raw: entry };
408
+ });
409
+ (0, registry_1.registerHandler)('index_health', () => {
410
+ const st = (0, indexContext_1.ensureLoaded)();
411
+ const governanceHash = (0, indexContext_1.computeGovernanceHash)(st.list);
412
+ const summary = st.loadSummary || { scanned: st.loadDebug?.scanned ?? st.list.length, accepted: st.list.length, skipped: (st.loadDebug ? (st.loadDebug.scanned - st.loadDebug.accepted) : 0), reasons: {} };
413
+ const total = st.list.length || 1;
414
+ const governanceKeywords = ['constitution', 'quality gate', 'p1 ', 'p0 ', 'lifecycle', 'governance', 'bootstrapper'];
415
+ let governanceLike = 0;
416
+ let keywordHit = 0;
417
+ for (const e of st.list) {
418
+ const body = (e.body || '').toLowerCase();
419
+ const title = (e.title || '').toLowerCase();
420
+ const composite = title + '\n' + body.slice(0, 2000);
421
+ if (/__governance_seed__/.test(composite) || /^000-bootstrapper/.test(e.id) || /^001-knowledge-index-lifecycle/.test(e.id)) {
422
+ governanceLike++;
423
+ continue;
424
+ }
425
+ if (governanceKeywords.some(k => composite.includes(k))) {
426
+ keywordHit++;
427
+ }
428
+ }
429
+ const leakageRatio = governanceLike / total;
430
+ const effectiveGovernanceLike = ((0, indexContext_1.ensureLoaded)().list.filter(e => e && e.id && !bootstrapGating_1.BOOTSTRAP_ALLOWLIST.has(e.id)).length === 0) ? 0 : governanceLike;
431
+ let recursionRisk;
432
+ try {
433
+ const st3 = (0, indexContext_1.ensureLoaded)();
434
+ const allowlistedCount = st3.list.filter(e => bootstrapGating_1.BOOTSTRAP_ALLOWLIST.has(e.id)).length;
435
+ const adjusted = Math.max(0, governanceLike - allowlistedCount);
436
+ recursionRisk = adjusted === 0 ? 'none' : (leakageRatio < 0.01 ? 'warning' : 'critical');
437
+ }
438
+ catch {
439
+ recursionRisk = effectiveGovernanceLike === 0 ? 'none' : (leakageRatio < 0.01 ? 'warning' : 'critical');
440
+ }
441
+ const snapshot = path_1.default.join(process.cwd(), 'snapshots', 'canonical-instructions.json');
442
+ if (!fs_1.default.existsSync(snapshot))
443
+ return { snapshot: 'missing', hash: st.hash, count: st.list.length, governanceHash, recursionRisk, leakage: { governanceLike, keywordHit, leakageRatio }, summary };
444
+ try {
445
+ const raw = JSON.parse(fs_1.default.readFileSync(snapshot, 'utf8'));
446
+ const snapItems = raw.items || [];
447
+ const snapMap = new Map(snapItems.map(i => [i.id, i.sourceHash]));
448
+ const missing = [];
449
+ const changed = [];
450
+ for (const e of st.list) {
451
+ const h = snapMap.get(e.id);
452
+ if (h === undefined)
453
+ missing.push(e.id);
454
+ else if (h !== e.sourceHash)
455
+ changed.push(e.id);
456
+ }
457
+ const extra = snapItems.filter(i => !st.byId.has(i.id)).map(i => i.id);
458
+ return { snapshot: 'present', hash: st.hash, count: st.list.length, missing, changed, extra, drift: missing.length + changed.length + extra.length, governanceHash, recursionRisk, leakage: { governanceLike, keywordHit, leakageRatio }, summary };
459
+ }
460
+ catch (e) {
461
+ return { snapshot: 'error', error: e instanceof Error ? e.message : String(e), hash: st.hash, governanceHash, recursionRisk, leakage: { governanceLike, keywordHit, leakageRatio }, summary };
462
+ }
463
+ });
464
+ (0, registry_1.registerHandler)('index_debug', () => {
465
+ const before = (0, indexContext_1.getDebugIndexSnapshot)();
466
+ const st = (0, indexContext_1.ensureLoaded)();
467
+ const after = { hash: st.hash, count: st.list.length };
468
+ return { before, after };
469
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const registry_1 = require("../../server/registry");
4
+ const indexContext_1 = require("../indexContext");
5
+ const auditLog_1 = require("../auditLog");
6
+ const instructions_shared_1 = require("./instructions.shared");
7
+ (0, registry_1.registerHandler)('index_reload', (0, instructions_shared_1.guard)('index_reload', () => {
8
+ (0, indexContext_1.invalidate)();
9
+ const st = (0, indexContext_1.ensureLoaded)();
10
+ const resp = { reloaded: true, hash: st.hash, count: st.list.length };
11
+ (0, auditLog_1.logAudit)('reload', undefined, { count: st.list.length });
12
+ return resp;
13
+ }));
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const fs_1 = __importDefault(require("fs"));
7
+ const path_1 = __importDefault(require("path"));
8
+ const registry_1 = require("../../server/registry");
9
+ const indexContext_1 = require("../indexContext");
10
+ const auditLog_1 = require("../auditLog");
11
+ const runtimeConfig_1 = require("../../config/runtimeConfig");
12
+ const manifestManager_1 = require("../manifestManager");
13
+ const tracing_1 = require("../tracing");
14
+ const instructions_shared_1 = require("./instructions.shared");
15
+ const backupZip_1 = require("../backupZip");
16
+ function backupInstructionsDir() {
17
+ const cfg = (0, runtimeConfig_1.getRuntimeConfig)();
18
+ const base = (0, indexContext_1.getInstructionsDir)();
19
+ const backupsRoot = cfg.dashboard.admin.backupsDir;
20
+ fs_1.default.mkdirSync(backupsRoot, { recursive: true });
21
+ const stamp = new Date().toISOString().replace(/[:.]/g, '').replace('T', '-').slice(0, 15);
22
+ let zipPath = path_1.default.join(backupsRoot, `instructions-${stamp}.zip`);
23
+ let i = 1;
24
+ while (fs_1.default.existsSync(zipPath)) {
25
+ zipPath = path_1.default.join(backupsRoot, `instructions-${stamp}-${i++}.zip`);
26
+ }
27
+ (0, backupZip_1.createZipBackup)(base, zipPath);
28
+ return zipPath;
29
+ }
30
+ (0, registry_1.registerHandler)('index_remove', (0, instructions_shared_1.guard)('index_remove', (p) => {
31
+ const ids = Array.isArray(p.ids) ? Array.from(new Set(p.ids.filter(x => typeof x === 'string' && x.trim()))) : [];
32
+ if (!ids.length)
33
+ return { removed: 0, removedIds: [], missing: [], errorCount: 0, errors: ['no ids supplied'] };
34
+ const base = (0, indexContext_1.getInstructionsDir)();
35
+ const cfg = (0, runtimeConfig_1.getRuntimeConfig)();
36
+ const instructionsCfg = cfg.instructions;
37
+ const mutationCfg = cfg.mutation;
38
+ const maxBulk = mutationCfg.maxBulkDelete;
39
+ if (p.dryRun) {
40
+ const wouldRemove = [];
41
+ const wouldMiss = [];
42
+ const stDry = (0, indexContext_1.ensureLoaded)();
43
+ for (const id of ids) {
44
+ const file = path_1.default.join(base, `${id}.json`);
45
+ if (fs_1.default.existsSync(file) || stDry.byId.has(id)) {
46
+ wouldRemove.push(id);
47
+ }
48
+ else {
49
+ wouldMiss.push(id);
50
+ }
51
+ }
52
+ return { dryRun: true, wouldRemove: wouldRemove.length, wouldRemoveIds: wouldRemove, wouldMiss, removed: 0 };
53
+ }
54
+ if (ids.length > maxBulk && !p.force) {
55
+ (0, auditLog_1.logAudit)('remove_blocked', ids, { count: ids.length, maxBulkDelete: maxBulk, reason: 'bulk_limit_exceeded' });
56
+ return { removed: 0, removedIds: [], missing: [], errorCount: 1, errors: [`Bulk delete blocked: ${ids.length} IDs exceeds INDEX_SERVER_MAX_BULK_DELETE=${maxBulk}. Pass force=true to proceed (a backup will be created first).`], bulkBlocked: true, maxBulkDelete: maxBulk, requestedCount: ids.length };
57
+ }
58
+ let backupDir;
59
+ if (ids.length > maxBulk && mutationCfg.backupBeforeBulkDelete) {
60
+ try {
61
+ backupDir = backupInstructionsDir();
62
+ (0, auditLog_1.logAudit)('remove_backup', ids, { backupDir, count: ids.length });
63
+ }
64
+ catch (e) {
65
+ const msg = e instanceof Error ? e.message : 'backup-failed';
66
+ (0, auditLog_1.logAudit)('remove_backup_failed', ids, { error: msg, count: ids.length });
67
+ return { removed: 0, removedIds: [], missing: [], errorCount: 1, errors: [`Bulk delete aborted: pre-mutation backup failed: ${msg}`], backupFailed: true };
68
+ }
69
+ }
70
+ const missing = [];
71
+ const removed = [];
72
+ const errors = [];
73
+ const stPre = (0, indexContext_1.ensureLoaded)();
74
+ for (const id of ids) {
75
+ const file = path_1.default.join(base, `${id}.json`);
76
+ try {
77
+ if (!fs_1.default.existsSync(file) && !stPre.byId.has(id)) {
78
+ missing.push(id);
79
+ continue;
80
+ }
81
+ (0, indexContext_1.removeEntry)(id);
82
+ removed.push(id);
83
+ }
84
+ catch (e) {
85
+ errors.push({ id, error: e instanceof Error ? e.message : 'delete-failed' });
86
+ }
87
+ }
88
+ if (removed.length) {
89
+ (0, indexContext_1.touchIndexVersion)();
90
+ (0, indexContext_1.invalidate)();
91
+ }
92
+ let st = (0, indexContext_1.ensureLoaded)();
93
+ const strictRemove = instructionsCfg.strictRemove;
94
+ let strictFailed = [];
95
+ if (strictRemove) {
96
+ const stillVisible = removed.filter(id => st.byId.has(id));
97
+ if (stillVisible.length) {
98
+ try {
99
+ (0, indexContext_1.invalidate)();
100
+ st = (0, indexContext_1.ensureLoaded)();
101
+ }
102
+ catch { /* ignore */ }
103
+ }
104
+ strictFailed = removed.filter(id => st.byId.has(id));
105
+ if (strictFailed.length && (0, instructions_shared_1.traceVisibility)())
106
+ (0, tracing_1.emitTrace)('[trace:remove:strict-failed]', { ids: strictFailed });
107
+ }
108
+ const resp = { removed: removed.length, removedIds: removed, missing, errorCount: errors.length + (strictFailed.length ? 1 : 0), errors, strictVerified: strictRemove ? (strictFailed.length === 0) : undefined, strictFailed, backupDir };
109
+ if (strictRemove && strictFailed.length) {
110
+ (0, auditLog_1.logAudit)('remove', ids, { removed: removed.length, missing: missing.length, errors: errors.length, strict_failed: strictFailed.length, backupDir });
111
+ return resp;
112
+ }
113
+ (0, auditLog_1.logAudit)('remove', ids, { removed: removed.length, missing: missing.length, errors: errors.length, backupDir });
114
+ try {
115
+ setImmediate(() => { try {
116
+ (0, manifestManager_1.attemptManifestUpdate)();
117
+ }
118
+ catch { /* ignore */ } });
119
+ }
120
+ catch { /* ignore */ }
121
+ return resp;
122
+ }));
@@ -0,0 +1,32 @@
1
+ import { InstructionEntry } from '../../models/instruction';
2
+ export declare function isMutationEnabled(): boolean;
3
+ export declare function isCI(): boolean;
4
+ export declare function limitResponseSize<T extends Record<string, unknown>>(response: T): T;
5
+ export interface ImportEntry {
6
+ id: string;
7
+ title: string;
8
+ body: string;
9
+ rationale?: string;
10
+ priority: number;
11
+ audience: InstructionEntry['audience'];
12
+ requirement: InstructionEntry['requirement'];
13
+ categories?: unknown[];
14
+ deprecatedBy?: string;
15
+ riskScore?: number;
16
+ version?: string;
17
+ owner?: string;
18
+ status?: InstructionEntry['status'];
19
+ priorityTier?: InstructionEntry['priorityTier'];
20
+ classification?: InstructionEntry['classification'];
21
+ lastReviewedAt?: string;
22
+ nextReviewDue?: string;
23
+ changeLog?: InstructionEntry['changeLog'];
24
+ semanticSummary?: string;
25
+ contentType?: InstructionEntry['contentType'];
26
+ extensions?: InstructionEntry['extensions'];
27
+ }
28
+ export declare function guard<TParams, TResult>(name: string, fn: (p: TParams) => TResult): (p: TParams) => TResult;
29
+ export declare function traceVisibility(): boolean;
30
+ export declare function traceInstructionVisibility(id: string, phase: string, extra?: Record<string, unknown>): void;
31
+ export declare function traceEnvSnapshot(phase: string, extra?: Record<string, unknown>): void;
32
+ export {};