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.
- package/.claude/guidance/shipped/moflo.md +45 -0
- package/.claude/helpers/statusline.cjs +1 -1
- package/.claude/workflow-state.json +9 -0
- package/package.json +2 -2
- package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +1 -1
- package/src/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +5 -3
- package/src/@claude-flow/cli/package.json +1 -1
- package/src/@claude-flow/memory/dist/agent-memory-scope.d.ts +131 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.js +223 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.test.js +466 -0
- package/src/@claude-flow/memory/dist/agentdb-adapter.d.ts +165 -0
- package/src/@claude-flow/memory/dist/agentdb-adapter.js +806 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.d.ts +212 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.js +842 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.test.d.ts +7 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.test.js +258 -0
- package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.d.ts +65 -0
- package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.js +129 -0
- package/src/@claude-flow/memory/dist/application/commands/store-memory.command.d.ts +48 -0
- package/src/@claude-flow/memory/dist/application/commands/store-memory.command.js +72 -0
- package/src/@claude-flow/memory/dist/application/index.d.ts +12 -0
- package/src/@claude-flow/memory/dist/application/index.js +15 -0
- package/src/@claude-flow/memory/dist/application/queries/search-memory.query.d.ts +72 -0
- package/src/@claude-flow/memory/dist/application/queries/search-memory.query.js +143 -0
- package/src/@claude-flow/memory/dist/application/services/memory-application-service.d.ts +121 -0
- package/src/@claude-flow/memory/dist/application/services/memory-application-service.js +190 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.d.ts +226 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.js +709 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +757 -0
- package/src/@claude-flow/memory/dist/benchmark.test.d.ts +2 -0
- package/src/@claude-flow/memory/dist/benchmark.test.js +277 -0
- package/src/@claude-flow/memory/dist/cache-manager.d.ts +134 -0
- package/src/@claude-flow/memory/dist/cache-manager.js +407 -0
- package/src/@claude-flow/memory/dist/controller-registry.d.ts +216 -0
- package/src/@claude-flow/memory/dist/controller-registry.js +893 -0
- package/src/@claude-flow/memory/dist/controller-registry.test.d.ts +14 -0
- package/src/@claude-flow/memory/dist/controller-registry.test.js +593 -0
- package/src/@claude-flow/memory/dist/database-provider.d.ts +87 -0
- package/src/@claude-flow/memory/dist/database-provider.js +372 -0
- package/src/@claude-flow/memory/dist/database-provider.test.d.ts +7 -0
- package/src/@claude-flow/memory/dist/database-provider.test.js +287 -0
- package/src/@claude-flow/memory/dist/domain/entities/memory-entry.d.ts +143 -0
- package/src/@claude-flow/memory/dist/domain/entities/memory-entry.js +226 -0
- package/src/@claude-flow/memory/dist/domain/index.d.ts +11 -0
- package/src/@claude-flow/memory/dist/domain/index.js +12 -0
- package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.d.ts +102 -0
- package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.js +11 -0
- package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.d.ts +105 -0
- package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.js +297 -0
- package/src/@claude-flow/memory/dist/hnsw-index.d.ts +111 -0
- package/src/@claude-flow/memory/dist/hnsw-index.js +781 -0
- package/src/@claude-flow/memory/dist/hnsw-lite.d.ts +23 -0
- package/src/@claude-flow/memory/dist/hnsw-lite.js +168 -0
- package/src/@claude-flow/memory/dist/index.d.ts +204 -0
- package/src/@claude-flow/memory/dist/index.js +358 -0
- package/src/@claude-flow/memory/dist/infrastructure/index.d.ts +17 -0
- package/src/@claude-flow/memory/dist/infrastructure/index.js +16 -0
- package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.d.ts +66 -0
- package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.js +409 -0
- package/src/@claude-flow/memory/dist/learning-bridge.d.ts +137 -0
- package/src/@claude-flow/memory/dist/learning-bridge.js +335 -0
- package/src/@claude-flow/memory/dist/learning-bridge.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/learning-bridge.test.js +578 -0
- package/src/@claude-flow/memory/dist/memory-graph.d.ts +100 -0
- package/src/@claude-flow/memory/dist/memory-graph.js +333 -0
- package/src/@claude-flow/memory/dist/memory-graph.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/memory-graph.test.js +609 -0
- package/src/@claude-flow/memory/dist/migration.d.ts +68 -0
- package/src/@claude-flow/memory/dist/migration.js +513 -0
- package/src/@claude-flow/memory/dist/persistent-sona.d.ts +144 -0
- package/src/@claude-flow/memory/dist/persistent-sona.js +332 -0
- package/src/@claude-flow/memory/dist/query-builder.d.ts +211 -0
- package/src/@claude-flow/memory/dist/query-builder.js +438 -0
- package/src/@claude-flow/memory/dist/rvf-backend.d.ts +51 -0
- package/src/@claude-flow/memory/dist/rvf-backend.js +481 -0
- package/src/@claude-flow/memory/dist/rvf-learning-store.d.ts +139 -0
- package/src/@claude-flow/memory/dist/rvf-learning-store.js +295 -0
- package/src/@claude-flow/memory/dist/rvf-migration.d.ts +45 -0
- package/src/@claude-flow/memory/dist/rvf-migration.js +234 -0
- package/src/@claude-flow/memory/dist/sqljs-backend.d.ts +127 -0
- package/src/@claude-flow/memory/dist/sqljs-backend.js +600 -0
- package/src/@claude-flow/memory/dist/types.d.ts +484 -0
- package/src/@claude-flow/memory/dist/types.js +58 -0
- package/src/@claude-flow/shared/dist/core/config/defaults.d.ts +41 -0
- package/src/@claude-flow/shared/dist/core/config/defaults.js +186 -0
- package/src/@claude-flow/shared/dist/core/config/index.d.ts +8 -0
- package/src/@claude-flow/shared/dist/core/config/index.js +12 -0
- package/src/@claude-flow/shared/dist/core/config/loader.d.ts +45 -0
- package/src/@claude-flow/shared/dist/core/config/loader.js +222 -0
- package/src/@claude-flow/shared/dist/core/config/schema.d.ts +1134 -0
- package/src/@claude-flow/shared/dist/core/config/schema.js +158 -0
- package/src/@claude-flow/shared/dist/core/config/validator.d.ts +92 -0
- package/src/@claude-flow/shared/dist/core/config/validator.js +147 -0
- package/src/@claude-flow/shared/dist/core/event-bus.d.ts +31 -0
- package/src/@claude-flow/shared/dist/core/event-bus.js +197 -0
- package/src/@claude-flow/shared/dist/core/index.d.ts +15 -0
- package/src/@claude-flow/shared/dist/core/index.js +19 -0
- package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +200 -0
- package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.js +6 -0
- package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +310 -0
- package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +7 -0
- package/src/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +224 -0
- package/src/@claude-flow/shared/dist/core/interfaces/event.interface.js +46 -0
- package/src/@claude-flow/shared/dist/core/interfaces/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/core/interfaces/index.js +15 -0
- package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +298 -0
- package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.js +7 -0
- package/src/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +185 -0
- package/src/@claude-flow/shared/dist/core/interfaces/task.interface.js +6 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +35 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +101 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +60 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +166 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/index.d.ts +46 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/index.js +64 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +195 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +83 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.js +193 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +49 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.js +253 -0
- package/src/@claude-flow/shared/dist/events/domain-events.d.ts +282 -0
- package/src/@claude-flow/shared/dist/events/domain-events.js +165 -0
- package/src/@claude-flow/shared/dist/events/event-store.d.ts +126 -0
- package/src/@claude-flow/shared/dist/events/event-store.js +432 -0
- package/src/@claude-flow/shared/dist/events/event-store.test.d.ts +8 -0
- package/src/@claude-flow/shared/dist/events/event-store.test.js +297 -0
- package/src/@claude-flow/shared/dist/events/example-usage.d.ts +10 -0
- package/src/@claude-flow/shared/dist/events/example-usage.js +193 -0
- package/src/@claude-flow/shared/dist/events/index.d.ts +21 -0
- package/src/@claude-flow/shared/dist/events/index.js +22 -0
- package/src/@claude-flow/shared/dist/events/projections.d.ts +177 -0
- package/src/@claude-flow/shared/dist/events/projections.js +421 -0
- package/src/@claude-flow/shared/dist/events/rvf-event-log.d.ts +82 -0
- package/src/@claude-flow/shared/dist/events/rvf-event-log.js +340 -0
- package/src/@claude-flow/shared/dist/events/state-reconstructor.d.ts +101 -0
- package/src/@claude-flow/shared/dist/events/state-reconstructor.js +263 -0
- package/src/@claude-flow/shared/dist/events.d.ts +80 -0
- package/src/@claude-flow/shared/dist/events.js +249 -0
- package/src/@claude-flow/shared/dist/hooks/example-usage.d.ts +42 -0
- package/src/@claude-flow/shared/dist/hooks/example-usage.js +351 -0
- package/src/@claude-flow/shared/dist/hooks/executor.d.ts +100 -0
- package/src/@claude-flow/shared/dist/hooks/executor.js +267 -0
- package/src/@claude-flow/shared/dist/hooks/hooks.test.d.ts +9 -0
- package/src/@claude-flow/shared/dist/hooks/hooks.test.js +322 -0
- package/src/@claude-flow/shared/dist/hooks/index.d.ts +52 -0
- package/src/@claude-flow/shared/dist/hooks/index.js +51 -0
- package/src/@claude-flow/shared/dist/hooks/registry.d.ts +133 -0
- package/src/@claude-flow/shared/dist/hooks/registry.js +277 -0
- package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +105 -0
- package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.js +481 -0
- package/src/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +144 -0
- package/src/@claude-flow/shared/dist/hooks/safety/file-organization.js +328 -0
- package/src/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +158 -0
- package/src/@claude-flow/shared/dist/hooks/safety/git-commit.js +450 -0
- package/src/@claude-flow/shared/dist/hooks/safety/index.d.ts +17 -0
- package/src/@claude-flow/shared/dist/hooks/safety/index.js +17 -0
- package/src/@claude-flow/shared/dist/hooks/session-hooks.d.ts +234 -0
- package/src/@claude-flow/shared/dist/hooks/session-hooks.js +334 -0
- package/src/@claude-flow/shared/dist/hooks/task-hooks.d.ts +163 -0
- package/src/@claude-flow/shared/dist/hooks/task-hooks.js +326 -0
- package/src/@claude-flow/shared/dist/hooks/types.d.ts +267 -0
- package/src/@claude-flow/shared/dist/hooks/types.js +62 -0
- package/src/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +9 -0
- package/src/@claude-flow/shared/dist/hooks/verify-exports.test.js +93 -0
- package/src/@claude-flow/shared/dist/index.d.ts +20 -0
- package/src/@claude-flow/shared/dist/index.js +50 -0
- package/src/@claude-flow/shared/dist/mcp/connection-pool.d.ts +98 -0
- package/src/@claude-flow/shared/dist/mcp/connection-pool.js +364 -0
- package/src/@claude-flow/shared/dist/mcp/index.d.ts +69 -0
- package/src/@claude-flow/shared/dist/mcp/index.js +84 -0
- package/src/@claude-flow/shared/dist/mcp/server.d.ts +166 -0
- package/src/@claude-flow/shared/dist/mcp/server.js +593 -0
- package/src/@claude-flow/shared/dist/mcp/session-manager.d.ts +136 -0
- package/src/@claude-flow/shared/dist/mcp/session-manager.js +335 -0
- package/src/@claude-flow/shared/dist/mcp/tool-registry.d.ts +178 -0
- package/src/@claude-flow/shared/dist/mcp/tool-registry.js +439 -0
- package/src/@claude-flow/shared/dist/mcp/transport/http.d.ts +104 -0
- package/src/@claude-flow/shared/dist/mcp/transport/http.js +476 -0
- package/src/@claude-flow/shared/dist/mcp/transport/index.d.ts +102 -0
- package/src/@claude-flow/shared/dist/mcp/transport/index.js +238 -0
- package/src/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +104 -0
- package/src/@claude-flow/shared/dist/mcp/transport/stdio.js +263 -0
- package/src/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +133 -0
- package/src/@claude-flow/shared/dist/mcp/transport/websocket.js +396 -0
- package/src/@claude-flow/shared/dist/mcp/types.d.ts +438 -0
- package/src/@claude-flow/shared/dist/mcp/types.js +54 -0
- package/src/@claude-flow/shared/dist/plugin-interface.d.ts +544 -0
- package/src/@claude-flow/shared/dist/plugin-interface.js +23 -0
- package/src/@claude-flow/shared/dist/plugin-loader.d.ts +139 -0
- package/src/@claude-flow/shared/dist/plugin-loader.js +434 -0
- package/src/@claude-flow/shared/dist/plugin-registry.d.ts +183 -0
- package/src/@claude-flow/shared/dist/plugin-registry.js +457 -0
- package/src/@claude-flow/shared/dist/plugins/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/plugins/index.js +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
- package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +241 -0
- package/src/@claude-flow/shared/dist/plugins/official/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/index.js +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +121 -0
- package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +355 -0
- package/src/@claude-flow/shared/dist/plugins/types.d.ts +93 -0
- package/src/@claude-flow/shared/dist/plugins/types.js +9 -0
- package/src/@claude-flow/shared/dist/resilience/bulkhead.d.ts +105 -0
- package/src/@claude-flow/shared/dist/resilience/bulkhead.js +206 -0
- package/src/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +132 -0
- package/src/@claude-flow/shared/dist/resilience/circuit-breaker.js +233 -0
- package/src/@claude-flow/shared/dist/resilience/index.d.ts +19 -0
- package/src/@claude-flow/shared/dist/resilience/index.js +19 -0
- package/src/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +168 -0
- package/src/@claude-flow/shared/dist/resilience/rate-limiter.js +314 -0
- package/src/@claude-flow/shared/dist/resilience/retry.d.ts +91 -0
- package/src/@claude-flow/shared/dist/resilience/retry.js +159 -0
- package/src/@claude-flow/shared/dist/security/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/security/index.js +12 -0
- package/src/@claude-flow/shared/dist/security/input-validation.d.ts +73 -0
- package/src/@claude-flow/shared/dist/security/input-validation.js +201 -0
- package/src/@claude-flow/shared/dist/security/secure-random.d.ts +92 -0
- package/src/@claude-flow/shared/dist/security/secure-random.js +142 -0
- package/src/@claude-flow/shared/dist/services/index.d.ts +7 -0
- package/src/@claude-flow/shared/dist/services/index.js +7 -0
- package/src/@claude-flow/shared/dist/services/v3-progress.service.d.ts +124 -0
- package/src/@claude-flow/shared/dist/services/v3-progress.service.js +402 -0
- package/src/@claude-flow/shared/dist/types/agent.types.d.ts +137 -0
- package/src/@claude-flow/shared/dist/types/agent.types.js +6 -0
- package/src/@claude-flow/shared/dist/types/index.d.ts +11 -0
- package/src/@claude-flow/shared/dist/types/index.js +17 -0
- package/src/@claude-flow/shared/dist/types/mcp.types.d.ts +266 -0
- package/src/@claude-flow/shared/dist/types/mcp.types.js +7 -0
- package/src/@claude-flow/shared/dist/types/memory.types.d.ts +236 -0
- package/src/@claude-flow/shared/dist/types/memory.types.js +7 -0
- package/src/@claude-flow/shared/dist/types/swarm.types.d.ts +186 -0
- package/src/@claude-flow/shared/dist/types/swarm.types.js +65 -0
- package/src/@claude-flow/shared/dist/types/task.types.d.ts +178 -0
- package/src/@claude-flow/shared/dist/types/task.types.js +32 -0
- package/src/@claude-flow/shared/dist/types.d.ts +197 -0
- package/src/@claude-flow/shared/dist/types.js +21 -0
- package/src/@claude-flow/shared/dist/utils/secure-logger.d.ts +69 -0
- 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
|