claude-code-swarm 0.3.2 → 0.3.4

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 (1129) hide show
  1. package/.claude-plugin/marketplace.json +1 -1
  2. package/.claude-plugin/plugin.json +1 -1
  3. package/CLAUDE.md +4 -0
  4. package/README.md +65 -0
  5. package/package.json +4 -4
  6. package/src/__tests__/config.test.mjs +128 -0
  7. package/src/__tests__/index.test.mjs +2 -0
  8. package/src/__tests__/paths.test.mjs +13 -0
  9. package/src/config.mjs +46 -16
  10. package/src/index.mjs +3 -1
  11. package/src/map-connection.mjs +3 -3
  12. package/src/paths.mjs +5 -0
  13. package/src/sidecar-client.mjs +2 -2
  14. package/references/multi-agent-protocol/.sudocode/issues.jsonl +0 -120
  15. package/references/multi-agent-protocol/.sudocode/specs.jsonl +0 -15
  16. package/references/multi-agent-protocol/LICENSE +0 -21
  17. package/references/multi-agent-protocol/README.md +0 -113
  18. package/references/multi-agent-protocol/docs/00-design-specification.md +0 -496
  19. package/references/multi-agent-protocol/docs/01-open-questions.md +0 -1050
  20. package/references/multi-agent-protocol/docs/02-wire-protocol.md +0 -296
  21. package/references/multi-agent-protocol/docs/03-streaming-semantics.md +0 -252
  22. package/references/multi-agent-protocol/docs/04-error-handling.md +0 -231
  23. package/references/multi-agent-protocol/docs/05-connection-model.md +0 -244
  24. package/references/multi-agent-protocol/docs/06-visibility-permissions.md +0 -243
  25. package/references/multi-agent-protocol/docs/07-federation.md +0 -335
  26. package/references/multi-agent-protocol/docs/08-macro-agent-migration.md +0 -253
  27. package/references/multi-agent-protocol/docs/09-authentication.md +0 -748
  28. package/references/multi-agent-protocol/docs/10-environment-awareness.md +0 -242
  29. package/references/multi-agent-protocol/docs/10-mail-protocol.md +0 -553
  30. package/references/multi-agent-protocol/docs/11-anp-inspired-improvements.md +0 -1079
  31. package/references/multi-agent-protocol/docs/11-trajectory-protocol.md +0 -292
  32. package/references/multi-agent-protocol/docs/12-anp-implementation-plan.md +0 -641
  33. package/references/multi-agent-protocol/docs/agent-iam-integration.md +0 -877
  34. package/references/multi-agent-protocol/docs/agentic-mesh-integration-draft.md +0 -459
  35. package/references/multi-agent-protocol/docs/git-transport-draft.md +0 -251
  36. package/references/multi-agent-protocol/docs-site/Gemfile +0 -22
  37. package/references/multi-agent-protocol/docs-site/README.md +0 -82
  38. package/references/multi-agent-protocol/docs-site/_config.yml +0 -91
  39. package/references/multi-agent-protocol/docs-site/_includes/head_custom.html +0 -20
  40. package/references/multi-agent-protocol/docs-site/_sass/color_schemes/map.scss +0 -42
  41. package/references/multi-agent-protocol/docs-site/_sass/custom/custom.scss +0 -34
  42. package/references/multi-agent-protocol/docs-site/examples/full-integration.md +0 -510
  43. package/references/multi-agent-protocol/docs-site/examples/index.md +0 -138
  44. package/references/multi-agent-protocol/docs-site/examples/simple-chat.md +0 -282
  45. package/references/multi-agent-protocol/docs-site/examples/task-queue.md +0 -399
  46. package/references/multi-agent-protocol/docs-site/getting-started/index.md +0 -98
  47. package/references/multi-agent-protocol/docs-site/getting-started/installation.md +0 -219
  48. package/references/multi-agent-protocol/docs-site/getting-started/overview.md +0 -172
  49. package/references/multi-agent-protocol/docs-site/getting-started/quickstart.md +0 -237
  50. package/references/multi-agent-protocol/docs-site/index.md +0 -136
  51. package/references/multi-agent-protocol/docs-site/protocol/authentication.md +0 -391
  52. package/references/multi-agent-protocol/docs-site/protocol/connection-model.md +0 -376
  53. package/references/multi-agent-protocol/docs-site/protocol/design.md +0 -284
  54. package/references/multi-agent-protocol/docs-site/protocol/error-handling.md +0 -312
  55. package/references/multi-agent-protocol/docs-site/protocol/federation.md +0 -449
  56. package/references/multi-agent-protocol/docs-site/protocol/index.md +0 -129
  57. package/references/multi-agent-protocol/docs-site/protocol/permissions.md +0 -398
  58. package/references/multi-agent-protocol/docs-site/protocol/streaming.md +0 -353
  59. package/references/multi-agent-protocol/docs-site/protocol/wire-protocol.md +0 -369
  60. package/references/multi-agent-protocol/docs-site/sdk/api/agent.md +0 -357
  61. package/references/multi-agent-protocol/docs-site/sdk/api/client.md +0 -380
  62. package/references/multi-agent-protocol/docs-site/sdk/api/index.md +0 -62
  63. package/references/multi-agent-protocol/docs-site/sdk/api/server.md +0 -453
  64. package/references/multi-agent-protocol/docs-site/sdk/api/types.md +0 -468
  65. package/references/multi-agent-protocol/docs-site/sdk/guides/agent.md +0 -375
  66. package/references/multi-agent-protocol/docs-site/sdk/guides/authentication.md +0 -405
  67. package/references/multi-agent-protocol/docs-site/sdk/guides/client.md +0 -352
  68. package/references/multi-agent-protocol/docs-site/sdk/guides/index.md +0 -89
  69. package/references/multi-agent-protocol/docs-site/sdk/guides/server.md +0 -360
  70. package/references/multi-agent-protocol/docs-site/sdk/guides/testing.md +0 -446
  71. package/references/multi-agent-protocol/docs-site/sdk/guides/transports.md +0 -363
  72. package/references/multi-agent-protocol/docs-site/sdk/index.md +0 -206
  73. package/references/multi-agent-protocol/package-lock.json +0 -4230
  74. package/references/multi-agent-protocol/package.json +0 -56
  75. package/references/multi-agent-protocol/schema/meta.json +0 -584
  76. package/references/multi-agent-protocol/schema/schema.json +0 -3067
  77. package/references/openhive/.claude/settings.json +0 -6
  78. package/references/openhive/.dockerignore +0 -54
  79. package/references/openhive/.github/workflows/docker.yml +0 -52
  80. package/references/openhive/.sudocode/issues.jsonl +0 -24
  81. package/references/openhive/.sudocode/specs.jsonl +0 -4
  82. package/references/openhive/CLAUDE.md +0 -88
  83. package/references/openhive/Dockerfile +0 -105
  84. package/references/openhive/README.md +0 -745
  85. package/references/openhive/bin/openhive.js +0 -6
  86. package/references/openhive/cloudbuild.yaml +0 -80
  87. package/references/openhive/deploy/cloud-run.sh +0 -106
  88. package/references/openhive/deploy/openhive.env.example +0 -80
  89. package/references/openhive/deploy/openhive.service +0 -91
  90. package/references/openhive/docker-compose.yml +0 -67
  91. package/references/openhive/docker-entrypoint.sh +0 -117
  92. package/references/openhive/docs/API_MIGRATION.md +0 -176
  93. package/references/openhive/docs/DEPLOYMENT.md +0 -847
  94. package/references/openhive/docs/DESIGN_v1.md +0 -489
  95. package/references/openhive/docs/DESIGN_v2.md +0 -564
  96. package/references/openhive/docs/HEADSCALE_HOSTING_SPEC.md +0 -513
  97. package/references/openhive/docs/HIVE_SYNC_DESIGN.md +0 -2362
  98. package/references/openhive/docs/HIVE_SYNC_IMPLEMENTATION_PLAN.md +0 -1169
  99. package/references/openhive/docs/HOSTING.md +0 -601
  100. package/references/openhive/docs/IMPLEMENTATION_PLAN.md +0 -428
  101. package/references/openhive/docs/LOCAL_SETUP.md +0 -506
  102. package/references/openhive/docs/MACRO_AGENT_ATLAS_EXTENSION.md +0 -351
  103. package/references/openhive/docs/MEMORY_BANK_SYNC_SPEC.md +0 -909
  104. package/references/openhive/docs/PLAN_v1.md +0 -471
  105. package/references/openhive/docs/PLAN_v2.md +0 -623
  106. package/references/openhive/docs/WEBSOCKET.md +0 -267
  107. package/references/openhive/docs/openswarm-bootstrap-token-spec.md +0 -240
  108. package/references/openhive/ecosystem.config.cjs +0 -76
  109. package/references/openhive/fly.toml +0 -63
  110. package/references/openhive/package-lock.json +0 -17640
  111. package/references/openhive/package.json +0 -128
  112. package/references/openhive/packages/openhive-types/package-lock.json +0 -1473
  113. package/references/openhive/packages/openhive-types/package.json +0 -42
  114. package/references/openhive/packages/openhive-types/src/index.ts +0 -36
  115. package/references/openhive/packages/openhive-types/src/map-coordination.ts +0 -92
  116. package/references/openhive/packages/openhive-types/src/map-session-sync.ts +0 -50
  117. package/references/openhive/packages/openhive-types/src/map-sync.ts +0 -68
  118. package/references/openhive/packages/openhive-types/tsconfig.json +0 -15
  119. package/references/openhive/packages/openhive-types/tsconfig.tsbuildinfo +0 -1
  120. package/references/openhive/packages/openhive-types/tsup.config.ts +0 -12
  121. package/references/openhive/railway.json +0 -13
  122. package/references/openhive/railway.toml +0 -24
  123. package/references/openhive/render.yaml +0 -51
  124. package/references/openhive/src/__tests__/auth.test.ts +0 -148
  125. package/references/openhive/src/__tests__/bridge/credentials.test.ts +0 -65
  126. package/references/openhive/src/__tests__/bridge/dal.test.ts +0 -279
  127. package/references/openhive/src/__tests__/bridge/inbound.test.ts +0 -349
  128. package/references/openhive/src/__tests__/bridge/manager.test.ts +0 -419
  129. package/references/openhive/src/__tests__/bridge/mentions.test.ts +0 -83
  130. package/references/openhive/src/__tests__/bridge/outbound.test.ts +0 -209
  131. package/references/openhive/src/__tests__/bridge/slack-adapter.test.ts +0 -276
  132. package/references/openhive/src/__tests__/cli.test.ts +0 -342
  133. package/references/openhive/src/__tests__/config.test.ts +0 -205
  134. package/references/openhive/src/__tests__/coordination/coordination.test.ts +0 -1072
  135. package/references/openhive/src/__tests__/coordination/cross-instance.test.ts +0 -540
  136. package/references/openhive/src/__tests__/coordination/e2e.test.ts +0 -780
  137. package/references/openhive/src/__tests__/data-dir.test.ts +0 -332
  138. package/references/openhive/src/__tests__/db.test.ts +0 -258
  139. package/references/openhive/src/__tests__/discovery.test.ts +0 -288
  140. package/references/openhive/src/__tests__/events/dal.test.ts +0 -371
  141. package/references/openhive/src/__tests__/events/dispatch.test.ts +0 -202
  142. package/references/openhive/src/__tests__/events/e2e.test.ts +0 -528
  143. package/references/openhive/src/__tests__/events/normalizers.test.ts +0 -263
  144. package/references/openhive/src/__tests__/events/router.test.ts +0 -314
  145. package/references/openhive/src/__tests__/events/routes.test.ts +0 -407
  146. package/references/openhive/src/__tests__/follows.test.ts +0 -328
  147. package/references/openhive/src/__tests__/helpers/test-dirs.ts +0 -44
  148. package/references/openhive/src/__tests__/ingest-keys.test.ts +0 -925
  149. package/references/openhive/src/__tests__/map/sync-client-content.test.ts +0 -288
  150. package/references/openhive/src/__tests__/map/sync-client.test.ts +0 -500
  151. package/references/openhive/src/__tests__/map/sync-listener.test.ts +0 -504
  152. package/references/openhive/src/__tests__/middleware/hostname-guard.test.ts +0 -73
  153. package/references/openhive/src/__tests__/migrations.test.ts +0 -260
  154. package/references/openhive/src/__tests__/opentasks/client.test.ts +0 -497
  155. package/references/openhive/src/__tests__/opentasks/discovery.test.ts +0 -283
  156. package/references/openhive/src/__tests__/opentasks/e2e.test.ts +0 -767
  157. package/references/openhive/src/__tests__/routes/agents.test.ts +0 -417
  158. package/references/openhive/src/__tests__/routes/opentasks-content.test.ts +0 -493
  159. package/references/openhive/src/__tests__/routes/resource-content.test.ts +0 -1741
  160. package/references/openhive/src/__tests__/sessions/adapters.test.ts +0 -524
  161. package/references/openhive/src/__tests__/sessions/routes.test.ts +0 -1053
  162. package/references/openhive/src/__tests__/sessions/storage.test.ts +0 -545
  163. package/references/openhive/src/__tests__/sessions/trajectory-checkpoints.test.ts +0 -349
  164. package/references/openhive/src/__tests__/sessions/trajectory-routes.test.ts +0 -290
  165. package/references/openhive/src/__tests__/swarm/config.test.ts +0 -125
  166. package/references/openhive/src/__tests__/swarm/credentials.test.ts +0 -254
  167. package/references/openhive/src/__tests__/swarm/dal.test.ts +0 -290
  168. package/references/openhive/src/__tests__/swarm/e2e.test.ts +0 -827
  169. package/references/openhive/src/__tests__/swarm/fixtures/exit-immediately.js +0 -3
  170. package/references/openhive/src/__tests__/swarm/fixtures/map-server.js +0 -147
  171. package/references/openhive/src/__tests__/swarm/fixtures/sleep-server.js +0 -52
  172. package/references/openhive/src/__tests__/swarm/local-provider.test.ts +0 -279
  173. package/references/openhive/src/__tests__/swarm/manager.test.ts +0 -305
  174. package/references/openhive/src/__tests__/swarm/routes.test.ts +0 -396
  175. package/references/openhive/src/__tests__/swarm/workspace.test.ts +0 -257
  176. package/references/openhive/src/__tests__/swarmhub/client.test.ts +0 -324
  177. package/references/openhive/src/__tests__/swarmhub/config.test.ts +0 -213
  178. package/references/openhive/src/__tests__/swarmhub/connector.test.ts +0 -581
  179. package/references/openhive/src/__tests__/swarmhub/routes.test.ts +0 -639
  180. package/references/openhive/src/__tests__/swarmhub/slack-client.test.ts +0 -164
  181. package/references/openhive/src/__tests__/swarmhub/slack-connector.test.ts +0 -164
  182. package/references/openhive/src/__tests__/swarmhub/slack-routes.test.ts +0 -373
  183. package/references/openhive/src/__tests__/swarmhub/webhook-handler.test.ts +0 -295
  184. package/references/openhive/src/__tests__/sync/resource-sync.test.ts +0 -1418
  185. package/references/openhive/src/__tests__/sync/sync.test.ts +0 -800
  186. package/references/openhive/src/api/index.ts +0 -65
  187. package/references/openhive/src/api/middleware/auth.ts +0 -227
  188. package/references/openhive/src/api/middleware/hostname-guard.ts +0 -38
  189. package/references/openhive/src/api/routes/admin.ts +0 -366
  190. package/references/openhive/src/api/routes/agents.ts +0 -223
  191. package/references/openhive/src/api/routes/auth.ts +0 -164
  192. package/references/openhive/src/api/routes/bridges.ts +0 -384
  193. package/references/openhive/src/api/routes/comments.ts +0 -294
  194. package/references/openhive/src/api/routes/coordination.ts +0 -312
  195. package/references/openhive/src/api/routes/events.ts +0 -158
  196. package/references/openhive/src/api/routes/federation.ts +0 -367
  197. package/references/openhive/src/api/routes/feed.ts +0 -212
  198. package/references/openhive/src/api/routes/hives.ts +0 -264
  199. package/references/openhive/src/api/routes/map.ts +0 -674
  200. package/references/openhive/src/api/routes/memory-banks.ts +0 -971
  201. package/references/openhive/src/api/routes/posts.ts +0 -342
  202. package/references/openhive/src/api/routes/resource-content.ts +0 -727
  203. package/references/openhive/src/api/routes/resources.ts +0 -1013
  204. package/references/openhive/src/api/routes/search.ts +0 -45
  205. package/references/openhive/src/api/routes/sessions.ts +0 -1187
  206. package/references/openhive/src/api/routes/swarm-hosting.ts +0 -313
  207. package/references/openhive/src/api/routes/sync-protocol.ts +0 -168
  208. package/references/openhive/src/api/routes/sync.ts +0 -279
  209. package/references/openhive/src/api/routes/uploads.ts +0 -174
  210. package/references/openhive/src/api/routes/webhooks.ts +0 -603
  211. package/references/openhive/src/api/schemas/agents.ts +0 -26
  212. package/references/openhive/src/api/schemas/comments.ts +0 -22
  213. package/references/openhive/src/api/schemas/hives.ts +0 -33
  214. package/references/openhive/src/api/schemas/posts.ts +0 -37
  215. package/references/openhive/src/api/schemas/sync.ts +0 -56
  216. package/references/openhive/src/auth/index.ts +0 -2
  217. package/references/openhive/src/auth/jwks.ts +0 -58
  218. package/references/openhive/src/bridge/adapters/slack.ts +0 -306
  219. package/references/openhive/src/bridge/credentials.ts +0 -72
  220. package/references/openhive/src/bridge/inbound.ts +0 -288
  221. package/references/openhive/src/bridge/index.ts +0 -42
  222. package/references/openhive/src/bridge/manager.ts +0 -425
  223. package/references/openhive/src/bridge/mentions.ts +0 -42
  224. package/references/openhive/src/bridge/outbound.ts +0 -103
  225. package/references/openhive/src/bridge/schema.ts +0 -82
  226. package/references/openhive/src/bridge/types.ts +0 -238
  227. package/references/openhive/src/cli/network.ts +0 -480
  228. package/references/openhive/src/cli.ts +0 -620
  229. package/references/openhive/src/config.ts +0 -611
  230. package/references/openhive/src/coordination/index.ts +0 -43
  231. package/references/openhive/src/coordination/listener.ts +0 -92
  232. package/references/openhive/src/coordination/schema.ts +0 -79
  233. package/references/openhive/src/coordination/service.ts +0 -233
  234. package/references/openhive/src/coordination/types.ts +0 -177
  235. package/references/openhive/src/data-dir.ts +0 -105
  236. package/references/openhive/src/db/adapters/index.ts +0 -21
  237. package/references/openhive/src/db/adapters/postgres.ts +0 -310
  238. package/references/openhive/src/db/adapters/sqlite.ts +0 -56
  239. package/references/openhive/src/db/adapters/types.ts +0 -65
  240. package/references/openhive/src/db/dal/agents.ts +0 -430
  241. package/references/openhive/src/db/dal/bridge.ts +0 -336
  242. package/references/openhive/src/db/dal/comments.ts +0 -213
  243. package/references/openhive/src/db/dal/coordination.ts +0 -361
  244. package/references/openhive/src/db/dal/events.ts +0 -381
  245. package/references/openhive/src/db/dal/follows.ts +0 -96
  246. package/references/openhive/src/db/dal/hives.ts +0 -198
  247. package/references/openhive/src/db/dal/ingest-keys.ts +0 -176
  248. package/references/openhive/src/db/dal/instances.ts +0 -196
  249. package/references/openhive/src/db/dal/invites.ts +0 -123
  250. package/references/openhive/src/db/dal/map.ts +0 -750
  251. package/references/openhive/src/db/dal/posts.ts +0 -274
  252. package/references/openhive/src/db/dal/remote-agents.ts +0 -56
  253. package/references/openhive/src/db/dal/search.ts +0 -238
  254. package/references/openhive/src/db/dal/sync-events.ts +0 -160
  255. package/references/openhive/src/db/dal/sync-groups.ts +0 -100
  256. package/references/openhive/src/db/dal/sync-peer-configs.ts +0 -216
  257. package/references/openhive/src/db/dal/sync-peers.ts +0 -145
  258. package/references/openhive/src/db/dal/syncable-resources.ts +0 -888
  259. package/references/openhive/src/db/dal/trajectory-checkpoints.ts +0 -291
  260. package/references/openhive/src/db/dal/uploads.ts +0 -124
  261. package/references/openhive/src/db/dal/votes.ts +0 -124
  262. package/references/openhive/src/db/index.ts +0 -293
  263. package/references/openhive/src/db/providers/index.ts +0 -75
  264. package/references/openhive/src/db/providers/postgres.ts +0 -529
  265. package/references/openhive/src/db/providers/sqlite.ts +0 -1383
  266. package/references/openhive/src/db/providers/turso.ts +0 -1360
  267. package/references/openhive/src/db/providers/types.ts +0 -516
  268. package/references/openhive/src/db/schema.ts +0 -641
  269. package/references/openhive/src/discovery/index.ts +0 -403
  270. package/references/openhive/src/events/dispatch.ts +0 -106
  271. package/references/openhive/src/events/index.ts +0 -17
  272. package/references/openhive/src/events/normalizers/github.ts +0 -133
  273. package/references/openhive/src/events/normalizers/index.ts +0 -62
  274. package/references/openhive/src/events/normalizers/slack.ts +0 -50
  275. package/references/openhive/src/events/router.ts +0 -156
  276. package/references/openhive/src/events/schema.ts +0 -66
  277. package/references/openhive/src/events/types.ts +0 -130
  278. package/references/openhive/src/federation/index.ts +0 -1
  279. package/references/openhive/src/federation/service.ts +0 -776
  280. package/references/openhive/src/headscale/client.ts +0 -256
  281. package/references/openhive/src/headscale/config.ts +0 -212
  282. package/references/openhive/src/headscale/index.ts +0 -23
  283. package/references/openhive/src/headscale/manager.ts +0 -249
  284. package/references/openhive/src/headscale/sync.ts +0 -272
  285. package/references/openhive/src/headscale/types.ts +0 -231
  286. package/references/openhive/src/index.ts +0 -225
  287. package/references/openhive/src/map/client-entry.ts +0 -26
  288. package/references/openhive/src/map/index.ts +0 -76
  289. package/references/openhive/src/map/schema.ts +0 -119
  290. package/references/openhive/src/map/service.ts +0 -323
  291. package/references/openhive/src/map/sync-client.ts +0 -696
  292. package/references/openhive/src/map/sync-listener.ts +0 -409
  293. package/references/openhive/src/map/types.ts +0 -290
  294. package/references/openhive/src/network/factory.ts +0 -118
  295. package/references/openhive/src/network/headscale-provider.ts +0 -437
  296. package/references/openhive/src/network/index.ts +0 -43
  297. package/references/openhive/src/network/tailscale-client.ts +0 -289
  298. package/references/openhive/src/network/tailscale-provider.ts +0 -287
  299. package/references/openhive/src/network/types.ts +0 -178
  300. package/references/openhive/src/opentasks-client/client.ts +0 -374
  301. package/references/openhive/src/opentasks-client/index.ts +0 -7
  302. package/references/openhive/src/realtime/index.ts +0 -282
  303. package/references/openhive/src/server.ts +0 -1069
  304. package/references/openhive/src/services/email.ts +0 -177
  305. package/references/openhive/src/services/sitemap.ts +0 -135
  306. package/references/openhive/src/sessions/adapters/claude.ts +0 -466
  307. package/references/openhive/src/sessions/adapters/codex.ts +0 -265
  308. package/references/openhive/src/sessions/adapters/index.ts +0 -263
  309. package/references/openhive/src/sessions/adapters/raw.ts +0 -144
  310. package/references/openhive/src/sessions/adapters/types.ts +0 -83
  311. package/references/openhive/src/sessions/index.ts +0 -50
  312. package/references/openhive/src/sessions/storage/adapters/gcs.ts +0 -277
  313. package/references/openhive/src/sessions/storage/adapters/local.ts +0 -240
  314. package/references/openhive/src/sessions/storage/adapters/s3.ts +0 -321
  315. package/references/openhive/src/sessions/storage/index.ts +0 -231
  316. package/references/openhive/src/sessions/storage/types.ts +0 -189
  317. package/references/openhive/src/sessions/types.ts +0 -415
  318. package/references/openhive/src/shared/types/index.ts +0 -45
  319. package/references/openhive/src/shared/types/map-coordination.ts +0 -92
  320. package/references/openhive/src/shared/types/map-session-sync.ts +0 -170
  321. package/references/openhive/src/shared/types/map-sync.ts +0 -68
  322. package/references/openhive/src/skill.ts +0 -203
  323. package/references/openhive/src/storage/adapters/local.ts +0 -169
  324. package/references/openhive/src/storage/adapters/s3.ts +0 -195
  325. package/references/openhive/src/storage/index.ts +0 -64
  326. package/references/openhive/src/storage/types.ts +0 -69
  327. package/references/openhive/src/swarm/credentials.ts +0 -98
  328. package/references/openhive/src/swarm/dal.ts +0 -206
  329. package/references/openhive/src/swarm/index.ts +0 -28
  330. package/references/openhive/src/swarm/manager.ts +0 -917
  331. package/references/openhive/src/swarm/providers/local.ts +0 -338
  332. package/references/openhive/src/swarm/providers/sandboxed-local.ts +0 -478
  333. package/references/openhive/src/swarm/providers/workspace.ts +0 -52
  334. package/references/openhive/src/swarm/schema.ts +0 -43
  335. package/references/openhive/src/swarm/types.ts +0 -333
  336. package/references/openhive/src/swarmhub/client.ts +0 -279
  337. package/references/openhive/src/swarmhub/connector.ts +0 -463
  338. package/references/openhive/src/swarmhub/index.ts +0 -43
  339. package/references/openhive/src/swarmhub/routes.ts +0 -296
  340. package/references/openhive/src/swarmhub/types.ts +0 -213
  341. package/references/openhive/src/swarmhub/webhook-handler.ts +0 -126
  342. package/references/openhive/src/sync/compaction.ts +0 -193
  343. package/references/openhive/src/sync/coordination-hooks.ts +0 -154
  344. package/references/openhive/src/sync/crypto.ts +0 -79
  345. package/references/openhive/src/sync/gossip.ts +0 -136
  346. package/references/openhive/src/sync/hooks.ts +0 -202
  347. package/references/openhive/src/sync/materializer-repo.ts +0 -256
  348. package/references/openhive/src/sync/materializer.ts +0 -682
  349. package/references/openhive/src/sync/middleware.ts +0 -140
  350. package/references/openhive/src/sync/peer-resolver.ts +0 -157
  351. package/references/openhive/src/sync/resource-hooks.ts +0 -161
  352. package/references/openhive/src/sync/schema.ts +0 -158
  353. package/references/openhive/src/sync/service.ts +0 -990
  354. package/references/openhive/src/sync/types.ts +0 -369
  355. package/references/openhive/src/terminal/index.ts +0 -4
  356. package/references/openhive/src/terminal/pty-manager.ts +0 -337
  357. package/references/openhive/src/terminal/resolve-tui.ts +0 -44
  358. package/references/openhive/src/terminal/terminal-ws.ts +0 -251
  359. package/references/openhive/src/types.ts +0 -442
  360. package/references/openhive/src/utils/git-remote.ts +0 -329
  361. package/references/openhive/src/web/App.tsx +0 -77
  362. package/references/openhive/src/web/__tests__/components/dashboard/RecentActivity.test.tsx +0 -77
  363. package/references/openhive/src/web/__tests__/components/dashboard/StatsOverview.test.tsx +0 -62
  364. package/references/openhive/src/web/__tests__/components/dashboard/SwarmStatusSummary.test.tsx +0 -122
  365. package/references/openhive/src/web/__tests__/components/dashboard/SyncResourcesStatus.test.tsx +0 -104
  366. package/references/openhive/src/web/__tests__/components/layout/Sidebar.test.tsx +0 -110
  367. package/references/openhive/src/web/__tests__/components/swarm/StatusBadges.test.tsx +0 -65
  368. package/references/openhive/src/web/__tests__/components/terminal/query-responses.test.ts +0 -143
  369. package/references/openhive/src/web/__tests__/components/terminal/terminal-mouse.test.ts +0 -509
  370. package/references/openhive/src/web/__tests__/hooks/useEventsApi.test.ts +0 -378
  371. package/references/openhive/src/web/__tests__/pages/Dashboard.test.tsx +0 -57
  372. package/references/openhive/src/web/__tests__/pages/Events.test.tsx +0 -886
  373. package/references/openhive/src/web/__tests__/pages/Explore.test.tsx +0 -63
  374. package/references/openhive/src/web/__tests__/routing.test.tsx +0 -79
  375. package/references/openhive/src/web/__tests__/setup.ts +0 -37
  376. package/references/openhive/src/web/__tests__/stores/dashboard.test.ts +0 -49
  377. package/references/openhive/src/web/components/common/AgentBadge.tsx +0 -58
  378. package/references/openhive/src/web/components/common/Avatar.tsx +0 -78
  379. package/references/openhive/src/web/components/common/ErrorBoundary.tsx +0 -76
  380. package/references/openhive/src/web/components/common/Highlight.tsx +0 -79
  381. package/references/openhive/src/web/components/common/ImageUpload.tsx +0 -209
  382. package/references/openhive/src/web/components/common/LoadingSpinner.tsx +0 -37
  383. package/references/openhive/src/web/components/common/Logo.tsx +0 -21
  384. package/references/openhive/src/web/components/common/Markdown.tsx +0 -53
  385. package/references/openhive/src/web/components/common/ProtectedRoute.tsx +0 -18
  386. package/references/openhive/src/web/components/common/ThemeToggle.tsx +0 -38
  387. package/references/openhive/src/web/components/common/TimeAgo.tsx +0 -17
  388. package/references/openhive/src/web/components/common/Toast.tsx +0 -70
  389. package/references/openhive/src/web/components/common/VoteButtons.tsx +0 -100
  390. package/references/openhive/src/web/components/dashboard/RecentActivity.tsx +0 -100
  391. package/references/openhive/src/web/components/dashboard/StatsOverview.tsx +0 -40
  392. package/references/openhive/src/web/components/dashboard/SwarmStatusSummary.tsx +0 -89
  393. package/references/openhive/src/web/components/dashboard/SyncResourcesStatus.tsx +0 -81
  394. package/references/openhive/src/web/components/feed/FeedControls.tsx +0 -38
  395. package/references/openhive/src/web/components/feed/NewPostsIndicator.tsx +0 -75
  396. package/references/openhive/src/web/components/feed/PostCard.tsx +0 -129
  397. package/references/openhive/src/web/components/feed/PostList.tsx +0 -83
  398. package/references/openhive/src/web/components/layout/Footer.tsx +0 -5
  399. package/references/openhive/src/web/components/layout/Layout.tsx +0 -29
  400. package/references/openhive/src/web/components/layout/Sidebar.tsx +0 -348
  401. package/references/openhive/src/web/components/post/CommentForm.tsx +0 -59
  402. package/references/openhive/src/web/components/post/CommentTree.tsx +0 -145
  403. package/references/openhive/src/web/components/resources/MemoryBrowser.tsx +0 -208
  404. package/references/openhive/src/web/components/resources/OpenTasksSummary.tsx +0 -138
  405. package/references/openhive/src/web/components/resources/SkillBrowser.tsx +0 -284
  406. package/references/openhive/src/web/components/swarm/StatusBadges.tsx +0 -56
  407. package/references/openhive/src/web/components/terminal/TerminalPanel.tsx +0 -485
  408. package/references/openhive/src/web/components/terminal/index.ts +0 -2
  409. package/references/openhive/src/web/components/terminal/query-responses.ts +0 -70
  410. package/references/openhive/src/web/components/terminal/terminal-mouse.ts +0 -222
  411. package/references/openhive/src/web/hooks/useApi.ts +0 -740
  412. package/references/openhive/src/web/hooks/useDocumentTitle.ts +0 -49
  413. package/references/openhive/src/web/hooks/useInfiniteScroll.ts +0 -58
  414. package/references/openhive/src/web/hooks/useRealtimeUpdates.ts +0 -154
  415. package/references/openhive/src/web/hooks/useWebSocket.ts +0 -225
  416. package/references/openhive/src/web/index.html +0 -73
  417. package/references/openhive/src/web/lib/api.ts +0 -518
  418. package/references/openhive/src/web/main.tsx +0 -32
  419. package/references/openhive/src/web/pages/About.tsx +0 -131
  420. package/references/openhive/src/web/pages/Agent.tsx +0 -130
  421. package/references/openhive/src/web/pages/Agents.tsx +0 -69
  422. package/references/openhive/src/web/pages/AuthCallback.tsx +0 -75
  423. package/references/openhive/src/web/pages/Dashboard.tsx +0 -41
  424. package/references/openhive/src/web/pages/Events.tsx +0 -1025
  425. package/references/openhive/src/web/pages/Explore.tsx +0 -43
  426. package/references/openhive/src/web/pages/Hive.tsx +0 -134
  427. package/references/openhive/src/web/pages/Hives.tsx +0 -64
  428. package/references/openhive/src/web/pages/Home.tsx +0 -43
  429. package/references/openhive/src/web/pages/Login.tsx +0 -122
  430. package/references/openhive/src/web/pages/Post.tsx +0 -216
  431. package/references/openhive/src/web/pages/ResourceDetail.tsx +0 -426
  432. package/references/openhive/src/web/pages/Resources.tsx +0 -276
  433. package/references/openhive/src/web/pages/Search.tsx +0 -234
  434. package/references/openhive/src/web/pages/SessionDetail.tsx +0 -703
  435. package/references/openhive/src/web/pages/Sessions.tsx +0 -129
  436. package/references/openhive/src/web/pages/Settings.tsx +0 -826
  437. package/references/openhive/src/web/pages/SwarmCraft.tsx +0 -16
  438. package/references/openhive/src/web/pages/Swarms.tsx +0 -981
  439. package/references/openhive/src/web/pages/Terminal.tsx +0 -69
  440. package/references/openhive/src/web/postcss.config.js +0 -5
  441. package/references/openhive/src/web/public/favicon.svg +0 -11
  442. package/references/openhive/src/web/public/manifest.json +0 -21
  443. package/references/openhive/src/web/stores/auth.ts +0 -207
  444. package/references/openhive/src/web/stores/dashboard.ts +0 -23
  445. package/references/openhive/src/web/stores/realtime.ts +0 -90
  446. package/references/openhive/src/web/stores/theme.ts +0 -70
  447. package/references/openhive/src/web/stores/toast.ts +0 -63
  448. package/references/openhive/src/web/styles/globals.css +0 -503
  449. package/references/openhive/src/web/sw.ts +0 -228
  450. package/references/openhive/src/web/utils/serviceWorker.ts +0 -86
  451. package/references/openhive/src/web/vite.config.ts +0 -81
  452. package/references/openhive/tsconfig.json +0 -32
  453. package/references/openhive/tsup.config.ts +0 -17
  454. package/references/openhive/vitest.config.ts +0 -30
  455. package/references/openhive/vitest.web.config.ts +0 -20
  456. package/references/opentasks/.claude/settings.json +0 -6
  457. package/references/opentasks/.claude-plugin/plugin.json +0 -20
  458. package/references/opentasks/.lintstagedrc.json +0 -4
  459. package/references/opentasks/.prettierignore +0 -4
  460. package/references/opentasks/.prettierrc.json +0 -11
  461. package/references/opentasks/.sudocode/issues.jsonl +0 -89
  462. package/references/opentasks/.sudocode/specs.jsonl +0 -24
  463. package/references/opentasks/README.md +0 -401
  464. package/references/opentasks/docs/ARCHITECTURE.md +0 -841
  465. package/references/opentasks/docs/DESIGN.md +0 -689
  466. package/references/opentasks/docs/INTERFACE.md +0 -670
  467. package/references/opentasks/docs/PERSISTENCE.md +0 -1638
  468. package/references/opentasks/docs/PROVIDERS.md +0 -1412
  469. package/references/opentasks/docs/SCHEMA.md +0 -815
  470. package/references/opentasks/docs/TESTING.md +0 -1081
  471. package/references/opentasks/eslint.config.js +0 -58
  472. package/references/opentasks/package-lock.json +0 -4348
  473. package/references/opentasks/package.json +0 -81
  474. package/references/opentasks/skills/opentasks/SKILL.md +0 -139
  475. package/references/opentasks/skills/opentasks/dependency-management.md +0 -119
  476. package/references/opentasks/skills/opentasks/feedback-and-review.md +0 -100
  477. package/references/opentasks/skills/opentasks/linking-external-data.md +0 -103
  478. package/references/opentasks/skills/opentasks/spec-to-implementation.md +0 -98
  479. package/references/opentasks/src/__tests__/cli-tools.test.ts +0 -800
  480. package/references/opentasks/src/__tests__/cli.test.ts +0 -97
  481. package/references/opentasks/src/__tests__/p1-p3-gaps.test.ts +0 -635
  482. package/references/opentasks/src/cli.ts +0 -929
  483. package/references/opentasks/src/client/__tests__/client-crud.test.ts +0 -546
  484. package/references/opentasks/src/client/__tests__/client.test.ts +0 -658
  485. package/references/opentasks/src/client/__tests__/socket-discovery.test.ts +0 -122
  486. package/references/opentasks/src/client/client.ts +0 -560
  487. package/references/opentasks/src/client/index.ts +0 -32
  488. package/references/opentasks/src/config/__tests__/defaults.test.ts +0 -66
  489. package/references/opentasks/src/config/__tests__/env.test.ts +0 -155
  490. package/references/opentasks/src/config/__tests__/index.test.ts +0 -148
  491. package/references/opentasks/src/config/__tests__/loader.test.ts +0 -173
  492. package/references/opentasks/src/config/__tests__/merge.test.ts +0 -121
  493. package/references/opentasks/src/config/__tests__/schema.test.ts +0 -446
  494. package/references/opentasks/src/config/defaults.ts +0 -18
  495. package/references/opentasks/src/config/env.ts +0 -170
  496. package/references/opentasks/src/config/errors.ts +0 -33
  497. package/references/opentasks/src/config/index.ts +0 -63
  498. package/references/opentasks/src/config/loader.ts +0 -90
  499. package/references/opentasks/src/config/merge.ts +0 -64
  500. package/references/opentasks/src/config/schema.ts +0 -767
  501. package/references/opentasks/src/core/__tests__/conditional-redirects.test.ts +0 -116
  502. package/references/opentasks/src/core/__tests__/connections.test.ts +0 -194
  503. package/references/opentasks/src/core/__tests__/hash.test.ts +0 -161
  504. package/references/opentasks/src/core/__tests__/id.test.ts +0 -175
  505. package/references/opentasks/src/core/__tests__/init.test.ts +0 -115
  506. package/references/opentasks/src/core/__tests__/location.test.ts +0 -94
  507. package/references/opentasks/src/core/__tests__/merge-driver.test.ts +0 -300
  508. package/references/opentasks/src/core/__tests__/redirects.test.ts +0 -169
  509. package/references/opentasks/src/core/__tests__/resolve-location-target.test.ts +0 -468
  510. package/references/opentasks/src/core/__tests__/uri.test.ts +0 -228
  511. package/references/opentasks/src/core/__tests__/worktree.test.ts +0 -160
  512. package/references/opentasks/src/core/conditional-redirects.ts +0 -100
  513. package/references/opentasks/src/core/connections.ts +0 -217
  514. package/references/opentasks/src/core/discover.ts +0 -195
  515. package/references/opentasks/src/core/hash.ts +0 -74
  516. package/references/opentasks/src/core/id.ts +0 -174
  517. package/references/opentasks/src/core/index.ts +0 -108
  518. package/references/opentasks/src/core/init.ts +0 -66
  519. package/references/opentasks/src/core/location.ts +0 -139
  520. package/references/opentasks/src/core/merge-driver.ts +0 -280
  521. package/references/opentasks/src/core/redirects.ts +0 -182
  522. package/references/opentasks/src/core/uri.ts +0 -270
  523. package/references/opentasks/src/core/worktree.ts +0 -504
  524. package/references/opentasks/src/daemon/__tests__/e2e-live-agent.test.ts +0 -344
  525. package/references/opentasks/src/daemon/__tests__/e2e-session-pipeline.test.ts +0 -447
  526. package/references/opentasks/src/daemon/__tests__/e2e-watch.test.ts +0 -279
  527. package/references/opentasks/src/daemon/__tests__/entire-linker.test.ts +0 -1074
  528. package/references/opentasks/src/daemon/__tests__/entire-watcher.test.ts +0 -659
  529. package/references/opentasks/src/daemon/__tests__/flush.test.ts +0 -306
  530. package/references/opentasks/src/daemon/__tests__/integration.test.ts +0 -338
  531. package/references/opentasks/src/daemon/__tests__/ipc.test.ts +0 -406
  532. package/references/opentasks/src/daemon/__tests__/lifecycle.test.ts +0 -378
  533. package/references/opentasks/src/daemon/__tests__/lock.test.ts +0 -240
  534. package/references/opentasks/src/daemon/__tests__/methods/graph.test.ts +0 -372
  535. package/references/opentasks/src/daemon/__tests__/methods/provider.test.ts +0 -238
  536. package/references/opentasks/src/daemon/__tests__/methods/tools.test.ts +0 -690
  537. package/references/opentasks/src/daemon/__tests__/multi-location.test.ts +0 -945
  538. package/references/opentasks/src/daemon/__tests__/registry.test.ts +0 -268
  539. package/references/opentasks/src/daemon/__tests__/watcher.test.ts +0 -329
  540. package/references/opentasks/src/daemon/entire-linker.ts +0 -615
  541. package/references/opentasks/src/daemon/entire-watcher.ts +0 -415
  542. package/references/opentasks/src/daemon/factory.ts +0 -133
  543. package/references/opentasks/src/daemon/flush.ts +0 -168
  544. package/references/opentasks/src/daemon/index.ts +0 -120
  545. package/references/opentasks/src/daemon/ipc.ts +0 -491
  546. package/references/opentasks/src/daemon/lifecycle.ts +0 -1106
  547. package/references/opentasks/src/daemon/location-state.ts +0 -481
  548. package/references/opentasks/src/daemon/lock.ts +0 -168
  549. package/references/opentasks/src/daemon/methods/__tests__/graph.test.ts +0 -359
  550. package/references/opentasks/src/daemon/methods/__tests__/provider.test.ts +0 -227
  551. package/references/opentasks/src/daemon/methods/__tests__/tools.test.ts +0 -360
  552. package/references/opentasks/src/daemon/methods/__tests__/watch.test.ts +0 -656
  553. package/references/opentasks/src/daemon/methods/archive.ts +0 -193
  554. package/references/opentasks/src/daemon/methods/graph.ts +0 -274
  555. package/references/opentasks/src/daemon/methods/lifecycle.ts +0 -112
  556. package/references/opentasks/src/daemon/methods/location.ts +0 -118
  557. package/references/opentasks/src/daemon/methods/provider.ts +0 -159
  558. package/references/opentasks/src/daemon/methods/tools.ts +0 -221
  559. package/references/opentasks/src/daemon/methods/watch.ts +0 -206
  560. package/references/opentasks/src/daemon/registry.ts +0 -244
  561. package/references/opentasks/src/daemon/types.ts +0 -163
  562. package/references/opentasks/src/daemon/watcher.ts +0 -248
  563. package/references/opentasks/src/entire/__tests__/agent-registry.test.ts +0 -127
  564. package/references/opentasks/src/entire/__tests__/claude-generator.test.ts +0 -49
  565. package/references/opentasks/src/entire/__tests__/commit-msg.test.ts +0 -89
  566. package/references/opentasks/src/entire/__tests__/cursor-agent.test.ts +0 -224
  567. package/references/opentasks/src/entire/__tests__/flush-sentinel.test.ts +0 -93
  568. package/references/opentasks/src/entire/__tests__/gemini-agent.test.ts +0 -375
  569. package/references/opentasks/src/entire/__tests__/git-hooks.test.ts +0 -85
  570. package/references/opentasks/src/entire/__tests__/hook-managers.test.ts +0 -128
  571. package/references/opentasks/src/entire/__tests__/opencode-agent.test.ts +0 -329
  572. package/references/opentasks/src/entire/__tests__/redaction.test.ts +0 -143
  573. package/references/opentasks/src/entire/__tests__/session-store.test.ts +0 -83
  574. package/references/opentasks/src/entire/__tests__/summarize.test.ts +0 -346
  575. package/references/opentasks/src/entire/__tests__/transcript-timestamp.test.ts +0 -127
  576. package/references/opentasks/src/entire/__tests__/types.test.ts +0 -112
  577. package/references/opentasks/src/entire/__tests__/utils.test.ts +0 -296
  578. package/references/opentasks/src/entire/__tests__/validation.test.ts +0 -103
  579. package/references/opentasks/src/entire/__tests__/worktree.test.ts +0 -66
  580. package/references/opentasks/src/entire/agent/registry.ts +0 -143
  581. package/references/opentasks/src/entire/agent/session-types.ts +0 -117
  582. package/references/opentasks/src/entire/agent/types.ts +0 -217
  583. package/references/opentasks/src/entire/commands/clean.ts +0 -134
  584. package/references/opentasks/src/entire/commands/disable.ts +0 -85
  585. package/references/opentasks/src/entire/commands/doctor.ts +0 -152
  586. package/references/opentasks/src/entire/commands/enable.ts +0 -149
  587. package/references/opentasks/src/entire/commands/explain.ts +0 -271
  588. package/references/opentasks/src/entire/commands/reset.ts +0 -105
  589. package/references/opentasks/src/entire/commands/resume.ts +0 -194
  590. package/references/opentasks/src/entire/commands/rewind.ts +0 -204
  591. package/references/opentasks/src/entire/commands/status.ts +0 -150
  592. package/references/opentasks/src/entire/config.ts +0 -153
  593. package/references/opentasks/src/entire/git-operations.ts +0 -485
  594. package/references/opentasks/src/entire/hooks/git-hooks.ts +0 -171
  595. package/references/opentasks/src/entire/hooks/lifecycle.ts +0 -224
  596. package/references/opentasks/src/entire/index.ts +0 -644
  597. package/references/opentasks/src/entire/security/redaction.ts +0 -263
  598. package/references/opentasks/src/entire/session/state-machine.ts +0 -463
  599. package/references/opentasks/src/entire/store/checkpoint-store.ts +0 -489
  600. package/references/opentasks/src/entire/store/native-store.ts +0 -178
  601. package/references/opentasks/src/entire/store/provider-types.ts +0 -99
  602. package/references/opentasks/src/entire/store/session-store.ts +0 -233
  603. package/references/opentasks/src/entire/strategy/attribution.ts +0 -300
  604. package/references/opentasks/src/entire/strategy/common.ts +0 -222
  605. package/references/opentasks/src/entire/strategy/content-overlap.ts +0 -242
  606. package/references/opentasks/src/entire/strategy/manual-commit.ts +0 -1008
  607. package/references/opentasks/src/entire/strategy/types.ts +0 -285
  608. package/references/opentasks/src/entire/summarize/claude-generator.ts +0 -119
  609. package/references/opentasks/src/entire/summarize/summarize.ts +0 -432
  610. package/references/opentasks/src/entire/types.ts +0 -408
  611. package/references/opentasks/src/entire/utils/chunk-files.ts +0 -49
  612. package/references/opentasks/src/entire/utils/commit-message.ts +0 -65
  613. package/references/opentasks/src/entire/utils/detect-agent.ts +0 -36
  614. package/references/opentasks/src/entire/utils/hook-managers.ts +0 -118
  615. package/references/opentasks/src/entire/utils/ide-tags.ts +0 -32
  616. package/references/opentasks/src/entire/utils/paths.ts +0 -59
  617. package/references/opentasks/src/entire/utils/preview-rewind.ts +0 -86
  618. package/references/opentasks/src/entire/utils/rewind-conflict.ts +0 -121
  619. package/references/opentasks/src/entire/utils/shadow-branch.ts +0 -113
  620. package/references/opentasks/src/entire/utils/string-utils.ts +0 -46
  621. package/references/opentasks/src/entire/utils/todo-extract.ts +0 -193
  622. package/references/opentasks/src/entire/utils/trailers.ts +0 -190
  623. package/references/opentasks/src/entire/utils/transcript-parse.ts +0 -177
  624. package/references/opentasks/src/entire/utils/transcript-timestamp.ts +0 -61
  625. package/references/opentasks/src/entire/utils/tree-ops.ts +0 -227
  626. package/references/opentasks/src/entire/utils/tty.ts +0 -72
  627. package/references/opentasks/src/entire/utils/validation.ts +0 -67
  628. package/references/opentasks/src/entire/utils/worktree.ts +0 -58
  629. package/references/opentasks/src/graph/EdgeTypeRegistry.ts +0 -330
  630. package/references/opentasks/src/graph/FederatedGraph.ts +0 -796
  631. package/references/opentasks/src/graph/GraphologyAdapter.ts +0 -374
  632. package/references/opentasks/src/graph/HydratingFederatedGraph.ts +0 -533
  633. package/references/opentasks/src/graph/__tests__/EdgeTypeRegistry.test.ts +0 -263
  634. package/references/opentasks/src/graph/__tests__/FederatedGraph.test.ts +0 -821
  635. package/references/opentasks/src/graph/__tests__/GraphologyAdapter.test.ts +0 -408
  636. package/references/opentasks/src/graph/__tests__/HydratingFederatedGraph.test.ts +0 -735
  637. package/references/opentasks/src/graph/__tests__/debounce.test.ts +0 -276
  638. package/references/opentasks/src/graph/__tests__/e2e-store-roundtrip.test.ts +0 -349
  639. package/references/opentasks/src/graph/__tests__/edge-cases.test.ts +0 -595
  640. package/references/opentasks/src/graph/__tests__/expansion.test.ts +0 -304
  641. package/references/opentasks/src/graph/__tests__/git-graph-syncer.test.ts +0 -572
  642. package/references/opentasks/src/graph/__tests__/provider-store.test.ts +0 -1091
  643. package/references/opentasks/src/graph/__tests__/query.test.ts +0 -991
  644. package/references/opentasks/src/graph/__tests__/store.test.ts +0 -998
  645. package/references/opentasks/src/graph/__tests__/sync.test.ts +0 -178
  646. package/references/opentasks/src/graph/__tests__/validation.test.ts +0 -657
  647. package/references/opentasks/src/graph/coordination.ts +0 -454
  648. package/references/opentasks/src/graph/debounce.ts +0 -154
  649. package/references/opentasks/src/graph/expansion.ts +0 -364
  650. package/references/opentasks/src/graph/git-graph-syncer.ts +0 -321
  651. package/references/opentasks/src/graph/history.ts +0 -438
  652. package/references/opentasks/src/graph/index.ts +0 -145
  653. package/references/opentasks/src/graph/provider-store.ts +0 -1077
  654. package/references/opentasks/src/graph/query.ts +0 -651
  655. package/references/opentasks/src/graph/store.ts +0 -861
  656. package/references/opentasks/src/graph/sync.ts +0 -116
  657. package/references/opentasks/src/graph/types.ts +0 -420
  658. package/references/opentasks/src/graph/validation.ts +0 -520
  659. package/references/opentasks/src/index.ts +0 -270
  660. package/references/opentasks/src/materialization/CLAUDE.md +0 -88
  661. package/references/opentasks/src/materialization/README.md +0 -187
  662. package/references/opentasks/src/materialization/__tests__/archive-methods.test.ts +0 -194
  663. package/references/opentasks/src/materialization/__tests__/archiver.test.ts +0 -528
  664. package/references/opentasks/src/materialization/__tests__/config.test.ts +0 -123
  665. package/references/opentasks/src/materialization/__tests__/git-remote-store.test.ts +0 -533
  666. package/references/opentasks/src/materialization/__tests__/graph-id.test.ts +0 -82
  667. package/references/opentasks/src/materialization/__tests__/http-remote-store.test.ts +0 -263
  668. package/references/opentasks/src/materialization/__tests__/materialize-before-archive.test.ts +0 -246
  669. package/references/opentasks/src/materialization/__tests__/remote-store-factory.test.ts +0 -152
  670. package/references/opentasks/src/materialization/__tests__/snapshot.test.ts +0 -209
  671. package/references/opentasks/src/materialization/archiver.ts +0 -318
  672. package/references/opentasks/src/materialization/git-archive-store.ts +0 -568
  673. package/references/opentasks/src/materialization/git-remote-store.ts +0 -551
  674. package/references/opentasks/src/materialization/graph-id.ts +0 -173
  675. package/references/opentasks/src/materialization/http-remote-store.ts +0 -190
  676. package/references/opentasks/src/materialization/index.ts +0 -62
  677. package/references/opentasks/src/materialization/remote-store-factory.ts +0 -55
  678. package/references/opentasks/src/materialization/snapshot.ts +0 -230
  679. package/references/opentasks/src/materialization/types.ts +0 -410
  680. package/references/opentasks/src/providers/__tests__/beads.test.ts +0 -752
  681. package/references/opentasks/src/providers/__tests__/claude-tasks.test.ts +0 -485
  682. package/references/opentasks/src/providers/__tests__/entire-e2e.test.ts +0 -692
  683. package/references/opentasks/src/providers/__tests__/entire-sessionlog-e2e.test.ts +0 -1113
  684. package/references/opentasks/src/providers/__tests__/entire.test.ts +0 -1016
  685. package/references/opentasks/src/providers/__tests__/from-config.test.ts +0 -183
  686. package/references/opentasks/src/providers/__tests__/global.test.ts +0 -515
  687. package/references/opentasks/src/providers/__tests__/materialization.test.ts +0 -567
  688. package/references/opentasks/src/providers/__tests__/native.test.ts +0 -693
  689. package/references/opentasks/src/providers/__tests__/registry.test.ts +0 -232
  690. package/references/opentasks/src/providers/beads.ts +0 -1155
  691. package/references/opentasks/src/providers/claude-tasks.ts +0 -402
  692. package/references/opentasks/src/providers/entire.ts +0 -608
  693. package/references/opentasks/src/providers/from-config.ts +0 -210
  694. package/references/opentasks/src/providers/global.ts +0 -460
  695. package/references/opentasks/src/providers/index.ts +0 -147
  696. package/references/opentasks/src/providers/location.ts +0 -237
  697. package/references/opentasks/src/providers/materialization.ts +0 -346
  698. package/references/opentasks/src/providers/native.ts +0 -725
  699. package/references/opentasks/src/providers/registry.ts +0 -114
  700. package/references/opentasks/src/providers/sudocode.ts +0 -1292
  701. package/references/opentasks/src/providers/sync.ts +0 -485
  702. package/references/opentasks/src/providers/traits/RelationshipQueryable.ts +0 -169
  703. package/references/opentasks/src/providers/traits/TaskManageable.ts +0 -211
  704. package/references/opentasks/src/providers/traits/Watchable.ts +0 -260
  705. package/references/opentasks/src/providers/traits/__tests__/RelationshipQueryable.test.ts +0 -217
  706. package/references/opentasks/src/providers/traits/__tests__/TaskManageable.test.ts +0 -241
  707. package/references/opentasks/src/providers/traits/index.ts +0 -42
  708. package/references/opentasks/src/providers/types.ts +0 -439
  709. package/references/opentasks/src/schema/__tests__/validation.test.ts +0 -283
  710. package/references/opentasks/src/schema/base.ts +0 -88
  711. package/references/opentasks/src/schema/edges.ts +0 -78
  712. package/references/opentasks/src/schema/index.ts +0 -37
  713. package/references/opentasks/src/schema/nodes.ts +0 -119
  714. package/references/opentasks/src/schema/storage.ts +0 -130
  715. package/references/opentasks/src/schema/validation.ts +0 -209
  716. package/references/opentasks/src/storage/__tests__/atomic-write.test.ts +0 -227
  717. package/references/opentasks/src/storage/__tests__/file-lock.test.ts +0 -120
  718. package/references/opentasks/src/storage/__tests__/jsonl.test.ts +0 -267
  719. package/references/opentasks/src/storage/__tests__/locked-writer.test.ts +0 -134
  720. package/references/opentasks/src/storage/__tests__/sqlite.test.ts +0 -572
  721. package/references/opentasks/src/storage/atomic-write.ts +0 -86
  722. package/references/opentasks/src/storage/file-lock.ts +0 -215
  723. package/references/opentasks/src/storage/index.ts +0 -24
  724. package/references/opentasks/src/storage/interface.ts +0 -289
  725. package/references/opentasks/src/storage/jsonl.ts +0 -264
  726. package/references/opentasks/src/storage/locked-writer.ts +0 -140
  727. package/references/opentasks/src/storage/sqlite-schema.ts +0 -177
  728. package/references/opentasks/src/storage/sqlite.ts +0 -791
  729. package/references/opentasks/src/tools/__tests__/annotate.test.ts +0 -381
  730. package/references/opentasks/src/tools/__tests__/link.test.ts +0 -299
  731. package/references/opentasks/src/tools/__tests__/query.test.ts +0 -350
  732. package/references/opentasks/src/tools/__tests__/task.test.ts +0 -218
  733. package/references/opentasks/src/tools/annotate.ts +0 -277
  734. package/references/opentasks/src/tools/index.ts +0 -57
  735. package/references/opentasks/src/tools/link.ts +0 -163
  736. package/references/opentasks/src/tools/query.ts +0 -468
  737. package/references/opentasks/src/tools/task.ts +0 -213
  738. package/references/opentasks/src/tools/types.ts +0 -451
  739. package/references/opentasks/src/tracking/__tests__/claude-tool-categorizer.test.ts +0 -223
  740. package/references/opentasks/src/tracking/__tests__/transcript-extractor.test.ts +0 -262
  741. package/references/opentasks/src/tracking/claude-tool-categorizer.ts +0 -155
  742. package/references/opentasks/src/tracking/index.ts +0 -32
  743. package/references/opentasks/src/tracking/skill-tracker.ts +0 -322
  744. package/references/opentasks/src/tracking/transcript-extractor.ts +0 -225
  745. package/references/opentasks/tests/e2e/helpers/assertions.ts +0 -211
  746. package/references/opentasks/tests/e2e/helpers/beads-helpers.ts +0 -487
  747. package/references/opentasks/tests/e2e/helpers/fixtures.ts +0 -236
  748. package/references/opentasks/tests/e2e/helpers/index.ts +0 -122
  749. package/references/opentasks/tests/e2e/helpers/sudocode-helpers.ts +0 -341
  750. package/references/opentasks/tests/e2e/helpers/system-setup.ts +0 -504
  751. package/references/opentasks/tests/e2e/helpers/test-agent.ts +0 -504
  752. package/references/opentasks/tests/e2e/infrastructure.e2e.test.ts +0 -521
  753. package/references/opentasks/tests/e2e/skill-tracking.e2e.test.ts +0 -625
  754. package/references/opentasks/tests/e2e/workflows/feedback-loop.e2e.test.ts +0 -279
  755. package/references/opentasks/tests/e2e/workflows/multi-agent.e2e.test.ts +0 -304
  756. package/references/opentasks/tests/e2e/workflows/provider-sync/background-sync.e2e.test.ts +0 -292
  757. package/references/opentasks/tests/e2e/workflows/provider-sync/beads-provider-compat.e2e.test.ts +0 -249
  758. package/references/opentasks/tests/e2e/workflows/provider-sync/cross-provider-edges.e2e.test.ts +0 -407
  759. package/references/opentasks/tests/e2e/workflows/provider-sync/federated-ready.e2e.test.ts +0 -504
  760. package/references/opentasks/tests/e2e/workflows/provider-sync/hydration.e2e.test.ts +0 -340
  761. package/references/opentasks/tests/e2e/workflows/provider-sync/materialization.e2e.test.ts +0 -370
  762. package/references/opentasks/tests/e2e/workflows/provider-sync/sudocode-provider-compat.e2e.test.ts +0 -683
  763. package/references/opentasks/tests/e2e/workflows/provider-sync/watchable-beads.e2e.test.ts +0 -573
  764. package/references/opentasks/tests/e2e/workflows/spec-driven.e2e.test.ts +0 -244
  765. package/references/opentasks/tests/e2e/worktree-location.e2e.test.ts +0 -699
  766. package/references/opentasks/tests/integration/daemon/helpers.ts +0 -147
  767. package/references/opentasks/tests/integration/daemon/ipc.integration.test.ts +0 -343
  768. package/references/opentasks/tests/integration/daemon/lifecycle.integration.test.ts +0 -407
  769. package/references/opentasks/tests/integration/graph/federated-graph.integration.test.ts +0 -660
  770. package/references/opentasks/tests/integration/helpers/flags.ts +0 -28
  771. package/references/opentasks/tests/integration/helpers/index.ts +0 -47
  772. package/references/opentasks/tests/integration/helpers/process.ts +0 -133
  773. package/references/opentasks/tests/integration/helpers/temp.ts +0 -105
  774. package/references/opentasks/tests/integration/helpers/wait.ts +0 -133
  775. package/references/opentasks/tests/integration/helpers.test.ts +0 -120
  776. package/references/opentasks/tests/integration/providers/beads-task-manageable.integration.test.ts +0 -450
  777. package/references/opentasks/tests/integration/providers/beads.integration.test.ts +0 -388
  778. package/references/opentasks/tests/integration/providers/native-task-manageable.integration.test.ts +0 -667
  779. package/references/opentasks/tests/integration/providers/sudocode-task-manageable.integration.test.ts +0 -406
  780. package/references/opentasks/tests/integration/providers/sudocode.integration.test.ts +0 -342
  781. package/references/opentasks/tests/integration/storage/jsonl-durability.integration.test.ts +0 -390
  782. package/references/opentasks/tests/integration/storage/sqlite-durability.integration.test.ts +0 -527
  783. package/references/opentasks/tests/integration/worktree/redirect-location-resolution.integration.test.ts +0 -578
  784. package/references/opentasks/tests/integration/worktree/worktree-flow.integration.test.ts +0 -656
  785. package/references/opentasks/tsconfig.json +0 -18
  786. package/references/opentasks/vitest.config.ts +0 -27
  787. package/references/opentasks/vitest.e2e.config.ts +0 -35
  788. package/references/opentasks/vitest.integration.config.ts +0 -19
  789. package/references/openteams/.claude/settings.json +0 -6
  790. package/references/openteams/CLAUDE.md +0 -98
  791. package/references/openteams/README.md +0 -508
  792. package/references/openteams/SKILL.md +0 -198
  793. package/references/openteams/design.md +0 -250
  794. package/references/openteams/docs/visual-editor-design.md +0 -1225
  795. package/references/openteams/editor/index.html +0 -15
  796. package/references/openteams/editor/package.json +0 -39
  797. package/references/openteams/editor/src/App.tsx +0 -48
  798. package/references/openteams/editor/src/components/canvas/Canvas.tsx +0 -131
  799. package/references/openteams/editor/src/components/canvas/QuickAddMenu.tsx +0 -134
  800. package/references/openteams/editor/src/components/edges/PeerRouteEdge.tsx +0 -82
  801. package/references/openteams/editor/src/components/edges/SignalFlowEdge.tsx +0 -77
  802. package/references/openteams/editor/src/components/edges/SpawnEdge.tsx +0 -54
  803. package/references/openteams/editor/src/components/inspector/ChannelInspector.tsx +0 -158
  804. package/references/openteams/editor/src/components/inspector/EdgeInspector.tsx +0 -168
  805. package/references/openteams/editor/src/components/inspector/Inspector.tsx +0 -46
  806. package/references/openteams/editor/src/components/inspector/RoleInspector.tsx +0 -508
  807. package/references/openteams/editor/src/components/inspector/TeamInspector.tsx +0 -126
  808. package/references/openteams/editor/src/components/nodes/ChannelNode.tsx +0 -103
  809. package/references/openteams/editor/src/components/nodes/RoleNode.tsx +0 -157
  810. package/references/openteams/editor/src/components/nodes/node-styles.ts +0 -101
  811. package/references/openteams/editor/src/components/sidebar/Sidebar.tsx +0 -227
  812. package/references/openteams/editor/src/components/toolbar/ExportModal.tsx +0 -110
  813. package/references/openteams/editor/src/components/toolbar/ImportModal.tsx +0 -139
  814. package/references/openteams/editor/src/components/toolbar/Toolbar.tsx +0 -190
  815. package/references/openteams/editor/src/hooks/use-autosave.ts +0 -126
  816. package/references/openteams/editor/src/hooks/use-keyboard.ts +0 -106
  817. package/references/openteams/editor/src/hooks/use-validation.ts +0 -45
  818. package/references/openteams/editor/src/index.css +0 -245
  819. package/references/openteams/editor/src/lib/auto-layout.ts +0 -51
  820. package/references/openteams/editor/src/lib/bundled-templates.ts +0 -42
  821. package/references/openteams/editor/src/lib/compiler.ts +0 -75
  822. package/references/openteams/editor/src/lib/load-template.ts +0 -103
  823. package/references/openteams/editor/src/lib/rebuild-edges.ts +0 -104
  824. package/references/openteams/editor/src/lib/serializer.ts +0 -408
  825. package/references/openteams/editor/src/lib/signal-catalog.ts +0 -50
  826. package/references/openteams/editor/src/lib/validator.ts +0 -172
  827. package/references/openteams/editor/src/main.tsx +0 -10
  828. package/references/openteams/editor/src/stores/canvas-store.ts +0 -80
  829. package/references/openteams/editor/src/stores/config-store.ts +0 -243
  830. package/references/openteams/editor/src/stores/history-store.ts +0 -143
  831. package/references/openteams/editor/src/stores/theme-store.ts +0 -66
  832. package/references/openteams/editor/src/stores/ui-store.ts +0 -46
  833. package/references/openteams/editor/src/stores/validation-store.ts +0 -27
  834. package/references/openteams/editor/src/types/editor.ts +0 -74
  835. package/references/openteams/editor/src/vite-env.d.ts +0 -1
  836. package/references/openteams/editor/tests/compiler.test.ts +0 -151
  837. package/references/openteams/editor/tests/e2e-add-remove.test.ts +0 -386
  838. package/references/openteams/editor/tests/e2e-components.test.tsx +0 -424
  839. package/references/openteams/editor/tests/e2e-export-roundtrip.test.ts +0 -299
  840. package/references/openteams/editor/tests/e2e-template-load.test.ts +0 -204
  841. package/references/openteams/editor/tests/e2e-ui-store.test.ts +0 -126
  842. package/references/openteams/editor/tests/e2e-undo-redo.test.ts +0 -203
  843. package/references/openteams/editor/tests/e2e-validation.test.ts +0 -307
  844. package/references/openteams/editor/tests/serializer.test.ts +0 -142
  845. package/references/openteams/editor/tests/setup.ts +0 -52
  846. package/references/openteams/editor/tests/validator.test.ts +0 -92
  847. package/references/openteams/editor/tsconfig.json +0 -21
  848. package/references/openteams/editor/tsconfig.tsbuildinfo +0 -1
  849. package/references/openteams/editor/vite.config.ts +0 -28
  850. package/references/openteams/examples/bmad-method/prompts/analyst/ROLE.md +0 -16
  851. package/references/openteams/examples/bmad-method/prompts/analyst/SOUL.md +0 -5
  852. package/references/openteams/examples/bmad-method/prompts/architect/ROLE.md +0 -24
  853. package/references/openteams/examples/bmad-method/prompts/architect/SOUL.md +0 -5
  854. package/references/openteams/examples/bmad-method/prompts/developer/ROLE.md +0 -25
  855. package/references/openteams/examples/bmad-method/prompts/developer/SOUL.md +0 -5
  856. package/references/openteams/examples/bmad-method/prompts/master/ROLE.md +0 -21
  857. package/references/openteams/examples/bmad-method/prompts/master/SOUL.md +0 -5
  858. package/references/openteams/examples/bmad-method/prompts/pm/ROLE.md +0 -20
  859. package/references/openteams/examples/bmad-method/prompts/pm/SOUL.md +0 -5
  860. package/references/openteams/examples/bmad-method/prompts/qa/ROLE.md +0 -17
  861. package/references/openteams/examples/bmad-method/prompts/qa/SOUL.md +0 -5
  862. package/references/openteams/examples/bmad-method/prompts/quick-flow-dev/ROLE.md +0 -23
  863. package/references/openteams/examples/bmad-method/prompts/quick-flow-dev/SOUL.md +0 -5
  864. package/references/openteams/examples/bmad-method/prompts/scrum-master/ROLE.md +0 -27
  865. package/references/openteams/examples/bmad-method/prompts/scrum-master/SOUL.md +0 -5
  866. package/references/openteams/examples/bmad-method/prompts/tech-writer/ROLE.md +0 -21
  867. package/references/openteams/examples/bmad-method/prompts/tech-writer/SOUL.md +0 -5
  868. package/references/openteams/examples/bmad-method/prompts/ux-designer/ROLE.md +0 -16
  869. package/references/openteams/examples/bmad-method/prompts/ux-designer/SOUL.md +0 -5
  870. package/references/openteams/examples/bmad-method/roles/analyst.yaml +0 -9
  871. package/references/openteams/examples/bmad-method/roles/architect.yaml +0 -9
  872. package/references/openteams/examples/bmad-method/roles/developer.yaml +0 -8
  873. package/references/openteams/examples/bmad-method/roles/master.yaml +0 -8
  874. package/references/openteams/examples/bmad-method/roles/pm.yaml +0 -9
  875. package/references/openteams/examples/bmad-method/roles/qa.yaml +0 -8
  876. package/references/openteams/examples/bmad-method/roles/quick-flow-dev.yaml +0 -8
  877. package/references/openteams/examples/bmad-method/roles/scrum-master.yaml +0 -9
  878. package/references/openteams/examples/bmad-method/roles/tech-writer.yaml +0 -8
  879. package/references/openteams/examples/bmad-method/roles/ux-designer.yaml +0 -8
  880. package/references/openteams/examples/bmad-method/team.yaml +0 -161
  881. package/references/openteams/examples/bug-fix-pipeline/roles/fixer.yaml +0 -9
  882. package/references/openteams/examples/bug-fix-pipeline/roles/investigator.yaml +0 -8
  883. package/references/openteams/examples/bug-fix-pipeline/roles/pr-creator.yaml +0 -6
  884. package/references/openteams/examples/bug-fix-pipeline/roles/triager.yaml +0 -7
  885. package/references/openteams/examples/bug-fix-pipeline/roles/verifier.yaml +0 -8
  886. package/references/openteams/examples/bug-fix-pipeline/team.yaml +0 -88
  887. package/references/openteams/examples/codebase-migration/roles/assessor.yaml +0 -7
  888. package/references/openteams/examples/codebase-migration/roles/migrator.yaml +0 -9
  889. package/references/openteams/examples/codebase-migration/roles/planner.yaml +0 -5
  890. package/references/openteams/examples/codebase-migration/roles/test-extractor.yaml +0 -9
  891. package/references/openteams/examples/codebase-migration/roles/validator.yaml +0 -7
  892. package/references/openteams/examples/codebase-migration/team.yaml +0 -81
  893. package/references/openteams/examples/docs-sync/roles/adr-writer.yaml +0 -7
  894. package/references/openteams/examples/docs-sync/roles/api-doc-writer.yaml +0 -7
  895. package/references/openteams/examples/docs-sync/roles/change-detector.yaml +0 -7
  896. package/references/openteams/examples/docs-sync/roles/doc-reviewer.yaml +0 -7
  897. package/references/openteams/examples/docs-sync/roles/guide-writer.yaml +0 -7
  898. package/references/openteams/examples/docs-sync/team.yaml +0 -84
  899. package/references/openteams/examples/gsd/prompts/codebase-mapper/ROLE.md +0 -17
  900. package/references/openteams/examples/gsd/prompts/codebase-mapper/SOUL.md +0 -5
  901. package/references/openteams/examples/gsd/prompts/debugger/ROLE.md +0 -25
  902. package/references/openteams/examples/gsd/prompts/debugger/SOUL.md +0 -5
  903. package/references/openteams/examples/gsd/prompts/executor/ROLE.md +0 -34
  904. package/references/openteams/examples/gsd/prompts/executor/SOUL.md +0 -5
  905. package/references/openteams/examples/gsd/prompts/integration-checker/ROLE.md +0 -18
  906. package/references/openteams/examples/gsd/prompts/integration-checker/SOUL.md +0 -3
  907. package/references/openteams/examples/gsd/prompts/orchestrator/ROLE.md +0 -42
  908. package/references/openteams/examples/gsd/prompts/orchestrator/SOUL.md +0 -5
  909. package/references/openteams/examples/gsd/prompts/phase-researcher/ROLE.md +0 -15
  910. package/references/openteams/examples/gsd/prompts/phase-researcher/SOUL.md +0 -3
  911. package/references/openteams/examples/gsd/prompts/plan-checker/ROLE.md +0 -17
  912. package/references/openteams/examples/gsd/prompts/plan-checker/SOUL.md +0 -3
  913. package/references/openteams/examples/gsd/prompts/planner/ROLE.md +0 -28
  914. package/references/openteams/examples/gsd/prompts/planner/SOUL.md +0 -5
  915. package/references/openteams/examples/gsd/prompts/project-researcher/ROLE.md +0 -16
  916. package/references/openteams/examples/gsd/prompts/project-researcher/SOUL.md +0 -3
  917. package/references/openteams/examples/gsd/prompts/research-synthesizer/ROLE.md +0 -13
  918. package/references/openteams/examples/gsd/prompts/research-synthesizer/SOUL.md +0 -3
  919. package/references/openteams/examples/gsd/prompts/roadmapper/ROLE.md +0 -14
  920. package/references/openteams/examples/gsd/prompts/roadmapper/SOUL.md +0 -3
  921. package/references/openteams/examples/gsd/prompts/verifier/ROLE.md +0 -19
  922. package/references/openteams/examples/gsd/prompts/verifier/SOUL.md +0 -5
  923. package/references/openteams/examples/gsd/roles/codebase-mapper.yaml +0 -8
  924. package/references/openteams/examples/gsd/roles/debugger.yaml +0 -8
  925. package/references/openteams/examples/gsd/roles/executor.yaml +0 -8
  926. package/references/openteams/examples/gsd/roles/integration-checker.yaml +0 -8
  927. package/references/openteams/examples/gsd/roles/orchestrator.yaml +0 -9
  928. package/references/openteams/examples/gsd/roles/phase-researcher.yaml +0 -7
  929. package/references/openteams/examples/gsd/roles/plan-checker.yaml +0 -8
  930. package/references/openteams/examples/gsd/roles/planner.yaml +0 -8
  931. package/references/openteams/examples/gsd/roles/project-researcher.yaml +0 -8
  932. package/references/openteams/examples/gsd/roles/research-synthesizer.yaml +0 -7
  933. package/references/openteams/examples/gsd/roles/roadmapper.yaml +0 -7
  934. package/references/openteams/examples/gsd/roles/verifier.yaml +0 -8
  935. package/references/openteams/examples/gsd/team.yaml +0 -154
  936. package/references/openteams/examples/incident-response/roles/communicator.yaml +0 -5
  937. package/references/openteams/examples/incident-response/roles/fix-proposer.yaml +0 -7
  938. package/references/openteams/examples/incident-response/roles/incident-triager.yaml +0 -8
  939. package/references/openteams/examples/incident-response/roles/investigator.yaml +0 -8
  940. package/references/openteams/examples/incident-response/team.yaml +0 -68
  941. package/references/openteams/examples/pr-review-checks/roles/code-reviewer.yaml +0 -7
  942. package/references/openteams/examples/pr-review-checks/roles/security-scanner.yaml +0 -6
  943. package/references/openteams/examples/pr-review-checks/roles/summarizer.yaml +0 -6
  944. package/references/openteams/examples/pr-review-checks/roles/test-checker.yaml +0 -8
  945. package/references/openteams/examples/pr-review-checks/team.yaml +0 -64
  946. package/references/openteams/examples/security-audit/roles/code-analyzer.yaml +0 -6
  947. package/references/openteams/examples/security-audit/roles/dep-scanner.yaml +0 -7
  948. package/references/openteams/examples/security-audit/roles/fixer.yaml +0 -9
  949. package/references/openteams/examples/security-audit/roles/pr-creator.yaml +0 -6
  950. package/references/openteams/examples/security-audit/roles/prioritizer.yaml +0 -6
  951. package/references/openteams/examples/security-audit/roles/secrets-scanner.yaml +0 -6
  952. package/references/openteams/examples/security-audit/roles/verifier.yaml +0 -8
  953. package/references/openteams/examples/security-audit/team.yaml +0 -102
  954. package/references/openteams/media/banner.png +0 -0
  955. package/references/openteams/media/editor.png +0 -0
  956. package/references/openteams/package-lock.json +0 -4804
  957. package/references/openteams/package.json +0 -58
  958. package/references/openteams/schema/role.schema.json +0 -147
  959. package/references/openteams/schema/team.schema.json +0 -311
  960. package/references/openteams/src/cli/editor.ts +0 -170
  961. package/references/openteams/src/cli/generate.test.ts +0 -191
  962. package/references/openteams/src/cli/generate.ts +0 -220
  963. package/references/openteams/src/cli/prompt-utils.ts +0 -42
  964. package/references/openteams/src/cli/template.test.ts +0 -365
  965. package/references/openteams/src/cli/template.ts +0 -205
  966. package/references/openteams/src/cli.ts +0 -22
  967. package/references/openteams/src/generators/agent-prompt-generator.test.ts +0 -332
  968. package/references/openteams/src/generators/agent-prompt-generator.ts +0 -527
  969. package/references/openteams/src/generators/package-generator.test.ts +0 -129
  970. package/references/openteams/src/generators/package-generator.ts +0 -102
  971. package/references/openteams/src/generators/skill-generator.test.ts +0 -246
  972. package/references/openteams/src/generators/skill-generator.ts +0 -388
  973. package/references/openteams/src/index.ts +0 -84
  974. package/references/openteams/src/template/builtins.test.ts +0 -74
  975. package/references/openteams/src/template/builtins.ts +0 -108
  976. package/references/openteams/src/template/install-service.test.ts +0 -452
  977. package/references/openteams/src/template/install-service.ts +0 -332
  978. package/references/openteams/src/template/loader.test.ts +0 -1696
  979. package/references/openteams/src/template/loader.ts +0 -804
  980. package/references/openteams/src/template/resolver.test.ts +0 -304
  981. package/references/openteams/src/template/resolver.ts +0 -251
  982. package/references/openteams/src/template/types.ts +0 -229
  983. package/references/openteams/tsconfig.cjs.json +0 -7
  984. package/references/openteams/tsconfig.esm.json +0 -8
  985. package/references/openteams/tsconfig.json +0 -16
  986. package/references/openteams/vitest.config.ts +0 -9
  987. package/references/sessionlog/.husky/pre-commit +0 -1
  988. package/references/sessionlog/.lintstagedrc.json +0 -4
  989. package/references/sessionlog/.prettierignore +0 -4
  990. package/references/sessionlog/.prettierrc.json +0 -11
  991. package/references/sessionlog/LICENSE +0 -21
  992. package/references/sessionlog/README.md +0 -453
  993. package/references/sessionlog/eslint.config.js +0 -58
  994. package/references/sessionlog/package-lock.json +0 -3672
  995. package/references/sessionlog/package.json +0 -65
  996. package/references/sessionlog/src/__tests__/agent-hooks.test.ts +0 -570
  997. package/references/sessionlog/src/__tests__/agent-registry.test.ts +0 -127
  998. package/references/sessionlog/src/__tests__/claude-code-hooks.test.ts +0 -225
  999. package/references/sessionlog/src/__tests__/claude-generator.test.ts +0 -46
  1000. package/references/sessionlog/src/__tests__/commit-msg.test.ts +0 -86
  1001. package/references/sessionlog/src/__tests__/cursor-agent.test.ts +0 -224
  1002. package/references/sessionlog/src/__tests__/e2e-live.test.ts +0 -890
  1003. package/references/sessionlog/src/__tests__/event-log.test.ts +0 -183
  1004. package/references/sessionlog/src/__tests__/flush-sentinel.test.ts +0 -105
  1005. package/references/sessionlog/src/__tests__/gemini-agent.test.ts +0 -375
  1006. package/references/sessionlog/src/__tests__/git-hooks.test.ts +0 -78
  1007. package/references/sessionlog/src/__tests__/hook-managers.test.ts +0 -121
  1008. package/references/sessionlog/src/__tests__/lifecycle-tasks.test.ts +0 -759
  1009. package/references/sessionlog/src/__tests__/opencode-agent.test.ts +0 -338
  1010. package/references/sessionlog/src/__tests__/redaction.test.ts +0 -136
  1011. package/references/sessionlog/src/__tests__/session-repo.test.ts +0 -353
  1012. package/references/sessionlog/src/__tests__/session-store.test.ts +0 -166
  1013. package/references/sessionlog/src/__tests__/setup-ccweb.test.ts +0 -466
  1014. package/references/sessionlog/src/__tests__/skill-live.test.ts +0 -461
  1015. package/references/sessionlog/src/__tests__/summarize.test.ts +0 -348
  1016. package/references/sessionlog/src/__tests__/task-plan-e2e.test.ts +0 -610
  1017. package/references/sessionlog/src/__tests__/task-plan-live.test.ts +0 -632
  1018. package/references/sessionlog/src/__tests__/transcript-timestamp.test.ts +0 -121
  1019. package/references/sessionlog/src/__tests__/types.test.ts +0 -166
  1020. package/references/sessionlog/src/__tests__/utils.test.ts +0 -333
  1021. package/references/sessionlog/src/__tests__/validation.test.ts +0 -103
  1022. package/references/sessionlog/src/__tests__/worktree.test.ts +0 -57
  1023. package/references/sessionlog/src/agent/registry.ts +0 -143
  1024. package/references/sessionlog/src/agent/session-types.ts +0 -113
  1025. package/references/sessionlog/src/agent/types.ts +0 -220
  1026. package/references/sessionlog/src/cli.ts +0 -597
  1027. package/references/sessionlog/src/commands/clean.ts +0 -133
  1028. package/references/sessionlog/src/commands/disable.ts +0 -84
  1029. package/references/sessionlog/src/commands/doctor.ts +0 -145
  1030. package/references/sessionlog/src/commands/enable.ts +0 -202
  1031. package/references/sessionlog/src/commands/explain.ts +0 -261
  1032. package/references/sessionlog/src/commands/reset.ts +0 -105
  1033. package/references/sessionlog/src/commands/resume.ts +0 -180
  1034. package/references/sessionlog/src/commands/rewind.ts +0 -195
  1035. package/references/sessionlog/src/commands/setup-ccweb.ts +0 -275
  1036. package/references/sessionlog/src/commands/status.ts +0 -172
  1037. package/references/sessionlog/src/config.ts +0 -165
  1038. package/references/sessionlog/src/events/event-log.ts +0 -126
  1039. package/references/sessionlog/src/git-operations.ts +0 -558
  1040. package/references/sessionlog/src/hooks/git-hooks.ts +0 -165
  1041. package/references/sessionlog/src/hooks/lifecycle.ts +0 -391
  1042. package/references/sessionlog/src/index.ts +0 -650
  1043. package/references/sessionlog/src/security/redaction.ts +0 -283
  1044. package/references/sessionlog/src/session/state-machine.ts +0 -452
  1045. package/references/sessionlog/src/store/checkpoint-store.ts +0 -509
  1046. package/references/sessionlog/src/store/native-store.ts +0 -173
  1047. package/references/sessionlog/src/store/provider-types.ts +0 -99
  1048. package/references/sessionlog/src/store/session-store.ts +0 -266
  1049. package/references/sessionlog/src/strategy/attribution.ts +0 -296
  1050. package/references/sessionlog/src/strategy/common.ts +0 -207
  1051. package/references/sessionlog/src/strategy/content-overlap.ts +0 -228
  1052. package/references/sessionlog/src/strategy/manual-commit.ts +0 -988
  1053. package/references/sessionlog/src/strategy/types.ts +0 -279
  1054. package/references/sessionlog/src/summarize/claude-generator.ts +0 -115
  1055. package/references/sessionlog/src/summarize/summarize.ts +0 -432
  1056. package/references/sessionlog/src/types.ts +0 -508
  1057. package/references/sessionlog/src/utils/chunk-files.ts +0 -49
  1058. package/references/sessionlog/src/utils/commit-message.ts +0 -65
  1059. package/references/sessionlog/src/utils/detect-agent.ts +0 -36
  1060. package/references/sessionlog/src/utils/hook-managers.ts +0 -125
  1061. package/references/sessionlog/src/utils/ide-tags.ts +0 -32
  1062. package/references/sessionlog/src/utils/paths.ts +0 -79
  1063. package/references/sessionlog/src/utils/preview-rewind.ts +0 -80
  1064. package/references/sessionlog/src/utils/rewind-conflict.ts +0 -121
  1065. package/references/sessionlog/src/utils/shadow-branch.ts +0 -109
  1066. package/references/sessionlog/src/utils/string-utils.ts +0 -46
  1067. package/references/sessionlog/src/utils/todo-extract.ts +0 -188
  1068. package/references/sessionlog/src/utils/trailers.ts +0 -187
  1069. package/references/sessionlog/src/utils/transcript-parse.ts +0 -177
  1070. package/references/sessionlog/src/utils/transcript-timestamp.ts +0 -59
  1071. package/references/sessionlog/src/utils/tree-ops.ts +0 -219
  1072. package/references/sessionlog/src/utils/tty.ts +0 -72
  1073. package/references/sessionlog/src/utils/validation.ts +0 -65
  1074. package/references/sessionlog/src/utils/worktree.ts +0 -58
  1075. package/references/sessionlog/src/wire-types.ts +0 -59
  1076. package/references/sessionlog/templates/setup-env.sh +0 -153
  1077. package/references/sessionlog/tsconfig.json +0 -18
  1078. package/references/sessionlog/vitest.config.ts +0 -12
  1079. package/references/swarmkit/LICENSE +0 -21
  1080. package/references/swarmkit/README.md +0 -130
  1081. package/references/swarmkit/docs/design.md +0 -453
  1082. package/references/swarmkit/docs/package-setup-reference.md +0 -519
  1083. package/references/swarmkit/package-lock.json +0 -1938
  1084. package/references/swarmkit/package.json +0 -43
  1085. package/references/swarmkit/src/cli.ts +0 -41
  1086. package/references/swarmkit/src/commands/add.ts +0 -126
  1087. package/references/swarmkit/src/commands/doctor.ts +0 -117
  1088. package/references/swarmkit/src/commands/hive.ts +0 -279
  1089. package/references/swarmkit/src/commands/init/phases/configure.ts +0 -96
  1090. package/references/swarmkit/src/commands/init/phases/global-setup.ts +0 -102
  1091. package/references/swarmkit/src/commands/init/phases/packages.ts +0 -44
  1092. package/references/swarmkit/src/commands/init/phases/project.ts +0 -81
  1093. package/references/swarmkit/src/commands/init/phases/use-case.ts +0 -47
  1094. package/references/swarmkit/src/commands/init/state.test.ts +0 -23
  1095. package/references/swarmkit/src/commands/init/state.ts +0 -22
  1096. package/references/swarmkit/src/commands/init/wizard.ts +0 -160
  1097. package/references/swarmkit/src/commands/init.ts +0 -17
  1098. package/references/swarmkit/src/commands/login.ts +0 -106
  1099. package/references/swarmkit/src/commands/logout.ts +0 -22
  1100. package/references/swarmkit/src/commands/remove.ts +0 -72
  1101. package/references/swarmkit/src/commands/status.ts +0 -101
  1102. package/references/swarmkit/src/commands/update.ts +0 -62
  1103. package/references/swarmkit/src/commands/whoami.ts +0 -41
  1104. package/references/swarmkit/src/config/global.test.ts +0 -258
  1105. package/references/swarmkit/src/config/global.ts +0 -141
  1106. package/references/swarmkit/src/config/keys.test.ts +0 -109
  1107. package/references/swarmkit/src/config/keys.ts +0 -49
  1108. package/references/swarmkit/src/doctor/checks.test.ts +0 -366
  1109. package/references/swarmkit/src/doctor/checks.ts +0 -292
  1110. package/references/swarmkit/src/doctor/types.ts +0 -33
  1111. package/references/swarmkit/src/hub/auth-flow.test.ts +0 -127
  1112. package/references/swarmkit/src/hub/auth-flow.ts +0 -144
  1113. package/references/swarmkit/src/hub/client.test.ts +0 -224
  1114. package/references/swarmkit/src/hub/client.ts +0 -185
  1115. package/references/swarmkit/src/hub/credentials.test.ts +0 -132
  1116. package/references/swarmkit/src/hub/credentials.ts +0 -51
  1117. package/references/swarmkit/src/index.ts +0 -116
  1118. package/references/swarmkit/src/packages/installer.test.ts +0 -365
  1119. package/references/swarmkit/src/packages/installer.ts +0 -206
  1120. package/references/swarmkit/src/packages/plugin.test.ts +0 -141
  1121. package/references/swarmkit/src/packages/plugin.ts +0 -46
  1122. package/references/swarmkit/src/packages/registry.test.ts +0 -235
  1123. package/references/swarmkit/src/packages/registry.ts +0 -209
  1124. package/references/swarmkit/src/packages/setup.test.ts +0 -1349
  1125. package/references/swarmkit/src/packages/setup.ts +0 -635
  1126. package/references/swarmkit/src/utils/ui.test.ts +0 -115
  1127. package/references/swarmkit/src/utils/ui.ts +0 -62
  1128. package/references/swarmkit/tsconfig.json +0 -17
  1129. package/references/swarmkit/vitest.config.ts +0 -9
@@ -1,1383 +0,0 @@
1
- /**
2
- * SQLite Database Provider
3
- *
4
- * Wraps the existing DAL functions to implement the DatabaseProvider interface.
5
- * Uses better-sqlite3 for synchronous SQLite access.
6
- */
7
-
8
- import Database from 'better-sqlite3';
9
- import { nanoid } from 'nanoid';
10
- import bcrypt from 'bcrypt';
11
- import * as path from 'path';
12
- import * as fs from 'fs';
13
- import type {
14
- DatabaseProvider,
15
- SQLiteProviderConfig,
16
- AgentRepository,
17
- PostRepository,
18
- CommentRepository,
19
- HiveRepository,
20
- VoteRepository,
21
- FollowRepository,
22
- InviteRepository,
23
- UploadRepository,
24
- InstanceRepository,
25
- SearchRepository,
26
- CreateAgentInput,
27
- CreateHumanInput,
28
- UpdateAgentInput,
29
- CreatePostInput,
30
- UpdatePostInput,
31
- ListPostsOptions,
32
- CreateCommentInput,
33
- UpdateCommentInput,
34
- ListCommentsOptions,
35
- CreateHiveInput,
36
- UpdateHiveInput,
37
- CastVoteInput,
38
- CreateInviteInput,
39
- CreateUploadInput,
40
- Upload,
41
- CreateInstanceInput,
42
- SearchOptions,
43
- SearchResults,
44
- } from './types.js';
45
- import type { Agent, AgentPublic, Post, PostWithAuthor, Comment, CommentWithAuthor, Hive, Vote, Follow, InviteCode, FederatedInstance } from '../../types.js';
46
-
47
- const SALT_ROUNDS = 10;
48
-
49
- // Schema and migrations
50
- const CREATE_TABLES = `
51
- CREATE TABLE IF NOT EXISTS schema_version (
52
- version INTEGER PRIMARY KEY
53
- );
54
-
55
- CREATE TABLE IF NOT EXISTS agents (
56
- id TEXT PRIMARY KEY,
57
- name TEXT UNIQUE NOT NULL,
58
- api_key_hash TEXT,
59
- description TEXT,
60
- avatar_url TEXT,
61
- karma INTEGER DEFAULT 0,
62
- is_verified INTEGER DEFAULT 0,
63
- is_admin INTEGER DEFAULT 0,
64
- metadata TEXT,
65
- verification_status TEXT DEFAULT 'pending',
66
- verification_data TEXT,
67
- account_type TEXT DEFAULT 'agent',
68
- email TEXT UNIQUE,
69
- password_hash TEXT,
70
- email_verified INTEGER DEFAULT 0,
71
- password_reset_token TEXT,
72
- password_reset_expires TEXT,
73
- created_at TEXT DEFAULT (datetime('now')),
74
- updated_at TEXT DEFAULT (datetime('now')),
75
- last_seen_at TEXT
76
- );
77
-
78
- CREATE TABLE IF NOT EXISTS hives (
79
- id TEXT PRIMARY KEY,
80
- name TEXT UNIQUE NOT NULL,
81
- description TEXT,
82
- owner_id TEXT NOT NULL REFERENCES agents(id),
83
- is_public INTEGER DEFAULT 1,
84
- settings TEXT,
85
- member_count INTEGER DEFAULT 0,
86
- created_at TEXT DEFAULT (datetime('now')),
87
- updated_at TEXT DEFAULT (datetime('now'))
88
- );
89
-
90
- CREATE TABLE IF NOT EXISTS posts (
91
- id TEXT PRIMARY KEY,
92
- hive_id TEXT NOT NULL REFERENCES hives(id) ON DELETE CASCADE,
93
- author_id TEXT NOT NULL REFERENCES agents(id),
94
- title TEXT NOT NULL,
95
- content TEXT,
96
- url TEXT,
97
- score INTEGER DEFAULT 0,
98
- comment_count INTEGER DEFAULT 0,
99
- is_pinned INTEGER DEFAULT 0,
100
- created_at TEXT DEFAULT (datetime('now')),
101
- updated_at TEXT DEFAULT (datetime('now'))
102
- );
103
-
104
- CREATE TABLE IF NOT EXISTS comments (
105
- id TEXT PRIMARY KEY,
106
- post_id TEXT NOT NULL REFERENCES posts(id) ON DELETE CASCADE,
107
- parent_id TEXT REFERENCES comments(id),
108
- author_id TEXT NOT NULL REFERENCES agents(id),
109
- content TEXT NOT NULL,
110
- score INTEGER DEFAULT 0,
111
- depth INTEGER DEFAULT 0,
112
- path TEXT NOT NULL,
113
- created_at TEXT DEFAULT (datetime('now')),
114
- updated_at TEXT DEFAULT (datetime('now'))
115
- );
116
-
117
- CREATE TABLE IF NOT EXISTS votes (
118
- id TEXT PRIMARY KEY,
119
- agent_id TEXT NOT NULL REFERENCES agents(id),
120
- target_type TEXT NOT NULL CHECK (target_type IN ('post', 'comment')),
121
- target_id TEXT NOT NULL,
122
- value INTEGER NOT NULL CHECK (value IN (-1, 1)),
123
- created_at TEXT DEFAULT (datetime('now')),
124
- UNIQUE(agent_id, target_type, target_id)
125
- );
126
-
127
- CREATE TABLE IF NOT EXISTS memberships (
128
- id TEXT PRIMARY KEY,
129
- agent_id TEXT NOT NULL REFERENCES agents(id),
130
- hive_id TEXT NOT NULL REFERENCES hives(id) ON DELETE CASCADE,
131
- role TEXT DEFAULT 'member' CHECK (role IN ('member', 'moderator', 'owner')),
132
- joined_at TEXT DEFAULT (datetime('now')),
133
- UNIQUE(agent_id, hive_id)
134
- );
135
-
136
- CREATE TABLE IF NOT EXISTS follows (
137
- id TEXT PRIMARY KEY,
138
- follower_id TEXT NOT NULL REFERENCES agents(id),
139
- following_id TEXT NOT NULL REFERENCES agents(id),
140
- created_at TEXT DEFAULT (datetime('now')),
141
- UNIQUE(follower_id, following_id)
142
- );
143
-
144
- CREATE TABLE IF NOT EXISTS invite_codes (
145
- id TEXT PRIMARY KEY,
146
- code TEXT UNIQUE NOT NULL,
147
- created_by TEXT REFERENCES agents(id),
148
- used_by TEXT REFERENCES agents(id),
149
- uses_left INTEGER DEFAULT 1,
150
- expires_at TEXT,
151
- created_at TEXT DEFAULT (datetime('now'))
152
- );
153
-
154
- CREATE TABLE IF NOT EXISTS uploads (
155
- id TEXT PRIMARY KEY,
156
- agent_id TEXT NOT NULL REFERENCES agents(id),
157
- filename TEXT NOT NULL,
158
- mime_type TEXT NOT NULL,
159
- size INTEGER NOT NULL,
160
- storage_key TEXT UNIQUE NOT NULL,
161
- purpose TEXT NOT NULL,
162
- created_at TEXT DEFAULT (datetime('now'))
163
- );
164
-
165
- CREATE TABLE IF NOT EXISTS federated_instances (
166
- id TEXT PRIMARY KEY,
167
- url TEXT UNIQUE NOT NULL,
168
- name TEXT NOT NULL,
169
- public_key TEXT,
170
- status TEXT DEFAULT 'pending',
171
- is_trusted INTEGER DEFAULT 0,
172
- agent_count INTEGER DEFAULT 0,
173
- post_count INTEGER DEFAULT 0,
174
- last_sync TEXT,
175
- last_error TEXT,
176
- created_at TEXT DEFAULT (datetime('now')),
177
- updated_at TEXT DEFAULT (datetime('now'))
178
- );
179
-
180
- -- Indexes
181
- CREATE INDEX IF NOT EXISTS idx_posts_hive ON posts(hive_id);
182
- CREATE INDEX IF NOT EXISTS idx_posts_author ON posts(author_id);
183
- CREATE INDEX IF NOT EXISTS idx_posts_created ON posts(created_at DESC);
184
- CREATE INDEX IF NOT EXISTS idx_comments_post ON comments(post_id);
185
- CREATE INDEX IF NOT EXISTS idx_comments_path ON comments(path);
186
- CREATE INDEX IF NOT EXISTS idx_votes_target ON votes(target_type, target_id);
187
- CREATE INDEX IF NOT EXISTS idx_memberships_hive ON memberships(hive_id);
188
- CREATE INDEX IF NOT EXISTS idx_memberships_agent ON memberships(agent_id);
189
- CREATE INDEX IF NOT EXISTS idx_follows_follower ON follows(follower_id);
190
- CREATE INDEX IF NOT EXISTS idx_follows_following ON follows(following_id);
191
- CREATE INDEX IF NOT EXISTS idx_uploads_agent ON uploads(agent_id);
192
- `;
193
-
194
- const CREATE_FTS = `
195
- CREATE VIRTUAL TABLE IF NOT EXISTS posts_fts USING fts5(title, content, content=posts, content_rowid=rowid);
196
- CREATE VIRTUAL TABLE IF NOT EXISTS comments_fts USING fts5(content, content=comments, content_rowid=rowid);
197
- CREATE VIRTUAL TABLE IF NOT EXISTS agents_fts USING fts5(name, description, content=agents, content_rowid=rowid);
198
- CREATE VIRTUAL TABLE IF NOT EXISTS hives_fts USING fts5(name, description, content=hives, content_rowid=rowid);
199
-
200
- -- Triggers to keep FTS in sync
201
- CREATE TRIGGER IF NOT EXISTS posts_ai AFTER INSERT ON posts BEGIN
202
- INSERT INTO posts_fts(rowid, title, content) VALUES (NEW.rowid, NEW.title, NEW.content);
203
- END;
204
- CREATE TRIGGER IF NOT EXISTS posts_ad AFTER DELETE ON posts BEGIN
205
- INSERT INTO posts_fts(posts_fts, rowid, title, content) VALUES('delete', OLD.rowid, OLD.title, OLD.content);
206
- END;
207
- CREATE TRIGGER IF NOT EXISTS posts_au AFTER UPDATE ON posts BEGIN
208
- INSERT INTO posts_fts(posts_fts, rowid, title, content) VALUES('delete', OLD.rowid, OLD.title, OLD.content);
209
- INSERT INTO posts_fts(rowid, title, content) VALUES (NEW.rowid, NEW.title, NEW.content);
210
- END;
211
- `;
212
-
213
- // Helper functions
214
- function rowToAgent(row: Record<string, unknown>): Agent {
215
- return {
216
- ...row,
217
- is_verified: Boolean(row.is_verified),
218
- is_admin: Boolean(row.is_admin),
219
- email_verified: Boolean(row.email_verified),
220
- account_type: (row.account_type as string) || 'agent',
221
- metadata: row.metadata ? JSON.parse(row.metadata as string) : null,
222
- verification_data: row.verification_data ? JSON.parse(row.verification_data as string) : null,
223
- } as Agent;
224
- }
225
-
226
- function toPublicAgent(agent: Agent): AgentPublic {
227
- return {
228
- id: agent.id,
229
- name: agent.name,
230
- description: agent.description,
231
- avatar_url: agent.avatar_url,
232
- karma: agent.karma,
233
- is_verified: agent.is_verified,
234
- created_at: agent.created_at,
235
- account_type: agent.account_type || 'agent',
236
- };
237
- }
238
-
239
- // SQLite Provider Implementation
240
- export class SQLiteProvider implements DatabaseProvider {
241
- readonly type = 'sqlite' as const;
242
- private db: Database.Database;
243
-
244
- agents: AgentRepository;
245
- posts: PostRepository;
246
- comments: CommentRepository;
247
- hives: HiveRepository;
248
- votes: VoteRepository;
249
- follows: FollowRepository;
250
- invites: InviteRepository;
251
- uploads: UploadRepository;
252
- instances: InstanceRepository;
253
- search: SearchRepository;
254
-
255
- // Sync repositories — stubs until sync layer is migrated to Provider pattern (NEW-11)
256
- syncGroups: any = null;
257
- syncPeers: any = null;
258
- syncEvents: any = null;
259
- syncPeerConfigs: any = null;
260
-
261
- constructor(private config: SQLiteProviderConfig) {
262
- // Ensure directory exists
263
- const dbPath = path.resolve(config.path);
264
- const dbDir = path.dirname(dbPath);
265
- if (!fs.existsSync(dbDir)) {
266
- fs.mkdirSync(dbDir, { recursive: true });
267
- }
268
-
269
- this.db = new Database(dbPath);
270
- this.db.pragma('journal_mode = WAL');
271
- this.db.pragma('foreign_keys = ON');
272
-
273
- // Initialize repositories
274
- this.agents = this.createAgentRepository();
275
- this.posts = this.createPostRepository();
276
- this.comments = this.createCommentRepository();
277
- this.hives = this.createHiveRepository();
278
- this.votes = this.createVoteRepository();
279
- this.follows = this.createFollowRepository();
280
- this.invites = this.createInviteRepository();
281
- this.uploads = this.createUploadRepository();
282
- this.instances = this.createInstanceRepository();
283
- this.search = this.createSearchRepository();
284
- }
285
-
286
- async initialize(): Promise<void> {
287
- this.db.exec(CREATE_TABLES);
288
- await this.migrate();
289
- }
290
-
291
- async close(): Promise<void> {
292
- this.db.close();
293
- }
294
-
295
- async transaction<T>(fn: () => Promise<T>): Promise<T> {
296
- const txn = this.db.transaction(async () => {
297
- return await fn();
298
- });
299
- return txn() as T;
300
- }
301
-
302
- async migrate(): Promise<void> {
303
- const version = await this.getSchemaVersion();
304
-
305
- if (version === 0) {
306
- // Fresh install
307
- this.db.prepare('INSERT INTO schema_version (version) VALUES (?)').run(6);
308
- this.db.exec(CREATE_FTS);
309
- } else if (version < 6) {
310
- // Run migrations
311
- if (version < 2) {
312
- this.db.exec(CREATE_FTS);
313
- }
314
- if (version < 3) {
315
- // Uploads table already in CREATE_TABLES
316
- }
317
- if (version < 4) {
318
- // Human account fields already in CREATE_TABLES
319
- }
320
- if (version < 6) {
321
- // Password reset fields already in CREATE_TABLES
322
- }
323
- this.db.prepare('UPDATE schema_version SET version = ?').run(6);
324
- }
325
- }
326
-
327
- async getSchemaVersion(): Promise<number> {
328
- try {
329
- const row = this.db.prepare('SELECT version FROM schema_version').get() as { version: number } | undefined;
330
- return row?.version ?? 0;
331
- } catch {
332
- return 0;
333
- }
334
- }
335
-
336
- // ============================================================================
337
- // Repository Implementations
338
- // ============================================================================
339
-
340
- private createAgentRepository(): AgentRepository {
341
- const db = this.db;
342
-
343
- return {
344
- async create(input: CreateAgentInput) {
345
- const id = nanoid();
346
- const apiKey = nanoid(32);
347
- const apiKeyHash = await bcrypt.hash(apiKey, SALT_ROUNDS);
348
-
349
- db.prepare(`
350
- INSERT INTO agents (id, name, api_key_hash, description, avatar_url, is_admin, metadata)
351
- VALUES (?, ?, ?, ?, ?, ?, ?)
352
- `).run(
353
- id,
354
- input.name,
355
- apiKeyHash,
356
- input.description || null,
357
- input.avatar_url || null,
358
- input.is_admin ? 1 : 0,
359
- input.metadata ? JSON.stringify(input.metadata) : null
360
- );
361
-
362
- const agent = await this.findById(id);
363
- return { agent: agent!, apiKey };
364
- },
365
-
366
- async findById(id: string) {
367
- const row = db.prepare('SELECT * FROM agents WHERE id = ?').get(id) as Record<string, unknown> | undefined;
368
- return row ? rowToAgent(row) : null;
369
- },
370
-
371
- async findByName(name: string) {
372
- const row = db.prepare('SELECT * FROM agents WHERE name = ?').get(name) as Record<string, unknown> | undefined;
373
- return row ? rowToAgent(row) : null;
374
- },
375
-
376
- async findByApiKey(apiKey: string) {
377
- const agents = db.prepare('SELECT * FROM agents WHERE api_key_hash IS NOT NULL').all() as Record<string, unknown>[];
378
- for (const row of agents) {
379
- if (await bcrypt.compare(apiKey, row.api_key_hash as string)) {
380
- return rowToAgent(row);
381
- }
382
- }
383
- return null;
384
- },
385
-
386
- async update(id: string, input: UpdateAgentInput) {
387
- const updates: string[] = [];
388
- const values: unknown[] = [];
389
-
390
- if (input.description !== undefined) { updates.push('description = ?'); values.push(input.description); }
391
- if (input.avatar_url !== undefined) { updates.push('avatar_url = ?'); values.push(input.avatar_url); }
392
- if (input.metadata !== undefined) { updates.push('metadata = ?'); values.push(JSON.stringify(input.metadata)); }
393
- if (input.verification_status !== undefined) { updates.push('verification_status = ?'); values.push(input.verification_status); }
394
- if (input.verification_data !== undefined) { updates.push('verification_data = ?'); values.push(JSON.stringify(input.verification_data)); }
395
- if (input.is_verified !== undefined) { updates.push('is_verified = ?'); values.push(input.is_verified ? 1 : 0); }
396
- if (input.is_admin !== undefined) { updates.push('is_admin = ?'); values.push(input.is_admin ? 1 : 0); }
397
-
398
- if (updates.length === 0) return this.findById(id);
399
-
400
- updates.push("updated_at = datetime('now')");
401
- values.push(id);
402
-
403
- db.prepare(`UPDATE agents SET ${updates.join(', ')} WHERE id = ?`).run(...values);
404
- return this.findById(id);
405
- },
406
-
407
- async updateKarma(id: string, delta: number) {
408
- db.prepare(`UPDATE agents SET karma = karma + ?, updated_at = datetime('now') WHERE id = ?`).run(delta, id);
409
- },
410
-
411
- async updateLastSeen(id: string) {
412
- db.prepare(`UPDATE agents SET last_seen_at = datetime('now') WHERE id = ?`).run(id);
413
- },
414
-
415
- async list(options) {
416
- let query = 'SELECT * FROM agents';
417
- const conditions: string[] = [];
418
- const values: unknown[] = [];
419
-
420
- if (options.verified_only) conditions.push('is_verified = 1');
421
- if (conditions.length > 0) query += ' WHERE ' + conditions.join(' AND ');
422
- query += ' ORDER BY created_at DESC';
423
- if (options.limit) { query += ' LIMIT ?'; values.push(options.limit); }
424
- if (options.offset) { query += ' OFFSET ?'; values.push(options.offset); }
425
-
426
- const rows = db.prepare(query).all(...values) as Record<string, unknown>[];
427
- return rows.map(rowToAgent);
428
- },
429
-
430
- async count() {
431
- const row = db.prepare('SELECT COUNT(*) as count FROM agents').get() as { count: number };
432
- return row.count;
433
- },
434
-
435
- async delete(id: string) {
436
- const result = db.prepare('DELETE FROM agents WHERE id = ?').run(id);
437
- return result.changes > 0;
438
- },
439
-
440
- toPublic: toPublicAgent,
441
-
442
- // Human accounts
443
- async createHuman(input: CreateHumanInput) {
444
- const id = nanoid();
445
- const passwordHash = await bcrypt.hash(input.password, SALT_ROUNDS);
446
-
447
- db.prepare(`
448
- INSERT INTO agents (id, name, email, password_hash, description, avatar_url, account_type, is_verified, verification_status)
449
- VALUES (?, ?, ?, ?, ?, ?, 'human', 0, 'pending')
450
- `).run(id, input.name, input.email.toLowerCase(), passwordHash, input.description || null, input.avatar_url || null);
451
-
452
- return (await this.findById(id))!;
453
- },
454
-
455
- async findByEmail(email: string) {
456
- const row = db.prepare('SELECT * FROM agents WHERE email = ? AND account_type = ?').get(email.toLowerCase(), 'human') as Record<string, unknown> | undefined;
457
- return row ? rowToAgent(row) : null;
458
- },
459
-
460
- async verifyPassword(agent: Agent, password: string) {
461
- if (!agent.password_hash) return false;
462
- return bcrypt.compare(password, agent.password_hash);
463
- },
464
-
465
- async setPassword(id: string, password: string) {
466
- const passwordHash = await bcrypt.hash(password, SALT_ROUNDS);
467
- db.prepare(`UPDATE agents SET password_hash = ?, updated_at = datetime('now') WHERE id = ?`).run(passwordHash, id);
468
- },
469
-
470
- async verifyEmail(id: string) {
471
- db.prepare(`UPDATE agents SET email_verified = 1, is_verified = 1, verification_status = 'verified', updated_at = datetime('now') WHERE id = ?`).run(id);
472
- },
473
-
474
- async isEmailTaken(email: string) {
475
- const row = db.prepare('SELECT id FROM agents WHERE email = ?').get(email.toLowerCase());
476
- return row !== undefined;
477
- },
478
-
479
- async isNameTaken(name: string) {
480
- const row = db.prepare('SELECT id FROM agents WHERE name = ?').get(name);
481
- return row !== undefined;
482
- },
483
-
484
- // Password reset
485
- async setResetToken(id: string, token: string, expiresAt: Date) {
486
- db.prepare(`UPDATE agents SET password_reset_token = ?, password_reset_expires = ?, updated_at = datetime('now') WHERE id = ?`)
487
- .run(token, expiresAt.toISOString(), id);
488
- },
489
-
490
- async findByResetToken(token: string) {
491
- const row = db.prepare('SELECT * FROM agents WHERE password_reset_token = ?').get(token) as Record<string, unknown> | undefined;
492
- if (!row) return null;
493
-
494
- const agent = rowToAgent(row);
495
- if (agent.password_reset_expires && new Date(agent.password_reset_expires) < new Date()) {
496
- return null;
497
- }
498
- return agent;
499
- },
500
-
501
- async resetPassword(id: string, newPassword: string) {
502
- const passwordHash = await bcrypt.hash(newPassword, SALT_ROUNDS);
503
- db.prepare(`UPDATE agents SET password_hash = ?, password_reset_token = NULL, password_reset_expires = NULL, updated_at = datetime('now') WHERE id = ?`)
504
- .run(passwordHash, id);
505
- },
506
-
507
- async clearResetToken(id: string) {
508
- db.prepare(`UPDATE agents SET password_reset_token = NULL, password_reset_expires = NULL, updated_at = datetime('now') WHERE id = ?`).run(id);
509
- },
510
- };
511
- }
512
-
513
- private createPostRepository(): PostRepository {
514
- const db = this.db;
515
-
516
- return {
517
- async create(input: CreatePostInput) {
518
- const id = nanoid();
519
- db.prepare(`
520
- INSERT INTO posts (id, hive_id, author_id, title, content, url)
521
- VALUES (?, ?, ?, ?, ?, ?)
522
- `).run(id, input.hive_id, input.author_id, input.title, input.content || null, input.url || null);
523
-
524
- return (await this.findById(id))!;
525
- },
526
-
527
- async findById(id: string) {
528
- const row = db.prepare('SELECT * FROM posts WHERE id = ?').get(id) as Post | undefined;
529
- return row || null;
530
- },
531
-
532
- async findWithAuthor(id: string, viewerId?: string) {
533
- let query = `
534
- SELECT p.*, a.name as author_name, a.avatar_url as author_avatar, a.karma as author_karma,
535
- a.is_verified as author_verified, a.created_at as author_created_at, a.account_type as author_account_type,
536
- h.name as hive_name
537
- FROM posts p
538
- JOIN agents a ON p.author_id = a.id
539
- JOIN hives h ON p.hive_id = h.id
540
- `;
541
-
542
- if (viewerId) {
543
- query += ` LEFT JOIN votes v ON v.target_type = 'post' AND v.target_id = p.id AND v.agent_id = ?`;
544
- }
545
- query += ` WHERE p.id = ?`;
546
-
547
- const row = db.prepare(query).get(...(viewerId ? [viewerId, id] : [id])) as Record<string, unknown> | undefined;
548
- if (!row) return null;
549
-
550
- return {
551
- id: row.id,
552
- hive_id: row.hive_id,
553
- author_id: row.author_id,
554
- title: row.title,
555
- content: row.content,
556
- url: row.url,
557
- score: row.score,
558
- comment_count: row.comment_count,
559
- is_pinned: Boolean(row.is_pinned),
560
- created_at: row.created_at,
561
- updated_at: row.updated_at,
562
- hive_name: row.hive_name,
563
- user_vote: (row as { value?: number }).value as (1 | -1 | null) || null,
564
- author: {
565
- id: row.author_id,
566
- name: row.author_name,
567
- description: null,
568
- avatar_url: row.author_avatar,
569
- karma: row.author_karma,
570
- is_verified: Boolean(row.author_verified),
571
- created_at: row.author_created_at,
572
- account_type: row.author_account_type || 'agent',
573
- },
574
- } as PostWithAuthor;
575
- },
576
-
577
- async update(id: string, input: UpdatePostInput) {
578
- const updates: string[] = [];
579
- const values: unknown[] = [];
580
-
581
- if (input.title !== undefined) { updates.push('title = ?'); values.push(input.title); }
582
- if (input.content !== undefined) { updates.push('content = ?'); values.push(input.content); }
583
- if (input.url !== undefined) { updates.push('url = ?'); values.push(input.url); }
584
- if (input.is_pinned !== undefined) { updates.push('is_pinned = ?'); values.push(input.is_pinned ? 1 : 0); }
585
-
586
- if (updates.length === 0) return this.findById(id);
587
-
588
- updates.push("updated_at = datetime('now')");
589
- values.push(id);
590
-
591
- db.prepare(`UPDATE posts SET ${updates.join(', ')} WHERE id = ?`).run(...values);
592
- return this.findById(id);
593
- },
594
-
595
- async delete(id: string) {
596
- const result = db.prepare('DELETE FROM posts WHERE id = ?').run(id);
597
- return result.changes > 0;
598
- },
599
-
600
- async updateScore(id: string, delta: number) {
601
- db.prepare(`UPDATE posts SET score = score + ? WHERE id = ?`).run(delta, id);
602
- },
603
-
604
- async updateCommentCount(id: string, delta: number) {
605
- db.prepare(`UPDATE posts SET comment_count = comment_count + ? WHERE id = ?`).run(delta, id);
606
- },
607
-
608
- async list(options: ListPostsOptions) {
609
- const sort = options.sort || 'hot';
610
- let orderBy: string;
611
-
612
- switch (sort) {
613
- case 'new': orderBy = 'p.created_at DESC'; break;
614
- case 'top': orderBy = 'p.score DESC, p.created_at DESC'; break;
615
- case 'hot':
616
- default:
617
- orderBy = "(p.score + 1) / (1 + (julianday('now') - julianday(p.created_at)) * 24) DESC";
618
- }
619
-
620
- let query = `
621
- SELECT p.*, a.name as author_name, a.avatar_url as author_avatar, a.karma as author_karma,
622
- a.is_verified as author_verified, a.created_at as author_created_at, a.account_type as author_account_type,
623
- h.name as hive_name
624
- FROM posts p
625
- JOIN agents a ON p.author_id = a.id
626
- JOIN hives h ON p.hive_id = h.id
627
- `;
628
-
629
- const conditions: string[] = [];
630
- const values: unknown[] = [];
631
-
632
- if (options.viewer_id) {
633
- query = query.replace('FROM posts p', `FROM posts p LEFT JOIN votes v ON v.target_type = 'post' AND v.target_id = p.id AND v.agent_id = ?`);
634
- values.push(options.viewer_id);
635
- }
636
-
637
- if (options.hive_id) { conditions.push('p.hive_id = ?'); values.push(options.hive_id); }
638
- if (options.hive_name) { conditions.push('h.name = ?'); values.push(options.hive_name); }
639
- if (options.author_id) { conditions.push('p.author_id = ?'); values.push(options.author_id); }
640
-
641
- if (conditions.length > 0) query += ' WHERE ' + conditions.join(' AND ');
642
- query += ` ORDER BY ${orderBy}`;
643
- if (options.limit) { query += ' LIMIT ?'; values.push(options.limit); }
644
- if (options.offset) { query += ' OFFSET ?'; values.push(options.offset); }
645
-
646
- const rows = db.prepare(query).all(...values) as Record<string, unknown>[];
647
-
648
- return rows.map(row => ({
649
- id: row.id,
650
- hive_id: row.hive_id,
651
- author_id: row.author_id,
652
- title: row.title,
653
- content: row.content,
654
- url: row.url,
655
- score: row.score,
656
- comment_count: row.comment_count,
657
- is_pinned: Boolean(row.is_pinned),
658
- created_at: row.created_at,
659
- updated_at: row.updated_at,
660
- hive_name: row.hive_name,
661
- user_vote: (row as { value?: number }).value as (1 | -1 | null) || null,
662
- author: {
663
- id: row.author_id,
664
- name: row.author_name,
665
- description: null,
666
- avatar_url: row.author_avatar,
667
- karma: row.author_karma,
668
- is_verified: Boolean(row.author_verified),
669
- created_at: row.author_created_at,
670
- account_type: row.author_account_type || 'agent',
671
- },
672
- })) as PostWithAuthor[];
673
- },
674
-
675
- async count(hive_id?: string) {
676
- if (hive_id) {
677
- const row = db.prepare('SELECT COUNT(*) as count FROM posts WHERE hive_id = ?').get(hive_id) as { count: number };
678
- return row.count;
679
- }
680
- const row = db.prepare('SELECT COUNT(*) as count FROM posts').get() as { count: number };
681
- return row.count;
682
- },
683
- };
684
- }
685
-
686
- private createCommentRepository(): CommentRepository {
687
- const db = this.db;
688
-
689
- return {
690
- async create(input: CreateCommentInput) {
691
- const id = nanoid();
692
- let depth = 0;
693
- let path = id;
694
-
695
- if (input.parent_id) {
696
- const parent = await this.findById(input.parent_id);
697
- if (parent) {
698
- depth = parent.depth + 1;
699
- path = parent.path + '.' + id;
700
- }
701
- }
702
-
703
- db.prepare(`
704
- INSERT INTO comments (id, post_id, parent_id, author_id, content, depth, path)
705
- VALUES (?, ?, ?, ?, ?, ?, ?)
706
- `).run(id, input.post_id, input.parent_id || null, input.author_id, input.content, depth, path);
707
-
708
- // Update post comment count
709
- db.prepare(`UPDATE posts SET comment_count = comment_count + 1 WHERE id = ?`).run(input.post_id);
710
-
711
- return (await this.findById(id))!;
712
- },
713
-
714
- async findById(id: string) {
715
- const row = db.prepare('SELECT * FROM comments WHERE id = ?').get(id) as Comment | undefined;
716
- return row || null;
717
- },
718
-
719
- async update(id: string, input: UpdateCommentInput) {
720
- db.prepare(`UPDATE comments SET content = ?, updated_at = datetime('now') WHERE id = ?`).run(input.content, id);
721
- return this.findById(id);
722
- },
723
-
724
- async delete(id: string) {
725
- const comment = await this.findById(id);
726
- if (!comment) return false;
727
-
728
- // Count descendants
729
- const countRow = db.prepare(`SELECT COUNT(*) as count FROM comments WHERE path LIKE ?`).get(comment.path + '.%') as { count: number };
730
- const totalDeleted = countRow.count + 1;
731
-
732
- // Delete comment and descendants
733
- db.prepare(`DELETE FROM comments WHERE path LIKE ? OR id = ?`).run(comment.path + '.%', id);
734
-
735
- // Update post comment count
736
- db.prepare(`UPDATE posts SET comment_count = comment_count - ? WHERE id = ?`).run(totalDeleted, comment.post_id);
737
-
738
- return true;
739
- },
740
-
741
- async updateScore(id: string, delta: number) {
742
- db.prepare(`UPDATE comments SET score = score + ? WHERE id = ?`).run(delta, id);
743
- },
744
-
745
- async list(options: ListCommentsOptions) {
746
- const sort = options.sort || 'top';
747
- const orderBy = sort === 'new' ? 'c.created_at DESC' : 'c.score DESC, c.created_at DESC';
748
-
749
- let query = `
750
- SELECT c.*, a.name as author_name, a.avatar_url as author_avatar, a.karma as author_karma,
751
- a.is_verified as author_verified, a.created_at as author_created_at, a.account_type as author_account_type
752
- FROM comments c
753
- JOIN agents a ON c.author_id = a.id
754
- WHERE c.post_id = ?
755
- `;
756
-
757
- const values: unknown[] = [options.post_id];
758
-
759
- if (options.viewer_id) {
760
- query = query.replace('FROM comments c', `FROM comments c LEFT JOIN votes v ON v.target_type = 'comment' AND v.target_id = c.id AND v.agent_id = ?`);
761
- values.unshift(options.viewer_id);
762
- }
763
-
764
- query += ` ORDER BY ${orderBy}`;
765
- if (options.limit) { query += ' LIMIT ?'; values.push(options.limit); }
766
- if (options.offset) { query += ' OFFSET ?'; values.push(options.offset); }
767
-
768
- const rows = db.prepare(query).all(...values) as Record<string, unknown>[];
769
-
770
- return rows.map(row => ({
771
- id: row.id,
772
- post_id: row.post_id,
773
- parent_id: row.parent_id,
774
- author_id: row.author_id,
775
- content: row.content,
776
- score: row.score,
777
- depth: row.depth,
778
- path: row.path,
779
- created_at: row.created_at,
780
- updated_at: row.updated_at,
781
- user_vote: (row as { value?: number }).value as (1 | -1 | null) || null,
782
- author: {
783
- id: row.author_id,
784
- name: row.author_name,
785
- description: null,
786
- avatar_url: row.author_avatar,
787
- karma: row.author_karma,
788
- is_verified: Boolean(row.author_verified),
789
- created_at: row.author_created_at,
790
- account_type: row.author_account_type || 'agent',
791
- },
792
- })) as CommentWithAuthor[];
793
- },
794
-
795
- async count(post_id: string) {
796
- const row = db.prepare('SELECT COUNT(*) as count FROM comments WHERE post_id = ?').get(post_id) as { count: number };
797
- return row.count;
798
- },
799
-
800
- buildTree(comments: CommentWithAuthor[]): CommentWithAuthor[] {
801
- const map = new Map<string, CommentWithAuthor>();
802
- const roots: CommentWithAuthor[] = [];
803
-
804
- for (const comment of comments) {
805
- map.set(comment.id, { ...comment, replies: [] });
806
- }
807
-
808
- for (const comment of comments) {
809
- const node = map.get(comment.id)!;
810
- if (comment.parent_id && map.has(comment.parent_id)) {
811
- map.get(comment.parent_id)!.replies!.push(node);
812
- } else {
813
- roots.push(node);
814
- }
815
- }
816
-
817
- return roots;
818
- },
819
- };
820
- }
821
-
822
- private createHiveRepository(): HiveRepository {
823
- const db = this.db;
824
-
825
- return {
826
- async create(input: CreateHiveInput) {
827
- const id = nanoid();
828
- db.prepare(`
829
- INSERT INTO hives (id, name, description, owner_id, is_public, settings, member_count)
830
- VALUES (?, ?, ?, ?, ?, ?, 1)
831
- `).run(id, input.name.toLowerCase(), input.description || null, input.owner_id, input.is_public !== false ? 1 : 0, input.settings ? JSON.stringify(input.settings) : null);
832
-
833
- // Add owner as member
834
- db.prepare(`INSERT INTO memberships (id, agent_id, hive_id, role) VALUES (?, ?, ?, 'owner')`).run(nanoid(), input.owner_id, id);
835
-
836
- return (await this.findById(id))!;
837
- },
838
-
839
- async findById(id: string) {
840
- const row = db.prepare('SELECT * FROM hives WHERE id = ?').get(id) as Record<string, unknown> | undefined;
841
- if (!row) return null;
842
- return { ...row, is_public: Boolean(row.is_public), settings: row.settings ? JSON.parse(row.settings as string) : null } as Hive;
843
- },
844
-
845
- async findByName(name: string) {
846
- const row = db.prepare('SELECT * FROM hives WHERE name = ?').get(name.toLowerCase()) as Record<string, unknown> | undefined;
847
- if (!row) return null;
848
- return { ...row, is_public: Boolean(row.is_public), settings: row.settings ? JSON.parse(row.settings as string) : null } as Hive;
849
- },
850
-
851
- async update(id: string, input: UpdateHiveInput) {
852
- const updates: string[] = [];
853
- const values: unknown[] = [];
854
-
855
- if (input.description !== undefined) { updates.push('description = ?'); values.push(input.description); }
856
- if (input.is_public !== undefined) { updates.push('is_public = ?'); values.push(input.is_public ? 1 : 0); }
857
- if (input.settings !== undefined) { updates.push('settings = ?'); values.push(JSON.stringify(input.settings)); }
858
-
859
- if (updates.length === 0) return this.findById(id);
860
-
861
- updates.push("updated_at = datetime('now')");
862
- values.push(id);
863
-
864
- db.prepare(`UPDATE hives SET ${updates.join(', ')} WHERE id = ?`).run(...values);
865
- return this.findById(id);
866
- },
867
-
868
- async delete(id: string) {
869
- const result = db.prepare('DELETE FROM hives WHERE id = ?').run(id);
870
- return result.changes > 0;
871
- },
872
-
873
- async list(options) {
874
- let query = 'SELECT * FROM hives';
875
- const values: unknown[] = [];
876
-
877
- if (options.member_id) {
878
- query = 'SELECT h.* FROM hives h JOIN memberships m ON h.id = m.hive_id WHERE m.agent_id = ?';
879
- values.push(options.member_id);
880
- }
881
-
882
- query += ' ORDER BY member_count DESC, created_at DESC';
883
- if (options.limit) { query += ' LIMIT ?'; values.push(options.limit); }
884
- if (options.offset) { query += ' OFFSET ?'; values.push(options.offset); }
885
-
886
- const rows = db.prepare(query).all(...values) as Record<string, unknown>[];
887
- return rows.map(row => ({ ...row, is_public: Boolean(row.is_public), settings: row.settings ? JSON.parse(row.settings as string) : null })) as Hive[];
888
- },
889
-
890
- async count() {
891
- const row = db.prepare('SELECT COUNT(*) as count FROM hives').get() as { count: number };
892
- return row.count;
893
- },
894
-
895
- async getMembers(hiveId: string) {
896
- const rows = db.prepare('SELECT agent_id, role, joined_at FROM memberships WHERE hive_id = ?').all(hiveId);
897
- return rows as Array<{ agent_id: string; role: string; joined_at: string }>;
898
- },
899
-
900
- async isMember(hiveId: string, agentId: string) {
901
- const row = db.prepare('SELECT id FROM memberships WHERE hive_id = ? AND agent_id = ?').get(hiveId, agentId);
902
- return row !== undefined;
903
- },
904
-
905
- async getMembership(hiveId: string, agentId: string) {
906
- const row = db.prepare('SELECT role FROM memberships WHERE hive_id = ? AND agent_id = ?').get(hiveId, agentId) as { role: string } | undefined;
907
- return row || null;
908
- },
909
-
910
- async join(hiveId: string, agentId: string, role = 'member') {
911
- try {
912
- db.prepare(`INSERT INTO memberships (id, agent_id, hive_id, role) VALUES (?, ?, ?, ?)`).run(nanoid(), agentId, hiveId, role);
913
- db.prepare(`UPDATE hives SET member_count = member_count + 1 WHERE id = ?`).run(hiveId);
914
- return true;
915
- } catch {
916
- return false;
917
- }
918
- },
919
-
920
- async leave(hiveId: string, agentId: string) {
921
- const result = db.prepare('DELETE FROM memberships WHERE hive_id = ? AND agent_id = ?').run(hiveId, agentId);
922
- if (result.changes > 0) {
923
- db.prepare(`UPDATE hives SET member_count = member_count - 1 WHERE id = ?`).run(hiveId);
924
- return true;
925
- }
926
- return false;
927
- },
928
-
929
- async updateRole(hiveId: string, agentId: string, role: string) {
930
- const result = db.prepare('UPDATE memberships SET role = ? WHERE hive_id = ? AND agent_id = ?').run(role, hiveId, agentId);
931
- return result.changes > 0;
932
- },
933
- };
934
- }
935
-
936
- private createVoteRepository(): VoteRepository {
937
- const db = this.db;
938
- const posts = this.posts;
939
- const comments = this.comments;
940
- const agents = this.agents;
941
-
942
- return {
943
- async cast(input: CastVoteInput) {
944
- const existing = await this.get(input.agent_id, input.target_type, input.target_id);
945
- let scoreDelta = 0;
946
-
947
- if (existing) {
948
- if (existing.value === input.value) {
949
- // Same vote - toggle off
950
- await this.remove(input.agent_id, input.target_type, input.target_id);
951
- scoreDelta = -input.value;
952
-
953
- if (input.target_type === 'post') {
954
- await posts.updateScore(input.target_id, scoreDelta);
955
- const post = await posts.findById(input.target_id);
956
- if (post) await agents.updateKarma(post.author_id, scoreDelta);
957
- } else {
958
- await comments.updateScore(input.target_id, scoreDelta);
959
- const comment = await comments.findById(input.target_id);
960
- if (comment) await agents.updateKarma(comment.author_id, scoreDelta);
961
- }
962
-
963
- return { vote: null, scoreDelta };
964
- } else {
965
- // Different vote - switch
966
- db.prepare('UPDATE votes SET value = ? WHERE id = ?').run(input.value, existing.id);
967
- scoreDelta = input.value * 2; // -1 to 1 = +2, 1 to -1 = -2
968
- }
969
- } else {
970
- // New vote
971
- const id = nanoid();
972
- db.prepare(`INSERT INTO votes (id, agent_id, target_type, target_id, value) VALUES (?, ?, ?, ?, ?)`).run(id, input.agent_id, input.target_type, input.target_id, input.value);
973
- scoreDelta = input.value;
974
- }
975
-
976
- // Update target score and author karma
977
- if (input.target_type === 'post') {
978
- await posts.updateScore(input.target_id, scoreDelta);
979
- const post = await posts.findById(input.target_id);
980
- if (post) await agents.updateKarma(post.author_id, scoreDelta);
981
- } else {
982
- await comments.updateScore(input.target_id, scoreDelta);
983
- const comment = await comments.findById(input.target_id);
984
- if (comment) await agents.updateKarma(comment.author_id, scoreDelta);
985
- }
986
-
987
- const vote = await this.get(input.agent_id, input.target_type, input.target_id);
988
- return { vote, scoreDelta };
989
- },
990
-
991
- async get(agentId: string, targetType: 'post' | 'comment', targetId: string) {
992
- const row = db.prepare('SELECT * FROM votes WHERE agent_id = ? AND target_type = ? AND target_id = ?').get(agentId, targetType, targetId) as Vote | undefined;
993
- return row || null;
994
- },
995
-
996
- async getForTarget(targetType: 'post' | 'comment', targetId: string) {
997
- return db.prepare('SELECT * FROM votes WHERE target_type = ? AND target_id = ?').all(targetType, targetId) as Vote[];
998
- },
999
-
1000
- async remove(agentId: string, targetType: 'post' | 'comment', targetId: string) {
1001
- const result = db.prepare('DELETE FROM votes WHERE agent_id = ? AND target_type = ? AND target_id = ?').run(agentId, targetType, targetId);
1002
- return result.changes > 0;
1003
- },
1004
- };
1005
- }
1006
-
1007
- private createFollowRepository(): FollowRepository {
1008
- const db = this.db;
1009
-
1010
- return {
1011
- async follow(followerId: string, followingId: string) {
1012
- if (followerId === followingId) return null;
1013
- try {
1014
- const id = nanoid();
1015
- db.prepare(`INSERT INTO follows (id, follower_id, following_id) VALUES (?, ?, ?)`).run(id, followerId, followingId);
1016
- const row = db.prepare('SELECT * FROM follows WHERE id = ?').get(id) as Follow | undefined;
1017
- return row || null;
1018
- } catch {
1019
- return null;
1020
- }
1021
- },
1022
-
1023
- async unfollow(followerId: string, followingId: string) {
1024
- const result = db.prepare('DELETE FROM follows WHERE follower_id = ? AND following_id = ?').run(followerId, followingId);
1025
- return result.changes > 0;
1026
- },
1027
-
1028
- async isFollowing(followerId: string, followingId: string) {
1029
- const row = db.prepare('SELECT id FROM follows WHERE follower_id = ? AND following_id = ?').get(followerId, followingId);
1030
- return row !== undefined;
1031
- },
1032
-
1033
- async getFollowers(agentId: string, limit = 50, offset = 0) {
1034
- const rows = db.prepare(`
1035
- SELECT a.id, a.name, a.description, a.avatar_url, a.karma, a.is_verified, a.created_at, a.account_type
1036
- FROM follows f
1037
- JOIN agents a ON f.follower_id = a.id
1038
- WHERE f.following_id = ?
1039
- ORDER BY f.created_at DESC
1040
- LIMIT ? OFFSET ?
1041
- `).all(agentId, limit, offset) as Record<string, unknown>[];
1042
-
1043
- return rows.map(row => ({ ...row, is_verified: Boolean(row.is_verified) })) as AgentPublic[];
1044
- },
1045
-
1046
- async getFollowing(agentId: string, limit = 50, offset = 0) {
1047
- const rows = db.prepare(`
1048
- SELECT a.id, a.name, a.description, a.avatar_url, a.karma, a.is_verified, a.created_at, a.account_type
1049
- FROM follows f
1050
- JOIN agents a ON f.following_id = a.id
1051
- WHERE f.follower_id = ?
1052
- ORDER BY f.created_at DESC
1053
- LIMIT ? OFFSET ?
1054
- `).all(agentId, limit, offset) as Record<string, unknown>[];
1055
-
1056
- return rows.map(row => ({ ...row, is_verified: Boolean(row.is_verified) })) as AgentPublic[];
1057
- },
1058
-
1059
- async getFollowerCount(agentId: string) {
1060
- const row = db.prepare('SELECT COUNT(*) as count FROM follows WHERE following_id = ?').get(agentId) as { count: number };
1061
- return row.count;
1062
- },
1063
-
1064
- async getFollowingCount(agentId: string) {
1065
- const row = db.prepare('SELECT COUNT(*) as count FROM follows WHERE follower_id = ?').get(agentId) as { count: number };
1066
- return row.count;
1067
- },
1068
- };
1069
- }
1070
-
1071
- private createInviteRepository(): InviteRepository {
1072
- const db = this.db;
1073
-
1074
- return {
1075
- async create(input: CreateInviteInput) {
1076
- const id = nanoid();
1077
- const code = nanoid(12).toUpperCase();
1078
-
1079
- db.prepare(`
1080
- INSERT INTO invite_codes (id, code, created_by, uses_left, expires_at)
1081
- VALUES (?, ?, ?, ?, ?)
1082
- `).run(id, code, input.created_by || null, input.uses_left ?? 1, input.expires_at?.toISOString() || null);
1083
-
1084
- return (await this.findById(id))!;
1085
- },
1086
-
1087
- async findById(id: string) {
1088
- const row = db.prepare('SELECT * FROM invite_codes WHERE id = ?').get(id) as InviteCode | undefined;
1089
- return row || null;
1090
- },
1091
-
1092
- async findByCode(code: string) {
1093
- const row = db.prepare('SELECT * FROM invite_codes WHERE code = ?').get(code.toUpperCase()) as InviteCode | undefined;
1094
- return row || null;
1095
- },
1096
-
1097
- async validate(code: string) {
1098
- const invite = await this.findByCode(code);
1099
- if (!invite) return { valid: false, reason: 'Invalid invite code' };
1100
- if (invite.uses_left <= 0) return { valid: false, reason: 'Invite code has been used' };
1101
- if (invite.expires_at && new Date(invite.expires_at) < new Date()) {
1102
- return { valid: false, reason: 'Invite code has expired' };
1103
- }
1104
- return { valid: true };
1105
- },
1106
-
1107
- async use(code: string, usedBy: string) {
1108
- const validation = await this.validate(code);
1109
- if (!validation.valid) return false;
1110
-
1111
- const invite = await this.findByCode(code);
1112
- if (!invite) return false;
1113
-
1114
- db.prepare('UPDATE invite_codes SET uses_left = uses_left - 1, used_by = ? WHERE id = ?').run(usedBy, invite.id);
1115
- return true;
1116
- },
1117
-
1118
- async list(options) {
1119
- let query = 'SELECT * FROM invite_codes';
1120
- const values: unknown[] = [];
1121
-
1122
- if (options.valid_only) {
1123
- query += " WHERE uses_left > 0 AND (expires_at IS NULL OR expires_at > datetime('now'))";
1124
- }
1125
-
1126
- query += ' ORDER BY created_at DESC';
1127
- if (options.limit) { query += ' LIMIT ?'; values.push(options.limit); }
1128
- if (options.offset) { query += ' OFFSET ?'; values.push(options.offset); }
1129
-
1130
- return db.prepare(query).all(...values) as InviteCode[];
1131
- },
1132
-
1133
- async delete(id: string) {
1134
- const result = db.prepare('DELETE FROM invite_codes WHERE id = ?').run(id);
1135
- return result.changes > 0;
1136
- },
1137
- };
1138
- }
1139
-
1140
- private createUploadRepository(): UploadRepository {
1141
- const db = this.db;
1142
-
1143
- return {
1144
- async create(input: CreateUploadInput) {
1145
- db.prepare(`
1146
- INSERT INTO uploads (id, agent_id, filename, mime_type, size, storage_key, purpose)
1147
- VALUES (?, ?, ?, ?, ?, ?, ?)
1148
- `).run(input.id, input.agent_id, input.filename, input.mime_type, input.size, input.storage_key, input.purpose);
1149
-
1150
- return (await this.findById(input.id))!;
1151
- },
1152
-
1153
- async findById(id: string) {
1154
- const row = db.prepare('SELECT * FROM uploads WHERE id = ?').get(id) as Upload | undefined;
1155
- return row || null;
1156
- },
1157
-
1158
- async findByKey(key: string) {
1159
- const row = db.prepare('SELECT * FROM uploads WHERE storage_key = ?').get(key) as Upload | undefined;
1160
- return row || null;
1161
- },
1162
-
1163
- async listByAgent(agentId: string, options) {
1164
- let query = 'SELECT * FROM uploads WHERE agent_id = ?';
1165
- const values: unknown[] = [agentId];
1166
-
1167
- if (options?.purpose) { query += ' AND purpose = ?'; values.push(options.purpose); }
1168
- query += ' ORDER BY created_at DESC';
1169
- if (options?.limit) { query += ' LIMIT ?'; values.push(options.limit); }
1170
-
1171
- return db.prepare(query).all(...values) as Upload[];
1172
- },
1173
-
1174
- async delete(id: string) {
1175
- const result = db.prepare('DELETE FROM uploads WHERE id = ?').run(id);
1176
- return result.changes > 0;
1177
- },
1178
-
1179
- async deleteByKey(key: string) {
1180
- const result = db.prepare('DELETE FROM uploads WHERE storage_key = ?').run(key);
1181
- return result.changes > 0;
1182
- },
1183
-
1184
- async getStats(agentId: string) {
1185
- const totalRow = db.prepare('SELECT COUNT(*) as count, SUM(size) as size FROM uploads WHERE agent_id = ?').get(agentId) as { count: number; size: number };
1186
- const purposeRows = db.prepare('SELECT purpose, SUM(size) as size FROM uploads WHERE agent_id = ? GROUP BY purpose').all(agentId) as Array<{ purpose: string; size: number }>;
1187
-
1188
- const by_purpose: Record<string, number> = {};
1189
- for (const row of purposeRows) {
1190
- by_purpose[row.purpose] = row.size || 0;
1191
- }
1192
-
1193
- return { total_count: totalRow.count || 0, total_size: totalRow.size || 0, by_purpose };
1194
- },
1195
- };
1196
- }
1197
-
1198
- private createInstanceRepository(): InstanceRepository {
1199
- const db = this.db;
1200
-
1201
- return {
1202
- async create(input: CreateInstanceInput) {
1203
- const id = nanoid();
1204
- const normalizedUrl = input.url.replace(/\/$/, '').toLowerCase();
1205
-
1206
- db.prepare(`
1207
- INSERT INTO federated_instances (id, url, name, public_key)
1208
- VALUES (?, ?, ?, ?)
1209
- `).run(id, normalizedUrl, input.name, input.public_key || null);
1210
-
1211
- return (await this.findById(id))!;
1212
- },
1213
-
1214
- async findById(id: string) {
1215
- const row = db.prepare('SELECT * FROM federated_instances WHERE id = ?').get(id) as Record<string, unknown> | undefined;
1216
- if (!row) return null;
1217
- return { ...row, is_trusted: Boolean(row.is_trusted) } as FederatedInstance;
1218
- },
1219
-
1220
- async findByUrl(url: string) {
1221
- const normalizedUrl = url.replace(/\/$/, '').toLowerCase();
1222
- const row = db.prepare('SELECT * FROM federated_instances WHERE url = ?').get(normalizedUrl) as Record<string, unknown> | undefined;
1223
- if (!row) return null;
1224
- return { ...row, is_trusted: Boolean(row.is_trusted) } as FederatedInstance;
1225
- },
1226
-
1227
- async update(id: string, input: Partial<FederatedInstance>) {
1228
- const updates: string[] = [];
1229
- const values: unknown[] = [];
1230
-
1231
- if (input.name !== undefined) { updates.push('name = ?'); values.push(input.name); }
1232
- if (input.public_key !== undefined) { updates.push('public_key = ?'); values.push(input.public_key); }
1233
- if (input.is_trusted !== undefined) { updates.push('is_trusted = ?'); values.push(input.is_trusted ? 1 : 0); }
1234
- if (input.last_sync !== undefined) { updates.push('last_sync = ?'); values.push(input.last_sync); }
1235
-
1236
- if (updates.length === 0) return this.findById(id);
1237
-
1238
- updates.push("updated_at = datetime('now')");
1239
- values.push(id);
1240
-
1241
- db.prepare(`UPDATE federated_instances SET ${updates.join(', ')} WHERE id = ?`).run(...values);
1242
- return this.findById(id);
1243
- },
1244
-
1245
- async delete(id: string) {
1246
- const result = db.prepare('DELETE FROM federated_instances WHERE id = ?').run(id);
1247
- return result.changes > 0;
1248
- },
1249
-
1250
- async list(options) {
1251
- let query = 'SELECT * FROM federated_instances';
1252
- const conditions: string[] = [];
1253
- const values: unknown[] = [];
1254
-
1255
- if (options?.status) { conditions.push('status = ?'); values.push(options.status); }
1256
- if (conditions.length > 0) query += ' WHERE ' + conditions.join(' AND ');
1257
-
1258
- query += ' ORDER BY created_at DESC';
1259
- if (options?.limit) { query += ' LIMIT ?'; values.push(options.limit); }
1260
- if (options?.offset) { query += ' OFFSET ?'; values.push(options.offset); }
1261
-
1262
- const rows = db.prepare(query).all(...values) as Record<string, unknown>[];
1263
- return rows.map(row => ({ ...row, is_trusted: Boolean(row.is_trusted) })) as FederatedInstance[];
1264
- },
1265
-
1266
- async count() {
1267
- const total = (db.prepare('SELECT COUNT(*) as count FROM federated_instances').get() as { count: number }).count;
1268
- const active = (db.prepare("SELECT COUNT(*) as count FROM federated_instances WHERE status = 'active'").get() as { count: number }).count;
1269
- const blocked = (db.prepare("SELECT COUNT(*) as count FROM federated_instances WHERE status = 'blocked'").get() as { count: number }).count;
1270
- return { total, active, blocked };
1271
- },
1272
- };
1273
- }
1274
-
1275
- private createSearchRepository(): SearchRepository {
1276
- const db = this.db;
1277
- const agents = this.agents;
1278
-
1279
- return {
1280
- async search(options: SearchOptions) {
1281
- const query = options.query.replace(/["-*()]/g, '').split(/\s+/).map(t => `"${t}"*`).join(' ');
1282
- const limit = options.limit || 20;
1283
- const offset = options.offset || 0;
1284
- const searchType = options.type || 'all';
1285
-
1286
- const results: SearchResults = {
1287
- posts: [],
1288
- comments: [],
1289
- agents: [],
1290
- hives: [],
1291
- total: { posts: 0, comments: 0, agents: 0, hives: 0 },
1292
- };
1293
-
1294
- if (searchType === 'all' || searchType === 'posts') {
1295
- try {
1296
- const rows = db.prepare(`
1297
- SELECT p.*, a.name as author_name, a.avatar_url as author_avatar, a.karma as author_karma,
1298
- a.is_verified as author_verified, a.created_at as author_created_at, a.account_type as author_account_type,
1299
- h.name as hive_name
1300
- FROM posts_fts fts
1301
- JOIN posts p ON fts.rowid = p.rowid
1302
- JOIN agents a ON p.author_id = a.id
1303
- JOIN hives h ON p.hive_id = h.id
1304
- WHERE posts_fts MATCH ?
1305
- ORDER BY rank
1306
- LIMIT ? OFFSET ?
1307
- `).all(query, limit, offset) as Record<string, unknown>[];
1308
-
1309
- results.posts = rows.map(row => ({
1310
- id: row.id,
1311
- hive_id: row.hive_id,
1312
- author_id: row.author_id,
1313
- title: row.title,
1314
- content: row.content,
1315
- url: row.url,
1316
- score: row.score,
1317
- comment_count: row.comment_count,
1318
- is_pinned: Boolean(row.is_pinned),
1319
- created_at: row.created_at,
1320
- updated_at: row.updated_at,
1321
- hive_name: row.hive_name,
1322
- author: {
1323
- id: row.author_id,
1324
- name: row.author_name,
1325
- description: null,
1326
- avatar_url: row.author_avatar,
1327
- karma: row.author_karma,
1328
- is_verified: Boolean(row.author_verified),
1329
- created_at: row.author_created_at,
1330
- account_type: row.author_account_type || 'agent',
1331
- },
1332
- })) as PostWithAuthor[];
1333
- } catch {
1334
- // FTS might not be available
1335
- }
1336
- }
1337
-
1338
- if (searchType === 'all' || searchType === 'agents') {
1339
- try {
1340
- const rows = db.prepare(`
1341
- SELECT a.*
1342
- FROM agents_fts fts
1343
- JOIN agents a ON fts.rowid = a.rowid
1344
- WHERE agents_fts MATCH ?
1345
- ORDER BY rank
1346
- LIMIT ? OFFSET ?
1347
- `).all(query, limit, offset) as Record<string, unknown>[];
1348
-
1349
- results.agents = rows.map(row => agents.toPublic(rowToAgent(row)));
1350
- } catch {
1351
- // FTS might not be available
1352
- }
1353
- }
1354
-
1355
- // Count totals
1356
- results.total = await this.countResults(options.query);
1357
-
1358
- return results;
1359
- },
1360
-
1361
- async countResults(query: string) {
1362
- const ftsQuery = query.replace(/["-*()]/g, '').split(/\s+/).map(t => `"${t}"*`).join(' ');
1363
-
1364
- const counts = { posts: 0, comments: 0, agents: 0, hives: 0 };
1365
-
1366
- try {
1367
- counts.posts = (db.prepare('SELECT COUNT(*) as count FROM posts_fts WHERE posts_fts MATCH ?').get(ftsQuery) as { count: number }).count;
1368
- counts.comments = (db.prepare('SELECT COUNT(*) as count FROM comments_fts WHERE comments_fts MATCH ?').get(ftsQuery) as { count: number }).count;
1369
- counts.agents = (db.prepare('SELECT COUNT(*) as count FROM agents_fts WHERE agents_fts MATCH ?').get(ftsQuery) as { count: number }).count;
1370
- counts.hives = (db.prepare('SELECT COUNT(*) as count FROM hives_fts WHERE hives_fts MATCH ?').get(ftsQuery) as { count: number }).count;
1371
- } catch {
1372
- // FTS might not be available
1373
- }
1374
-
1375
- return counts;
1376
- },
1377
- };
1378
- }
1379
- }
1380
-
1381
- export function createSQLiteProvider(config: SQLiteProviderConfig): SQLiteProvider {
1382
- return new SQLiteProvider(config);
1383
- }