@stackmemoryai/stackmemory 0.5.57 → 0.5.59

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 (611) hide show
  1. package/bin/codex-smd +6 -0
  2. package/dist/cli/codex-sm-danger.js +21 -0
  3. package/dist/cli/codex-sm-danger.js.map +7 -0
  4. package/dist/cli/commands/handoff.js +33 -3
  5. package/dist/cli/commands/handoff.js.map +2 -2
  6. package/dist/cli/commands/search.js +20 -3
  7. package/dist/cli/commands/search.js.map +2 -2
  8. package/dist/core/database/sqlite-adapter.js +13 -3
  9. package/dist/core/database/sqlite-adapter.js.map +2 -2
  10. package/dist/core/errors/error-utils.js +208 -0
  11. package/dist/core/errors/error-utils.js.map +7 -0
  12. package/dist/core/errors/index.js +13 -4
  13. package/dist/core/errors/index.js.map +2 -2
  14. package/dist/core/merge/unified-merge-resolver.js +303 -0
  15. package/dist/core/merge/unified-merge-resolver.js.map +7 -0
  16. package/dist/core/monitoring/logger.js +61 -9
  17. package/dist/core/monitoring/logger.js.map +2 -2
  18. package/dist/core/security/index.js +35 -0
  19. package/dist/core/security/index.js.map +7 -0
  20. package/dist/core/security/input-sanitizer.js +321 -0
  21. package/dist/core/security/input-sanitizer.js.map +7 -0
  22. package/dist/core/session/enhanced-handoff.js +136 -2
  23. package/dist/core/session/enhanced-handoff.js.map +3 -3
  24. package/dist/integrations/linear/client.js +5 -1
  25. package/dist/integrations/linear/client.js.map +2 -2
  26. package/dist/integrations/mcp/remote-server.js +27 -36
  27. package/dist/integrations/mcp/remote-server.js.map +2 -2
  28. package/dist/integrations/mcp/server.js +44 -29
  29. package/dist/integrations/mcp/server.js.map +3 -3
  30. package/dist/scripts/benchmark-performance.js +48 -0
  31. package/dist/scripts/benchmark-performance.js.map +7 -0
  32. package/dist/scripts/check-redis.js +42 -0
  33. package/dist/scripts/check-redis.js.map +7 -0
  34. package/dist/scripts/initialize.js +116 -0
  35. package/dist/scripts/initialize.js.map +7 -0
  36. package/dist/scripts/list-linear-tasks.js +124 -0
  37. package/dist/scripts/list-linear-tasks.js.map +7 -0
  38. package/dist/scripts/measure-handoff-impact.js +340 -0
  39. package/dist/scripts/measure-handoff-impact.js.map +7 -0
  40. package/dist/scripts/query-chromadb.js +160 -0
  41. package/dist/scripts/query-chromadb.js.map +7 -0
  42. package/dist/scripts/show-linear-summary.js +119 -0
  43. package/dist/scripts/show-linear-summary.js.map +7 -0
  44. package/dist/scripts/simple-swarm-demo.js +90 -0
  45. package/dist/scripts/simple-swarm-demo.js.map +7 -0
  46. package/dist/scripts/status.js +155 -0
  47. package/dist/scripts/status.js.map +7 -0
  48. package/dist/scripts/test-chromadb-sync.js +192 -0
  49. package/dist/scripts/test-chromadb-sync.js.map +7 -0
  50. package/dist/scripts/test-ralph-iteration-fix.js +86 -0
  51. package/dist/scripts/test-ralph-iteration-fix.js.map +7 -0
  52. package/dist/scripts/test-ralph-iterations.js +121 -0
  53. package/dist/scripts/test-ralph-iterations.js.map +7 -0
  54. package/dist/scripts/test-redis-storage.js +389 -0
  55. package/dist/scripts/test-redis-storage.js.map +7 -0
  56. package/dist/scripts/test-simple-ralph-state-sync.js +115 -0
  57. package/dist/scripts/test-simple-ralph-state-sync.js.map +7 -0
  58. package/dist/scripts/test-swarm-fixes.js +125 -0
  59. package/dist/scripts/test-swarm-fixes.js.map +7 -0
  60. package/dist/scripts/test-swarm-tui.js +23 -0
  61. package/dist/scripts/test-swarm-tui.js.map +7 -0
  62. package/dist/scripts/test-tui-shortcuts.js +52 -0
  63. package/dist/scripts/test-tui-shortcuts.js.map +7 -0
  64. package/dist/scripts/validate-tui-shortcuts.js +60 -0
  65. package/dist/scripts/validate-tui-shortcuts.js.map +7 -0
  66. package/dist/src/agents/core/agent-task-manager.js +527 -0
  67. package/dist/src/agents/core/agent-task-manager.js.map +7 -0
  68. package/dist/src/agents/verifiers/base-verifier.js +133 -0
  69. package/dist/src/agents/verifiers/base-verifier.js.map +7 -0
  70. package/dist/src/agents/verifiers/formatter-verifier.js +130 -0
  71. package/dist/src/agents/verifiers/formatter-verifier.js.map +7 -0
  72. package/dist/src/agents/verifiers/llm-judge.js +252 -0
  73. package/dist/src/agents/verifiers/llm-judge.js.map +7 -0
  74. package/dist/src/cli/auto-detect.js +321 -0
  75. package/dist/src/cli/auto-detect.js.map +7 -0
  76. package/dist/src/cli/claude-sm-danger.js +21 -0
  77. package/dist/src/cli/claude-sm-danger.js.map +7 -0
  78. package/dist/src/cli/claude-sm.js +1156 -0
  79. package/dist/src/cli/claude-sm.js.map +7 -0
  80. package/dist/src/cli/codex-sm-danger.js +21 -0
  81. package/dist/src/cli/codex-sm-danger.js.map +7 -0
  82. package/dist/src/cli/codex-sm.js +349 -0
  83. package/dist/src/cli/codex-sm.js.map +7 -0
  84. package/dist/src/cli/commands/api.js +232 -0
  85. package/dist/src/cli/commands/api.js.map +7 -0
  86. package/dist/src/cli/commands/auto-background.js +180 -0
  87. package/dist/src/cli/commands/auto-background.js.map +7 -0
  88. package/dist/src/cli/commands/cleanup-processes.js +68 -0
  89. package/dist/src/cli/commands/cleanup-processes.js.map +7 -0
  90. package/dist/src/cli/commands/clear.js +202 -0
  91. package/dist/src/cli/commands/clear.js.map +7 -0
  92. package/dist/src/cli/commands/config.js +445 -0
  93. package/dist/src/cli/commands/config.js.map +7 -0
  94. package/dist/src/cli/commands/context-rehydrate.js +751 -0
  95. package/dist/src/cli/commands/context-rehydrate.js.map +7 -0
  96. package/dist/src/cli/commands/context.js +343 -0
  97. package/dist/src/cli/commands/context.js.map +7 -0
  98. package/dist/src/cli/commands/daemon.js +392 -0
  99. package/dist/src/cli/commands/daemon.js.map +7 -0
  100. package/dist/src/cli/commands/dashboard.js +210 -0
  101. package/dist/src/cli/commands/dashboard.js.map +7 -0
  102. package/dist/src/cli/commands/db.js +147 -0
  103. package/dist/src/cli/commands/db.js.map +7 -0
  104. package/dist/src/cli/commands/decision.js +266 -0
  105. package/dist/src/cli/commands/decision.js.map +7 -0
  106. package/dist/src/cli/commands/discovery.js +279 -0
  107. package/dist/src/cli/commands/discovery.js.map +7 -0
  108. package/dist/src/cli/commands/handoff.js +624 -0
  109. package/dist/src/cli/commands/handoff.js.map +7 -0
  110. package/dist/src/cli/commands/hooks.js +298 -0
  111. package/dist/src/cli/commands/hooks.js.map +7 -0
  112. package/dist/src/cli/commands/linear.js +529 -0
  113. package/dist/src/cli/commands/linear.js.map +7 -0
  114. package/dist/src/cli/commands/log.js +169 -0
  115. package/dist/src/cli/commands/log.js.map +7 -0
  116. package/dist/src/cli/commands/login.js +172 -0
  117. package/dist/src/cli/commands/login.js.map +7 -0
  118. package/dist/src/cli/commands/migrate.js +240 -0
  119. package/dist/src/cli/commands/migrate.js.map +7 -0
  120. package/dist/src/cli/commands/model.js +533 -0
  121. package/dist/src/cli/commands/model.js.map +7 -0
  122. package/dist/src/cli/commands/onboard.js +536 -0
  123. package/dist/src/cli/commands/onboard.js.map +7 -0
  124. package/dist/src/cli/commands/projects.js +199 -0
  125. package/dist/src/cli/commands/projects.js.map +7 -0
  126. package/dist/src/cli/commands/ralph.js +909 -0
  127. package/dist/src/cli/commands/ralph.js.map +7 -0
  128. package/dist/src/cli/commands/retrieval.js +248 -0
  129. package/dist/src/cli/commands/retrieval.js.map +7 -0
  130. package/dist/src/cli/commands/search.js +173 -0
  131. package/dist/src/cli/commands/search.js.map +7 -0
  132. package/dist/src/cli/commands/service.js +749 -0
  133. package/dist/src/cli/commands/service.js.map +7 -0
  134. package/dist/src/cli/commands/session.js +200 -0
  135. package/dist/src/cli/commands/session.js.map +7 -0
  136. package/dist/src/cli/commands/settings.js +306 -0
  137. package/dist/src/cli/commands/settings.js.map +7 -0
  138. package/dist/src/cli/commands/setup.js +701 -0
  139. package/dist/src/cli/commands/setup.js.map +7 -0
  140. package/dist/src/cli/commands/shell.js +249 -0
  141. package/dist/src/cli/commands/shell.js.map +7 -0
  142. package/dist/src/cli/commands/signup.js +50 -0
  143. package/dist/src/cli/commands/signup.js.map +7 -0
  144. package/dist/src/cli/commands/skills.js +470 -0
  145. package/dist/src/cli/commands/skills.js.map +7 -0
  146. package/dist/src/cli/commands/sms-notify.js +795 -0
  147. package/dist/src/cli/commands/sms-notify.js.map +7 -0
  148. package/dist/src/cli/commands/storage-tier.js +183 -0
  149. package/dist/src/cli/commands/storage-tier.js.map +7 -0
  150. package/dist/src/cli/commands/sweep.js +249 -0
  151. package/dist/src/cli/commands/sweep.js.map +7 -0
  152. package/dist/src/cli/commands/tasks.js +213 -0
  153. package/dist/src/cli/commands/tasks.js.map +7 -0
  154. package/dist/src/cli/commands/worktree.js +319 -0
  155. package/dist/src/cli/commands/worktree.js.map +7 -0
  156. package/dist/src/cli/index.js +594 -0
  157. package/dist/src/cli/index.js.map +7 -0
  158. package/dist/src/cli/opencode-sm.js +448 -0
  159. package/dist/src/cli/opencode-sm.js.map +7 -0
  160. package/dist/src/cli/utils/viewer.js +96 -0
  161. package/dist/src/cli/utils/viewer.js.map +7 -0
  162. package/dist/src/core/config/config-manager.js +398 -0
  163. package/dist/src/core/config/config-manager.js.map +7 -0
  164. package/dist/src/core/config/feature-flags.js +76 -0
  165. package/dist/src/core/config/feature-flags.js.map +7 -0
  166. package/dist/src/core/config/storage-config.js +115 -0
  167. package/dist/src/core/config/storage-config.js.map +7 -0
  168. package/dist/src/core/config/types.js +144 -0
  169. package/dist/src/core/config/types.js.map +7 -0
  170. package/dist/src/core/context/auto-context.js +80 -0
  171. package/dist/src/core/context/auto-context.js.map +7 -0
  172. package/dist/src/core/context/dual-stack-manager.js +870 -0
  173. package/dist/src/core/context/dual-stack-manager.js.map +7 -0
  174. package/dist/src/core/context/enhanced-rehydration.js +994 -0
  175. package/dist/src/core/context/enhanced-rehydration.js.map +7 -0
  176. package/dist/src/core/context/frame-database.js +479 -0
  177. package/dist/src/core/context/frame-database.js.map +7 -0
  178. package/dist/src/core/context/frame-digest.js +250 -0
  179. package/dist/src/core/context/frame-digest.js.map +7 -0
  180. package/dist/src/core/context/frame-handoff-manager.js +778 -0
  181. package/dist/src/core/context/frame-handoff-manager.js.map +7 -0
  182. package/dist/src/core/context/frame-lifecycle-hooks.js +119 -0
  183. package/dist/src/core/context/frame-lifecycle-hooks.js.map +7 -0
  184. package/dist/src/core/context/frame-recovery.js +302 -0
  185. package/dist/src/core/context/frame-recovery.js.map +7 -0
  186. package/dist/src/core/context/frame-stack.js +314 -0
  187. package/dist/src/core/context/frame-stack.js.map +7 -0
  188. package/dist/src/core/context/frame-types.js +5 -0
  189. package/dist/src/core/context/frame-types.js.map +7 -0
  190. package/dist/src/core/context/index.js +25 -0
  191. package/dist/src/core/context/index.js.map +7 -0
  192. package/dist/src/core/context/permission-manager.js +185 -0
  193. package/dist/src/core/context/permission-manager.js.map +7 -0
  194. package/dist/src/core/context/recursive-context-manager.js +592 -0
  195. package/dist/src/core/context/recursive-context-manager.js.map +7 -0
  196. package/dist/src/core/context/refactored-frame-manager.js +754 -0
  197. package/dist/src/core/context/refactored-frame-manager.js.map +7 -0
  198. package/dist/src/core/context/shared-context-layer.js +621 -0
  199. package/dist/src/core/context/shared-context-layer.js.map +7 -0
  200. package/dist/src/core/context/stack-merge-resolver.js +749 -0
  201. package/dist/src/core/context/stack-merge-resolver.js.map +7 -0
  202. package/dist/src/core/context/validation.js +130 -0
  203. package/dist/src/core/context/validation.js.map +7 -0
  204. package/dist/src/core/database/batch-operations.js +384 -0
  205. package/dist/src/core/database/batch-operations.js.map +7 -0
  206. package/dist/src/core/database/connection-pool.js +330 -0
  207. package/dist/src/core/database/connection-pool.js.map +7 -0
  208. package/dist/src/core/database/database-adapter.js +60 -0
  209. package/dist/src/core/database/database-adapter.js.map +7 -0
  210. package/dist/src/core/database/migration-manager.js +614 -0
  211. package/dist/src/core/database/migration-manager.js.map +7 -0
  212. package/dist/src/core/database/query-cache.js +298 -0
  213. package/dist/src/core/database/query-cache.js.map +7 -0
  214. package/dist/src/core/database/query-router.js +430 -0
  215. package/dist/src/core/database/query-router.js.map +7 -0
  216. package/dist/src/core/database/sqlite-adapter.js +738 -0
  217. package/dist/src/core/database/sqlite-adapter.js.map +7 -0
  218. package/dist/src/core/digest/enhanced-hybrid-digest.js +277 -0
  219. package/dist/src/core/digest/enhanced-hybrid-digest.js.map +7 -0
  220. package/dist/src/core/digest/frame-digest-integration.js +176 -0
  221. package/dist/src/core/digest/frame-digest-integration.js.map +7 -0
  222. package/dist/src/core/digest/hybrid-digest-generator.js +553 -0
  223. package/dist/src/core/digest/hybrid-digest-generator.js.map +7 -0
  224. package/dist/src/core/digest/index.js +9 -0
  225. package/dist/src/core/digest/index.js.map +7 -0
  226. package/dist/src/core/digest/types.js +25 -0
  227. package/dist/src/core/digest/types.js.map +7 -0
  228. package/dist/src/core/errors/error-utils.js +208 -0
  229. package/dist/src/core/errors/error-utils.js.map +7 -0
  230. package/dist/src/core/errors/index.js +521 -0
  231. package/dist/src/core/errors/index.js.map +7 -0
  232. package/dist/src/core/errors/recovery.js +269 -0
  233. package/dist/src/core/errors/recovery.js.map +7 -0
  234. package/dist/src/core/execution/parallel-executor.js +258 -0
  235. package/dist/src/core/execution/parallel-executor.js.map +7 -0
  236. package/dist/src/core/frame/workflow-templates.js +319 -0
  237. package/dist/src/core/frame/workflow-templates.js.map +7 -0
  238. package/dist/src/core/merge/conflict-detector.js +431 -0
  239. package/dist/src/core/merge/conflict-detector.js.map +7 -0
  240. package/dist/src/core/merge/index.js +9 -0
  241. package/dist/src/core/merge/index.js.map +7 -0
  242. package/dist/src/core/merge/resolution-engine.js +558 -0
  243. package/dist/src/core/merge/resolution-engine.js.map +7 -0
  244. package/dist/src/core/merge/stack-diff.js +532 -0
  245. package/dist/src/core/merge/stack-diff.js.map +7 -0
  246. package/dist/src/core/merge/types.js +5 -0
  247. package/dist/src/core/merge/types.js.map +7 -0
  248. package/dist/src/core/merge/unified-merge-resolver.js +303 -0
  249. package/dist/src/core/merge/unified-merge-resolver.js.map +7 -0
  250. package/dist/src/core/models/fallback-monitor.js +232 -0
  251. package/dist/src/core/models/fallback-monitor.js.map +7 -0
  252. package/dist/src/core/models/model-router.js +340 -0
  253. package/dist/src/core/models/model-router.js.map +7 -0
  254. package/dist/src/core/monitoring/error-handler.js +49 -0
  255. package/dist/src/core/monitoring/error-handler.js.map +7 -0
  256. package/dist/src/core/monitoring/logger.js +202 -0
  257. package/dist/src/core/monitoring/logger.js.map +7 -0
  258. package/dist/src/core/monitoring/metrics.js +172 -0
  259. package/dist/src/core/monitoring/metrics.js.map +7 -0
  260. package/dist/src/core/monitoring/progress-tracker.js +189 -0
  261. package/dist/src/core/monitoring/progress-tracker.js.map +7 -0
  262. package/dist/src/core/monitoring/session-monitor.js +300 -0
  263. package/dist/src/core/monitoring/session-monitor.js.map +7 -0
  264. package/dist/src/core/performance/context-cache.js +273 -0
  265. package/dist/src/core/performance/context-cache.js.map +7 -0
  266. package/dist/src/core/performance/index.js +11 -0
  267. package/dist/src/core/performance/index.js.map +7 -0
  268. package/dist/src/core/performance/lazy-context-loader.js +327 -0
  269. package/dist/src/core/performance/lazy-context-loader.js.map +7 -0
  270. package/dist/src/core/performance/monitor.js +221 -0
  271. package/dist/src/core/performance/monitor.js.map +7 -0
  272. package/dist/src/core/performance/optimized-frame-context.js +345 -0
  273. package/dist/src/core/performance/optimized-frame-context.js.map +7 -0
  274. package/dist/src/core/performance/performance-benchmark.js +277 -0
  275. package/dist/src/core/performance/performance-benchmark.js.map +7 -0
  276. package/dist/src/core/performance/performance-profiler.js +370 -0
  277. package/dist/src/core/performance/performance-profiler.js.map +7 -0
  278. package/dist/src/core/performance/streaming-jsonl-parser.js +195 -0
  279. package/dist/src/core/performance/streaming-jsonl-parser.js.map +7 -0
  280. package/dist/src/core/persistence/postgres-adapter.js +349 -0
  281. package/dist/src/core/persistence/postgres-adapter.js.map +7 -0
  282. package/dist/src/core/projects/project-isolation.js +201 -0
  283. package/dist/src/core/projects/project-isolation.js.map +7 -0
  284. package/dist/src/core/projects/project-manager.js +697 -0
  285. package/dist/src/core/projects/project-manager.js.map +7 -0
  286. package/dist/src/core/query/query-parser.js +370 -0
  287. package/dist/src/core/query/query-parser.js.map +7 -0
  288. package/dist/src/core/query/query-templates.js +321 -0
  289. package/dist/src/core/query/query-templates.js.map +7 -0
  290. package/dist/src/core/retrieval/context-retriever.js +479 -0
  291. package/dist/src/core/retrieval/context-retriever.js.map +7 -0
  292. package/dist/src/core/retrieval/index.js +8 -0
  293. package/dist/src/core/retrieval/index.js.map +7 -0
  294. package/dist/src/core/retrieval/llm-context-retrieval.js +613 -0
  295. package/dist/src/core/retrieval/llm-context-retrieval.js.map +7 -0
  296. package/dist/src/core/retrieval/llm-provider.js +151 -0
  297. package/dist/src/core/retrieval/llm-provider.js.map +7 -0
  298. package/dist/src/core/retrieval/retrieval-audit.js +236 -0
  299. package/dist/src/core/retrieval/retrieval-audit.js.map +7 -0
  300. package/dist/src/core/retrieval/summary-generator.js +589 -0
  301. package/dist/src/core/retrieval/summary-generator.js.map +7 -0
  302. package/dist/src/core/retrieval/types.js +21 -0
  303. package/dist/src/core/retrieval/types.js.map +7 -0
  304. package/dist/src/core/security/index.js +35 -0
  305. package/dist/src/core/security/index.js.map +7 -0
  306. package/dist/src/core/security/input-sanitizer.js +321 -0
  307. package/dist/src/core/security/input-sanitizer.js.map +7 -0
  308. package/dist/src/core/session/clear-survival.js +465 -0
  309. package/dist/src/core/session/clear-survival.js.map +7 -0
  310. package/dist/src/core/session/enhanced-handoff.js +792 -0
  311. package/dist/src/core/session/enhanced-handoff.js.map +7 -0
  312. package/dist/src/core/session/handoff-generator.js +343 -0
  313. package/dist/src/core/session/handoff-generator.js.map +7 -0
  314. package/dist/src/core/session/index.js +15 -0
  315. package/dist/src/core/session/index.js.map +7 -0
  316. package/dist/src/core/session/session-manager.js +347 -0
  317. package/dist/src/core/session/session-manager.js.map +7 -0
  318. package/dist/src/core/skills/index.js +7 -0
  319. package/dist/src/core/skills/index.js.map +7 -0
  320. package/dist/src/core/skills/skill-storage.js +764 -0
  321. package/dist/src/core/skills/skill-storage.js.map +7 -0
  322. package/dist/src/core/skills/types.js +193 -0
  323. package/dist/src/core/skills/types.js.map +7 -0
  324. package/dist/src/core/storage/chromadb-adapter.js +354 -0
  325. package/dist/src/core/storage/chromadb-adapter.js.map +7 -0
  326. package/dist/src/core/storage/infinite-storage.js +510 -0
  327. package/dist/src/core/storage/infinite-storage.js.map +7 -0
  328. package/dist/src/core/storage/remote-storage.js +489 -0
  329. package/dist/src/core/storage/remote-storage.js.map +7 -0
  330. package/dist/src/core/storage/two-tier-storage.js +766 -0
  331. package/dist/src/core/storage/two-tier-storage.js.map +7 -0
  332. package/dist/src/core/trace/cli-trace-wrapper.js +132 -0
  333. package/dist/src/core/trace/cli-trace-wrapper.js.map +7 -0
  334. package/dist/src/core/trace/db-trace-wrapper.js +247 -0
  335. package/dist/src/core/trace/db-trace-wrapper.js.map +7 -0
  336. package/dist/src/core/trace/debug-trace.js +417 -0
  337. package/dist/src/core/trace/debug-trace.js.map +7 -0
  338. package/dist/src/core/trace/index.js +109 -0
  339. package/dist/src/core/trace/index.js.map +7 -0
  340. package/dist/src/core/trace/linear-api-wrapper.js +178 -0
  341. package/dist/src/core/trace/linear-api-wrapper.js.map +7 -0
  342. package/dist/src/core/trace/trace-detector.js +528 -0
  343. package/dist/src/core/trace/trace-detector.js.map +7 -0
  344. package/dist/src/core/trace/trace-store.js +345 -0
  345. package/dist/src/core/trace/trace-store.js.map +7 -0
  346. package/dist/src/core/trace/types.js +77 -0
  347. package/dist/src/core/trace/types.js.map +7 -0
  348. package/dist/src/core/types.js +5 -0
  349. package/dist/src/core/types.js.map +7 -0
  350. package/dist/src/core/utils/async-mutex.js +114 -0
  351. package/dist/src/core/utils/async-mutex.js.map +7 -0
  352. package/dist/src/core/utils/compression.js +83 -0
  353. package/dist/src/core/utils/compression.js.map +7 -0
  354. package/dist/src/core/utils/update-checker.js +218 -0
  355. package/dist/src/core/utils/update-checker.js.map +7 -0
  356. package/dist/src/core/worktree/worktree-manager.js +465 -0
  357. package/dist/src/core/worktree/worktree-manager.js.map +7 -0
  358. package/dist/src/daemon/daemon-config.js +149 -0
  359. package/dist/src/daemon/daemon-config.js.map +7 -0
  360. package/dist/src/daemon/services/context-service.js +122 -0
  361. package/dist/src/daemon/services/context-service.js.map +7 -0
  362. package/dist/src/daemon/services/linear-service.js +136 -0
  363. package/dist/src/daemon/services/linear-service.js.map +7 -0
  364. package/dist/src/daemon/session-daemon.js +312 -0
  365. package/dist/src/daemon/session-daemon.js.map +7 -0
  366. package/dist/src/daemon/unified-daemon.js +276 -0
  367. package/dist/src/daemon/unified-daemon.js.map +7 -0
  368. package/dist/src/features/analytics/api/analytics-api.js +287 -0
  369. package/dist/src/features/analytics/api/analytics-api.js.map +7 -0
  370. package/dist/src/features/analytics/core/analytics-service.js +282 -0
  371. package/dist/src/features/analytics/core/analytics-service.js.map +7 -0
  372. package/dist/src/features/analytics/index.js +18 -0
  373. package/dist/src/features/analytics/index.js.map +7 -0
  374. package/dist/src/features/analytics/queries/metrics-queries.js +277 -0
  375. package/dist/src/features/analytics/queries/metrics-queries.js.map +7 -0
  376. package/dist/src/features/analytics/types/metrics.js +5 -0
  377. package/dist/src/features/analytics/types/metrics.js.map +7 -0
  378. package/dist/src/features/browser/browser-mcp.js +492 -0
  379. package/dist/src/features/browser/browser-mcp.js.map +7 -0
  380. package/dist/src/features/sweep/index.js +20 -0
  381. package/dist/src/features/sweep/index.js.map +7 -0
  382. package/dist/src/features/sweep/prediction-client.js +155 -0
  383. package/dist/src/features/sweep/prediction-client.js.map +7 -0
  384. package/dist/src/features/sweep/prompt-builder.js +85 -0
  385. package/dist/src/features/sweep/prompt-builder.js.map +7 -0
  386. package/dist/src/features/sweep/pty-wrapper.js +171 -0
  387. package/dist/src/features/sweep/pty-wrapper.js.map +7 -0
  388. package/dist/src/features/sweep/state-watcher.js +87 -0
  389. package/dist/src/features/sweep/state-watcher.js.map +7 -0
  390. package/dist/src/features/sweep/status-bar.js +88 -0
  391. package/dist/src/features/sweep/status-bar.js.map +7 -0
  392. package/dist/src/features/sweep/sweep-server-manager.js +226 -0
  393. package/dist/src/features/sweep/sweep-server-manager.js.map +7 -0
  394. package/dist/src/features/sweep/tab-interceptor.js +38 -0
  395. package/dist/src/features/sweep/tab-interceptor.js.map +7 -0
  396. package/dist/src/features/sweep/types.js +18 -0
  397. package/dist/src/features/sweep/types.js.map +7 -0
  398. package/dist/src/features/tasks/linear-task-manager.js +487 -0
  399. package/dist/src/features/tasks/linear-task-manager.js.map +7 -0
  400. package/dist/src/features/tasks/task-aware-context.js +410 -0
  401. package/dist/src/features/tasks/task-aware-context.js.map +7 -0
  402. package/dist/src/features/tui/simple-monitor.js +116 -0
  403. package/dist/src/features/tui/simple-monitor.js.map +7 -0
  404. package/dist/src/features/tui/swarm-monitor.js +648 -0
  405. package/dist/src/features/tui/swarm-monitor.js.map +7 -0
  406. package/dist/src/features/web/client/stores/task-store.js +26 -0
  407. package/dist/src/features/web/client/stores/task-store.js.map +7 -0
  408. package/dist/src/features/web/server/index.js +194 -0
  409. package/dist/src/features/web/server/index.js.map +7 -0
  410. package/dist/src/hooks/auto-background.js +151 -0
  411. package/dist/src/hooks/auto-background.js.map +7 -0
  412. package/dist/src/hooks/claude-code-whatsapp-hook.js +197 -0
  413. package/dist/src/hooks/claude-code-whatsapp-hook.js.map +7 -0
  414. package/dist/src/hooks/config.js +150 -0
  415. package/dist/src/hooks/config.js.map +7 -0
  416. package/dist/src/hooks/daemon.js +364 -0
  417. package/dist/src/hooks/daemon.js.map +7 -0
  418. package/dist/src/hooks/events.js +58 -0
  419. package/dist/src/hooks/events.js.map +7 -0
  420. package/dist/src/hooks/index.js +12 -0
  421. package/dist/src/hooks/index.js.map +7 -0
  422. package/dist/src/hooks/linear-task-picker.js +186 -0
  423. package/dist/src/hooks/linear-task-picker.js.map +7 -0
  424. package/dist/src/hooks/schemas.js +197 -0
  425. package/dist/src/hooks/schemas.js.map +7 -0
  426. package/dist/src/hooks/secure-fs.js +49 -0
  427. package/dist/src/hooks/secure-fs.js.map +7 -0
  428. package/dist/src/hooks/security-logger.js +155 -0
  429. package/dist/src/hooks/security-logger.js.map +7 -0
  430. package/dist/src/hooks/session-summary.js +222 -0
  431. package/dist/src/hooks/session-summary.js.map +7 -0
  432. package/dist/src/hooks/sms-action-runner.js +371 -0
  433. package/dist/src/hooks/sms-action-runner.js.map +7 -0
  434. package/dist/src/hooks/sms-notify.js +506 -0
  435. package/dist/src/hooks/sms-notify.js.map +7 -0
  436. package/dist/src/hooks/sms-watcher.js +93 -0
  437. package/dist/src/hooks/sms-watcher.js.map +7 -0
  438. package/dist/src/hooks/sms-webhook.js +555 -0
  439. package/dist/src/hooks/sms-webhook.js.map +7 -0
  440. package/dist/src/hooks/whatsapp-commands.js +479 -0
  441. package/dist/src/hooks/whatsapp-commands.js.map +7 -0
  442. package/dist/src/hooks/whatsapp-scheduler.js +317 -0
  443. package/dist/src/hooks/whatsapp-scheduler.js.map +7 -0
  444. package/dist/src/hooks/whatsapp-sync.js +409 -0
  445. package/dist/src/hooks/whatsapp-sync.js.map +7 -0
  446. package/dist/src/index.js +25 -0
  447. package/dist/src/index.js.map +7 -0
  448. package/dist/src/integrations/anthropic/client.js +263 -0
  449. package/dist/src/integrations/anthropic/client.js.map +7 -0
  450. package/dist/src/integrations/claude-code/agent-bridge.js +768 -0
  451. package/dist/src/integrations/claude-code/agent-bridge.js.map +7 -0
  452. package/dist/src/integrations/claude-code/enhanced-pre-clear-hooks.js +459 -0
  453. package/dist/src/integrations/claude-code/enhanced-pre-clear-hooks.js.map +7 -0
  454. package/dist/src/integrations/claude-code/lifecycle-hooks.js +254 -0
  455. package/dist/src/integrations/claude-code/lifecycle-hooks.js.map +7 -0
  456. package/dist/src/integrations/claude-code/post-task-hooks.js +545 -0
  457. package/dist/src/integrations/claude-code/post-task-hooks.js.map +7 -0
  458. package/dist/src/integrations/claude-code/subagent-client-stub.js +20 -0
  459. package/dist/src/integrations/claude-code/subagent-client-stub.js.map +7 -0
  460. package/dist/src/integrations/claude-code/subagent-client.js +511 -0
  461. package/dist/src/integrations/claude-code/subagent-client.js.map +7 -0
  462. package/dist/src/integrations/claude-code/task-coordinator.js +360 -0
  463. package/dist/src/integrations/claude-code/task-coordinator.js.map +7 -0
  464. package/dist/src/integrations/linear/auth.js +337 -0
  465. package/dist/src/integrations/linear/auth.js.map +7 -0
  466. package/dist/src/integrations/linear/auto-sync.js +258 -0
  467. package/dist/src/integrations/linear/auto-sync.js.map +7 -0
  468. package/dist/src/integrations/linear/client.js +634 -0
  469. package/dist/src/integrations/linear/client.js.map +7 -0
  470. package/dist/src/integrations/linear/config.js +130 -0
  471. package/dist/src/integrations/linear/config.js.map +7 -0
  472. package/dist/src/integrations/linear/migration.js +361 -0
  473. package/dist/src/integrations/linear/migration.js.map +7 -0
  474. package/dist/src/integrations/linear/oauth-server.js +454 -0
  475. package/dist/src/integrations/linear/oauth-server.js.map +7 -0
  476. package/dist/src/integrations/linear/rest-client.js +213 -0
  477. package/dist/src/integrations/linear/rest-client.js.map +7 -0
  478. package/dist/src/integrations/linear/sync-manager.js +236 -0
  479. package/dist/src/integrations/linear/sync-manager.js.map +7 -0
  480. package/dist/src/integrations/linear/sync-service.js +231 -0
  481. package/dist/src/integrations/linear/sync-service.js.map +7 -0
  482. package/dist/src/integrations/linear/sync.js +782 -0
  483. package/dist/src/integrations/linear/sync.js.map +7 -0
  484. package/dist/src/integrations/linear/types.js +5 -0
  485. package/dist/src/integrations/linear/types.js.map +7 -0
  486. package/dist/src/integrations/linear/unified-sync.js +589 -0
  487. package/dist/src/integrations/linear/unified-sync.js.map +7 -0
  488. package/dist/src/integrations/linear/webhook-handler.js +219 -0
  489. package/dist/src/integrations/linear/webhook-handler.js.map +7 -0
  490. package/dist/src/integrations/linear/webhook-server.js +218 -0
  491. package/dist/src/integrations/linear/webhook-server.js.map +7 -0
  492. package/dist/src/integrations/linear/webhook.js +291 -0
  493. package/dist/src/integrations/linear/webhook.js.map +7 -0
  494. package/dist/src/integrations/mcp/handlers/code-execution-handlers.js +266 -0
  495. package/dist/src/integrations/mcp/handlers/code-execution-handlers.js.map +7 -0
  496. package/dist/src/integrations/mcp/handlers/context-handlers.js +257 -0
  497. package/dist/src/integrations/mcp/handlers/context-handlers.js.map +7 -0
  498. package/dist/src/integrations/mcp/handlers/discovery-handlers.js +497 -0
  499. package/dist/src/integrations/mcp/handlers/discovery-handlers.js.map +7 -0
  500. package/dist/src/integrations/mcp/handlers/index.js +166 -0
  501. package/dist/src/integrations/mcp/handlers/index.js.map +7 -0
  502. package/dist/src/integrations/mcp/handlers/linear-handlers.js +247 -0
  503. package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +7 -0
  504. package/dist/src/integrations/mcp/handlers/skill-handlers.js +529 -0
  505. package/dist/src/integrations/mcp/handlers/skill-handlers.js.map +7 -0
  506. package/dist/src/integrations/mcp/handlers/task-handlers.js +239 -0
  507. package/dist/src/integrations/mcp/handlers/task-handlers.js.map +7 -0
  508. package/dist/src/integrations/mcp/handlers/trace-handlers.js +308 -0
  509. package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +7 -0
  510. package/dist/src/integrations/mcp/index.js +23 -0
  511. package/dist/src/integrations/mcp/index.js.map +7 -0
  512. package/dist/src/integrations/mcp/middleware/tool-scoring.js +356 -0
  513. package/dist/src/integrations/mcp/middleware/tool-scoring.js.map +7 -0
  514. package/dist/src/integrations/mcp/refactored-server.js +374 -0
  515. package/dist/src/integrations/mcp/refactored-server.js.map +7 -0
  516. package/dist/src/integrations/mcp/remote-server.js +682 -0
  517. package/dist/src/integrations/mcp/remote-server.js.map +7 -0
  518. package/dist/src/integrations/mcp/schemas.js +147 -0
  519. package/dist/src/integrations/mcp/schemas.js.map +7 -0
  520. package/dist/src/integrations/mcp/server.js +1975 -0
  521. package/dist/src/integrations/mcp/server.js.map +7 -0
  522. package/dist/src/integrations/mcp/tool-definitions-code.js +125 -0
  523. package/dist/src/integrations/mcp/tool-definitions-code.js.map +7 -0
  524. package/dist/src/integrations/mcp/tool-definitions.js +702 -0
  525. package/dist/src/integrations/mcp/tool-definitions.js.map +7 -0
  526. package/dist/src/integrations/ralph/bridge/ralph-stackmemory-bridge.js +860 -0
  527. package/dist/src/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +7 -0
  528. package/dist/src/integrations/ralph/context/context-budget-manager.js +301 -0
  529. package/dist/src/integrations/ralph/context/context-budget-manager.js.map +7 -0
  530. package/dist/src/integrations/ralph/context/stackmemory-context-loader.js +360 -0
  531. package/dist/src/integrations/ralph/context/stackmemory-context-loader.js.map +7 -0
  532. package/dist/src/integrations/ralph/coordination/enhanced-coordination.js +410 -0
  533. package/dist/src/integrations/ralph/coordination/enhanced-coordination.js.map +7 -0
  534. package/dist/src/integrations/ralph/index.js +18 -0
  535. package/dist/src/integrations/ralph/index.js.map +7 -0
  536. package/dist/src/integrations/ralph/learning/pattern-learner.js +401 -0
  537. package/dist/src/integrations/ralph/learning/pattern-learner.js.map +7 -0
  538. package/dist/src/integrations/ralph/lifecycle/iteration-lifecycle.js +448 -0
  539. package/dist/src/integrations/ralph/lifecycle/iteration-lifecycle.js.map +7 -0
  540. package/dist/src/integrations/ralph/monitoring/swarm-dashboard.js +294 -0
  541. package/dist/src/integrations/ralph/monitoring/swarm-dashboard.js.map +7 -0
  542. package/dist/src/integrations/ralph/monitoring/swarm-registry.js +108 -0
  543. package/dist/src/integrations/ralph/monitoring/swarm-registry.js.map +7 -0
  544. package/dist/src/integrations/ralph/orchestration/multi-loop-orchestrator.js +463 -0
  545. package/dist/src/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +7 -0
  546. package/dist/src/integrations/ralph/patterns/compounding-engineering-pattern.js +400 -0
  547. package/dist/src/integrations/ralph/patterns/compounding-engineering-pattern.js.map +7 -0
  548. package/dist/src/integrations/ralph/patterns/extended-coherence-sessions.js +473 -0
  549. package/dist/src/integrations/ralph/patterns/extended-coherence-sessions.js.map +7 -0
  550. package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js +388 -0
  551. package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js.map +7 -0
  552. package/dist/src/integrations/ralph/performance/performance-optimizer.js +358 -0
  553. package/dist/src/integrations/ralph/performance/performance-optimizer.js.map +7 -0
  554. package/dist/src/integrations/ralph/recovery/crash-recovery.js +462 -0
  555. package/dist/src/integrations/ralph/recovery/crash-recovery.js.map +7 -0
  556. package/dist/src/integrations/ralph/state/state-reconciler.js +404 -0
  557. package/dist/src/integrations/ralph/state/state-reconciler.js.map +7 -0
  558. package/dist/src/integrations/ralph/swarm/git-workflow-manager.js +428 -0
  559. package/dist/src/integrations/ralph/swarm/git-workflow-manager.js.map +7 -0
  560. package/dist/src/integrations/ralph/swarm/swarm-coordinator.js +996 -0
  561. package/dist/src/integrations/ralph/swarm/swarm-coordinator.js.map +7 -0
  562. package/dist/src/integrations/ralph/types.js +5 -0
  563. package/dist/src/integrations/ralph/types.js.map +7 -0
  564. package/dist/src/integrations/ralph/visualization/ralph-debugger.js +585 -0
  565. package/dist/src/integrations/ralph/visualization/ralph-debugger.js.map +7 -0
  566. package/dist/src/mcp/stackmemory-mcp-server.js +554 -0
  567. package/dist/src/mcp/stackmemory-mcp-server.js.map +7 -0
  568. package/dist/src/middleware/exponential-rate-limiter.js +289 -0
  569. package/dist/src/middleware/exponential-rate-limiter.js.map +7 -0
  570. package/dist/src/models/user.model.js +358 -0
  571. package/dist/src/models/user.model.js.map +7 -0
  572. package/dist/src/servers/production/auth-middleware.js +528 -0
  573. package/dist/src/servers/production/auth-middleware.js.map +7 -0
  574. package/dist/src/services/config-service.js +65 -0
  575. package/dist/src/services/config-service.js.map +7 -0
  576. package/dist/src/services/context-service.js +194 -0
  577. package/dist/src/services/context-service.js.map +7 -0
  578. package/dist/src/skills/api-discovery.js +354 -0
  579. package/dist/src/skills/api-discovery.js.map +7 -0
  580. package/dist/src/skills/api-skill.js +475 -0
  581. package/dist/src/skills/api-skill.js.map +7 -0
  582. package/dist/src/skills/claude-skills.js +1061 -0
  583. package/dist/src/skills/claude-skills.js.map +7 -0
  584. package/dist/src/skills/dashboard-launcher.js +216 -0
  585. package/dist/src/skills/dashboard-launcher.js.map +7 -0
  586. package/dist/src/skills/recursive-agent-orchestrator.js +575 -0
  587. package/dist/src/skills/recursive-agent-orchestrator.js.map +7 -0
  588. package/dist/src/skills/repo-ingestion-skill.js +609 -0
  589. package/dist/src/skills/repo-ingestion-skill.js.map +7 -0
  590. package/dist/src/skills/unified-rlm-orchestrator.js +404 -0
  591. package/dist/src/skills/unified-rlm-orchestrator.js.map +7 -0
  592. package/dist/src/types/task.js +5 -0
  593. package/dist/src/types/task.js.map +7 -0
  594. package/dist/src/utils/env.js +50 -0
  595. package/dist/src/utils/env.js.map +7 -0
  596. package/dist/src/utils/formatting.js +62 -0
  597. package/dist/src/utils/formatting.js.map +7 -0
  598. package/dist/src/utils/process-cleanup.js +136 -0
  599. package/dist/src/utils/process-cleanup.js.map +7 -0
  600. package/package.json +4 -3
  601. package/scripts/create-cleanup-issues.js +302 -0
  602. package/scripts/demos/browser-test.ts +39 -0
  603. package/scripts/demos/ralph-integration-demo.ts +244 -0
  604. package/scripts/demos/trace-demo.ts +214 -0
  605. package/scripts/demos/trace-detector.demo.ts +171 -0
  606. package/scripts/demos/trace-test.ts +67 -0
  607. package/scripts/initialize.ts +16 -7
  608. package/scripts/install.sh +14 -62
  609. package/scripts/status.ts +111 -46
  610. package/scripts/test-claude-config.sh +123 -0
  611. package/scripts/validate-claude-config.sh +155 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/skills/api-discovery.ts"],
4
+ "sourcesContent": ["/**\n * API Auto-Discovery Skill\n *\n * Automatically detects API endpoints and OpenAPI specs when Claude\n * reads documentation or API URLs, then registers them for easy access.\n */\n\nimport { execSync } from 'child_process';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\nimport { logger } from '../core/monitoring/logger.js';\nimport { getAPISkill } from './api-skill.js';\n\n// Common API documentation patterns\nconst API_PATTERNS = [\n // Direct API URLs\n {\n pattern: /https?:\\/\\/api\\.([a-z0-9-]+)\\.(com|io|dev|app|co)/,\n nameGroup: 1,\n },\n // REST API paths in docs\n { pattern: /https?:\\/\\/([a-z0-9-]+)\\.com\\/api/, nameGroup: 1 },\n // Developer docs\n { pattern: /https?:\\/\\/developer\\.([a-z0-9-]+)\\.com/, nameGroup: 1 },\n // Docs subdomains\n { pattern: /https?:\\/\\/docs\\.([a-z0-9-]+)\\.(com|io|dev)/, nameGroup: 1 },\n];\n\n// Known OpenAPI spec locations for popular services\nconst KNOWN_SPECS: Record<string, string> = {\n github:\n 'https://raw.githubusercontent.com/github/rest-api-description/main/descriptions/api.github.com/api.github.com.json',\n stripe:\n 'https://raw.githubusercontent.com/stripe/openapi/master/openapi/spec3.json',\n twilio:\n 'https://raw.githubusercontent.com/twilio/twilio-oai/main/spec/json/twilio_api_v2010.json',\n slack: 'https://api.slack.com/specs/openapi/v2/slack_web.json',\n discord:\n 'https://raw.githubusercontent.com/discord/discord-api-spec/main/specs/openapi.json',\n openai:\n 'https://raw.githubusercontent.com/openai/openai-openapi/master/openapi.yaml',\n anthropic:\n 'https://raw.githubusercontent.com/anthropics/anthropic-sdk-python/main/openapi.json',\n linear: 'https://api.linear.app/graphql', // GraphQL, not REST\n notion:\n 'https://raw.githubusercontent.com/NotionX/notion-sdk-js/main/openapi.json',\n vercel: 'https://openapi.vercel.sh/',\n cloudflare:\n 'https://raw.githubusercontent.com/cloudflare/api-schemas/main/openapi.json',\n // Google Cloud Platform - uses Google Discovery format\n gcp: 'https://www.googleapis.com/discovery/v1/apis',\n 'gcp-compute': 'https://compute.googleapis.com/$discovery/rest?version=v1',\n 'gcp-storage': 'https://storage.googleapis.com/$discovery/rest?version=v1',\n 'gcp-run': 'https://run.googleapis.com/$discovery/rest?version=v2',\n 'gcp-functions':\n 'https://cloudfunctions.googleapis.com/$discovery/rest?version=v2',\n 'gcp-bigquery': 'https://bigquery.googleapis.com/$discovery/rest?version=v2',\n 'gcp-aiplatform':\n 'https://aiplatform.googleapis.com/$discovery/rest?version=v1',\n // Railway - GraphQL API\n railway: 'https://backboard.railway.com/graphql/v2', // GraphQL endpoint\n};\n\n// Known base URLs for popular services\nconst KNOWN_BASES: Record<string, string> = {\n github: 'https://api.github.com',\n stripe: 'https://api.stripe.com',\n twilio: 'https://api.twilio.com',\n slack: 'https://slack.com/api',\n discord: 'https://discord.com/api',\n openai: 'https://api.openai.com',\n anthropic: 'https://api.anthropic.com',\n linear: 'https://api.linear.app',\n notion: 'https://api.notion.com',\n vercel: 'https://api.vercel.com',\n cloudflare: 'https://api.cloudflare.com',\n // Google Cloud Platform\n gcp: 'https://www.googleapis.com',\n 'gcp-compute': 'https://compute.googleapis.com',\n 'gcp-storage': 'https://storage.googleapis.com',\n 'gcp-run': 'https://run.googleapis.com',\n 'gcp-functions': 'https://cloudfunctions.googleapis.com',\n 'gcp-bigquery': 'https://bigquery.googleapis.com',\n 'gcp-aiplatform': 'https://aiplatform.googleapis.com',\n // Railway (GraphQL)\n railway: 'https://backboard.railway.com/graphql/v2',\n};\n\n// API types for special handling\nconst API_TYPES: Record<string, 'rest' | 'graphql' | 'google-discovery'> = {\n railway: 'graphql',\n linear: 'graphql',\n gcp: 'google-discovery',\n 'gcp-compute': 'google-discovery',\n 'gcp-storage': 'google-discovery',\n 'gcp-run': 'google-discovery',\n 'gcp-functions': 'google-discovery',\n 'gcp-bigquery': 'google-discovery',\n 'gcp-aiplatform': 'google-discovery',\n};\n\nexport interface DiscoveredAPI {\n name: string;\n baseUrl: string;\n specUrl?: string;\n source: 'url' | 'docs' | 'known' | 'inferred';\n confidence: number; // 0-1\n apiType?: 'rest' | 'graphql' | 'google-discovery';\n}\n\nexport interface DiscoveryResult {\n discovered: DiscoveredAPI[];\n registered: string[];\n skipped: string[];\n}\n\nexport class APIDiscoverySkill {\n private discoveryLog: string;\n private discoveredAPIs: Map<string, DiscoveredAPI> = new Map();\n\n constructor() {\n this.discoveryLog = path.join(\n os.homedir(),\n '.stackmemory',\n 'api-discovery.log'\n );\n }\n\n /**\n * Analyze a URL for potential API endpoints\n */\n analyzeUrl(url: string): DiscoveredAPI | null {\n // Check for GCP URLs first (special pattern)\n if (url.includes('googleapis.com')) {\n const gcpMatch = url.match(/https?:\\/\\/([a-z]+)\\.googleapis\\.com/);\n if (gcpMatch) {\n const service = gcpMatch[1];\n const name = `gcp-${service}`;\n return {\n name,\n baseUrl: `https://${service}.googleapis.com`,\n specUrl:\n KNOWN_SPECS[name] ||\n `https://${service}.googleapis.com/$discovery/rest?version=v1`,\n source: 'known',\n confidence: 0.95,\n apiType: 'google-discovery',\n };\n }\n }\n\n // Check for Railway\n if (url.includes('railway.com') || url.includes('railway.app')) {\n return {\n name: 'railway',\n baseUrl: KNOWN_BASES['railway'],\n specUrl: KNOWN_SPECS['railway'],\n source: 'known',\n confidence: 0.95,\n apiType: 'graphql',\n };\n }\n\n // Check if it's a known service\n for (const [name, baseUrl] of Object.entries(KNOWN_BASES)) {\n if (url.includes(name) || url.includes(baseUrl)) {\n return {\n name,\n baseUrl,\n specUrl: KNOWN_SPECS[name],\n source: 'known',\n confidence: 0.95,\n apiType: API_TYPES[name] || 'rest',\n };\n }\n }\n\n // Try to match API patterns\n for (const { pattern, nameGroup } of API_PATTERNS) {\n const match = url.match(pattern);\n if (match) {\n const name = match[nameGroup].toLowerCase();\n const baseUrl = this.inferBaseUrl(url, name);\n\n return {\n name,\n baseUrl,\n source: 'inferred',\n confidence: 0.7,\n apiType: 'rest',\n };\n }\n }\n\n return null;\n }\n\n /**\n * Infer base URL from a discovered URL\n */\n private inferBaseUrl(url: string, name: string): string {\n // Try common patterns\n const patterns = [\n `https://api.${name}.com`,\n `https://api.${name}.io`,\n `https://${name}.com/api`,\n ];\n\n // Extract domain from URL\n try {\n const urlObj = new URL(url);\n if (urlObj.hostname.startsWith('api.')) {\n return `${urlObj.protocol}//${urlObj.hostname}`;\n }\n if (urlObj.pathname.includes('/api')) {\n return `${urlObj.protocol}//${urlObj.hostname}/api`;\n }\n return `${urlObj.protocol}//${urlObj.hostname}`;\n } catch {\n return patterns[0];\n }\n }\n\n /**\n * Try to discover OpenAPI spec for a service\n */\n async discoverSpec(name: string, baseUrl: string): Promise<string | null> {\n // Check known specs first\n if (KNOWN_SPECS[name]) {\n return KNOWN_SPECS[name];\n }\n\n // Try common spec locations\n const specPaths = [\n '/openapi.json',\n '/openapi.yaml',\n '/swagger.json',\n '/swagger.yaml',\n '/api-docs',\n '/v1/openapi.json',\n '/v2/openapi.json',\n '/docs/openapi.json',\n '/.well-known/openapi.json',\n ];\n\n for (const specPath of specPaths) {\n const specUrl = `${baseUrl}${specPath}`;\n try {\n // Quick HEAD request to check if spec exists\n execSync(`curl -sI --max-time 2 \"${specUrl}\" | grep -q \"200 OK\"`, {\n stdio: 'pipe',\n });\n return specUrl;\n } catch {\n // Spec not found at this location\n }\n }\n\n return null;\n }\n\n /**\n * Process a URL and auto-register if it's an API\n */\n async processUrl(\n url: string,\n autoRegister: boolean = true\n ): Promise<DiscoveredAPI | null> {\n const discovered = this.analyzeUrl(url);\n\n if (!discovered) {\n return null;\n }\n\n // Check if already discovered\n const existing = this.discoveredAPIs.get(discovered.name);\n if (existing) {\n return existing;\n }\n\n // Only probe for spec if it's not a known service (known services already have spec URLs)\n if (!discovered.specUrl && discovered.source !== 'known') {\n // Try to find OpenAPI spec (with timeout protection)\n try {\n discovered.specUrl =\n (await this.discoverSpec(discovered.name, discovered.baseUrl)) ||\n undefined;\n } catch {\n // Spec discovery failed, continue without\n }\n }\n\n this.discoveredAPIs.set(discovered.name, discovered);\n this.logDiscovery(discovered, url);\n\n // Auto-register if enabled and confidence is high enough\n if (autoRegister && discovered.confidence >= 0.7) {\n await this.registerAPI(discovered);\n }\n\n return discovered;\n }\n\n /**\n * Register a discovered API\n */\n async registerAPI(api: DiscoveredAPI): Promise<boolean> {\n const skill = getAPISkill();\n\n try {\n const result = await skill.add(api.name, api.baseUrl, {\n spec: api.specUrl,\n });\n\n if (result.success) {\n logger.info(`Auto-registered API: ${api.name}`);\n return true;\n }\n } catch (error) {\n logger.warn(`Failed to auto-register API ${api.name}:`, error);\n }\n\n return false;\n }\n\n /**\n * Log discovery for debugging\n */\n private logDiscovery(api: DiscoveredAPI, sourceUrl: string): void {\n const entry = {\n timestamp: new Date().toISOString(),\n api,\n sourceUrl,\n };\n\n try {\n const dir = path.dirname(this.discoveryLog);\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n\n fs.appendFileSync(this.discoveryLog, JSON.stringify(entry) + '\\n');\n } catch (error) {\n logger.warn('Failed to log API discovery:', error);\n }\n }\n\n /**\n * Get all discovered APIs\n */\n getDiscoveredAPIs(): DiscoveredAPI[] {\n return Array.from(this.discoveredAPIs.values());\n }\n\n /**\n * Suggest API registration based on recent activity\n */\n async suggestFromContext(recentUrls: string[]): Promise<DiscoveryResult> {\n const result: DiscoveryResult = {\n discovered: [],\n registered: [],\n skipped: [],\n };\n\n for (const url of recentUrls) {\n const discovered = await this.processUrl(url, false);\n\n if (discovered) {\n result.discovered.push(discovered);\n\n // Check if already registered\n const skill = getAPISkill();\n const listResult = await skill.list();\n const existingAPIs = (listResult.data as Array<{ name: string }>) || [];\n\n if (existingAPIs.some((api) => api.name === discovered.name)) {\n result.skipped.push(discovered.name);\n } else if (discovered.confidence >= 0.7) {\n const registered = await this.registerAPI(discovered);\n if (registered) {\n result.registered.push(discovered.name);\n }\n }\n }\n }\n\n return result;\n }\n\n /**\n * Get help text\n */\n getHelp(): string {\n const restAPIs = Object.keys(KNOWN_SPECS).filter(\n (s) => !API_TYPES[s] || API_TYPES[s] === 'rest'\n );\n const graphqlAPIs = Object.keys(KNOWN_SPECS).filter(\n (s) => API_TYPES[s] === 'graphql'\n );\n const gcpAPIs = Object.keys(KNOWN_SPECS).filter(\n (s) => API_TYPES[s] === 'google-discovery'\n );\n\n return `\nAPI Auto-Discovery\n\nAutomatically detects and registers APIs when you browse documentation.\n\nREST APIs (OpenAPI specs):\n${restAPIs.map((s) => ` - ${s}`).join('\\n')}\n\nGraphQL APIs:\n${graphqlAPIs.map((s) => ` - ${s}`).join('\\n')}\n\nGoogle Cloud Platform (Discovery format):\n${gcpAPIs.map((s) => ` - ${s}`).join('\\n')}\n\nHow It Works:\n1. Monitors URLs you access during development\n2. Identifies API documentation and endpoints\n3. Finds OpenAPI specs automatically\n4. Registers APIs for easy access via /api exec\n\nUsage:\n # Check if a URL is a known API\n stackmemory api discover <url>\n\n # List discovered APIs\n stackmemory api discovered\n\n # Register all discovered APIs\n stackmemory api register-discovered\n`;\n }\n}\n\n// Singleton instance\nlet discoveryInstance: APIDiscoverySkill | null = null;\n\nexport function getAPIDiscovery(): APIDiscoverySkill {\n if (!discoveryInstance) {\n discoveryInstance = new APIDiscoverySkill();\n }\n return discoveryInstance;\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,475 @@
1
+ import { fileURLToPath as __fileURLToPath } from 'url';
2
+ import { dirname as __pathDirname } from 'path';
3
+ const __filename = __fileURLToPath(import.meta.url);
4
+ const __dirname = __pathDirname(__filename);
5
+ import { execSync } from "child_process";
6
+ import * as fs from "fs";
7
+ import * as path from "path";
8
+ import * as os from "os";
9
+ import { logger } from "../core/monitoring/logger.js";
10
+ class APISkill {
11
+ registryPath;
12
+ restishConfigPath;
13
+ registry;
14
+ constructor() {
15
+ this.registryPath = path.join(
16
+ os.homedir(),
17
+ ".stackmemory",
18
+ "api-registry.json"
19
+ );
20
+ this.restishConfigPath = process.platform === "darwin" ? path.join(
21
+ os.homedir(),
22
+ "Library",
23
+ "Application Support",
24
+ "restish",
25
+ "apis.json"
26
+ ) : path.join(os.homedir(), ".config", "restish", "apis.json");
27
+ this.registry = this.loadRegistry();
28
+ }
29
+ loadRegistry() {
30
+ try {
31
+ if (fs.existsSync(this.registryPath)) {
32
+ return JSON.parse(fs.readFileSync(this.registryPath, "utf-8"));
33
+ }
34
+ } catch (error) {
35
+ logger.warn("Failed to load API registry:", error);
36
+ }
37
+ return { apis: {}, version: "1.0.0" };
38
+ }
39
+ saveRegistry() {
40
+ const dir = path.dirname(this.registryPath);
41
+ if (!fs.existsSync(dir)) {
42
+ fs.mkdirSync(dir, { recursive: true });
43
+ }
44
+ fs.writeFileSync(this.registryPath, JSON.stringify(this.registry, null, 2));
45
+ }
46
+ /**
47
+ * Load restish config
48
+ */
49
+ loadRestishConfig() {
50
+ try {
51
+ if (fs.existsSync(this.restishConfigPath)) {
52
+ return JSON.parse(fs.readFileSync(this.restishConfigPath, "utf-8"));
53
+ }
54
+ } catch (error) {
55
+ logger.warn("Failed to load restish config:", error);
56
+ }
57
+ return {};
58
+ }
59
+ /**
60
+ * Save restish config
61
+ */
62
+ saveRestishConfig(config) {
63
+ const dir = path.dirname(this.restishConfigPath);
64
+ if (!fs.existsSync(dir)) {
65
+ fs.mkdirSync(dir, { recursive: true });
66
+ }
67
+ fs.writeFileSync(this.restishConfigPath, JSON.stringify(config, null, 2));
68
+ }
69
+ /**
70
+ * Check if restish is installed
71
+ */
72
+ checkRestish() {
73
+ try {
74
+ execSync("which restish", { stdio: "pipe" });
75
+ return true;
76
+ } catch {
77
+ return false;
78
+ }
79
+ }
80
+ /**
81
+ * Add/register a new API
82
+ */
83
+ async add(name, baseUrl, options) {
84
+ if (!this.checkRestish()) {
85
+ return {
86
+ success: false,
87
+ message: "restish not installed. Run: brew install restish"
88
+ };
89
+ }
90
+ try {
91
+ const restishConfig = this.loadRestishConfig();
92
+ const apiConfig = {
93
+ base: baseUrl
94
+ };
95
+ if (options?.spec) {
96
+ apiConfig.spec_files = [options.spec];
97
+ }
98
+ if (options?.authType === "api-key" && options?.envVar) {
99
+ apiConfig.profiles = {
100
+ default: {
101
+ headers: {
102
+ [options.headerName || "Authorization"]: `$${options.envVar}`
103
+ }
104
+ }
105
+ };
106
+ }
107
+ restishConfig[name] = apiConfig;
108
+ this.saveRestishConfig(restishConfig);
109
+ const config = {
110
+ name,
111
+ baseUrl,
112
+ specUrl: options?.spec,
113
+ authType: options?.authType || "none",
114
+ authConfig: {
115
+ headerName: options?.headerName || "Authorization",
116
+ envVar: options?.envVar
117
+ },
118
+ registeredAt: (/* @__PURE__ */ new Date()).toISOString()
119
+ };
120
+ if (options?.spec) {
121
+ config.specUrl = options.spec;
122
+ }
123
+ this.registry.apis[name] = config;
124
+ this.saveRegistry();
125
+ return {
126
+ success: true,
127
+ message: `API '${name}' registered successfully`,
128
+ data: {
129
+ name,
130
+ baseUrl,
131
+ authType: config.authType,
132
+ operations: config.operations?.length || "auto-discovered"
133
+ }
134
+ };
135
+ } catch (error) {
136
+ logger.error("Failed to add API:", error);
137
+ return {
138
+ success: false,
139
+ message: `Failed to register API: ${error.message}`
140
+ };
141
+ }
142
+ }
143
+ /**
144
+ * Discover available operations for an API
145
+ */
146
+ discoverOperations(apiName) {
147
+ try {
148
+ const output = execSync(`restish ${apiName} --help 2>&1`, {
149
+ encoding: "utf-8",
150
+ stdio: ["pipe", "pipe", "pipe"]
151
+ });
152
+ const operations = [];
153
+ const lines = output.split("\n");
154
+ let inCommands = false;
155
+ for (const line of lines) {
156
+ if (line.includes("Available Commands:")) {
157
+ inCommands = true;
158
+ continue;
159
+ }
160
+ if (inCommands && line.trim()) {
161
+ const match = line.match(/^\s+(\S+)/);
162
+ if (match && !line.includes("help")) {
163
+ operations.push(match[1]);
164
+ }
165
+ }
166
+ if (inCommands && line.includes("Flags:")) {
167
+ break;
168
+ }
169
+ }
170
+ return operations;
171
+ } catch {
172
+ return [];
173
+ }
174
+ }
175
+ /**
176
+ * List registered APIs
177
+ */
178
+ async list() {
179
+ const apis = Object.values(this.registry.apis);
180
+ if (apis.length === 0) {
181
+ return {
182
+ success: true,
183
+ message: "No APIs registered. Use /api add <name> <url> to register one.",
184
+ data: []
185
+ };
186
+ }
187
+ return {
188
+ success: true,
189
+ message: `${apis.length} API(s) registered`,
190
+ data: apis.map((api) => ({
191
+ name: api.name,
192
+ baseUrl: api.baseUrl,
193
+ authType: api.authType,
194
+ operations: api.operations?.length || "unknown",
195
+ registeredAt: api.registeredAt
196
+ }))
197
+ };
198
+ }
199
+ /**
200
+ * Show details for a specific API
201
+ */
202
+ async describe(apiName, operation) {
203
+ const api = this.registry.apis[apiName];
204
+ if (!api) {
205
+ try {
206
+ const output = execSync(`restish api show ${apiName}`, {
207
+ encoding: "utf-8",
208
+ stdio: ["pipe", "pipe", "pipe"]
209
+ });
210
+ return {
211
+ success: true,
212
+ message: `API '${apiName}' (from restish config)`,
213
+ data: { raw: output }
214
+ };
215
+ } catch {
216
+ return {
217
+ success: false,
218
+ message: `API '${apiName}' not found`
219
+ };
220
+ }
221
+ }
222
+ if (operation) {
223
+ try {
224
+ const output = execSync(`restish ${apiName} ${operation} --help`, {
225
+ encoding: "utf-8",
226
+ stdio: ["pipe", "pipe", "pipe"]
227
+ });
228
+ return {
229
+ success: true,
230
+ message: `Operation: ${apiName}.${operation}`,
231
+ data: {
232
+ operation,
233
+ help: output
234
+ }
235
+ };
236
+ } catch {
237
+ return {
238
+ success: false,
239
+ message: `Operation '${operation}' not found for API '${apiName}'`
240
+ };
241
+ }
242
+ }
243
+ const operations = this.discoverOperations(apiName);
244
+ api.operations = operations;
245
+ this.saveRegistry();
246
+ return {
247
+ success: true,
248
+ message: `API: ${apiName}`,
249
+ data: {
250
+ ...api,
251
+ operations
252
+ }
253
+ };
254
+ }
255
+ /**
256
+ * Execute an API operation
257
+ */
258
+ async exec(apiName, operation, params, options) {
259
+ if (!this.checkRestish()) {
260
+ return {
261
+ success: false,
262
+ message: "restish not installed. Run: brew install restish"
263
+ };
264
+ }
265
+ const api = this.registry.apis[apiName];
266
+ if (!api) {
267
+ return {
268
+ success: false,
269
+ message: `API '${apiName}' not registered. Use /api add first.`
270
+ };
271
+ }
272
+ const urlPath = operation.startsWith("/") ? operation : `/${operation}`;
273
+ const fullUrl = `${api.baseUrl}${urlPath}`;
274
+ const args = ["get", fullUrl];
275
+ if (options?.raw) {
276
+ args.push("--rsh-raw");
277
+ }
278
+ if (options?.filter) {
279
+ args.push("--rsh-filter", options.filter);
280
+ }
281
+ if (api?.authConfig?.envVar) {
282
+ const token = process.env[api.authConfig.envVar];
283
+ if (token) {
284
+ const headerName = api.authConfig.headerName || "Authorization";
285
+ args.push("-H", `${headerName}:${token}`);
286
+ }
287
+ }
288
+ if (options?.headers) {
289
+ for (const [key, value] of Object.entries(options.headers)) {
290
+ args.push("-H", `${key}:${value}`);
291
+ }
292
+ }
293
+ if (params) {
294
+ for (const [key, value] of Object.entries(params)) {
295
+ args.push("-q", `${key}=${String(value)}`);
296
+ }
297
+ }
298
+ args.push("-o", "json");
299
+ try {
300
+ logger.info(`Executing: restish ${args.join(" ")}`);
301
+ const output = execSync(`restish ${args.join(" ")}`, {
302
+ encoding: "utf-8",
303
+ stdio: ["pipe", "pipe", "pipe"],
304
+ env: process.env
305
+ });
306
+ let data;
307
+ try {
308
+ data = JSON.parse(output);
309
+ } catch {
310
+ data = output;
311
+ }
312
+ return {
313
+ success: true,
314
+ message: `${apiName} ${operation} executed`,
315
+ data
316
+ };
317
+ } catch (error) {
318
+ const stderr = error.stderr?.toString() || error.message;
319
+ logger.error(`API exec failed:`, stderr);
320
+ return {
321
+ success: false,
322
+ message: `API call failed: ${stderr}`
323
+ };
324
+ }
325
+ }
326
+ /**
327
+ * Configure authentication for an API
328
+ */
329
+ async auth(apiName, options) {
330
+ const api = this.registry.apis[apiName];
331
+ if (!api) {
332
+ return {
333
+ success: false,
334
+ message: `API '${apiName}' not registered. Use /api add first.`
335
+ };
336
+ }
337
+ if (options.token) {
338
+ const envVar = options.envVar || `${apiName.toUpperCase()}_API_KEY`;
339
+ process.env[envVar] = options.token;
340
+ api.authType = "api-key";
341
+ api.authConfig = {
342
+ ...api.authConfig,
343
+ envVar
344
+ };
345
+ this.saveRegistry();
346
+ return {
347
+ success: true,
348
+ message: `Auth configured for '${apiName}'. Token stored in ${envVar}`,
349
+ data: { envVar }
350
+ };
351
+ }
352
+ if (options.oauth) {
353
+ try {
354
+ const scopeArg = options.scopes ? `--scopes=${options.scopes.join(",")}` : "";
355
+ execSync(`restish api configure ${apiName} --auth=oauth2 ${scopeArg}`, {
356
+ stdio: "inherit"
357
+ });
358
+ api.authType = "oauth2";
359
+ this.saveRegistry();
360
+ return {
361
+ success: true,
362
+ message: `OAuth2 configured for '${apiName}'`
363
+ };
364
+ } catch (error) {
365
+ return {
366
+ success: false,
367
+ message: `OAuth setup failed: ${error.message}`
368
+ };
369
+ }
370
+ }
371
+ return {
372
+ success: false,
373
+ message: "Specify --token or --oauth"
374
+ };
375
+ }
376
+ /**
377
+ * Remove an API
378
+ */
379
+ async remove(apiName) {
380
+ if (!this.registry.apis[apiName]) {
381
+ return {
382
+ success: false,
383
+ message: `API '${apiName}' not found`
384
+ };
385
+ }
386
+ delete this.registry.apis[apiName];
387
+ this.saveRegistry();
388
+ return {
389
+ success: true,
390
+ message: `API '${apiName}' removed`
391
+ };
392
+ }
393
+ /**
394
+ * Sync API spec (refresh operations)
395
+ */
396
+ async sync(apiName) {
397
+ if (!this.checkRestish()) {
398
+ return {
399
+ success: false,
400
+ message: "restish not installed. Run: brew install restish"
401
+ };
402
+ }
403
+ try {
404
+ execSync(`restish api sync ${apiName}`, { stdio: "pipe" });
405
+ const operations = this.discoverOperations(apiName);
406
+ if (this.registry.apis[apiName]) {
407
+ this.registry.apis[apiName].operations = operations;
408
+ this.saveRegistry();
409
+ }
410
+ return {
411
+ success: true,
412
+ message: `API '${apiName}' synced`,
413
+ data: { operations }
414
+ };
415
+ } catch (error) {
416
+ return {
417
+ success: false,
418
+ message: `Sync failed: ${error.message}`
419
+ };
420
+ }
421
+ }
422
+ /**
423
+ * Get help for the API skill
424
+ */
425
+ getHelp() {
426
+ return `
427
+ /api - OpenAPI-based API access via Restish
428
+
429
+ Commands:
430
+ /api add <name> <url> [--spec <url>] [--auth-type api-key|oauth2]
431
+ Register a new API
432
+
433
+ /api list
434
+ List all registered APIs
435
+
436
+ /api describe <name> [operation]
437
+ Show API details or specific operation
438
+
439
+ /api exec <name> <operation> [--param value...]
440
+ Execute an API operation
441
+
442
+ /api auth <name> --token <token> [--env-var NAME]
443
+ Configure API authentication
444
+
445
+ /api auth <name> --oauth [--scopes scope1,scope2]
446
+ Configure OAuth2 authentication
447
+
448
+ /api sync <name>
449
+ Refresh API operations from spec
450
+
451
+ /api remove <name>
452
+ Remove a registered API
453
+
454
+ Examples:
455
+ /api add github https://api.github.com --spec https://raw.githubusercontent.com/github/rest-api-description/main/descriptions/api.github.com/api.github.com.json
456
+ /api auth github --token "$GITHUB_TOKEN"
457
+ /api exec github repos list-for-user --username octocat
458
+ /api exec github issues list --owner microsoft --repo vscode --state open
459
+
460
+ Built on restish (https://rest.sh) for automatic OpenAPI discovery.
461
+ `;
462
+ }
463
+ }
464
+ let apiSkillInstance = null;
465
+ function getAPISkill() {
466
+ if (!apiSkillInstance) {
467
+ apiSkillInstance = new APISkill();
468
+ }
469
+ return apiSkillInstance;
470
+ }
471
+ export {
472
+ APISkill,
473
+ getAPISkill
474
+ };
475
+ //# sourceMappingURL=api-skill.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/skills/api-skill.ts"],
4
+ "sourcesContent": ["/**\n * API Skill - OpenAPI-based API access via Restish\n *\n * Wraps the restish CLI to provide zero-code API integration\n * based on OpenAPI specifications.\n */\n\nimport { execSync } from 'child_process';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\nimport { logger } from '../core/monitoring/logger.js';\nimport type { SkillResult } from './claude-skills.js';\n\nexport interface APIConfig {\n name: string;\n baseUrl: string;\n specUrl?: string;\n authType: 'none' | 'api-key' | 'oauth2' | 'basic';\n authConfig?: {\n headerName?: string;\n queryParam?: string;\n envVar?: string;\n };\n registeredAt: string;\n operations?: string[];\n}\n\nexport interface APIRegistry {\n apis: Record<string, APIConfig>;\n version: string;\n}\n\nexport class APISkill {\n private registryPath: string;\n private restishConfigPath: string;\n private registry: APIRegistry;\n\n constructor() {\n this.registryPath = path.join(\n os.homedir(),\n '.stackmemory',\n 'api-registry.json'\n );\n // Platform-specific restish config path\n // Mac: ~/Library/Application Support/restish/apis.json\n // Linux: ~/.config/restish/apis.json\n // Windows: %AppData%/restish/apis.json\n this.restishConfigPath =\n process.platform === 'darwin'\n ? path.join(\n os.homedir(),\n 'Library',\n 'Application Support',\n 'restish',\n 'apis.json'\n )\n : path.join(os.homedir(), '.config', 'restish', 'apis.json');\n this.registry = this.loadRegistry();\n }\n\n private loadRegistry(): APIRegistry {\n try {\n if (fs.existsSync(this.registryPath)) {\n return JSON.parse(fs.readFileSync(this.registryPath, 'utf-8'));\n }\n } catch (error) {\n logger.warn('Failed to load API registry:', error);\n }\n return { apis: {}, version: '1.0.0' };\n }\n\n private saveRegistry(): void {\n const dir = path.dirname(this.registryPath);\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n fs.writeFileSync(this.registryPath, JSON.stringify(this.registry, null, 2));\n }\n\n /**\n * Load restish config\n */\n private loadRestishConfig(): Record<string, unknown> {\n try {\n if (fs.existsSync(this.restishConfigPath)) {\n return JSON.parse(fs.readFileSync(this.restishConfigPath, 'utf-8'));\n }\n } catch (error) {\n logger.warn('Failed to load restish config:', error);\n }\n return {};\n }\n\n /**\n * Save restish config\n */\n private saveRestishConfig(config: Record<string, unknown>): void {\n const dir = path.dirname(this.restishConfigPath);\n if (!fs.existsSync(dir)) {\n fs.mkdirSync(dir, { recursive: true });\n }\n fs.writeFileSync(this.restishConfigPath, JSON.stringify(config, null, 2));\n }\n\n /**\n * Check if restish is installed\n */\n private checkRestish(): boolean {\n try {\n execSync('which restish', { stdio: 'pipe' });\n return true;\n } catch {\n return false;\n }\n }\n\n /**\n * Add/register a new API\n */\n async add(\n name: string,\n baseUrl: string,\n options?: {\n spec?: string;\n authType?: 'none' | 'api-key' | 'oauth2' | 'basic';\n headerName?: string;\n envVar?: string;\n }\n ): Promise<SkillResult> {\n if (!this.checkRestish()) {\n return {\n success: false,\n message: 'restish not installed. Run: brew install restish',\n };\n }\n\n try {\n // Configure restish for this API by writing directly to config\n const restishConfig = this.loadRestishConfig();\n\n // Build restish API config\n const apiConfig: Record<string, unknown> = {\n base: baseUrl,\n };\n\n // Add spec URL if provided for auto-discovery\n if (options?.spec) {\n apiConfig.spec_files = [options.spec];\n }\n\n // Add auth config based on type\n if (options?.authType === 'api-key' && options?.envVar) {\n apiConfig.profiles = {\n default: {\n headers: {\n [options.headerName || 'Authorization']: `$${options.envVar}`,\n },\n },\n };\n }\n\n restishConfig[name] = apiConfig;\n this.saveRestishConfig(restishConfig);\n\n // Store in our registry\n const config: APIConfig = {\n name,\n baseUrl,\n specUrl: options?.spec,\n authType: options?.authType || 'none',\n authConfig: {\n headerName: options?.headerName || 'Authorization',\n envVar: options?.envVar,\n },\n registeredAt: new Date().toISOString(),\n };\n\n // Skip sync during add - it can be slow due to network requests\n // Users can manually sync with: stackmemory api sync <name>\n if (options?.spec) {\n config.specUrl = options.spec;\n }\n\n this.registry.apis[name] = config;\n this.saveRegistry();\n\n return {\n success: true,\n message: `API '${name}' registered successfully`,\n data: {\n name,\n baseUrl,\n authType: config.authType,\n operations: config.operations?.length || 'auto-discovered',\n },\n };\n } catch (error) {\n logger.error('Failed to add API:', error);\n return {\n success: false,\n message: `Failed to register API: ${error.message}`,\n };\n }\n }\n\n /**\n * Discover available operations for an API\n */\n private discoverOperations(apiName: string): string[] {\n try {\n const output = execSync(`restish ${apiName} --help 2>&1`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n\n // Parse operations from help output\n const operations: string[] = [];\n const lines = output.split('\\n');\n let inCommands = false;\n\n for (const line of lines) {\n if (line.includes('Available Commands:')) {\n inCommands = true;\n continue;\n }\n if (inCommands && line.trim()) {\n const match = line.match(/^\\s+(\\S+)/);\n if (match && !line.includes('help')) {\n operations.push(match[1]);\n }\n }\n if (inCommands && line.includes('Flags:')) {\n break;\n }\n }\n\n return operations;\n } catch {\n return [];\n }\n }\n\n /**\n * List registered APIs\n */\n async list(): Promise<SkillResult> {\n const apis = Object.values(this.registry.apis);\n\n if (apis.length === 0) {\n return {\n success: true,\n message:\n 'No APIs registered. Use /api add <name> <url> to register one.',\n data: [],\n };\n }\n\n return {\n success: true,\n message: `${apis.length} API(s) registered`,\n data: apis.map((api) => ({\n name: api.name,\n baseUrl: api.baseUrl,\n authType: api.authType,\n operations: api.operations?.length || 'unknown',\n registeredAt: api.registeredAt,\n })),\n };\n }\n\n /**\n * Show details for a specific API\n */\n async describe(apiName: string, operation?: string): Promise<SkillResult> {\n const api = this.registry.apis[apiName];\n\n if (!api) {\n // Try to get info directly from restish\n try {\n const output = execSync(`restish api show ${apiName}`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n\n return {\n success: true,\n message: `API '${apiName}' (from restish config)`,\n data: { raw: output },\n };\n } catch {\n return {\n success: false,\n message: `API '${apiName}' not found`,\n };\n }\n }\n\n if (operation) {\n // Get specific operation details\n try {\n const output = execSync(`restish ${apiName} ${operation} --help`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n\n return {\n success: true,\n message: `Operation: ${apiName}.${operation}`,\n data: {\n operation,\n help: output,\n },\n };\n } catch {\n return {\n success: false,\n message: `Operation '${operation}' not found for API '${apiName}'`,\n };\n }\n }\n\n // Get all operations\n const operations = this.discoverOperations(apiName);\n api.operations = operations;\n this.saveRegistry();\n\n return {\n success: true,\n message: `API: ${apiName}`,\n data: {\n ...api,\n operations,\n },\n };\n }\n\n /**\n * Execute an API operation\n */\n async exec(\n apiName: string,\n operation: string,\n params?: Record<string, unknown>,\n options?: {\n raw?: boolean;\n filter?: string;\n headers?: Record<string, string>;\n }\n ): Promise<SkillResult> {\n if (!this.checkRestish()) {\n return {\n success: false,\n message: 'restish not installed. Run: brew install restish',\n };\n }\n\n const api = this.registry.apis[apiName];\n if (!api) {\n return {\n success: false,\n message: `API '${apiName}' not registered. Use /api add first.`,\n };\n }\n\n // Build the URL path from operation\n // e.g., \"repos/owner/repo\" or \"/repos/owner/repo\"\n const urlPath = operation.startsWith('/') ? operation : `/${operation}`;\n const fullUrl = `${api.baseUrl}${urlPath}`;\n\n // Build command using direct URL (more reliable than API names)\n const args: string[] = ['get', fullUrl];\n\n // Add options\n if (options?.raw) {\n args.push('--rsh-raw');\n }\n if (options?.filter) {\n args.push('--rsh-filter', options.filter);\n }\n\n // Add headers (including auth)\n if (api?.authConfig?.envVar) {\n const token = process.env[api.authConfig.envVar];\n if (token) {\n const headerName = api.authConfig.headerName || 'Authorization';\n args.push('-H', `${headerName}:${token}`);\n }\n }\n\n if (options?.headers) {\n for (const [key, value] of Object.entries(options.headers)) {\n args.push('-H', `${key}:${value}`);\n }\n }\n\n // Add query parameters\n if (params) {\n for (const [key, value] of Object.entries(params)) {\n args.push('-q', `${key}=${String(value)}`);\n }\n }\n\n // Output as JSON\n args.push('-o', 'json');\n\n try {\n logger.info(`Executing: restish ${args.join(' ')}`);\n\n const output = execSync(`restish ${args.join(' ')}`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n env: process.env,\n });\n\n // Try to parse as JSON\n let data: unknown;\n try {\n data = JSON.parse(output);\n } catch {\n data = output;\n }\n\n return {\n success: true,\n message: `${apiName} ${operation} executed`,\n data,\n };\n } catch (error) {\n const stderr = error.stderr?.toString() || error.message;\n logger.error(`API exec failed:`, stderr);\n\n return {\n success: false,\n message: `API call failed: ${stderr}`,\n };\n }\n }\n\n /**\n * Configure authentication for an API\n */\n async auth(\n apiName: string,\n options: {\n token?: string;\n envVar?: string;\n oauth?: boolean;\n scopes?: string[];\n }\n ): Promise<SkillResult> {\n const api = this.registry.apis[apiName];\n\n if (!api) {\n return {\n success: false,\n message: `API '${apiName}' not registered. Use /api add first.`,\n };\n }\n\n if (options.token) {\n // Store token in env var (don't save to disk for security)\n const envVar = options.envVar || `${apiName.toUpperCase()}_API_KEY`;\n process.env[envVar] = options.token;\n\n api.authType = 'api-key';\n api.authConfig = {\n ...api.authConfig,\n envVar,\n };\n this.saveRegistry();\n\n return {\n success: true,\n message: `Auth configured for '${apiName}'. Token stored in ${envVar}`,\n data: { envVar },\n };\n }\n\n if (options.oauth) {\n // Use restish's OAuth flow\n try {\n const scopeArg = options.scopes\n ? `--scopes=${options.scopes.join(',')}`\n : '';\n execSync(`restish api configure ${apiName} --auth=oauth2 ${scopeArg}`, {\n stdio: 'inherit',\n });\n\n api.authType = 'oauth2';\n this.saveRegistry();\n\n return {\n success: true,\n message: `OAuth2 configured for '${apiName}'`,\n };\n } catch (error) {\n return {\n success: false,\n message: `OAuth setup failed: ${error.message}`,\n };\n }\n }\n\n return {\n success: false,\n message: 'Specify --token or --oauth',\n };\n }\n\n /**\n * Remove an API\n */\n async remove(apiName: string): Promise<SkillResult> {\n if (!this.registry.apis[apiName]) {\n return {\n success: false,\n message: `API '${apiName}' not found`,\n };\n }\n\n delete this.registry.apis[apiName];\n this.saveRegistry();\n\n return {\n success: true,\n message: `API '${apiName}' removed`,\n };\n }\n\n /**\n * Sync API spec (refresh operations)\n */\n async sync(apiName: string): Promise<SkillResult> {\n if (!this.checkRestish()) {\n return {\n success: false,\n message: 'restish not installed. Run: brew install restish',\n };\n }\n\n try {\n execSync(`restish api sync ${apiName}`, { stdio: 'pipe' });\n\n const operations = this.discoverOperations(apiName);\n\n if (this.registry.apis[apiName]) {\n this.registry.apis[apiName].operations = operations;\n this.saveRegistry();\n }\n\n return {\n success: true,\n message: `API '${apiName}' synced`,\n data: { operations },\n };\n } catch (error) {\n return {\n success: false,\n message: `Sync failed: ${error.message}`,\n };\n }\n }\n\n /**\n * Get help for the API skill\n */\n getHelp(): string {\n return `\n/api - OpenAPI-based API access via Restish\n\nCommands:\n /api add <name> <url> [--spec <url>] [--auth-type api-key|oauth2]\n Register a new API\n\n /api list\n List all registered APIs\n\n /api describe <name> [operation]\n Show API details or specific operation\n\n /api exec <name> <operation> [--param value...]\n Execute an API operation\n\n /api auth <name> --token <token> [--env-var NAME]\n Configure API authentication\n\n /api auth <name> --oauth [--scopes scope1,scope2]\n Configure OAuth2 authentication\n\n /api sync <name>\n Refresh API operations from spec\n\n /api remove <name>\n Remove a registered API\n\nExamples:\n /api add github https://api.github.com --spec https://raw.githubusercontent.com/github/rest-api-description/main/descriptions/api.github.com/api.github.com.json\n /api auth github --token \"$GITHUB_TOKEN\"\n /api exec github repos list-for-user --username octocat\n /api exec github issues list --owner microsoft --repo vscode --state open\n\nBuilt on restish (https://rest.sh) for automatic OpenAPI discovery.\n`;\n }\n}\n\n// Singleton instance\nlet apiSkillInstance: APISkill | null = null;\n\nexport function getAPISkill(): APISkill {\n if (!apiSkillInstance) {\n apiSkillInstance = new APISkill();\n }\n return apiSkillInstance;\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }