moflo 4.8.19 → 4.8.20

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 (241) hide show
  1. package/.claude/guidance/shipped/moflo.md +45 -0
  2. package/.claude/helpers/statusline.cjs +1 -1
  3. package/.claude/workflow-state.json +9 -0
  4. package/package.json +2 -2
  5. package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +1 -1
  6. package/src/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +5 -3
  7. package/src/@claude-flow/cli/package.json +1 -1
  8. package/src/@claude-flow/memory/dist/agent-memory-scope.d.ts +131 -0
  9. package/src/@claude-flow/memory/dist/agent-memory-scope.js +223 -0
  10. package/src/@claude-flow/memory/dist/agent-memory-scope.test.d.ts +8 -0
  11. package/src/@claude-flow/memory/dist/agent-memory-scope.test.js +466 -0
  12. package/src/@claude-flow/memory/dist/agentdb-adapter.d.ts +165 -0
  13. package/src/@claude-flow/memory/dist/agentdb-adapter.js +806 -0
  14. package/src/@claude-flow/memory/dist/agentdb-backend.d.ts +212 -0
  15. package/src/@claude-flow/memory/dist/agentdb-backend.js +842 -0
  16. package/src/@claude-flow/memory/dist/agentdb-backend.test.d.ts +7 -0
  17. package/src/@claude-flow/memory/dist/agentdb-backend.test.js +258 -0
  18. package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.d.ts +65 -0
  19. package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.js +129 -0
  20. package/src/@claude-flow/memory/dist/application/commands/store-memory.command.d.ts +48 -0
  21. package/src/@claude-flow/memory/dist/application/commands/store-memory.command.js +72 -0
  22. package/src/@claude-flow/memory/dist/application/index.d.ts +12 -0
  23. package/src/@claude-flow/memory/dist/application/index.js +15 -0
  24. package/src/@claude-flow/memory/dist/application/queries/search-memory.query.d.ts +72 -0
  25. package/src/@claude-flow/memory/dist/application/queries/search-memory.query.js +143 -0
  26. package/src/@claude-flow/memory/dist/application/services/memory-application-service.d.ts +121 -0
  27. package/src/@claude-flow/memory/dist/application/services/memory-application-service.js +190 -0
  28. package/src/@claude-flow/memory/dist/auto-memory-bridge.d.ts +226 -0
  29. package/src/@claude-flow/memory/dist/auto-memory-bridge.js +709 -0
  30. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.d.ts +8 -0
  31. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +757 -0
  32. package/src/@claude-flow/memory/dist/benchmark.test.d.ts +2 -0
  33. package/src/@claude-flow/memory/dist/benchmark.test.js +277 -0
  34. package/src/@claude-flow/memory/dist/cache-manager.d.ts +134 -0
  35. package/src/@claude-flow/memory/dist/cache-manager.js +407 -0
  36. package/src/@claude-flow/memory/dist/controller-registry.d.ts +216 -0
  37. package/src/@claude-flow/memory/dist/controller-registry.js +893 -0
  38. package/src/@claude-flow/memory/dist/controller-registry.test.d.ts +14 -0
  39. package/src/@claude-flow/memory/dist/controller-registry.test.js +593 -0
  40. package/src/@claude-flow/memory/dist/database-provider.d.ts +87 -0
  41. package/src/@claude-flow/memory/dist/database-provider.js +372 -0
  42. package/src/@claude-flow/memory/dist/database-provider.test.d.ts +7 -0
  43. package/src/@claude-flow/memory/dist/database-provider.test.js +287 -0
  44. package/src/@claude-flow/memory/dist/domain/entities/memory-entry.d.ts +143 -0
  45. package/src/@claude-flow/memory/dist/domain/entities/memory-entry.js +226 -0
  46. package/src/@claude-flow/memory/dist/domain/index.d.ts +11 -0
  47. package/src/@claude-flow/memory/dist/domain/index.js +12 -0
  48. package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.d.ts +102 -0
  49. package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.js +11 -0
  50. package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.d.ts +105 -0
  51. package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.js +297 -0
  52. package/src/@claude-flow/memory/dist/hnsw-index.d.ts +111 -0
  53. package/src/@claude-flow/memory/dist/hnsw-index.js +781 -0
  54. package/src/@claude-flow/memory/dist/hnsw-lite.d.ts +23 -0
  55. package/src/@claude-flow/memory/dist/hnsw-lite.js +168 -0
  56. package/src/@claude-flow/memory/dist/index.d.ts +204 -0
  57. package/src/@claude-flow/memory/dist/index.js +358 -0
  58. package/src/@claude-flow/memory/dist/infrastructure/index.d.ts +17 -0
  59. package/src/@claude-flow/memory/dist/infrastructure/index.js +16 -0
  60. package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.d.ts +66 -0
  61. package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.js +409 -0
  62. package/src/@claude-flow/memory/dist/learning-bridge.d.ts +137 -0
  63. package/src/@claude-flow/memory/dist/learning-bridge.js +335 -0
  64. package/src/@claude-flow/memory/dist/learning-bridge.test.d.ts +8 -0
  65. package/src/@claude-flow/memory/dist/learning-bridge.test.js +578 -0
  66. package/src/@claude-flow/memory/dist/memory-graph.d.ts +100 -0
  67. package/src/@claude-flow/memory/dist/memory-graph.js +333 -0
  68. package/src/@claude-flow/memory/dist/memory-graph.test.d.ts +8 -0
  69. package/src/@claude-flow/memory/dist/memory-graph.test.js +609 -0
  70. package/src/@claude-flow/memory/dist/migration.d.ts +68 -0
  71. package/src/@claude-flow/memory/dist/migration.js +513 -0
  72. package/src/@claude-flow/memory/dist/persistent-sona.d.ts +144 -0
  73. package/src/@claude-flow/memory/dist/persistent-sona.js +332 -0
  74. package/src/@claude-flow/memory/dist/query-builder.d.ts +211 -0
  75. package/src/@claude-flow/memory/dist/query-builder.js +438 -0
  76. package/src/@claude-flow/memory/dist/rvf-backend.d.ts +51 -0
  77. package/src/@claude-flow/memory/dist/rvf-backend.js +481 -0
  78. package/src/@claude-flow/memory/dist/rvf-learning-store.d.ts +139 -0
  79. package/src/@claude-flow/memory/dist/rvf-learning-store.js +295 -0
  80. package/src/@claude-flow/memory/dist/rvf-migration.d.ts +45 -0
  81. package/src/@claude-flow/memory/dist/rvf-migration.js +234 -0
  82. package/src/@claude-flow/memory/dist/sqljs-backend.d.ts +127 -0
  83. package/src/@claude-flow/memory/dist/sqljs-backend.js +600 -0
  84. package/src/@claude-flow/memory/dist/types.d.ts +484 -0
  85. package/src/@claude-flow/memory/dist/types.js +58 -0
  86. package/src/@claude-flow/shared/dist/core/config/defaults.d.ts +41 -0
  87. package/src/@claude-flow/shared/dist/core/config/defaults.js +186 -0
  88. package/src/@claude-flow/shared/dist/core/config/index.d.ts +8 -0
  89. package/src/@claude-flow/shared/dist/core/config/index.js +12 -0
  90. package/src/@claude-flow/shared/dist/core/config/loader.d.ts +45 -0
  91. package/src/@claude-flow/shared/dist/core/config/loader.js +222 -0
  92. package/src/@claude-flow/shared/dist/core/config/schema.d.ts +1134 -0
  93. package/src/@claude-flow/shared/dist/core/config/schema.js +158 -0
  94. package/src/@claude-flow/shared/dist/core/config/validator.d.ts +92 -0
  95. package/src/@claude-flow/shared/dist/core/config/validator.js +147 -0
  96. package/src/@claude-flow/shared/dist/core/event-bus.d.ts +31 -0
  97. package/src/@claude-flow/shared/dist/core/event-bus.js +197 -0
  98. package/src/@claude-flow/shared/dist/core/index.d.ts +15 -0
  99. package/src/@claude-flow/shared/dist/core/index.js +19 -0
  100. package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +200 -0
  101. package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.js +6 -0
  102. package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +310 -0
  103. package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +7 -0
  104. package/src/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +224 -0
  105. package/src/@claude-flow/shared/dist/core/interfaces/event.interface.js +46 -0
  106. package/src/@claude-flow/shared/dist/core/interfaces/index.d.ts +10 -0
  107. package/src/@claude-flow/shared/dist/core/interfaces/index.js +15 -0
  108. package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +298 -0
  109. package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.js +7 -0
  110. package/src/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +185 -0
  111. package/src/@claude-flow/shared/dist/core/interfaces/task.interface.js +6 -0
  112. package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +35 -0
  113. package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +101 -0
  114. package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +60 -0
  115. package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +166 -0
  116. package/src/@claude-flow/shared/dist/core/orchestrator/index.d.ts +46 -0
  117. package/src/@claude-flow/shared/dist/core/orchestrator/index.js +64 -0
  118. package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
  119. package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +195 -0
  120. package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +83 -0
  121. package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.js +193 -0
  122. package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +49 -0
  123. package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.js +253 -0
  124. package/src/@claude-flow/shared/dist/events/domain-events.d.ts +282 -0
  125. package/src/@claude-flow/shared/dist/events/domain-events.js +165 -0
  126. package/src/@claude-flow/shared/dist/events/event-store.d.ts +126 -0
  127. package/src/@claude-flow/shared/dist/events/event-store.js +432 -0
  128. package/src/@claude-flow/shared/dist/events/event-store.test.d.ts +8 -0
  129. package/src/@claude-flow/shared/dist/events/event-store.test.js +297 -0
  130. package/src/@claude-flow/shared/dist/events/example-usage.d.ts +10 -0
  131. package/src/@claude-flow/shared/dist/events/example-usage.js +193 -0
  132. package/src/@claude-flow/shared/dist/events/index.d.ts +21 -0
  133. package/src/@claude-flow/shared/dist/events/index.js +22 -0
  134. package/src/@claude-flow/shared/dist/events/projections.d.ts +177 -0
  135. package/src/@claude-flow/shared/dist/events/projections.js +421 -0
  136. package/src/@claude-flow/shared/dist/events/rvf-event-log.d.ts +82 -0
  137. package/src/@claude-flow/shared/dist/events/rvf-event-log.js +340 -0
  138. package/src/@claude-flow/shared/dist/events/state-reconstructor.d.ts +101 -0
  139. package/src/@claude-flow/shared/dist/events/state-reconstructor.js +263 -0
  140. package/src/@claude-flow/shared/dist/events.d.ts +80 -0
  141. package/src/@claude-flow/shared/dist/events.js +249 -0
  142. package/src/@claude-flow/shared/dist/hooks/example-usage.d.ts +42 -0
  143. package/src/@claude-flow/shared/dist/hooks/example-usage.js +351 -0
  144. package/src/@claude-flow/shared/dist/hooks/executor.d.ts +100 -0
  145. package/src/@claude-flow/shared/dist/hooks/executor.js +267 -0
  146. package/src/@claude-flow/shared/dist/hooks/hooks.test.d.ts +9 -0
  147. package/src/@claude-flow/shared/dist/hooks/hooks.test.js +322 -0
  148. package/src/@claude-flow/shared/dist/hooks/index.d.ts +52 -0
  149. package/src/@claude-flow/shared/dist/hooks/index.js +51 -0
  150. package/src/@claude-flow/shared/dist/hooks/registry.d.ts +133 -0
  151. package/src/@claude-flow/shared/dist/hooks/registry.js +277 -0
  152. package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +105 -0
  153. package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.js +481 -0
  154. package/src/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +144 -0
  155. package/src/@claude-flow/shared/dist/hooks/safety/file-organization.js +328 -0
  156. package/src/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +158 -0
  157. package/src/@claude-flow/shared/dist/hooks/safety/git-commit.js +450 -0
  158. package/src/@claude-flow/shared/dist/hooks/safety/index.d.ts +17 -0
  159. package/src/@claude-flow/shared/dist/hooks/safety/index.js +17 -0
  160. package/src/@claude-flow/shared/dist/hooks/session-hooks.d.ts +234 -0
  161. package/src/@claude-flow/shared/dist/hooks/session-hooks.js +334 -0
  162. package/src/@claude-flow/shared/dist/hooks/task-hooks.d.ts +163 -0
  163. package/src/@claude-flow/shared/dist/hooks/task-hooks.js +326 -0
  164. package/src/@claude-flow/shared/dist/hooks/types.d.ts +267 -0
  165. package/src/@claude-flow/shared/dist/hooks/types.js +62 -0
  166. package/src/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +9 -0
  167. package/src/@claude-flow/shared/dist/hooks/verify-exports.test.js +93 -0
  168. package/src/@claude-flow/shared/dist/index.d.ts +20 -0
  169. package/src/@claude-flow/shared/dist/index.js +50 -0
  170. package/src/@claude-flow/shared/dist/mcp/connection-pool.d.ts +98 -0
  171. package/src/@claude-flow/shared/dist/mcp/connection-pool.js +364 -0
  172. package/src/@claude-flow/shared/dist/mcp/index.d.ts +69 -0
  173. package/src/@claude-flow/shared/dist/mcp/index.js +84 -0
  174. package/src/@claude-flow/shared/dist/mcp/server.d.ts +166 -0
  175. package/src/@claude-flow/shared/dist/mcp/server.js +593 -0
  176. package/src/@claude-flow/shared/dist/mcp/session-manager.d.ts +136 -0
  177. package/src/@claude-flow/shared/dist/mcp/session-manager.js +335 -0
  178. package/src/@claude-flow/shared/dist/mcp/tool-registry.d.ts +178 -0
  179. package/src/@claude-flow/shared/dist/mcp/tool-registry.js +439 -0
  180. package/src/@claude-flow/shared/dist/mcp/transport/http.d.ts +104 -0
  181. package/src/@claude-flow/shared/dist/mcp/transport/http.js +476 -0
  182. package/src/@claude-flow/shared/dist/mcp/transport/index.d.ts +102 -0
  183. package/src/@claude-flow/shared/dist/mcp/transport/index.js +238 -0
  184. package/src/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +104 -0
  185. package/src/@claude-flow/shared/dist/mcp/transport/stdio.js +263 -0
  186. package/src/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +133 -0
  187. package/src/@claude-flow/shared/dist/mcp/transport/websocket.js +396 -0
  188. package/src/@claude-flow/shared/dist/mcp/types.d.ts +438 -0
  189. package/src/@claude-flow/shared/dist/mcp/types.js +54 -0
  190. package/src/@claude-flow/shared/dist/plugin-interface.d.ts +544 -0
  191. package/src/@claude-flow/shared/dist/plugin-interface.js +23 -0
  192. package/src/@claude-flow/shared/dist/plugin-loader.d.ts +139 -0
  193. package/src/@claude-flow/shared/dist/plugin-loader.js +434 -0
  194. package/src/@claude-flow/shared/dist/plugin-registry.d.ts +183 -0
  195. package/src/@claude-flow/shared/dist/plugin-registry.js +457 -0
  196. package/src/@claude-flow/shared/dist/plugins/index.d.ts +10 -0
  197. package/src/@claude-flow/shared/dist/plugins/index.js +10 -0
  198. package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
  199. package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +241 -0
  200. package/src/@claude-flow/shared/dist/plugins/official/index.d.ts +10 -0
  201. package/src/@claude-flow/shared/dist/plugins/official/index.js +10 -0
  202. package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +121 -0
  203. package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +355 -0
  204. package/src/@claude-flow/shared/dist/plugins/types.d.ts +93 -0
  205. package/src/@claude-flow/shared/dist/plugins/types.js +9 -0
  206. package/src/@claude-flow/shared/dist/resilience/bulkhead.d.ts +105 -0
  207. package/src/@claude-flow/shared/dist/resilience/bulkhead.js +206 -0
  208. package/src/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +132 -0
  209. package/src/@claude-flow/shared/dist/resilience/circuit-breaker.js +233 -0
  210. package/src/@claude-flow/shared/dist/resilience/index.d.ts +19 -0
  211. package/src/@claude-flow/shared/dist/resilience/index.js +19 -0
  212. package/src/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +168 -0
  213. package/src/@claude-flow/shared/dist/resilience/rate-limiter.js +314 -0
  214. package/src/@claude-flow/shared/dist/resilience/retry.d.ts +91 -0
  215. package/src/@claude-flow/shared/dist/resilience/retry.js +159 -0
  216. package/src/@claude-flow/shared/dist/security/index.d.ts +10 -0
  217. package/src/@claude-flow/shared/dist/security/index.js +12 -0
  218. package/src/@claude-flow/shared/dist/security/input-validation.d.ts +73 -0
  219. package/src/@claude-flow/shared/dist/security/input-validation.js +201 -0
  220. package/src/@claude-flow/shared/dist/security/secure-random.d.ts +92 -0
  221. package/src/@claude-flow/shared/dist/security/secure-random.js +142 -0
  222. package/src/@claude-flow/shared/dist/services/index.d.ts +7 -0
  223. package/src/@claude-flow/shared/dist/services/index.js +7 -0
  224. package/src/@claude-flow/shared/dist/services/v3-progress.service.d.ts +124 -0
  225. package/src/@claude-flow/shared/dist/services/v3-progress.service.js +402 -0
  226. package/src/@claude-flow/shared/dist/types/agent.types.d.ts +137 -0
  227. package/src/@claude-flow/shared/dist/types/agent.types.js +6 -0
  228. package/src/@claude-flow/shared/dist/types/index.d.ts +11 -0
  229. package/src/@claude-flow/shared/dist/types/index.js +17 -0
  230. package/src/@claude-flow/shared/dist/types/mcp.types.d.ts +266 -0
  231. package/src/@claude-flow/shared/dist/types/mcp.types.js +7 -0
  232. package/src/@claude-flow/shared/dist/types/memory.types.d.ts +236 -0
  233. package/src/@claude-flow/shared/dist/types/memory.types.js +7 -0
  234. package/src/@claude-flow/shared/dist/types/swarm.types.d.ts +186 -0
  235. package/src/@claude-flow/shared/dist/types/swarm.types.js +65 -0
  236. package/src/@claude-flow/shared/dist/types/task.types.d.ts +178 -0
  237. package/src/@claude-flow/shared/dist/types/task.types.js +32 -0
  238. package/src/@claude-flow/shared/dist/types.d.ts +197 -0
  239. package/src/@claude-flow/shared/dist/types.js +21 -0
  240. package/src/@claude-flow/shared/dist/utils/secure-logger.d.ts +69 -0
  241. package/src/@claude-flow/shared/dist/utils/secure-logger.js +208 -0
@@ -0,0 +1,450 @@
1
+ /**
2
+ * V3 Git Commit Hook
3
+ *
4
+ * TypeScript conversion of V2 git-commit-hook.sh.
5
+ * Provides conventional commit formatting, JIRA ticket extraction,
6
+ * co-author addition, and commit message validation.
7
+ *
8
+ * @module v3/shared/hooks/safety/git-commit
9
+ */
10
+ import { HookEvent, HookPriority, } from '../types.js';
11
+ const COMMIT_TYPE_PATTERNS = [
12
+ {
13
+ keywords: ['add', 'implement', 'create', 'introduce', 'new'],
14
+ type: 'feat',
15
+ description: 'A new feature',
16
+ },
17
+ {
18
+ keywords: ['fix', 'resolve', 'repair', 'patch', 'correct', 'bug'],
19
+ type: 'fix',
20
+ description: 'A bug fix',
21
+ },
22
+ {
23
+ keywords: ['doc', 'docs', 'readme', 'comment', 'documentation'],
24
+ type: 'docs',
25
+ description: 'Documentation changes',
26
+ },
27
+ {
28
+ keywords: ['style', 'format', 'lint', 'whitespace', 'prettier'],
29
+ type: 'style',
30
+ description: 'Code style changes',
31
+ },
32
+ {
33
+ keywords: ['refactor', 'restructure', 'reorganize', 'extract', 'simplify'],
34
+ type: 'refactor',
35
+ description: 'Code refactoring',
36
+ },
37
+ {
38
+ keywords: ['perf', 'performance', 'optimize', 'speed', 'faster'],
39
+ type: 'perf',
40
+ description: 'Performance improvements',
41
+ },
42
+ {
43
+ keywords: ['test', 'tests', 'spec', 'coverage', 'unittest'],
44
+ type: 'test',
45
+ description: 'Adding or updating tests',
46
+ },
47
+ {
48
+ keywords: ['build', 'webpack', 'rollup', 'vite', 'esbuild', 'package'],
49
+ type: 'build',
50
+ description: 'Build system changes',
51
+ },
52
+ {
53
+ keywords: ['ci', 'github action', 'workflow', 'pipeline', 'travis', 'jenkins'],
54
+ type: 'ci',
55
+ description: 'CI/CD changes',
56
+ },
57
+ {
58
+ keywords: ['chore', 'update', 'upgrade', 'bump', 'dependency', 'deps'],
59
+ type: 'chore',
60
+ description: 'Maintenance tasks',
61
+ },
62
+ {
63
+ keywords: ['revert', 'rollback', 'undo'],
64
+ type: 'revert',
65
+ description: 'Reverting changes',
66
+ },
67
+ ];
68
+ /**
69
+ * Ticket patterns (JIRA, GitHub, etc.)
70
+ */
71
+ const TICKET_PATTERNS = [
72
+ {
73
+ name: 'JIRA',
74
+ pattern: /([A-Z]{2,10}-\d+)/,
75
+ format: (match) => match[1],
76
+ },
77
+ {
78
+ name: 'GitHub Issue',
79
+ pattern: /#(\d+)/,
80
+ format: (match) => `#${match[1]}`,
81
+ },
82
+ {
83
+ name: 'Linear',
84
+ pattern: /([A-Z]{2,10}-[A-Z0-9]+)/,
85
+ format: (match) => match[1],
86
+ },
87
+ ];
88
+ const DEFAULT_CO_AUTHOR = {
89
+ name: 'Claude Opus 4.5',
90
+ email: 'noreply@anthropic.com',
91
+ };
92
+ const DEFAULT_CONFIG = {
93
+ maxSubjectLength: 72,
94
+ maxBodyLength: 100,
95
+ requireConventional: true,
96
+ addCoAuthor: true,
97
+ coAuthor: DEFAULT_CO_AUTHOR,
98
+ addClaudeReference: true,
99
+ };
100
+ /**
101
+ * Git Commit Hook Manager
102
+ */
103
+ export class GitCommitHook {
104
+ registry;
105
+ config;
106
+ constructor(registry, config) {
107
+ this.registry = registry;
108
+ this.config = { ...DEFAULT_CONFIG, ...config };
109
+ this.registerHooks();
110
+ }
111
+ /**
112
+ * Register git commit hooks
113
+ */
114
+ registerHooks() {
115
+ // We use PreCommand hook since there's no specific commit hook event
116
+ // In practice, this would be called when detecting git commit commands
117
+ this.registry.register(HookEvent.PreCommand, this.handlePreCommit.bind(this), HookPriority.Normal, { name: 'git-commit:pre-commit' });
118
+ }
119
+ /**
120
+ * Handle pre-commit (when a git commit command is detected)
121
+ */
122
+ async handlePreCommit(context) {
123
+ const command = context.command?.command || '';
124
+ // Only process git commit commands
125
+ if (!command.includes('git commit')) {
126
+ return { success: true };
127
+ }
128
+ // Extract message from command if present
129
+ const messageMatch = command.match(/-m\s+["']([^"']+)["']/);
130
+ if (!messageMatch) {
131
+ return { success: true }; // No message to process
132
+ }
133
+ const message = messageMatch[1];
134
+ const branchName = context.metadata?.branchName;
135
+ const result = await this.processCommitMessage(message, branchName);
136
+ // Modify the command with the new message
137
+ if (result.success && result.modifiedMessage !== message) {
138
+ const modifiedCommand = command.replace(/-m\s+["'][^"']+["']/, `-m "${result.modifiedMessage.replace(/"/g, '\\"')}"`);
139
+ return {
140
+ ...result,
141
+ data: {
142
+ command: {
143
+ ...context.command,
144
+ command: modifiedCommand,
145
+ },
146
+ },
147
+ };
148
+ }
149
+ return result;
150
+ }
151
+ /**
152
+ * Process commit message
153
+ */
154
+ async processCommitMessage(message, branchName) {
155
+ const originalMessage = message;
156
+ let modifiedMessage = message;
157
+ const validationIssues = [];
158
+ const suggestions = [];
159
+ // Parse existing message structure
160
+ const { subject, body, footer } = this.parseMessage(message);
161
+ // Detect commit type
162
+ const commitType = this.detectCommitType(subject);
163
+ // Add commit type prefix if not present and type was detected
164
+ if (commitType && !this.hasConventionalPrefix(subject)) {
165
+ modifiedMessage = `${commitType}: ${this.lowercaseFirstLetter(subject)}`;
166
+ suggestions.push(`Added conventional commit prefix: ${commitType}`);
167
+ }
168
+ else if (!commitType && this.config.requireConventional && !this.hasConventionalPrefix(subject)) {
169
+ // No type detected but conventional commits are required - suggest adding a prefix
170
+ suggestions.push('Consider adding a conventional commit prefix (feat:, fix:, docs:, etc.)');
171
+ }
172
+ // Validate subject length
173
+ if (subject.length > this.config.maxSubjectLength) {
174
+ validationIssues.push({
175
+ type: 'length',
176
+ severity: 'warning',
177
+ description: `Subject line exceeds ${this.config.maxSubjectLength} characters`,
178
+ suggestedFix: 'Shorten the subject line',
179
+ });
180
+ }
181
+ // Extract ticket reference from branch name
182
+ let ticketReference;
183
+ if (branchName) {
184
+ ticketReference = this.extractTicket(branchName);
185
+ if (ticketReference && !modifiedMessage.includes(ticketReference)) {
186
+ modifiedMessage = this.addTicketReference(modifiedMessage, ticketReference);
187
+ suggestions.push(`Added ticket reference: ${ticketReference}`);
188
+ }
189
+ }
190
+ // Add Claude Code reference and co-author
191
+ let coAuthorAdded = false;
192
+ if (this.config.addClaudeReference || this.config.addCoAuthor) {
193
+ const additions = [];
194
+ if (this.config.addClaudeReference) {
195
+ additions.push('\n\nGenerated with [Claude Code](https://claude.com/claude-code)');
196
+ }
197
+ if (this.config.addCoAuthor) {
198
+ additions.push(`\n\nCo-Authored-By: ${this.config.coAuthor.name} <${this.config.coAuthor.email}>`);
199
+ coAuthorAdded = true;
200
+ }
201
+ // Only add if not already present
202
+ for (const addition of additions) {
203
+ const searchStr = addition.trim().split('\n')[0];
204
+ if (!modifiedMessage.includes(searchStr)) {
205
+ modifiedMessage += addition;
206
+ }
207
+ }
208
+ }
209
+ // Validate conventional commit format
210
+ if (this.config.requireConventional) {
211
+ const conventionalIssues = this.validateConventional(modifiedMessage);
212
+ validationIssues.push(...conventionalIssues);
213
+ }
214
+ return {
215
+ success: true,
216
+ originalMessage,
217
+ modifiedMessage,
218
+ commitType,
219
+ ticketReference,
220
+ coAuthorAdded,
221
+ validationIssues: validationIssues.length > 0 ? validationIssues : undefined,
222
+ suggestions: suggestions.length > 0 ? suggestions : undefined,
223
+ };
224
+ }
225
+ /**
226
+ * Parse commit message into parts
227
+ */
228
+ parseMessage(message) {
229
+ const parts = message.split('\n\n');
230
+ return {
231
+ subject: parts[0] || '',
232
+ body: parts[1],
233
+ footer: parts.slice(2).join('\n\n'),
234
+ };
235
+ }
236
+ /**
237
+ * Detect commit type from message
238
+ */
239
+ detectCommitType(message) {
240
+ const lowerMessage = message.toLowerCase();
241
+ // First check if message already has conventional prefix
242
+ const prefixMatch = lowerMessage.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore|revert)(\(.+\))?:/);
243
+ if (prefixMatch) {
244
+ return prefixMatch[1];
245
+ }
246
+ // Score each commit type based on keyword matches
247
+ // More specific/unique keywords get higher weight
248
+ const scores = new Map();
249
+ // High-priority patterns (check these first as they're more specific)
250
+ const priorityPatterns = [
251
+ // Test patterns - high priority because "add tests" should be 'test' not 'feat'
252
+ { pattern: /\b(test|tests|spec|specs|unittest|unit test|testing)\b/i, type: 'test', weight: 3 },
253
+ // Docs patterns
254
+ { pattern: /\b(doc|docs|documentation|readme|comment|comments)\b/i, type: 'docs', weight: 3 },
255
+ // Revert patterns
256
+ { pattern: /\b(revert|rollback|undo)\b/i, type: 'revert', weight: 3 },
257
+ // Fix patterns (bug-specific)
258
+ { pattern: /\b(fix|bug|bugfix|resolve|patch|hotfix)\b/i, type: 'fix', weight: 2 },
259
+ // CI patterns
260
+ { pattern: /\b(ci|github action|workflow|pipeline|travis|jenkins|circleci)\b/i, type: 'ci', weight: 3 },
261
+ // Build patterns
262
+ { pattern: /\b(build|webpack|rollup|vite|esbuild|bundler|package\.json)\b/i, type: 'build', weight: 2 },
263
+ // Perf patterns
264
+ { pattern: /\b(perf|performance|optimize|speed|faster|slow)\b/i, type: 'perf', weight: 2 },
265
+ // Refactor patterns
266
+ { pattern: /\b(refactor|restructure|reorganize|extract|simplify|clean)\b/i, type: 'refactor', weight: 2 },
267
+ // Style patterns
268
+ { pattern: /\b(style|format|lint|whitespace|prettier|eslint)\b/i, type: 'style', weight: 2 },
269
+ // Chore patterns - specifically for dependencies
270
+ { pattern: /\b(dependency|dependencies|deps|bump|upgrade version)\b/i, type: 'chore', weight: 2 },
271
+ // Generic update is lower priority (could be chore or other)
272
+ { pattern: /\b(update)\b/i, type: 'chore', weight: 1 },
273
+ // Feat patterns (generic add/create/implement)
274
+ { pattern: /\b(add|implement|create|introduce|new feature)\b/i, type: 'feat', weight: 1 },
275
+ ];
276
+ // Calculate scores for each pattern
277
+ for (const { pattern, type, weight } of priorityPatterns) {
278
+ if (pattern.test(lowerMessage)) {
279
+ const currentScore = scores.get(type) || 0;
280
+ scores.set(type, currentScore + weight);
281
+ }
282
+ }
283
+ // Find highest scoring type
284
+ let maxScore = 0;
285
+ let detectedType;
286
+ for (const [type, score] of scores) {
287
+ if (score > maxScore) {
288
+ maxScore = score;
289
+ detectedType = type;
290
+ }
291
+ }
292
+ return detectedType;
293
+ }
294
+ /**
295
+ * Check if message has conventional commit prefix
296
+ */
297
+ hasConventionalPrefix(message) {
298
+ return /^(feat|fix|docs|style|refactor|perf|test|build|ci|chore|revert)(\(.+\))?:/.test(message.toLowerCase());
299
+ }
300
+ /**
301
+ * Lowercase first letter of a string
302
+ */
303
+ lowercaseFirstLetter(str) {
304
+ // Don't lowercase if it's an acronym or proper noun
305
+ if (/^[A-Z]{2,}/.test(str)) {
306
+ return str;
307
+ }
308
+ return str.charAt(0).toLowerCase() + str.slice(1);
309
+ }
310
+ /**
311
+ * Extract ticket reference from branch name
312
+ */
313
+ extractTicket(branchName) {
314
+ for (const { pattern, format } of TICKET_PATTERNS) {
315
+ const match = pattern.exec(branchName);
316
+ if (match) {
317
+ return format(match);
318
+ }
319
+ }
320
+ return undefined;
321
+ }
322
+ /**
323
+ * Add ticket reference to message
324
+ */
325
+ addTicketReference(message, ticket) {
326
+ const parts = message.split('\n\n');
327
+ const subject = parts[0];
328
+ const rest = parts.slice(1).join('\n\n');
329
+ // Add refs line
330
+ if (rest) {
331
+ return `${subject}\n\nRefs: ${ticket}\n\n${rest}`;
332
+ }
333
+ return `${subject}\n\nRefs: ${ticket}`;
334
+ }
335
+ /**
336
+ * Validate conventional commit format
337
+ */
338
+ validateConventional(message) {
339
+ const issues = [];
340
+ const lines = message.split('\n');
341
+ const subject = lines[0] || '';
342
+ // Check for conventional prefix
343
+ if (!this.hasConventionalPrefix(subject)) {
344
+ issues.push({
345
+ type: 'format',
346
+ severity: 'warning',
347
+ description: 'Missing conventional commit prefix',
348
+ suggestedFix: 'Add a prefix like feat:, fix:, docs:, etc.',
349
+ });
350
+ }
351
+ // Check subject line starts with lowercase (after prefix)
352
+ const afterPrefix = subject.replace(/^[a-z]+(\(.+\))?: /, '');
353
+ if (afterPrefix && /^[A-Z]/.test(afterPrefix) && !/^[A-Z]{2,}/.test(afterPrefix)) {
354
+ issues.push({
355
+ type: 'format',
356
+ severity: 'info',
357
+ description: 'Subject should start with lowercase (conventional style)',
358
+ suggestedFix: 'Use lowercase for the first word after the prefix',
359
+ });
360
+ }
361
+ // Check for period at end of subject
362
+ if (subject.endsWith('.')) {
363
+ issues.push({
364
+ type: 'format',
365
+ severity: 'info',
366
+ description: 'Subject line should not end with a period',
367
+ suggestedFix: 'Remove the trailing period',
368
+ });
369
+ }
370
+ // Check body line lengths
371
+ for (let i = 1; i < lines.length; i++) {
372
+ const line = lines[i];
373
+ if (line.length > this.config.maxBodyLength && !line.startsWith('Co-Authored-By:')) {
374
+ issues.push({
375
+ type: 'body',
376
+ severity: 'info',
377
+ description: `Line ${i + 1} exceeds ${this.config.maxBodyLength} characters`,
378
+ suggestedFix: 'Wrap long lines in the commit body',
379
+ });
380
+ break; // Only report first occurrence
381
+ }
382
+ }
383
+ // Check for breaking change indicator
384
+ if (subject.includes('!:') || message.includes('BREAKING CHANGE:')) {
385
+ issues.push({
386
+ type: 'breaking',
387
+ severity: 'info',
388
+ description: 'Breaking change detected - ensure changelog is updated',
389
+ });
390
+ }
391
+ return issues;
392
+ }
393
+ /**
394
+ * Process commit message manually
395
+ */
396
+ async process(message, branchName) {
397
+ return this.processCommitMessage(message, branchName);
398
+ }
399
+ /**
400
+ * Format a commit message with heredoc-style for git
401
+ */
402
+ formatForGit(message) {
403
+ // Escape for heredoc usage
404
+ return `$(cat <<'EOF'
405
+ ${message}
406
+ EOF
407
+ )`;
408
+ }
409
+ /**
410
+ * Generate a commit command with formatted message
411
+ */
412
+ generateCommitCommand(message) {
413
+ return `git commit -m "${this.formatForGit(message)}"`;
414
+ }
415
+ /**
416
+ * Get commit type description
417
+ */
418
+ getCommitTypeDescription(type) {
419
+ const pattern = COMMIT_TYPE_PATTERNS.find(p => p.type === type);
420
+ return pattern?.description || 'Unknown commit type';
421
+ }
422
+ /**
423
+ * Get all available commit types
424
+ */
425
+ getAllCommitTypes() {
426
+ return COMMIT_TYPE_PATTERNS.map(p => ({
427
+ type: p.type,
428
+ description: p.description,
429
+ }));
430
+ }
431
+ /**
432
+ * Update configuration
433
+ */
434
+ setConfig(config) {
435
+ this.config = { ...this.config, ...config };
436
+ }
437
+ /**
438
+ * Get current configuration
439
+ */
440
+ getConfig() {
441
+ return { ...this.config };
442
+ }
443
+ }
444
+ /**
445
+ * Create git commit hook
446
+ */
447
+ export function createGitCommitHook(registry, config) {
448
+ return new GitCommitHook(registry, config);
449
+ }
450
+ //# sourceMappingURL=git-commit.js.map
@@ -0,0 +1,17 @@
1
+ /**
2
+ * V3 Safety Hooks - Index
3
+ *
4
+ * TypeScript conversions of V2 shell hooks for:
5
+ * - Bash command safety
6
+ * - File organization enforcement
7
+ * - Git commit formatting
8
+ *
9
+ * @module v3/shared/hooks/safety
10
+ */
11
+ export { BashSafetyHook, createBashSafetyHook, } from './bash-safety.js';
12
+ export type { BashSafetyResult, CommandRisk, } from './bash-safety.js';
13
+ export { FileOrganizationHook, createFileOrganizationHook, } from './file-organization.js';
14
+ export type { FileOrganizationResult, FormatterRecommendation, LinterRecommendation, OrganizationIssue, } from './file-organization.js';
15
+ export { GitCommitHook, createGitCommitHook, } from './git-commit.js';
16
+ export type { GitCommitResult, CommitType, CommitValidationIssue, } from './git-commit.js';
17
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,17 @@
1
+ /**
2
+ * V3 Safety Hooks - Index
3
+ *
4
+ * TypeScript conversions of V2 shell hooks for:
5
+ * - Bash command safety
6
+ * - File organization enforcement
7
+ * - Git commit formatting
8
+ *
9
+ * @module v3/shared/hooks/safety
10
+ */
11
+ // Bash safety hook
12
+ export { BashSafetyHook, createBashSafetyHook, } from './bash-safety.js';
13
+ // File organization hook
14
+ export { FileOrganizationHook, createFileOrganizationHook, } from './file-organization.js';
15
+ // Git commit hook
16
+ export { GitCommitHook, createGitCommitHook, } from './git-commit.js';
17
+ //# sourceMappingURL=index.js.map