sqlew 3.8.1 → 3.9.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 (881) hide show
  1. package/CHANGELOG.md +155 -285
  2. package/README.md +150 -32
  3. package/assets/sample-agents/sqlew-architect.md +72 -17
  4. package/assets/sample-agents/sqlew-researcher.md +62 -1
  5. package/assets/sample-agents/sqlew-scrum-master.md +5 -1
  6. package/assets/sample-commands/README.md +57 -0
  7. package/assets/sample-commands/sqw-documentor.md +158 -0
  8. package/assets/sample-commands/sqw-plan.md +301 -0
  9. package/assets/sample-commands/sqw-research.md +298 -0
  10. package/assets/sample-commands/sqw-review.md +340 -0
  11. package/assets/sample-commands/sqw-scrum.md +423 -0
  12. package/assets/sample-commands/sqw-secretary.md +187 -0
  13. package/dist/adapters/sqlite-adapter.d.ts +0 -6
  14. package/dist/adapters/sqlite-adapter.d.ts.map +1 -1
  15. package/dist/adapters/sqlite-adapter.js +10 -14
  16. package/dist/adapters/sqlite-adapter.js.map +1 -1
  17. package/dist/cli/db-dump.d.ts +1 -1
  18. package/dist/cli/db-dump.d.ts.map +1 -1
  19. package/dist/cli/db-dump.js +1 -1
  20. package/dist/cli/db-dump.js.map +1 -1
  21. package/dist/config/knex/bootstrap/20251025021352_fix_mysql_index_syntax.d.ts +4 -0
  22. package/dist/config/knex/bootstrap/20251025021352_fix_mysql_index_syntax.d.ts.map +1 -0
  23. package/dist/config/knex/bootstrap/20251025021352_fix_mysql_index_syntax.js +146 -0
  24. package/dist/config/knex/bootstrap/20251025021352_fix_mysql_index_syntax.js.map +1 -0
  25. package/dist/config/knex/enhancements/20251112000001_fix_task_file_links_schema_v3_9_0.d.ts +22 -0
  26. package/dist/config/knex/enhancements/20251112000001_fix_task_file_links_schema_v3_9_0.d.ts.map +1 -0
  27. package/dist/config/knex/enhancements/20251112000001_fix_task_file_links_schema_v3_9_0.js +106 -0
  28. package/dist/config/knex/enhancements/20251112000001_fix_task_file_links_schema_v3_9_0.js.map +1 -0
  29. package/dist/config/knex/enhancements/20251112000002_fix_task_pruned_files_schema_v3_9_0.d.ts +21 -0
  30. package/dist/config/knex/enhancements/20251112000002_fix_task_pruned_files_schema_v3_9_0.d.ts.map +1 -0
  31. package/dist/config/knex/enhancements/20251112000002_fix_task_pruned_files_schema_v3_9_0.js +106 -0
  32. package/dist/config/knex/enhancements/20251112000002_fix_task_pruned_files_schema_v3_9_0.js.map +1 -0
  33. package/dist/config/knex/enhancements/20251114000000_fix_v_tagged_decisions_numeric_support.d.ts +21 -0
  34. package/dist/config/knex/enhancements/20251114000000_fix_v_tagged_decisions_numeric_support.d.ts.map +1 -0
  35. package/dist/config/knex/enhancements/20251114000000_fix_v_tagged_decisions_numeric_support.js +91 -0
  36. package/dist/config/knex/enhancements/20251114000000_fix_v_tagged_decisions_numeric_support.js.map +1 -0
  37. package/dist/config/knex/enhancements/20251114120000_add_suggest_tool_to_help_system_v3_9_0.d.ts +15 -0
  38. package/dist/config/knex/enhancements/20251114120000_add_suggest_tool_to_help_system_v3_9_0.d.ts.map +1 -0
  39. package/dist/config/knex/enhancements/20251114120000_add_suggest_tool_to_help_system_v3_9_0.js +270 -0
  40. package/dist/config/knex/enhancements/20251114120000_add_suggest_tool_to_help_system_v3_9_0.js.map +1 -0
  41. package/dist/config/knex/enhancements/20251114121000_add_suggest_tool_use_cases_v3_9_0.d.ts +15 -0
  42. package/dist/config/knex/enhancements/20251114121000_add_suggest_tool_use_cases_v3_9_0.d.ts.map +1 -0
  43. package/dist/config/knex/enhancements/20251114121000_add_suggest_tool_use_cases_v3_9_0.js +241 -0
  44. package/dist/config/knex/enhancements/20251114121000_add_suggest_tool_use_cases_v3_9_0.js.map +1 -0
  45. package/dist/config/knex/enhancements/20251114130000_seed_builtin_policies_v3_9_0.d.ts +16 -0
  46. package/dist/config/knex/enhancements/20251114130000_seed_builtin_policies_v3_9_0.d.ts.map +1 -0
  47. package/dist/config/knex/enhancements/20251114130000_seed_builtin_policies_v3_9_0.js +168 -0
  48. package/dist/config/knex/enhancements/20251114130000_seed_builtin_policies_v3_9_0.js.map +1 -0
  49. package/dist/config/knex/enhancements/20251114140000_add_policy_help_v3_9_0.d.ts +14 -0
  50. package/dist/config/knex/enhancements/20251114140000_add_policy_help_v3_9_0.d.ts.map +1 -0
  51. package/dist/config/knex/enhancements/20251114140000_add_policy_help_v3_9_0.js +228 -0
  52. package/dist/config/knex/enhancements/20251114140000_add_policy_help_v3_9_0.js.map +1 -0
  53. package/dist/config/knex/enhancements/20251114141000_add_policy_use_cases_v3_9_0.d.ts +14 -0
  54. package/dist/config/knex/enhancements/20251114141000_add_policy_use_cases_v3_9_0.d.ts.map +1 -0
  55. package/dist/config/knex/enhancements/20251114141000_add_policy_use_cases_v3_9_0.js +237 -0
  56. package/dist/config/knex/enhancements/20251114141000_add_policy_use_cases_v3_9_0.js.map +1 -0
  57. package/dist/config/knex/enhancements/20251114150000_fix_policy_unique_constraint_v3_9_0.d.ts +14 -0
  58. package/dist/config/knex/enhancements/20251114150000_fix_policy_unique_constraint_v3_9_0.d.ts.map +1 -0
  59. package/dist/config/knex/enhancements/20251114150000_fix_policy_unique_constraint_v3_9_0.js +61 -0
  60. package/dist/config/knex/enhancements/20251114150000_fix_policy_unique_constraint_v3_9_0.js.map +1 -0
  61. package/dist/config/knex/enhancements/20251115000000_fix_task_decision_links_unique_constraint.d.ts +21 -0
  62. package/dist/config/knex/enhancements/20251115000000_fix_task_decision_links_unique_constraint.d.ts.map +1 -0
  63. package/dist/config/knex/enhancements/20251115000000_fix_task_decision_links_unique_constraint.js +127 -0
  64. package/dist/config/knex/enhancements/20251115000000_fix_task_decision_links_unique_constraint.js.map +1 -0
  65. package/dist/config/knex/enhancements/20251115100000_fix_read_keyword_index_v3_9_0.d.ts +15 -0
  66. package/dist/config/knex/enhancements/20251115100000_fix_read_keyword_index_v3_9_0.d.ts.map +1 -0
  67. package/dist/config/knex/enhancements/20251115100000_fix_read_keyword_index_v3_9_0.js +69 -0
  68. package/dist/config/knex/enhancements/20251115100000_fix_read_keyword_index_v3_9_0.js.map +1 -0
  69. package/dist/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.d.ts +15 -0
  70. package/dist/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.d.ts.map +1 -0
  71. package/dist/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.js +132 -0
  72. package/dist/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.js.map +1 -0
  73. package/dist/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts +18 -0
  74. package/dist/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts.map +1 -0
  75. package/dist/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.js +47 -0
  76. package/dist/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.js.map +1 -0
  77. package/dist/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.d.ts +20 -0
  78. package/dist/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.d.ts.map +1 -0
  79. package/dist/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.js +119 -0
  80. package/dist/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.js.map +1 -0
  81. package/dist/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts +19 -0
  82. package/dist/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts.map +1 -0
  83. package/dist/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.js +196 -0
  84. package/dist/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.js.map +1 -0
  85. package/dist/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.d.ts +22 -0
  86. package/dist/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.d.ts.map +1 -0
  87. package/dist/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.js +375 -0
  88. package/dist/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.js.map +1 -0
  89. package/dist/config/loader.d.ts.map +1 -1
  90. package/dist/config/loader.js +4 -0
  91. package/dist/config/loader.js.map +1 -1
  92. package/dist/config/minimal-generator.d.ts.map +1 -1
  93. package/dist/config/minimal-generator.js +34 -0
  94. package/dist/config/minimal-generator.js.map +1 -1
  95. package/dist/config/types.d.ts +19 -0
  96. package/dist/config/types.d.ts.map +1 -1
  97. package/dist/config/types.js +8 -0
  98. package/dist/config/types.js.map +1 -1
  99. package/dist/constants.d.ts +30 -0
  100. package/dist/constants.d.ts.map +1 -1
  101. package/dist/constants.js +33 -0
  102. package/dist/constants.js.map +1 -1
  103. package/dist/database/initialization/cleanup.d.ts +1 -1
  104. package/dist/database/initialization/cleanup.d.ts.map +1 -1
  105. package/dist/database/initialization/cleanup.js +15 -1
  106. package/dist/database/initialization/cleanup.js.map +1 -1
  107. package/dist/database/initialization/init.d.ts.map +1 -1
  108. package/dist/database/initialization/init.js +3 -0
  109. package/dist/database/initialization/init.js.map +1 -1
  110. package/dist/database/migrations/20251024010000_upgrade_v1_0_to_v1_1.d.ts +16 -0
  111. package/dist/database/migrations/20251024010000_upgrade_v1_0_to_v1_1.d.ts.map +1 -0
  112. package/dist/database/migrations/20251024010000_upgrade_v1_0_to_v1_1.js +84 -0
  113. package/dist/database/migrations/20251024010000_upgrade_v1_0_to_v1_1.js.map +1 -0
  114. package/dist/database/migrations/20251024020000_upgrade_v2_0_to_v2_1.d.ts +14 -0
  115. package/dist/database/migrations/20251024020000_upgrade_v2_0_to_v2_1.d.ts.map +1 -0
  116. package/dist/database/migrations/20251024020000_upgrade_v2_0_to_v2_1.js +42 -0
  117. package/dist/database/migrations/20251024020000_upgrade_v2_0_to_v2_1.js.map +1 -0
  118. package/dist/database/migrations/20251024030000_upgrade_v2_1_to_v3_0.d.ts +17 -0
  119. package/dist/database/migrations/20251024030000_upgrade_v2_1_to_v3_0.d.ts.map +1 -0
  120. package/dist/database/migrations/20251024030000_upgrade_v2_1_to_v3_0.js +122 -0
  121. package/dist/database/migrations/20251024030000_upgrade_v2_1_to_v3_0.js.map +1 -0
  122. package/dist/database/migrations/20251024040000_upgrade_v3_0_to_v3_2.d.ts +12 -0
  123. package/dist/database/migrations/20251024040000_upgrade_v3_0_to_v3_2.d.ts.map +1 -0
  124. package/dist/database/migrations/20251024040000_upgrade_v3_0_to_v3_2.js +49 -0
  125. package/dist/database/migrations/20251024040000_upgrade_v3_0_to_v3_2.js.map +1 -0
  126. package/dist/database/migrations/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts +12 -0
  127. package/dist/database/migrations/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts.map +1 -0
  128. package/dist/database/migrations/20251024050000_upgrade_v3_2_0_to_v3_2_2.js +53 -0
  129. package/dist/database/migrations/20251024050000_upgrade_v3_2_0_to_v3_2_2.js.map +1 -0
  130. package/dist/database/migrations/20251024060000_upgrade_v3_4_to_v3_5.d.ts +12 -0
  131. package/dist/database/migrations/20251024060000_upgrade_v3_4_to_v3_5.d.ts.map +1 -0
  132. package/dist/database/migrations/20251024060000_upgrade_v3_4_to_v3_5.js +44 -0
  133. package/dist/database/migrations/20251024060000_upgrade_v3_4_to_v3_5.js.map +1 -0
  134. package/dist/database/migrations/20251024070000_upgrade_v3_5_to_v3_6.d.ts +13 -0
  135. package/dist/database/migrations/20251024070000_upgrade_v3_5_to_v3_6.d.ts.map +1 -0
  136. package/dist/database/migrations/20251024070000_upgrade_v3_5_to_v3_6.js +33 -0
  137. package/dist/database/migrations/20251024070000_upgrade_v3_5_to_v3_6.js.map +1 -0
  138. package/dist/database/migrations/20251025020452_create_master_tables_wrapper.d.ts +17 -0
  139. package/dist/database/migrations/20251025020452_create_master_tables_wrapper.d.ts.map +1 -0
  140. package/dist/database/migrations/20251025020452_create_master_tables_wrapper.js +119 -0
  141. package/dist/database/migrations/20251025020452_create_master_tables_wrapper.js.map +1 -0
  142. package/dist/database/migrations/20251025021152_create_transaction_tables_wrapper.d.ts +15 -0
  143. package/dist/database/migrations/20251025021152_create_transaction_tables_wrapper.d.ts.map +1 -0
  144. package/dist/database/migrations/20251025021152_create_transaction_tables_wrapper.js +282 -0
  145. package/dist/database/migrations/20251025021152_create_transaction_tables_wrapper.js.map +1 -0
  146. package/dist/database/migrations/20251025021351_create_indexes_wrapper.d.ts +21 -0
  147. package/dist/database/migrations/20251025021351_create_indexes_wrapper.d.ts.map +1 -0
  148. package/dist/database/migrations/20251025021351_create_indexes_wrapper.js +83 -0
  149. package/dist/database/migrations/20251025021351_create_indexes_wrapper.js.map +1 -0
  150. package/dist/database/migrations/20251025021352_fix_mysql_index_syntax_wrapper.d.ts +22 -0
  151. package/dist/database/migrations/20251025021352_fix_mysql_index_syntax_wrapper.d.ts.map +1 -0
  152. package/dist/database/migrations/20251025021352_fix_mysql_index_syntax_wrapper.js +94 -0
  153. package/dist/database/migrations/20251025021352_fix_mysql_index_syntax_wrapper.js.map +1 -0
  154. package/dist/database/migrations/20251025021416_seed_master_data_wrapper.d.ts +19 -0
  155. package/dist/database/migrations/20251025021416_seed_master_data_wrapper.d.ts.map +1 -0
  156. package/dist/database/migrations/20251025021416_seed_master_data_wrapper.js +120 -0
  157. package/dist/database/migrations/20251025021416_seed_master_data_wrapper.js.map +1 -0
  158. package/dist/database/migrations/20251025070349_create_views_wrapper.d.ts +14 -0
  159. package/dist/database/migrations/20251025070349_create_views_wrapper.d.ts.map +1 -0
  160. package/dist/database/migrations/20251025070349_create_views_wrapper.js +160 -0
  161. package/dist/database/migrations/20251025070349_create_views_wrapper.js.map +1 -0
  162. package/dist/database/migrations/20251025081221_add_link_type_to_task_decision_links.d.ts +9 -0
  163. package/dist/database/migrations/20251025081221_add_link_type_to_task_decision_links.d.ts.map +1 -0
  164. package/dist/database/migrations/20251025081221_add_link_type_to_task_decision_links.js +21 -0
  165. package/dist/database/migrations/20251025081221_add_link_type_to_task_decision_links.js.map +1 -0
  166. package/dist/database/migrations/20251025082220_fix_task_dependencies_columns.d.ts +13 -0
  167. package/dist/database/migrations/20251025082220_fix_task_dependencies_columns.d.ts.map +1 -0
  168. package/dist/database/migrations/20251025082220_fix_task_dependencies_columns.js +17 -0
  169. package/dist/database/migrations/20251025082220_fix_task_dependencies_columns.js.map +1 -0
  170. package/dist/database/migrations/20251025090000_create_help_system_tables.d.ts +27 -0
  171. package/dist/database/migrations/20251025090000_create_help_system_tables.d.ts.map +1 -0
  172. package/dist/database/migrations/20251025090000_create_help_system_tables.js +120 -0
  173. package/dist/database/migrations/20251025090000_create_help_system_tables.js.map +1 -0
  174. package/dist/database/migrations/20251025090100_seed_help_categories_and_use_cases.d.ts +18 -0
  175. package/dist/database/migrations/20251025090100_seed_help_categories_and_use_cases.d.ts.map +1 -0
  176. package/dist/database/migrations/20251025090100_seed_help_categories_and_use_cases.js +388 -0
  177. package/dist/database/migrations/20251025090100_seed_help_categories_and_use_cases.js.map +1 -0
  178. package/dist/database/migrations/20251025100000_seed_help_metadata.d.ts +20 -0
  179. package/dist/database/migrations/20251025100000_seed_help_metadata.d.ts.map +1 -0
  180. package/dist/database/migrations/20251025100000_seed_help_metadata.js +264 -0
  181. package/dist/database/migrations/20251025100000_seed_help_metadata.js.map +1 -0
  182. package/dist/database/migrations/20251025100100_seed_remaining_use_cases.d.ts +21 -0
  183. package/dist/database/migrations/20251025100100_seed_remaining_use_cases.d.ts.map +1 -0
  184. package/dist/database/migrations/20251025100100_seed_remaining_use_cases.js +281 -0
  185. package/dist/database/migrations/20251025100100_seed_remaining_use_cases.js.map +1 -0
  186. package/dist/database/migrations/20251025120000_add_cascade_to_task_dependencies.d.ts +13 -0
  187. package/dist/database/migrations/20251025120000_add_cascade_to_task_dependencies.d.ts.map +1 -0
  188. package/dist/database/migrations/20251025120000_add_cascade_to_task_dependencies.js +76 -0
  189. package/dist/database/migrations/20251025120000_add_cascade_to_task_dependencies.js.map +1 -0
  190. package/dist/database/migrations/20251027000000_add_agent_reuse_system.d.ts +17 -0
  191. package/dist/database/migrations/20251027000000_add_agent_reuse_system.d.ts.map +1 -0
  192. package/dist/database/migrations/20251027000000_add_agent_reuse_system.js +42 -0
  193. package/dist/database/migrations/20251027000000_add_agent_reuse_system.js.map +1 -0
  194. package/dist/database/migrations/20251027010000_add_task_constraint_to_decision_context.d.ts +10 -0
  195. package/dist/database/migrations/20251027010000_add_task_constraint_to_decision_context.d.ts.map +1 -0
  196. package/dist/database/migrations/20251027010000_add_task_constraint_to_decision_context.js +28 -0
  197. package/dist/database/migrations/20251027010000_add_task_constraint_to_decision_context.js.map +1 -0
  198. package/dist/database/migrations/20251027020000_update_agent_reusability.d.ts +21 -0
  199. package/dist/database/migrations/20251027020000_update_agent_reusability.d.ts.map +1 -0
  200. package/dist/database/migrations/20251027020000_update_agent_reusability.js +38 -0
  201. package/dist/database/migrations/20251027020000_update_agent_reusability.js.map +1 -0
  202. package/dist/database/migrations/20251028000000_simplify_agent_system.d.ts +26 -0
  203. package/dist/database/migrations/20251028000000_simplify_agent_system.d.ts.map +1 -0
  204. package/dist/database/migrations/20251028000000_simplify_agent_system.js +56 -0
  205. package/dist/database/migrations/20251028000000_simplify_agent_system.js.map +1 -0
  206. package/dist/database/migrations/20251031000000_drop_orphaned_message_view.d.ts +16 -0
  207. package/dist/database/migrations/20251031000000_drop_orphaned_message_view.d.ts.map +1 -0
  208. package/dist/database/migrations/20251031000000_drop_orphaned_message_view.js +52 -0
  209. package/dist/database/migrations/20251031000000_drop_orphaned_message_view.js.map +1 -0
  210. package/dist/database/migrations/20251104000000_add_multi_project_v3_7_0.d.ts +56 -0
  211. package/dist/database/migrations/20251104000000_add_multi_project_v3_7_0.d.ts.map +1 -0
  212. package/dist/database/migrations/20251104000000_add_multi_project_v3_7_0.js +701 -0
  213. package/dist/database/migrations/20251104000000_add_multi_project_v3_7_0.js.map +1 -0
  214. package/dist/database/migrations/20251104000003_rename_constraints_created_by_to_agent_id.d.ts +30 -0
  215. package/dist/database/migrations/20251104000003_rename_constraints_created_by_to_agent_id.d.ts.map +1 -0
  216. package/dist/database/migrations/20251104000003_rename_constraints_created_by_to_agent_id.js +180 -0
  217. package/dist/database/migrations/20251104000003_rename_constraints_created_by_to_agent_id.js.map +1 -0
  218. package/dist/database/migrations/20251105000000_add_token_usage_table.d.ts +19 -0
  219. package/dist/database/migrations/20251105000000_add_token_usage_table.d.ts.map +1 -0
  220. package/dist/database/migrations/20251105000000_add_token_usage_table.js +47 -0
  221. package/dist/database/migrations/20251105000000_add_token_usage_table.js.map +1 -0
  222. package/dist/database/migrations/20251105000001_rename_decision_context_decided_by_to_agent_id.d.ts +28 -0
  223. package/dist/database/migrations/20251105000001_rename_decision_context_decided_by_to_agent_id.d.ts.map +1 -0
  224. package/dist/database/migrations/20251105000001_rename_decision_context_decided_by_to_agent_id.js +123 -0
  225. package/dist/database/migrations/20251105000001_rename_decision_context_decided_by_to_agent_id.js.map +1 -0
  226. package/dist/database/migrations/20251106000000_fix_master_tables_project_id_v3_7_3.d.ts +36 -0
  227. package/dist/database/migrations/20251106000000_fix_master_tables_project_id_v3_7_3.d.ts.map +1 -0
  228. package/dist/database/migrations/20251106000000_fix_master_tables_project_id_v3_7_3.js +559 -0
  229. package/dist/database/migrations/20251106000000_fix_master_tables_project_id_v3_7_3.js.map +1 -0
  230. package/dist/database/migrations/20251108000000_add_planning_layers_v3_8_0.d.ts +26 -0
  231. package/dist/database/migrations/20251108000000_add_planning_layers_v3_8_0.d.ts.map +1 -0
  232. package/dist/database/migrations/20251108000000_add_planning_layers_v3_8_0.js +78 -0
  233. package/dist/database/migrations/20251108000000_add_planning_layers_v3_8_0.js.map +1 -0
  234. package/dist/database/migrations/20251108000000_hotfix_v_tagged_constraints_project_id.d.ts +17 -0
  235. package/dist/database/migrations/20251108000000_hotfix_v_tagged_constraints_project_id.d.ts.map +1 -0
  236. package/dist/database/migrations/20251108000000_hotfix_v_tagged_constraints_project_id.js +78 -0
  237. package/dist/database/migrations/20251108000000_hotfix_v_tagged_constraints_project_id.js.map +1 -0
  238. package/dist/database/migrations/20251109000000_fix_task_file_links_unique_constraint_v3_8_0.d.ts +24 -0
  239. package/dist/database/migrations/20251109000000_fix_task_file_links_unique_constraint_v3_8_0.d.ts.map +1 -0
  240. package/dist/database/migrations/20251109000000_fix_task_file_links_unique_constraint_v3_8_0.js +63 -0
  241. package/dist/database/migrations/20251109000000_fix_task_file_links_unique_constraint_v3_8_0.js.map +1 -0
  242. package/dist/database/migrations/20251109000002_multi_project_cross_db_compat_v3_7_5.d.ts +27 -0
  243. package/dist/database/migrations/20251109000002_multi_project_cross_db_compat_v3_7_5.d.ts.map +1 -0
  244. package/dist/database/migrations/20251109000002_multi_project_cross_db_compat_v3_7_5.js +276 -0
  245. package/dist/database/migrations/20251109000002_multi_project_cross_db_compat_v3_7_5.js.map +1 -0
  246. package/dist/database/migrations/20251109000003_token_usage_cross_db_compat_v3_7_5.d.ts +27 -0
  247. package/dist/database/migrations/20251109000003_token_usage_cross_db_compat_v3_7_5.d.ts.map +1 -0
  248. package/dist/database/migrations/20251109000003_token_usage_cross_db_compat_v3_7_5.js +67 -0
  249. package/dist/database/migrations/20251109000003_token_usage_cross_db_compat_v3_7_5.js.map +1 -0
  250. package/dist/database/migrations/20251109010000_tool_cleanup_v3_8_0.d.ts +32 -0
  251. package/dist/database/migrations/20251109010000_tool_cleanup_v3_8_0.d.ts.map +1 -0
  252. package/dist/database/migrations/20251109010000_tool_cleanup_v3_8_0.js +352 -0
  253. package/dist/database/migrations/20251109010000_tool_cleanup_v3_8_0.js.map +1 -0
  254. package/dist/database/migrations/20251109020000_fix_missing_help_actions_v3_8_0.d.ts +35 -0
  255. package/dist/database/migrations/20251109020000_fix_missing_help_actions_v3_8_0.d.ts.map +1 -0
  256. package/dist/database/migrations/20251109020000_fix_missing_help_actions_v3_8_0.js +237 -0
  257. package/dist/database/migrations/20251109020000_fix_missing_help_actions_v3_8_0.js.map +1 -0
  258. package/dist/database/migrations/20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts +22 -0
  259. package/dist/database/migrations/20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts.map +1 -0
  260. package/dist/database/migrations/20251111235959_preemptive_fix_cross_database_v3_9_0.js +190 -0
  261. package/dist/database/migrations/20251111235959_preemptive_fix_cross_database_v3_9_0.js.map +1 -0
  262. package/dist/database/migrations/20251112000000_decision_intelligence_v3_9_0.d.ts +32 -0
  263. package/dist/database/migrations/20251112000000_decision_intelligence_v3_9_0.d.ts.map +1 -0
  264. package/dist/database/migrations/20251112000000_decision_intelligence_v3_9_0.js +342 -0
  265. package/dist/database/migrations/20251112000000_decision_intelligence_v3_9_0.js.map +1 -0
  266. package/dist/database/migrations/20251112000001_fix_task_file_links_schema_v3_9_0.d.ts +25 -0
  267. package/dist/database/migrations/20251112000001_fix_task_file_links_schema_v3_9_0.d.ts.map +1 -0
  268. package/dist/database/migrations/20251112000001_fix_task_file_links_schema_v3_9_0.js +109 -0
  269. package/dist/database/migrations/20251112000001_fix_task_file_links_schema_v3_9_0.js.map +1 -0
  270. package/dist/database/migrations/20251112000002_fix_task_pruned_files_schema_v3_9_0.d.ts +24 -0
  271. package/dist/database/migrations/20251112000002_fix_task_pruned_files_schema_v3_9_0.d.ts.map +1 -0
  272. package/dist/database/migrations/20251112000002_fix_task_pruned_files_schema_v3_9_0.js +111 -0
  273. package/dist/database/migrations/20251112000002_fix_task_pruned_files_schema_v3_9_0.js.map +1 -0
  274. package/dist/database/migrations/20251114000000_fix_v_tagged_decisions_numeric_support.d.ts +24 -0
  275. package/dist/database/migrations/20251114000000_fix_v_tagged_decisions_numeric_support.d.ts.map +1 -0
  276. package/dist/database/migrations/20251114000000_fix_v_tagged_decisions_numeric_support.js +90 -0
  277. package/dist/database/migrations/20251114000000_fix_v_tagged_decisions_numeric_support.js.map +1 -0
  278. package/dist/database/migrations/20251114120000_add_suggest_tool_to_help_system_v3_9_0.d.ts +20 -0
  279. package/dist/database/migrations/20251114120000_add_suggest_tool_to_help_system_v3_9_0.d.ts.map +1 -0
  280. package/dist/database/migrations/20251114120000_add_suggest_tool_to_help_system_v3_9_0.js +275 -0
  281. package/dist/database/migrations/20251114120000_add_suggest_tool_to_help_system_v3_9_0.js.map +1 -0
  282. package/dist/database/migrations/20251114121000_add_suggest_tool_use_cases_v3_9_0.d.ts +20 -0
  283. package/dist/database/migrations/20251114121000_add_suggest_tool_use_cases_v3_9_0.d.ts.map +1 -0
  284. package/dist/database/migrations/20251114121000_add_suggest_tool_use_cases_v3_9_0.js +246 -0
  285. package/dist/database/migrations/20251114121000_add_suggest_tool_use_cases_v3_9_0.js.map +1 -0
  286. package/dist/database/migrations/20251114130000_seed_builtin_policies_v3_9_0.d.ts +23 -0
  287. package/dist/database/migrations/20251114130000_seed_builtin_policies_v3_9_0.d.ts.map +1 -0
  288. package/dist/database/migrations/20251114130000_seed_builtin_policies_v3_9_0.js +175 -0
  289. package/dist/database/migrations/20251114130000_seed_builtin_policies_v3_9_0.js.map +1 -0
  290. package/dist/database/migrations/20251114140000_add_policy_help_v3_9_0.d.ts +21 -0
  291. package/dist/database/migrations/20251114140000_add_policy_help_v3_9_0.d.ts.map +1 -0
  292. package/dist/database/migrations/20251114140000_add_policy_help_v3_9_0.js +235 -0
  293. package/dist/database/migrations/20251114140000_add_policy_help_v3_9_0.js.map +1 -0
  294. package/dist/database/migrations/20251114141000_add_policy_use_cases_v3_9_0.d.ts +21 -0
  295. package/dist/database/migrations/20251114141000_add_policy_use_cases_v3_9_0.d.ts.map +1 -0
  296. package/dist/database/migrations/20251114141000_add_policy_use_cases_v3_9_0.js +244 -0
  297. package/dist/database/migrations/20251114141000_add_policy_use_cases_v3_9_0.js.map +1 -0
  298. package/dist/database/migrations/20251114150000_fix_policy_unique_constraint_v3_9_0.d.ts +23 -0
  299. package/dist/database/migrations/20251114150000_fix_policy_unique_constraint_v3_9_0.d.ts.map +1 -0
  300. package/dist/database/migrations/20251114150000_fix_policy_unique_constraint_v3_9_0.js +70 -0
  301. package/dist/database/migrations/20251114150000_fix_policy_unique_constraint_v3_9_0.js.map +1 -0
  302. package/dist/database/migrations/20251115000000_fix_task_decision_links_unique_constraint.d.ts +29 -0
  303. package/dist/database/migrations/20251115000000_fix_task_decision_links_unique_constraint.d.ts.map +1 -0
  304. package/dist/database/migrations/20251115000000_fix_task_decision_links_unique_constraint.js +135 -0
  305. package/dist/database/migrations/20251115000000_fix_task_decision_links_unique_constraint.js.map +1 -0
  306. package/dist/database/migrations/20251115100000_fix_read_keyword_index_v3_9_0.d.ts +23 -0
  307. package/dist/database/migrations/20251115100000_fix_read_keyword_index_v3_9_0.d.ts.map +1 -0
  308. package/dist/database/migrations/20251115100000_fix_read_keyword_index_v3_9_0.js +42 -0
  309. package/dist/database/migrations/20251115100000_fix_read_keyword_index_v3_9_0.js.map +1 -0
  310. package/dist/database/migrations/20251115110000_fix_cross_database_timestamps_v3_9_0.d.ts +25 -0
  311. package/dist/database/migrations/20251115110000_fix_cross_database_timestamps_v3_9_0.d.ts.map +1 -0
  312. package/dist/database/migrations/20251115110000_fix_cross_database_timestamps_v3_9_0.js +102 -0
  313. package/dist/database/migrations/20251115110000_fix_cross_database_timestamps_v3_9_0.js.map +1 -0
  314. package/dist/database/migrations/20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts +25 -0
  315. package/dist/database/migrations/20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts.map +1 -0
  316. package/dist/database/migrations/20251115120000_fix_all_cross_db_issues_v3_9_0.js +55 -0
  317. package/dist/database/migrations/20251115120000_fix_all_cross_db_issues_v3_9_0.js.map +1 -0
  318. package/dist/database/migrations/20251118000000_eliminate_views_v3_9_0.d.ts +29 -0
  319. package/dist/database/migrations/20251118000000_eliminate_views_v3_9_0.d.ts.map +1 -0
  320. package/dist/database/migrations/20251118000000_eliminate_views_v3_9_0.js +62 -0
  321. package/dist/database/migrations/20251118000000_eliminate_views_v3_9_0.js.map +1 -0
  322. package/dist/database/migrations/20251119000000_add_constraint_text_hash_v3_9_1.d.ts +25 -0
  323. package/dist/database/migrations/20251119000000_add_constraint_text_hash_v3_9_1.d.ts.map +1 -0
  324. package/dist/database/migrations/20251119000000_add_constraint_text_hash_v3_9_1.js +100 -0
  325. package/dist/database/migrations/20251119000000_add_constraint_text_hash_v3_9_1.js.map +1 -0
  326. package/dist/init-commands.d.ts +7 -0
  327. package/dist/init-commands.d.ts.map +1 -0
  328. package/dist/init-commands.js +185 -0
  329. package/dist/init-commands.js.map +1 -0
  330. package/dist/schema.d.ts +11 -19
  331. package/dist/schema.d.ts.map +1 -1
  332. package/dist/schema.js +51 -63
  333. package/dist/schema.js.map +1 -1
  334. package/dist/server/tool-handlers.d.ts.map +1 -1
  335. package/dist/server/tool-handlers.js +20 -1
  336. package/dist/server/tool-handlers.js.map +1 -1
  337. package/dist/server/tool-registry.d.ts.map +1 -1
  338. package/dist/server/tool-registry.js +42 -1
  339. package/dist/server/tool-registry.js.map +1 -1
  340. package/dist/sync-commands.d.ts +13 -0
  341. package/dist/sync-commands.d.ts.map +1 -0
  342. package/dist/sync-commands.js +115 -0
  343. package/dist/sync-commands.js.map +1 -0
  344. package/dist/tests/database/connection/connection-manager-integration.test.d.ts.map +1 -0
  345. package/dist/tests/{connection-manager-integration.test.js → database/connection/connection-manager-integration.test.js} +1 -1
  346. package/dist/tests/database/connection/connection-manager-integration.test.js.map +1 -0
  347. package/dist/tests/database/connection/connection-manager.test.d.ts.map +1 -0
  348. package/dist/tests/{connection-manager.test.js → database/connection/connection-manager.test.js} +1 -1
  349. package/dist/tests/database/connection/connection-manager.test.js.map +1 -0
  350. package/dist/tests/database/migrations/idempotency.test.d.ts +2 -0
  351. package/dist/tests/database/migrations/idempotency.test.d.ts.map +1 -0
  352. package/dist/tests/{migration-idempotency.test.js → database/migrations/idempotency.test.js} +1 -1
  353. package/dist/tests/database/migrations/idempotency.test.js.map +1 -0
  354. package/dist/tests/database/migrations/upgrade-paths.test.d.ts +2 -0
  355. package/dist/tests/database/migrations/upgrade-paths.test.d.ts.map +1 -0
  356. package/dist/tests/{migration-upgrade-paths.test.js → database/migrations/upgrade-paths.test.js} +1 -1
  357. package/dist/tests/database/migrations/upgrade-paths.test.js.map +1 -0
  358. package/dist/tests/database/multi-project/multi-project.test.d.ts.map +1 -0
  359. package/dist/tests/{multi-project.test.js → database/multi-project/multi-project.test.js} +5 -5
  360. package/dist/tests/database/multi-project/multi-project.test.js.map +1 -0
  361. package/dist/tests/{sql-dump-converters.test.d.ts → database/sql-dump/converters.test.d.ts} +1 -1
  362. package/dist/tests/database/sql-dump/converters.test.d.ts.map +1 -0
  363. package/dist/tests/{sql-dump-converters.test.js → database/sql-dump/converters.test.js} +2 -2
  364. package/dist/tests/database/sql-dump/converters.test.js.map +1 -0
  365. package/dist/tests/{sql-dump-default-conversions.test.d.ts → database/sql-dump/default-conversions.test.d.ts} +1 -1
  366. package/dist/tests/database/sql-dump/default-conversions.test.d.ts.map +1 -0
  367. package/dist/tests/{sql-dump-default-conversions.test.js → database/sql-dump/default-conversions.test.js} +2 -2
  368. package/dist/tests/database/sql-dump/default-conversions.test.js.map +1 -0
  369. package/dist/tests/database/sql-dump/table-ordering.test.d.ts +27 -0
  370. package/dist/tests/database/sql-dump/table-ordering.test.d.ts.map +1 -0
  371. package/dist/tests/{sql-dump-table-ordering.test.js → database/sql-dump/table-ordering.test.js} +34 -8
  372. package/dist/tests/database/sql-dump/table-ordering.test.js.map +1 -0
  373. package/dist/tests/database/sql-dump/type-conversion.test.d.ts.map +1 -0
  374. package/dist/tests/{type-conversion.test.js → database/sql-dump/type-conversion.test.js} +1 -1
  375. package/dist/tests/database/sql-dump/type-conversion.test.js.map +1 -0
  376. package/dist/tests/database/testing-config.d.ts +105 -0
  377. package/dist/tests/database/testing-config.d.ts.map +1 -0
  378. package/dist/tests/database/testing-config.js +192 -0
  379. package/dist/tests/database/testing-config.js.map +1 -0
  380. package/dist/tests/{sql-dump-cross-database.test.d.ts → docker/cross-database.test.d.ts} +1 -1
  381. package/dist/tests/docker/cross-database.test.d.ts.map +1 -0
  382. package/dist/tests/{sql-dump-cross-database.test.js → docker/cross-database.test.js} +3 -3
  383. package/dist/tests/docker/cross-database.test.js.map +1 -0
  384. package/dist/tests/docker/dump-import.test.d.ts.map +1 -0
  385. package/dist/tests/{dump-import.test.js → docker/dump-import.test.js} +25 -31
  386. package/dist/tests/docker/dump-import.test.js.map +1 -0
  387. package/dist/tests/{sql-dump-fk-constraints.test.d.ts → docker/fk-constraints.test.d.ts} +1 -1
  388. package/dist/tests/docker/fk-constraints.test.d.ts.map +1 -0
  389. package/dist/tests/{sql-dump-fk-constraints.test.js → docker/fk-constraints.test.js} +3 -3
  390. package/dist/tests/docker/fk-constraints.test.js.map +1 -0
  391. package/dist/tests/{sql-dump-indexes.test.d.ts → docker/indexes.test.d.ts} +1 -1
  392. package/dist/tests/docker/indexes.test.d.ts.map +1 -0
  393. package/dist/tests/{sql-dump-indexes.test.js → docker/indexes.test.js} +10 -29
  394. package/dist/tests/docker/indexes.test.js.map +1 -0
  395. package/dist/tests/{sql-dump-integration.test.d.ts → docker/integration.test.d.ts} +1 -1
  396. package/dist/tests/docker/integration.test.d.ts.map +1 -0
  397. package/dist/tests/{sql-dump-integration.test.js → docker/integration.test.js} +9 -28
  398. package/dist/tests/docker/integration.test.js.map +1 -0
  399. package/dist/tests/docker/multi-project-migration.test.d.ts.map +1 -0
  400. package/dist/tests/{multi-project-migration.test.js → docker/multi-project-migration.test.js} +20 -8
  401. package/dist/tests/docker/multi-project-migration.test.js.map +1 -0
  402. package/dist/tests/docker/native/constraint-operations.test.d.ts +23 -0
  403. package/dist/tests/docker/native/constraint-operations.test.d.ts.map +1 -0
  404. package/dist/tests/docker/native/constraint-operations.test.js +693 -0
  405. package/dist/tests/docker/native/constraint-operations.test.js.map +1 -0
  406. package/dist/tests/docker/native/db-init.d.ts +59 -0
  407. package/dist/tests/docker/native/db-init.d.ts.map +1 -0
  408. package/dist/tests/docker/native/db-init.js +207 -0
  409. package/dist/tests/docker/native/db-init.js.map +1 -0
  410. package/dist/tests/docker/native/decision-operations.test.d.ts +16 -0
  411. package/dist/tests/docker/native/decision-operations.test.d.ts.map +1 -0
  412. package/dist/tests/docker/native/decision-operations.test.js +590 -0
  413. package/dist/tests/docker/native/decision-operations.test.js.map +1 -0
  414. package/dist/tests/docker/native/help-system.test.d.ts +10 -0
  415. package/dist/tests/docker/native/help-system.test.d.ts.map +1 -0
  416. package/dist/tests/docker/native/help-system.test.js +568 -0
  417. package/dist/tests/docker/native/help-system.test.js.map +1 -0
  418. package/dist/tests/docker/native/suggest-tool.test.d.ts +16 -0
  419. package/dist/tests/docker/native/suggest-tool.test.d.ts.map +1 -0
  420. package/dist/tests/docker/native/suggest-tool.test.js +607 -0
  421. package/dist/tests/docker/native/suggest-tool.test.js.map +1 -0
  422. package/dist/tests/docker/native/task-operations.test.d.ts +16 -0
  423. package/dist/tests/docker/native/task-operations.test.d.ts.map +1 -0
  424. package/dist/tests/docker/native/task-operations.test.js +836 -0
  425. package/dist/tests/docker/native/task-operations.test.js.map +1 -0
  426. package/dist/tests/docker/native/test-harness.d.ts +129 -0
  427. package/dist/tests/docker/native/test-harness.d.ts.map +1 -0
  428. package/dist/tests/docker/native/test-harness.js +314 -0
  429. package/dist/tests/docker/native/test-harness.js.map +1 -0
  430. package/dist/tests/docker/schema-migration.test.d.ts.map +1 -0
  431. package/dist/tests/{schema-migration.test.js → docker/schema-migration.test.js} +8 -18
  432. package/dist/tests/docker/schema-migration.test.js.map +1 -0
  433. package/dist/tests/feature/decision/analytics.test.d.ts +7 -0
  434. package/dist/tests/feature/decision/analytics.test.d.ts.map +1 -0
  435. package/dist/tests/feature/decision/analytics.test.js +140 -0
  436. package/dist/tests/feature/decision/analytics.test.js.map +1 -0
  437. package/dist/tests/feature/decision/batch-validation-comprehensive.test.d.ts.map +1 -0
  438. package/dist/tests/{batch-validation-comprehensive.test.js → feature/decision/batch-validation-comprehensive.test.js} +5 -5
  439. package/dist/tests/feature/decision/batch-validation-comprehensive.test.js.map +1 -0
  440. package/dist/tests/feature/decision/batch-validation-integration.test.d.ts.map +1 -0
  441. package/dist/tests/{batch-validation-integration.test.js → feature/decision/batch-validation-integration.test.js} +3 -3
  442. package/dist/tests/feature/decision/batch-validation-integration.test.js.map +1 -0
  443. package/dist/tests/{decision-batch-validation.test.d.ts → feature/decision/batch-validation.test.d.ts} +1 -1
  444. package/dist/tests/feature/decision/batch-validation.test.d.ts.map +1 -0
  445. package/dist/tests/{decision-batch-validation.test.js → feature/decision/batch-validation.test.js} +4 -4
  446. package/dist/tests/feature/decision/batch-validation.test.js.map +1 -0
  447. package/dist/tests/feature/decision/context-modular.test.d.ts.map +1 -0
  448. package/dist/tests/{context-modular.test.js → feature/decision/context-modular.test.js} +17 -8
  449. package/dist/tests/feature/decision/context-modular.test.js.map +1 -0
  450. package/dist/tests/feature/help/help-system.test.d.ts.map +1 -0
  451. package/dist/tests/{help-system.test.js → feature/help/help-system.test.js} +9 -9
  452. package/dist/tests/feature/help/help-system.test.js.map +1 -0
  453. package/dist/tests/{tasks.auto-pruning-decision-link.test.d.ts → feature/task/auto-pruning-decision-link.test.d.ts} +1 -1
  454. package/dist/tests/feature/task/auto-pruning-decision-link.test.d.ts.map +1 -0
  455. package/dist/tests/{tasks.auto-pruning-decision-link.test.js → feature/task/auto-pruning-decision-link.test.js} +30 -8
  456. package/dist/tests/feature/task/auto-pruning-decision-link.test.js.map +1 -0
  457. package/dist/tests/{tasks.auto-pruning-partial.test.d.ts → feature/task/auto-pruning-partial.test.d.ts} +1 -1
  458. package/dist/tests/feature/task/auto-pruning-partial.test.d.ts.map +1 -0
  459. package/dist/tests/{tasks.auto-pruning-partial.test.js → feature/task/auto-pruning-partial.test.js} +26 -4
  460. package/dist/tests/feature/task/auto-pruning-partial.test.js.map +1 -0
  461. package/dist/tests/{tasks.auto-pruning-persistence.test.d.ts → feature/task/auto-pruning-persistence.test.d.ts} +1 -1
  462. package/dist/tests/feature/task/auto-pruning-persistence.test.d.ts.map +1 -0
  463. package/dist/tests/{tasks.auto-pruning-persistence.test.js → feature/task/auto-pruning-persistence.test.js} +23 -3
  464. package/dist/tests/feature/task/auto-pruning-persistence.test.js.map +1 -0
  465. package/dist/tests/{tasks.auto-pruning-safety.test.d.ts → feature/task/auto-pruning-safety.test.d.ts} +1 -1
  466. package/dist/tests/feature/task/auto-pruning-safety.test.d.ts.map +1 -0
  467. package/dist/tests/{tasks.auto-pruning-safety.test.js → feature/task/auto-pruning-safety.test.js} +46 -20
  468. package/dist/tests/feature/task/auto-pruning-safety.test.js.map +1 -0
  469. package/dist/tests/{tasks.dependencies.test.d.ts → feature/task/dependencies.test.d.ts} +1 -1
  470. package/dist/tests/feature/task/dependencies.test.d.ts.map +1 -0
  471. package/dist/tests/{tasks.dependencies.test.js → feature/task/dependencies.test.js} +46 -30
  472. package/dist/tests/feature/task/dependencies.test.js.map +1 -0
  473. package/dist/tests/{tasks.file-actions-integration.test.d.ts → feature/task/file-actions-integration.test.d.ts} +1 -1
  474. package/dist/tests/feature/task/file-actions-integration.test.d.ts.map +1 -0
  475. package/dist/tests/{tasks.file-actions-integration.test.js → feature/task/file-actions-integration.test.js} +6 -6
  476. package/dist/tests/feature/task/file-actions-integration.test.js.map +1 -0
  477. package/dist/tests/{tasks.file-actions-validation.test.d.ts → feature/task/file-actions-validation.test.d.ts} +1 -1
  478. package/dist/tests/feature/task/file-actions-validation.test.d.ts.map +1 -0
  479. package/dist/tests/{tasks.file-actions-validation.test.js → feature/task/file-actions-validation.test.js} +11 -4
  480. package/dist/tests/feature/task/file-actions-validation.test.js.map +1 -0
  481. package/dist/tests/{tasks.link-file-backward-compat.test.d.ts → feature/task/link-file-backward-compat.test.d.ts} +1 -1
  482. package/dist/tests/feature/task/link-file-backward-compat.test.d.ts.map +1 -0
  483. package/dist/tests/{tasks.link-file-backward-compat.test.js → feature/task/link-file-backward-compat.test.js} +65 -40
  484. package/dist/tests/feature/task/link-file-backward-compat.test.js.map +1 -0
  485. package/dist/tests/{tasks.watch-files-action.test.d.ts → feature/task/watch-files-action.test.d.ts} +3 -1
  486. package/dist/tests/feature/task/watch-files-action.test.d.ts.map +1 -0
  487. package/dist/tests/{tasks.watch-files-action.test.js → feature/task/watch-files-action.test.js} +58 -36
  488. package/dist/tests/feature/task/watch-files-action.test.js.map +1 -0
  489. package/dist/tests/{tasks.watch-files-parameter.test.d.ts → feature/task/watch-files-parameter.test.d.ts} +3 -1
  490. package/dist/tests/feature/task/watch-files-parameter.test.d.ts.map +1 -0
  491. package/dist/tests/{tasks.watch-files-parameter.test.js → feature/task/watch-files-parameter.test.js} +64 -39
  492. package/dist/tests/feature/task/watch-files-parameter.test.js.map +1 -0
  493. package/dist/tests/feature/vcs/git-aware-completion.test.d.ts.map +1 -0
  494. package/dist/tests/{git-aware-completion.test.js → feature/vcs/git-aware-completion.test.js} +25 -11
  495. package/dist/tests/feature/vcs/git-aware-completion.test.js.map +1 -0
  496. package/dist/tests/feature/vcs/two-step-git-completion.test.d.ts.map +1 -0
  497. package/dist/tests/{two-step-git-completion.test.js → feature/vcs/two-step-git-completion.test.js} +2 -2
  498. package/dist/tests/feature/vcs/two-step-git-completion.test.js.map +1 -0
  499. package/dist/tests/feature/vcs/vcs-staging.test.d.ts.map +1 -0
  500. package/dist/tests/{vcs-staging.test.js → feature/vcs/vcs-staging.test.js} +8 -3
  501. package/dist/tests/feature/vcs/vcs-staging.test.js.map +1 -0
  502. package/dist/tests/{all-features.test.d.ts → integration/all-features.standalone.d.ts} +1 -1
  503. package/dist/tests/integration/all-features.standalone.d.ts.map +1 -0
  504. package/dist/tests/{all-features.test.js → integration/all-features.standalone.js} +7 -9
  505. package/dist/tests/integration/all-features.standalone.js.map +1 -0
  506. package/dist/tests/integration/auto-trigger-suggestions.test.d.ts +7 -0
  507. package/dist/tests/integration/auto-trigger-suggestions.test.d.ts.map +1 -0
  508. package/dist/tests/integration/auto-trigger-suggestions.test.js +331 -0
  509. package/dist/tests/integration/auto-trigger-suggestions.test.js.map +1 -0
  510. package/dist/tests/integration/decision-intelligence-e2e.test.d.ts +13 -0
  511. package/dist/tests/integration/decision-intelligence-e2e.test.d.ts.map +1 -0
  512. package/dist/tests/integration/decision-intelligence-e2e.test.js +558 -0
  513. package/dist/tests/integration/decision-intelligence-e2e.test.js.map +1 -0
  514. package/dist/tests/integration/e2e-workflow1-debug.test.d.ts +5 -0
  515. package/dist/tests/integration/e2e-workflow1-debug.test.d.ts.map +1 -0
  516. package/dist/tests/integration/e2e-workflow1-debug.test.js +99 -0
  517. package/dist/tests/integration/e2e-workflow1-debug.test.js.map +1 -0
  518. package/dist/tests/integration/hybrid-similarity-detection.test.d.ts +7 -0
  519. package/dist/tests/integration/hybrid-similarity-detection.test.d.ts.map +1 -0
  520. package/dist/tests/integration/hybrid-similarity-detection.test.js +512 -0
  521. package/dist/tests/integration/hybrid-similarity-detection.test.js.map +1 -0
  522. package/dist/tests/integration/suggest-simple.test.d.ts +5 -0
  523. package/dist/tests/integration/suggest-simple.test.d.ts.map +1 -0
  524. package/dist/tests/integration/suggest-simple.test.js +72 -0
  525. package/dist/tests/integration/suggest-simple.test.js.map +1 -0
  526. package/dist/tests/unit/universal-knex.test.d.ts +2 -0
  527. package/dist/tests/unit/universal-knex.test.d.ts.map +1 -0
  528. package/dist/tests/unit/universal-knex.test.js +250 -0
  529. package/dist/tests/unit/universal-knex.test.js.map +1 -0
  530. package/dist/tests/unit/utils/config-loader.test.d.ts.map +1 -0
  531. package/dist/tests/{config-loader.test.js → unit/utils/config-loader.test.js} +63 -42
  532. package/dist/tests/unit/utils/config-loader.test.js.map +1 -0
  533. package/dist/tests/unit/utils/project-detector.test.d.ts.map +1 -0
  534. package/dist/tests/{project-detector.test.js → unit/utils/project-detector.test.js} +1 -1
  535. package/dist/tests/unit/utils/project-detector.test.js.map +1 -0
  536. package/dist/tests/unit/utils/semver.test.d.ts +2 -0
  537. package/dist/tests/unit/utils/semver.test.d.ts.map +1 -0
  538. package/dist/tests/unit/utils/semver.test.js +72 -0
  539. package/dist/tests/unit/utils/semver.test.js.map +1 -0
  540. package/dist/tests/unit/validation/batch-validation.test.d.ts.map +1 -0
  541. package/dist/tests/{batch-validation.test.js → unit/validation/batch-validation.test.js} +2 -2
  542. package/dist/tests/unit/validation/batch-validation.test.js.map +1 -0
  543. package/dist/tests/unit/validation/parameter-validation.test.d.ts.map +1 -0
  544. package/dist/tests/{parameter-validation.test.js → unit/validation/parameter-validation.test.js} +9 -12
  545. package/dist/tests/unit/validation/parameter-validation.test.js.map +1 -0
  546. package/dist/tests/unit/validation/policy-validation.test.d.ts +15 -0
  547. package/dist/tests/unit/validation/policy-validation.test.d.ts.map +1 -0
  548. package/dist/tests/unit/validation/policy-validation.test.js +343 -0
  549. package/dist/tests/unit/validation/policy-validation.test.js.map +1 -0
  550. package/dist/tests/utils/db-config.d.ts +21 -0
  551. package/dist/tests/utils/db-config.d.ts.map +1 -0
  552. package/dist/tests/utils/db-config.js +59 -0
  553. package/dist/tests/utils/db-config.js.map +1 -0
  554. package/dist/tests/utils/db-import.d.ts +11 -0
  555. package/dist/tests/utils/db-import.d.ts.map +1 -0
  556. package/dist/tests/utils/db-import.js +38 -0
  557. package/dist/tests/utils/db-import.js.map +1 -0
  558. package/dist/tests/utils/db-schema.d.ts +58 -0
  559. package/dist/tests/utils/db-schema.d.ts.map +1 -0
  560. package/dist/tests/utils/db-schema.js +218 -0
  561. package/dist/tests/utils/db-schema.js.map +1 -0
  562. package/dist/tests/utils/db-seeding.d.ts +18 -0
  563. package/dist/tests/utils/db-seeding.d.ts.map +1 -0
  564. package/dist/tests/utils/db-seeding.js +54 -0
  565. package/dist/tests/utils/db-seeding.js.map +1 -0
  566. package/dist/tests/utils/index.d.ts +20 -0
  567. package/dist/tests/utils/index.d.ts.map +1 -0
  568. package/dist/tests/utils/index.js +26 -0
  569. package/dist/tests/utils/index.js.map +1 -0
  570. package/dist/tests/utils/task-helpers.d.ts +67 -0
  571. package/dist/tests/utils/task-helpers.d.ts.map +1 -0
  572. package/dist/tests/utils/task-helpers.js +151 -0
  573. package/dist/tests/utils/task-helpers.js.map +1 -0
  574. package/dist/tests/utils/test-helpers.d.ts +93 -1
  575. package/dist/tests/utils/test-helpers.d.ts.map +1 -1
  576. package/dist/tests/utils/test-helpers.js +232 -64
  577. package/dist/tests/utils/test-helpers.js.map +1 -1
  578. package/dist/tests/utils/test-lifecycle.d.ts +52 -0
  579. package/dist/tests/utils/test-lifecycle.d.ts.map +1 -0
  580. package/dist/tests/utils/test-lifecycle.js +88 -0
  581. package/dist/tests/utils/test-lifecycle.js.map +1 -0
  582. package/dist/tools/context/actions/analytics.d.ts +88 -0
  583. package/dist/tools/context/actions/analytics.d.ts.map +1 -0
  584. package/dist/tools/context/actions/analytics.js +92 -0
  585. package/dist/tools/context/actions/analytics.js.map +1 -0
  586. package/dist/tools/context/actions/create-policy.d.ts +38 -0
  587. package/dist/tools/context/actions/create-policy.d.ts.map +1 -0
  588. package/dist/tools/context/actions/create-policy.js +87 -0
  589. package/dist/tools/context/actions/create-policy.js.map +1 -0
  590. package/dist/tools/context/actions/create-template.js +2 -2
  591. package/dist/tools/context/actions/create-template.js.map +1 -1
  592. package/dist/tools/context/actions/get.d.ts.map +1 -1
  593. package/dist/tools/context/actions/get.js +5 -4
  594. package/dist/tools/context/actions/get.js.map +1 -1
  595. package/dist/tools/context/actions/has-updates.d.ts.map +1 -1
  596. package/dist/tools/context/actions/has-updates.js +4 -19
  597. package/dist/tools/context/actions/has-updates.js.map +1 -1
  598. package/dist/tools/context/actions/list-policies.d.ts +31 -0
  599. package/dist/tools/context/actions/list-policies.d.ts.map +1 -0
  600. package/dist/tools/context/actions/list-policies.js +55 -0
  601. package/dist/tools/context/actions/list-policies.js.map +1 -0
  602. package/dist/tools/context/actions/list-templates.d.ts.map +1 -1
  603. package/dist/tools/context/actions/list-templates.js +2 -1
  604. package/dist/tools/context/actions/list-templates.js.map +1 -1
  605. package/dist/tools/context/actions/list.d.ts +1 -1
  606. package/dist/tools/context/actions/list.d.ts.map +1 -1
  607. package/dist/tools/context/actions/list.js +24 -18
  608. package/dist/tools/context/actions/list.js.map +1 -1
  609. package/dist/tools/context/actions/search-advanced.d.ts.map +1 -1
  610. package/dist/tools/context/actions/search-advanced.js +61 -42
  611. package/dist/tools/context/actions/search-advanced.js.map +1 -1
  612. package/dist/tools/context/actions/search-layer.d.ts.map +1 -1
  613. package/dist/tools/context/actions/search-layer.js +16 -7
  614. package/dist/tools/context/actions/search-layer.js.map +1 -1
  615. package/dist/tools/context/actions/search-tags.d.ts.map +1 -1
  616. package/dist/tools/context/actions/search-tags.js +22 -14
  617. package/dist/tools/context/actions/search-tags.js.map +1 -1
  618. package/dist/tools/context/actions/set-from-policy.d.ts +28 -0
  619. package/dist/tools/context/actions/set-from-policy.d.ts.map +1 -0
  620. package/dist/tools/context/actions/set-from-policy.js +54 -0
  621. package/dist/tools/context/actions/set-from-policy.js.map +1 -0
  622. package/dist/tools/context/actions/set-from-template.d.ts.map +1 -1
  623. package/dist/tools/context/actions/set-from-template.js +2 -1
  624. package/dist/tools/context/actions/set-from-template.js.map +1 -1
  625. package/dist/tools/context/index.d.ts +5 -0
  626. package/dist/tools/context/index.d.ts.map +1 -1
  627. package/dist/tools/context/index.js +5 -0
  628. package/dist/tools/context/index.js.map +1 -1
  629. package/dist/tools/context/internal/queries.d.ts.map +1 -1
  630. package/dist/tools/context/internal/queries.js +551 -31
  631. package/dist/tools/context/internal/queries.js.map +1 -1
  632. package/dist/tools/context/internal/validation.d.ts +4 -0
  633. package/dist/tools/context/internal/validation.d.ts.map +1 -1
  634. package/dist/tools/context/internal/validation.js +13 -0
  635. package/dist/tools/context/internal/validation.js.map +1 -1
  636. package/dist/tools/help/actions/query-action.js +1 -1
  637. package/dist/tools/help/actions/query-action.js.map +1 -1
  638. package/dist/tools/help/actions/query-params.js +1 -1
  639. package/dist/tools/help/actions/query-params.js.map +1 -1
  640. package/dist/tools/help/actions/query-tool.js +1 -1
  641. package/dist/tools/help/actions/query-tool.js.map +1 -1
  642. package/dist/tools/help-queries.d.ts +12 -12
  643. package/dist/tools/help-queries.d.ts.map +1 -1
  644. package/dist/tools/help-queries.js +121 -140
  645. package/dist/tools/help-queries.js.map +1 -1
  646. package/dist/tools/suggest/actions/by-context.d.ts +28 -0
  647. package/dist/tools/suggest/actions/by-context.d.ts.map +1 -0
  648. package/dist/tools/suggest/actions/by-context.js +68 -0
  649. package/dist/tools/suggest/actions/by-context.js.map +1 -0
  650. package/dist/tools/suggest/actions/by-key.d.ts +20 -0
  651. package/dist/tools/suggest/actions/by-key.d.ts.map +1 -0
  652. package/dist/tools/suggest/actions/by-key.js +55 -0
  653. package/dist/tools/suggest/actions/by-key.js.map +1 -0
  654. package/dist/tools/suggest/actions/by-tags.d.ts +23 -0
  655. package/dist/tools/suggest/actions/by-tags.d.ts.map +1 -0
  656. package/dist/tools/suggest/actions/by-tags.js +58 -0
  657. package/dist/tools/suggest/actions/by-tags.js.map +1 -0
  658. package/dist/tools/suggest/actions/check-duplicate.d.ts +20 -0
  659. package/dist/tools/suggest/actions/check-duplicate.d.ts.map +1 -0
  660. package/dist/tools/suggest/actions/check-duplicate.js +59 -0
  661. package/dist/tools/suggest/actions/check-duplicate.js.map +1 -0
  662. package/dist/tools/suggest/help/help.d.ts +5 -0
  663. package/dist/tools/suggest/help/help.d.ts.map +1 -0
  664. package/dist/tools/suggest/help/help.js +50 -0
  665. package/dist/tools/suggest/help/help.js.map +1 -0
  666. package/dist/tools/suggest/index.d.ts +18 -0
  667. package/dist/tools/suggest/index.d.ts.map +1 -0
  668. package/dist/tools/suggest/index.js +55 -0
  669. package/dist/tools/suggest/index.js.map +1 -0
  670. package/dist/tools/suggest/internal/queries.d.ts +60 -0
  671. package/dist/tools/suggest/internal/queries.d.ts.map +1 -0
  672. package/dist/tools/suggest/internal/queries.js +154 -0
  673. package/dist/tools/suggest/internal/queries.js.map +1 -0
  674. package/dist/tools/suggest/types.d.ts +70 -0
  675. package/dist/tools/suggest/types.d.ts.map +1 -0
  676. package/dist/tools/suggest/types.js +5 -0
  677. package/dist/tools/suggest/types.js.map +1 -0
  678. package/dist/tools/tasks/actions/link-pruned-file.d.ts +1 -0
  679. package/dist/tools/tasks/actions/link-pruned-file.d.ts.map +1 -1
  680. package/dist/tools/tasks/actions/link-pruned-file.js +7 -2
  681. package/dist/tools/tasks/actions/link-pruned-file.js.map +1 -1
  682. package/dist/tools/tasks/actions/link.d.ts.map +1 -1
  683. package/dist/tools/tasks/actions/link.js +4 -2
  684. package/dist/tools/tasks/actions/link.js.map +1 -1
  685. package/dist/tools/tasks/actions/list.d.ts.map +1 -1
  686. package/dist/tools/tasks/actions/list.js +37 -35
  687. package/dist/tools/tasks/actions/list.js.map +1 -1
  688. package/dist/tools/use_case/actions/search.d.ts +1 -1
  689. package/dist/tools/use_case/actions/search.d.ts.map +1 -1
  690. package/dist/tools/use_case/actions/search.js +31 -40
  691. package/dist/tools/use_case/actions/search.js.map +1 -1
  692. package/dist/types/actions.d.ts +10 -0
  693. package/dist/types/actions.d.ts.map +1 -1
  694. package/dist/types/decision/params.d.ts +7 -0
  695. package/dist/types/decision/params.d.ts.map +1 -1
  696. package/dist/types/decision/responses.d.ts +38 -0
  697. package/dist/types/decision/responses.d.ts.map +1 -1
  698. package/dist/types/view-entities.d.ts +1 -0
  699. package/dist/types/view-entities.d.ts.map +1 -1
  700. package/dist/types.d.ts +33 -1
  701. package/dist/types.d.ts.map +1 -1
  702. package/dist/utils/action-specs/decision-specs.js +3 -3
  703. package/dist/utils/action-specs/decision-specs.js.map +1 -1
  704. package/dist/utils/activity-logging.d.ts.map +1 -1
  705. package/dist/utils/activity-logging.js +7 -0
  706. package/dist/utils/activity-logging.js.map +1 -1
  707. package/dist/utils/db-aggregations.d.ts +88 -0
  708. package/dist/utils/db-aggregations.d.ts.map +1 -0
  709. package/dist/utils/db-aggregations.js +158 -0
  710. package/dist/utils/db-aggregations.js.map +1 -0
  711. package/dist/utils/file-pruning.d.ts +37 -13
  712. package/dist/utils/file-pruning.d.ts.map +1 -1
  713. package/dist/utils/file-pruning.js +93 -84
  714. package/dist/utils/file-pruning.js.map +1 -1
  715. package/dist/utils/policy-validator.d.ts +37 -0
  716. package/dist/utils/policy-validator.d.ts.map +1 -0
  717. package/dist/utils/policy-validator.js +240 -0
  718. package/dist/utils/policy-validator.js.map +1 -0
  719. package/dist/utils/quality-checks.d.ts +7 -7
  720. package/dist/utils/quality-checks.d.ts.map +1 -1
  721. package/dist/utils/quality-checks.js +18 -21
  722. package/dist/utils/quality-checks.js.map +1 -1
  723. package/dist/utils/semver.d.ts +50 -0
  724. package/dist/utils/semver.d.ts.map +1 -0
  725. package/dist/utils/semver.js +78 -0
  726. package/dist/utils/semver.js.map +1 -0
  727. package/dist/utils/sql-dump/schema/tables.d.ts.map +1 -1
  728. package/dist/utils/sql-dump/schema/tables.js +125 -7
  729. package/dist/utils/sql-dump/schema/tables.js.map +1 -1
  730. package/dist/utils/sql-dump/schema/views.d.ts.map +1 -1
  731. package/dist/utils/sql-dump/schema/views.js +6 -0
  732. package/dist/utils/sql-dump/schema/views.js.map +1 -1
  733. package/dist/utils/suggestion-scorer.d.ts +62 -0
  734. package/dist/utils/suggestion-scorer.d.ts.map +1 -0
  735. package/dist/utils/suggestion-scorer.js +169 -0
  736. package/dist/utils/suggestion-scorer.js.map +1 -0
  737. package/dist/utils/tag-parser.d.ts +52 -0
  738. package/dist/utils/tag-parser.d.ts.map +1 -0
  739. package/dist/utils/tag-parser.js +65 -0
  740. package/dist/utils/tag-parser.js.map +1 -0
  741. package/dist/utils/task-stale-detection.d.ts.map +1 -1
  742. package/dist/utils/task-stale-detection.js +40 -4
  743. package/dist/utils/task-stale-detection.js.map +1 -1
  744. package/dist/utils/token-logging.d.ts +9 -9
  745. package/dist/utils/token-logging.d.ts.map +1 -1
  746. package/dist/utils/token-logging.js +36 -38
  747. package/dist/utils/token-logging.js.map +1 -1
  748. package/dist/utils/universal-knex.d.ts +169 -0
  749. package/dist/utils/universal-knex.d.ts.map +1 -0
  750. package/dist/utils/universal-knex.js +318 -0
  751. package/dist/utils/universal-knex.js.map +1 -0
  752. package/dist/utils/validators.d.ts +2 -2
  753. package/dist/utils/validators.d.ts.map +1 -1
  754. package/dist/utils/validators.js +3 -2
  755. package/dist/utils/validators.js.map +1 -1
  756. package/dist/utils/vcs-adapter.d.ts.map +1 -1
  757. package/dist/utils/vcs-adapter.js +21 -14
  758. package/dist/utils/vcs-adapter.js.map +1 -1
  759. package/dist/utils/view-queries.d.ts +11 -3
  760. package/dist/utils/view-queries.d.ts.map +1 -1
  761. package/dist/utils/view-queries.js +122 -87
  762. package/dist/utils/view-queries.js.map +1 -1
  763. package/dist/watcher/file-watcher.d.ts.map +1 -1
  764. package/dist/watcher/file-watcher.js +99 -84
  765. package/dist/watcher/file-watcher.js.map +1 -1
  766. package/docs/BEST_PRACTICES.md +10 -0
  767. package/docs/DECISION_CONTEXT.md +190 -1
  768. package/docs/DECISION_INTELLIGENCE.md +594 -0
  769. package/docs/MIGRATION_GUIDE_V3.9.0.md +371 -0
  770. package/docs/SLASH_COMMANDS.md +652 -0
  771. package/docs/TOOL_REFERENCE.md +164 -22
  772. package/docs/TOOL_SELECTION.md +16 -2
  773. package/docs/WORKFLOWS.md +163 -0
  774. package/docs/changelogs/CHANGELOG_ARCHIVE_v3.4_and_older.md +296 -0
  775. package/package.json +35 -10
  776. package/scripts/check-cross-db-patterns.sh +105 -0
  777. package/scripts/filter-test-output.js +74 -0
  778. package/scripts/verify-migrations.sh +129 -0
  779. package/dist/tests/all-features.test.d.ts.map +0 -1
  780. package/dist/tests/all-features.test.js.map +0 -1
  781. package/dist/tests/batch-validation-comprehensive.test.d.ts.map +0 -1
  782. package/dist/tests/batch-validation-comprehensive.test.js.map +0 -1
  783. package/dist/tests/batch-validation-integration.test.d.ts.map +0 -1
  784. package/dist/tests/batch-validation-integration.test.js.map +0 -1
  785. package/dist/tests/batch-validation.test.d.ts.map +0 -1
  786. package/dist/tests/batch-validation.test.js.map +0 -1
  787. package/dist/tests/config-loader.test.d.ts.map +0 -1
  788. package/dist/tests/config-loader.test.js.map +0 -1
  789. package/dist/tests/connection-manager-integration.test.d.ts.map +0 -1
  790. package/dist/tests/connection-manager-integration.test.js.map +0 -1
  791. package/dist/tests/connection-manager.test.d.ts.map +0 -1
  792. package/dist/tests/connection-manager.test.js.map +0 -1
  793. package/dist/tests/context-modular.test.d.ts.map +0 -1
  794. package/dist/tests/context-modular.test.js.map +0 -1
  795. package/dist/tests/decision-batch-validation.test.d.ts.map +0 -1
  796. package/dist/tests/decision-batch-validation.test.js.map +0 -1
  797. package/dist/tests/dump-import.test.d.ts.map +0 -1
  798. package/dist/tests/dump-import.test.js.map +0 -1
  799. package/dist/tests/git-aware-completion.test.d.ts.map +0 -1
  800. package/dist/tests/git-aware-completion.test.js.map +0 -1
  801. package/dist/tests/help-system.test.d.ts.map +0 -1
  802. package/dist/tests/help-system.test.js.map +0 -1
  803. package/dist/tests/migration-idempotency.test.d.ts +0 -2
  804. package/dist/tests/migration-idempotency.test.d.ts.map +0 -1
  805. package/dist/tests/migration-idempotency.test.js.map +0 -1
  806. package/dist/tests/migration-upgrade-paths.test.d.ts +0 -2
  807. package/dist/tests/migration-upgrade-paths.test.d.ts.map +0 -1
  808. package/dist/tests/migration-upgrade-paths.test.js.map +0 -1
  809. package/dist/tests/multi-project-migration.test.d.ts.map +0 -1
  810. package/dist/tests/multi-project-migration.test.js.map +0 -1
  811. package/dist/tests/multi-project.test.d.ts.map +0 -1
  812. package/dist/tests/multi-project.test.js.map +0 -1
  813. package/dist/tests/parameter-validation.test.d.ts.map +0 -1
  814. package/dist/tests/parameter-validation.test.js.map +0 -1
  815. package/dist/tests/project-detector.test.d.ts.map +0 -1
  816. package/dist/tests/project-detector.test.js.map +0 -1
  817. package/dist/tests/schema-migration.test.d.ts.map +0 -1
  818. package/dist/tests/schema-migration.test.js.map +0 -1
  819. package/dist/tests/sql-dump-converters.test.d.ts.map +0 -1
  820. package/dist/tests/sql-dump-converters.test.js.map +0 -1
  821. package/dist/tests/sql-dump-cross-database.test.d.ts.map +0 -1
  822. package/dist/tests/sql-dump-cross-database.test.js.map +0 -1
  823. package/dist/tests/sql-dump-default-conversions.test.d.ts.map +0 -1
  824. package/dist/tests/sql-dump-default-conversions.test.js.map +0 -1
  825. package/dist/tests/sql-dump-fk-constraints.test.d.ts.map +0 -1
  826. package/dist/tests/sql-dump-fk-constraints.test.js.map +0 -1
  827. package/dist/tests/sql-dump-indexes.test.d.ts.map +0 -1
  828. package/dist/tests/sql-dump-indexes.test.js.map +0 -1
  829. package/dist/tests/sql-dump-integration.test.d.ts.map +0 -1
  830. package/dist/tests/sql-dump-integration.test.js.map +0 -1
  831. package/dist/tests/sql-dump-table-ordering.test.d.ts +0 -8
  832. package/dist/tests/sql-dump-table-ordering.test.d.ts.map +0 -1
  833. package/dist/tests/sql-dump-table-ordering.test.js.map +0 -1
  834. package/dist/tests/tasks.auto-pruning-decision-link.test.d.ts.map +0 -1
  835. package/dist/tests/tasks.auto-pruning-decision-link.test.js.map +0 -1
  836. package/dist/tests/tasks.auto-pruning-partial.test.d.ts.map +0 -1
  837. package/dist/tests/tasks.auto-pruning-partial.test.js.map +0 -1
  838. package/dist/tests/tasks.auto-pruning-persistence.test.d.ts.map +0 -1
  839. package/dist/tests/tasks.auto-pruning-persistence.test.js.map +0 -1
  840. package/dist/tests/tasks.auto-pruning-safety.test.d.ts.map +0 -1
  841. package/dist/tests/tasks.auto-pruning-safety.test.js.map +0 -1
  842. package/dist/tests/tasks.dependencies.test.d.ts.map +0 -1
  843. package/dist/tests/tasks.dependencies.test.js.map +0 -1
  844. package/dist/tests/tasks.file-actions-integration.test.d.ts.map +0 -1
  845. package/dist/tests/tasks.file-actions-integration.test.js.map +0 -1
  846. package/dist/tests/tasks.file-actions-validation.test.d.ts.map +0 -1
  847. package/dist/tests/tasks.file-actions-validation.test.js.map +0 -1
  848. package/dist/tests/tasks.link-file-backward-compat.test.d.ts.map +0 -1
  849. package/dist/tests/tasks.link-file-backward-compat.test.js.map +0 -1
  850. package/dist/tests/tasks.watch-files-action.test.d.ts.map +0 -1
  851. package/dist/tests/tasks.watch-files-action.test.js.map +0 -1
  852. package/dist/tests/tasks.watch-files-parameter.test.d.ts.map +0 -1
  853. package/dist/tests/tasks.watch-files-parameter.test.js.map +0 -1
  854. package/dist/tests/two-step-git-completion.test.d.ts.map +0 -1
  855. package/dist/tests/two-step-git-completion.test.js.map +0 -1
  856. package/dist/tests/type-conversion.test.d.ts.map +0 -1
  857. package/dist/tests/type-conversion.test.js.map +0 -1
  858. package/dist/tests/vcs-staging.test.d.ts.map +0 -1
  859. package/dist/tests/vcs-staging.test.js.map +0 -1
  860. package/dist/utils/sql-dump.d.ts +0 -102
  861. package/dist/utils/sql-dump.d.ts.map +0 -1
  862. package/dist/utils/sql-dump.js +0 -1590
  863. package/dist/utils/sql-dump.js.map +0 -1
  864. /package/dist/tests/{connection-manager-integration.test.d.ts → database/connection/connection-manager-integration.test.d.ts} +0 -0
  865. /package/dist/tests/{connection-manager.test.d.ts → database/connection/connection-manager.test.d.ts} +0 -0
  866. /package/dist/tests/{multi-project.test.d.ts → database/multi-project/multi-project.test.d.ts} +0 -0
  867. /package/dist/tests/{type-conversion.test.d.ts → database/sql-dump/type-conversion.test.d.ts} +0 -0
  868. /package/dist/tests/{dump-import.test.d.ts → docker/dump-import.test.d.ts} +0 -0
  869. /package/dist/tests/{multi-project-migration.test.d.ts → docker/multi-project-migration.test.d.ts} +0 -0
  870. /package/dist/tests/{schema-migration.test.d.ts → docker/schema-migration.test.d.ts} +0 -0
  871. /package/dist/tests/{batch-validation-comprehensive.test.d.ts → feature/decision/batch-validation-comprehensive.test.d.ts} +0 -0
  872. /package/dist/tests/{batch-validation-integration.test.d.ts → feature/decision/batch-validation-integration.test.d.ts} +0 -0
  873. /package/dist/tests/{context-modular.test.d.ts → feature/decision/context-modular.test.d.ts} +0 -0
  874. /package/dist/tests/{help-system.test.d.ts → feature/help/help-system.test.d.ts} +0 -0
  875. /package/dist/tests/{git-aware-completion.test.d.ts → feature/vcs/git-aware-completion.test.d.ts} +0 -0
  876. /package/dist/tests/{two-step-git-completion.test.d.ts → feature/vcs/two-step-git-completion.test.d.ts} +0 -0
  877. /package/dist/tests/{vcs-staging.test.d.ts → feature/vcs/vcs-staging.test.d.ts} +0 -0
  878. /package/dist/tests/{config-loader.test.d.ts → unit/utils/config-loader.test.d.ts} +0 -0
  879. /package/dist/tests/{project-detector.test.d.ts → unit/utils/project-detector.test.d.ts} +0 -0
  880. /package/dist/tests/{batch-validation.test.d.ts → unit/validation/batch-validation.test.d.ts} +0 -0
  881. /package/dist/tests/{parameter-validation.test.d.ts → unit/validation/parameter-validation.test.d.ts} +0 -0
@@ -0,0 +1,132 @@
1
+ /**
2
+ * Migration: Fix Cross-Database Timestamp Defaults (v3.9.0)
3
+ *
4
+ * Problem: Upgrade migration 20251112000000_decision_intelligence_v3_9_0.ts uses
5
+ * SQLite-specific strftime('%s', 'now') for DEFAULT values, which fails on PostgreSQL.
6
+ *
7
+ * Solution: This migration acts as a "catch-up" to complete the work if the original
8
+ * migration failed on non-SQLite databases. It uses database-aware timestamp functions.
9
+ *
10
+ * Note: This is a hotfix migration. We cannot edit the pushed upgrade migration.
11
+ */
12
+ export async function up(knex) {
13
+ const client = knex.client.config.client;
14
+ const isSQLite = client === 'sqlite3' || client === 'better-sqlite3';
15
+ const isMySQL = client === 'mysql2' || client === 'mysql';
16
+ const isPostgreSQL = client === 'pg' || client === 'postgresql';
17
+ // Skip on SQLite - original migration works fine there
18
+ if (isSQLite) {
19
+ console.log('✓ SQLite: Original migration already handled timestamps correctly');
20
+ return;
21
+ }
22
+ console.log(`🔧 Fixing cross-database timestamp issues for ${client}...`);
23
+ // ============================================================================
24
+ // Fix t_decision_policies table
25
+ // ============================================================================
26
+ const hasPoliciesTable = await knex.schema.hasTable('t_decision_policies');
27
+ if (hasPoliciesTable) {
28
+ const hasProjectId = await knex.schema.hasColumn('t_decision_policies', 'project_id');
29
+ const hasCreatedBy = await knex.schema.hasColumn('t_decision_policies', 'created_by');
30
+ const hasTs = await knex.schema.hasColumn('t_decision_policies', 'ts');
31
+ if (!hasProjectId || !hasCreatedBy || !hasTs) {
32
+ console.log(' ⏭️ Adding missing columns to t_decision_policies...');
33
+ await knex.schema.alterTable('t_decision_policies', (table) => {
34
+ if (!hasProjectId) {
35
+ table.integer('project_id').notNullable().defaultTo(1);
36
+ }
37
+ if (!hasCreatedBy) {
38
+ table.integer('created_by').nullable();
39
+ }
40
+ if (!hasTs) {
41
+ // Add as nullable first, then populate and make NOT NULL
42
+ table.integer('ts').nullable();
43
+ }
44
+ });
45
+ // Populate ts column with current timestamp if it was just created
46
+ if (!hasTs) {
47
+ const currentTs = Math.floor(Date.now() / 1000);
48
+ await knex('t_decision_policies').update({ ts: currentTs });
49
+ // Make ts NOT NULL
50
+ if (isMySQL) {
51
+ await knex.raw('ALTER TABLE t_decision_policies MODIFY ts INT NOT NULL');
52
+ }
53
+ else if (isPostgreSQL) {
54
+ await knex.raw('ALTER TABLE t_decision_policies ALTER COLUMN ts SET NOT NULL');
55
+ }
56
+ }
57
+ console.log(' ✅ Fixed t_decision_policies columns');
58
+ }
59
+ else {
60
+ console.log(' ✓ t_decision_policies already has required columns');
61
+ }
62
+ }
63
+ // ============================================================================
64
+ // Fix t_decision_pruning_log table
65
+ // ============================================================================
66
+ const hasPruningLog = await knex.schema.hasTable('t_decision_pruning_log');
67
+ if (!hasPruningLog) {
68
+ console.log(' ⏭️ Creating t_decision_pruning_log table...');
69
+ await knex.schema.createTable('t_decision_pruning_log', (table) => {
70
+ table.increments('id').primary();
71
+ table.integer('original_decision_id').notNullable();
72
+ table.string('original_key', 256).notNullable();
73
+ table.text('original_value').notNullable();
74
+ table.integer('original_version').notNullable();
75
+ table.bigInteger('original_ts').notNullable();
76
+ table.integer('project_id').notNullable().defaultTo(1);
77
+ // Add pruned_ts as nullable first
78
+ table.bigInteger('pruned_ts').nullable();
79
+ });
80
+ // Populate pruned_ts with current timestamp
81
+ const currentTs = Math.floor(Date.now() / 1000);
82
+ await knex('t_decision_pruning_log').update({ pruned_ts: currentTs });
83
+ // Make pruned_ts NOT NULL
84
+ if (isMySQL) {
85
+ await knex.raw('ALTER TABLE t_decision_pruning_log MODIFY pruned_ts BIGINT NOT NULL');
86
+ }
87
+ else if (isPostgreSQL) {
88
+ await knex.raw('ALTER TABLE t_decision_pruning_log ALTER COLUMN pruned_ts SET NOT NULL');
89
+ }
90
+ console.log(' ✅ Created t_decision_pruning_log table');
91
+ }
92
+ else {
93
+ console.log(' ✓ t_decision_pruning_log already exists');
94
+ }
95
+ // ============================================================================
96
+ // Fix m_tag_index table
97
+ // ============================================================================
98
+ const hasTagIndex = await knex.schema.hasTable('m_tag_index');
99
+ if (!hasTagIndex) {
100
+ console.log(' ⏭️ Creating m_tag_index table...');
101
+ await knex.schema.createTable('m_tag_index', (table) => {
102
+ // Use VARCHAR(191) instead of TEXT for PRIMARY KEY (MySQL/MariaDB requirement)
103
+ table.string('tag_name', 191).notNullable();
104
+ table.integer('decision_count').notNullable().defaultTo(0);
105
+ table.integer('constraint_count').notNullable().defaultTo(0);
106
+ table.integer('task_count').notNullable().defaultTo(0);
107
+ table.integer('total_count').notNullable().defaultTo(0);
108
+ table.primary(['tag_name']);
109
+ });
110
+ console.log(' ✅ Created m_tag_index table');
111
+ }
112
+ else {
113
+ console.log(' ✓ m_tag_index already exists');
114
+ }
115
+ console.log('✅ Cross-database timestamp fixes applied successfully');
116
+ }
117
+ export async function down(knex) {
118
+ const client = knex.client.config.client;
119
+ const isSQLite = client === 'sqlite3' || client === 'better-sqlite3';
120
+ if (isSQLite) {
121
+ console.log('✓ SQLite: No rollback needed');
122
+ return;
123
+ }
124
+ // This migration is a hotfix, so down() should not break the database
125
+ // We'll just log what we would do but not actually drop columns/tables
126
+ console.log('⚠️ Hotfix migration rollback: Not dropping columns/tables to preserve data');
127
+ console.log(' If you need to rollback, manually drop the columns/tables:');
128
+ console.log(' - t_decision_policies: project_id, created_by, ts');
129
+ console.log(' - t_decision_pruning_log: entire table');
130
+ console.log(' - m_tag_index: entire table');
131
+ }
132
+ //# sourceMappingURL=20251115110000_fix_cross_database_timestamps_v3_9_0.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20251115110000_fix_cross_database_timestamps_v3_9_0.js","sourceRoot":"","sources":["../../../../src/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import type { Knex } from "knex";
2
+ /**
3
+ * Migration: Final Cross-Database Compatibility Hotfix (v3.9.0)
4
+ *
5
+ * This migration runs AFTER all v3.9.0 migrations to ensure cross-database
6
+ * compatibility. It acts as a "safety net" to handle any issues that weren't
7
+ * caught by the pre-emptive migrations.
8
+ *
9
+ * Fixes:
10
+ * 1. Ensures all tables exist (no-op if already created)
11
+ * 2. Database-agnostic - skips on SQLite, handles MySQL/PostgreSQL specifics
12
+ *
13
+ * Note: This is a final safety migration. All future migrations should use
14
+ * database-aware syntax from the start.
15
+ */
16
+ export declare function up(knex: Knex): Promise<void>;
17
+ export declare function down(knex: Knex): Promise<void>;
18
+ //# sourceMappingURL=20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts","sourceRoot":"","sources":["../../../../src/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC;;;;;;;;;;;;;GAaG;AAEH,wBAAsB,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CA+BlD;AAED,wBAAsB,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAGpD"}
@@ -0,0 +1,47 @@
1
+ /**
2
+ * Migration: Final Cross-Database Compatibility Hotfix (v3.9.0)
3
+ *
4
+ * This migration runs AFTER all v3.9.0 migrations to ensure cross-database
5
+ * compatibility. It acts as a "safety net" to handle any issues that weren't
6
+ * caught by the pre-emptive migrations.
7
+ *
8
+ * Fixes:
9
+ * 1. Ensures all tables exist (no-op if already created)
10
+ * 2. Database-agnostic - skips on SQLite, handles MySQL/PostgreSQL specifics
11
+ *
12
+ * Note: This is a final safety migration. All future migrations should use
13
+ * database-aware syntax from the start.
14
+ */
15
+ export async function up(knex) {
16
+ const client = knex.client.config.client;
17
+ const isSQLite = client === 'sqlite3' || client === 'better-sqlite3';
18
+ // Skip on SQLite - all migrations work correctly there
19
+ if (isSQLite) {
20
+ console.log('✓ SQLite: All migrations completed successfully');
21
+ return;
22
+ }
23
+ console.log(`🔧 Final cross-database safety check for ${client}...`);
24
+ // Verify all critical tables exist
25
+ const criticalTables = [
26
+ 't_decision_policies',
27
+ 'm_tag_index',
28
+ 't_decision_pruning_log',
29
+ 't_task_pruned_files'
30
+ ];
31
+ for (const tableName of criticalTables) {
32
+ const exists = await knex.schema.hasTable(tableName);
33
+ if (!exists) {
34
+ console.log(`⚠️ WARNING: Table ${tableName} does not exist!`);
35
+ console.log(` This suggests a migration failure. Please check migration logs.`);
36
+ }
37
+ else {
38
+ console.log(` ✓ ${tableName} exists`);
39
+ }
40
+ }
41
+ console.log('✅ Cross-database compatibility verified');
42
+ }
43
+ export async function down(knex) {
44
+ // This is a safety check migration - no rollback needed
45
+ console.log('✓ Safety check migration - no rollback actions');
46
+ }
47
+ //# sourceMappingURL=20251115120000_fix_all_cross_db_issues_v3_9_0.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20251115120000_fix_all_cross_db_issues_v3_9_0.js","sourceRoot":"","sources":["../../../../src/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;;;GAaG;AAEH,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC;IACzC,MAAM,QAAQ,GAAG,MAAM,KAAK,SAAS,IAAI,MAAM,KAAK,gBAAgB,CAAC;IAErE,uDAAuD;IACvD,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,CAAC,GAAG,CAAC,iDAAiD,CAAC,CAAC;QAC/D,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,4CAA4C,MAAM,KAAK,CAAC,CAAC;IAErE,mCAAmC;IACnC,MAAM,cAAc,GAAG;QACrB,qBAAqB;QACrB,aAAa;QACb,wBAAwB;QACxB,qBAAqB;KACtB,CAAC;IAEF,KAAK,MAAM,SAAS,IAAI,cAAc,EAAE,CAAC;QACvC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO,CAAC,GAAG,CAAC,sBAAsB,SAAS,kBAAkB,CAAC,CAAC;YAC/D,OAAO,CAAC,GAAG,CAAC,oEAAoE,CAAC,CAAC;QACpF,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,OAAO,SAAS,SAAS,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,yCAAyC,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,wDAAwD;IACxD,OAAO,CAAC,GAAG,CAAC,gDAAgD,CAAC,CAAC;AAChE,CAAC"}
@@ -0,0 +1,20 @@
1
+ import type { Knex } from "knex";
2
+ /**
3
+ * v3.9.1 Hotfix - Native Database Test Issues
4
+ *
5
+ * Fixes:
6
+ * 1. MySQL/MariaDB: m_files composite UNIQUE index exceeds 3072 bytes
7
+ * - Reduce path length from 768 to 767 chars (767 * 4 + 4 = 3072 bytes exactly)
8
+ * 2. All databases: v_unread_messages_by_priority references dropped t_agent_messages table
9
+ * - Drop the view if it exists (table removed in v3.6.5)
10
+ *
11
+ * Context: Native database tests (fresh installations) fail because:
12
+ * - Bootstrap migration creates v_unread_messages_by_priority
13
+ * - Enhancement migration 20251028000000 drops t_agent_messages table
14
+ * - View becomes orphaned and causes errors
15
+ *
16
+ * This migration MUST run before bootstrap migrations for fresh installations.
17
+ */
18
+ export declare function up(knex: Knex): Promise<void>;
19
+ export declare function down(knex: Knex): Promise<void>;
20
+ //# sourceMappingURL=20251118000000_fix_native_db_test_issues_v3_9_1.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20251118000000_fix_native_db_test_issues_v3_9_1.d.ts","sourceRoot":"","sources":["../../../../src/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC;;;;;;;;;;;;;;;GAeG;AAEH,wBAAsB,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAyElD;AAED,wBAAsB,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAuCpD"}
@@ -0,0 +1,119 @@
1
+ /**
2
+ * v3.9.1 Hotfix - Native Database Test Issues
3
+ *
4
+ * Fixes:
5
+ * 1. MySQL/MariaDB: m_files composite UNIQUE index exceeds 3072 bytes
6
+ * - Reduce path length from 768 to 767 chars (767 * 4 + 4 = 3072 bytes exactly)
7
+ * 2. All databases: v_unread_messages_by_priority references dropped t_agent_messages table
8
+ * - Drop the view if it exists (table removed in v3.6.5)
9
+ *
10
+ * Context: Native database tests (fresh installations) fail because:
11
+ * - Bootstrap migration creates v_unread_messages_by_priority
12
+ * - Enhancement migration 20251028000000 drops t_agent_messages table
13
+ * - View becomes orphaned and causes errors
14
+ *
15
+ * This migration MUST run before bootstrap migrations for fresh installations.
16
+ */
17
+ export async function up(knex) {
18
+ const client = knex.client.config.client;
19
+ const isMySQL = client === 'mysql2' || client === 'mysql';
20
+ const isSQLite = client === 'better-sqlite3' || client === 'sqlite3';
21
+ console.log(`\n🔧 [v3.9.1 Hotfix] Fixing native database test issues for ${client}...`);
22
+ // ========================================================================
23
+ // Fix 1: m_files UNIQUE index length (MySQL/MariaDB only)
24
+ // ========================================================================
25
+ if (isMySQL) {
26
+ const hasTable = await knex.schema.hasTable('m_files');
27
+ if (hasTable) {
28
+ // Check if path column is > 767 characters
29
+ const columns = await knex('information_schema.COLUMNS')
30
+ .select('CHARACTER_MAXIMUM_LENGTH as max_length')
31
+ .where({
32
+ TABLE_SCHEMA: knex.client.database(),
33
+ TABLE_NAME: 'm_files',
34
+ COLUMN_NAME: 'path'
35
+ })
36
+ .first();
37
+ if (columns && columns.max_length > 767) {
38
+ console.log(` ⚠️ m_files.path is ${columns.max_length} chars (MySQL limit: 767 for UNIQUE index)`);
39
+ // Drop existing UNIQUE constraint if it exists
40
+ try {
41
+ await knex.schema.alterTable('m_files', (table) => {
42
+ table.dropUnique(['project_id', 'path']);
43
+ });
44
+ console.log(' ✓ Dropped existing UNIQUE constraint on (project_id, path)');
45
+ }
46
+ catch (error) {
47
+ if (!error.message.includes('check that column/key exists')) {
48
+ console.log(` ⓘ No existing UNIQUE constraint to drop (${error.message})`);
49
+ }
50
+ }
51
+ // Modify column to 767 characters
52
+ await knex.schema.alterTable('m_files', (table) => {
53
+ table.string('path', 767).notNullable().alter();
54
+ });
55
+ console.log(' ✓ Reduced path column to 767 characters');
56
+ // Re-create UNIQUE constraint
57
+ await knex.schema.alterTable('m_files', (table) => {
58
+ table.unique(['project_id', 'path']);
59
+ });
60
+ console.log(' ✓ Re-created UNIQUE constraint on (project_id, path)');
61
+ }
62
+ else {
63
+ console.log(' ✓ m_files.path length is within MySQL limits');
64
+ }
65
+ }
66
+ else {
67
+ console.log(' ⓘ m_files table does not exist yet (will be created with correct length)');
68
+ }
69
+ }
70
+ // ========================================================================
71
+ // Fix 2: Drop orphaned v_unread_messages_by_priority view
72
+ // ========================================================================
73
+ // This view references t_agent_messages which was dropped in v3.6.5
74
+ // The view should have been dropped in 20251031000000_drop_orphaned_message_view.ts,
75
+ // but for fresh installations the order is: bootstrap creates view → enhancement drops table → orphaned view
76
+ try {
77
+ await knex.raw('DROP VIEW IF EXISTS v_unread_messages_by_priority');
78
+ console.log(' ✓ Dropped v_unread_messages_by_priority view (references dropped t_agent_messages)');
79
+ }
80
+ catch (error) {
81
+ console.log(` ⓘ Could not drop view: ${error.message}`);
82
+ }
83
+ console.log('✅ [v3.9.1 Hotfix] Native database test fixes applied successfully\n');
84
+ }
85
+ export async function down(knex) {
86
+ const client = knex.client.config.client;
87
+ const isMySQL = client === 'mysql2' || client === 'mysql';
88
+ console.log(`\n🔄 [v3.9.1 Hotfix] Reverting native database test fixes for ${client}...`);
89
+ // Revert Fix 1: Restore path length to 768 (MySQL only)
90
+ if (isMySQL) {
91
+ const hasTable = await knex.schema.hasTable('m_files');
92
+ if (hasTable) {
93
+ // Drop UNIQUE constraint
94
+ try {
95
+ await knex.schema.alterTable('m_files', (table) => {
96
+ table.dropUnique(['project_id', 'path']);
97
+ });
98
+ console.log(' ✓ Dropped UNIQUE constraint on (project_id, path)');
99
+ }
100
+ catch (error) {
101
+ console.log(` ⓘ No UNIQUE constraint to drop (${error.message})`);
102
+ }
103
+ // Restore column to 768 characters
104
+ await knex.schema.alterTable('m_files', (table) => {
105
+ table.string('path', 768).notNullable().alter();
106
+ });
107
+ console.log(' ✓ Restored path column to 768 characters');
108
+ // Re-create UNIQUE constraint
109
+ await knex.schema.alterTable('m_files', (table) => {
110
+ table.unique(['project_id', 'path']);
111
+ });
112
+ console.log(' ✓ Re-created UNIQUE constraint on (project_id, path)');
113
+ }
114
+ }
115
+ // Fix 2: Cannot restore view because t_agent_messages table no longer exists
116
+ console.log(' ⓘ Cannot restore v_unread_messages_by_priority (t_agent_messages table removed in v3.6.5)');
117
+ console.log('✅ [v3.9.1 Hotfix] Rollback completed\n');
118
+ }
119
+ //# sourceMappingURL=20251118000000_fix_native_db_test_issues_v3_9_1.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20251118000000_fix_native_db_test_issues_v3_9_1.js","sourceRoot":"","sources":["../../../../src/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;;;;;GAeG;AAEH,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC;IACzC,MAAM,OAAO,GAAG,MAAM,KAAK,QAAQ,IAAI,MAAM,KAAK,OAAO,CAAC;IAC1D,MAAM,QAAQ,GAAG,MAAM,KAAK,gBAAgB,IAAI,MAAM,KAAK,SAAS,CAAC;IAErE,OAAO,CAAC,GAAG,CAAC,+DAA+D,MAAM,KAAK,CAAC,CAAC;IAExF,2EAA2E;IAC3E,0DAA0D;IAC1D,2EAA2E;IAC3E,IAAI,OAAO,EAAE,CAAC;QACZ,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEvD,IAAI,QAAQ,EAAE,CAAC;YACb,2CAA2C;YAC3C,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,4BAA4B,CAAC;iBACrD,MAAM,CAAC,wCAAwC,CAAC;iBAChD,KAAK,CAAC;gBACL,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;gBACpC,UAAU,EAAE,SAAS;gBACrB,WAAW,EAAE,MAAM;aACpB,CAAC;iBACD,KAAK,EAAE,CAAC;YAEX,IAAI,OAAO,IAAI,OAAO,CAAC,UAAU,GAAG,GAAG,EAAE,CAAC;gBACxC,OAAO,CAAC,GAAG,CAAC,yBAAyB,OAAO,CAAC,UAAU,4CAA4C,CAAC,CAAC;gBAErG,+CAA+C;gBAC/C,IAAI,CAAC;oBACH,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;wBAChD,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,CAAC;oBAC3C,CAAC,CAAC,CAAC;oBACH,OAAO,CAAC,GAAG,CAAC,8DAA8D,CAAC,CAAC;gBAC9E,CAAC;gBAAC,OAAO,KAAU,EAAE,CAAC;oBACpB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,8BAA8B,CAAC,EAAE,CAAC;wBAC5D,OAAO,CAAC,GAAG,CAAC,8CAA8C,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;oBAC9E,CAAC;gBACH,CAAC;gBAED,kCAAkC;gBAClC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;oBAChD,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,CAAC;gBAClD,CAAC,CAAC,CAAC;gBACH,OAAO,CAAC,GAAG,CAAC,2CAA2C,CAAC,CAAC;gBAEzD,8BAA8B;gBAC9B,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;oBAChD,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,CAAC;gBACvC,CAAC,CAAC,CAAC;gBACH,OAAO,CAAC,GAAG,CAAC,wDAAwD,CAAC,CAAC;YACxE,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,GAAG,CAAC,gDAAgD,CAAC,CAAC;YAChE,CAAC;QACH,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,4EAA4E,CAAC,CAAC;QAC5F,CAAC;IACH,CAAC;IAED,2EAA2E;IAC3E,0DAA0D;IAC1D,2EAA2E;IAC3E,oEAAoE;IACpE,qFAAqF;IACrF,6GAA6G;IAE7G,IAAI,CAAC;QACH,MAAM,IAAI,CAAC,GAAG,CAAC,mDAAmD,CAAC,CAAC;QACpE,OAAO,CAAC,GAAG,CAAC,sFAAsF,CAAC,CAAC;IACtG,CAAC;IAAC,OAAO,KAAU,EAAE,CAAC;QACpB,OAAO,CAAC,GAAG,CAAC,4BAA4B,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;IAC3D,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,qEAAqE,CAAC,CAAC;AACrF,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC;IACzC,MAAM,OAAO,GAAG,MAAM,KAAK,QAAQ,IAAI,MAAM,KAAK,OAAO,CAAC;IAE1D,OAAO,CAAC,GAAG,CAAC,iEAAiE,MAAM,KAAK,CAAC,CAAC;IAE1F,wDAAwD;IACxD,IAAI,OAAO,EAAE,CAAC;QACZ,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEvD,IAAI,QAAQ,EAAE,CAAC;YACb,yBAAyB;YACzB,IAAI,CAAC;gBACH,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;oBAChD,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,CAAC;gBAC3C,CAAC,CAAC,CAAC;gBACH,OAAO,CAAC,GAAG,CAAC,qDAAqD,CAAC,CAAC;YACrE,CAAC;YAAC,OAAO,KAAU,EAAE,CAAC;gBACpB,OAAO,CAAC,GAAG,CAAC,qCAAqC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;YACrE,CAAC;YAED,mCAAmC;YACnC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;gBAChD,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,CAAC;YAClD,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,4CAA4C,CAAC,CAAC;YAE1D,8BAA8B;YAC9B,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE;gBAChD,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,wDAAwD,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAED,6EAA6E;IAC7E,OAAO,CAAC,GAAG,CAAC,6FAA6F,CAAC,CAAC;IAE3G,OAAO,CAAC,GAAG,CAAC,wCAAwC,CAAC,CAAC;AACxD,CAAC"}
@@ -0,0 +1,19 @@
1
+ import type { Knex } from "knex";
2
+ /**
3
+ * Migration: Pre-emptive Cross-Database Compatibility Fix (v3.9.0)
4
+ *
5
+ * Purpose: This migration runs BEFORE 20251112000000_decision_intelligence_v3_9_0.ts
6
+ * to add problematic columns with database-aware syntax.
7
+ *
8
+ * Problem: The original migration uses SQLite-specific strftime('%s', 'now')
9
+ * which fails on PostgreSQL/MySQL.
10
+ *
11
+ * Solution: Add the columns here with proper cross-database syntax, then the
12
+ * original migration will detect them and skip (due to hasColumn checks).
13
+ *
14
+ * Note: This is a hotfix migration. We cannot edit the pushed upgrade migration.
15
+ * Timestamp 20251111235959 ensures this runs just before 20251112000000.
16
+ */
17
+ export declare function up(knex: Knex): Promise<void>;
18
+ export declare function down(knex: Knex): Promise<void>;
19
+ //# sourceMappingURL=20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts","sourceRoot":"","sources":["../../../../src/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC;;;;;;;;;;;;;;GAcG;AAEH,wBAAsB,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAwMlD;AAED,wBAAsB,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAYpD"}
@@ -0,0 +1,196 @@
1
+ /**
2
+ * Migration: Pre-emptive Cross-Database Compatibility Fix (v3.9.0)
3
+ *
4
+ * Purpose: This migration runs BEFORE 20251112000000_decision_intelligence_v3_9_0.ts
5
+ * to add problematic columns with database-aware syntax.
6
+ *
7
+ * Problem: The original migration uses SQLite-specific strftime('%s', 'now')
8
+ * which fails on PostgreSQL/MySQL.
9
+ *
10
+ * Solution: Add the columns here with proper cross-database syntax, then the
11
+ * original migration will detect them and skip (due to hasColumn checks).
12
+ *
13
+ * Note: This is a hotfix migration. We cannot edit the pushed upgrade migration.
14
+ * Timestamp 20251111235959 ensures this runs just before 20251112000000.
15
+ */
16
+ export async function up(knex) {
17
+ const client = knex.client.config.client;
18
+ const isSQLite = client === 'sqlite3' || client === 'better-sqlite3';
19
+ // Only run on MySQL/PostgreSQL - let original migration handle SQLite
20
+ if (isSQLite) {
21
+ console.log('✓ SQLite: Skipping pre-emptive fix (original migration works fine)');
22
+ return;
23
+ }
24
+ console.log(`🔧 Pre-emptive cross-database fix for ${client}...`);
25
+ // ============================================================================
26
+ // Pre-fix t_decision_policies columns (before 20251112000000 runs)
27
+ // ============================================================================
28
+ const hasPoliciesTable = await knex.schema.hasTable('t_decision_policies');
29
+ if (!hasPoliciesTable) {
30
+ // Create table with proper cross-database syntax (no strftime)
31
+ console.log(' ⏭️ Pre-creating t_decision_policies table...');
32
+ const currentTs = Math.floor(Date.now() / 1000);
33
+ await knex.schema.createTable('t_decision_policies', (table) => {
34
+ table.increments('id').primary();
35
+ table.string('name', 200).notNullable();
36
+ table.integer('project_id').notNullable().references('id').inTable('m_projects').onDelete('CASCADE');
37
+ table.text('description');
38
+ table.text('defaults'); // JSON
39
+ table.text('required_fields'); // JSON
40
+ table.integer('created_by').nullable().references('id').inTable('m_agents').onDelete('SET NULL');
41
+ table.integer('ts').notNullable().defaultTo(currentTs);
42
+ // UNIQUE constraint on (name, project_id)
43
+ table.unique(['name', 'project_id']);
44
+ });
45
+ console.log(' ✅ Pre-created t_decision_policies table');
46
+ }
47
+ else {
48
+ const hasProjectId = await knex.schema.hasColumn('t_decision_policies', 'project_id');
49
+ const hasCreatedBy = await knex.schema.hasColumn('t_decision_policies', 'created_by');
50
+ const hasTs = await knex.schema.hasColumn('t_decision_policies', 'ts');
51
+ if (!hasProjectId || !hasCreatedBy || !hasTs) {
52
+ console.log(' ⏭️ Pre-adding columns to t_decision_policies...');
53
+ await knex.schema.alterTable('t_decision_policies', (table) => {
54
+ if (!hasProjectId) {
55
+ table.integer('project_id').notNullable().defaultTo(1);
56
+ }
57
+ if (!hasCreatedBy) {
58
+ table.integer('created_by').nullable();
59
+ }
60
+ if (!hasTs) {
61
+ // Add as nullable first, then populate and make NOT NULL
62
+ table.integer('ts').nullable();
63
+ }
64
+ });
65
+ // Populate ts column with current timestamp if it was just created
66
+ if (!hasTs) {
67
+ const currentTs = Math.floor(Date.now() / 1000);
68
+ await knex('t_decision_policies').update({ ts: currentTs });
69
+ // Make ts NOT NULL with database-specific syntax
70
+ const isMySQL = client === 'mysql2' || client === 'mysql';
71
+ const isPostgreSQL = client === 'pg' || client === 'postgresql';
72
+ if (isMySQL) {
73
+ await knex.raw('ALTER TABLE t_decision_policies MODIFY ts INT NOT NULL');
74
+ }
75
+ else if (isPostgreSQL) {
76
+ await knex.raw('ALTER TABLE t_decision_policies ALTER COLUMN ts SET NOT NULL');
77
+ }
78
+ }
79
+ console.log(' ✅ Pre-added columns to t_decision_policies');
80
+ }
81
+ else {
82
+ console.log(' ✓ Columns already exist, skipping');
83
+ }
84
+ }
85
+ // ============================================================================
86
+ // Pre-create m_tag_index table (with VARCHAR instead of TEXT)
87
+ // ============================================================================
88
+ const hasTagIndex = await knex.schema.hasTable('m_tag_index');
89
+ if (!hasTagIndex) {
90
+ console.log(' ⏭️ Pre-creating m_tag_index table...');
91
+ await knex.schema.createTable('m_tag_index', (table) => {
92
+ // Use VARCHAR(191) instead of TEXT for PRIMARY KEY (MySQL/MariaDB requirement)
93
+ table.string('tag_name', 191).notNullable();
94
+ table.integer('decision_count').notNullable().defaultTo(0);
95
+ table.integer('constraint_count').notNullable().defaultTo(0);
96
+ table.integer('task_count').notNullable().defaultTo(0);
97
+ table.integer('total_count').notNullable().defaultTo(0);
98
+ table.primary(['tag_name']);
99
+ });
100
+ console.log(' ✅ Pre-created m_tag_index table');
101
+ }
102
+ else {
103
+ console.log(' ✓ m_tag_index already exists');
104
+ }
105
+ // ============================================================================
106
+ // Pre-create t_decision_pruning_log table
107
+ // ============================================================================
108
+ const hasPruningLog = await knex.schema.hasTable('t_decision_pruning_log');
109
+ if (!hasPruningLog) {
110
+ console.log(' ⏭️ Pre-creating t_decision_pruning_log table...');
111
+ await knex.schema.createTable('t_decision_pruning_log', (table) => {
112
+ table.increments('id').primary();
113
+ table.integer('original_decision_id').notNullable();
114
+ table.string('original_key', 256).notNullable();
115
+ table.text('original_value').notNullable();
116
+ table.integer('original_version').notNullable();
117
+ table.bigInteger('original_ts').notNullable();
118
+ table.integer('project_id').notNullable().defaultTo(1);
119
+ // Add pruned_ts as nullable first
120
+ table.bigInteger('pruned_ts').nullable();
121
+ });
122
+ // Populate pruned_ts with current timestamp (if table just created, no rows yet)
123
+ // This is for future rows - current table is empty
124
+ const isMySQL = client === 'mysql2' || client === 'mysql';
125
+ const isPostgreSQL = client === 'pg' || client === 'postgresql';
126
+ // Make pruned_ts NOT NULL
127
+ if (isMySQL) {
128
+ await knex.raw('ALTER TABLE t_decision_pruning_log MODIFY pruned_ts BIGINT NOT NULL');
129
+ }
130
+ else if (isPostgreSQL) {
131
+ await knex.raw('ALTER TABLE t_decision_pruning_log ALTER COLUMN pruned_ts SET NOT NULL');
132
+ }
133
+ console.log(' ✅ Pre-created t_decision_pruning_log table');
134
+ }
135
+ else {
136
+ console.log(' ✓ t_decision_pruning_log already exists');
137
+ }
138
+ // ============================================================================
139
+ // Pre-create t_task_pruned_files table
140
+ // ============================================================================
141
+ const hasPrunedFilesTable = await knex.schema.hasTable('t_task_pruned_files');
142
+ if (!hasPrunedFilesTable) {
143
+ console.log(' ⏭️ Pre-creating t_task_pruned_files table...');
144
+ await knex.schema.createTable('t_task_pruned_files', (table) => {
145
+ table.increments('id').primary();
146
+ table.integer('task_id').notNullable()
147
+ .references('id').inTable('t_tasks').onDelete('CASCADE');
148
+ table.string('file_path', 500).notNullable();
149
+ table.bigInteger('pruned_ts').notNullable().defaultTo(Math.floor(Date.now() / 1000));
150
+ table.integer('linked_decision_key_id').nullable()
151
+ .references('id').inTable('m_context_keys').onDelete('SET NULL');
152
+ table.integer('project_id').notNullable()
153
+ .references('id').inTable('m_projects').onDelete('CASCADE');
154
+ // UNIQUE constraint on (task_id, file_path)
155
+ table.unique(['task_id', 'file_path']);
156
+ });
157
+ console.log(' ✅ Pre-created t_task_pruned_files table');
158
+ }
159
+ else {
160
+ console.log(' ✓ t_task_pruned_files already exists');
161
+ }
162
+ // ============================================================================
163
+ // Pre-create system agent (to prevent INSERT destructuring error)
164
+ // ============================================================================
165
+ const systemAgent = await knex('m_agents').where('name', 'system').first();
166
+ if (!systemAgent) {
167
+ console.log(' ⏭️ Pre-creating system agent...');
168
+ const isMySQL = client === 'mysql2' || client === 'mysql';
169
+ const isPostgreSQL = client === 'pg' || client === 'postgresql';
170
+ if (isPostgreSQL || isMySQL) {
171
+ // Use returning() for databases that support it
172
+ await knex('m_agents').insert({
173
+ name: 'system',
174
+ last_active_ts: Math.floor(Date.now() / 1000)
175
+ });
176
+ }
177
+ console.log(' ✅ Pre-created system agent');
178
+ }
179
+ else {
180
+ console.log(' ✓ System agent already exists');
181
+ }
182
+ console.log('✅ Pre-emptive cross-database fix completed successfully');
183
+ console.log(' Original migration will detect these changes and skip problematic steps');
184
+ }
185
+ export async function down(knex) {
186
+ const client = knex.client.config.client;
187
+ const isSQLite = client === 'sqlite3' || client === 'better-sqlite3';
188
+ if (isSQLite) {
189
+ console.log('✓ SQLite: No rollback needed');
190
+ return;
191
+ }
192
+ // This is a pre-emptive hotfix, so down() should not break the database
193
+ console.log('⚠️ Pre-emptive fix rollback: Not dropping columns/tables to preserve data');
194
+ console.log(' The original migration owns these structures');
195
+ }
196
+ //# sourceMappingURL=20251111235959_preemptive_fix_cross_database_v3_9_0.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20251111235959_preemptive_fix_cross_database_v3_9_0.js","sourceRoot":"","sources":["../../../../src/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Migration: Decision Intelligence System v3.9.0
3
+ *
4
+ * Transforms template system into comprehensive Decision Intelligence System:
5
+ * 1. Renames t_decision_templates → t_decision_policies
6
+ * 2. Adds validation_rules, quality_gates, suggest_similar, category columns
7
+ * 3. Creates m_tag_index for fast tag-based suggestions
8
+ * 4. Populates tag index from existing data
9
+ * 5. Adds auto-population trigger (SQLite only, MySQL/PostgreSQL pending)
10
+ * 6. Updates built-in policies with validation rules and quality gates
11
+ * 7. Creates t_task_pruned_files table (missing from bootstrap schema)
12
+ *
13
+ * Satisfies Constraints:
14
+ * - #398: Policy schema changes for Decision Intelligence System
15
+ * - Fixes missing t_task_pruned_files table in fresh installations
16
+ * - Idempotent: Can be run multiple times safely
17
+ * - Cross-DB Compatible: SQLite (full), MySQL/PostgreSQL (partial trigger support)
18
+ */
19
+ import type { Knex } from 'knex';
20
+ export declare function up(knex: Knex): Promise<void>;
21
+ export declare function down(knex: Knex): Promise<void>;
22
+ //# sourceMappingURL=20251112000000_decision_intelligence_v3_9_0.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"20251112000000_decision_intelligence_v3_9_0.d.ts","sourceRoot":"","sources":["../../../../src/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC,wBAAsB,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAoVlD;AAED,wBAAsB,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAqDpD"}