@jagilber-org/index-server 1.19.1

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 (360) hide show
  1. package/CHANGELOG.md +1218 -0
  2. package/CODE_OF_CONDUCT.md +49 -0
  3. package/CONTRIBUTING.md +75 -0
  4. package/LICENSE +21 -0
  5. package/README.md +523 -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 +45 -0
  10. package/dist/config/dashboardConfig.js +63 -0
  11. package/dist/config/defaultValues.d.ts +61 -0
  12. package/dist/config/defaultValues.js +70 -0
  13. package/dist/config/dirConstants.d.ts +17 -0
  14. package/dist/config/dirConstants.js +28 -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 +145 -0
  18. package/dist/config/runtimeConfig.js +334 -0
  19. package/dist/config/serverConfig.d.ts +90 -0
  20. package/dist/config/serverConfig.js +164 -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 +2150 -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 +1466 -0
  29. package/dist/dashboard/client/js/admin.boot.js +359 -0
  30. package/dist/dashboard/client/js/admin.config.js +196 -0
  31. package/dist/dashboard/client/js/admin.embeddings.js +425 -0
  32. package/dist/dashboard/client/js/admin.graph.js +583 -0
  33. package/dist/dashboard/client/js/admin.instances.js +120 -0
  34. package/dist/dashboard/client/js/admin.instructions.js +552 -0
  35. package/dist/dashboard/client/js/admin.logs.js +113 -0
  36. package/dist/dashboard/client/js/admin.maintenance.js +354 -0
  37. package/dist/dashboard/client/js/admin.messaging.js +635 -0
  38. package/dist/dashboard/client/js/admin.monitor.js +181 -0
  39. package/dist/dashboard/client/js/admin.overview.js +221 -0
  40. package/dist/dashboard/client/js/admin.performance.js +61 -0
  41. package/dist/dashboard/client/js/admin.sessions.js +293 -0
  42. package/dist/dashboard/client/js/admin.sqlite.js +366 -0
  43. package/dist/dashboard/client/js/admin.utils.js +49 -0
  44. package/dist/dashboard/client/js/chart.umd.js +14 -0
  45. package/dist/dashboard/client/js/elk.bundled.js +6696 -0
  46. package/dist/dashboard/client/js/marked.umd.js +74 -0
  47. package/dist/dashboard/client/js/mermaid.min.js +3022 -0
  48. package/dist/dashboard/client/mermaid-layout-elk.esm.min.mjs +1 -0
  49. package/dist/dashboard/export/DataExporter.d.ts +169 -0
  50. package/dist/dashboard/export/DataExporter.js +737 -0
  51. package/dist/dashboard/export/exporters/csvExporter.d.ts +11 -0
  52. package/dist/dashboard/export/exporters/csvExporter.js +46 -0
  53. package/dist/dashboard/export/exporters/exportTypes.d.ts +89 -0
  54. package/dist/dashboard/export/exporters/exportTypes.js +5 -0
  55. package/dist/dashboard/export/exporters/jsonExporter.d.ts +7 -0
  56. package/dist/dashboard/export/exporters/jsonExporter.js +22 -0
  57. package/dist/dashboard/export/exporters/xmlExporter.d.ts +17 -0
  58. package/dist/dashboard/export/exporters/xmlExporter.js +175 -0
  59. package/dist/dashboard/integration/APIIntegration.d.ts +41 -0
  60. package/dist/dashboard/integration/APIIntegration.js +95 -0
  61. package/dist/dashboard/security/SecurityMonitor.d.ts +167 -0
  62. package/dist/dashboard/security/SecurityMonitor.js +559 -0
  63. package/dist/dashboard/server/AdminPanel.d.ts +183 -0
  64. package/dist/dashboard/server/AdminPanel.js +792 -0
  65. package/dist/dashboard/server/AdminPanelConfig.d.ts +42 -0
  66. package/dist/dashboard/server/AdminPanelConfig.js +80 -0
  67. package/dist/dashboard/server/AdminPanelState.d.ts +47 -0
  68. package/dist/dashboard/server/AdminPanelState.js +214 -0
  69. package/dist/dashboard/server/ApiRoutes.d.ts +17 -0
  70. package/dist/dashboard/server/ApiRoutes.js +149 -0
  71. package/dist/dashboard/server/DashboardServer.d.ts +49 -0
  72. package/dist/dashboard/server/DashboardServer.js +159 -0
  73. package/dist/dashboard/server/FileMetricsStorage.d.ts +49 -0
  74. package/dist/dashboard/server/FileMetricsStorage.js +195 -0
  75. package/dist/dashboard/server/HttpTransport.d.ts +23 -0
  76. package/dist/dashboard/server/HttpTransport.js +116 -0
  77. package/dist/dashboard/server/InstanceManager.d.ts +53 -0
  78. package/dist/dashboard/server/InstanceManager.js +284 -0
  79. package/dist/dashboard/server/KnowledgeStore.d.ts +35 -0
  80. package/dist/dashboard/server/KnowledgeStore.js +105 -0
  81. package/dist/dashboard/server/LeaderElection.d.ts +81 -0
  82. package/dist/dashboard/server/LeaderElection.js +268 -0
  83. package/dist/dashboard/server/MetricsCollector.d.ts +200 -0
  84. package/dist/dashboard/server/MetricsCollector.js +803 -0
  85. package/dist/dashboard/server/SessionPersistenceManager.d.ts +88 -0
  86. package/dist/dashboard/server/SessionPersistenceManager.js +457 -0
  87. package/dist/dashboard/server/ThinClient.d.ts +64 -0
  88. package/dist/dashboard/server/ThinClient.js +237 -0
  89. package/dist/dashboard/server/WebSocketManager.d.ts +161 -0
  90. package/dist/dashboard/server/WebSocketManager.js +463 -0
  91. package/dist/dashboard/server/httpLifecycle.d.ts +17 -0
  92. package/dist/dashboard/server/httpLifecycle.js +35 -0
  93. package/dist/dashboard/server/legacyDashboardHtml.d.ts +9 -0
  94. package/dist/dashboard/server/legacyDashboardHtml.js +618 -0
  95. package/dist/dashboard/server/legacyDashboardStyles.d.ts +5 -0
  96. package/dist/dashboard/server/legacyDashboardStyles.js +490 -0
  97. package/dist/dashboard/server/metricsAggregation.d.ts +252 -0
  98. package/dist/dashboard/server/metricsAggregation.js +206 -0
  99. package/dist/dashboard/server/metricsSerializer.d.ts +25 -0
  100. package/dist/dashboard/server/metricsSerializer.js +195 -0
  101. package/dist/dashboard/server/routes/admin.routes.d.ts +16 -0
  102. package/dist/dashboard/server/routes/admin.routes.js +596 -0
  103. package/dist/dashboard/server/routes/alerts.routes.d.ts +7 -0
  104. package/dist/dashboard/server/routes/alerts.routes.js +93 -0
  105. package/dist/dashboard/server/routes/api.feedback.routes.d.ts +73 -0
  106. package/dist/dashboard/server/routes/api.feedback.routes.js +171 -0
  107. package/dist/dashboard/server/routes/api.instructions.routes.d.ts +101 -0
  108. package/dist/dashboard/server/routes/api.instructions.routes.js +213 -0
  109. package/dist/dashboard/server/routes/api.usage.routes.d.ts +57 -0
  110. package/dist/dashboard/server/routes/api.usage.routes.js +374 -0
  111. package/dist/dashboard/server/routes/embeddings.routes.d.ts +6 -0
  112. package/dist/dashboard/server/routes/embeddings.routes.js +246 -0
  113. package/dist/dashboard/server/routes/graph.routes.d.ts +6 -0
  114. package/dist/dashboard/server/routes/graph.routes.js +280 -0
  115. package/dist/dashboard/server/routes/index.d.ts +38 -0
  116. package/dist/dashboard/server/routes/index.js +194 -0
  117. package/dist/dashboard/server/routes/instances.routes.d.ts +6 -0
  118. package/dist/dashboard/server/routes/instances.routes.js +35 -0
  119. package/dist/dashboard/server/routes/instructions.routes.d.ts +8 -0
  120. package/dist/dashboard/server/routes/instructions.routes.js +336 -0
  121. package/dist/dashboard/server/routes/knowledge.routes.d.ts +6 -0
  122. package/dist/dashboard/server/routes/knowledge.routes.js +82 -0
  123. package/dist/dashboard/server/routes/logs.routes.d.ts +6 -0
  124. package/dist/dashboard/server/routes/logs.routes.js +164 -0
  125. package/dist/dashboard/server/routes/messaging.routes.d.ts +16 -0
  126. package/dist/dashboard/server/routes/messaging.routes.js +293 -0
  127. package/dist/dashboard/server/routes/metrics.routes.d.ts +10 -0
  128. package/dist/dashboard/server/routes/metrics.routes.js +346 -0
  129. package/dist/dashboard/server/routes/scripts.routes.d.ts +9 -0
  130. package/dist/dashboard/server/routes/scripts.routes.js +84 -0
  131. package/dist/dashboard/server/routes/sqlite.routes.d.ts +9 -0
  132. package/dist/dashboard/server/routes/sqlite.routes.js +569 -0
  133. package/dist/dashboard/server/routes/status.routes.d.ts +7 -0
  134. package/dist/dashboard/server/routes/status.routes.js +183 -0
  135. package/dist/dashboard/server/routes/synthetic.routes.d.ts +7 -0
  136. package/dist/dashboard/server/routes/synthetic.routes.js +195 -0
  137. package/dist/dashboard/server/routes/tools.routes.d.ts +6 -0
  138. package/dist/dashboard/server/routes/tools.routes.js +46 -0
  139. package/dist/dashboard/server/routes/usage.routes.d.ts +6 -0
  140. package/dist/dashboard/server/routes/usage.routes.js +25 -0
  141. package/dist/dashboard/server/wsInit.d.ts +16 -0
  142. package/dist/dashboard/server/wsInit.js +35 -0
  143. package/dist/externalClientLib.d.ts +1 -0
  144. package/dist/externalClientLib.js +2 -0
  145. package/dist/minimal/index.d.ts +1 -0
  146. package/dist/minimal/index.js +140 -0
  147. package/dist/models/SessionPersistence.d.ts +115 -0
  148. package/dist/models/SessionPersistence.js +66 -0
  149. package/dist/models/instruction.d.ts +45 -0
  150. package/dist/models/instruction.js +2 -0
  151. package/dist/perf/benchmark.d.ts +1 -0
  152. package/dist/perf/benchmark.js +50 -0
  153. package/dist/portableClientWrapper.d.ts +1 -0
  154. package/dist/portableClientWrapper.js +2 -0
  155. package/dist/schemas/index.d.ts +128 -0
  156. package/dist/schemas/index.js +371 -0
  157. package/dist/scripts/runPerformanceBaseline.d.ts +1 -0
  158. package/dist/scripts/runPerformanceBaseline.js +17 -0
  159. package/dist/server/handshakeManager.d.ts +25 -0
  160. package/dist/server/handshakeManager.js +472 -0
  161. package/dist/server/index-server.d.ts +56 -0
  162. package/dist/server/index-server.js +822 -0
  163. package/dist/server/registry.d.ts +44 -0
  164. package/dist/server/registry.js +236 -0
  165. package/dist/server/sdkServer.d.ts +8 -0
  166. package/dist/server/sdkServer.js +299 -0
  167. package/dist/server/shutdownGuard.d.ts +41 -0
  168. package/dist/server/shutdownGuard.js +52 -0
  169. package/dist/server/thin-client.d.ts +22 -0
  170. package/dist/server/thin-client.js +111 -0
  171. package/dist/server/transport.d.ts +41 -0
  172. package/dist/server/transport.js +312 -0
  173. package/dist/server/transportFactory.d.ts +21 -0
  174. package/dist/server/transportFactory.js +429 -0
  175. package/dist/services/atomicFs.d.ts +22 -0
  176. package/dist/services/atomicFs.js +103 -0
  177. package/dist/services/auditLog.d.ts +38 -0
  178. package/dist/services/auditLog.js +142 -0
  179. package/dist/services/autoBackup.d.ts +14 -0
  180. package/dist/services/autoBackup.js +171 -0
  181. package/dist/services/autoSplit.d.ts +32 -0
  182. package/dist/services/autoSplit.js +113 -0
  183. package/dist/services/backupZip.d.ts +25 -0
  184. package/dist/services/backupZip.js +110 -0
  185. package/dist/services/bootstrapGating.d.ts +123 -0
  186. package/dist/services/bootstrapGating.js +221 -0
  187. package/dist/services/canonical.d.ts +23 -0
  188. package/dist/services/canonical.js +65 -0
  189. package/dist/services/categoryRules.d.ts +7 -0
  190. package/dist/services/categoryRules.js +37 -0
  191. package/dist/services/classificationService.d.ts +42 -0
  192. package/dist/services/classificationService.js +168 -0
  193. package/dist/services/embeddingService.d.ts +62 -0
  194. package/dist/services/embeddingService.js +259 -0
  195. package/dist/services/errors.d.ts +22 -0
  196. package/dist/services/errors.js +31 -0
  197. package/dist/services/featureFlags.d.ts +25 -0
  198. package/dist/services/featureFlags.js +89 -0
  199. package/dist/services/features.d.ts +13 -0
  200. package/dist/services/features.js +35 -0
  201. package/dist/services/handlers/instructions.add.d.ts +1 -0
  202. package/dist/services/handlers/instructions.add.js +496 -0
  203. package/dist/services/handlers/instructions.groom.d.ts +1 -0
  204. package/dist/services/handlers/instructions.groom.js +523 -0
  205. package/dist/services/handlers/instructions.import.d.ts +1 -0
  206. package/dist/services/handlers/instructions.import.js +173 -0
  207. package/dist/services/handlers/instructions.patch.d.ts +1 -0
  208. package/dist/services/handlers/instructions.patch.js +167 -0
  209. package/dist/services/handlers/instructions.query.d.ts +163 -0
  210. package/dist/services/handlers/instructions.query.js +522 -0
  211. package/dist/services/handlers/instructions.reload.d.ts +1 -0
  212. package/dist/services/handlers/instructions.reload.js +13 -0
  213. package/dist/services/handlers/instructions.remove.d.ts +1 -0
  214. package/dist/services/handlers/instructions.remove.js +118 -0
  215. package/dist/services/handlers/instructions.shared.d.ts +31 -0
  216. package/dist/services/handlers/instructions.shared.js +124 -0
  217. package/dist/services/handlers.activation.d.ts +1 -0
  218. package/dist/services/handlers.activation.js +203 -0
  219. package/dist/services/handlers.bootstrap.d.ts +1 -0
  220. package/dist/services/handlers.bootstrap.js +38 -0
  221. package/dist/services/handlers.dashboardConfig.d.ts +34 -0
  222. package/dist/services/handlers.dashboardConfig.js +108 -0
  223. package/dist/services/handlers.diagnostics.d.ts +1 -0
  224. package/dist/services/handlers.diagnostics.js +64 -0
  225. package/dist/services/handlers.feedback.d.ts +15 -0
  226. package/dist/services/handlers.feedback.js +378 -0
  227. package/dist/services/handlers.gates.d.ts +1 -0
  228. package/dist/services/handlers.gates.js +46 -0
  229. package/dist/services/handlers.graph.d.ts +53 -0
  230. package/dist/services/handlers.graph.js +231 -0
  231. package/dist/services/handlers.help.d.ts +1 -0
  232. package/dist/services/handlers.help.js +119 -0
  233. package/dist/services/handlers.instructionSchema.d.ts +1 -0
  234. package/dist/services/handlers.instructionSchema.js +227 -0
  235. package/dist/services/handlers.instructions.d.ts +8 -0
  236. package/dist/services/handlers.instructions.js +14 -0
  237. package/dist/services/handlers.instructionsDiagnostics.d.ts +1 -0
  238. package/dist/services/handlers.instructionsDiagnostics.js +14 -0
  239. package/dist/services/handlers.integrity.d.ts +1 -0
  240. package/dist/services/handlers.integrity.js +35 -0
  241. package/dist/services/handlers.manifest.d.ts +1 -0
  242. package/dist/services/handlers.manifest.js +24 -0
  243. package/dist/services/handlers.messaging.d.ts +12 -0
  244. package/dist/services/handlers.messaging.js +203 -0
  245. package/dist/services/handlers.metrics.d.ts +1 -0
  246. package/dist/services/handlers.metrics.js +43 -0
  247. package/dist/services/handlers.promote.d.ts +1 -0
  248. package/dist/services/handlers.promote.js +306 -0
  249. package/dist/services/handlers.prompt.d.ts +1 -0
  250. package/dist/services/handlers.prompt.js +7 -0
  251. package/dist/services/handlers.search.d.ts +69 -0
  252. package/dist/services/handlers.search.js +645 -0
  253. package/dist/services/handlers.testPrimitive.d.ts +1 -0
  254. package/dist/services/handlers.testPrimitive.js +5 -0
  255. package/dist/services/handlers.trace.d.ts +1 -0
  256. package/dist/services/handlers.trace.js +31 -0
  257. package/dist/services/handlers.usage.d.ts +1 -0
  258. package/dist/services/handlers.usage.js +11 -0
  259. package/dist/services/hotScore.d.ts +137 -0
  260. package/dist/services/hotScore.js +244 -0
  261. package/dist/services/indexContext.d.ts +117 -0
  262. package/dist/services/indexContext.js +968 -0
  263. package/dist/services/indexLoader.d.ts +44 -0
  264. package/dist/services/indexLoader.js +921 -0
  265. package/dist/services/indexRepository.d.ts +32 -0
  266. package/dist/services/indexRepository.js +71 -0
  267. package/dist/services/indexingService.d.ts +1 -0
  268. package/dist/services/indexingService.js +2 -0
  269. package/dist/services/instructions.dispatcher.d.ts +1 -0
  270. package/dist/services/instructions.dispatcher.js +231 -0
  271. package/dist/services/logPrefix.d.ts +1 -0
  272. package/dist/services/logPrefix.js +30 -0
  273. package/dist/services/logger.d.ts +52 -0
  274. package/dist/services/logger.js +268 -0
  275. package/dist/services/manifestManager.d.ts +82 -0
  276. package/dist/services/manifestManager.js +200 -0
  277. package/dist/services/messaging/agentMailbox.d.ts +60 -0
  278. package/dist/services/messaging/agentMailbox.js +353 -0
  279. package/dist/services/messaging/messagingPersistence.d.ts +20 -0
  280. package/dist/services/messaging/messagingPersistence.js +111 -0
  281. package/dist/services/messaging/messagingTypes.d.ts +150 -0
  282. package/dist/services/messaging/messagingTypes.js +66 -0
  283. package/dist/services/ownershipService.d.ts +1 -0
  284. package/dist/services/ownershipService.js +38 -0
  285. package/dist/services/performanceBaseline.d.ts +19 -0
  286. package/dist/services/performanceBaseline.js +210 -0
  287. package/dist/services/preflight.d.ts +12 -0
  288. package/dist/services/preflight.js +79 -0
  289. package/dist/services/promptReviewService.d.ts +44 -0
  290. package/dist/services/promptReviewService.js +101 -0
  291. package/dist/services/responseEnvelope.d.ts +6 -0
  292. package/dist/services/responseEnvelope.js +25 -0
  293. package/dist/services/seedBootstrap.d.ts +34 -0
  294. package/dist/services/seedBootstrap.js +427 -0
  295. package/dist/services/storage/factory.d.ts +17 -0
  296. package/dist/services/storage/factory.js +35 -0
  297. package/dist/services/storage/hashUtils.d.ts +11 -0
  298. package/dist/services/storage/hashUtils.js +35 -0
  299. package/dist/services/storage/index.d.ts +12 -0
  300. package/dist/services/storage/index.js +18 -0
  301. package/dist/services/storage/jsonFileStore.d.ts +32 -0
  302. package/dist/services/storage/jsonFileStore.js +241 -0
  303. package/dist/services/storage/migrationEngine.d.ts +35 -0
  304. package/dist/services/storage/migrationEngine.js +93 -0
  305. package/dist/services/storage/sqliteMessageStore.d.ts +53 -0
  306. package/dist/services/storage/sqliteMessageStore.js +146 -0
  307. package/dist/services/storage/sqliteSchema.d.ts +12 -0
  308. package/dist/services/storage/sqliteSchema.js +122 -0
  309. package/dist/services/storage/sqliteStore.d.ts +41 -0
  310. package/dist/services/storage/sqliteStore.js +339 -0
  311. package/dist/services/storage/sqliteUsageStore.d.ts +35 -0
  312. package/dist/services/storage/sqliteUsageStore.js +94 -0
  313. package/dist/services/storage/types.d.ts +171 -0
  314. package/dist/services/storage/types.js +12 -0
  315. package/dist/services/toolHandlers.d.ts +23 -0
  316. package/dist/services/toolHandlers.js +50 -0
  317. package/dist/services/toolRegistry.d.ts +20 -0
  318. package/dist/services/toolRegistry.js +490 -0
  319. package/dist/services/toolRegistry.zod.d.ts +10 -0
  320. package/dist/services/toolRegistry.zod.js +323 -0
  321. package/dist/services/tracing.d.ts +26 -0
  322. package/dist/services/tracing.js +260 -0
  323. package/dist/services/usageBuckets.d.ts +161 -0
  324. package/dist/services/usageBuckets.js +364 -0
  325. package/dist/services/validationService.d.ts +38 -0
  326. package/dist/services/validationService.js +125 -0
  327. package/dist/utils/BufferRing.d.ts +203 -0
  328. package/dist/utils/BufferRing.js +551 -0
  329. package/dist/utils/BufferRingExamples.d.ts +55 -0
  330. package/dist/utils/BufferRingExamples.js +188 -0
  331. package/dist/utils/envUtils.d.ts +42 -0
  332. package/dist/utils/envUtils.js +80 -0
  333. package/dist/utils/memoryMonitor.d.ts +83 -0
  334. package/dist/utils/memoryMonitor.js +275 -0
  335. package/dist/versioning/schemaVersion.d.ts +6 -0
  336. package/dist/versioning/schemaVersion.js +93 -0
  337. package/package.json +134 -0
  338. package/schemas/README.md +13 -0
  339. package/schemas/feedback-entry.schema.json +27 -0
  340. package/schemas/graph-export-v2.schema.json +60 -0
  341. package/schemas/index-server.code-schema.json +38477 -0
  342. package/schemas/instruction.schema.json +262 -0
  343. package/schemas/json-schema/SessionPersistence-persisted-admin-session.schema.json +54 -0
  344. package/schemas/json-schema/SessionPersistence-persisted-session-history-entry.schema.json +51 -0
  345. package/schemas/json-schema/SessionPersistence-persisted-web-socket-connection.schema.json +54 -0
  346. package/schemas/json-schema/SessionPersistence-session-persistence-config.schema.json +110 -0
  347. package/schemas/json-schema/SessionPersistence-session-persistence-data.schema.json +229 -0
  348. package/schemas/json-schema/SessionPersistence-session-persistence-manifest.schema.json +109 -0
  349. package/schemas/json-schema/SessionPersistence-session-persistence-metadata.schema.json +55 -0
  350. package/schemas/json-schema/instruction-audience-scope.schema.json +14 -0
  351. package/schemas/json-schema/instruction-content-type.schema.json +17 -0
  352. package/schemas/json-schema/instruction-instruction-entry.schema.json +206 -0
  353. package/schemas/json-schema/instruction-requirement-level.schema.json +16 -0
  354. package/schemas/manifest.json +78 -0
  355. package/schemas/manifest.schema.json +33 -0
  356. package/schemas/usage-batch.schema.json +16 -0
  357. package/schemas/usage-buckets.schema.json +30 -0
  358. package/schemas/usage-event.schema.json +17 -0
  359. package/scripts/copy-dashboard-assets.mjs +170 -0
  360. package/scripts/setup-hooks.cjs +28 -0
@@ -0,0 +1,93 @@
1
+ "use strict";
2
+ /**
3
+ * Alerts Routes
4
+ * Routes: GET /alerts/active, POST /alerts/:id/resolve, POST /alerts/generate
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.createAlertsRoutes = createAlertsRoutes;
8
+ const express_1 = require("express");
9
+ function createAlertsRoutes(metricsCollector) {
10
+ const router = (0, express_1.Router)();
11
+ /**
12
+ * GET /api/alerts/active - Get active alerts
13
+ */
14
+ router.get('/alerts/active', (_req, res) => {
15
+ try {
16
+ const activeAlerts = metricsCollector.getActiveAlerts();
17
+ res.json({
18
+ success: true,
19
+ data: activeAlerts,
20
+ count: activeAlerts.length,
21
+ timestamp: Date.now()
22
+ });
23
+ }
24
+ catch (error) {
25
+ console.error('[API] Active alerts error:', error);
26
+ res.status(500).json({
27
+ error: 'Failed to get active alerts',
28
+ message: error instanceof Error ? error.message : 'Unknown error',
29
+ });
30
+ }
31
+ });
32
+ /**
33
+ * POST /api/alerts/:id/resolve - Resolve an alert
34
+ */
35
+ router.post('/alerts/:id/resolve', (req, res) => {
36
+ try {
37
+ const alertId = req.params.id;
38
+ const resolved = metricsCollector.resolveAlert(alertId);
39
+ if (resolved) {
40
+ res.json({
41
+ success: true,
42
+ message: `Alert ${alertId} resolved successfully`,
43
+ timestamp: Date.now()
44
+ });
45
+ }
46
+ else {
47
+ res.status(404).json({
48
+ error: 'Alert not found',
49
+ message: `Alert with ID ${alertId} not found`,
50
+ timestamp: Date.now()
51
+ });
52
+ }
53
+ }
54
+ catch (error) {
55
+ console.error('[API] Resolve alert error:', error);
56
+ res.status(500).json({
57
+ error: 'Failed to resolve alert',
58
+ message: error instanceof Error ? error.message : 'Unknown error',
59
+ });
60
+ }
61
+ });
62
+ /**
63
+ * POST /api/alerts/generate - Generate test alert for Phase 4 testing
64
+ */
65
+ router.post('/alerts/generate', (req, res) => {
66
+ try {
67
+ const { type, severity, message, value, threshold } = req.body;
68
+ // Basic validation
69
+ if (!type || !severity || !message || value === undefined || threshold === undefined) {
70
+ return res.status(400).json({
71
+ error: 'Missing required fields',
72
+ required: ['type', 'severity', 'message', 'value', 'threshold'],
73
+ timestamp: Date.now()
74
+ });
75
+ }
76
+ const alert = metricsCollector.generateRealTimeAlert(type, severity, message, value, threshold);
77
+ res.json({
78
+ success: true,
79
+ data: alert,
80
+ message: 'Alert generated successfully',
81
+ timestamp: Date.now()
82
+ });
83
+ }
84
+ catch (error) {
85
+ console.error('[API] Generate alert error:', error);
86
+ res.status(500).json({
87
+ error: 'Failed to generate alert',
88
+ message: error instanceof Error ? error.message : 'Unknown error',
89
+ });
90
+ }
91
+ });
92
+ return router;
93
+ }
@@ -0,0 +1,73 @@
1
+ /**
2
+ * API Feedback Routes — Webhook and external connector management.
3
+ *
4
+ * Manages outbound webhooks and external service connectors that provide
5
+ * feedback / integration channels for the APIIntegration coordinator.
6
+ * Depends on UsageManager for request execution.
7
+ */
8
+ import type { UsageManager, APIResponse } from './api.usage.routes.js';
9
+ import type { APIAuthentication, RetryConfig } from './api.instructions.routes.js';
10
+ export interface WebhookConfig {
11
+ id: string;
12
+ name: string;
13
+ url: string;
14
+ events: string[];
15
+ authentication: APIAuthentication;
16
+ headers: Record<string, string>;
17
+ retryConfig: RetryConfig;
18
+ verification: {
19
+ enabled: boolean;
20
+ secret?: string;
21
+ algorithm: 'sha256' | 'sha512';
22
+ headerName: string;
23
+ };
24
+ filters: Array<{
25
+ field: string;
26
+ operator: string;
27
+ value: unknown;
28
+ }>;
29
+ }
30
+ export interface ExternalConnector {
31
+ id: string;
32
+ name: string;
33
+ type: 'database' | 'queue' | 'storage' | 'monitoring' | 'notification' | 'analytics';
34
+ config: Record<string, unknown>;
35
+ healthCheck: {
36
+ enabled: boolean;
37
+ interval: number;
38
+ timeout: number;
39
+ endpoint?: string;
40
+ };
41
+ status: 'connected' | 'disconnected' | 'error' | 'connecting';
42
+ lastCheck?: number;
43
+ metrics: {
44
+ requestCount: number;
45
+ errorCount: number;
46
+ avgResponseTime: number;
47
+ lastError?: string;
48
+ };
49
+ }
50
+ export declare class FeedbackManager {
51
+ private readonly usageMgr;
52
+ readonly webhooks: Map<string, WebhookConfig>;
53
+ readonly connectors: Map<string, ExternalConnector>;
54
+ constructor(usageMgr: UsageManager);
55
+ private initializeDefaultConnectors;
56
+ performHealthChecks(): Promise<void>;
57
+ private performConnectorHealthCheck;
58
+ createWebhook(webhook: Omit<WebhookConfig, 'id'>): string;
59
+ triggerWebhook(id: string, event: string, data: unknown): Promise<boolean>;
60
+ executeWebhookRequest(webhook: WebhookConfig, payload: unknown): Promise<APIResponse>;
61
+ private generateWebhookSignature;
62
+ private evaluateWebhookFilter;
63
+ createConnector(connector: Omit<ExternalConnector, 'id' | 'status' | 'metrics'>): string;
64
+ getConnectorStatus(id: string): ExternalConnector | undefined;
65
+ listConnectors(): ExternalConnector[];
66
+ getStats(): {
67
+ webhookCount: number;
68
+ connectorCount: number;
69
+ activeConnections: number;
70
+ totalRequests: number;
71
+ totalErrors: number;
72
+ };
73
+ }
@@ -0,0 +1,171 @@
1
+ "use strict";
2
+ /**
3
+ * API Feedback Routes — Webhook and external connector management.
4
+ *
5
+ * Manages outbound webhooks and external service connectors that provide
6
+ * feedback / integration channels for the APIIntegration coordinator.
7
+ * Depends on UsageManager for request execution.
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.FeedbackManager = void 0;
11
+ // ── FeedbackManager ──────────────────────────────────────────────────────────────────
12
+ class FeedbackManager {
13
+ usageMgr;
14
+ webhooks = new Map();
15
+ connectors = new Map();
16
+ constructor(usageMgr) {
17
+ this.usageMgr = usageMgr;
18
+ this.initializeDefaultConnectors();
19
+ }
20
+ initializeDefaultConnectors() {
21
+ const defaultConnectors = [
22
+ {
23
+ id: 'prometheus_metrics',
24
+ name: 'Prometheus Metrics Collector',
25
+ type: 'monitoring',
26
+ config: {
27
+ url: 'http://localhost:9090',
28
+ scrapeInterval: 15000,
29
+ metrics: ['cpu_usage', 'memory_usage', 'request_rate', 'error_rate']
30
+ },
31
+ healthCheck: { enabled: true, interval: 30000, timeout: 5000, endpoint: '/api/v1/status/buildinfo' },
32
+ status: 'disconnected',
33
+ metrics: { requestCount: 0, errorCount: 0, avgResponseTime: 0 }
34
+ },
35
+ {
36
+ id: 'slack_notifications',
37
+ name: 'Slack Notification Connector',
38
+ type: 'notification',
39
+ config: { webhookUrl: '${SLACK_WEBHOOK_URL}', channel: '#alerts', username: 'Index-Server', iconEmoji: ':robot_face:' },
40
+ healthCheck: { enabled: true, interval: 300000, timeout: 10000 },
41
+ status: 'disconnected',
42
+ metrics: { requestCount: 0, errorCount: 0, avgResponseTime: 0 }
43
+ },
44
+ {
45
+ id: 'elasticsearch_logs',
46
+ name: 'Elasticsearch Log Connector',
47
+ type: 'analytics',
48
+ config: { host: 'localhost', port: 9200, index: 'index-logs', batchSize: 100, flushInterval: 5000 },
49
+ healthCheck: { enabled: true, interval: 60000, timeout: 5000, endpoint: '/_cluster/health' },
50
+ status: 'disconnected',
51
+ metrics: { requestCount: 0, errorCount: 0, avgResponseTime: 0 }
52
+ }
53
+ ];
54
+ defaultConnectors.forEach(connector => {
55
+ this.connectors.set(connector.id, connector);
56
+ });
57
+ }
58
+ async performHealthChecks() {
59
+ const promises = Array.from(this.connectors.entries()).map(async ([_id, connector]) => {
60
+ if (!connector.healthCheck.enabled)
61
+ return;
62
+ const now = Date.now();
63
+ if (connector.lastCheck && now - connector.lastCheck < connector.healthCheck.interval)
64
+ return;
65
+ try {
66
+ connector.status = 'connecting';
67
+ await this.performConnectorHealthCheck(connector);
68
+ connector.status = 'connected';
69
+ connector.lastCheck = now;
70
+ }
71
+ catch (error) {
72
+ connector.status = 'error';
73
+ connector.metrics.lastError = error instanceof Error ? error.message : 'Unknown error';
74
+ connector.lastCheck = now;
75
+ }
76
+ });
77
+ await Promise.allSettled(promises);
78
+ }
79
+ async performConnectorHealthCheck(_connector) {
80
+ await this.usageMgr.sleep(Math.random() * 1000 + 100);
81
+ if (Math.random() < 0.1)
82
+ throw new Error('Health check failed');
83
+ }
84
+ createWebhook(webhook) {
85
+ const id = `webhook_${Date.now()}`;
86
+ const fullWebhook = { id, ...webhook };
87
+ this.webhooks.set(id, fullWebhook);
88
+ return id;
89
+ }
90
+ async triggerWebhook(id, event, data) {
91
+ const webhook = this.webhooks.get(id);
92
+ if (!webhook || !webhook.events.includes(event))
93
+ return false;
94
+ if (webhook.filters.length > 0) {
95
+ const passesFilters = webhook.filters.every(filter => this.evaluateWebhookFilter(data, filter));
96
+ if (!passesFilters)
97
+ return false;
98
+ }
99
+ try {
100
+ const payload = { event, timestamp: Date.now(), data };
101
+ const response = await this.executeWebhookRequest(webhook, payload);
102
+ return response.status >= 200 && response.status < 300;
103
+ }
104
+ catch (error) {
105
+ console.error('Webhook execution error:', error);
106
+ return false;
107
+ }
108
+ }
109
+ async executeWebhookRequest(webhook, payload) {
110
+ const request = {
111
+ id: `webhook_${Date.now()}`,
112
+ endpointId: webhook.id,
113
+ method: 'POST',
114
+ url: webhook.url,
115
+ headers: { ...webhook.headers, 'Content-Type': 'application/json' },
116
+ body: payload,
117
+ timestamp: Date.now(),
118
+ timeout: 10000
119
+ };
120
+ this.usageMgr.applyAuthentication(request, webhook.authentication);
121
+ if (webhook.verification.enabled && webhook.verification.secret) {
122
+ const signature = this.generateWebhookSignature(payload, webhook.verification);
123
+ request.headers[webhook.verification.headerName] = signature;
124
+ }
125
+ return this.usageMgr.executeWithRetry(request, webhook.retryConfig);
126
+ }
127
+ generateWebhookSignature(payload, verification) {
128
+ const payloadString = JSON.stringify(payload);
129
+ return `${verification.algorithm}=${Buffer.from(payloadString + verification.secret).toString('base64')}`;
130
+ }
131
+ evaluateWebhookFilter(data, filter) {
132
+ if (!data || typeof data !== 'object')
133
+ return false;
134
+ const getNestedValue = (obj, path) => path.split('.').reduce((current, key) => current && typeof current === 'object' ? current[key] : undefined, obj);
135
+ const fieldValue = getNestedValue(data, filter.field);
136
+ switch (filter.operator) {
137
+ case 'equals': return fieldValue === filter.value;
138
+ case 'not_equals': return fieldValue !== filter.value;
139
+ case 'contains': return String(fieldValue).includes(String(filter.value));
140
+ default: return true;
141
+ }
142
+ }
143
+ createConnector(connector) {
144
+ const id = `connector_${Date.now()}`;
145
+ const fullConnector = {
146
+ id,
147
+ ...connector,
148
+ status: 'disconnected',
149
+ metrics: { requestCount: 0, errorCount: 0, avgResponseTime: 0 }
150
+ };
151
+ this.connectors.set(id, fullConnector);
152
+ return id;
153
+ }
154
+ getConnectorStatus(id) {
155
+ return this.connectors.get(id);
156
+ }
157
+ listConnectors() {
158
+ return Array.from(this.connectors.values());
159
+ }
160
+ getStats() {
161
+ const connectors = Array.from(this.connectors.values());
162
+ return {
163
+ webhookCount: this.webhooks.size,
164
+ connectorCount: this.connectors.size,
165
+ activeConnections: connectors.filter(c => c.status === 'connected').length,
166
+ totalRequests: connectors.reduce((sum, c) => sum + c.metrics.requestCount, 0),
167
+ totalErrors: connectors.reduce((sum, c) => sum + c.metrics.errorCount, 0)
168
+ };
169
+ }
170
+ }
171
+ exports.FeedbackManager = FeedbackManager;
@@ -0,0 +1,101 @@
1
+ /**
2
+ * API Instructions Routes — Endpoint configuration and management.
3
+ *
4
+ * Manages APIEndpoint CRUD, rate limiting, and request queuing infrastructure
5
+ * used by the APIIntegration coordinator.
6
+ */
7
+ export interface APIAuthentication {
8
+ type: 'none' | 'api_key' | 'bearer_token' | 'oauth2' | 'basic_auth' | 'custom';
9
+ config: Record<string, unknown>;
10
+ tokenRefresh?: {
11
+ enabled: boolean;
12
+ endpoint?: string;
13
+ threshold: number;
14
+ };
15
+ }
16
+ export interface RetryConfig {
17
+ enabled: boolean;
18
+ maxAttempts: number;
19
+ backoffStrategy: 'linear' | 'exponential' | 'fixed';
20
+ baseDelay: number;
21
+ maxDelay: number;
22
+ retryOn: Array<'timeout' | 'network_error' | 'server_error' | 'rate_limit'>;
23
+ }
24
+ export interface RateLimitConfig {
25
+ enabled: boolean;
26
+ requestsPerMinute: number;
27
+ burstLimit: number;
28
+ queueMaxSize: number;
29
+ dropOnFull: boolean;
30
+ }
31
+ export interface DataMapping {
32
+ requestTransform?: string;
33
+ responseTransform?: string;
34
+ errorTransform?: string;
35
+ fieldMappings: Array<{
36
+ source: string;
37
+ target: string;
38
+ transform?: string;
39
+ }>;
40
+ }
41
+ export interface ValidationConfig {
42
+ requestSchema?: object;
43
+ responseSchema?: object;
44
+ validateRequest: boolean;
45
+ validateResponse: boolean;
46
+ strictMode: boolean;
47
+ }
48
+ export interface MonitoringConfig {
49
+ logRequests: boolean;
50
+ logResponses: boolean;
51
+ logErrors: boolean;
52
+ collectMetrics: boolean;
53
+ alertOnFailure: boolean;
54
+ alertThreshold: number;
55
+ }
56
+ export interface APIEndpoint {
57
+ id: string;
58
+ name: string;
59
+ url: string;
60
+ method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';
61
+ protocol: 'rest' | 'graphql' | 'websocket' | 'grpc';
62
+ authentication: APIAuthentication;
63
+ headers: Record<string, string>;
64
+ timeout: number;
65
+ retryConfig: RetryConfig;
66
+ rateLimit: RateLimitConfig;
67
+ dataMapping: DataMapping;
68
+ validation: ValidationConfig;
69
+ monitoring: MonitoringConfig;
70
+ }
71
+ export interface QueuedRequest {
72
+ id: string;
73
+ endpointId: string;
74
+ body?: unknown;
75
+ headers?: Record<string, string>;
76
+ timeout?: number;
77
+ }
78
+ export declare class EndpointManager {
79
+ readonly endpoints: Map<string, APIEndpoint>;
80
+ readonly requestQueue: Map<string, QueuedRequest[]>;
81
+ readonly responseCache: Map<string, {
82
+ response: unknown;
83
+ expiry: number;
84
+ }>;
85
+ readonly rateLimiters: Map<string, {
86
+ requests: number[];
87
+ lastReset: number;
88
+ }>;
89
+ constructor();
90
+ private initializeDefaultEndpoints;
91
+ initializeRateLimit(endpointId: string, config: RateLimitConfig): void;
92
+ checkRateLimit(endpointId: string): boolean;
93
+ createEndpoint(endpoint: Omit<APIEndpoint, 'id'>): string;
94
+ getEndpoint(id: string): APIEndpoint | undefined;
95
+ listEndpoints(): APIEndpoint[];
96
+ updateEndpoint(id: string, updates: Partial<APIEndpoint>): boolean;
97
+ deleteEndpoint(id: string): boolean;
98
+ getConfiguredEndpoints(): APIEndpoint[];
99
+ cleanupCache(): void;
100
+ resetRateLimiters(): void;
101
+ }
@@ -0,0 +1,213 @@
1
+ "use strict";
2
+ /**
3
+ * API Instructions Routes — Endpoint configuration and management.
4
+ *
5
+ * Manages APIEndpoint CRUD, rate limiting, and request queuing infrastructure
6
+ * used by the APIIntegration coordinator.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.EndpointManager = void 0;
10
+ // ── EndpointManager ──────────────────────────────────────────────────────────────────
11
+ class EndpointManager {
12
+ endpoints = new Map();
13
+ requestQueue = new Map();
14
+ responseCache = new Map();
15
+ rateLimiters = new Map();
16
+ constructor() {
17
+ this.initializeDefaultEndpoints();
18
+ }
19
+ initializeDefaultEndpoints() {
20
+ const defaultEndpoints = [
21
+ {
22
+ id: 'system_health',
23
+ name: 'System Health Check',
24
+ url: 'http://localhost:8989/api/health',
25
+ method: 'GET',
26
+ protocol: 'rest',
27
+ authentication: { type: 'none', config: {} },
28
+ headers: { 'Content-Type': 'application/json' },
29
+ timeout: 5000,
30
+ retryConfig: {
31
+ enabled: true,
32
+ maxAttempts: 3,
33
+ backoffStrategy: 'exponential',
34
+ baseDelay: 1000,
35
+ maxDelay: 5000,
36
+ retryOn: ['timeout', 'network_error', 'server_error']
37
+ },
38
+ rateLimit: {
39
+ enabled: true,
40
+ requestsPerMinute: 60,
41
+ burstLimit: 10,
42
+ queueMaxSize: 100,
43
+ dropOnFull: false
44
+ },
45
+ dataMapping: { fieldMappings: [] },
46
+ validation: { validateRequest: false, validateResponse: true, strictMode: false },
47
+ monitoring: {
48
+ logRequests: true,
49
+ logResponses: false,
50
+ logErrors: true,
51
+ collectMetrics: true,
52
+ alertOnFailure: true,
53
+ alertThreshold: 5
54
+ }
55
+ },
56
+ {
57
+ id: 'external_metrics',
58
+ name: 'External Metrics API',
59
+ url: 'https://api.example.com/metrics',
60
+ method: 'POST',
61
+ protocol: 'rest',
62
+ authentication: {
63
+ type: 'api_key',
64
+ config: {
65
+ keyName: 'X-API-Key',
66
+ keyValue: '${API_KEY}'
67
+ }
68
+ },
69
+ headers: {
70
+ 'Content-Type': 'application/json',
71
+ 'User-Agent': 'Index-Server/1.0'
72
+ },
73
+ timeout: 10000,
74
+ retryConfig: {
75
+ enabled: true,
76
+ maxAttempts: 5,
77
+ backoffStrategy: 'exponential',
78
+ baseDelay: 2000,
79
+ maxDelay: 30000,
80
+ retryOn: ['timeout', 'network_error', 'server_error', 'rate_limit']
81
+ },
82
+ rateLimit: {
83
+ enabled: true,
84
+ requestsPerMinute: 30,
85
+ burstLimit: 5,
86
+ queueMaxSize: 50,
87
+ dropOnFull: true
88
+ },
89
+ dataMapping: {
90
+ requestTransform: `
91
+ function transform(data) {
92
+ return {
93
+ timestamp: Date.now(),
94
+ source: 'index',
95
+ metrics: data
96
+ };
97
+ }
98
+ `,
99
+ responseTransform: `
100
+ function transform(response) {
101
+ return {
102
+ success: response.status === 'ok',
103
+ processed: response.count || 0,
104
+ errors: response.errors || []
105
+ };
106
+ }
107
+ `,
108
+ fieldMappings: [
109
+ { source: 'cpu_usage', target: 'cpu', transform: 'Math.round(value * 100) / 100' },
110
+ { source: 'memory_usage', target: 'memory', transform: 'Math.round(value)' }
111
+ ]
112
+ },
113
+ validation: {
114
+ validateRequest: true,
115
+ validateResponse: true,
116
+ strictMode: true,
117
+ requestSchema: {
118
+ type: 'object',
119
+ properties: {
120
+ metrics: { type: 'array' },
121
+ timestamp: { type: 'number' }
122
+ },
123
+ required: ['metrics', 'timestamp']
124
+ }
125
+ },
126
+ monitoring: {
127
+ logRequests: true,
128
+ logResponses: true,
129
+ logErrors: true,
130
+ collectMetrics: true,
131
+ alertOnFailure: true,
132
+ alertThreshold: 3
133
+ }
134
+ }
135
+ ];
136
+ defaultEndpoints.forEach(endpoint => {
137
+ this.endpoints.set(endpoint.id, endpoint);
138
+ this.initializeRateLimit(endpoint.id, endpoint.rateLimit);
139
+ });
140
+ }
141
+ initializeRateLimit(endpointId, config) {
142
+ if (config.enabled) {
143
+ this.rateLimiters.set(endpointId, { requests: [], lastReset: Date.now() });
144
+ }
145
+ }
146
+ checkRateLimit(endpointId) {
147
+ const endpoint = this.endpoints.get(endpointId);
148
+ if (!endpoint?.rateLimit.enabled)
149
+ return true;
150
+ const limiter = this.rateLimiters.get(endpointId);
151
+ if (!limiter)
152
+ return true;
153
+ const now = Date.now();
154
+ const config = endpoint.rateLimit;
155
+ limiter.requests = limiter.requests.filter(time => now - time < 60000);
156
+ if (limiter.requests.length >= config.requestsPerMinute)
157
+ return false;
158
+ const recentRequests = limiter.requests.filter(time => now - time < 1000);
159
+ if (recentRequests.length >= config.burstLimit)
160
+ return false;
161
+ limiter.requests.push(now);
162
+ return true;
163
+ }
164
+ createEndpoint(endpoint) {
165
+ const id = `endpoint_${Date.now()}`;
166
+ const fullEndpoint = { id, ...endpoint };
167
+ this.endpoints.set(id, fullEndpoint);
168
+ this.initializeRateLimit(id, fullEndpoint.rateLimit);
169
+ return id;
170
+ }
171
+ getEndpoint(id) {
172
+ return this.endpoints.get(id);
173
+ }
174
+ listEndpoints() {
175
+ return Array.from(this.endpoints.values());
176
+ }
177
+ updateEndpoint(id, updates) {
178
+ const endpoint = this.endpoints.get(id);
179
+ if (!endpoint)
180
+ return false;
181
+ Object.assign(endpoint, updates);
182
+ if (updates.rateLimit) {
183
+ this.initializeRateLimit(id, endpoint.rateLimit);
184
+ }
185
+ return true;
186
+ }
187
+ deleteEndpoint(id) {
188
+ this.rateLimiters.delete(id);
189
+ this.requestQueue.delete(id);
190
+ return this.endpoints.delete(id);
191
+ }
192
+ getConfiguredEndpoints() {
193
+ return Array.from(this.endpoints.values());
194
+ }
195
+ cleanupCache() {
196
+ const now = Date.now();
197
+ for (const [key, cached] of Array.from(this.responseCache.entries())) {
198
+ if (cached.expiry <= now) {
199
+ this.responseCache.delete(key);
200
+ }
201
+ }
202
+ }
203
+ resetRateLimiters() {
204
+ const now = Date.now();
205
+ this.rateLimiters.forEach(limiter => {
206
+ if (now - limiter.lastReset > 60000) {
207
+ limiter.requests = [];
208
+ limiter.lastReset = now;
209
+ }
210
+ });
211
+ }
212
+ }
213
+ exports.EndpointManager = EndpointManager;