sqlew 4.3.0 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (858) hide show
  1. package/CHANGELOG.md +95 -0
  2. package/LICENSE +1 -1
  3. package/NOTICE +2 -2
  4. package/README.md +338 -269
  5. package/assets/claude-md-snippets/plan-mode-integration.md +104 -48
  6. package/assets/claude-md-snippets/queue-monitoring.md +84 -0
  7. package/dist/backend/backend-factory.d.ts +67 -0
  8. package/dist/backend/backend-factory.d.ts.map +1 -0
  9. package/dist/backend/backend-factory.js +171 -0
  10. package/dist/backend/backend-factory.js.map +1 -0
  11. package/dist/backend/index.d.ts +12 -0
  12. package/dist/backend/index.d.ts.map +1 -0
  13. package/dist/backend/index.js +13 -0
  14. package/dist/backend/index.js.map +1 -0
  15. package/dist/backend/inference.d.ts +38 -0
  16. package/dist/backend/inference.d.ts.map +1 -0
  17. package/dist/backend/inference.js +76 -0
  18. package/dist/backend/inference.js.map +1 -0
  19. package/dist/backend/local-backend.d.ts +40 -0
  20. package/dist/backend/local-backend.d.ts.map +1 -0
  21. package/dist/backend/local-backend.js +410 -0
  22. package/dist/backend/local-backend.js.map +1 -0
  23. package/dist/backend/transforming-backend.d.ts +47 -0
  24. package/dist/backend/transforming-backend.d.ts.map +1 -0
  25. package/dist/backend/transforming-backend.js +80 -0
  26. package/dist/backend/transforming-backend.js.map +1 -0
  27. package/dist/backend/types.d.ts +58 -0
  28. package/dist/backend/types.d.ts.map +1 -0
  29. package/dist/backend/types.js +7 -0
  30. package/dist/backend/types.js.map +1 -0
  31. package/dist/cli/db-dump.js +45 -45
  32. package/dist/cli/db-dump.js.map +1 -1
  33. package/dist/cli/db-export.js +30 -30
  34. package/dist/cli/db-export.js.map +1 -1
  35. package/dist/cli/db-import.d.ts.map +1 -1
  36. package/dist/cli/db-import.js +32 -33
  37. package/dist/cli/db-import.js.map +1 -1
  38. package/dist/cli/hooks/check-completion.d.ts +1 -0
  39. package/dist/cli/hooks/check-completion.d.ts.map +1 -1
  40. package/dist/cli/hooks/check-completion.js +15 -26
  41. package/dist/cli/hooks/check-completion.js.map +1 -1
  42. package/dist/cli/hooks/mark-done.d.ts +1 -0
  43. package/dist/cli/hooks/mark-done.d.ts.map +1 -1
  44. package/dist/cli/hooks/mark-done.js +12 -17
  45. package/dist/cli/hooks/mark-done.js.map +1 -1
  46. package/dist/cli/hooks/on-enter-plan.js +2 -2
  47. package/dist/cli/hooks/on-enter-plan.js.map +1 -1
  48. package/dist/cli/hooks/on-session-start.d.ts +23 -0
  49. package/dist/cli/hooks/on-session-start.d.ts.map +1 -0
  50. package/dist/cli/hooks/on-session-start.js +70 -0
  51. package/dist/cli/hooks/on-session-start.js.map +1 -0
  52. package/dist/cli/hooks/on-stop.js +5 -5
  53. package/dist/cli/hooks/on-stop.js.map +1 -1
  54. package/dist/cli/hooks/{plan-toml-parser.d.ts → plan-parser.d.ts} +1 -1
  55. package/dist/cli/hooks/plan-parser.d.ts.map +1 -0
  56. package/dist/cli/hooks/{plan-toml-parser.js → plan-parser.js} +1 -1
  57. package/dist/cli/hooks/plan-parser.js.map +1 -0
  58. package/dist/cli/hooks/plan-pattern-extractor.d.ts.map +1 -1
  59. package/dist/cli/hooks/plan-pattern-extractor.js +6 -3
  60. package/dist/cli/hooks/plan-pattern-extractor.js.map +1 -1
  61. package/dist/cli/hooks/plan-processor.js +1 -1
  62. package/dist/cli/hooks/plan-processor.js.map +1 -1
  63. package/dist/cli/hooks/stdin-parser.d.ts +4 -0
  64. package/dist/cli/hooks/stdin-parser.d.ts.map +1 -1
  65. package/dist/cli/hooks/stdin-parser.js.map +1 -1
  66. package/dist/cli/hooks/suggest.js +2 -2
  67. package/dist/cli/hooks/suggest.js.map +1 -1
  68. package/dist/cli/hooks/track-plan.d.ts.map +1 -1
  69. package/dist/cli/hooks/track-plan.js +24 -18
  70. package/dist/cli/hooks/track-plan.js.map +1 -1
  71. package/dist/cli.d.ts.map +1 -1
  72. package/dist/cli.js +108 -108
  73. package/dist/cli.js.map +1 -1
  74. package/dist/config/cloud-config-loader.d.ts +107 -0
  75. package/dist/config/cloud-config-loader.d.ts.map +1 -0
  76. package/dist/config/cloud-config-loader.js +273 -0
  77. package/dist/config/cloud-config-loader.js.map +1 -0
  78. package/dist/config/global-config.d.ts +10 -10
  79. package/dist/config/global-config.d.ts.map +1 -1
  80. package/dist/config/global-config.js +12 -12
  81. package/dist/config/global-config.js.map +1 -1
  82. package/dist/config/loader.d.ts.map +1 -1
  83. package/dist/config/loader.js +5 -1
  84. package/dist/config/loader.js.map +1 -1
  85. package/dist/config/minimal-generator.d.ts.map +1 -1
  86. package/dist/config/minimal-generator.js +22 -72
  87. package/dist/config/minimal-generator.js.map +1 -1
  88. package/dist/config/types.d.ts +59 -1
  89. package/dist/config/types.d.ts.map +1 -1
  90. package/dist/config/types.js +14 -0
  91. package/dist/config/types.js.map +1 -1
  92. package/dist/constants.d.ts +1 -29
  93. package/dist/constants.d.ts.map +1 -1
  94. package/dist/constants.js +1 -38
  95. package/dist/constants.js.map +1 -1
  96. package/dist/database/initialization/cleanup.d.ts.map +1 -1
  97. package/dist/database/initialization/cleanup.js +0 -13
  98. package/dist/database/initialization/cleanup.js.map +1 -1
  99. package/dist/database/initialization/init.d.ts.map +1 -1
  100. package/dist/database/initialization/init.js +0 -9
  101. package/dist/database/initialization/init.js.map +1 -1
  102. package/dist/database/initialization/schema-version.d.ts +4 -4
  103. package/dist/database/initialization/schema-version.js +9 -9
  104. package/dist/database/initialization/schema-version.js.map +1 -1
  105. package/dist/database/migrations/v4/20260107000000_v5_drop_task_file_tables.d.ts +36 -0
  106. package/dist/database/migrations/v4/20260107000000_v5_drop_task_file_tables.d.ts.map +1 -0
  107. package/dist/database/migrations/v4/20260107000000_v5_drop_task_file_tables.js +135 -0
  108. package/dist/database/migrations/v4/20260107000000_v5_drop_task_file_tables.js.map +1 -0
  109. package/dist/database/migrations/v4/20260107000001_v5_drop_legacy_tables.d.ts +20 -0
  110. package/dist/database/migrations/v4/20260107000001_v5_drop_legacy_tables.d.ts.map +1 -0
  111. package/dist/database/migrations/v4/20260107000001_v5_drop_legacy_tables.js +168 -0
  112. package/dist/database/migrations/v4/20260107000001_v5_drop_legacy_tables.js.map +1 -0
  113. package/dist/database/migrations/v4/20260108000000_v5_rename_to_m_t_prefix.d.ts +23 -0
  114. package/dist/database/migrations/v4/20260108000000_v5_rename_to_m_t_prefix.d.ts.map +1 -0
  115. package/dist/database/migrations/v4/20260108000000_v5_rename_to_m_t_prefix.js +570 -0
  116. package/dist/database/migrations/v4/20260108000000_v5_rename_to_m_t_prefix.js.map +1 -0
  117. package/dist/database/migrations/v4/20260109000000_v5_drop_help_tables.d.ts +29 -0
  118. package/dist/database/migrations/v4/20260109000000_v5_drop_help_tables.d.ts.map +1 -0
  119. package/dist/database/migrations/v4/20260109000000_v5_drop_help_tables.js +80 -0
  120. package/dist/database/migrations/v4/20260109000000_v5_drop_help_tables.js.map +1 -0
  121. package/dist/database/operations/inserts.js +11 -11
  122. package/dist/database/operations/inserts.js.map +1 -1
  123. package/dist/database/operations/queries.js +9 -9
  124. package/dist/database/operations/queries.js.map +1 -1
  125. package/dist/formatters/adr-formatter.d.ts +22 -0
  126. package/dist/formatters/adr-formatter.d.ts.map +1 -0
  127. package/dist/formatters/adr-formatter.js +127 -0
  128. package/dist/formatters/adr-formatter.js.map +1 -0
  129. package/dist/formatters/confluence-formatter.d.ts +26 -0
  130. package/dist/formatters/confluence-formatter.d.ts.map +1 -0
  131. package/dist/formatters/confluence-formatter.js +129 -0
  132. package/dist/formatters/confluence-formatter.js.map +1 -0
  133. package/dist/formatters/index.d.ts +34 -0
  134. package/dist/formatters/index.d.ts.map +1 -0
  135. package/dist/formatters/index.js +57 -0
  136. package/dist/formatters/index.js.map +1 -0
  137. package/dist/formatters/markdown-formatter.d.ts +16 -0
  138. package/dist/formatters/markdown-formatter.d.ts.map +1 -0
  139. package/dist/formatters/markdown-formatter.js +110 -0
  140. package/dist/formatters/markdown-formatter.js.map +1 -0
  141. package/dist/formatters/notion-formatter.d.ts +29 -0
  142. package/dist/formatters/notion-formatter.d.ts.map +1 -0
  143. package/dist/formatters/notion-formatter.js +177 -0
  144. package/dist/formatters/notion-formatter.js.map +1 -0
  145. package/dist/formatters/types.d.ts +31 -0
  146. package/dist/formatters/types.d.ts.map +1 -0
  147. package/dist/formatters/types.js +6 -0
  148. package/dist/formatters/types.js.map +1 -0
  149. package/dist/help-data/_schema.toml +21 -0
  150. package/dist/help-data/constraint.toml +259 -0
  151. package/dist/help-data/decision.toml +833 -0
  152. package/dist/help-data/example.toml +177 -0
  153. package/dist/help-data/help.toml +246 -0
  154. package/dist/help-data/queue.toml +134 -0
  155. package/dist/help-data/suggest.toml +219 -0
  156. package/dist/help-data/use-cases/_categories.toml +22 -0
  157. package/dist/help-data/use-cases/constraint-basic.toml +34 -0
  158. package/dist/help-data/use-cases/cross-tool-workflow.toml +50 -0
  159. package/dist/help-data/use-cases/decision-intelligence-duplicate.toml +35 -0
  160. package/dist/help-data/use-cases/decision-intelligence-related.toml +35 -0
  161. package/dist/help-data/use-cases/decision-tracking-basic.toml +42 -0
  162. package/dist/help-data/use-cases/decision-tracking-versions.toml +42 -0
  163. package/dist/help-data/use_case.toml +147 -0
  164. package/dist/help-loader.d.ts +194 -0
  165. package/dist/help-loader.d.ts.map +1 -0
  166. package/dist/help-loader.js +419 -0
  167. package/dist/help-loader.js.map +1 -0
  168. package/dist/index.js +15 -10
  169. package/dist/index.js.map +1 -1
  170. package/dist/init-rules.d.ts +42 -0
  171. package/dist/init-rules.d.ts.map +1 -0
  172. package/dist/init-rules.js +217 -0
  173. package/dist/init-rules.js.map +1 -0
  174. package/dist/schema.d.ts +4 -6
  175. package/dist/schema.d.ts.map +1 -1
  176. package/dist/schema.js +28 -45
  177. package/dist/schema.js.map +1 -1
  178. package/dist/server/setup.d.ts +0 -10
  179. package/dist/server/setup.d.ts.map +1 -1
  180. package/dist/server/setup.js +97 -89
  181. package/dist/server/setup.js.map +1 -1
  182. package/dist/server/shutdown.d.ts +1 -1
  183. package/dist/server/shutdown.d.ts.map +1 -1
  184. package/dist/server/shutdown.js +1 -16
  185. package/dist/server/shutdown.js.map +1 -1
  186. package/dist/server/tool-handlers.d.ts +15 -0
  187. package/dist/server/tool-handlers.d.ts.map +1 -1
  188. package/dist/server/tool-handlers.js +47 -462
  189. package/dist/server/tool-handlers.js.map +1 -1
  190. package/dist/server/tool-registry.d.ts.map +1 -1
  191. package/dist/server/tool-registry.js +50 -62
  192. package/dist/server/tool-registry.js.map +1 -1
  193. package/dist/tests/backend/backend-factory.test.d.ts +7 -0
  194. package/dist/tests/backend/backend-factory.test.d.ts.map +1 -0
  195. package/dist/tests/backend/backend-factory.test.js +157 -0
  196. package/dist/tests/backend/backend-factory.test.js.map +1 -0
  197. package/dist/tests/backend/inference.test.d.ts +7 -0
  198. package/dist/tests/backend/inference.test.d.ts.map +1 -0
  199. package/dist/tests/backend/inference.test.js +142 -0
  200. package/dist/tests/backend/inference.test.js.map +1 -0
  201. package/dist/tests/database/multi-project/multi-project.test.js +9 -70
  202. package/dist/tests/database/multi-project/multi-project.test.js.map +1 -1
  203. package/dist/tests/database/sql-dump/table-ordering.test.js +14 -14
  204. package/dist/tests/database/sql-dump/table-ordering.test.js.map +1 -1
  205. package/dist/tests/docker/cross-database.test.js +32 -32
  206. package/dist/tests/docker/cross-database.test.js.map +1 -1
  207. package/dist/tests/docker/dump-import.test.js +55 -55
  208. package/dist/tests/docker/dump-import.test.js.map +1 -1
  209. package/dist/tests/docker/fk-constraints.test.js +3 -3
  210. package/dist/tests/docker/indexes.test.js +34 -34
  211. package/dist/tests/docker/integration.test.js +33 -33
  212. package/dist/tests/docker/multi-project-migration.test.js +47 -47
  213. package/dist/tests/docker/multi-project-migration.test.js.map +1 -1
  214. package/dist/tests/docker/native/constraint-operations.test.js +49 -49
  215. package/dist/tests/docker/native/constraint-operations.test.js.map +1 -1
  216. package/dist/tests/docker/native/db-init.d.ts +3 -1
  217. package/dist/tests/docker/native/db-init.d.ts.map +1 -1
  218. package/dist/tests/docker/native/db-init.js +14 -12
  219. package/dist/tests/docker/native/db-init.js.map +1 -1
  220. package/dist/tests/docker/native/decision-operations.test.js +91 -91
  221. package/dist/tests/docker/native/decision-operations.test.js.map +1 -1
  222. package/dist/tests/docker/native/help-system.test.d.ts +2 -2
  223. package/dist/tests/docker/native/help-system.test.js +113 -138
  224. package/dist/tests/docker/native/help-system.test.js.map +1 -1
  225. package/dist/tests/docker/native/suggest-tool.test.d.ts +2 -2
  226. package/dist/tests/docker/native/suggest-tool.test.js +35 -35
  227. package/dist/tests/docker/native/suggest-tool.test.js.map +1 -1
  228. package/dist/tests/docker/native/test-harness.d.ts +6 -12
  229. package/dist/tests/docker/native/test-harness.d.ts.map +1 -1
  230. package/dist/tests/docker/native/test-harness.js +74 -156
  231. package/dist/tests/docker/native/test-harness.js.map +1 -1
  232. package/dist/tests/docker/schema-migration.test.js +6 -6
  233. package/dist/tests/feature/decision/batch-validation-comprehensive.test.d.ts +3 -7
  234. package/dist/tests/feature/decision/batch-validation-comprehensive.test.d.ts.map +1 -1
  235. package/dist/tests/feature/decision/batch-validation-comprehensive.test.js +7 -318
  236. package/dist/tests/feature/decision/batch-validation-comprehensive.test.js.map +1 -1
  237. package/dist/tests/feature/help/help-system.test.d.ts +6 -6
  238. package/dist/tests/feature/help/help-system.test.js +166 -124
  239. package/dist/tests/feature/help/help-system.test.js.map +1 -1
  240. package/dist/tests/integration/auto-trigger-suggestions.test.js +22 -22
  241. package/dist/tests/integration/auto-trigger-suggestions.test.js.map +1 -1
  242. package/dist/tests/integration/decision-intelligence-e2e.test.js +23 -22
  243. package/dist/tests/integration/decision-intelligence-e2e.test.js.map +1 -1
  244. package/dist/tests/integration/e2e-workflow1-debug.test.js +3 -3
  245. package/dist/tests/integration/e2e-workflow1-debug.test.js.map +1 -1
  246. package/dist/tests/integration/hybrid-similarity-detection.test.js +25 -25
  247. package/dist/tests/integration/hybrid-similarity-detection.test.js.map +1 -1
  248. package/dist/tests/integration/suggest-simple.test.js +18 -0
  249. package/dist/tests/integration/suggest-simple.test.js.map +1 -1
  250. package/dist/tests/migrations/test-all-versions.js +212 -212
  251. package/dist/tests/migrations/test-all-versions.js.map +1 -1
  252. package/dist/tests/migrations/v4/v4-fresh-install.test.js +29 -29
  253. package/dist/tests/migrations/v4/v4-fresh-install.test.js.map +1 -1
  254. package/dist/tests/migrations/v4/v4-migrate-data.test.js +20 -20
  255. package/dist/tests/migrations/v4/v4-migrate-data.test.js.map +1 -1
  256. package/dist/tests/test-v4-native-rdbms.js +20 -20
  257. package/dist/tests/test-v4-native-rdbms.js.map +1 -1
  258. package/dist/tests/unit/config/cloud-config-loader.test.d.ts +2 -0
  259. package/dist/tests/unit/config/cloud-config-loader.test.d.ts.map +1 -0
  260. package/dist/tests/unit/config/cloud-config-loader.test.js +103 -0
  261. package/dist/tests/unit/config/cloud-config-loader.test.js.map +1 -0
  262. package/dist/tests/unit/config/{plan-toml-cache.test.d.ts → plan-cache.test.d.ts} +1 -1
  263. package/dist/tests/unit/config/plan-cache.test.d.ts.map +1 -0
  264. package/dist/tests/unit/config/{plan-toml-cache.test.js → plan-cache.test.js} +32 -32
  265. package/dist/tests/unit/config/plan-cache.test.js.map +1 -0
  266. package/dist/tests/unit/hooks/{plan-toml-parser.test.d.ts → plan-parser.test.d.ts} +1 -1
  267. package/dist/tests/unit/hooks/plan-parser.test.d.ts.map +1 -0
  268. package/dist/tests/unit/hooks/{plan-toml-parser.test.js → plan-parser.test.js} +179 -179
  269. package/dist/tests/unit/hooks/plan-parser.test.js.map +1 -0
  270. package/dist/tests/unit/server/tool-handlers.test.d.ts +7 -0
  271. package/dist/tests/unit/server/tool-handlers.test.d.ts.map +1 -0
  272. package/dist/tests/unit/server/tool-handlers.test.js +76 -0
  273. package/dist/tests/unit/server/tool-handlers.test.js.map +1 -0
  274. package/dist/tests/unit/utils/config-loader.test.js +17 -17
  275. package/dist/tests/unit/utils/connection-hash.test.d.ts +2 -0
  276. package/dist/tests/unit/utils/connection-hash.test.d.ts.map +1 -0
  277. package/dist/tests/unit/utils/connection-hash.test.js +57 -0
  278. package/dist/tests/unit/utils/connection-hash.test.js.map +1 -0
  279. package/dist/tests/unit/utils/environment-detector.test.d.ts +2 -0
  280. package/dist/tests/unit/utils/environment-detector.test.d.ts.map +1 -0
  281. package/dist/tests/unit/utils/environment-detector.test.js +43 -0
  282. package/dist/tests/unit/utils/environment-detector.test.js.map +1 -0
  283. package/dist/tests/unit/utils/path-utils.test.d.ts +2 -0
  284. package/dist/tests/unit/utils/path-utils.test.d.ts.map +1 -0
  285. package/dist/tests/unit/utils/path-utils.test.js +72 -0
  286. package/dist/tests/unit/utils/path-utils.test.js.map +1 -0
  287. package/dist/tests/unit/utils/project-detector.test.js +14 -13
  288. package/dist/tests/unit/utils/project-detector.test.js.map +1 -1
  289. package/dist/tests/unit/validation/parameter-validation.test.d.ts +2 -1
  290. package/dist/tests/unit/validation/parameter-validation.test.d.ts.map +1 -1
  291. package/dist/tests/unit/validation/parameter-validation.test.js +5 -133
  292. package/dist/tests/unit/validation/parameter-validation.test.js.map +1 -1
  293. package/dist/tests/unit/validation/policy-validation.test.js +15 -15
  294. package/dist/tests/unit/validation/policy-validation.test.js.map +1 -1
  295. package/dist/tests/utils/db-schema.js +48 -48
  296. package/dist/tests/utils/db-seeding.js +11 -11
  297. package/dist/tests/utils/db-seeding.js.map +1 -1
  298. package/dist/tests/utils/json-export-import.test.d.ts +6 -0
  299. package/dist/tests/utils/json-export-import.test.d.ts.map +1 -0
  300. package/dist/tests/utils/json-export-import.test.js +474 -0
  301. package/dist/tests/utils/json-export-import.test.js.map +1 -0
  302. package/dist/tests/utils/test-helpers.js +59 -59
  303. package/dist/tests/utils/test-helpers.js.map +1 -1
  304. package/dist/tools/constraints/actions/activate.d.ts +2 -2
  305. package/dist/tools/constraints/actions/activate.d.ts.map +1 -1
  306. package/dist/tools/constraints/actions/activate.js +12 -12
  307. package/dist/tools/constraints/actions/activate.js.map +1 -1
  308. package/dist/tools/constraints/actions/add.js +3 -3
  309. package/dist/tools/constraints/actions/add.js.map +1 -1
  310. package/dist/tools/constraints/actions/deactivate.js +6 -6
  311. package/dist/tools/constraints/actions/deactivate.js.map +1 -1
  312. package/dist/tools/constraints/actions/get.d.ts +2 -2
  313. package/dist/tools/constraints/actions/get.js +9 -9
  314. package/dist/tools/constraints/actions/get.js.map +1 -1
  315. package/dist/tools/constraints/actions/suggest-pending.js +2 -2
  316. package/dist/tools/constraints/actions/suggest-pending.js.map +1 -1
  317. package/dist/tools/constraints/index.d.ts +1 -1
  318. package/dist/tools/constraints/index.d.ts.map +1 -1
  319. package/dist/tools/constraints/index.js +1 -1
  320. package/dist/tools/constraints/index.js.map +1 -1
  321. package/dist/tools/context/actions/create-policy.js +3 -3
  322. package/dist/tools/context/actions/create-policy.js.map +1 -1
  323. package/dist/tools/context/actions/create-template.js +2 -2
  324. package/dist/tools/context/actions/create-template.js.map +1 -1
  325. package/dist/tools/context/actions/export.d.ts +35 -0
  326. package/dist/tools/context/actions/export.d.ts.map +1 -0
  327. package/dist/tools/context/actions/export.js +93 -0
  328. package/dist/tools/context/actions/export.js.map +1 -0
  329. package/dist/tools/context/actions/hard-delete.js +11 -11
  330. package/dist/tools/context/actions/hard-delete.js.map +1 -1
  331. package/dist/tools/context/actions/has-updates.d.ts +1 -1
  332. package/dist/tools/context/actions/has-updates.d.ts.map +1 -1
  333. package/dist/tools/context/actions/has-updates.js +5 -17
  334. package/dist/tools/context/actions/has-updates.js.map +1 -1
  335. package/dist/tools/context/actions/list-policies.js +1 -1
  336. package/dist/tools/context/actions/list-policies.js.map +1 -1
  337. package/dist/tools/context/actions/list-templates.js +2 -2
  338. package/dist/tools/context/actions/list-templates.js.map +1 -1
  339. package/dist/tools/context/actions/list.js +1 -1
  340. package/dist/tools/context/actions/list.js.map +1 -1
  341. package/dist/tools/context/actions/search-layer.js +8 -8
  342. package/dist/tools/context/actions/search-layer.js.map +1 -1
  343. package/dist/tools/context/actions/set-from-policy.js +1 -1
  344. package/dist/tools/context/actions/set-from-policy.js.map +1 -1
  345. package/dist/tools/context/actions/set-from-template.js +2 -2
  346. package/dist/tools/context/actions/set-from-template.js.map +1 -1
  347. package/dist/tools/context/actions/versions.js +3 -3
  348. package/dist/tools/context/actions/versions.js.map +1 -1
  349. package/dist/tools/context/index.d.ts +1 -0
  350. package/dist/tools/context/index.d.ts.map +1 -1
  351. package/dist/tools/context/index.js +2 -0
  352. package/dist/tools/context/index.js.map +1 -1
  353. package/dist/tools/context/internal/queries.d.ts.map +1 -1
  354. package/dist/tools/context/internal/queries.js +54 -43
  355. package/dist/tools/context/internal/queries.js.map +1 -1
  356. package/dist/tools/context/types.d.ts +1 -1
  357. package/dist/tools/context/types.d.ts.map +1 -1
  358. package/dist/tools/example/actions/get.d.ts +8 -3
  359. package/dist/tools/example/actions/get.d.ts.map +1 -1
  360. package/dist/tools/example/actions/get.js +29 -30
  361. package/dist/tools/example/actions/get.js.map +1 -1
  362. package/dist/tools/example/actions/list-all.d.ts +8 -2
  363. package/dist/tools/example/actions/list-all.d.ts.map +1 -1
  364. package/dist/tools/example/actions/list-all.js +37 -29
  365. package/dist/tools/example/actions/list-all.js.map +1 -1
  366. package/dist/tools/example/actions/search.d.ts +8 -3
  367. package/dist/tools/example/actions/search.d.ts.map +1 -1
  368. package/dist/tools/example/actions/search.js +29 -43
  369. package/dist/tools/example/actions/search.js.map +1 -1
  370. package/dist/tools/help/actions/batch-guide.js +5 -5
  371. package/dist/tools/help/actions/batch-guide.js.map +1 -1
  372. package/dist/tools/help/actions/query-action.d.ts +7 -3
  373. package/dist/tools/help/actions/query-action.d.ts.map +1 -1
  374. package/dist/tools/help/actions/query-action.js +35 -6
  375. package/dist/tools/help/actions/query-action.js.map +1 -1
  376. package/dist/tools/help/actions/query-params.d.ts +5 -3
  377. package/dist/tools/help/actions/query-params.d.ts.map +1 -1
  378. package/dist/tools/help/actions/query-params.js +28 -6
  379. package/dist/tools/help/actions/query-params.js.map +1 -1
  380. package/dist/tools/help/actions/query-tool.d.ts +5 -3
  381. package/dist/tools/help/actions/query-tool.d.ts.map +1 -1
  382. package/dist/tools/help/actions/query-tool.js +23 -6
  383. package/dist/tools/help/actions/query-tool.js.map +1 -1
  384. package/dist/tools/help/actions/workflow-hints.d.ts +5 -3
  385. package/dist/tools/help/actions/workflow-hints.d.ts.map +1 -1
  386. package/dist/tools/help/actions/workflow-hints.js +21 -6
  387. package/dist/tools/help/actions/workflow-hints.js.map +1 -1
  388. package/dist/tools/queue/actions/clear.d.ts +19 -0
  389. package/dist/tools/queue/actions/clear.d.ts.map +1 -0
  390. package/dist/tools/queue/actions/clear.js +79 -0
  391. package/dist/tools/queue/actions/clear.js.map +1 -0
  392. package/dist/tools/queue/actions/list.d.ts +16 -0
  393. package/dist/tools/queue/actions/list.d.ts.map +1 -0
  394. package/dist/tools/queue/actions/list.js +95 -0
  395. package/dist/tools/queue/actions/list.js.map +1 -0
  396. package/dist/tools/queue/actions/remove.d.ts +19 -0
  397. package/dist/tools/queue/actions/remove.d.ts.map +1 -0
  398. package/dist/tools/queue/actions/remove.js +81 -0
  399. package/dist/tools/queue/actions/remove.js.map +1 -0
  400. package/dist/tools/queue/index.d.ts +13 -0
  401. package/dist/tools/queue/index.d.ts.map +1 -0
  402. package/dist/tools/queue/index.js +13 -0
  403. package/dist/tools/queue/index.js.map +1 -0
  404. package/dist/tools/queue/types.d.ts +87 -0
  405. package/dist/tools/queue/types.d.ts.map +1 -0
  406. package/dist/tools/queue/types.js +9 -0
  407. package/dist/tools/queue/types.js.map +1 -0
  408. package/dist/tools/suggest/actions/by-context.d.ts.map +1 -1
  409. package/dist/tools/suggest/actions/by-context.js +7 -15
  410. package/dist/tools/suggest/actions/by-context.js.map +1 -1
  411. package/dist/tools/suggest/actions/by-key.d.ts.map +1 -1
  412. package/dist/tools/suggest/actions/by-key.js +7 -15
  413. package/dist/tools/suggest/actions/by-key.js.map +1 -1
  414. package/dist/tools/suggest/actions/by-tags.d.ts +2 -2
  415. package/dist/tools/suggest/actions/by-tags.d.ts.map +1 -1
  416. package/dist/tools/suggest/actions/by-tags.js +8 -18
  417. package/dist/tools/suggest/actions/by-tags.js.map +1 -1
  418. package/dist/tools/suggest/actions/constraint-by-context.d.ts +1 -1
  419. package/dist/tools/suggest/actions/constraint-by-context.d.ts.map +1 -1
  420. package/dist/tools/suggest/actions/constraint-by-context.js +9 -16
  421. package/dist/tools/suggest/actions/constraint-by-context.js.map +1 -1
  422. package/dist/tools/suggest/actions/constraint-by-tags.d.ts +1 -1
  423. package/dist/tools/suggest/actions/constraint-by-tags.d.ts.map +1 -1
  424. package/dist/tools/suggest/actions/constraint-by-tags.js +11 -17
  425. package/dist/tools/suggest/actions/constraint-by-tags.js.map +1 -1
  426. package/dist/tools/suggest/actions/constraint-by-text.d.ts +1 -1
  427. package/dist/tools/suggest/actions/constraint-by-text.d.ts.map +1 -1
  428. package/dist/tools/suggest/actions/constraint-by-text.js +6 -15
  429. package/dist/tools/suggest/actions/constraint-by-text.js.map +1 -1
  430. package/dist/tools/suggest/internal/constraint-queries.d.ts +4 -4
  431. package/dist/tools/suggest/internal/constraint-queries.js +14 -14
  432. package/dist/tools/suggest/internal/constraint-queries.js.map +1 -1
  433. package/dist/tools/suggest/internal/queries.d.ts +4 -4
  434. package/dist/tools/suggest/internal/queries.js +25 -25
  435. package/dist/tools/suggest/internal/queries.js.map +1 -1
  436. package/dist/tools/use_case/actions/get.d.ts +5 -3
  437. package/dist/tools/use_case/actions/get.d.ts.map +1 -1
  438. package/dist/tools/use_case/actions/get.js +20 -6
  439. package/dist/tools/use_case/actions/get.js.map +1 -1
  440. package/dist/tools/use_case/actions/list-all.d.ts +5 -3
  441. package/dist/tools/use_case/actions/list-all.d.ts.map +1 -1
  442. package/dist/tools/use_case/actions/list-all.js +36 -6
  443. package/dist/tools/use_case/actions/list-all.js.map +1 -1
  444. package/dist/tools/use_case/actions/search.d.ts +6 -3
  445. package/dist/tools/use_case/actions/search.d.ts.map +1 -1
  446. package/dist/tools/use_case/actions/search.js +37 -67
  447. package/dist/tools/use_case/actions/search.js.map +1 -1
  448. package/dist/tools/use_case/help/example.js +17 -17
  449. package/dist/tools/use_case/help/example.js.map +1 -1
  450. package/dist/types.d.ts +81 -380
  451. package/dist/types.d.ts.map +1 -1
  452. package/dist/types.js +0 -10
  453. package/dist/types.js.map +1 -1
  454. package/dist/utils/action-specs/constraint-specs.js +6 -6
  455. package/dist/utils/action-specs/constraint-specs.js.map +1 -1
  456. package/dist/utils/action-specs/index.d.ts +0 -2
  457. package/dist/utils/action-specs/index.d.ts.map +1 -1
  458. package/dist/utils/action-specs/index.js +0 -6
  459. package/dist/utils/action-specs/index.js.map +1 -1
  460. package/dist/utils/batch-validation.d.ts +1 -1
  461. package/dist/utils/batch-validation.js +3 -3
  462. package/dist/utils/batch-validation.js.map +1 -1
  463. package/dist/utils/case-insensitive-validator.d.ts +2 -2
  464. package/dist/utils/case-insensitive-validator.js +2 -2
  465. package/dist/utils/connection-hash.d.ts +37 -0
  466. package/dist/utils/connection-hash.d.ts.map +1 -0
  467. package/dist/utils/connection-hash.js +55 -0
  468. package/dist/utils/connection-hash.js.map +1 -0
  469. package/dist/utils/db-aggregations.js +16 -16
  470. package/dist/utils/db-aggregations.js.map +1 -1
  471. package/dist/utils/enum-converter.d.ts +0 -21
  472. package/dist/utils/enum-converter.d.ts.map +1 -1
  473. package/dist/utils/enum-converter.js +1 -23
  474. package/dist/utils/enum-converter.js.map +1 -1
  475. package/dist/utils/environment-detector.d.ts +30 -0
  476. package/dist/utils/environment-detector.d.ts.map +1 -0
  477. package/dist/utils/environment-detector.js +86 -0
  478. package/dist/utils/environment-detector.js.map +1 -0
  479. package/dist/utils/example-filter.d.ts +34 -0
  480. package/dist/utils/example-filter.d.ts.map +1 -0
  481. package/dist/utils/example-filter.js +45 -0
  482. package/dist/utils/example-filter.js.map +1 -0
  483. package/dist/utils/exporter/export.d.ts +2 -16
  484. package/dist/utils/exporter/export.d.ts.map +1 -1
  485. package/dist/utils/exporter/export.js +49 -130
  486. package/dist/utils/exporter/export.js.map +1 -1
  487. package/dist/utils/hook-queue.d.ts +60 -0
  488. package/dist/utils/hook-queue.d.ts.map +1 -1
  489. package/dist/utils/hook-queue.js +114 -11
  490. package/dist/utils/hook-queue.js.map +1 -1
  491. package/dist/utils/importer/import.d.ts.map +1 -1
  492. package/dist/utils/importer/import.js +33 -188
  493. package/dist/utils/importer/import.js.map +1 -1
  494. package/dist/utils/importer/master-tables.d.ts +2 -1
  495. package/dist/utils/importer/master-tables.d.ts.map +1 -1
  496. package/dist/utils/importer/master-tables.js +35 -81
  497. package/dist/utils/importer/master-tables.js.map +1 -1
  498. package/dist/utils/param-normalizer.d.ts +0 -1
  499. package/dist/utils/param-normalizer.d.ts.map +1 -1
  500. package/dist/utils/param-normalizer.js +1 -3
  501. package/dist/utils/param-normalizer.js.map +1 -1
  502. package/dist/utils/path-utils.d.ts +46 -0
  503. package/dist/utils/path-utils.d.ts.map +1 -0
  504. package/dist/utils/path-utils.js +74 -0
  505. package/dist/utils/path-utils.js.map +1 -0
  506. package/dist/utils/policy-validator.js +1 -1
  507. package/dist/utils/policy-validator.js.map +1 -1
  508. package/dist/utils/project-context.d.ts +23 -0
  509. package/dist/utils/project-context.d.ts.map +1 -1
  510. package/dist/utils/project-context.js +45 -3
  511. package/dist/utils/project-context.js.map +1 -1
  512. package/dist/utils/project-root.d.ts +2 -2
  513. package/dist/utils/project-root.js +2 -2
  514. package/dist/utils/sql-dump/core/index-export.js +7 -7
  515. package/dist/utils/sql-dump/schema/indexes.js +24 -24
  516. package/dist/utils/sql-dump/schema/tables.js +44 -44
  517. package/dist/utils/suggest-helpers.d.ts +82 -0
  518. package/dist/utils/suggest-helpers.d.ts.map +1 -0
  519. package/dist/utils/suggest-helpers.js +93 -0
  520. package/dist/utils/suggest-helpers.js.map +1 -0
  521. package/dist/utils/token-logging.js +6 -6
  522. package/dist/utils/token-logging.js.map +1 -1
  523. package/dist/utils/validators.js +1 -1
  524. package/dist/utils/validators.js.map +1 -1
  525. package/dist/utils/view-queries.d.ts +0 -8
  526. package/dist/utils/view-queries.d.ts.map +1 -1
  527. package/dist/utils/view-queries.js +29 -84
  528. package/dist/utils/view-queries.js.map +1 -1
  529. package/dist/watcher/index.d.ts +1 -4
  530. package/dist/watcher/index.d.ts.map +1 -1
  531. package/dist/watcher/index.js +1 -3
  532. package/dist/watcher/index.js.map +1 -1
  533. package/dist/watcher/queue-watcher.d.ts +10 -3
  534. package/dist/watcher/queue-watcher.d.ts.map +1 -1
  535. package/dist/watcher/queue-watcher.js +24 -21
  536. package/dist/watcher/queue-watcher.js.map +1 -1
  537. package/docs/CONFIGURATION.md +14 -14
  538. package/docs/DATABASE_AUTH.md +1 -1
  539. package/docs/HOOKS_GUIDE.md +30 -50
  540. package/docs/HOW_TO_UNINSTALL.md +199 -0
  541. package/docs/MIGRATION_CLEANUP_GUIDE.md +212 -0
  542. package/docs/MIGRATION_TO_SAAS.md +176 -0
  543. package/docs/SLASH_COMMANDS.md +1 -1
  544. package/docs/cli/DATABASE_MIGRATION.md +13 -13
  545. package/docs/cli/DATA_EXPORT_IMPORT.md +71 -69
  546. package/package.json +10 -8
  547. package/saas-connector/LICENSE +190 -0
  548. package/saas-connector/README.md +122 -0
  549. package/saas-connector/dist/auth/auth-manager.d.ts +6 -0
  550. package/saas-connector/dist/auth/auth-manager.d.ts.map +1 -0
  551. package/saas-connector/dist/auth/auth-manager.js +39 -0
  552. package/saas-connector/dist/auth/auth-manager.js.map +7 -0
  553. package/saas-connector/dist/backend/saas-backend.d.ts +20 -0
  554. package/saas-connector/dist/backend/saas-backend.d.ts.map +1 -0
  555. package/saas-connector/dist/backend/saas-backend.js +104 -0
  556. package/saas-connector/dist/backend/saas-backend.js.map +7 -0
  557. package/saas-connector/dist/client/http-client.d.ts +33 -0
  558. package/saas-connector/dist/client/http-client.d.ts.map +1 -0
  559. package/saas-connector/dist/client/http-client.js +226 -0
  560. package/saas-connector/dist/client/http-client.js.map +7 -0
  561. package/saas-connector/dist/client/types.d.ts +62 -0
  562. package/saas-connector/dist/client/types.d.ts.map +1 -0
  563. package/saas-connector/dist/client/types.js +17 -0
  564. package/saas-connector/dist/client/types.js.map +7 -0
  565. package/saas-connector/dist/config/constants.d.ts +14 -0
  566. package/saas-connector/dist/config/constants.d.ts.map +1 -0
  567. package/saas-connector/dist/config/constants.js +68 -0
  568. package/saas-connector/dist/config/constants.js.map +7 -0
  569. package/saas-connector/dist/errors/api-error.d.ts +26 -0
  570. package/saas-connector/dist/errors/api-error.d.ts.map +1 -0
  571. package/saas-connector/dist/errors/api-error.js +62 -0
  572. package/saas-connector/dist/errors/api-error.js.map +7 -0
  573. package/saas-connector/dist/index.d.ts +18 -0
  574. package/saas-connector/dist/index.d.ts.map +1 -0
  575. package/saas-connector/dist/index.js +51 -0
  576. package/saas-connector/dist/index.js.map +7 -0
  577. package/saas-connector/package-lock.json +518 -0
  578. package/saas-connector/package.json +34 -0
  579. package/scripts/copy-help-data.js +19 -0
  580. package/assets/config.example.toml +0 -282
  581. package/assets/kanban-style.png +0 -0
  582. package/assets/kanban-visualizer.png +0 -0
  583. package/assets/sample-agents/README.md +0 -36
  584. package/assets/sample-agents/sqlew-architect.md +0 -321
  585. package/assets/sample-agents/sqlew-researcher.md +0 -292
  586. package/assets/sample-agents/sqlew-scrum-master.md +0 -286
  587. package/assets/sample-commands/README.md +0 -56
  588. package/assets/sample-commands/sqlew.md +0 -144
  589. package/assets/sample-skills/sqlew-decision-format/SKILL.md +0 -73
  590. package/assets/sample-skills/sqlew-plan-guidance/SKILL.md +0 -62
  591. package/assets/schema.sql +0 -564
  592. package/dist/cli/hooks/init-hooks.d.ts +0 -35
  593. package/dist/cli/hooks/init-hooks.d.ts.map +0 -1
  594. package/dist/cli/hooks/init-hooks.js +0 -517
  595. package/dist/cli/hooks/init-hooks.js.map +0 -1
  596. package/dist/cli/hooks/plan-toml-parser.d.ts.map +0 -1
  597. package/dist/cli/hooks/plan-toml-parser.js.map +0 -1
  598. package/dist/init-agents.d.ts +0 -7
  599. package/dist/init-agents.d.ts.map +0 -1
  600. package/dist/init-agents.js +0 -206
  601. package/dist/init-agents.js.map +0 -1
  602. package/dist/init-commands.d.ts +0 -10
  603. package/dist/init-commands.d.ts.map +0 -1
  604. package/dist/init-commands.js +0 -46
  605. package/dist/init-commands.js.map +0 -1
  606. package/dist/init-skills.d.ts +0 -25
  607. package/dist/init-skills.d.ts.map +0 -1
  608. package/dist/init-skills.js +0 -160
  609. package/dist/init-skills.js.map +0 -1
  610. package/dist/sync-agents.d.ts +0 -13
  611. package/dist/sync-agents.d.ts.map +0 -1
  612. package/dist/sync-agents.js +0 -157
  613. package/dist/sync-agents.js.map +0 -1
  614. package/dist/sync-commands.d.ts +0 -13
  615. package/dist/sync-commands.d.ts.map +0 -1
  616. package/dist/sync-commands.js +0 -150
  617. package/dist/sync-commands.js.map +0 -1
  618. package/dist/sync-gitignore.d.ts +0 -13
  619. package/dist/sync-gitignore.d.ts.map +0 -1
  620. package/dist/sync-gitignore.js +0 -60
  621. package/dist/sync-gitignore.js.map +0 -1
  622. package/dist/tests/docker/native/task-operations.test.d.ts +0 -16
  623. package/dist/tests/docker/native/task-operations.test.d.ts.map +0 -1
  624. package/dist/tests/docker/native/task-operations.test.js +0 -800
  625. package/dist/tests/docker/native/task-operations.test.js.map +0 -1
  626. package/dist/tests/feature/decision/batch-validation-integration.test.d.ts +0 -6
  627. package/dist/tests/feature/decision/batch-validation-integration.test.d.ts.map +0 -1
  628. package/dist/tests/feature/decision/batch-validation-integration.test.js +0 -193
  629. package/dist/tests/feature/decision/batch-validation-integration.test.js.map +0 -1
  630. package/dist/tests/feature/task/auto-pruning-decision-link.test.d.ts +0 -6
  631. package/dist/tests/feature/task/auto-pruning-decision-link.test.d.ts.map +0 -1
  632. package/dist/tests/feature/task/auto-pruning-decision-link.test.js +0 -281
  633. package/dist/tests/feature/task/auto-pruning-decision-link.test.js.map +0 -1
  634. package/dist/tests/feature/task/auto-pruning-partial.test.d.ts +0 -6
  635. package/dist/tests/feature/task/auto-pruning-partial.test.d.ts.map +0 -1
  636. package/dist/tests/feature/task/auto-pruning-partial.test.js +0 -305
  637. package/dist/tests/feature/task/auto-pruning-partial.test.js.map +0 -1
  638. package/dist/tests/feature/task/auto-pruning-persistence.test.d.ts +0 -6
  639. package/dist/tests/feature/task/auto-pruning-persistence.test.d.ts.map +0 -1
  640. package/dist/tests/feature/task/auto-pruning-persistence.test.js +0 -267
  641. package/dist/tests/feature/task/auto-pruning-persistence.test.js.map +0 -1
  642. package/dist/tests/feature/task/auto-pruning-safety.test.d.ts +0 -12
  643. package/dist/tests/feature/task/auto-pruning-safety.test.d.ts.map +0 -1
  644. package/dist/tests/feature/task/auto-pruning-safety.test.js +0 -224
  645. package/dist/tests/feature/task/auto-pruning-safety.test.js.map +0 -1
  646. package/dist/tests/feature/task/dependencies.test.d.ts +0 -7
  647. package/dist/tests/feature/task/dependencies.test.d.ts.map +0 -1
  648. package/dist/tests/feature/task/dependencies.test.js +0 -656
  649. package/dist/tests/feature/task/dependencies.test.js.map +0 -1
  650. package/dist/tests/feature/task/file-actions-integration.test.d.ts +0 -10
  651. package/dist/tests/feature/task/file-actions-integration.test.d.ts.map +0 -1
  652. package/dist/tests/feature/task/file-actions-integration.test.js +0 -162
  653. package/dist/tests/feature/task/file-actions-integration.test.js.map +0 -1
  654. package/dist/tests/feature/task/file-actions-validation.test.d.ts +0 -6
  655. package/dist/tests/feature/task/file-actions-validation.test.d.ts.map +0 -1
  656. package/dist/tests/feature/task/file-actions-validation.test.js +0 -228
  657. package/dist/tests/feature/task/file-actions-validation.test.js.map +0 -1
  658. package/dist/tests/feature/task/link-file-backward-compat.test.d.ts +0 -6
  659. package/dist/tests/feature/task/link-file-backward-compat.test.d.ts.map +0 -1
  660. package/dist/tests/feature/task/link-file-backward-compat.test.js +0 -280
  661. package/dist/tests/feature/task/link-file-backward-compat.test.js.map +0 -1
  662. package/dist/tests/feature/task/watch-files-action.test.d.ts +0 -8
  663. package/dist/tests/feature/task/watch-files-action.test.d.ts.map +0 -1
  664. package/dist/tests/feature/task/watch-files-action.test.js +0 -402
  665. package/dist/tests/feature/task/watch-files-action.test.js.map +0 -1
  666. package/dist/tests/feature/task/watch-files-parameter.test.d.ts +0 -8
  667. package/dist/tests/feature/task/watch-files-parameter.test.d.ts.map +0 -1
  668. package/dist/tests/feature/task/watch-files-parameter.test.js +0 -283
  669. package/dist/tests/feature/task/watch-files-parameter.test.js.map +0 -1
  670. package/dist/tests/integration/all-features.standalone.d.ts +0 -7
  671. package/dist/tests/integration/all-features.standalone.d.ts.map +0 -1
  672. package/dist/tests/integration/all-features.standalone.js +0 -417
  673. package/dist/tests/integration/all-features.standalone.js.map +0 -1
  674. package/dist/tests/unit/config/plan-toml-cache.test.d.ts.map +0 -1
  675. package/dist/tests/unit/config/plan-toml-cache.test.js.map +0 -1
  676. package/dist/tests/unit/hooks/plan-toml-parser.test.d.ts.map +0 -1
  677. package/dist/tests/unit/hooks/plan-toml-parser.test.js.map +0 -1
  678. package/dist/tools/files/actions/check-lock.d.ts +0 -16
  679. package/dist/tools/files/actions/check-lock.d.ts.map +0 -1
  680. package/dist/tools/files/actions/check-lock.js +0 -74
  681. package/dist/tools/files/actions/check-lock.js.map +0 -1
  682. package/dist/tools/files/actions/get.d.ts +0 -16
  683. package/dist/tools/files/actions/get.d.ts.map +0 -1
  684. package/dist/tools/files/actions/get.js +0 -85
  685. package/dist/tools/files/actions/get.js.map +0 -1
  686. package/dist/tools/files/actions/record-batch.d.ts +0 -18
  687. package/dist/tools/files/actions/record-batch.d.ts.map +0 -1
  688. package/dist/tools/files/actions/record-batch.js +0 -119
  689. package/dist/tools/files/actions/record-batch.js.map +0 -1
  690. package/dist/tools/files/actions/record.d.ts +0 -16
  691. package/dist/tools/files/actions/record.d.ts.map +0 -1
  692. package/dist/tools/files/actions/record.js +0 -43
  693. package/dist/tools/files/actions/record.js.map +0 -1
  694. package/dist/tools/files/actions/sqlite-flush.d.ts +0 -27
  695. package/dist/tools/files/actions/sqlite-flush.d.ts.map +0 -1
  696. package/dist/tools/files/actions/sqlite-flush.js +0 -66
  697. package/dist/tools/files/actions/sqlite-flush.js.map +0 -1
  698. package/dist/tools/files/help/example.d.ts +0 -5
  699. package/dist/tools/files/help/example.d.ts.map +0 -1
  700. package/dist/tools/files/help/example.js +0 -98
  701. package/dist/tools/files/help/example.js.map +0 -1
  702. package/dist/tools/files/help/help.d.ts +0 -5
  703. package/dist/tools/files/help/help.d.ts.map +0 -1
  704. package/dist/tools/files/help/help.js +0 -24
  705. package/dist/tools/files/help/help.js.map +0 -1
  706. package/dist/tools/files/index.d.ts +0 -14
  707. package/dist/tools/files/index.d.ts.map +0 -1
  708. package/dist/tools/files/index.js +0 -15
  709. package/dist/tools/files/index.js.map +0 -1
  710. package/dist/tools/files/internal/queries.d.ts +0 -18
  711. package/dist/tools/files/internal/queries.d.ts.map +0 -1
  712. package/dist/tools/files/internal/queries.js +0 -54
  713. package/dist/tools/files/internal/queries.js.map +0 -1
  714. package/dist/tools/files/internal/validation.d.ts +0 -18
  715. package/dist/tools/files/internal/validation.d.ts.map +0 -1
  716. package/dist/tools/files/internal/validation.js +0 -39
  717. package/dist/tools/files/internal/validation.js.map +0 -1
  718. package/dist/tools/files/types.d.ts +0 -6
  719. package/dist/tools/files/types.d.ts.map +0 -1
  720. package/dist/tools/files/types.js +0 -6
  721. package/dist/tools/files/types.js.map +0 -1
  722. package/dist/tools/help-queries.d.ts +0 -130
  723. package/dist/tools/help-queries.d.ts.map +0 -1
  724. package/dist/tools/help-queries.js +0 -411
  725. package/dist/tools/help-queries.js.map +0 -1
  726. package/dist/tools/tasks/actions/add-dependency.d.ts +0 -12
  727. package/dist/tools/tasks/actions/add-dependency.d.ts.map +0 -1
  728. package/dist/tools/tasks/actions/add-dependency.js +0 -129
  729. package/dist/tools/tasks/actions/add-dependency.js.map +0 -1
  730. package/dist/tools/tasks/actions/archive.d.ts +0 -11
  731. package/dist/tools/tasks/actions/archive.d.ts.map +0 -1
  732. package/dist/tools/tasks/actions/archive.js +0 -58
  733. package/dist/tools/tasks/actions/archive.js.map +0 -1
  734. package/dist/tools/tasks/actions/create-batch.d.ts +0 -19
  735. package/dist/tools/tasks/actions/create-batch.d.ts.map +0 -1
  736. package/dist/tools/tasks/actions/create-batch.js +0 -103
  737. package/dist/tools/tasks/actions/create-batch.js.map +0 -1
  738. package/dist/tools/tasks/actions/create.d.ts +0 -16
  739. package/dist/tools/tasks/actions/create.d.ts.map +0 -1
  740. package/dist/tools/tasks/actions/create.js +0 -163
  741. package/dist/tools/tasks/actions/create.js.map +0 -1
  742. package/dist/tools/tasks/actions/get-dependencies.d.ts +0 -12
  743. package/dist/tools/tasks/actions/get-dependencies.d.ts.map +0 -1
  744. package/dist/tools/tasks/actions/get-dependencies.js +0 -41
  745. package/dist/tools/tasks/actions/get-dependencies.js.map +0 -1
  746. package/dist/tools/tasks/actions/get-pruned-files.d.ts +0 -13
  747. package/dist/tools/tasks/actions/get-pruned-files.d.ts.map +0 -1
  748. package/dist/tools/tasks/actions/get-pruned-files.js +0 -45
  749. package/dist/tools/tasks/actions/get-pruned-files.js.map +0 -1
  750. package/dist/tools/tasks/actions/get.d.ts +0 -12
  751. package/dist/tools/tasks/actions/get.d.ts.map +0 -1
  752. package/dist/tools/tasks/actions/get.js +0 -84
  753. package/dist/tools/tasks/actions/get.js.map +0 -1
  754. package/dist/tools/tasks/actions/link-pruned-file.d.ts +0 -14
  755. package/dist/tools/tasks/actions/link-pruned-file.d.ts.map +0 -1
  756. package/dist/tools/tasks/actions/link-pruned-file.js +0 -68
  757. package/dist/tools/tasks/actions/link-pruned-file.js.map +0 -1
  758. package/dist/tools/tasks/actions/link.d.ts +0 -14
  759. package/dist/tools/tasks/actions/link.d.ts.map +0 -1
  760. package/dist/tools/tasks/actions/link.js +0 -120
  761. package/dist/tools/tasks/actions/link.js.map +0 -1
  762. package/dist/tools/tasks/actions/list.d.ts +0 -17
  763. package/dist/tools/tasks/actions/list.d.ts.map +0 -1
  764. package/dist/tools/tasks/actions/list.js +0 -100
  765. package/dist/tools/tasks/actions/list.js.map +0 -1
  766. package/dist/tools/tasks/actions/move.d.ts +0 -13
  767. package/dist/tools/tasks/actions/move.d.ts.map +0 -1
  768. package/dist/tools/tasks/actions/move.js +0 -91
  769. package/dist/tools/tasks/actions/move.js.map +0 -1
  770. package/dist/tools/tasks/actions/remove-dependency.d.ts +0 -12
  771. package/dist/tools/tasks/actions/remove-dependency.d.ts.map +0 -1
  772. package/dist/tools/tasks/actions/remove-dependency.js +0 -36
  773. package/dist/tools/tasks/actions/remove-dependency.js.map +0 -1
  774. package/dist/tools/tasks/actions/update.d.ts +0 -10
  775. package/dist/tools/tasks/actions/update.d.ts.map +0 -1
  776. package/dist/tools/tasks/actions/update.js +0 -183
  777. package/dist/tools/tasks/actions/update.js.map +0 -1
  778. package/dist/tools/tasks/actions/watch-files.d.ts +0 -14
  779. package/dist/tools/tasks/actions/watch-files.d.ts.map +0 -1
  780. package/dist/tools/tasks/actions/watch-files.js +0 -127
  781. package/dist/tools/tasks/actions/watch-files.js.map +0 -1
  782. package/dist/tools/tasks/help/example.d.ts +0 -8
  783. package/dist/tools/tasks/help/example.d.ts.map +0 -1
  784. package/dist/tools/tasks/help/example.js +0 -225
  785. package/dist/tools/tasks/help/example.js.map +0 -1
  786. package/dist/tools/tasks/help/help.d.ts +0 -8
  787. package/dist/tools/tasks/help/help.d.ts.map +0 -1
  788. package/dist/tools/tasks/help/help.js +0 -307
  789. package/dist/tools/tasks/help/help.js.map +0 -1
  790. package/dist/tools/tasks/help/use-case.d.ts +0 -11
  791. package/dist/tools/tasks/help/use-case.d.ts.map +0 -1
  792. package/dist/tools/tasks/help/use-case.js +0 -767
  793. package/dist/tools/tasks/help/use-case.js.map +0 -1
  794. package/dist/tools/tasks/index.d.ts +0 -28
  795. package/dist/tools/tasks/index.d.ts.map +0 -1
  796. package/dist/tools/tasks/index.js +0 -33
  797. package/dist/tools/tasks/index.js.map +0 -1
  798. package/dist/tools/tasks/internal/state-machine.d.ts +0 -16
  799. package/dist/tools/tasks/internal/state-machine.d.ts.map +0 -1
  800. package/dist/tools/tasks/internal/state-machine.js +0 -36
  801. package/dist/tools/tasks/internal/state-machine.js.map +0 -1
  802. package/dist/tools/tasks/internal/task-queries.d.ts +0 -12
  803. package/dist/tools/tasks/internal/task-queries.d.ts.map +0 -1
  804. package/dist/tools/tasks/internal/task-queries.js +0 -53
  805. package/dist/tools/tasks/internal/task-queries.js.map +0 -1
  806. package/dist/tools/tasks/internal/validation.d.ts +0 -47
  807. package/dist/tools/tasks/internal/validation.d.ts.map +0 -1
  808. package/dist/tools/tasks/internal/validation.js +0 -261
  809. package/dist/tools/tasks/internal/validation.js.map +0 -1
  810. package/dist/tools/tasks/types.d.ts +0 -80
  811. package/dist/tools/tasks/types.d.ts.map +0 -1
  812. package/dist/tools/tasks/types.js +0 -68
  813. package/dist/tools/tasks/types.js.map +0 -1
  814. package/dist/tools/tasks/watcher/status.d.ts +0 -9
  815. package/dist/tools/tasks/watcher/status.d.ts.map +0 -1
  816. package/dist/tools/tasks/watcher/status.js +0 -130
  817. package/dist/tools/tasks/watcher/status.js.map +0 -1
  818. package/dist/tools/tasks.d.ts +0 -16
  819. package/dist/tools/tasks.d.ts.map +0 -1
  820. package/dist/tools/tasks.js +0 -17
  821. package/dist/tools/tasks.js.map +0 -1
  822. package/dist/utils/action-specs/file-specs.d.ts +0 -9
  823. package/dist/utils/action-specs/file-specs.d.ts.map +0 -1
  824. package/dist/utils/action-specs/file-specs.js +0 -54
  825. package/dist/utils/action-specs/file-specs.js.map +0 -1
  826. package/dist/utils/action-specs/task-specs.d.ts +0 -9
  827. package/dist/utils/action-specs/task-specs.d.ts.map +0 -1
  828. package/dist/utils/action-specs/task-specs.js +0 -143
  829. package/dist/utils/action-specs/task-specs.js.map +0 -1
  830. package/dist/utils/cleanup.d.ts +0 -69
  831. package/dist/utils/cleanup.d.ts.map +0 -1
  832. package/dist/utils/cleanup.js +0 -102
  833. package/dist/utils/cleanup.js.map +0 -1
  834. package/dist/utils/file-pruning.d.ts +0 -93
  835. package/dist/utils/file-pruning.d.ts.map +0 -1
  836. package/dist/utils/file-pruning.js +0 -194
  837. package/dist/utils/file-pruning.js.map +0 -1
  838. package/dist/utils/importer/topological-sort.d.ts +0 -61
  839. package/dist/utils/importer/topological-sort.d.ts.map +0 -1
  840. package/dist/utils/importer/topological-sort.js +0 -143
  841. package/dist/utils/importer/topological-sort.js.map +0 -1
  842. package/dist/utils/retention.d.ts +0 -65
  843. package/dist/utils/retention.d.ts.map +0 -1
  844. package/dist/utils/retention.js +0 -156
  845. package/dist/utils/retention.js.map +0 -1
  846. package/dist/utils/task-stale-detection.d.ts +0 -98
  847. package/dist/utils/task-stale-detection.d.ts.map +0 -1
  848. package/dist/utils/task-stale-detection.js +0 -479
  849. package/dist/utils/task-stale-detection.js.map +0 -1
  850. package/dist/watcher/file-watcher.d.ts +0 -131
  851. package/dist/watcher/file-watcher.d.ts.map +0 -1
  852. package/dist/watcher/file-watcher.js +0 -730
  853. package/dist/watcher/file-watcher.js.map +0 -1
  854. package/dist/watcher/test-executor.d.ts +0 -23
  855. package/dist/watcher/test-executor.d.ts.map +0 -1
  856. package/dist/watcher/test-executor.js +0 -226
  857. package/dist/watcher/test-executor.js.map +0 -1
  858. package/docs/TASK_SYSTEM_DEPRECATED.md +0 -88
package/README.md CHANGED
@@ -1,269 +1,338 @@
1
- # sqlew
2
- ![sqlew_logo](assets/sqlew-logo.png)
3
-
4
- [![npm version](https://img.shields.io/npm/v/sqlew.svg)](https://www.npmjs.com/package/sqlew)
5
- [![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
6
-
7
- > **ADR (Architecture Decision Record) for AI Agents** – An MCP server that enables AI agents to create, query, and maintain architecture decision records in a structured SQL database
8
-
9
- ## 🚀 Quick Start
10
-
11
- ### 1. Install globally (Recommended)
12
-
13
- ```bash
14
- npm install -g sqlew
15
- ```
16
-
17
- ### 2. Add to your MCP config
18
-
19
- Add to `.mcp.json` in your project root:
20
-
21
- ```json
22
- {
23
- "mcpServers": {
24
- "sqlew": {
25
- "command": "sqlew"
26
- }
27
- }
28
- }
29
- ```
30
-
31
- ### 3. Initialize project
32
-
33
- ```bash
34
- sqlew --init
35
- ```
36
-
37
- This one-shot command sets up:
38
- - Claude Code Skills
39
- - CLAUDE.md integration hints
40
- - Plan-to-ADR hooks
41
- - .gitignore entries
42
-
43
- ### 4. Just use Plan Mode!
44
-
45
- **That's it!** Now every time you:
46
- 1. Create a plan in Claude Code
47
- 2. Get user approval (ExitPlanMode)
48
-
49
- Your architectural decisions are **automatically recorded** as ADR knowledge.
50
-
51
- No special commands needed. Just plan your work normally, and sqlew captures the decisions in the background.
52
-
53
- ### Optional: /sqlew command
54
-
55
- For manual queries and explicit decision recording:
56
-
57
- ```bash
58
- /sqlew # Show status
59
- /sqlew search auth # Search past decisions
60
- /sqlew record use Redis # Record a decision manually
61
- ```
62
-
63
- ---
64
-
65
- ## What is sqlew?
66
-
67
- **sqlew** is a Model Context Protocol (MCP) server that brings ADR (Architecture Decision Record) capabilities to AI agents through a shared SQL-backed repository.
68
-
69
- ### The Problem: AI Agents Lack Decision Memory
70
- Every AI session starts with zero context. Agents must re-learn architectural decisions, can reintroduce previously rejected patterns, and have no systematic way to understand WHY past choices were made.
71
-
72
- Traditional ADR approaches use Markdown files scattered across repositories. While human-readable, this format creates challenges for AI agents:
73
- - **No structured querying** AI must read entire files to find relevant decisions
74
- - **Context explosion** – Token costs grow linearly with decision history
75
- - **No duplicate detection** AI cannot easily identify similar or conflicting decisions
76
- - **Poor discoverability** Finding related decisions requires full-text search across many files
77
-
78
- ### *sqlew* brings structured ADR to AI agents
79
- sqlew transforms ADR from static documentation into a **queryable, AI-native decision database**:
80
-
81
- - **Structured records** Decisions stored as relational data with metadata, tags, and relationships
82
- - **Efficient querying** – AI agents retrieve only relevant decisions via SQL queries
83
- - **Smart suggestions** Three-tier similarity system detects duplicate or related decisions
84
- - **Constraint tracking** – Architectural rules and principles as first-class entities
85
- - **Auto-capture** Claude Code Hooks automatically record decisions from Plan Mode
86
-
87
- > *This software does not send any data to external networks. We NEVER collect any data or usage statistics. Please use it with complete security.*
88
-
89
- ## Why sqlew?
90
-
91
- AI agents automatically accumulate project knowledge through Plan Mode. Decisions are stored in SQL for efficient querying.
92
-
93
- **Perfect for:**
94
- - 🏢 Large-scale projects with many architectural decisions
95
- - 🔧 Long-term maintenance where context must persist across sessions
96
- - 👥 Team environments where multiple AI agents share knowledge
97
-
98
- **Key benefits:**
99
- - **60-75% token reduction** vs reading Markdown ADRs
100
- - 🔍 **Millisecond queries** (2-50ms) even with thousands of decisions
101
- - 🛡️ **Duplicate prevention** via similarity detection
102
- - 📚 **Persistent memory** across all AI sessions
103
-
104
- See [ADR Concepts](docs/ADR_CONCEPTS.md) for detailed architecture.
105
-
106
- ---
107
-
108
- **Technical Features**: 6 MCP tools (3 core: decision, constraint, suggest + 3 utility: help, example, use_case), three-tier similarity detection (0-100 point scoring), ACID transaction support, multi-database backend (SQLite/PostgreSQL/MySQL), metadata-driven organization with layers and tags
109
-
110
-
111
- ## Installation
112
-
113
- ### Requirements
114
- - Node.js 20.0.0 or higher
115
- - npm or npx
116
-
117
- ### Recommended: Global Install
118
-
119
- ```bash
120
- npm install -g sqlew
121
- ```
122
-
123
- > **Why global install?** Claude Code Hooks call `sqlew` directly from shell. Global install ensures hooks work correctly without npx overhead.
124
-
125
- Then add to `.mcp.json` in your project root:
126
-
127
- ```json
128
- {
129
- "mcpServers": {
130
- "sqlew": {
131
- "command": "sqlew"
132
- }
133
- }
134
- }
135
- ```
136
-
137
- ### Alternative: npx (Not Recommended)
138
-
139
- **⚠️ Not recommended**: npx usage prevents Claude Code Hooks from working, disabling Plan-to-ADR automatic decision capture. Use global install instead.
140
-
141
- **Note**: First run initializes the database. Restart Claude Code to load the MCP server.
142
-
143
- Each project maintains its own context database in `.sqlew/sqlew.db`.
144
-
145
- **Custom database path:** Add path as argument: `"args": ["sqlew", "/path/to/db.db"]`
146
- **Default location:** `.sqlew/sqlew.db`
147
-
148
- ## Configuration
149
-
150
- sqlew supports multiple database backends:
151
-
152
- | Database | Use Case | Status |
153
- |----------|----------|--------|
154
- | **SQLite** | Personal/small projects | ✅ Default |
155
- | **MySQL 8.0+ / MariaDB 10+** | Production, team sharing | ✅ Supported |
156
- | **PostgreSQL 12+** | Production, team sharing | ✅ Supported |
157
-
158
- Configuration is managed via `.sqlew/config.toml` file and CLI arguments.
159
-
160
- **[Full Configuration Guide](docs/CONFIGURATION.md)** - All options, database setup, validation rules
161
-
162
- ## Documentation
163
-
164
- Each tool supports `action: "help"` for full documentation and `action: "example"` for comprehensive usage examples.
165
-
166
- And `action: "use_case"` shows how to use the tool in a real-world scenario.
167
-
168
- ### On-Demand Documentation
169
-
170
- All tools support:
171
- - `action: "help"` - Parameter reference and descriptions
172
- - `action: "example"` - Usage scenarios and examples
173
- - `action: "use_case"` - Real-world usage examples
174
-
175
- ### For AI Agents
176
-
177
- **Essential Guides:**
178
-
179
- **Advanced Features:**
180
- - [Hooks Guide](docs/HOOKS_GUIDE.md) - Claude Code Hooks integration
181
- - [Cross Database](docs/CROSS_DATABASE.md) - Multi-database support
182
-
183
- **Reference:**
184
- - [Configuration](docs/CONFIGURATION.md) - Config file setup, all options
185
-
186
- ### Advanced Usage
187
-
188
- - [Configuration Guide](docs/CONFIGURATION.md) - TOML config file setup
189
- - [CLI Mode Overview](docs/cli/README.md) - Database migration, export/import commands
190
- - [Migration Guides](docs/MIGRATION_v2.md) - Version upgrade guides
191
-
192
- ## Use Cases
193
-
194
- ### ADR-Driven Development with AI
195
- - **Architecture Evolution** Document major architectural decisions with full context and alternatives
196
- - **Pattern Standardization** – Establish coding patterns as constraints, enforce via AI code generation
197
- - **Technical Debt Tracking** Record temporary decisions with deprecation paths and future plans
198
- - **Onboarding Acceleration** – New AI sessions instantly understand architectural history
199
-
200
- ### Cross-Session AI Workflows
201
- - **Multi-Session Projects** AI maintains context across days/weeks without re-reading documentation
202
- - **Multi-Agent Coordination** – Multiple AI agents share architectural understanding through ADR database
203
- - **Breaking Change Management** Document API changes, deprecations, and migration paths systematically
204
- - **Refactoring Guidance** – AI references past decisions to maintain architectural consistency during refactors
205
-
206
- ### Real-World Examples
207
- ```bash
208
- # Document an architectural decision with alternatives
209
- /sqlew record we use PostgreSQL over MongoDB. MongoDB was rejected due to lack of ACID transactions for our financial data requirements.
210
-
211
- # Search for past decisions before making new ones
212
- /sqlew search why did we choose JWT authentication
213
-
214
- # Create constraint to guide AI code generation
215
- /sqlew add constraint all API endpoints must use /v2/ prefix for versioning
216
-
217
- # Plan implementation of a decision
218
- /sqlew plan implementing the PostgreSQL connection pool with pgBouncer
219
- ```
220
-
221
-
222
- ## Performance
223
-
224
- - **Query speed**: 2-50ms
225
- - **Concurrent agents**: 5+ simultaneous
226
- - **Storage efficiency**: ~140 bytes per decision
227
- - **Token savings**: 60-75% in typical projects
228
-
229
- ## Support
230
-
231
- Support development via [GitHub Sponsors](https://github.com/sponsors/sin5ddd) - One-time or monthly options available.
232
-
233
- ## Version
234
-
235
- Current version: **4.3.0**
236
- See [CHANGELOG.md](CHANGELOG.md) for release history.
237
-
238
- **What's New in v4.3.0:**
239
- - **Plan-to-ADR** - Automatic Architecture Decision Records from Claude Code Plan Mode
240
- - **Markdown Pattern Extraction** - 📌 Decision / 🚫 Constraint markers auto-detected
241
- - **One-shot Setup** - `sqlew --init` initializes everything (Skills, Hooks, gitignore)
242
- - **Parameter Aliases** - Simplified tool usage with intuitive parameter names
243
-
244
- See [docs/HOOKS_GUIDE.md](docs/HOOKS_GUIDE.md) for Claude Code Hooks details.
245
-
246
- ## License
247
-
248
- Apache License 2.0 - Free for commercial and personal use. See [LICENSE](LICENSE) for details.
249
-
250
- ## Links
251
-
252
- - [npm package](https://www.npmjs.com/package/sqlew)
253
- - [GitHub repository](https://github.com/sin5ddd/mcp-sqlew)
254
- - [Model Context Protocol](https://modelcontextprotocol.io/)
255
-
256
- ## Support & Documentation
257
-
258
- - Issues: [GitHub Issues](https://github.com/sin5ddd/mcp-sqlew/issues)
259
- - Docs: [docs/](docs/) directory
260
-
261
- ## Acknowledgments
262
-
263
- Built with [Model Context Protocol SDK](https://github.com/modelcontextprotocol/sdk), [better-sqlite3](https://github.com/WiseLibs/better-sqlite3), and TypeScript.
264
-
265
- **Author**: sin5ddd
266
-
267
- ---
268
-
269
- <!-- Git Hooks Integration Test: 2025-12-22 - This line tests post-merge hook triggering mark-done --auto -->
1
+ # sqlew
2
+
3
+ ![sqlew_logo](assets/sqlew-logo.png)
4
+
5
+ [![npm version](https://img.shields.io/npm/v/sqlew.svg)](https://www.npmjs.com/package/sqlew)
6
+ [![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
7
+
8
+ > **ADR (Architecture Decision Record) for AI Agents** – An MCP server that enables AI agents to create, query, and maintain architecture decision records in a structured SQL database
9
+
10
+ ## 🚀 Quick Start
11
+
12
+ ### 1. Install MCP Server
13
+
14
+ ```bash
15
+ npm install -g sqlew
16
+ ```
17
+
18
+ ### 2. Install Plugin (Recommended)
19
+
20
+ In Claude Code, run the following commands:
21
+
22
+ ```bash
23
+ # 1. Add the marketplace
24
+ /plugin marketplace add sqlew-io/sqlew-plugin
25
+
26
+ # 2. Install the plugin (user-level recommended)
27
+ /plugin install sqlew-plugin
28
+
29
+ # 3. Restart Claude Code to apply changes
30
+ ```
31
+
32
+ **That's it!** The plugin automatically sets up everything:
33
+
34
+ - ✅ MCP server config (`.mcp.json`)
35
+ - ✅ Claude Code Skills (Plan Mode guidance)
36
+ - ✅ Claude Code Hooks (automatic decision capture)
37
+
38
+ > **Note:** Global Rules are automatically created at `~/.claude/rules/sqlew/` when the MCP server starts.
39
+
40
+ ### 3. Connect to sqlew.io (For Teams) 🌐
41
+
42
+ **NEW in v5.0.0**: Connect to the cloud for team-shared decisions!
43
+
44
+ **Step 1: Get your API key** (one-time setup)
45
+
46
+ Visit [sqlew.io](https://sqlew.io) and save your API key:
47
+
48
+ ```bash
49
+ # ~/.sqlew.env (shared across all projects)
50
+ SQLEW_API_KEY=your-api-key
51
+ ```
52
+
53
+ **Step 2: Configure each project**
54
+
55
+ ```toml
56
+ # .sqlew/config.toml (per-project)
57
+ [database]
58
+ type = "cloud"
59
+
60
+ [project]
61
+ name = "your-project-name"
62
+ ```
63
+
64
+ > **Note:** Each project needs its own `.sqlew/config.toml` to specify the project name.
65
+
66
+ **Benefits:**
67
+ - 👥 **Team sharing** - All team members share the same decision database
68
+ - 🌳 **Git worktree ready** - Works seamlessly with multiple branches
69
+ - **Zero setup** - No local database required
70
+
71
+ ### Alternative: Local Database (Offline)
72
+
73
+ For offline or single-developer use, **no setup required**:
74
+
75
+ - Database (`.sqlew/sqlew.db`) is auto-created on first MCP server start
76
+ - Config file (`.sqlew/config.toml`) is auto-generated with detected project name
77
+ - Global rules (`~/.claude/rules/sqlew/`) are auto-installed
78
+
79
+ Just start using Claude Code - everything initializes automatically!
80
+
81
+ ### 4. Just use Plan Mode!
82
+
83
+ **That's it!** Now every time you:
84
+
85
+ 1. Create a plan in Claude Code
86
+ 2. Get user approval (ExitPlanMode)
87
+
88
+ → Your architectural decisions are **automatically recorded** as ADR knowledge.
89
+
90
+ No special commands needed. Just plan your work normally, and sqlew captures the decisions in the background.
91
+
92
+ ### Optional: /sqlew command
93
+
94
+ For manual queries and explicit decision recording:
95
+
96
+ ```bash
97
+ /sqlew # Show status
98
+ /sqlew search auth # Search past decisions
99
+ /sqlew record use Redis # Record a decision manually
100
+ ```
101
+
102
+ ---
103
+
104
+ ## What is sqlew?
105
+
106
+ **sqlew** is a Model Context Protocol (MCP) server that brings ADR (Architecture Decision Record) capabilities to AI agents through a shared SQL-backed repository.
107
+
108
+ ### The Problem: AI Agents Lack Decision Memory
109
+
110
+ Every AI session starts with zero context. Agents must re-learn architectural decisions, can reintroduce previously rejected patterns, and have no systematic way to understand WHY past choices were made.
111
+
112
+ Traditional ADR approaches use Markdown files scattered across repositories. While human-readable, this format creates challenges for AI agents:
113
+
114
+ - **No structured querying** – AI must read entire files to find relevant decisions
115
+ - **Context explosion** – Token costs grow linearly with decision history
116
+ - **No duplicate detection** – AI cannot easily identify similar or conflicting decisions
117
+ - **Poor discoverability** – Finding related decisions requires full-text search across many files
118
+
119
+ ### _sqlew_ brings structured ADR to AI agents
120
+
121
+ sqlew transforms ADR from static documentation into a **queryable, AI-native decision database**:
122
+
123
+ - **Structured records** Decisions stored as relational data with metadata, tags, and relationships
124
+ - **Efficient querying** – AI agents retrieve only relevant decisions via SQL queries
125
+ - **Smart suggestions** Three-tier similarity system detects duplicate or related decisions
126
+ - **Constraint tracking** – Architectural rules and principles as first-class entities
127
+ - **Auto-capture** – Claude Code Hooks automatically record decisions from Plan Mode
128
+
129
+ > _This software does not send any data to external networks. We NEVER collect any data or usage statistics. Please use it with complete security._
130
+
131
+ ## Why sqlew?
132
+
133
+ AI agents automatically accumulate project knowledge through Plan Mode. Decisions are stored in SQL for efficient querying.
134
+
135
+ ### 🌐 Team Development Made Easy (NEW in v5.0.0)
136
+
137
+ - **Shared decision database** - All team members see the same architectural decisions
138
+ - **Multiple AI agents** - Work simultaneously without conflicts
139
+ - **No local setup** - Just add your API key and start
140
+
141
+ ### 🌳 Perfect for Git Worktree Workflows
142
+
143
+ - **Automatic worktree detection** - Each worktree shares the same context
144
+ - **Config inheritance** - Main repository settings apply everywhere
145
+ - **Independent sessions** - Each worktree has its own cache
146
+
147
+ **Perfect for:**
148
+
149
+ - 🏢 Large-scale projects with many architectural decisions
150
+ - 🔧 Long-term maintenance where context must persist across sessions
151
+ - 👥 **Team environments** where multiple AI agents share knowledge
152
+ - 🌳 **Git worktree** workflows with multiple concurrent branches
153
+
154
+ **Key benefits:**
155
+
156
+ - **60-75% token reduction** vs reading Markdown ADRs
157
+ - 🔍 **Millisecond queries** (2-50ms) even with thousands of decisions
158
+ - 🛡️ **Duplicate prevention** via similarity detection
159
+ - 📚 **Persistent memory** across all AI sessions
160
+ - 👥 **Team sync** via sqlew.io cloud backend
161
+
162
+ See [ADR Concepts](docs/ADR_CONCEPTS.md) for detailed architecture.
163
+
164
+ ---
165
+
166
+ **Technical Features**: 7 MCP tools (3 core: decision, constraint, suggest + 4 utility: help, example, use_case, queue), three-tier similarity detection (0-100 point scoring), ACID transaction support, multi-database backend (SQLite/PostgreSQL/MySQL/Cloud), metadata-driven organization with layers and tags
167
+
168
+ ## Installation
169
+
170
+ ### Requirements
171
+
172
+ - Node.js 20.0.0 or higher
173
+ - npm or npx
174
+
175
+ ### Recommended: Global Install
176
+
177
+ ```bash
178
+ npm install -g sqlew
179
+ ```
180
+
181
+ > **Why global install?** Claude Code Hooks call `sqlew` directly from shell. Global install ensures hooks work correctly without npx overhead.
182
+
183
+ Then add to `.mcp.json` in your project root:
184
+
185
+ ```json
186
+ {
187
+ "mcpServers": {
188
+ "sqlew": {
189
+ "command": "sqlew"
190
+ }
191
+ }
192
+ }
193
+ ```
194
+
195
+ ### Alternative: npx (Not Recommended)
196
+
197
+ **⚠️ Not recommended**: npx usage prevents Claude Code Hooks from working, disabling Plan-to-ADR automatic decision capture. Use global install instead.
198
+
199
+ **Note**: First run initializes the database. Restart Claude Code to load the MCP server.
200
+
201
+ Each project maintains its own context database in `.sqlew/sqlew.db`.
202
+
203
+ **Custom database path:** Add path as argument: `"args": ["sqlew", "/path/to/db.db"]`
204
+ **Default location:** `.sqlew/sqlew.db`
205
+
206
+ ## Configuration
207
+
208
+ sqlew supports multiple database backends:
209
+
210
+ | Database | Use Case | Status |
211
+ | ---------------------------- | ------------------------ | ------------ |
212
+ | **SQLite** | Personal/small projects | Default |
213
+ | **MySQL 8.0+ / MariaDB 10+** | Production, team sharing | ✅ Supported |
214
+ | **PostgreSQL 12+** | Production, team sharing | ✅ Supported |
215
+
216
+ Configuration is managed via `.sqlew/config.toml` file and CLI arguments.
217
+
218
+ → **[Full Configuration Guide](docs/CONFIGURATION.md)** - All options, database setup, validation rules
219
+
220
+ ## Documentation
221
+
222
+ Each tool supports `action: "help"` for full documentation and `action: "example"` for comprehensive usage examples.
223
+
224
+ And `action: "use_case"` shows how to use the tool in a real-world scenario.
225
+
226
+ ### On-Demand Documentation
227
+
228
+ All tools support:
229
+
230
+ - `action: "help"` - Parameter reference and descriptions
231
+ - `action: "example"` - Usage scenarios and examples
232
+ - `action: "use_case"` - Real-world usage examples
233
+
234
+ ### For AI Agents
235
+
236
+ **Essential Guides:**
237
+
238
+ **Advanced Features:**
239
+
240
+ - [Hooks Guide](docs/HOOKS_GUIDE.md) - Claude Code Hooks integration
241
+ - [Cross Database](docs/CROSS_DATABASE.md) - Multi-database support
242
+
243
+ **Reference:**
244
+
245
+ - [Configuration](docs/CONFIGURATION.md) - Config file setup, all options
246
+
247
+ ### Advanced Usage
248
+
249
+ - [Configuration Guide](docs/CONFIGURATION.md) - TOML config file setup
250
+ - [CLI Mode Overview](docs/cli/README.md) - Database migration, export/import commands
251
+
252
+ ### Upgrade Guides
253
+
254
+ - **[Upgrade from v4 to v5](docs/MIGRATION_CLEANUP_GUIDE.md)** - Cleanup legacy files after plugin migration
255
+ - **[Migrating Local Data to SaaS](docs/MIGRATION_TO_SAAS.md)** - Export local v3.x/v4.x data to sqlew.io cloud
256
+ - [Migration from v2](docs/MIGRATION_v2.md) - Version upgrade guides
257
+
258
+ ## Use Cases
259
+
260
+ ### ADR-Driven Development with AI
261
+
262
+ - **Architecture Evolution** – Document major architectural decisions with full context and alternatives
263
+ - **Pattern Standardization** Establish coding patterns as constraints, enforce via AI code generation
264
+ - **Technical Debt Tracking** – Record temporary decisions with deprecation paths and future plans
265
+ - **Onboarding Acceleration** – New AI sessions instantly understand architectural history
266
+
267
+ ### Cross-Session AI Workflows
268
+
269
+ - **Multi-Session Projects** AI maintains context across days/weeks without re-reading documentation
270
+ - **Multi-Agent Coordination** – Multiple AI agents share architectural understanding through ADR database
271
+ - **Breaking Change Management** – Document API changes, deprecations, and migration paths systematically
272
+ - **Refactoring Guidance** – AI references past decisions to maintain architectural consistency during refactors
273
+
274
+ ### Real-World Examples
275
+
276
+ ```bash
277
+ # Document an architectural decision with alternatives
278
+ /sqlew record we use PostgreSQL over MongoDB. MongoDB was rejected due to lack of ACID transactions for our financial data requirements.
279
+
280
+ # Search for past decisions before making new ones
281
+ /sqlew search why did we choose JWT authentication
282
+
283
+ # Create constraint to guide AI code generation
284
+ /sqlew add constraint all API endpoints must use /v2/ prefix for versioning
285
+
286
+ # Plan implementation of a decision
287
+ /sqlew plan implementing the PostgreSQL connection pool with pgBouncer
288
+ ```
289
+
290
+ ## Performance
291
+
292
+ - **Query speed**: 2-50ms
293
+ - **Concurrent agents**: 5+ simultaneous
294
+ - **Storage efficiency**: ~140 bytes per decision
295
+ - **Token savings**: 60-75% in typical projects
296
+
297
+ ## Support
298
+
299
+ Support development via [GitHub Sponsors](https://github.com/sponsors/sqlew-io) - One-time or monthly options available.
300
+
301
+ ## Version
302
+
303
+ Current version: **5.0.0**
304
+ See [CHANGELOG.md](CHANGELOG.md) for release history.
305
+
306
+ **What's New in v5.0.0:**
307
+
308
+ - 🌐 **SaaS Backend** - Connect to [sqlew.io](https://sqlew.io) for team-shared decisions
309
+ - 🌳 **Git Worktree Support** - Seamless multi-branch development
310
+ - 🔌 **Plugin-first Architecture** - Simplified setup via sqlew-plugin
311
+ - 🔧 **Queue Tool** - Hook queue management (list, remove, clear)
312
+
313
+ See [docs/HOOKS_GUIDE.md](docs/HOOKS_GUIDE.md) for Claude Code Hooks details.
314
+
315
+ ## License
316
+
317
+ Apache License 2.0 - Free for commercial and personal use. See [LICENSE](LICENSE) for details.
318
+
319
+ ## Links
320
+
321
+ - [npm package](https://www.npmjs.com/package/sqlew)
322
+ - [GitHub repository](https://github.com/sqlew-io/sqlew)
323
+ - [Model Context Protocol](https://modelcontextprotocol.io/)
324
+
325
+ ## Support & Documentation
326
+
327
+ - Issues: [GitHub Issues](https://github.com/sqlew-io/sqlew/issues)
328
+ - Docs: [docs/](docs/) directory
329
+
330
+ ## Acknowledgments
331
+
332
+ Built with [Model Context Protocol SDK](https://github.com/modelcontextprotocol/sdk), [better-sqlite3](https://github.com/WiseLibs/better-sqlite3), and TypeScript.
333
+
334
+ **Author**: sqlew-io
335
+
336
+ ---
337
+
338
+ <!-- Git Hooks Integration Test: 2025-12-22 - This line tests post-merge hook triggering mark-done --auto -->