moai-adk 0.15.0__py3-none-any.whl → 0.25.4__py3-none-any.whl
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.
Potentially problematic release.
This version of moai-adk might be problematic. Click here for more details.
- moai_adk/__init__.py +1 -2
- moai_adk/__main__.py +85 -2
- moai_adk/cli/__init__.py +0 -1
- moai_adk/cli/commands/__init__.py +0 -1
- moai_adk/cli/commands/analyze.py +127 -0
- moai_adk/cli/commands/backup.py +5 -3
- moai_adk/cli/commands/doctor.py +35 -11
- moai_adk/cli/commands/improve_user_experience.py +348 -0
- moai_adk/cli/commands/init.py +150 -23
- moai_adk/cli/commands/language.py +269 -0
- moai_adk/cli/commands/migrate.py +158 -0
- moai_adk/cli/commands/status.py +13 -12
- moai_adk/cli/commands/update.py +364 -60
- moai_adk/cli/commands/validate_links.py +118 -0
- moai_adk/cli/main.py +3 -2
- moai_adk/cli/prompts/init_prompts.py +79 -82
- moai_adk/core/__init__.py +0 -1
- moai_adk/core/analysis/__init__.py +9 -0
- moai_adk/core/analysis/session_analyzer.py +439 -0
- moai_adk/core/claude_integration.py +421 -0
- moai_adk/core/command_helpers.py +270 -0
- moai_adk/core/config/__init__.py +6 -0
- moai_adk/core/config/auto_spec_config.py +346 -0
- moai_adk/core/config/migration.py +133 -12
- moai_adk/core/context_manager.py +279 -0
- moai_adk/core/diagnostics/slash_commands.py +0 -1
- moai_adk/core/error_recovery_system.py +1289 -0
- moai_adk/core/git/__init__.py +0 -1
- moai_adk/core/git/branch.py +0 -1
- moai_adk/core/git/branch_manager.py +4 -4
- moai_adk/core/git/checkpoint.py +1 -5
- moai_adk/core/git/commit.py +0 -1
- moai_adk/core/git/event_detector.py +3 -5
- moai_adk/core/git/manager.py +0 -1
- moai_adk/core/hooks/post_tool_auto_spec_completion.py +925 -0
- moai_adk/core/integration/__init__.py +22 -0
- moai_adk/core/integration/engine.py +169 -0
- moai_adk/core/integration/integration_tester.py +225 -0
- moai_adk/core/integration/models.py +88 -0
- moai_adk/core/integration/utils.py +211 -0
- moai_adk/core/issue_creator.py +28 -18
- moai_adk/core/language_config.py +202 -0
- moai_adk/core/language_validator.py +556 -0
- moai_adk/core/mcp/setup.py +113 -0
- moai_adk/core/migration/__init__.py +18 -0
- moai_adk/core/migration/backup_manager.py +208 -0
- moai_adk/core/migration/file_migrator.py +218 -0
- moai_adk/core/migration/version_detector.py +143 -0
- moai_adk/core/migration/version_migrator.py +228 -0
- moai_adk/core/performance/__init__.py +6 -0
- moai_adk/core/performance/cache_system.py +318 -0
- moai_adk/core/performance/parallel_processor.py +116 -0
- moai_adk/core/project/__init__.py +0 -1
- moai_adk/core/project/backup_utils.py +2 -7
- moai_adk/core/project/checker.py +3 -3
- moai_adk/core/project/detector.py +20 -40
- moai_adk/core/project/initializer.py +42 -17
- moai_adk/core/project/phase_executor.py +415 -58
- moai_adk/core/project/validator.py +6 -25
- moai_adk/core/quality/__init__.py +1 -1
- moai_adk/core/quality/trust_checker.py +64 -110
- moai_adk/core/quality/validators/__init__.py +1 -1
- moai_adk/core/quality/validators/base_validator.py +1 -1
- moai_adk/core/rollback_manager.py +993 -0
- moai_adk/core/session_manager.py +667 -0
- moai_adk/core/spec/confidence_scoring.py +749 -0
- moai_adk/core/spec/ears_template_engine.py +1182 -0
- moai_adk/core/spec/quality_validator.py +721 -0
- moai_adk/core/spec_status_manager.py +488 -0
- moai_adk/core/template/__init__.py +0 -1
- moai_adk/core/template/backup.py +41 -1
- moai_adk/core/template/config.py +11 -12
- moai_adk/core/template/languages.py +0 -1
- moai_adk/core/template/merger.py +79 -22
- moai_adk/core/template/processor.py +614 -40
- moai_adk/core/template_engine.py +36 -27
- moai_adk/foundation/git/commit_templates.py +565 -0
- moai_adk/foundation/trust/trust_principles.py +725 -0
- moai_adk/foundation/trust/validation_checklist.py +1678 -0
- moai_adk/statusline/__init__.py +38 -0
- moai_adk/statusline/alfred_detector.py +107 -0
- moai_adk/statusline/config.py +364 -0
- moai_adk/statusline/enhanced_output_style_detector.py +364 -0
- moai_adk/statusline/git_collector.py +190 -0
- moai_adk/statusline/main.py +228 -0
- moai_adk/statusline/metrics_tracker.py +78 -0
- moai_adk/statusline/renderer.py +327 -0
- moai_adk/statusline/update_checker.py +135 -0
- moai_adk/statusline/version_reader.py +647 -0
- moai_adk/templates/.git-hooks/pre-commit +66 -0
- moai_adk/templates/.git-hooks/pre-push +116 -4
- moai_adk/templates/.github/workflows/moai-gitflow.yml +1 -7
- moai_adk/templates/.github/workflows/spec-issue-sync.yml +0 -1
- moai_adk/templates/.gitignore +44 -0
- moai_adk/templates/.mcp.json +22 -0
- moai_adk/templates/CLAUDE.md +450 -1071
- moai_adk/utils/__init__.py +0 -1
- moai_adk/utils/banner.py +0 -1
- moai_adk/utils/common.py +308 -0
- moai_adk/utils/link_validator.py +249 -0
- moai_adk/utils/logger.py +4 -9
- moai_adk/utils/safe_file_reader.py +210 -0
- moai_adk/utils/user_experience.py +531 -0
- moai_adk-0.25.4.dist-info/METADATA +2279 -0
- moai_adk-0.25.4.dist-info/RECORD +112 -0
- moai_adk/core/tags/__init__.py +0 -86
- moai_adk/core/tags/ci_validator.py +0 -463
- moai_adk/core/tags/cli.py +0 -283
- moai_adk/core/tags/generator.py +0 -109
- moai_adk/core/tags/inserter.py +0 -99
- moai_adk/core/tags/mapper.py +0 -126
- moai_adk/core/tags/parser.py +0 -76
- moai_adk/core/tags/pre_commit_validator.py +0 -393
- moai_adk/core/tags/reporter.py +0 -956
- moai_adk/core/tags/tags.py +0 -149
- moai_adk/core/tags/validator.py +0 -897
- moai_adk/templates/.claude/agents/alfred/backend-expert.md +0 -319
- moai_adk/templates/.claude/agents/alfred/cc-manager.md +0 -316
- moai_adk/templates/.claude/agents/alfred/debug-helper.md +0 -208
- moai_adk/templates/.claude/agents/alfred/devops-expert.md +0 -464
- moai_adk/templates/.claude/agents/alfred/doc-syncer.md +0 -214
- moai_adk/templates/.claude/agents/alfred/frontend-expert.md +0 -357
- moai_adk/templates/.claude/agents/alfred/git-manager.md +0 -406
- moai_adk/templates/.claude/agents/alfred/implementation-planner.md +0 -423
- moai_adk/templates/.claude/agents/alfred/project-manager.md +0 -312
- moai_adk/templates/.claude/agents/alfred/quality-gate.md +0 -343
- moai_adk/templates/.claude/agents/alfred/skill-factory.md +0 -865
- moai_adk/templates/.claude/agents/alfred/spec-builder.md +0 -392
- moai_adk/templates/.claude/agents/alfred/tag-agent.md +0 -361
- moai_adk/templates/.claude/agents/alfred/tdd-implementer.md +0 -428
- moai_adk/templates/.claude/agents/alfred/trust-checker.md +0 -375
- moai_adk/templates/.claude/agents/alfred/ui-ux-expert.md +0 -571
- moai_adk/templates/.claude/commands/alfred/0-project.md +0 -1525
- moai_adk/templates/.claude/commands/alfred/1-plan.md +0 -802
- moai_adk/templates/.claude/commands/alfred/2-run.md +0 -709
- moai_adk/templates/.claude/commands/alfred/3-sync.md +0 -1009
- moai_adk/templates/.claude/commands/alfred/9-feedback.md +0 -149
- moai_adk/templates/.claude/hooks/alfred/core/project.py +0 -748
- moai_adk/templates/.claude/hooks/alfred/core/timeout.py +0 -136
- moai_adk/templates/.claude/hooks/alfred/core/ttl_cache.py +0 -108
- moai_adk/templates/.claude/hooks/alfred/core/version_cache.py +0 -198
- moai_adk/templates/.claude/hooks/alfred/handlers/__init__.py +0 -29
- moai_adk/templates/.claude/hooks/alfred/post_tool__log_changes.py +0 -94
- moai_adk/templates/.claude/hooks/alfred/pre_tool__auto_checkpoint.py +0 -100
- moai_adk/templates/.claude/hooks/alfred/session_end__cleanup.py +0 -94
- moai_adk/templates/.claude/hooks/alfred/session_start__show_project_info.py +0 -94
- moai_adk/templates/.claude/hooks/alfred/shared/core/__init__.py +0 -170
- moai_adk/templates/.claude/hooks/alfred/shared/core/checkpoint.py +0 -271
- moai_adk/templates/.claude/hooks/alfred/shared/core/context.py +0 -67
- moai_adk/templates/.claude/hooks/alfred/shared/core/project.py +0 -749
- moai_adk/templates/.claude/hooks/alfred/shared/core/tags.py +0 -230
- moai_adk/templates/.claude/hooks/alfred/shared/core/version_cache.py +0 -198
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/__init__.py +0 -21
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/notification.py +0 -154
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/session.py +0 -174
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/tool.py +0 -87
- moai_adk/templates/.claude/hooks/alfred/shared/handlers/user.py +0 -61
- moai_adk/templates/.claude/hooks/alfred/user_prompt__jit_load_docs.py +0 -112
- moai_adk/templates/.claude/hooks/alfred/utils/__init__.py +0 -1
- moai_adk/templates/.claude/hooks/alfred/utils/timeout.py +0 -161
- moai_adk/templates/.claude/settings.json +0 -144
- moai_adk/templates/.claude/skills/moai-alfred-agent-guide/SKILL.md +0 -70
- moai_adk/templates/.claude/skills/moai-alfred-agent-guide/examples.md +0 -62
- moai_adk/templates/.claude/skills/moai-alfred-agent-guide/reference.md +0 -242
- moai_adk/templates/.claude/skills/moai-alfred-config-schema/SKILL.md +0 -56
- moai_adk/templates/.claude/skills/moai-alfred-config-schema/examples.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-config-schema/reference.md +0 -444
- moai_adk/templates/.claude/skills/moai-alfred-context-budget/SKILL.md +0 -62
- moai_adk/templates/.claude/skills/moai-alfred-context-budget/examples.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-context-budget/reference.md +0 -405
- moai_adk/templates/.claude/skills/moai-alfred-dev-guide/SKILL.md +0 -51
- moai_adk/templates/.claude/skills/moai-alfred-dev-guide/examples.md +0 -355
- moai_adk/templates/.claude/skills/moai-alfred-dev-guide/reference.md +0 -239
- moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-ears-authoring/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-expertise-detection/SKILL.md +0 -323
- moai_adk/templates/.claude/skills/moai-alfred-expertise-detection/examples.md +0 -286
- moai_adk/templates/.claude/skills/moai-alfred-expertise-detection/reference.md +0 -126
- moai_adk/templates/.claude/skills/moai-alfred-git-workflow/SKILL.md +0 -122
- moai_adk/templates/.claude/skills/moai-alfred-git-workflow/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-git-workflow/reference.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-gitflow-policy/SKILL.md +0 -74
- moai_adk/templates/.claude/skills/moai-alfred-gitflow-policy/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-gitflow-policy/reference.md +0 -269
- moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/SKILL.md +0 -237
- moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/examples.md +0 -615
- moai_adk/templates/.claude/skills/moai-alfred-interactive-questions/reference.md +0 -653
- moai_adk/templates/.claude/skills/moai-alfred-issue-labels/SKILL.md +0 -19
- moai_adk/templates/.claude/skills/moai-alfred-issue-labels/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-issue-labels/reference.md +0 -150
- moai_adk/templates/.claude/skills/moai-alfred-language-detection/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-language-detection/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-language-detection/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-persona-roles/SKILL.md +0 -198
- moai_adk/templates/.claude/skills/moai-alfred-persona-roles/examples.md +0 -431
- moai_adk/templates/.claude/skills/moai-alfred-persona-roles/reference.md +0 -141
- moai_adk/templates/.claude/skills/moai-alfred-practices/SKILL.md +0 -89
- moai_adk/templates/.claude/skills/moai-alfred-practices/examples.md +0 -122
- moai_adk/templates/.claude/skills/moai-alfred-practices/reference.md +0 -369
- moai_adk/templates/.claude/skills/moai-alfred-proactive-suggestions/SKILL.md +0 -508
- moai_adk/templates/.claude/skills/moai-alfred-proactive-suggestions/examples.md +0 -481
- moai_adk/templates/.claude/skills/moai-alfred-proactive-suggestions/reference.md +0 -100
- moai_adk/templates/.claude/skills/moai-alfred-reporting/SKILL.md +0 -273
- moai_adk/templates/.claude/skills/moai-alfred-rules/SKILL.md +0 -77
- moai_adk/templates/.claude/skills/moai-alfred-rules/examples.md +0 -265
- moai_adk/templates/.claude/skills/moai-alfred-rules/reference.md +0 -539
- moai_adk/templates/.claude/skills/moai-alfred-session-state/SKILL.md +0 -19
- moai_adk/templates/.claude/skills/moai-alfred-session-state/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-session-state/reference.md +0 -84
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/README.md +0 -137
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/SKILL.md +0 -219
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/examples/validate-spec.sh +0 -161
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/examples.md +0 -541
- moai_adk/templates/.claude/skills/moai-alfred-spec-authoring/reference.md +0 -622
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-extended/SKILL.md +0 -115
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-extended/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-extended/reference.md +0 -348
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-spec-metadata-validation/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-tag-scanning/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-todowrite-pattern/SKILL.md +0 -19
- moai_adk/templates/.claude/skills/moai-alfred-todowrite-pattern/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-alfred-todowrite-pattern/reference.md +0 -211
- moai_adk/templates/.claude/skills/moai-alfred-trust-validation/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-alfred-trust-validation/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-alfred-trust-validation/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-alfred-workflow/SKILL.md +0 -288
- moai_adk/templates/.claude/skills/moai-cc-agents/SKILL.md +0 -269
- moai_adk/templates/.claude/skills/moai-cc-agents/templates/agent-template.md +0 -32
- moai_adk/templates/.claude/skills/moai-cc-claude-md/SKILL.md +0 -298
- moai_adk/templates/.claude/skills/moai-cc-claude-md/templates/CLAUDE-template.md +0 -26
- moai_adk/templates/.claude/skills/moai-cc-commands/SKILL.md +0 -307
- moai_adk/templates/.claude/skills/moai-cc-commands/templates/command-template.md +0 -21
- moai_adk/templates/.claude/skills/moai-cc-hooks/SKILL.md +0 -252
- moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/pre-bash-check.sh +0 -19
- moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/preserve-permissions.sh +0 -19
- moai_adk/templates/.claude/skills/moai-cc-hooks/scripts/validate-bash-command.py +0 -24
- moai_adk/templates/.claude/skills/moai-cc-mcp-plugins/SKILL.md +0 -199
- moai_adk/templates/.claude/skills/moai-cc-mcp-plugins/templates/settings-mcp-template.json +0 -39
- moai_adk/templates/.claude/skills/moai-cc-memory/SKILL.md +0 -316
- moai_adk/templates/.claude/skills/moai-cc-memory/templates/session-summary-template.md +0 -18
- moai_adk/templates/.claude/skills/moai-cc-settings/SKILL.md +0 -263
- moai_adk/templates/.claude/skills/moai-cc-settings/templates/settings-complete-template.json +0 -30
- moai_adk/templates/.claude/skills/moai-cc-skill-descriptions/SKILL.md +0 -19
- moai_adk/templates/.claude/skills/moai-cc-skill-descriptions/examples.md +0 -4
- moai_adk/templates/.claude/skills/moai-cc-skill-descriptions/reference.md +0 -218
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/CHECKLIST.md +0 -482
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/EXAMPLES.md +0 -278
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/INTERACTIVE-DISCOVERY.md +0 -524
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/METADATA.md +0 -477
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/PARALLEL-ANALYSIS-REPORT.md +0 -429
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/PYTHON-VERSION-MATRIX.md +0 -391
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/SKILL-FACTORY-WORKFLOW.md +0 -431
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/SKILL-UPDATE-ADVISOR.md +0 -577
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/SKILL.md +0 -271
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/STEP-BY-STEP-GUIDE.md +0 -466
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/STRUCTURE.md +0 -583
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/WEB-RESEARCH.md +0 -526
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/reference.md +0 -465
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/scripts/generate-structure.sh +0 -328
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/scripts/validate-skill.sh +0 -312
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/templates/SKILL_TEMPLATE.md +0 -245
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/templates/examples-template.md +0 -285
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/templates/reference-template.md +0 -278
- moai_adk/templates/.claude/skills/moai-cc-skill-factory/templates/scripts-template.sh +0 -303
- moai_adk/templates/.claude/skills/moai-cc-skills/SKILL.md +0 -291
- moai_adk/templates/.claude/skills/moai-cc-skills/templates/SKILL-template.md +0 -15
- moai_adk/templates/.claude/skills/moai-design-systems/SKILL.md +0 -802
- moai_adk/templates/.claude/skills/moai-design-systems/examples.md +0 -1238
- moai_adk/templates/.claude/skills/moai-design-systems/reference.md +0 -673
- moai_adk/templates/.claude/skills/moai-domain-backend/SKILL.md +0 -290
- moai_adk/templates/.claude/skills/moai-domain-backend/examples.md +0 -1633
- moai_adk/templates/.claude/skills/moai-domain-backend/reference.md +0 -660
- moai_adk/templates/.claude/skills/moai-domain-cli-tool/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-cli-tool/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-cli-tool/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-data-science/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-data-science/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-data-science/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-database/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-database/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-database/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-devops/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-domain-devops/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-devops/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-domain-frontend/SKILL.md +0 -128
- moai_adk/templates/.claude/skills/moai-domain-frontend/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-frontend/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-domain-ml/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-ml/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-ml/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-mobile-app/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-mobile-app/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-mobile-app/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-security/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-security/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-security/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-domain-web-api/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-domain-web-api/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-domain-web-api/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-essentials-debug/SKILL.md +0 -303
- moai_adk/templates/.claude/skills/moai-essentials-debug/examples.md +0 -1064
- moai_adk/templates/.claude/skills/moai-essentials-debug/reference.md +0 -1047
- moai_adk/templates/.claude/skills/moai-essentials-perf/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-essentials-perf/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-essentials-perf/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-essentials-refactor/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-essentials-refactor/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-essentials-refactor/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-essentials-review/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-essentials-review/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-essentials-review/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-ears/SKILL.md +0 -116
- moai_adk/templates/.claude/skills/moai-foundation-ears/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-ears/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-git/SKILL.md +0 -122
- moai_adk/templates/.claude/skills/moai-foundation-git/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-git/reference.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-langs/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-foundation-langs/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-langs/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-specs/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-foundation-specs/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-specs/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-tags/SKILL.md +0 -113
- moai_adk/templates/.claude/skills/moai-foundation-tags/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-foundation-tags/reference.md +0 -28
- moai_adk/templates/.claude/skills/moai-foundation-trust/SKILL.md +0 -307
- moai_adk/templates/.claude/skills/moai-foundation-trust/examples.md +0 -0
- moai_adk/templates/.claude/skills/moai-foundation-trust/reference.md +0 -1099
- moai_adk/templates/.claude/skills/moai-lang-c/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-c/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-c/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-cpp/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-cpp/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-cpp/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-csharp/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-csharp/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-csharp/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-dart/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-dart/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-dart/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-go/SKILL.md +0 -127
- moai_adk/templates/.claude/skills/moai-lang-go/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-go/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-java/SKILL.md +0 -126
- moai_adk/templates/.claude/skills/moai-lang-java/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-java/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-javascript/SKILL.md +0 -125
- moai_adk/templates/.claude/skills/moai-lang-javascript/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-javascript/reference.md +0 -32
- moai_adk/templates/.claude/skills/moai-lang-kotlin/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-kotlin/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-kotlin/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-php/SKILL.md +0 -126
- moai_adk/templates/.claude/skills/moai-lang-php/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-php/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-python/SKILL.md +0 -433
- moai_adk/templates/.claude/skills/moai-lang-python/examples.md +0 -624
- moai_adk/templates/.claude/skills/moai-lang-python/reference.md +0 -316
- moai_adk/templates/.claude/skills/moai-lang-r/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-r/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-r/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-ruby/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-ruby/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-ruby/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-rust/SKILL.md +0 -127
- moai_adk/templates/.claude/skills/moai-lang-rust/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-rust/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-scala/SKILL.md +0 -125
- moai_adk/templates/.claude/skills/moai-lang-scala/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-scala/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-shell/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-shell/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-shell/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-sql/SKILL.md +0 -124
- moai_adk/templates/.claude/skills/moai-lang-sql/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-sql/reference.md +0 -31
- moai_adk/templates/.claude/skills/moai-lang-swift/SKILL.md +0 -123
- moai_adk/templates/.claude/skills/moai-lang-swift/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-swift/reference.md +0 -30
- moai_adk/templates/.claude/skills/moai-lang-typescript/SKILL.md +0 -133
- moai_adk/templates/.claude/skills/moai-lang-typescript/examples.md +0 -29
- moai_adk/templates/.claude/skills/moai-lang-typescript/reference.md +0 -34
- moai_adk/templates/.claude/skills/moai-project-documentation.md +0 -622
- moai_adk/templates/.github/workflows/c-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/cpp-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/csharp-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/dart-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/go-tag-validation.yml +0 -130
- moai_adk/templates/.github/workflows/java-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/javascript-tag-validation.yml +0 -135
- moai_adk/templates/.github/workflows/kotlin-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/php-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/python-tag-validation.yml +0 -118
- moai_adk/templates/.github/workflows/release.yml +0 -118
- moai_adk/templates/.github/workflows/ruby-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/rust-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/shell-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/swift-tag-validation.yml +0 -11
- moai_adk/templates/.github/workflows/tag-report.yml +0 -269
- moai_adk/templates/.github/workflows/tag-validation.yml +0 -186
- moai_adk/templates/.github/workflows/typescript-tag-validation.yml +0 -154
- moai_adk/templates/.moai/config.json +0 -115
- moai_adk/templates/workflows/go-tag-validation.yml +0 -30
- moai_adk/templates/workflows/javascript-tag-validation.yml +0 -41
- moai_adk/templates/workflows/python-tag-validation.yml +0 -42
- moai_adk/templates/workflows/typescript-tag-validation.yml +0 -31
- moai_adk-0.15.0.dist-info/METADATA +0 -3079
- moai_adk-0.15.0.dist-info/RECORD +0 -365
- {moai_adk-0.15.0.dist-info → moai_adk-0.25.4.dist-info}/WHEEL +0 -0
- {moai_adk-0.15.0.dist-info → moai_adk-0.25.4.dist-info}/entry_points.txt +0 -0
- {moai_adk-0.15.0.dist-info → moai_adk-0.25.4.dist-info}/licenses/LICENSE +0 -0
|
@@ -1,174 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
"""Session event handlers
|
|
3
|
-
|
|
4
|
-
SessionStart, SessionEnd event handling
|
|
5
|
-
"""
|
|
6
|
-
|
|
7
|
-
from core import HookPayload, HookResult
|
|
8
|
-
from core.checkpoint import list_checkpoints
|
|
9
|
-
from core.project import count_specs, get_git_info, get_package_version_info
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
def handle_session_start(payload: HookPayload) -> HookResult:
|
|
13
|
-
"""SessionStart event handler with GRACEFUL DEGRADATION
|
|
14
|
-
|
|
15
|
-
When Claude Code Session starts, it displays a summary of project status.
|
|
16
|
-
You can check the language, Git status, SPEC progress, and checkpoint list at a glance.
|
|
17
|
-
All optional operations are wrapped in try-except to ensure hook completes quickly even if
|
|
18
|
-
Git commands, file I/O, or other operations timeout or fail.
|
|
19
|
-
|
|
20
|
-
Args:
|
|
21
|
-
payload: Claude Code event payload (cwd key required)
|
|
22
|
-
|
|
23
|
-
Returns:
|
|
24
|
-
HookResult(system_message=project status summary message)
|
|
25
|
-
|
|
26
|
-
Message Format:
|
|
27
|
-
🚀 MoAI-ADK Session Started
|
|
28
|
-
[Version: {version}] - optional if version check fails
|
|
29
|
-
[Branch: {branch} ({commit hash})] - optional if git fails
|
|
30
|
-
[Changes: {Number of Changed Files}] - optional if git fails
|
|
31
|
-
[SPEC Progress: {Complete}/{Total} ({percent}%)] - optional if specs fail
|
|
32
|
-
[Checkpoints: {number} available] - optional if checkpoint list fails
|
|
33
|
-
|
|
34
|
-
Graceful Degradation Strategy:
|
|
35
|
-
- OPTIONAL: Version info (skip if timeout/failure)
|
|
36
|
-
- OPTIONAL: Git info (skip if timeout/failure)
|
|
37
|
-
- OPTIONAL: SPEC progress (skip if timeout/failure)
|
|
38
|
-
- OPTIONAL: Checkpoint list (skip if timeout/failure)
|
|
39
|
-
- Always display SOMETHING to user, never return empty message
|
|
40
|
-
|
|
41
|
-
Note:
|
|
42
|
-
- Claude Code processes SessionStart in several stages (clear → compact)
|
|
43
|
-
- Display message only at "compact" stage to prevent duplicate output
|
|
44
|
-
- "clear" step returns minimal result (empty hookSpecificOutput)
|
|
45
|
-
- CRITICAL: All optional operations must complete within 2-3 seconds total
|
|
46
|
-
|
|
47
|
-
TDD History:
|
|
48
|
-
- RED: Session startup message format test
|
|
49
|
-
- GREEN: Generate status message by combining helper functions
|
|
50
|
-
- REFACTOR: Improved message format, improved readability, added checkpoint list
|
|
51
|
-
- FIX: Prevent duplicate output of clear step (only compact step is displayed)
|
|
52
|
-
- UPDATE: Migrated to Claude Code standard Hook schema
|
|
53
|
-
- HOTFIX: Add graceful degradation for timeout scenarios (Issue #66)
|
|
54
|
-
- Phase 3: Add major version warning and release notes display (@TEST:MAJOR-UPDATE-001-07/08)
|
|
55
|
-
|
|
56
|
-
@TAG:CHECKPOINT-EVENT-001
|
|
57
|
-
@TAG:HOOKS-TIMEOUT-001
|
|
58
|
-
@CODE:MAJOR-UPDATE-WARN-001
|
|
59
|
-
"""
|
|
60
|
-
# Claude Code SessionStart runs in several stages (clear, compact, etc.)
|
|
61
|
-
# Ignore the "clear" stage and output messages only at the "compact" stage
|
|
62
|
-
event_phase = payload.get("phase", "")
|
|
63
|
-
if event_phase == "clear":
|
|
64
|
-
# Return minimal valid Hook result for clear phase
|
|
65
|
-
return HookResult(continue_execution=True)
|
|
66
|
-
|
|
67
|
-
cwd = payload.get("cwd", ".")
|
|
68
|
-
|
|
69
|
-
# OPTIONAL: Git info - skip if timeout/failure
|
|
70
|
-
git_info = {}
|
|
71
|
-
try:
|
|
72
|
-
git_info = get_git_info(cwd)
|
|
73
|
-
except Exception:
|
|
74
|
-
# Graceful degradation - continue without git info
|
|
75
|
-
pass
|
|
76
|
-
|
|
77
|
-
# OPTIONAL: SPEC progress - skip if timeout/failure
|
|
78
|
-
specs = {"completed": 0, "total": 0, "percentage": 0}
|
|
79
|
-
try:
|
|
80
|
-
specs = count_specs(cwd)
|
|
81
|
-
except Exception:
|
|
82
|
-
# Graceful degradation - continue without spec info
|
|
83
|
-
pass
|
|
84
|
-
|
|
85
|
-
# OPTIONAL: Checkpoint list - skip if timeout/failure
|
|
86
|
-
checkpoints = []
|
|
87
|
-
try:
|
|
88
|
-
checkpoints = list_checkpoints(cwd, max_count=10)
|
|
89
|
-
except Exception:
|
|
90
|
-
# Graceful degradation - continue without checkpoints
|
|
91
|
-
pass
|
|
92
|
-
|
|
93
|
-
# OPTIONAL: Package version info - skip if timeout/failure
|
|
94
|
-
version_info = {}
|
|
95
|
-
try:
|
|
96
|
-
version_info = get_package_version_info()
|
|
97
|
-
except Exception:
|
|
98
|
-
# Graceful degradation - continue without version info
|
|
99
|
-
pass
|
|
100
|
-
|
|
101
|
-
# Build message with available information
|
|
102
|
-
branch = git_info.get("branch", "N/A") if git_info else "N/A"
|
|
103
|
-
commit = git_info.get("commit", "N/A")[:7] if git_info else "N/A"
|
|
104
|
-
changes = git_info.get("changes", 0) if git_info else 0
|
|
105
|
-
spec_progress = f"{specs['completed']}/{specs['total']}" if specs["total"] > 0 else "0/0"
|
|
106
|
-
|
|
107
|
-
# system_message: displayed directly to the user
|
|
108
|
-
lines = [
|
|
109
|
-
"🚀 MoAI-ADK Session Started",
|
|
110
|
-
"", # Blank line after title
|
|
111
|
-
]
|
|
112
|
-
|
|
113
|
-
# Add version info first (at the top, right after title)
|
|
114
|
-
if version_info and version_info.get("current") != "unknown":
|
|
115
|
-
if version_info.get("update_available"):
|
|
116
|
-
# Check if this is a major version update
|
|
117
|
-
if version_info.get("is_major_update"):
|
|
118
|
-
# Major version warning
|
|
119
|
-
lines.append(
|
|
120
|
-
f" ⚠️ Major version update available: {version_info['current']} → {version_info['latest']}"
|
|
121
|
-
)
|
|
122
|
-
lines.append(" Breaking changes detected. Review release notes:")
|
|
123
|
-
if version_info.get("release_notes_url"):
|
|
124
|
-
lines.append(f" 📝 {version_info['release_notes_url']}")
|
|
125
|
-
else:
|
|
126
|
-
# Regular update
|
|
127
|
-
lines.append(
|
|
128
|
-
f" 🗿 MoAI-ADK Ver: {version_info['current']} → {version_info['latest']} available ✨"
|
|
129
|
-
)
|
|
130
|
-
if version_info.get("release_notes_url"):
|
|
131
|
-
lines.append(f" 📝 Release Notes: {version_info['release_notes_url']}")
|
|
132
|
-
|
|
133
|
-
# Add upgrade recommendation
|
|
134
|
-
if version_info.get("upgrade_command"):
|
|
135
|
-
lines.append(f" ⬆️ Upgrade: {version_info['upgrade_command']}")
|
|
136
|
-
else:
|
|
137
|
-
# No update available - show current version only
|
|
138
|
-
lines.append(f" 🗿 MoAI-ADK Ver: {version_info['current']}")
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
# Add Git info only if available (not degraded)
|
|
142
|
-
if git_info:
|
|
143
|
-
lines.append(f" 🌿 Branch: {branch} ({commit})")
|
|
144
|
-
lines.append(f" 📝 Changes: {changes}")
|
|
145
|
-
|
|
146
|
-
# Add last commit message if available
|
|
147
|
-
last_commit = git_info.get("last_commit", "")
|
|
148
|
-
if last_commit:
|
|
149
|
-
lines.append(f" 🔨 Last: {last_commit}")
|
|
150
|
-
|
|
151
|
-
# Add Checkpoint list (show only the latest 3 items)
|
|
152
|
-
if checkpoints:
|
|
153
|
-
lines.append(f" 🗂️ Checkpoints: {len(checkpoints)} available")
|
|
154
|
-
for cp in reversed(checkpoints[-3:]): # Latest 3 items
|
|
155
|
-
branch_short = cp["branch"].replace("before-", "")
|
|
156
|
-
lines.append(f" 📌 {branch_short}")
|
|
157
|
-
lines.append("") # Blank line before restore command
|
|
158
|
-
lines.append(" ↩️ Restore: /alfred:0-project restore")
|
|
159
|
-
|
|
160
|
-
# Add SPEC progress only if available (not degraded) - at the bottom
|
|
161
|
-
if specs["total"] > 0:
|
|
162
|
-
lines.append(f" 📋 SPEC Progress: {spec_progress} ({specs['percentage']}%)")
|
|
163
|
-
|
|
164
|
-
system_message = "\n".join(lines)
|
|
165
|
-
|
|
166
|
-
return HookResult(system_message=system_message)
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
def handle_session_end(payload: HookPayload) -> HookResult:
|
|
170
|
-
"""SessionEnd event handler (default implementation)"""
|
|
171
|
-
return HookResult()
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
__all__ = ["handle_session_start", "handle_session_end"]
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
# @CODE:HOOK-TOOL-001 | SPEC: TBD | TEST: tests/hooks/test_handlers.py
|
|
3
|
-
"""Tool usage handlers
|
|
4
|
-
|
|
5
|
-
PreToolUse, PostToolUse event handling
|
|
6
|
-
"""
|
|
7
|
-
|
|
8
|
-
from core import HookPayload, HookResult
|
|
9
|
-
from core.checkpoint import create_checkpoint, detect_risky_operation
|
|
10
|
-
from core.tags import scan_recent_changes_for_missing_tags
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
def handle_pre_tool_use(payload: HookPayload) -> HookResult:
|
|
14
|
-
"""PreToolUse event handler (Event-Driven Checkpoint integration)
|
|
15
|
-
|
|
16
|
-
Automatically creates checkpoints before dangerous operations.
|
|
17
|
-
Called before using the Claude Code tool, it notifies the user when danger is detected.
|
|
18
|
-
|
|
19
|
-
Args:
|
|
20
|
-
payload: Claude Code event payload
|
|
21
|
-
(includes tool, arguments, cwd keys)
|
|
22
|
-
|
|
23
|
-
Returns:
|
|
24
|
-
HookResult(
|
|
25
|
-
system_message=checkpoint creation notification (when danger is detected);
|
|
26
|
-
continue_execution=True (always continue operation)
|
|
27
|
-
)
|
|
28
|
-
|
|
29
|
-
Checkpoint Triggers:
|
|
30
|
-
- Bash: rm -rf, git merge, git reset --hard
|
|
31
|
-
- Edit/Write: CLAUDE.md, config.json
|
|
32
|
-
- MultiEdit: ≥10 files
|
|
33
|
-
|
|
34
|
-
Examples:
|
|
35
|
-
Bash tool (rm -rf) detection:
|
|
36
|
-
→ "🛡️ Checkpoint created: before-delete-20251015-143000"
|
|
37
|
-
|
|
38
|
-
Notes:
|
|
39
|
-
- Return continue_execution=True even after detection of danger (continue operation)
|
|
40
|
-
- Work continues even when checkpoint fails (ignores)
|
|
41
|
-
- Transparent background operation
|
|
42
|
-
|
|
43
|
-
@TAG:CHECKPOINT-EVENT-001
|
|
44
|
-
"""
|
|
45
|
-
tool_name = payload.get("tool", "")
|
|
46
|
-
tool_args = payload.get("arguments", {})
|
|
47
|
-
cwd = payload.get("cwd", ".")
|
|
48
|
-
|
|
49
|
-
# Dangerous operation detection (best-effort)
|
|
50
|
-
try:
|
|
51
|
-
is_risky, operation_type = detect_risky_operation(tool_name, tool_args, cwd)
|
|
52
|
-
# Create checkpoint when danger is detected
|
|
53
|
-
if is_risky:
|
|
54
|
-
checkpoint_branch = create_checkpoint(cwd, operation_type)
|
|
55
|
-
if checkpoint_branch != "checkpoint-failed":
|
|
56
|
-
system_message = (
|
|
57
|
-
f"🛡️ Checkpoint created: {checkpoint_branch}\n Operation: {operation_type}"
|
|
58
|
-
)
|
|
59
|
-
return HookResult(system_message=system_message, continue_execution=True)
|
|
60
|
-
except Exception:
|
|
61
|
-
# Do not fail the hook if risk detection errors out
|
|
62
|
-
pass
|
|
63
|
-
|
|
64
|
-
# TAG Guard (gentle): warn when recent changes miss @TAG
|
|
65
|
-
issues = scan_recent_changes_for_missing_tags(cwd)
|
|
66
|
-
if issues:
|
|
67
|
-
# Summarize first few issues for display
|
|
68
|
-
preview = "\n".join(f" - {i.path} → 기대 태그: {i.expected}" for i in issues[:5])
|
|
69
|
-
more = "" if len(issues) <= 5 else f"\n (외 {len(issues) - 5}건 더 존재)"
|
|
70
|
-
msg = (
|
|
71
|
-
"⚠️ TAG 누락 감지: 생성/수정한 파일 중 @TAG가 없는 항목이 있습니다.\n"
|
|
72
|
-
f"{preview}{more}\n"
|
|
73
|
-
"권장 조치:\n"
|
|
74
|
-
" 1) SPEC/TEST/CODE/DOC 유형에 맞는 @TAG를 파일 상단 주석이나 헤더에 추가\n"
|
|
75
|
-
" 2) rg로 확인: rg '@(SPEC|TEST|CODE|DOC):' -n <경로>\n"
|
|
76
|
-
)
|
|
77
|
-
return HookResult(system_message=msg, continue_execution=True)
|
|
78
|
-
|
|
79
|
-
return HookResult(continue_execution=True)
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
def handle_post_tool_use(payload: HookPayload) -> HookResult:
|
|
83
|
-
"""PostToolUse event handler (default implementation)"""
|
|
84
|
-
return HookResult()
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
__all__ = ["handle_pre_tool_use", "handle_post_tool_use"]
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
"""User interaction handlers
|
|
3
|
-
|
|
4
|
-
Handling the UserPromptSubmit event
|
|
5
|
-
"""
|
|
6
|
-
|
|
7
|
-
from datetime import datetime
|
|
8
|
-
from pathlib import Path
|
|
9
|
-
|
|
10
|
-
from core import HookPayload, HookResult
|
|
11
|
-
from core.context import get_jit_context
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
def handle_user_prompt_submit(payload: HookPayload) -> HookResult:
|
|
15
|
-
"""UserPromptSubmit event handler
|
|
16
|
-
|
|
17
|
-
Analyze user prompts and automatically add relevant documents into context.
|
|
18
|
-
Follow the just-in-time (JIT) retrieval principle to load only the documents you need.
|
|
19
|
-
|
|
20
|
-
Args:
|
|
21
|
-
payload: Claude Code event payload
|
|
22
|
-
(includes userPrompt, cwd keys)
|
|
23
|
-
|
|
24
|
-
Returns:
|
|
25
|
-
HookResult(
|
|
26
|
-
system_message=Number of Files loaded (or None),
|
|
27
|
-
context_files=Recommended document path list
|
|
28
|
-
)
|
|
29
|
-
|
|
30
|
-
TDD History:
|
|
31
|
-
- RED: JIT document loading scenario testing
|
|
32
|
-
- GREEN: Recommend documents by calling get_jit_context()
|
|
33
|
-
- REFACTOR: Message conditional display (only when there is a file)
|
|
34
|
-
- UPDATE: Migrated to Claude Code standard Hook schema with snake_case fields
|
|
35
|
-
- FEATURE: Command execution logging for tracking double-run debugging
|
|
36
|
-
"""
|
|
37
|
-
user_prompt = payload.get("userPrompt", "")
|
|
38
|
-
cwd = payload.get("cwd", ".")
|
|
39
|
-
context_files = get_jit_context(user_prompt, cwd)
|
|
40
|
-
|
|
41
|
-
# Command execution logging (DEBUG feature for tracking invocations)
|
|
42
|
-
if user_prompt.startswith("/alfred:"):
|
|
43
|
-
try:
|
|
44
|
-
log_dir = Path(cwd) / ".moai" / "logs"
|
|
45
|
-
log_dir.mkdir(parents=True, exist_ok=True)
|
|
46
|
-
|
|
47
|
-
log_file = log_dir / "command-invocations.log"
|
|
48
|
-
timestamp = datetime.now().isoformat()
|
|
49
|
-
|
|
50
|
-
with open(log_file, "a", encoding="utf-8") as f:
|
|
51
|
-
f.write(f"{timestamp} | {user_prompt}\n")
|
|
52
|
-
except Exception:
|
|
53
|
-
# Silently fail if logging fails (don't interrupt main flow)
|
|
54
|
-
pass
|
|
55
|
-
|
|
56
|
-
system_message = f"📎 Loaded {len(context_files)} context file(s)" if context_files else None
|
|
57
|
-
|
|
58
|
-
return HookResult(system_message=system_message, context_files=context_files)
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
__all__ = ["handle_user_prompt_submit"]
|
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
# @CODE:HOOKS-CLARITY-DOCS | SPEC: Individual hook files for better UX
|
|
3
|
-
"""UserPromptSubmit Hook: Just-In-Time Document Loading
|
|
4
|
-
|
|
5
|
-
Claude Code Event: UserPromptSubmit
|
|
6
|
-
Purpose: Analyze user prompt and recommend relevant documents to load into context
|
|
7
|
-
Execution: Triggered when user submits a prompt
|
|
8
|
-
|
|
9
|
-
Output: additionalContext with document path suggestions
|
|
10
|
-
"""
|
|
11
|
-
|
|
12
|
-
import json
|
|
13
|
-
import sys
|
|
14
|
-
from pathlib import Path
|
|
15
|
-
from typing import Any
|
|
16
|
-
|
|
17
|
-
from utils.timeout import CrossPlatformTimeout
|
|
18
|
-
from utils.timeout import TimeoutError as PlatformTimeoutError
|
|
19
|
-
|
|
20
|
-
# Setup import path for shared modules
|
|
21
|
-
HOOKS_DIR = Path(__file__).parent
|
|
22
|
-
SHARED_DIR = HOOKS_DIR / "shared"
|
|
23
|
-
if str(SHARED_DIR) not in sys.path:
|
|
24
|
-
sys.path.insert(0, str(SHARED_DIR))
|
|
25
|
-
|
|
26
|
-
from handlers import handle_user_prompt_submit
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
def main() -> None:
|
|
30
|
-
"""Main entry point for UserPromptSubmit hook
|
|
31
|
-
|
|
32
|
-
Analyzes user prompt patterns and recommends relevant documents:
|
|
33
|
-
- /alfred:1-plan → spec-metadata.md
|
|
34
|
-
- /alfred:2-run → development-guide.md
|
|
35
|
-
- @TAG mentions → TAG documentation
|
|
36
|
-
- SPEC references → related SPEC files
|
|
37
|
-
|
|
38
|
-
Exit Codes:
|
|
39
|
-
0: Success
|
|
40
|
-
1: Error (timeout, JSON parse failure, handler exception)
|
|
41
|
-
|
|
42
|
-
Note: Uses special output schema for UserPromptSubmit:
|
|
43
|
-
{
|
|
44
|
-
"continue": true,
|
|
45
|
-
"hookSpecificOutput": {
|
|
46
|
-
"hookEventName": "UserPromptSubmit",
|
|
47
|
-
"additionalContext": "Document path suggestions..."
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
"""
|
|
51
|
-
# Set 5-second timeout
|
|
52
|
-
timeout = CrossPlatformTimeout(5)
|
|
53
|
-
timeout.start()
|
|
54
|
-
|
|
55
|
-
try:
|
|
56
|
-
# Read JSON payload from stdin
|
|
57
|
-
input_data = sys.stdin.read()
|
|
58
|
-
data = json.loads(input_data) if input_data.strip() else {}
|
|
59
|
-
|
|
60
|
-
# Call handler
|
|
61
|
-
result = handle_user_prompt_submit(data)
|
|
62
|
-
|
|
63
|
-
# Output result using UserPromptSubmit-specific schema
|
|
64
|
-
print(json.dumps(result.to_user_prompt_submit_dict()))
|
|
65
|
-
sys.exit(0)
|
|
66
|
-
|
|
67
|
-
except PlatformTimeoutError:
|
|
68
|
-
# Timeout - return minimal valid response
|
|
69
|
-
timeout_response: dict[str, Any] = {
|
|
70
|
-
"continue": True,
|
|
71
|
-
"hookSpecificOutput": {
|
|
72
|
-
"hookEventName": "UserPromptSubmit",
|
|
73
|
-
"additionalContext": "⚠️ JIT context timeout - continuing without suggestions",
|
|
74
|
-
},
|
|
75
|
-
}
|
|
76
|
-
print(json.dumps(timeout_response))
|
|
77
|
-
print("UserPromptSubmit hook timeout after 5 seconds", file=sys.stderr)
|
|
78
|
-
sys.exit(1)
|
|
79
|
-
|
|
80
|
-
except json.JSONDecodeError as e:
|
|
81
|
-
# JSON parse error
|
|
82
|
-
error_response: dict[str, Any] = {
|
|
83
|
-
"continue": True,
|
|
84
|
-
"hookSpecificOutput": {
|
|
85
|
-
"hookEventName": "UserPromptSubmit",
|
|
86
|
-
"error": f"JSON parse error: {e}",
|
|
87
|
-
},
|
|
88
|
-
}
|
|
89
|
-
print(json.dumps(error_response))
|
|
90
|
-
print(f"UserPromptSubmit JSON parse error: {e}", file=sys.stderr)
|
|
91
|
-
sys.exit(1)
|
|
92
|
-
|
|
93
|
-
except Exception as e:
|
|
94
|
-
# Unexpected error
|
|
95
|
-
error_response: dict[str, Any] = {
|
|
96
|
-
"continue": True,
|
|
97
|
-
"hookSpecificOutput": {
|
|
98
|
-
"hookEventName": "UserPromptSubmit",
|
|
99
|
-
"error": f"UserPromptSubmit error: {e}",
|
|
100
|
-
},
|
|
101
|
-
}
|
|
102
|
-
print(json.dumps(error_response))
|
|
103
|
-
print(f"UserPromptSubmit unexpected error: {e}", file=sys.stderr)
|
|
104
|
-
sys.exit(1)
|
|
105
|
-
|
|
106
|
-
finally:
|
|
107
|
-
# Always cancel alarm
|
|
108
|
-
timeout.cancel()
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
if __name__ == "__main__":
|
|
112
|
-
main()
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"""Utility modules for Alfred hooks."""
|
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
# @CODE:TIMEOUT-001 | SPEC: SPEC-TIMEOUT-HANDLING-001
|
|
3
|
-
"""Cross-Platform Timeout Handler for Windows & Unix Compatibility
|
|
4
|
-
|
|
5
|
-
Provides a unified timeout mechanism that works on both Windows (threading-based)
|
|
6
|
-
and Unix/POSIX systems (signal-based).
|
|
7
|
-
|
|
8
|
-
Architecture:
|
|
9
|
-
- Windows: threading.Timer with exception injection
|
|
10
|
-
- Unix/POSIX: signal.SIGALRM (traditional approach)
|
|
11
|
-
- Both: Context manager for clean cancellation
|
|
12
|
-
"""
|
|
13
|
-
|
|
14
|
-
import platform
|
|
15
|
-
import signal
|
|
16
|
-
import threading
|
|
17
|
-
from contextlib import contextmanager
|
|
18
|
-
from typing import Callable, Optional
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
class TimeoutError(Exception):
|
|
22
|
-
"""Timeout exception raised when deadline exceeded"""
|
|
23
|
-
pass
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
class CrossPlatformTimeout:
|
|
27
|
-
"""Cross-platform timeout handler supporting Windows and Unix.
|
|
28
|
-
|
|
29
|
-
Windows: Uses threading.Timer to schedule timeout exception
|
|
30
|
-
Unix: Uses signal.SIGALRM for timeout handling
|
|
31
|
-
|
|
32
|
-
Usage:
|
|
33
|
-
# Context manager (recommended)
|
|
34
|
-
with CrossPlatformTimeout(5):
|
|
35
|
-
long_running_operation()
|
|
36
|
-
|
|
37
|
-
# Manual control
|
|
38
|
-
timeout = CrossPlatformTimeout(5)
|
|
39
|
-
timeout.start()
|
|
40
|
-
try:
|
|
41
|
-
long_running_operation()
|
|
42
|
-
finally:
|
|
43
|
-
timeout.cancel()
|
|
44
|
-
"""
|
|
45
|
-
|
|
46
|
-
def __init__(self, timeout_seconds: float, callback: Optional[Callable] = None):
|
|
47
|
-
"""Initialize timeout with duration in seconds.
|
|
48
|
-
|
|
49
|
-
Args:
|
|
50
|
-
timeout_seconds: Timeout duration in seconds (float or int)
|
|
51
|
-
callback: Optional callback to execute before raising TimeoutError
|
|
52
|
-
"""
|
|
53
|
-
# Convert float to int for signal.alarm()
|
|
54
|
-
self.timeout_seconds = timeout_seconds
|
|
55
|
-
self.timeout_seconds_int = max(1, int(timeout_seconds)) # signal.alarm requires >=1
|
|
56
|
-
self.callback = callback
|
|
57
|
-
self.timer: Optional[threading.Timer] = None
|
|
58
|
-
self._is_windows = platform.system() == "Windows"
|
|
59
|
-
self._old_handler = None
|
|
60
|
-
|
|
61
|
-
def start(self) -> None:
|
|
62
|
-
"""Start timeout countdown."""
|
|
63
|
-
# Handle zero/negative timeouts
|
|
64
|
-
if self.timeout_seconds <= 0:
|
|
65
|
-
if self.timeout_seconds == 0:
|
|
66
|
-
# Zero timeout: raise immediately
|
|
67
|
-
if self.callback:
|
|
68
|
-
self.callback()
|
|
69
|
-
raise TimeoutError("Timeout of 0 seconds exceeded immediately")
|
|
70
|
-
else:
|
|
71
|
-
# Negative timeout: don't timeout at all
|
|
72
|
-
return
|
|
73
|
-
|
|
74
|
-
if self._is_windows:
|
|
75
|
-
self._start_windows_timeout()
|
|
76
|
-
else:
|
|
77
|
-
self._start_unix_timeout()
|
|
78
|
-
|
|
79
|
-
def cancel(self) -> None:
|
|
80
|
-
"""Cancel timeout (must call before timeout expires)."""
|
|
81
|
-
if self._is_windows:
|
|
82
|
-
self._cancel_windows_timeout()
|
|
83
|
-
else:
|
|
84
|
-
self._cancel_unix_timeout()
|
|
85
|
-
|
|
86
|
-
def _start_windows_timeout(self) -> None:
|
|
87
|
-
"""Windows: Use threading.Timer to raise exception."""
|
|
88
|
-
def timeout_handler():
|
|
89
|
-
if self.callback:
|
|
90
|
-
self.callback()
|
|
91
|
-
raise TimeoutError(
|
|
92
|
-
f"Operation exceeded {self.timeout_seconds}s timeout (Windows threading)"
|
|
93
|
-
)
|
|
94
|
-
|
|
95
|
-
self.timer = threading.Timer(self.timeout_seconds, timeout_handler)
|
|
96
|
-
self.timer.daemon = True
|
|
97
|
-
self.timer.start()
|
|
98
|
-
|
|
99
|
-
def _cancel_windows_timeout(self) -> None:
|
|
100
|
-
"""Windows: Cancel timer thread."""
|
|
101
|
-
if self.timer:
|
|
102
|
-
self.timer.cancel()
|
|
103
|
-
self.timer = None
|
|
104
|
-
|
|
105
|
-
def _start_unix_timeout(self) -> None:
|
|
106
|
-
"""Unix/POSIX: Use signal.SIGALRM for timeout."""
|
|
107
|
-
def signal_handler(signum, frame):
|
|
108
|
-
if self.callback:
|
|
109
|
-
try:
|
|
110
|
-
self.callback()
|
|
111
|
-
except Exception:
|
|
112
|
-
# Ignore callback exceptions, timeout error takes precedence
|
|
113
|
-
pass
|
|
114
|
-
raise TimeoutError(
|
|
115
|
-
f"Operation exceeded {self.timeout_seconds}s timeout (Unix signal)"
|
|
116
|
-
)
|
|
117
|
-
|
|
118
|
-
# Save old handler to restore later
|
|
119
|
-
self._old_handler = signal.signal(signal.SIGALRM, signal_handler)
|
|
120
|
-
# Use integer timeout_seconds_int for signal.alarm()
|
|
121
|
-
signal.alarm(self.timeout_seconds_int)
|
|
122
|
-
|
|
123
|
-
def _cancel_unix_timeout(self) -> None:
|
|
124
|
-
"""Unix/POSIX: Cancel alarm and restore old handler."""
|
|
125
|
-
signal.alarm(0) # Cancel pending alarm
|
|
126
|
-
if self._old_handler is not None:
|
|
127
|
-
signal.signal(signal.SIGALRM, self._old_handler)
|
|
128
|
-
self._old_handler = None
|
|
129
|
-
|
|
130
|
-
def __enter__(self):
|
|
131
|
-
"""Context manager entry."""
|
|
132
|
-
self.start()
|
|
133
|
-
return self
|
|
134
|
-
|
|
135
|
-
def __exit__(self, exc_type, exc_val, exc_tb):
|
|
136
|
-
"""Context manager exit - always cancel."""
|
|
137
|
-
self.cancel()
|
|
138
|
-
return False # Don't suppress exceptions
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
@contextmanager
|
|
142
|
-
def timeout_context(timeout_seconds: float, callback: Optional[Callable] = None):
|
|
143
|
-
"""Decorator/context manager for timeout.
|
|
144
|
-
|
|
145
|
-
Usage:
|
|
146
|
-
with timeout_context(5):
|
|
147
|
-
slow_function()
|
|
148
|
-
|
|
149
|
-
Args:
|
|
150
|
-
timeout_seconds: Timeout duration in seconds (float or int)
|
|
151
|
-
callback: Optional callback to execute before raising TimeoutError
|
|
152
|
-
|
|
153
|
-
Yields:
|
|
154
|
-
CrossPlatformTimeout instance
|
|
155
|
-
"""
|
|
156
|
-
timeout = CrossPlatformTimeout(timeout_seconds, callback=callback)
|
|
157
|
-
timeout.start()
|
|
158
|
-
try:
|
|
159
|
-
yield timeout
|
|
160
|
-
finally:
|
|
161
|
-
timeout.cancel()
|