@takuma-hirai/hirai-method 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/.stale-harness-state/last-check +0 -0
- package/.claude/CommonRules.md +121 -0
- package/.claude/agents/01-core-development/api-designer.md +237 -0
- package/.claude/agents/01-core-development/backend-developer.md +222 -0
- package/.claude/agents/01-core-development/design-bridge.md +127 -0
- package/.claude/agents/01-core-development/electron-pro.md +240 -0
- package/.claude/agents/01-core-development/frontend-developer.md +133 -0
- package/.claude/agents/01-core-development/fullstack-developer.md +235 -0
- package/.claude/agents/01-core-development/graphql-architect.md +238 -0
- package/.claude/agents/01-core-development/microservices-architect.md +239 -0
- package/.claude/agents/01-core-development/mobile-developer.md +283 -0
- package/.claude/agents/01-core-development/ui-designer.md +174 -0
- package/.claude/agents/01-core-development/websocket-engineer.md +150 -0
- package/.claude/agents/03-infrastructure/azure-infra-engineer.md +53 -0
- package/.claude/agents/03-infrastructure/cloud-architect.md +277 -0
- package/.claude/agents/03-infrastructure/database-administrator.md +287 -0
- package/.claude/agents/03-infrastructure/deployment-engineer.md +287 -0
- package/.claude/agents/03-infrastructure/devops-engineer.md +287 -0
- package/.claude/agents/03-infrastructure/devops-incident-responder.md +287 -0
- package/.claude/agents/03-infrastructure/docker-expert.md +278 -0
- package/.claude/agents/03-infrastructure/incident-responder.md +287 -0
- package/.claude/agents/03-infrastructure/kubernetes-specialist.md +287 -0
- package/.claude/agents/03-infrastructure/network-engineer.md +287 -0
- package/.claude/agents/03-infrastructure/platform-engineer.md +287 -0
- package/.claude/agents/03-infrastructure/security-engineer.md +277 -0
- package/.claude/agents/03-infrastructure/sre-engineer.md +287 -0
- package/.claude/agents/03-infrastructure/terraform-engineer.md +287 -0
- package/.claude/agents/03-infrastructure/terragrunt-expert.md +307 -0
- package/.claude/agents/03-infrastructure/windows-infra-admin.md +52 -0
- package/.claude/agents/04-quality-security/accessibility-tester.md +277 -0
- package/.claude/agents/04-quality-security/ad-security-reviewer.md +56 -0
- package/.claude/agents/04-quality-security/ai-writing-auditor.md +77 -0
- package/.claude/agents/04-quality-security/architect-reviewer.md +287 -0
- package/.claude/agents/04-quality-security/chaos-engineer.md +277 -0
- package/.claude/agents/04-quality-security/code-reviewer.md +287 -0
- package/.claude/agents/04-quality-security/compliance-auditor.md +277 -0
- package/.claude/agents/04-quality-security/debugger.md +287 -0
- package/.claude/agents/04-quality-security/error-detective.md +287 -0
- package/.claude/agents/04-quality-security/penetration-tester.md +287 -0
- package/.claude/agents/04-quality-security/performance-engineer.md +287 -0
- package/.claude/agents/04-quality-security/powershell-security-hardening.md +54 -0
- package/.claude/agents/04-quality-security/qa-expert.md +287 -0
- package/.claude/agents/04-quality-security/security-auditor.md +287 -0
- package/.claude/agents/04-quality-security/test-automator.md +287 -0
- package/.claude/agents/04-quality-security/ui-ux-tester.md +234 -0
- package/.claude/agents/06-developer-experience/build-engineer.md +286 -0
- package/.claude/agents/06-developer-experience/cli-developer.md +286 -0
- package/.claude/agents/06-developer-experience/dependency-manager.md +286 -0
- package/.claude/agents/06-developer-experience/documentation-engineer.md +276 -0
- package/.claude/agents/06-developer-experience/dx-optimizer.md +286 -0
- package/.claude/agents/06-developer-experience/git-workflow-manager.md +286 -0
- package/.claude/agents/06-developer-experience/legacy-modernizer.md +286 -0
- package/.claude/agents/06-developer-experience/mcp-developer.md +275 -0
- package/.claude/agents/06-developer-experience/powershell-module-architect.md +58 -0
- package/.claude/agents/06-developer-experience/powershell-ui-architect.md +135 -0
- package/.claude/agents/06-developer-experience/readme-generator.md +238 -0
- package/.claude/agents/06-developer-experience/refactoring-specialist.md +286 -0
- package/.claude/agents/06-developer-experience/slack-expert.md +232 -0
- package/.claude/agents/06-developer-experience/tooling-engineer.md +286 -0
- package/.claude/agents/09-meta-orchestration/agent-installer.md +97 -0
- package/.claude/agents/09-meta-orchestration/agent-organizer.md +287 -0
- package/.claude/agents/09-meta-orchestration/codebase-orchestrator.md +249 -0
- package/.claude/agents/09-meta-orchestration/context-manager.md +287 -0
- package/.claude/agents/09-meta-orchestration/error-coordinator.md +287 -0
- package/.claude/agents/09-meta-orchestration/it-ops-orchestrator.md +60 -0
- package/.claude/agents/09-meta-orchestration/knowledge-synthesizer.md +287 -0
- package/.claude/agents/09-meta-orchestration/multi-agent-coordinator.md +287 -0
- package/.claude/agents/09-meta-orchestration/performance-monitor.md +287 -0
- package/.claude/agents/09-meta-orchestration/task-distributor.md +287 -0
- package/.claude/agents/09-meta-orchestration/workflow-orchestrator.md +287 -0
- package/.claude/agents/10-research-analysis/competitive-analyst.md +287 -0
- package/.claude/agents/10-research-analysis/data-researcher.md +287 -0
- package/.claude/agents/10-research-analysis/market-researcher.md +287 -0
- package/.claude/agents/10-research-analysis/project-idea-validator.md +269 -0
- package/.claude/agents/10-research-analysis/research-analyst.md +287 -0
- package/.claude/agents/10-research-analysis/scientific-literature-researcher.md +151 -0
- package/.claude/agents/10-research-analysis/search-specialist.md +287 -0
- package/.claude/agents/10-research-analysis/trend-analyst.md +287 -0
- package/.claude/archive/README.md +47 -0
- package/.claude/archive/agents/02-language-specialists/angular-architect.md +287 -0
- package/.claude/archive/agents/02-language-specialists/cpp-pro.md +277 -0
- package/.claude/archive/agents/02-language-specialists/csharp-developer.md +287 -0
- package/.claude/archive/agents/02-language-specialists/django-developer.md +287 -0
- package/.claude/archive/agents/02-language-specialists/dotnet-core-expert.md +287 -0
- package/.claude/archive/agents/02-language-specialists/dotnet-framework-4.8-expert.md +306 -0
- package/.claude/archive/agents/02-language-specialists/elixir-expert.md +311 -0
- package/.claude/archive/agents/02-language-specialists/expo-react-native-expert.md +268 -0
- package/.claude/archive/agents/02-language-specialists/fastapi-developer.md +287 -0
- package/.claude/archive/agents/02-language-specialists/flutter-expert.md +287 -0
- package/.claude/archive/agents/02-language-specialists/golang-pro.md +277 -0
- package/.claude/archive/agents/02-language-specialists/java-architect.md +287 -0
- package/.claude/archive/agents/02-language-specialists/javascript-pro.md +277 -0
- package/.claude/archive/agents/02-language-specialists/kotlin-specialist.md +287 -0
- package/.claude/archive/agents/02-language-specialists/laravel-specialist.md +287 -0
- package/.claude/archive/agents/02-language-specialists/nextjs-developer.md +287 -0
- package/.claude/archive/agents/02-language-specialists/node-specialist.md +124 -0
- package/.claude/archive/agents/02-language-specialists/php-pro.md +287 -0
- package/.claude/archive/agents/02-language-specialists/powershell-5.1-expert.md +59 -0
- package/.claude/archive/agents/02-language-specialists/powershell-7-expert.md +57 -0
- package/.claude/archive/agents/02-language-specialists/python-pro.md +277 -0
- package/.claude/archive/agents/02-language-specialists/rails-expert.md +358 -0
- package/.claude/archive/agents/02-language-specialists/react-specialist.md +287 -0
- package/.claude/archive/agents/02-language-specialists/rust-engineer.md +287 -0
- package/.claude/archive/agents/02-language-specialists/spring-boot-engineer.md +287 -0
- package/.claude/archive/agents/02-language-specialists/sql-pro.md +287 -0
- package/.claude/archive/agents/02-language-specialists/swift-expert.md +287 -0
- package/.claude/archive/agents/02-language-specialists/symfony-specialist.md +354 -0
- package/.claude/archive/agents/02-language-specialists/typescript-pro.md +277 -0
- package/.claude/archive/agents/02-language-specialists/vue-expert.md +287 -0
- package/.claude/archive/agents/05-data-ai/ai-engineer.md +287 -0
- package/.claude/archive/agents/05-data-ai/data-analyst.md +277 -0
- package/.claude/archive/agents/05-data-ai/data-engineer.md +287 -0
- package/.claude/archive/agents/05-data-ai/data-scientist.md +287 -0
- package/.claude/archive/agents/05-data-ai/database-optimizer.md +287 -0
- package/.claude/archive/agents/05-data-ai/llm-architect.md +287 -0
- package/.claude/archive/agents/05-data-ai/machine-learning-engineer.md +277 -0
- package/.claude/archive/agents/05-data-ai/ml-engineer.md +287 -0
- package/.claude/archive/agents/05-data-ai/mlops-engineer.md +287 -0
- package/.claude/archive/agents/05-data-ai/nlp-engineer.md +287 -0
- package/.claude/archive/agents/05-data-ai/postgres-pro.md +287 -0
- package/.claude/archive/agents/05-data-ai/prompt-engineer.md +287 -0
- package/.claude/archive/agents/05-data-ai/reinforcement-learning-engineer.md +277 -0
- package/.claude/archive/agents/07-specialized-domains/api-documenter.md +277 -0
- package/.claude/archive/agents/07-specialized-domains/blockchain-developer.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/embedded-systems.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/fintech-engineer.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/game-developer.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/healthcare-admin.md +199 -0
- package/.claude/archive/agents/07-specialized-domains/iot-engineer.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/m365-admin.md +48 -0
- package/.claude/archive/agents/07-specialized-domains/mobile-app-developer.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/payment-integration.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/quant-analyst.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/risk-manager.md +287 -0
- package/.claude/archive/agents/07-specialized-domains/seo-specialist.md +184 -0
- package/.claude/archive/agents/08-business-product/business-analyst.md +287 -0
- package/.claude/archive/agents/08-business-product/content-marketer.md +287 -0
- package/.claude/archive/agents/08-business-product/customer-success-manager.md +287 -0
- package/.claude/archive/agents/08-business-product/legal-advisor.md +287 -0
- package/.claude/archive/agents/08-business-product/license-engineer.md +295 -0
- package/.claude/archive/agents/08-business-product/product-manager.md +287 -0
- package/.claude/archive/agents/08-business-product/project-manager.md +287 -0
- package/.claude/archive/agents/08-business-product/sales-engineer.md +287 -0
- package/.claude/archive/agents/08-business-product/scrum-master.md +287 -0
- package/.claude/archive/agents/08-business-product/technical-writer.md +287 -0
- package/.claude/archive/agents/08-business-product/ux-researcher.md +287 -0
- package/.claude/archive/agents/08-business-product/wordpress-master.md +316 -0
- package/.claude/archive/skills/competitive-ads-extractor/SKILL.md +293 -0
- package/.claude/archive/skills/developer-growth-analysis/SKILL.md +322 -0
- package/.claude/archive/skills/document-docx/LICENSE.txt +30 -0
- package/.claude/archive/skills/document-docx/SKILL.md +197 -0
- package/.claude/archive/skills/document-docx/docx-js.md +350 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/mce/mc.xsd +75 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/.claude/archive/skills/document-docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/.claude/archive/skills/document-docx/ooxml/scripts/pack.py +159 -0
- package/.claude/archive/skills/document-docx/ooxml/scripts/unpack.py +29 -0
- package/.claude/archive/skills/document-docx/ooxml/scripts/validate.py +69 -0
- package/.claude/archive/skills/document-docx/ooxml/scripts/validation/__init__.py +15 -0
- package/.claude/archive/skills/document-docx/ooxml/scripts/validation/base.py +951 -0
- package/.claude/archive/skills/document-docx/ooxml/scripts/validation/docx.py +274 -0
- package/.claude/archive/skills/document-docx/ooxml/scripts/validation/pptx.py +315 -0
- package/.claude/archive/skills/document-docx/ooxml/scripts/validation/redlining.py +279 -0
- package/.claude/archive/skills/document-docx/ooxml.md +610 -0
- package/.claude/archive/skills/document-docx/scripts/__init__.py +1 -0
- package/.claude/archive/skills/document-docx/scripts/document.py +1276 -0
- package/.claude/archive/skills/document-docx/scripts/templates/comments.xml +3 -0
- package/.claude/archive/skills/document-docx/scripts/templates/commentsExtended.xml +3 -0
- package/.claude/archive/skills/document-docx/scripts/templates/commentsExtensible.xml +3 -0
- package/.claude/archive/skills/document-docx/scripts/templates/commentsIds.xml +3 -0
- package/.claude/archive/skills/document-docx/scripts/templates/people.xml +3 -0
- package/.claude/archive/skills/document-docx/scripts/utilities.py +374 -0
- package/.claude/archive/skills/document-pdf/LICENSE.txt +30 -0
- package/.claude/archive/skills/document-pdf/SKILL.md +294 -0
- package/.claude/archive/skills/document-pdf/forms.md +205 -0
- package/.claude/archive/skills/document-pdf/reference.md +612 -0
- package/.claude/archive/skills/document-pdf/scripts/check_bounding_boxes.py +70 -0
- package/.claude/archive/skills/document-pdf/scripts/check_bounding_boxes_test.py +226 -0
- package/.claude/archive/skills/document-pdf/scripts/check_fillable_fields.py +12 -0
- package/.claude/archive/skills/document-pdf/scripts/convert_pdf_to_images.py +35 -0
- package/.claude/archive/skills/document-pdf/scripts/create_validation_image.py +41 -0
- package/.claude/archive/skills/document-pdf/scripts/extract_form_field_info.py +152 -0
- package/.claude/archive/skills/document-pdf/scripts/fill_fillable_fields.py +114 -0
- package/.claude/archive/skills/document-pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
- package/.claude/archive/skills/document-pptx/LICENSE.txt +30 -0
- package/.claude/archive/skills/document-pptx/SKILL.md +484 -0
- package/.claude/archive/skills/document-pptx/html2pptx.md +625 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/mce/mc.xsd +75 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/.claude/archive/skills/document-pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/.claude/archive/skills/document-pptx/ooxml/scripts/pack.py +159 -0
- package/.claude/archive/skills/document-pptx/ooxml/scripts/unpack.py +29 -0
- package/.claude/archive/skills/document-pptx/ooxml/scripts/validate.py +69 -0
- package/.claude/archive/skills/document-pptx/ooxml/scripts/validation/__init__.py +15 -0
- package/.claude/archive/skills/document-pptx/ooxml/scripts/validation/base.py +951 -0
- package/.claude/archive/skills/document-pptx/ooxml/scripts/validation/docx.py +274 -0
- package/.claude/archive/skills/document-pptx/ooxml/scripts/validation/pptx.py +315 -0
- package/.claude/archive/skills/document-pptx/ooxml/scripts/validation/redlining.py +279 -0
- package/.claude/archive/skills/document-pptx/ooxml.md +427 -0
- package/.claude/archive/skills/document-pptx/scripts/html2pptx.js +979 -0
- package/.claude/archive/skills/document-pptx/scripts/inventory.py +1020 -0
- package/.claude/archive/skills/document-pptx/scripts/rearrange.py +231 -0
- package/.claude/archive/skills/document-pptx/scripts/replace.py +385 -0
- package/.claude/archive/skills/document-pptx/scripts/thumbnail.py +450 -0
- package/.claude/archive/skills/document-xlsx/LICENSE.txt +30 -0
- package/.claude/archive/skills/document-xlsx/SKILL.md +289 -0
- package/.claude/archive/skills/document-xlsx/recalc.py +178 -0
- package/.claude/archive/skills/image-enhancer/SKILL.md +99 -0
- package/.claude/archive/skills/meeting-insights-analyzer/SKILL.md +327 -0
- package/.claude/archive/skills/slack-gif-creator/LICENSE.txt +202 -0
- package/.claude/archive/skills/slack-gif-creator/SKILL.md +646 -0
- package/.claude/archive/skills/slack-gif-creator/core/color_palettes.py +302 -0
- package/.claude/archive/skills/slack-gif-creator/core/easing.py +230 -0
- package/.claude/archive/skills/slack-gif-creator/core/frame_composer.py +469 -0
- package/.claude/archive/skills/slack-gif-creator/core/gif_builder.py +246 -0
- package/.claude/archive/skills/slack-gif-creator/core/typography.py +357 -0
- package/.claude/archive/skills/slack-gif-creator/core/validators.py +264 -0
- package/.claude/archive/skills/slack-gif-creator/core/visual_effects.py +494 -0
- package/.claude/archive/skills/slack-gif-creator/requirements.txt +4 -0
- package/.claude/archive/skills/slack-gif-creator/templates/bounce.py +106 -0
- package/.claude/archive/skills/slack-gif-creator/templates/explode.py +331 -0
- package/.claude/archive/skills/slack-gif-creator/templates/fade.py +329 -0
- package/.claude/archive/skills/slack-gif-creator/templates/flip.py +291 -0
- package/.claude/archive/skills/slack-gif-creator/templates/kaleidoscope.py +211 -0
- package/.claude/archive/skills/slack-gif-creator/templates/morph.py +329 -0
- package/.claude/archive/skills/slack-gif-creator/templates/move.py +293 -0
- package/.claude/archive/skills/slack-gif-creator/templates/pulse.py +268 -0
- package/.claude/archive/skills/slack-gif-creator/templates/shake.py +127 -0
- package/.claude/archive/skills/slack-gif-creator/templates/slide.py +291 -0
- package/.claude/archive/skills/slack-gif-creator/templates/spin.py +269 -0
- package/.claude/archive/skills/slack-gif-creator/templates/wiggle.py +300 -0
- package/.claude/archive/skills/slack-gif-creator/templates/zoom.py +312 -0
- package/.claude/archive/skills/twitter-algorithm-optimizer/SKILL.md +327 -0
- package/.claude/archive/skills/video-downloader/SKILL.md +99 -0
- package/.claude/archive/skills/video-downloader/scripts/download_video.py +145 -0
- package/.claude/bash-whitelist-requests/2026-05-28-grep-find-rg.md +68 -0
- package/.claude/bash-whitelist-requests/2026-06-01-readonly-filters.md +76 -0
- package/.claude/bash-whitelist.txt +124 -0
- package/.claude/commands/agent-introspect.md +89 -0
- package/.claude/commands/apply-rules.md +363 -0
- package/.claude/commands/approve-design.md +219 -0
- package/.claude/commands/approve-org-money.md +267 -0
- package/.claude/commands/build.md +234 -0
- package/.claude/commands/commit.md +97 -0
- package/.claude/commands/context-fetch.md +113 -0
- package/.claude/commands/create-tool.md +496 -0
- package/.claude/commands/design-review.md +138 -0
- package/.claude/commands/design.md +807 -0
- package/.claude/commands/discharge-byproduct.md +208 -0
- package/.claude/commands/doc-review.md +165 -0
- package/.claude/commands/document-pair.md +76 -0
- package/.claude/commands/error-triage.md +435 -0
- package/.claude/commands/eval.md +70 -0
- package/.claude/commands/evolve.md +49 -0
- package/.claude/commands/finish-task.md +105 -0
- package/.claude/commands/gan-build.md +91 -0
- package/.claude/commands/gan-design.md +82 -0
- package/.claude/commands/gate-bypass.md +77 -0
- package/.claude/commands/gate-clear.md +45 -0
- package/.claude/commands/gate-status.md +46 -0
- package/.claude/commands/harness-audit.md +151 -0
- package/.claude/commands/hearing.md +138 -0
- package/.claude/commands/impact-check.md +486 -0
- package/.claude/commands/init-tasks.md +49 -0
- package/.claude/commands/instinct-export.md +47 -0
- package/.claude/commands/instinct-import.md +41 -0
- package/.claude/commands/instinct-status.md +43 -0
- package/.claude/commands/investigate.md +547 -0
- package/.claude/commands/learn.md +55 -0
- package/.claude/commands/lint-rules.md +400 -0
- package/.claude/commands/mode.md +58 -0
- package/.claude/commands/modify-feature.md +209 -0
- package/.claude/commands/module-review.md +149 -0
- package/.claude/commands/move-section.md +67 -0
- package/.claude/commands/new-draft.md +67 -0
- package/.claude/commands/new-feature.md +286 -0
- package/.claude/commands/new-task.md +156 -0
- package/.claude/commands/notification.md +107 -0
- package/.claude/commands/pm-start.md +119 -0
- package/.claude/commands/projects.md +32 -0
- package/.claude/commands/promote.md +43 -0
- package/.claude/commands/rasis-report.md +1323 -0
- package/.claude/commands/release-note.md +130 -0
- package/.claude/commands/reply-watch.md +149 -0
- package/.claude/commands/requirement.md +352 -0
- package/.claude/commands/resume-state.md +187 -0
- package/.claude/commands/reviewpr.md +118 -0
- package/.claude/commands/save-state.md +100 -0
- package/.claude/commands/sentry-pr.md +157 -0
- package/.claude/commands/start-task.md +87 -0
- package/.claude/commands/system-review.md +147 -0
- package/.claude/commands/task-bypass.md +70 -0
- package/.claude/commands/task-estimate.md +100 -0
- package/.claude/commands/template-apply.md +89 -0
- package/.claude/commands/test-design.md +116 -0
- package/.claude/commands/transfer-mismatch.md +317 -0
- package/.claude/commands/verify.md +51 -0
- package/.claude/evals/grader-loop-mode-autonomy.sh +165 -0
- package/.claude/evals/grader-system-reminder-attention.sh +99 -0
- package/.claude/evals/loop-mode-autonomy.md +121 -0
- package/.claude/evals/loop-mode-autonomy.results.template.md +133 -0
- package/.claude/evals/system-reminder-attention.md +123 -0
- package/.claude/evals/system-reminder-attention.results.template.md +93 -0
- package/.claude/evals/system-reminder-attention.runner.md +353 -0
- package/.claude/harness-config.local.yml +48 -0
- package/.claude/harness-config.yml +534 -0
- package/.claude/hooks/agent-marker-clear.sh +43 -0
- package/.claude/hooks/agent-marker-set.sh +40 -0
- package/.claude/hooks/agent-router-suggest.sh +123 -0
- package/.claude/hooks/autonomous-action-guard.sh +242 -0
- package/.claude/hooks/byproduct-discharge-guard.sh +128 -0
- package/.claude/hooks/check-md-mermaid.sh +144 -0
- package/.claude/hooks/check-required-env.sh +95 -0
- package/.claude/hooks/check-serena-mcp.sh +123 -0
- package/.claude/hooks/confidence-gate.sh +139 -0
- package/.claude/hooks/context-budget.sh +233 -0
- package/.claude/hooks/delegation-guard.sh +99 -0
- package/.claude/hooks/dispatcher-manifest.tsv +38 -0
- package/.claude/hooks/draft-flow-guard.sh +304 -0
- package/.claude/hooks/failure-loop-detect.sh +139 -0
- package/.claude/hooks/gateguard.sh +209 -0
- package/.claude/hooks/improvement-proposal.sh +112 -0
- package/.claude/hooks/init-tasks-on-start.sh +34 -0
- package/.claude/hooks/lib/bypass-logger.sh +82 -0
- package/.claude/hooks/lib/confidence-gate/bypass.sh +48 -0
- package/.claude/hooks/lib/confidence-gate/extract.sh +99 -0
- package/.claude/hooks/lib/confidence-gate/major-agent-filter.sh +59 -0
- package/.claude/hooks/lib/confidence-gate/messages.sh +53 -0
- package/.claude/hooks/lib/config-loader.sh +784 -0
- package/.claude/hooks/lib/delegation-guard/bash-whitelist.sh +323 -0
- package/.claude/hooks/lib/delegation-guard/git-deny.sh +188 -0
- package/.claude/hooks/lib/delegation-guard/protected-paths.sh +105 -0
- package/.claude/hooks/lib/delegation-guard/subagent-detect.sh +40 -0
- package/.claude/hooks/lib/dispatcher-core.sh +454 -0
- package/.claude/hooks/lib/improvement-proposal/aggregate.py +466 -0
- package/.claude/hooks/lib/improvement-proposal/cache.sh +78 -0
- package/.claude/hooks/lib/mode-loader.sh +80 -0
- package/.claude/hooks/lib/next-actions-parser.sh +153 -0
- package/.claude/hooks/lib/project-root.sh +60 -0
- package/.claude/hooks/list-md-plan-first-reminder.sh +143 -0
- package/.claude/hooks/loop-auto-progress-reminder.sh +108 -0
- package/.claude/hooks/loop-confirmation-detector.sh +241 -0
- package/.claude/hooks/mode-asana-prompt.sh +61 -0
- package/.claude/hooks/mode-enforce.sh +57 -0
- package/.claude/hooks/mode-session-start.sh +93 -0
- package/.claude/hooks/next-actions-surface.sh +136 -0
- package/.claude/hooks/notification-dispatcher.sh +9 -0
- package/.claude/hooks/notify.sh +27 -0
- package/.claude/hooks/parallel-subagent-reminder.sh +469 -0
- package/.claude/hooks/post-tool-use-dispatcher.sh +9 -0
- package/.claude/hooks/pre-tool-use-dispatcher.sh +9 -0
- package/.claude/hooks/reviewer-count-guard.sh +313 -0
- package/.claude/hooks/session-help-surface.sh +192 -0
- package/.claude/hooks/session-start-dispatcher.sh +9 -0
- package/.claude/hooks/session-start-wrapper.sh +156 -0
- package/.claude/hooks/stale-harness-detect.sh +422 -0
- package/.claude/hooks/stop-dispatcher.sh +9 -0
- package/.claude/hooks/stop.sh +25 -0
- package/.claude/hooks/subagent-stop-dispatcher.sh +9 -0
- package/.claude/hooks/task-rule-guard.sh +317 -0
- package/.claude/hooks/tests/run-tests.sh +23 -0
- package/.claude/hooks/tests/test-agent-marker-warn.sh +86 -0
- package/.claude/hooks/tests/test-check-required-env.sh +138 -0
- package/.claude/hooks/tests/test-confidence-gate.sh +170 -0
- package/.claude/hooks/tests/test-config-env-override.sh +220 -0
- package/.claude/hooks/tests/test-gate-disable.sh +118 -0
- package/.claude/hooks/tests/test-improvement-proposal.sh +284 -0
- package/.claude/hooks/tool-call-slip-detector.sh +188 -0
- package/.claude/hooks/user-prompt-submit-dispatcher.sh +9 -0
- package/.claude/hooks/why-x5-reminder.sh +45 -0
- package/.claude/hooks/why-x5-violation-detect.sh +152 -0
- package/.claude/hooks/workflow-guard.sh +263 -0
- package/.claude/mode.yml +28 -0
- package/.claude/project-rules/development-process.md +8 -0
- package/.claude/project-rules/git-workflow.md +8 -0
- package/.claude/project-rules/modes.md +8 -0
- package/.claude/project-rules/self-improvement.md +8 -0
- package/.claude/project-rules/task-management.md +8 -0
- package/.claude/project-rules/why-x5-output.md +8 -0
- package/.claude/project-rules/workflow.md +8 -0
- package/.claude/rules/development-process.md +293 -0
- package/.claude/rules/git-workflow.md +71 -0
- package/.claude/rules/modes.md +189 -0
- package/.claude/rules/self-improvement.md +76 -0
- package/.claude/rules/task-management.md +261 -0
- package/.claude/rules/why-x5-output.md +97 -0
- package/.claude/rules/workflow.md +157 -0
- package/.claude/rules-details/README.md +67 -0
- package/.claude/rules-details/development-process/confidence-gate.md +22 -0
- package/.claude/rules-details/development-process/cross-repo-write.md +35 -0
- package/.claude/rules-details/development-process/delegation-requirements.md +158 -0
- package/.claude/rules-details/development-process/harness-sync.md +21 -0
- package/.claude/rules-details/development-process/origin.md +13 -0
- package/.claude/rules-details/development-process/parallelization-origin.md +22 -0
- package/.claude/rules-details/development-process/research-reuse.md +22 -0
- package/.claude/rules-details/development-process/staging-strategy.md +47 -0
- package/.claude/rules-details/modes/artifacts.md +34 -0
- package/.claude/rules-details/modes/compliance-items.md +120 -0
- package/.claude/rules-details/modes/five-layer-enforcement.md +46 -0
- package/.claude/rules-details/modes/mode-hooks.md +51 -0
- package/.claude/rules-details/modes/origin.md +17 -0
- package/.claude/rules-details/self-improvement/l4-mechanics.md +36 -0
- package/.claude/rules-details/self-improvement/origin.md +8 -0
- package/.claude/rules-details/self-improvement/related-skills.md +35 -0
- package/.claude/rules-details/self-improvement/when-to-use-layers.md +39 -0
- package/.claude/rules-details/task-management/hook-enforcement.md +25 -0
- package/.claude/rules-details/task-management/mandatory-reading.md +20 -0
- package/.claude/rules-details/task-management/origin.md +12 -0
- package/.claude/rules-details/task-management/parking-lot.md +26 -0
- package/.claude/rules-details/task-management/plan-first.md +44 -0
- package/.claude/rules-details/task-management/six-articles.md +68 -0
- package/.claude/rules-details/task-management/task-migration.md +16 -0
- package/.claude/rules-details/task-management/ui-detection.md +11 -0
- package/.claude/rules-details/why-x5-output/examples.md +41 -0
- package/.claude/rules-details/why-x5-output/feedback-memory.md +14 -0
- package/.claude/rules-details/why-x5-output/origin.md +10 -0
- package/.claude/rules-details/why-x5-output/v1-v10-history.md +19 -0
- package/.claude/rules-details/workflow/10-stage.md +43 -0
- package/.claude/rules-details/workflow/14-stage.md +52 -0
- package/.claude/rules-details/workflow/byproduct-discharge.md +39 -0
- package/.claude/rules-details/workflow/draft-flow-guard.md +31 -0
- package/.claude/rules-details/workflow/fan-out.md +70 -0
- package/.claude/rules-details/workflow/mece-20.md +36 -0
- package/.claude/rules-details/workflow/origin.md +14 -0
- package/.claude/rules-details/workflow/refactoring.md +48 -0
- package/.claude/rules-details/workflow/related-skills.md +22 -0
- package/.claude/rules-details/workflow/reviewer-prompt.md +100 -0
- package/.claude/rules-details/workflow/session-persistence.md +46 -0
- package/.claude/rules-details/workflow/workflow-guard.md +36 -0
- package/.claude/scripts/__pycache__/harness-audit.cpython-313.pyc +0 -0
- package/.claude/scripts/agent-stocktake.py +421 -0
- package/.claude/scripts/check-md-mermaid.mjs +138 -0
- package/.claude/scripts/generate-settings.sh +0 -0
- package/.claude/scripts/harness-audit.py +1547 -0
- package/.claude/scripts/hc-config.sh +2265 -0
- package/.claude/scripts/init-tasks.sh +117 -0
- package/.claude/scripts/lib/enforcement-matrix-parse.sh +81 -0
- package/.claude/scripts/lib/hc-config-metadata.sh +190 -0
- package/.claude/scripts/lib/hc-config-web-server.js +1528 -0
- package/.claude/scripts/lib/hc-config-web-ui/app.js +1054 -0
- package/.claude/scripts/lib/hc-config-web-ui/index.html +130 -0
- package/.claude/scripts/lib/hc-config-web-ui/style.css +522 -0
- package/.claude/scripts/new-task-helper.sh +432 -0
- package/.claude/scripts/observe-repair.sh +437 -0
- package/.claude/scripts/observe-rotate.sh +311 -0
- package/.claude/scripts/statusline.sh +239 -0
- package/.claude/settings.generated.preview.json +211 -0
- package/.claude/settings.json +215 -0
- package/.claude/settings.local.example.json +20 -0
- package/.claude/settings.local.json +36 -0
- package/.claude/skills/agent-introspection-debugging/SKILL.md +123 -0
- package/.claude/skills/agent-router/README.md +137 -0
- package/.claude/skills/agent-router/SKILL.md +74 -0
- package/.claude/skills/agent-router/dispatch-table.yml +352 -0
- package/.claude/skills/agent-router/router.py +1086 -0
- package/.claude/skills/agent-router/samples/representative_prompts.txt +24 -0
- package/.claude/skills/agent-router/tests/__init__.py +0 -0
- package/.claude/skills/agent-router/tests/test_router.py +762 -0
- package/.claude/skills/artifacts-builder/LICENSE.txt +202 -0
- package/.claude/skills/artifacts-builder/SKILL.md +74 -0
- package/.claude/skills/artifacts-builder/scripts/bundle-artifact.sh +54 -0
- package/.claude/skills/artifacts-builder/scripts/init-artifact.sh +322 -0
- package/.claude/skills/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
- package/.claude/skills/brand-guidelines/LICENSE.txt +202 -0
- package/.claude/skills/brand-guidelines/SKILL.md +73 -0
- package/.claude/skills/canvas-design/LICENSE.txt +202 -0
- package/.claude/skills/canvas-design/SKILL.md +130 -0
- package/.claude/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
- package/.claude/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
- package/.claude/skills/changelog-generator/SKILL.md +104 -0
- package/.claude/skills/check-md-mermaid/SKILL.md +62 -0
- package/.claude/skills/connect/SKILL.md +156 -0
- package/.claude/skills/connect-apps/SKILL.md +80 -0
- package/.claude/skills/content-research-writer/SKILL.md +538 -0
- package/.claude/skills/continuous-agent-loop/SKILL.md +187 -0
- package/.claude/skills/continuous-learning-v2/SKILL.md +238 -0
- package/.claude/skills/continuous-learning-v2/config.json +35 -0
- package/.claude/skills/continuous-learning-v2/hooks/observe.sh +333 -0
- package/.claude/skills/continuous-learning-v2/instinct-cli.py +406 -0
- package/.claude/skills/domain-name-brainstormer/SKILL.md +212 -0
- package/.claude/skills/eval-harness/SKILL.md +100 -0
- package/.claude/skills/eval-harness/swe-bench/README.md +80 -0
- package/.claude/skills/eval-harness/swe-bench/config.yml +29 -0
- package/.claude/skills/eval-harness/swe-bench/docker/Dockerfile +25 -0
- package/.claude/skills/eval-harness/swe-bench/docker/docker-compose.yml +18 -0
- package/.claude/skills/eval-harness/swe-bench/results/dry-run-2026-05-04.json +137 -0
- package/.claude/skills/eval-harness/swe-bench/results/dry-run-comparison-2026-05-04.md +112 -0
- package/.claude/skills/eval-harness/swe-bench/results/dry-run-improved-2026-05-04.json +165 -0
- package/.claude/skills/eval-harness/swe-bench/results/raw/astropy__astropy-12907.patch +12 -0
- package/.claude/skills/eval-harness/swe-bench/results/raw/astropy__astropy-12907.txt +322 -0
- package/.claude/skills/eval-harness/swe-bench/results/raw/astropy__astropy-12907.whole-file.txt +322 -0
- package/.claude/skills/eval-harness/swe-bench/runner.py +845 -0
- package/.claude/skills/eval-harness/swe-bench/scoring.py +298 -0
- package/.claude/skills/eval-harness/swe-bench/tasks/fetch_tasks.py +81 -0
- package/.claude/skills/eval-harness/swe-bench/tasks/lite-50.json +702 -0
- package/.claude/skills/file-organizer/SKILL.md +433 -0
- package/.claude/skills/gan-style-harness/SKILL.md +111 -0
- package/.claude/skills/gateguard/.gateguard.yml +47 -0
- package/.claude/skills/gateguard/SKILL.md +99 -0
- package/.claude/skills/internal-comms/LICENSE.txt +202 -0
- package/.claude/skills/internal-comms/SKILL.md +32 -0
- package/.claude/skills/internal-comms/examples/3p-updates.md +47 -0
- package/.claude/skills/internal-comms/examples/company-newsletter.md +65 -0
- package/.claude/skills/internal-comms/examples/faq-answers.md +30 -0
- package/.claude/skills/internal-comms/examples/general-comms.md +16 -0
- package/.claude/skills/invoice-organizer/SKILL.md +446 -0
- package/.claude/skills/karpathy-guidelines/SKILL.md +67 -0
- package/.claude/skills/langsmith-fetch/SKILL.md +485 -0
- package/.claude/skills/lead-research-assistant/SKILL.md +199 -0
- package/.claude/skills/mcp-builder/LICENSE.txt +202 -0
- package/.claude/skills/mcp-builder/SKILL.md +328 -0
- package/.claude/skills/mcp-builder/reference/evaluation.md +602 -0
- package/.claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
- package/.claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
- package/.claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
- package/.claude/skills/mcp-builder/scripts/connections.py +151 -0
- package/.claude/skills/mcp-builder/scripts/evaluation.py +373 -0
- package/.claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
- package/.claude/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/.claude/skills/raffle-winner-picker/SKILL.md +159 -0
- package/.claude/skills/repo-map/README.md +125 -0
- package/.claude/skills/repo-map/SKILL.md +128 -0
- package/.claude/skills/repo-map/examples/sample-output.md +1194 -0
- package/.claude/skills/repo-map/repo-map.py +715 -0
- package/.claude/skills/salesforce-e2e-testing/SKILL.md +116 -0
- package/.claude/skills/salesforce-e2e-testing/catalog-template.md +161 -0
- package/.claude/skills/salesforce-e2e-testing/methodology.md +179 -0
- package/.claude/skills/salesforce-e2e-testing/observation-rules.md +280 -0
- package/.claude/skills/salesforce-e2e-testing/pattern-taxonomy.md +392 -0
- package/.claude/skills/salesforce-e2e-testing/procedure-template.md +376 -0
- package/.claude/skills/skill-creator/LICENSE.txt +202 -0
- package/.claude/skills/skill-creator/SKILL.md +209 -0
- package/.claude/skills/skill-creator/scripts/init_skill.py +303 -0
- package/.claude/skills/skill-creator/scripts/package_skill.py +110 -0
- package/.claude/skills/skill-creator/scripts/quick_validate.py +65 -0
- package/.claude/skills/skill-share/SKILL.md +80 -0
- package/.claude/skills/tailored-resume-generator/SKILL.md +345 -0
- package/.claude/skills/template-skill/SKILL.md +6 -0
- package/.claude/skills/theme-factory/LICENSE.txt +202 -0
- package/.claude/skills/theme-factory/SKILL.md +59 -0
- package/.claude/skills/theme-factory/theme-showcase.pdf +0 -0
- package/.claude/skills/theme-factory/themes/arctic-frost.md +19 -0
- package/.claude/skills/theme-factory/themes/botanical-garden.md +19 -0
- package/.claude/skills/theme-factory/themes/desert-rose.md +19 -0
- package/.claude/skills/theme-factory/themes/forest-canopy.md +19 -0
- package/.claude/skills/theme-factory/themes/golden-hour.md +19 -0
- package/.claude/skills/theme-factory/themes/midnight-galaxy.md +19 -0
- package/.claude/skills/theme-factory/themes/modern-minimalist.md +19 -0
- package/.claude/skills/theme-factory/themes/ocean-depths.md +19 -0
- package/.claude/skills/theme-factory/themes/sunset-boulevard.md +19 -0
- package/.claude/skills/theme-factory/themes/tech-innovation.md +19 -0
- package/.claude/skills/verification-loop/SKILL.md +129 -0
- package/.claude/skills/webapp-testing/LICENSE.txt +202 -0
- package/.claude/skills/webapp-testing/SKILL.md +96 -0
- package/.claude/skills/webapp-testing/examples/console_logging.py +35 -0
- package/.claude/skills/webapp-testing/examples/element_discovery.py +40 -0
- package/.claude/skills/webapp-testing/examples/static_html_automation.py +33 -0
- package/.claude/skills/webapp-testing/scripts/with_server.py +106 -0
- package/.claude/templates/docs/draft/_DRAFT_TEMPLATE.md +162 -0
- package/.claude/templates/docs/draft/_TEST_DESIGN_TEMPLATE.md +76 -0
- package/.claude/templates/docs/tasks/_TASK_TEMPLATE.md +276 -0
- package/.claude/templates/docs/tasks/list.md +80 -0
- package/.claude/templates/docs/tasks/parking-lot.md +82 -0
- package/.claude/templates/settings.user-level.json.template +306 -0
- package/.claude/tests/SMOKE-CLASSIFICATION.md +199 -0
- package/.claude/tests/action-space-count-smoke.sh +130 -0
- package/.claude/tests/agent-router-suggest-wiring-smoke.sh +188 -0
- package/.claude/tests/audit-followups-smoke.sh +158 -0
- package/.claude/tests/autonomous-action-guard-relaxation-smoke.sh +479 -0
- package/.claude/tests/autonomous-action-guard-smoke.sh +187 -0
- package/.claude/tests/check-serena-mcp-smoke.sh +156 -0
- package/.claude/tests/common-rules-import-smoke.sh +209 -0
- package/.claude/tests/confidence-gate-smoke.sh +220 -0
- package/.claude/tests/config-feature-toggles-smoke.sh +389 -0
- package/.claude/tests/context-budget-smoke.sh +222 -0
- package/.claude/tests/custom-pm-commands-smoke.sh +93 -0
- package/.claude/tests/delegation-guard-code-smoke.sh +244 -0
- package/.claude/tests/delegation-guard-deny-layers-smoke.sh +356 -0
- package/.claude/tests/delegation-guard-readonly-filter-smoke.sh +205 -0
- package/.claude/tests/delegation-guard-search-whitelist-smoke.sh +152 -0
- package/.claude/tests/delegation-guard-segment-smoke.sh +109 -0
- package/.claude/tests/dispatcher-blocker-invariance-smoke.sh +700 -0
- package/.claude/tests/dispatcher-core-smoke.sh +452 -0
- package/.claude/tests/dispatcher-merge-matrix-smoke.sh +825 -0
- package/.claude/tests/dispatcher-success-stdout-smoke.sh +290 -0
- package/.claude/tests/draft-flow-guard-approved-dir-smoke.sh +234 -0
- package/.claude/tests/draft-flow-guard-smoke.sh +194 -0
- package/.claude/tests/dual-mode-portability-smoke.sh +131 -0
- package/.claude/tests/effective-hook-matrix-smoke.sh +261 -0
- package/.claude/tests/enforcement-mismatch-smoke.sh +263 -0
- package/.claude/tests/fixtures/cascade-sample.jsonl +9 -0
- package/.claude/tests/fixtures/next-actions/case-clean.md +14 -0
- package/.claude/tests/fixtures/next-actions/case-with-red.md +16 -0
- package/.claude/tests/fixtures/next-actions/case-with-yellow-only.md +14 -0
- package/.claude/tests/fixtures/normal-broken-scatter.jsonl +5 -0
- package/.claude/tests/fixtures/task-71/blocker-baseline.tsv +24 -0
- package/.claude/tests/fixtures/task-71/settings-inventory.tsv +37 -0
- package/.claude/tests/fixtures/transcript-50pct.jsonl +2 -0
- package/.claude/tests/fixtures/transcript-60pct.jsonl +2 -0
- package/.claude/tests/fixtures/transcript-80pct.jsonl +2 -0
- package/.claude/tests/fixtures/transcript-95pct.jsonl +2 -0
- package/.claude/tests/fixtures/workflow-guard/case-2-mid.json +21 -0
- package/.claude/tests/fixtures/workflow-guard/case-3-blocked.json +33 -0
- package/.claude/tests/fixtures/workflow-guard/case-4-clean.json +27 -0
- package/.claude/tests/fixtures/workflow-guard/case-8-modify.json +23 -0
- package/.claude/tests/fixtures/workflow-guard/inputs/case-1.json +1 -0
- package/.claude/tests/fixtures/workflow-guard/inputs/case-2.json +1 -0
- package/.claude/tests/fixtures/workflow-guard/inputs/case-3.json +1 -0
- package/.claude/tests/fixtures/workflow-guard/inputs/case-4.json +1 -0
- package/.claude/tests/fixtures/workflow-guard/inputs/case-5.json +1 -0
- package/.claude/tests/fixtures/workflow-guard/inputs/case-6.json +1 -0
- package/.claude/tests/fixtures/workflow-guard/inputs/case-7.json +1 -0
- package/.claude/tests/fixtures/workflow-guard/inputs/case-8.json +1 -0
- package/.claude/tests/gateguard-smoke.sh +213 -0
- package/.claude/tests/git-deny-mainline-policy-smoke.sh +222 -0
- package/.claude/tests/harness-audit-c-batch-smoke.sh +270 -0
- package/.claude/tests/harness-audit-compare-smoke.sh +186 -0
- package/.claude/tests/harness-audit-pipeline-health-smoke.sh +326 -0
- package/.claude/tests/harness-config-local-smoke.sh +232 -0
- package/.claude/tests/hc-config-git-policy-smoke.sh +241 -0
- package/.claude/tests/hc-config-key-parity-smoke.sh +149 -0
- package/.claude/tests/hc-config-migration-smoke.sh +251 -0
- package/.claude/tests/hc-config-script-smoke.sh +1106 -0
- package/.claude/tests/hc-config-tui-smoke.sh +801 -0
- package/.claude/tests/hc-config-web-ui-smoke.sh +3224 -0
- package/.claude/tests/hook-cwd-robustness-smoke.sh +206 -0
- package/.claude/tests/hook-frequency-tweaks-smoke.sh +312 -0
- package/.claude/tests/improvement-proposal-cache-smoke.sh +238 -0
- package/.claude/tests/install-sh-overwrite-all-smoke.sh +274 -0
- package/.claude/tests/install-sh-regen-settings-smoke.sh +301 -0
- package/.claude/tests/install-sh-sync-drift-smoke.sh +285 -0
- package/.claude/tests/layer-b-context-isolation-smoke.sh +392 -0
- package/.claude/tests/list-md-plan-first-reminder-smoke.sh +313 -0
- package/.claude/tests/loop-auto-progress-smoke.sh +372 -0
- package/.claude/tests/loop-confirmation-detector-smoke.sh +674 -0
- package/.claude/tests/new-task-batch-update-smoke.sh +664 -0
- package/.claude/tests/next-actions-hooks-smoke.sh +283 -0
- package/.claude/tests/npx-cli-smoke.sh +696 -0
- package/.claude/tests/observe-flock-smoke.sh +223 -0
- package/.claude/tests/observe-jq-parse-smoke.sh +250 -0
- package/.claude/tests/observe-repair-smoke.sh +475 -0
- package/.claude/tests/observe-rotate-smoke.sh +428 -0
- package/.claude/tests/observe-subagent-stop-smoke.sh +476 -0
- package/.claude/tests/parallel-subagent-reminder-smoke.sh +918 -0
- package/.claude/tests/project-root-smoke.sh +140 -0
- package/.claude/tests/project-rules-protection-smoke.sh +199 -0
- package/.claude/tests/review-required-min-count-smoke.sh +286 -0
- package/.claude/tests/reviewer-count-guard-smoke.sh +490 -0
- package/.claude/tests/rule-architecture-smoke.sh +418 -0
- package/.claude/tests/rule-change-draft-flow-guard-smoke.sh +343 -0
- package/.claude/tests/run-all-smokes.sh +340 -0
- package/.claude/tests/session-help-surface-smoke.sh +224 -0
- package/.claude/tests/session-start-parallel-smoke.sh +165 -0
- package/.claude/tests/sessionstart-budget-smoke.sh +185 -0
- package/.claude/tests/sessionstart-footprint-smoke.sh +258 -0
- package/.claude/tests/settings-dispatcher-baseline-smoke.sh +709 -0
- package/.claude/tests/settings-generation-feature-pruning-smoke.sh +196 -0
- package/.claude/tests/stale-harness-detect-smoke.sh +974 -0
- package/.claude/tests/statusline-smoke.sh +180 -0
- package/.claude/tests/task-rule-guard-smoke.sh +656 -0
- package/.claude/tests/tool-call-slip-detector-smoke.sh +101 -0
- package/.claude/tests/wave-precheck-template-smoke.sh +159 -0
- package/.claude/tests/why-x5-violation-detect-smoke.sh +157 -0
- package/.claude/tests/workflow-guard-smoke.sh +266 -0
- package/CLAUDE.md +75 -0
- package/LICENSE +21 -0
- package/README.md +790 -0
- package/bin/cli.js +395 -0
- package/docs/INVENTORY.md +163 -0
- package/install.sh +769 -0
- package/package.json +25 -0
|
@@ -0,0 +1,209 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# gateguard.sh — Fact-forcing PreToolUse gate (ECC GateGuard)
|
|
3
|
+
#
|
|
4
|
+
# Args: $1 = tool name (Edit|Write|Bash) used as fallback if JSON tool_name absent
|
|
5
|
+
# Stdin: PreToolUse JSON
|
|
6
|
+
#
|
|
7
|
+
# Bypass:
|
|
8
|
+
# ECC_GATEGUARD=off # disable globally
|
|
9
|
+
# /gate-clear # reset state
|
|
10
|
+
# /gate-bypass <file> # pre-clear one file
|
|
11
|
+
#
|
|
12
|
+
# Config keys consumed (.claude/harness-config.yml):
|
|
13
|
+
# gateguard_state_dir # state file root (cleared markers)
|
|
14
|
+
# agent_marker_dir # for subagent passthrough detection
|
|
15
|
+
|
|
16
|
+
set -u
|
|
17
|
+
|
|
18
|
+
# config 読み込み (HC_* 変数 export)
|
|
19
|
+
# shellcheck source=lib/config-loader.sh
|
|
20
|
+
source "$(dirname "$0")/lib/config-loader.sh"
|
|
21
|
+
|
|
22
|
+
# Feature toggle 参照 (task-45 Phase 2)
|
|
23
|
+
if command -v is_feature_enabled >/dev/null 2>&1 && ! is_feature_enabled gateguard; then
|
|
24
|
+
echo '{}'
|
|
25
|
+
exit 0 # feature OFF で no-op
|
|
26
|
+
fi
|
|
27
|
+
|
|
28
|
+
# Phase β: F1 disable for SWE-bench grid evaluation (fail-open)
|
|
29
|
+
# ECC_F{1,2,3}_OFF env vars allow runner.py to bypass gates per-task
|
|
30
|
+
# while measuring gate effectiveness. Production usage MUST NOT set these.
|
|
31
|
+
if [ "${ECC_F1_OFF:-0}" = "1" ] || [ "${ECC_F1_OFF:-}" = "true" ]; then
|
|
32
|
+
if command -v jq >/dev/null 2>&1; then
|
|
33
|
+
jq -n '{decision:"approve", reason:"F1 (gateguard) disabled via ECC_F1_OFF"}'
|
|
34
|
+
else
|
|
35
|
+
printf '{"decision":"approve","reason":"F1 (gateguard) disabled via ECC_F1_OFF"}\n'
|
|
36
|
+
fi
|
|
37
|
+
exit 0
|
|
38
|
+
fi
|
|
39
|
+
|
|
40
|
+
# Bypass
|
|
41
|
+
if [ "${ECC_GATEGUARD:-}" = "off" ]; then
|
|
42
|
+
echo '{}'
|
|
43
|
+
exit 0
|
|
44
|
+
fi
|
|
45
|
+
|
|
46
|
+
input=$(cat)
|
|
47
|
+
|
|
48
|
+
# Need jq
|
|
49
|
+
if ! command -v jq >/dev/null 2>&1; then
|
|
50
|
+
echo '{}'
|
|
51
|
+
exit 0
|
|
52
|
+
fi
|
|
53
|
+
|
|
54
|
+
# Detect tool from JSON, fallback to $1
|
|
55
|
+
tool=$(printf '%s' "$input" | jq -r '.tool_name // empty' 2>/dev/null)
|
|
56
|
+
if [ -z "$tool" ] || [ "$tool" = "null" ]; then
|
|
57
|
+
tool="${1:-}"
|
|
58
|
+
fi
|
|
59
|
+
|
|
60
|
+
# Subagent passthrough (same multi-stage detection as delegation-guard)
|
|
61
|
+
is_subagent="false"
|
|
62
|
+
if [ "${CLAUDE_HARNESS_ROLE:-}" = "subagent" ]; then
|
|
63
|
+
is_subagent="true"
|
|
64
|
+
fi
|
|
65
|
+
if [ "$is_subagent" = "false" ]; then
|
|
66
|
+
for field in agent_type subagent_type parent_tool_use_id agent_id; do
|
|
67
|
+
v=$(printf '%s' "$input" | jq -r ".${field} // empty" 2>/dev/null)
|
|
68
|
+
if [ -n "$v" ] && [ "$v" != "null" ]; then
|
|
69
|
+
is_subagent="true"
|
|
70
|
+
break
|
|
71
|
+
fi
|
|
72
|
+
done
|
|
73
|
+
fi
|
|
74
|
+
if [ "$is_subagent" = "false" ] && [ -d "$HC_AGENT_MARKER_DIR" ]; then
|
|
75
|
+
if ls "$HC_AGENT_MARKER_DIR"/*.lock >/dev/null 2>&1; then
|
|
76
|
+
is_subagent="true"
|
|
77
|
+
fi
|
|
78
|
+
fi
|
|
79
|
+
if [ "$is_subagent" = "true" ]; then
|
|
80
|
+
echo '{}'
|
|
81
|
+
exit 0
|
|
82
|
+
fi
|
|
83
|
+
|
|
84
|
+
state_dir="$HC_GATEGUARD_STATE_DIR"
|
|
85
|
+
mkdir -p "$state_dir" 2>/dev/null
|
|
86
|
+
|
|
87
|
+
hash_str() {
|
|
88
|
+
printf '%s' "$1" | shasum -a 256 2>/dev/null | cut -c1-12
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
emit_block() {
|
|
92
|
+
jq -n --arg r "$1" '{decision:"block", reason:$r}'
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
# === Edit gate ===
|
|
96
|
+
if [ "$tool" = "Edit" ]; then
|
|
97
|
+
file=$(printf '%s' "$input" | jq -r '.tool_input.file_path // .tool_input.filePath // empty')
|
|
98
|
+
if [ -z "$file" ]; then echo '{}'; exit 0; fi
|
|
99
|
+
|
|
100
|
+
# Excluded paths
|
|
101
|
+
case "$file" in
|
|
102
|
+
*/CLAUDE.md|*/README.md|*/.gitignore|*/.dockerignore|*/.env.example|*/.gitmessage|*/.claude/.agent-markers/*|*/.claude/.gateguard-state/*|*.lock)
|
|
103
|
+
echo '{}'; exit 0;;
|
|
104
|
+
esac
|
|
105
|
+
|
|
106
|
+
fhash=$(hash_str "$file")
|
|
107
|
+
state="$state_dir/edit-$fhash.cleared"
|
|
108
|
+
|
|
109
|
+
if [ -f "$state" ]; then
|
|
110
|
+
echo '{}'; exit 0
|
|
111
|
+
fi
|
|
112
|
+
|
|
113
|
+
touch "$state" 2>/dev/null
|
|
114
|
+
|
|
115
|
+
msg="[GateGuard] First Edit to: $file"
|
|
116
|
+
msg="$msg"$'\n\n'"Before retrying, gather and present these facts:"
|
|
117
|
+
msg="$msg"$'\n\n'" 1. Run Grep to list ALL files importing/requiring this file"
|
|
118
|
+
msg="$msg"$'\n'" -> which downstream code is affected by this edit?"
|
|
119
|
+
msg="$msg"$'\n'" 2. Identify public functions / classes / exports affected"
|
|
120
|
+
msg="$msg"$'\n'" -> API surface that callers depend on"
|
|
121
|
+
msg="$msg"$'\n'" 3. Describe data structure (field names, types, date formats)"
|
|
122
|
+
msg="$msg"$'\n'" -> values may be redacted"
|
|
123
|
+
msg="$msg"$'\n'" 4. Quote the user's verbatim instruction authorizing this change"
|
|
124
|
+
msg="$msg"$'\n\n'"After presenting these facts, retry the Edit — the gate is now cleared"
|
|
125
|
+
msg="$msg"$'\n'"for this file in this session ($state created)."
|
|
126
|
+
msg="$msg"$'\n\n'"Bypass: ECC_GATEGUARD=off / /gate-clear / /gate-bypass $file"
|
|
127
|
+
|
|
128
|
+
emit_block "$msg"
|
|
129
|
+
exit 0
|
|
130
|
+
fi
|
|
131
|
+
|
|
132
|
+
# === Write gate ===
|
|
133
|
+
if [ "$tool" = "Write" ]; then
|
|
134
|
+
file=$(printf '%s' "$input" | jq -r '.tool_input.file_path // .tool_input.filePath // empty')
|
|
135
|
+
if [ -z "$file" ]; then echo '{}'; exit 0; fi
|
|
136
|
+
|
|
137
|
+
case "$file" in
|
|
138
|
+
*/CLAUDE.md|*/README.md|*/.gitignore|*/.dockerignore|*/.env.example|*/.gitmessage|*/.claude/.agent-markers/*|*/.claude/.gateguard-state/*|*.lock)
|
|
139
|
+
echo '{}'; exit 0;;
|
|
140
|
+
esac
|
|
141
|
+
|
|
142
|
+
fhash=$(hash_str "$file")
|
|
143
|
+
state="$state_dir/write-$fhash.cleared"
|
|
144
|
+
|
|
145
|
+
if [ -f "$state" ]; then
|
|
146
|
+
echo '{}'; exit 0
|
|
147
|
+
fi
|
|
148
|
+
|
|
149
|
+
touch "$state" 2>/dev/null
|
|
150
|
+
|
|
151
|
+
msg="[GateGuard] First Write of new file: $file"
|
|
152
|
+
msg="$msg"$'\n\n'"Before retrying, gather and present these facts:"
|
|
153
|
+
msg="$msg"$'\n\n'" 1. Which files / lines will call or import this new file?"
|
|
154
|
+
msg="$msg"$'\n'" -> if none yet, name the caller you'll add next"
|
|
155
|
+
msg="$msg"$'\n'" 2. Confirm via Glob that no existing file duplicates this purpose"
|
|
156
|
+
msg="$msg"$'\n'" 3. Describe data structure (if applicable)"
|
|
157
|
+
msg="$msg"$'\n'" 4. Quote the user's verbatim instruction authorizing creation"
|
|
158
|
+
msg="$msg"$'\n\n'"After presenting these facts, retry the Write — the gate is now cleared"
|
|
159
|
+
msg="$msg"$'\n'"for this file in this session ($state created)."
|
|
160
|
+
msg="$msg"$'\n\n'"Bypass: ECC_GATEGUARD=off / /gate-clear / /gate-bypass $file"
|
|
161
|
+
|
|
162
|
+
emit_block "$msg"
|
|
163
|
+
exit 0
|
|
164
|
+
fi
|
|
165
|
+
|
|
166
|
+
# === Bash gate ===
|
|
167
|
+
if [ "$tool" = "Bash" ]; then
|
|
168
|
+
cmd=$(printf '%s' "$input" | jq -r '.tool_input.command // empty')
|
|
169
|
+
if [ -z "$cmd" ]; then echo '{}'; exit 0; fi
|
|
170
|
+
|
|
171
|
+
is_destructive="false"
|
|
172
|
+
if printf '%s' "$cmd" | grep -qE '(rm -rf|rm -fr|git reset --hard|git push --force|git push -f|git branch -D|drop table|DROP TABLE|truncate table|TRUNCATE TABLE|supabase db reset)'; then
|
|
173
|
+
is_destructive="true"
|
|
174
|
+
fi
|
|
175
|
+
|
|
176
|
+
if [ "$is_destructive" = "false" ]; then
|
|
177
|
+
echo '{}'; exit 0
|
|
178
|
+
fi
|
|
179
|
+
|
|
180
|
+
chash=$(hash_str "$cmd")
|
|
181
|
+
state="$state_dir/bash-$chash.cleared"
|
|
182
|
+
|
|
183
|
+
if [ -f "$state" ]; then
|
|
184
|
+
echo '{}'; exit 0
|
|
185
|
+
fi
|
|
186
|
+
|
|
187
|
+
touch "$state" 2>/dev/null
|
|
188
|
+
|
|
189
|
+
cmd_short=$(printf '%s' "$cmd" | head -c 200)
|
|
190
|
+
|
|
191
|
+
msg="[GateGuard] First destructive Bash command:"
|
|
192
|
+
msg="$msg"$'\n'" \$ $cmd_short"
|
|
193
|
+
msg="$msg"$'\n\n'"Before retrying, gather and present these facts:"
|
|
194
|
+
msg="$msg"$'\n\n'" 1. List ALL files / data this command modifies or deletes"
|
|
195
|
+
msg="$msg"$'\n'" -> enumerate explicitly, not 'various files'"
|
|
196
|
+
msg="$msg"$'\n'" 2. Provide a one-line rollback procedure"
|
|
197
|
+
msg="$msg"$'\n'" -> e.g. git reflog / DB snapshot restore"
|
|
198
|
+
msg="$msg"$'\n'" 3. Quote the user's verbatim instruction authorizing this destructive action"
|
|
199
|
+
msg="$msg"$'\n\n'"After presenting these facts, retry — the gate is cleared for this exact"
|
|
200
|
+
msg="$msg"$'\n'"command in this session ($state created)."
|
|
201
|
+
msg="$msg"$'\n\n'"Bypass: ECC_GATEGUARD=off / /gate-clear"
|
|
202
|
+
|
|
203
|
+
emit_block "$msg"
|
|
204
|
+
exit 0
|
|
205
|
+
fi
|
|
206
|
+
|
|
207
|
+
# Default: allow
|
|
208
|
+
echo '{}'
|
|
209
|
+
exit 0
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# improvement-proposal.sh — SessionStart hook that surfaces self-improvement hints.
|
|
3
|
+
#
|
|
4
|
+
# Orchestrator: env load + kill switch + cache check + Python aggregate dispatch + output flush.
|
|
5
|
+
# 集計 / cache / heuristics logic は lib/improvement-proposal/ に分割。
|
|
6
|
+
#
|
|
7
|
+
# 設計原則:
|
|
8
|
+
# - fail-open: jq / python3 が無くても、または読み取り失敗でも exit 0
|
|
9
|
+
# - noisy にしない: 提案 0 件なら何も出さない、dedup で同提案を 24h 以内に再表示しない
|
|
10
|
+
# - data 駆動: heuristics は Python 側に集約 (lib/improvement-proposal/aggregate.py)
|
|
11
|
+
# - cache: 集計結果を TTL 1h で cache し SessionStart 時間を短縮 (lib/improvement-proposal/cache.sh)
|
|
12
|
+
# - kill switch:
|
|
13
|
+
# ECC_IMPROVEMENT_PROPOSAL=off → 全 skip
|
|
14
|
+
# HC_IMPROVEMENT_PROPOSAL_ENABLED=false → 全 skip
|
|
15
|
+
# HC_IMPROVEMENT_PROPOSAL_CACHE_ENABLED=false → cache skip (常に再集計)
|
|
16
|
+
#
|
|
17
|
+
# Stdin: SessionStart hook JSON(読むが現状未使用)
|
|
18
|
+
# Stdout: 空
|
|
19
|
+
# Stderr: 提案行 + フッター 1 行(提案 1+ 件のときのみ)
|
|
20
|
+
# Exit: 常に 0
|
|
21
|
+
|
|
22
|
+
set -uo pipefail
|
|
23
|
+
|
|
24
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
25
|
+
# shellcheck source=lib/config-loader.sh
|
|
26
|
+
. "$SCRIPT_DIR/lib/config-loader.sh"
|
|
27
|
+
|
|
28
|
+
# Feature toggle 参照 (task-45 Phase 2)
|
|
29
|
+
if command -v is_feature_enabled >/dev/null 2>&1 && ! is_feature_enabled improvement_proposal; then
|
|
30
|
+
exit 0 # feature OFF で no-op
|
|
31
|
+
fi
|
|
32
|
+
|
|
33
|
+
# shellcheck source=lib/improvement-proposal/cache.sh
|
|
34
|
+
. "$SCRIPT_DIR/lib/improvement-proposal/cache.sh"
|
|
35
|
+
|
|
36
|
+
# stdin を捨てる
|
|
37
|
+
cat >/dev/null 2>&1 || true
|
|
38
|
+
|
|
39
|
+
# kill switch (env > config)
|
|
40
|
+
if [ "${ECC_IMPROVEMENT_PROPOSAL:-}" = "off" ]; then
|
|
41
|
+
exit 0
|
|
42
|
+
fi
|
|
43
|
+
case "${HC_IMPROVEMENT_PROPOSAL_ENABLED:-true}" in
|
|
44
|
+
false|False|FALSE|0|no|off) exit 0 ;;
|
|
45
|
+
esac
|
|
46
|
+
|
|
47
|
+
if ! command -v python3 >/dev/null 2>&1; then
|
|
48
|
+
exit 0
|
|
49
|
+
fi
|
|
50
|
+
|
|
51
|
+
# project root を決定(CLAUDE_PROJECT_DIR > git toplevel > pwd)
|
|
52
|
+
PROJ_ROOT="${CLAUDE_PROJECT_DIR:-}"
|
|
53
|
+
if [ -z "$PROJ_ROOT" ] || [ ! -d "$PROJ_ROOT" ]; then
|
|
54
|
+
PROJ_ROOT="$(git rev-parse --show-toplevel 2>/dev/null || pwd)"
|
|
55
|
+
fi
|
|
56
|
+
|
|
57
|
+
# state dir 解決(config 相対パスを project root に基づき絶対化)
|
|
58
|
+
STATE_DIR="${HC_IMPROVEMENT_PROPOSAL_STATE_DIR:-.claude/.improvement-proposal-state}"
|
|
59
|
+
case "$STATE_DIR" in
|
|
60
|
+
/*) ABS_STATE_DIR="$STATE_DIR" ;;
|
|
61
|
+
*) ABS_STATE_DIR="$PROJ_ROOT/$STATE_DIR" ;;
|
|
62
|
+
esac
|
|
63
|
+
|
|
64
|
+
mkdir -p "$ABS_STATE_DIR" 2>/dev/null || true
|
|
65
|
+
|
|
66
|
+
# === cache layer (task-22 W5) =================================================
|
|
67
|
+
# cache TTL は秒指定 (default 3600 = 1h)。テスト用に env で短縮可能。
|
|
68
|
+
CACHE_TTL_SECONDS="${HC_IMPROVEMENT_PROPOSAL_CACHE_TTL:-3600}"
|
|
69
|
+
# 整数値検証 (非数値なら default 3600 に fallback)
|
|
70
|
+
case "$CACHE_TTL_SECONDS" in
|
|
71
|
+
''|*[!0-9]*) CACHE_TTL_SECONDS=3600 ;;
|
|
72
|
+
esac
|
|
73
|
+
CACHE_FILE="$ABS_STATE_DIR/cache.json"
|
|
74
|
+
CACHE_ENABLED="${HC_IMPROVEMENT_PROPOSAL_CACHE_ENABLED:-true}"
|
|
75
|
+
|
|
76
|
+
# cache hit → payload を stderr に流して exit 0 (集計 skip)
|
|
77
|
+
if _cache_hit; then
|
|
78
|
+
jq -r '.payload' "$CACHE_FILE" >&2 2>/dev/null || true
|
|
79
|
+
exit 0
|
|
80
|
+
fi
|
|
81
|
+
|
|
82
|
+
# === 集計実行 (cache miss or expired or corrupt) ==============================
|
|
83
|
+
# Python 側に集計を委譲(標準ライブラリのみ使用、lib/improvement-proposal/aggregate.py)
|
|
84
|
+
# 環境変数経由で設定を渡す
|
|
85
|
+
export HC_IMPROVEMENT_PROPOSAL_LOOKBACK_DAYS
|
|
86
|
+
export HC_IMPROVEMENT_PROPOSAL_MAX_COUNT
|
|
87
|
+
export HC_IMPROVEMENT_PROPOSAL_DEDUP_HOURS
|
|
88
|
+
export HC_GATEGUARD_STATE_DIR
|
|
89
|
+
export HC_TASKGUARD_STATE_DIR
|
|
90
|
+
export HC_FAILURE_WINDOW_DIR
|
|
91
|
+
export HC_CONFIDENCE_STATE_DIR
|
|
92
|
+
export HC_HOMUNCULUS_ROOT
|
|
93
|
+
export ECC_IMPROVEMENT_PROPOSAL_TEST_NOW
|
|
94
|
+
export ABS_STATE_DIR
|
|
95
|
+
export PROJ_ROOT
|
|
96
|
+
|
|
97
|
+
# Python の stderr を一旦 tmp に捕捉、終了後に cache 書き込み + stderr に流す。
|
|
98
|
+
CACHE_TMP="$(mktemp 2>/dev/null || printf '%s' "$ABS_STATE_DIR/.cache.tmp.$$")"
|
|
99
|
+
# observations count を Python 側から拾うための tmp path (cache metadata 用)
|
|
100
|
+
export HC_IMPROVEMENT_PROPOSAL_OBS_COUNT_FILE="$ABS_STATE_DIR/.obs-count.tmp.$$"
|
|
101
|
+
|
|
102
|
+
python3 "$SCRIPT_DIR/lib/improvement-proposal/aggregate.py" 2>"$CACHE_TMP"
|
|
103
|
+
|
|
104
|
+
_write_cache
|
|
105
|
+
|
|
106
|
+
# 集計結果 stderr を実際に流す (cache hit 時と同じ挙動を保証)
|
|
107
|
+
cat "$CACHE_TMP" >&2 2>/dev/null || true
|
|
108
|
+
|
|
109
|
+
# クリーンアップ
|
|
110
|
+
rm -f "$CACHE_TMP" "$HC_IMPROVEMENT_PROPOSAL_OBS_COUNT_FILE" 2>/dev/null || true
|
|
111
|
+
|
|
112
|
+
exit 0
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# init-tasks-on-start.sh — SessionStart hook
|
|
3
|
+
#
|
|
4
|
+
# 役割:
|
|
5
|
+
# セッション開始時に docs/tasks/ docs/draft/ が未整備なら自動でテンプレ展開する。
|
|
6
|
+
# 既存ファイルは触らない。失敗してもセッションをブロックしない。
|
|
7
|
+
#
|
|
8
|
+
# 設計:
|
|
9
|
+
# - quiet モードで init-tasks.sh を呼ぶ
|
|
10
|
+
# - exit 0 を強制(fail-open)
|
|
11
|
+
|
|
12
|
+
set -u
|
|
13
|
+
|
|
14
|
+
# config 読み込み (HC_* 変数 + is_feature_enabled 関数 export、task-45 Phase 2)
|
|
15
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
16
|
+
# shellcheck source=lib/config-loader.sh
|
|
17
|
+
. "$SCRIPT_DIR/lib/config-loader.sh" 2>/dev/null || true
|
|
18
|
+
|
|
19
|
+
# Feature toggle 参照 (task-45 Phase 2)
|
|
20
|
+
if command -v is_feature_enabled >/dev/null 2>&1 && ! is_feature_enabled init_tasks_on_start; then
|
|
21
|
+
exit 0 # feature OFF で no-op
|
|
22
|
+
fi
|
|
23
|
+
|
|
24
|
+
# プロジェクト直下で実行
|
|
25
|
+
if [ -n "${CLAUDE_PROJECT_DIR:-}" ] && [ -d "$CLAUDE_PROJECT_DIR" ]; then
|
|
26
|
+
cd "$CLAUDE_PROJECT_DIR" 2>/dev/null || true
|
|
27
|
+
fi
|
|
28
|
+
|
|
29
|
+
# init-tasks.sh が見つかれば実行
|
|
30
|
+
if [ -f .claude/scripts/init-tasks.sh ]; then
|
|
31
|
+
bash .claude/scripts/init-tasks.sh --quiet 2>/dev/null || true
|
|
32
|
+
fi
|
|
33
|
+
|
|
34
|
+
exit 0
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# .claude/hooks/lib/bypass-logger.sh
|
|
3
|
+
# Centralized bypass logging — 全 hook の env-var bypass を統一フォーマットで
|
|
4
|
+
# .claude/.workflow-state/bypass.log に記録する共通ライブラリ。
|
|
5
|
+
#
|
|
6
|
+
# 役割:
|
|
7
|
+
# 各 hook が env-var (例: ECC_WORKFLOW_GUARD_OFF / HC_WORKFLOW_GUARD_ENABLED=false)
|
|
8
|
+
# で skip された際に audit log を 1 行 append する。
|
|
9
|
+
# 形式は .claude/.workflow-state/bypass.log.template と一致:
|
|
10
|
+
# <ISO-8601> | <session_id> | <hook_name> | <env_var> | <reason>
|
|
11
|
+
#
|
|
12
|
+
# 設計:
|
|
13
|
+
# - file-top に set を書かない (CLAUDE.md Critical Lessons HIGH 準拠、caller への
|
|
14
|
+
# shell flags leak 防止。pipefail leak → SIGPIPE → exit 141 サイレント終了の根絶)
|
|
15
|
+
# - set -e は使わない (mode-loader.sh の CB-verify 教訓 - 5846925)
|
|
16
|
+
# - 各関数 body 内で set -uo pipefail を subshell `( ... )` 形式で局所化
|
|
17
|
+
# - 失敗しても hook 本体を止めない (mkdir / printf を best-effort)
|
|
18
|
+
# - reason 未指定時は "(not provided)"
|
|
19
|
+
# - session_id 未取得時は "unknown"
|
|
20
|
+
#
|
|
21
|
+
# Security (task-40 Step 7 iter3 HIGH-1):
|
|
22
|
+
# - 全フィールド (hook_name / env_var / reason / session_id) に対し改行 -> 空白、
|
|
23
|
+
# pipe -> カンマの sanitize を実施。Claude tool_input から取得した file_path 等が
|
|
24
|
+
# reason に含まれる場合に改行/pipe 注入で bypass.log の audit trail (format:
|
|
25
|
+
# <ts> | <session> | <hook> | <env> | <reason>) が破壊・偽造されることを防止。
|
|
26
|
+
# - defense in depth: timestamp は date(1) 出力 (control 化済) だが念のため対象外。
|
|
27
|
+
#
|
|
28
|
+
# 使い方:
|
|
29
|
+
# source "${CLAUDE_PROJECT_DIR:-$(pwd)}/.claude/hooks/lib/bypass-logger.sh"
|
|
30
|
+
# log_bypass "workflow-guard" "ECC_WORKFLOW_GUARD_OFF" "$ECC_BYPASS_REASON"
|
|
31
|
+
#
|
|
32
|
+
# Args:
|
|
33
|
+
# $1 = hook_name (例: "workflow-guard")
|
|
34
|
+
# $2 = env_var (例: "ECC_WORKFLOW_GUARD_OFF")
|
|
35
|
+
# $3 = reason (任意 — 未指定時は "(not provided)")
|
|
36
|
+
|
|
37
|
+
# Note: file-top に `set -uo pipefail` を書かない。caller hook (autonomous-action-guard /
|
|
38
|
+
# confidence-gate / parallel-subagent-reminder 等) が source した瞬間に pipefail flag が
|
|
39
|
+
# leak し、`cmd | head -1` 等の SIGPIPE で exit 141 サイレント終了する事故を防ぐ
|
|
40
|
+
# (CLAUDE.md Critical Operational Lessons HIGH 準拠)。各関数は subshell `( ... )`
|
|
41
|
+
# 形式で定義し、内部で `set -uo pipefail` を局所適用する。
|
|
42
|
+
|
|
43
|
+
# log_bypass <hook_name> <env_var> <reason>
|
|
44
|
+
# 副作用: .claude/.workflow-state/bypass.log に 1 行 append
|
|
45
|
+
# subshell 関数化 ( ... ): 内部の set -uo pipefail は caller の shell flags に leak しない
|
|
46
|
+
log_bypass() (
|
|
47
|
+
set -uo pipefail
|
|
48
|
+
local hook_name="${1:-unknown}"
|
|
49
|
+
local env_var="${2:-unknown}"
|
|
50
|
+
local reason="${3:-(not provided)}"
|
|
51
|
+
local session_id="${CLAUDE_SESSION_ID:-unknown}"
|
|
52
|
+
local timestamp
|
|
53
|
+
timestamp=$(date -u +"%Y-%m-%dT%H:%M:%SZ" 2>/dev/null)
|
|
54
|
+
|
|
55
|
+
# ----------------------------------------------------------------------
|
|
56
|
+
# HIGH-1 (task-40 Step 7 iter3): audit trail 改行/pipe 注入 sanitize
|
|
57
|
+
# reason は Claude tool_input.file_path 等の untrusted source を含み得る。
|
|
58
|
+
# 改行 (\n) を空白に置換 -> 後続行偽造防止。
|
|
59
|
+
# pipe (|) をカンマに置換 -> 5-field format (<ts> | <s> | <h> | <e> | <r>) 破壊防止。
|
|
60
|
+
# 全フィールドに適用 (defense in depth、env_var / hook_name は通常静的だが念のため)。
|
|
61
|
+
# CR (\r) も改行扱いで sanitize (Windows-style line ending 経由の偽造防止)。
|
|
62
|
+
# ----------------------------------------------------------------------
|
|
63
|
+
hook_name="${hook_name//$'\n'/ }"
|
|
64
|
+
hook_name="${hook_name//$'\r'/ }"
|
|
65
|
+
hook_name="${hook_name//|/,}"
|
|
66
|
+
env_var="${env_var//$'\n'/ }"
|
|
67
|
+
env_var="${env_var//$'\r'/ }"
|
|
68
|
+
env_var="${env_var//|/,}"
|
|
69
|
+
reason="${reason//$'\n'/ }"
|
|
70
|
+
reason="${reason//$'\r'/ }"
|
|
71
|
+
reason="${reason//|/,}"
|
|
72
|
+
session_id="${session_id//$'\n'/ }"
|
|
73
|
+
session_id="${session_id//$'\r'/ }"
|
|
74
|
+
session_id="${session_id//|/,}"
|
|
75
|
+
|
|
76
|
+
local log_dir="${CLAUDE_PROJECT_DIR:-$(pwd)}/.claude/.workflow-state"
|
|
77
|
+
local log_file="${log_dir}/bypass.log"
|
|
78
|
+
mkdir -p "$log_dir" 2>/dev/null
|
|
79
|
+
printf '%s | %s | %s | %s | %s\n' \
|
|
80
|
+
"$timestamp" "$session_id" "$hook_name" "$env_var" "$reason" \
|
|
81
|
+
>> "$log_file" 2>/dev/null
|
|
82
|
+
)
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# bypass.sh — confidence-gate の bypass marker 判定 + log_failure helper
|
|
3
|
+
#
|
|
4
|
+
# 提供関数:
|
|
5
|
+
# init_bypass_paths — state_dir / bypass_marker / bypass_log を設定
|
|
6
|
+
# log_failure <phase> [detail] — 失敗理由を bypass.log に構造化記録
|
|
7
|
+
# handle_bypass_marker — bypass.cleared 存在時に通過 + 1 回 re-arm
|
|
8
|
+
#
|
|
9
|
+
# caller (orchestrator) が事前に export 必須:
|
|
10
|
+
# HC_CONFIDENCE_STATE_DIR (config-loader 経由で setup 済)
|
|
11
|
+
#
|
|
12
|
+
# 副作用:
|
|
13
|
+
# handle_bypass_marker は bypass marker 検出時に jq '{}' echo + exit 0
|
|
14
|
+
|
|
15
|
+
init_bypass_paths() {
|
|
16
|
+
state_dir="${HC_CONFIDENCE_STATE_DIR:-.claude/.confidence-gate-state}"
|
|
17
|
+
mkdir -p "$state_dir" 2>/dev/null
|
|
18
|
+
bypass_marker="${state_dir}/bypass.cleared"
|
|
19
|
+
bypass_log="${state_dir}/bypass.log"
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
# bypass.log 拡張: 失敗理由を構造化ログ。
|
|
23
|
+
# 引数: $1 = phase (regex_no_match / no_transcript / file_not_found / extract_failed
|
|
24
|
+
# / below_threshold / below_threshold_via_tool_response)
|
|
25
|
+
# $2 = detail (任意 free text、200 char 上限、改行/タブは空白に置換)
|
|
26
|
+
log_failure() {
|
|
27
|
+
local phase="$1"
|
|
28
|
+
local detail="${2:-}"
|
|
29
|
+
local ts
|
|
30
|
+
ts=$(date -u +%Y-%m-%dT%H:%M:%SZ)
|
|
31
|
+
detail=$(printf '%s' "$detail" | tr '\n\t' ' ' | cut -c1-200)
|
|
32
|
+
printf '%s\tfailed: %s\t%s\n' "$ts" "$phase" "$detail" >> "$bypass_log" 2>/dev/null
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
handle_bypass_marker() {
|
|
36
|
+
if [ -f "$bypass_marker" ]; then
|
|
37
|
+
local bypass_reason=""
|
|
38
|
+
if [ -s "$bypass_marker" ]; then
|
|
39
|
+
bypass_reason=$(cat "$bypass_marker" 2>/dev/null | head -c 200)
|
|
40
|
+
fi
|
|
41
|
+
local ts
|
|
42
|
+
ts=$(date -u +%Y-%m-%dT%H:%M:%SZ)
|
|
43
|
+
printf '%s\tbypassed: %s\n' "$ts" "${bypass_reason:-(no reason given)}" >> "$bypass_log" 2>/dev/null
|
|
44
|
+
rm -f "$bypass_marker" 2>/dev/null
|
|
45
|
+
echo '{}'
|
|
46
|
+
exit 0
|
|
47
|
+
fi
|
|
48
|
+
}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# extract.sh — confidence-gate の text 抽出 helper
|
|
3
|
+
#
|
|
4
|
+
# 提供関数:
|
|
5
|
+
# extract_confidence <text> — text から `confidence: 0.X` を抽出 (variant 対応)
|
|
6
|
+
# extract_tool_response_text <input> — SubagentStop JSON の tool_response から最終 reply text 抽出
|
|
7
|
+
# resolve_subagent_transcript <transcript> <agent_id>
|
|
8
|
+
# — subagent transcript path 解決 (agent_id 付きなら subagents/ 優先)
|
|
9
|
+
# extract_final_assistant_text <transcript>
|
|
10
|
+
# — transcript 末尾 500 行から assistant message text を join
|
|
11
|
+
|
|
12
|
+
# === 抽出ヘルパー: confidence 数値を文字列から抜く ===
|
|
13
|
+
# 対応 variant:
|
|
14
|
+
# confidence: 0.85
|
|
15
|
+
# Confidence: 0.85
|
|
16
|
+
# confidence_score: 0.85
|
|
17
|
+
# confidence score: 0.85
|
|
18
|
+
# 信頼度: 0.85
|
|
19
|
+
# 信頼度 0.85
|
|
20
|
+
# 数値レンジ: 0(.0..) / 1(.0..)
|
|
21
|
+
# 区切り: 半角 ":" / 全角 ":"(記号のみ env-portable な POSIX class で)
|
|
22
|
+
extract_confidence() {
|
|
23
|
+
local text="$1"
|
|
24
|
+
local m
|
|
25
|
+
# 英語 variant — confidence / confidence_score / confidence score
|
|
26
|
+
m=$(printf '%s' "$text" | grep -ioE '(confidence([_[:space:]]*score)?)[[:space:]]*[::][[:space:]]*(0(\.[0-9]+)?|1(\.0+)?)' | tail -n 1)
|
|
27
|
+
if [ -z "$m" ]; then
|
|
28
|
+
# 日本語 variant — 信頼度: 0.X / 信頼度 0.X
|
|
29
|
+
m=$(printf '%s' "$text" | grep -ioE '信頼度[[:space:]]*[::]?[[:space:]]*(0(\.[0-9]+)?|1(\.0+)?)' | tail -n 1)
|
|
30
|
+
fi
|
|
31
|
+
printf '%s' "$m"
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
# === fallback: hook input の tool_response から最終 reply text を構築 ===
|
|
35
|
+
extract_tool_response_text() {
|
|
36
|
+
printf '%s' "$1" | jq -r '
|
|
37
|
+
(.tool_response // {})
|
|
38
|
+
| if type == "string" then .
|
|
39
|
+
elif type == "object" then
|
|
40
|
+
(.content // .text // "")
|
|
41
|
+
| if type == "array" then
|
|
42
|
+
[ .[] | (.text // (if type == "string" then . else "" end)) ] | join("\n")
|
|
43
|
+
elif type == "string" then .
|
|
44
|
+
else "" end
|
|
45
|
+
else "" end
|
|
46
|
+
' 2>/dev/null
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
# === subagent transcript 解決 ===
|
|
50
|
+
# SubagentStop hook に渡される transcript_path は親セッションの JSONL を指すことがある。
|
|
51
|
+
# 実際のサブエージェント応答は <parent_stem>/subagents/agent-<id>.jsonl に書かれる。
|
|
52
|
+
# agent_id が SubagentStop JSON に含まれる場合は subagent ファイルを優先して読む。
|
|
53
|
+
# stdout に解決後 transcript path を返す
|
|
54
|
+
resolve_subagent_transcript() {
|
|
55
|
+
local transcript="$1"
|
|
56
|
+
local agent_id="$2"
|
|
57
|
+
if [ -n "$agent_id" ] && [ -n "$transcript" ] && [ "$transcript" != "null" ]; then
|
|
58
|
+
local stem subagent_file
|
|
59
|
+
stem="${transcript%.jsonl}"
|
|
60
|
+
subagent_file="${stem}/subagents/agent-${agent_id}.jsonl"
|
|
61
|
+
if [ -f "$subagent_file" ]; then
|
|
62
|
+
printf '%s' "$subagent_file"
|
|
63
|
+
return
|
|
64
|
+
fi
|
|
65
|
+
fi
|
|
66
|
+
printf '%s' "$transcript"
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
# === 最終 assistant text を抽出 ===
|
|
70
|
+
# transcript は JSONL。末尾 500 行から assistant role のメッセージを集める
|
|
71
|
+
# (元 200 行では subagent の長い summary が境界をまたぎ confidence を見落とす
|
|
72
|
+
# ケースが頻発したため拡大)。
|
|
73
|
+
# Claude Code transcript schema 新旧両対応:
|
|
74
|
+
# 旧: {"type":"assistant","message":{"content":[{"type":"text","text":"..."}]}}
|
|
75
|
+
# 新: {"role":"assistant","content":[{"type":"text","text":"..."}]} 等
|
|
76
|
+
extract_final_assistant_text() {
|
|
77
|
+
local transcript="$1"
|
|
78
|
+
tail -n 500 "$transcript" 2>/dev/null | jq -rs '
|
|
79
|
+
[
|
|
80
|
+
.[]
|
|
81
|
+
| select(
|
|
82
|
+
((.type // "") == "assistant")
|
|
83
|
+
or ((.role // "") == "assistant")
|
|
84
|
+
or (((.message // {}).role // "") == "assistant")
|
|
85
|
+
)
|
|
86
|
+
| (
|
|
87
|
+
((.message // .).content)
|
|
88
|
+
| if type == "array" then
|
|
89
|
+
[ .[] | (.text // "") ] | join("\n")
|
|
90
|
+
elif type == "string" then
|
|
91
|
+
.
|
|
92
|
+
else
|
|
93
|
+
""
|
|
94
|
+
end
|
|
95
|
+
)
|
|
96
|
+
]
|
|
97
|
+
| join("\n")
|
|
98
|
+
' 2>/dev/null
|
|
99
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# major-agent-filter.sh — F3 major subagent only block の判定
|
|
3
|
+
#
|
|
4
|
+
# 役割:
|
|
5
|
+
# SubagentStop hook は agent_type を問わず全 stop event で fire するため、
|
|
6
|
+
# 軽量 sidechain (Task tool query / tool-use only) で 96 件の regex_no_match
|
|
7
|
+
# が累積する事故があった (/harness-audit 2026-05-13 観察)。
|
|
8
|
+
# major subagent (general-purpose 等の allowlist or path_subagents) 以外は
|
|
9
|
+
# fail-open で通過させ、major subagent only に confidence 自己評価を強制する。
|
|
10
|
+
#
|
|
11
|
+
# bypass: HC_CONFIDENCE_MAJOR_AGENT_ONLY=false で従来動作 (全 stop event で block 判定)。
|
|
12
|
+
#
|
|
13
|
+
# 提供関数:
|
|
14
|
+
# classify_sidechain <transcript> — transcript path / record から is_sidechain 判定
|
|
15
|
+
# stdout: "path_subagents" / "record_isSidechain" / "no" / "unknown"
|
|
16
|
+
# is_major_subagent <agent_type> <is_sidechain>
|
|
17
|
+
# — major subagent 判定
|
|
18
|
+
# stdout: "true" / "false"
|
|
19
|
+
|
|
20
|
+
# transcript path から sidechain 判定
|
|
21
|
+
classify_sidechain() {
|
|
22
|
+
local transcript="$1"
|
|
23
|
+
case "$transcript" in
|
|
24
|
+
*/subagents/*) printf 'path_subagents'; return ;;
|
|
25
|
+
esac
|
|
26
|
+
printf 'unknown'
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
# transcript file 内の record から sidechain 判定 (path 判定で unknown のとき)
|
|
30
|
+
refine_sidechain_from_records() {
|
|
31
|
+
local current="$1"
|
|
32
|
+
local transcript="$2"
|
|
33
|
+
if [ "$current" = "unknown" ]; then
|
|
34
|
+
if grep -q '"isSidechain"[[:space:]]*:[[:space:]]*true' "$transcript" 2>/dev/null; then
|
|
35
|
+
printf 'record_isSidechain'
|
|
36
|
+
else
|
|
37
|
+
printf 'no'
|
|
38
|
+
fi
|
|
39
|
+
return
|
|
40
|
+
fi
|
|
41
|
+
printf '%s' "$current"
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
# === major subagent 判定 (W1, task #9) ===
|
|
45
|
+
# allowlist match (agent_type が general-purpose / Explore / Task) または
|
|
46
|
+
# is_sidechain==path_subagents なら major subagent (confidence 必須)。
|
|
47
|
+
# それ以外 (軽量 sidechain / Task tool query etc.) は extract_confidence 失敗時に fail-open。
|
|
48
|
+
is_major_subagent() {
|
|
49
|
+
local agent_type="$1"
|
|
50
|
+
local is_sidechain="$2"
|
|
51
|
+
local result="false"
|
|
52
|
+
case "$agent_type" in
|
|
53
|
+
general-purpose|Explore|Task) result="true" ;;
|
|
54
|
+
esac
|
|
55
|
+
if [ "$is_sidechain" = "path_subagents" ]; then
|
|
56
|
+
result="true"
|
|
57
|
+
fi
|
|
58
|
+
printf '%s' "$result"
|
|
59
|
+
}
|