aigroup-workflow 1.3.0 → 2.0.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/agents/architect.md +211 -0
- package/.claude/agents/build-error-resolver.md +114 -0
- package/.claude/agents/code-reviewer.md +237 -0
- package/.claude/agents/doc-updater.md +107 -0
- package/.claude/agents/e2e-runner.md +107 -0
- package/.claude/agents/init-architect.md +185 -128
- package/.claude/agents/planner.md +212 -0
- package/.claude/agents/refactor-cleaner.md +85 -0
- package/.claude/agents/rust-reviewer.md +94 -0
- package/.claude/agents/security-reviewer.md +108 -0
- package/.claude/agents/tdd-guide.md +91 -0
- package/.claude/commands/fix-build.md +32 -0
- package/.claude/commands/git-commit.md +1 -1
- package/.claude/commands/init-project.md +66 -50
- package/.claude/commands/plan.md +32 -0
- package/.claude/commands/review.md +29 -0
- package/.claude/commands/tdd.md +32 -0
- package/.claude/commands/workflow-start.md +87 -0
- package/.claude/hooks.json +3 -3
- package/.claude-plugin/plugin.json +20 -0
- package/.codex/AGENTS.md +107 -0
- package/.codex/agents/docs-researcher.toml +14 -0
- package/.codex/agents/explorer.toml +14 -0
- package/.codex/agents/reviewer.toml +16 -0
- package/.codex/config.toml +93 -0
- package/.codex-plugin/plugin.json +33 -0
- package/AGENTS.md +76 -0
- package/CLAUDE.md +18 -83
- package/README.md +220 -317
- package/cli/commands/check.mjs +11 -19
- package/cli/commands/init.mjs +133 -49
- package/cli/commands/status.mjs +42 -39
- package/cli/commands/update.mjs +10 -12
- package/cli/utils/scaffold.mjs +297 -126
- package/docs/README.md +46 -29
- package/docs/red-flags.md +29 -24
- package/docs/rules/README.md +51 -0
- package/docs/rules/agents.md +50 -0
- package/docs/rules/coding-style.md +79 -0
- package/docs/rules/cpp/coding-style.md +44 -0
- package/docs/rules/cpp/hooks.md +39 -0
- package/docs/rules/cpp/patterns.md +51 -0
- package/docs/rules/cpp/security.md +51 -0
- package/docs/rules/cpp/testing.md +44 -0
- package/docs/rules/csharp/coding-style.md +72 -0
- package/docs/rules/csharp/hooks.md +25 -0
- package/docs/rules/csharp/patterns.md +50 -0
- package/docs/rules/csharp/security.md +58 -0
- package/docs/rules/csharp/testing.md +46 -0
- package/docs/rules/dart/coding-style.md +159 -0
- package/docs/rules/dart/hooks.md +66 -0
- package/docs/rules/dart/patterns.md +261 -0
- package/docs/rules/dart/security.md +135 -0
- package/docs/rules/dart/testing.md +215 -0
- package/docs/rules/git-workflow.md +53 -0
- package/docs/rules/golang/coding-style.md +32 -0
- package/docs/rules/golang/hooks.md +17 -0
- package/docs/rules/golang/patterns.md +45 -0
- package/docs/rules/golang/security.md +34 -0
- package/docs/rules/golang/testing.md +31 -0
- package/docs/rules/hooks.md +61 -0
- package/docs/rules/java/coding-style.md +114 -0
- package/docs/rules/java/hooks.md +18 -0
- package/docs/rules/java/patterns.md +146 -0
- package/docs/rules/java/security.md +100 -0
- package/docs/rules/java/testing.md +131 -0
- package/docs/rules/kotlin/coding-style.md +86 -0
- package/docs/rules/kotlin/hooks.md +17 -0
- package/docs/rules/kotlin/patterns.md +146 -0
- package/docs/rules/kotlin/security.md +82 -0
- package/docs/rules/kotlin/testing.md +128 -0
- package/docs/rules/performance.md +30 -0
- package/docs/rules/perl/coding-style.md +46 -0
- package/docs/rules/perl/hooks.md +22 -0
- package/docs/rules/perl/patterns.md +76 -0
- package/docs/rules/perl/security.md +69 -0
- package/docs/rules/perl/testing.md +54 -0
- package/docs/rules/php/coding-style.md +40 -0
- package/docs/rules/php/hooks.md +24 -0
- package/docs/rules/php/patterns.md +33 -0
- package/docs/rules/php/security.md +37 -0
- package/docs/rules/php/testing.md +39 -0
- package/docs/rules/python/coding-style.md +42 -0
- package/docs/rules/python/hooks.md +19 -0
- package/docs/rules/python/patterns.md +39 -0
- package/docs/rules/python/security.md +30 -0
- package/docs/rules/python/testing.md +38 -0
- package/docs/rules/rust/coding-style.md +151 -0
- package/docs/rules/rust/hooks.md +16 -0
- package/docs/rules/rust/patterns.md +168 -0
- package/docs/rules/rust/security.md +141 -0
- package/docs/rules/rust/testing.md +154 -0
- package/docs/rules/security.md +73 -0
- package/docs/rules/swift/coding-style.md +47 -0
- package/docs/rules/swift/hooks.md +20 -0
- package/docs/rules/swift/patterns.md +66 -0
- package/docs/rules/swift/security.md +33 -0
- package/docs/rules/swift/testing.md +45 -0
- package/docs/rules/testing.md +77 -0
- package/docs/rules/typescript/coding-style.md +199 -0
- package/docs/rules/typescript/hooks.md +22 -0
- package/docs/rules/typescript/patterns.md +52 -0
- package/docs/rules/typescript/security.md +28 -0
- package/docs/rules/typescript/testing.md +18 -0
- package/docs/rules/web/coding-style.md +96 -0
- package/docs/rules/web/design-quality.md +63 -0
- package/docs/rules/web/hooks.md +120 -0
- package/docs/rules/web/patterns.md +79 -0
- package/docs/rules/web/performance.md +64 -0
- package/docs/rules/web/security.md +57 -0
- package/docs/rules/web/testing.md +55 -0
- package/docs/templates/code-review.md +1 -1
- package/docs/templates/implementation-plan.md +82 -82
- package/docs/workflow-pipeline.md +55 -127
- package/manifests/install-modules.json +294 -0
- package/package.json +7 -2
- package/scripts/harness/log-event.sh +11 -21
- package/scripts/harness/logs-query.sh +3 -8
- package/scripts/harness/tests/test-log-event.sh +16 -31
- package/scripts/harness/tests/test-logs-query.sh +4 -4
- package/scripts/hooks/README.md +49 -0
- package/scripts/hooks/checks/claude-md-size.cjs +21 -0
- package/scripts/hooks/checks/delegation-antipatterns.cjs +66 -0
- package/scripts/hooks/checks/empty-docs.cjs +32 -0
- package/scripts/hooks/checks/orchestration-artifacts.cjs +65 -0
- package/scripts/hooks/checks/structure.cjs +23 -0
- package/scripts/hooks/checks/workflow-state.cjs +56 -0
- package/scripts/hooks/dispatcher.cjs +64 -0
- package/scripts/hooks/lib/runner.cjs +81 -0
- package/scripts/orchestration/lib/orchestrator.cjs +181 -0
- package/scripts/orchestration/session.cjs +180 -0
- package/skills/documentation/SKILL.md +45 -0
- package/skills/{max/workflow/entropy-management → entropy-management}/SKILL.md +115 -124
- package/skills/requirement-engineering/SKILL.md +111 -0
- package/skills/{max/workflow/subagent-driven-development → subagent-driven-development}/SKILL.md +18 -18
- package/skills/{max/workflow/writing-plans → writing-plans}/SKILL.md +165 -165
- package/.claude/agents/ella.md +0 -101
- package/.claude/agents/jarvis.md +0 -193
- package/.claude/agents/kyle.md +0 -168
- package/docs/ARCHITECTURE.md +0 -117
- package/docs/QUALITY_SCORE.md +0 -44
- package/docs/coding-standards.md +0 -48
- package/docs/dispatch-rules.md +0 -83
- package/docs/steering-loop.md +0 -72
- package/docs/tech-debt-tracker.md +0 -26
- package/docs/templates/memory/activeContext.template.md +0 -30
- package/docs/templates/memory/projectContext.template.md +0 -36
- package/docs/templates/memory/systemPatterns.template.md +0 -26
- package/scripts/check-gitignore.sh +0 -130
- package/scripts/clean-system-files.sh +0 -169
- package/scripts/harness/hook-post-edit.sh +0 -40
- package/scripts/harness/hook-stop.sh +0 -70
- package/scripts/harness/hook-subagent-stop.sh +0 -54
- package/scripts/harness/lint-delegation.sh +0 -168
- package/scripts/harness/lint-docs.sh +0 -121
- package/scripts/harness/lint-process.sh +0 -221
- package/scripts/harness/lint-structure.sh +0 -145
- package/scripts/harness/lint-workflow-artifacts.sh +0 -150
- package/scripts/harness/run-all.sh +0 -77
- package/scripts/harness/workflow-state.sh +0 -397
- package/scripts/update-skills.sh +0 -187
- package/skills/max/workflow/brainstorming/SKILL.md +0 -111
- package/skills/max/workflow/documentation/SKILL.md +0 -82
- package/skills/max/workflow/requirement-validation/SKILL.md +0 -107
- package/skills/max/workflow/solution-design/SKILL.md +0 -117
- package/skills/max/workflow/testing/SKILL.md +0 -118
- /package/skills/{ella/angular-architect → angular-architect}/SKILL.md +0 -0
- /package/skills/{ella/angular-architect → angular-architect}/references/components.md +0 -0
- /package/skills/{ella/angular-architect → angular-architect}/references/ngrx.md +0 -0
- /package/skills/{ella/angular-architect → angular-architect}/references/routing.md +0 -0
- /package/skills/{ella/angular-architect → angular-architect}/references/rxjs.md +0 -0
- /package/skills/{ella/angular-architect → angular-architect}/references/testing.md +0 -0
- /package/skills/{jarvis/api-designer → api-designer}/SKILL.md +0 -0
- /package/skills/{jarvis/api-designer → api-designer}/references/error-handling.md +0 -0
- /package/skills/{jarvis/api-designer → api-designer}/references/openapi.md +0 -0
- /package/skills/{jarvis/api-designer → api-designer}/references/pagination.md +0 -0
- /package/skills/{jarvis/api-designer → api-designer}/references/rest-patterns.md +0 -0
- /package/skills/{jarvis/api-designer → api-designer}/references/versioning.md +0 -0
- /package/skills/{jarvis/architecture-designer → architecture-designer}/SKILL.md +0 -0
- /package/skills/{jarvis/architecture-designer → architecture-designer}/references/adr-template.md +0 -0
- /package/skills/{jarvis/architecture-designer → architecture-designer}/references/architecture-patterns.md +0 -0
- /package/skills/{jarvis/architecture-designer → architecture-designer}/references/database-selection.md +0 -0
- /package/skills/{jarvis/architecture-designer → architecture-designer}/references/nfr-checklist.md +0 -0
- /package/skills/{jarvis/architecture-designer → architecture-designer}/references/system-design.md +0 -0
- /package/skills/{kyle/chaos-engineer → chaos-engineer}/SKILL.md +0 -0
- /package/skills/{kyle/chaos-engineer → chaos-engineer}/references/chaos-tools.md +0 -0
- /package/skills/{kyle/chaos-engineer → chaos-engineer}/references/experiment-design.md +0 -0
- /package/skills/{kyle/chaos-engineer → chaos-engineer}/references/game-days.md +0 -0
- /package/skills/{kyle/chaos-engineer → chaos-engineer}/references/infrastructure-chaos.md +0 -0
- /package/skills/{kyle/chaos-engineer → chaos-engineer}/references/kubernetes-chaos.md +0 -0
- /package/skills/{jarvis/cli-developer → cli-developer}/SKILL.md +0 -0
- /package/skills/{jarvis/cli-developer → cli-developer}/references/design-patterns.md +0 -0
- /package/skills/{jarvis/cli-developer → cli-developer}/references/go-cli.md +0 -0
- /package/skills/{jarvis/cli-developer → cli-developer}/references/node-cli.md +0 -0
- /package/skills/{jarvis/cli-developer → cli-developer}/references/python-cli.md +0 -0
- /package/skills/{jarvis/cli-developer → cli-developer}/references/ux-patterns.md +0 -0
- /package/skills/{jarvis/cloud-architect → cloud-architect}/SKILL.md +0 -0
- /package/skills/{jarvis/cloud-architect → cloud-architect}/references/aws.md +0 -0
- /package/skills/{jarvis/cloud-architect → cloud-architect}/references/azure.md +0 -0
- /package/skills/{jarvis/cloud-architect → cloud-architect}/references/cost.md +0 -0
- /package/skills/{jarvis/cloud-architect → cloud-architect}/references/gcp.md +0 -0
- /package/skills/{jarvis/cloud-architect → cloud-architect}/references/multi-cloud.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/SKILL.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/references/api-docs-fastapi-django.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/references/api-docs-nestjs-express.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/references/coverage-reports.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/references/documentation-systems.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/references/interactive-api-docs.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/references/python-docstrings.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/references/typescript-jsdoc.md +0 -0
- /package/skills/{jarvis/code-documenter → code-documenter}/references/user-guides-tutorials.md +0 -0
- /package/skills/{kyle/code-reviewer → code-reviewer}/SKILL.md +0 -0
- /package/skills/{kyle/code-reviewer → code-reviewer}/references/common-issues.md +0 -0
- /package/skills/{kyle/code-reviewer → code-reviewer}/references/feedback-examples.md +0 -0
- /package/skills/{kyle/code-reviewer → code-reviewer}/references/receiving-feedback.md +0 -0
- /package/skills/{kyle/code-reviewer → code-reviewer}/references/report-template.md +0 -0
- /package/skills/{kyle/code-reviewer → code-reviewer}/references/review-checklist.md +0 -0
- /package/skills/{kyle/code-reviewer → code-reviewer}/references/spec-compliance-review.md +0 -0
- /package/skills/{max/competitive-analysis → competitive-analysis}/SKILL.md +0 -0
- /package/skills/{jarvis/cpp-pro → cpp-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/cpp-pro → cpp-pro}/references/build-tooling.md +0 -0
- /package/skills/{jarvis/cpp-pro → cpp-pro}/references/concurrency.md +0 -0
- /package/skills/{jarvis/cpp-pro → cpp-pro}/references/memory-performance.md +0 -0
- /package/skills/{jarvis/cpp-pro → cpp-pro}/references/modern-cpp.md +0 -0
- /package/skills/{jarvis/cpp-pro → cpp-pro}/references/templates.md +0 -0
- /package/skills/{jarvis/csharp-developer → csharp-developer}/SKILL.md +0 -0
- /package/skills/{jarvis/csharp-developer → csharp-developer}/references/aspnet-core.md +0 -0
- /package/skills/{jarvis/csharp-developer → csharp-developer}/references/blazor.md +0 -0
- /package/skills/{jarvis/csharp-developer → csharp-developer}/references/entity-framework.md +0 -0
- /package/skills/{jarvis/csharp-developer → csharp-developer}/references/modern-csharp.md +0 -0
- /package/skills/{jarvis/csharp-developer → csharp-developer}/references/performance.md +0 -0
- /package/skills/{jarvis/database-optimizer → database-optimizer}/SKILL.md +0 -0
- /package/skills/{jarvis/database-optimizer → database-optimizer}/references/index-strategies.md +0 -0
- /package/skills/{jarvis/database-optimizer → database-optimizer}/references/monitoring-analysis.md +0 -0
- /package/skills/{jarvis/database-optimizer → database-optimizer}/references/mysql-tuning.md +0 -0
- /package/skills/{jarvis/database-optimizer → database-optimizer}/references/postgresql-tuning.md +0 -0
- /package/skills/{jarvis/database-optimizer → database-optimizer}/references/query-optimization.md +0 -0
- /package/skills/{jarvis/debugging-wizard → debugging-wizard}/SKILL.md +0 -0
- /package/skills/{jarvis/debugging-wizard → debugging-wizard}/references/common-patterns.md +0 -0
- /package/skills/{jarvis/debugging-wizard → debugging-wizard}/references/debugging-tools.md +0 -0
- /package/skills/{jarvis/debugging-wizard → debugging-wizard}/references/quick-fixes.md +0 -0
- /package/skills/{jarvis/debugging-wizard → debugging-wizard}/references/strategies.md +0 -0
- /package/skills/{jarvis/debugging-wizard → debugging-wizard}/references/systematic-debugging.md +0 -0
- /package/skills/{ella/commands → design-commands}/design.md +0 -0
- /package/skills/{ella/commands → design-commands}/handoff.md +0 -0
- /package/skills/{ella/commands → design-commands}/prototype.md +0 -0
- /package/skills/{ella/commands → design-commands}/spec.md +0 -0
- /package/skills/{ella/commands → design-commands}/style.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/SKILL.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/references/deployment-strategies.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/references/docker-patterns.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/references/github-actions.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/references/incident-response.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/references/kubernetes.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/references/platform-engineering.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/references/release-automation.md +0 -0
- /package/skills/{jarvis/devops-engineer → devops-engineer}/references/terraform-iac.md +0 -0
- /package/skills/{jarvis/django-expert → django-expert}/SKILL.md +0 -0
- /package/skills/{jarvis/django-expert → django-expert}/references/authentication.md +0 -0
- /package/skills/{jarvis/django-expert → django-expert}/references/drf-serializers.md +0 -0
- /package/skills/{jarvis/django-expert → django-expert}/references/models-orm.md +0 -0
- /package/skills/{jarvis/django-expert → django-expert}/references/testing-django.md +0 -0
- /package/skills/{jarvis/django-expert → django-expert}/references/viewsets-views.md +0 -0
- /package/skills/{jarvis/dotnet-core-expert → dotnet-core-expert}/SKILL.md +0 -0
- /package/skills/{jarvis/dotnet-core-expert → dotnet-core-expert}/references/authentication.md +0 -0
- /package/skills/{jarvis/dotnet-core-expert → dotnet-core-expert}/references/clean-architecture.md +0 -0
- /package/skills/{jarvis/dotnet-core-expert → dotnet-core-expert}/references/cloud-native.md +0 -0
- /package/skills/{jarvis/dotnet-core-expert → dotnet-core-expert}/references/entity-framework.md +0 -0
- /package/skills/{jarvis/dotnet-core-expert → dotnet-core-expert}/references/minimal-apis.md +0 -0
- /package/skills/{jarvis/fastapi-expert → fastapi-expert}/SKILL.md +0 -0
- /package/skills/{jarvis/fastapi-expert → fastapi-expert}/references/async-sqlalchemy.md +0 -0
- /package/skills/{jarvis/fastapi-expert → fastapi-expert}/references/authentication.md +0 -0
- /package/skills/{jarvis/fastapi-expert → fastapi-expert}/references/endpoints-routing.md +0 -0
- /package/skills/{jarvis/fastapi-expert → fastapi-expert}/references/migration-from-django.md +0 -0
- /package/skills/{jarvis/fastapi-expert → fastapi-expert}/references/pydantic-v2.md +0 -0
- /package/skills/{jarvis/fastapi-expert → fastapi-expert}/references/testing-async.md +0 -0
- /package/skills/{jarvis/feature-forge → feature-forge}/SKILL.md +0 -0
- /package/skills/{jarvis/feature-forge → feature-forge}/references/acceptance-criteria.md +0 -0
- /package/skills/{jarvis/feature-forge → feature-forge}/references/ears-syntax.md +0 -0
- /package/skills/{jarvis/feature-forge → feature-forge}/references/interview-questions.md +0 -0
- /package/skills/{jarvis/feature-forge → feature-forge}/references/pre-discovery-subagents.md +0 -0
- /package/skills/{jarvis/feature-forge → feature-forge}/references/specification-template.md +0 -0
- /package/skills/{jarvis/fine-tuning-expert → fine-tuning-expert}/SKILL.md +0 -0
- /package/skills/{jarvis/fine-tuning-expert → fine-tuning-expert}/references/dataset-preparation.md +0 -0
- /package/skills/{jarvis/fine-tuning-expert → fine-tuning-expert}/references/deployment-optimization.md +0 -0
- /package/skills/{jarvis/fine-tuning-expert → fine-tuning-expert}/references/evaluation-metrics.md +0 -0
- /package/skills/{jarvis/fine-tuning-expert → fine-tuning-expert}/references/hyperparameter-tuning.md +0 -0
- /package/skills/{jarvis/fine-tuning-expert → fine-tuning-expert}/references/lora-peft.md +0 -0
- /package/skills/{max/workflow/finishing-a-development-branch → finishing-a-development-branch}/SKILL.md +0 -0
- /package/skills/{ella/flutter-expert → flutter-expert}/SKILL.md +0 -0
- /package/skills/{ella/flutter-expert → flutter-expert}/references/bloc-state.md +0 -0
- /package/skills/{ella/flutter-expert → flutter-expert}/references/gorouter-navigation.md +0 -0
- /package/skills/{ella/flutter-expert → flutter-expert}/references/performance.md +0 -0
- /package/skills/{ella/flutter-expert → flutter-expert}/references/project-structure.md +0 -0
- /package/skills/{ella/flutter-expert → flutter-expert}/references/riverpod-state.md +0 -0
- /package/skills/{ella/flutter-expert → flutter-expert}/references/widget-patterns.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/SKILL.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/api-design-standards.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/architecture-decisions.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/backend-patterns.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/common-patterns.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/deliverables-checklist.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/design-template.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/error-handling.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/frontend-patterns.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/integration-patterns.md +0 -0
- /package/skills/{jarvis/fullstack-guardian → fullstack-guardian}/references/security-checklist.md +0 -0
- /package/skills/{jarvis/golang-pro → golang-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/golang-pro → golang-pro}/references/concurrency.md +0 -0
- /package/skills/{jarvis/golang-pro → golang-pro}/references/generics.md +0 -0
- /package/skills/{jarvis/golang-pro → golang-pro}/references/interfaces.md +0 -0
- /package/skills/{jarvis/golang-pro → golang-pro}/references/project-structure.md +0 -0
- /package/skills/{jarvis/golang-pro → golang-pro}/references/testing.md +0 -0
- /package/skills/{jarvis/graphql-architect → graphql-architect}/SKILL.md +0 -0
- /package/skills/{jarvis/graphql-architect → graphql-architect}/references/federation.md +0 -0
- /package/skills/{jarvis/graphql-architect → graphql-architect}/references/migration-from-rest.md +0 -0
- /package/skills/{jarvis/graphql-architect → graphql-architect}/references/resolvers.md +0 -0
- /package/skills/{jarvis/graphql-architect → graphql-architect}/references/schema-design.md +0 -0
- /package/skills/{jarvis/graphql-architect → graphql-architect}/references/security.md +0 -0
- /package/skills/{jarvis/graphql-architect → graphql-architect}/references/subscriptions.md +0 -0
- /package/skills/{jarvis/java-architect → java-architect}/SKILL.md +0 -0
- /package/skills/{jarvis/java-architect → java-architect}/references/jpa-optimization.md +0 -0
- /package/skills/{jarvis/java-architect → java-architect}/references/reactive-webflux.md +0 -0
- /package/skills/{jarvis/java-architect → java-architect}/references/spring-boot-setup.md +0 -0
- /package/skills/{jarvis/java-architect → java-architect}/references/spring-security.md +0 -0
- /package/skills/{jarvis/java-architect → java-architect}/references/testing-patterns.md +0 -0
- /package/skills/{jarvis/javascript-pro → javascript-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/javascript-pro → javascript-pro}/references/async-patterns.md +0 -0
- /package/skills/{jarvis/javascript-pro → javascript-pro}/references/browser-apis.md +0 -0
- /package/skills/{jarvis/javascript-pro → javascript-pro}/references/modern-syntax.md +0 -0
- /package/skills/{jarvis/javascript-pro → javascript-pro}/references/modules.md +0 -0
- /package/skills/{jarvis/javascript-pro → javascript-pro}/references/node-essentials.md +0 -0
- /package/skills/{jarvis/kotlin-specialist → kotlin-specialist}/SKILL.md +0 -0
- /package/skills/{jarvis/kotlin-specialist → kotlin-specialist}/references/android-compose.md +0 -0
- /package/skills/{jarvis/kotlin-specialist → kotlin-specialist}/references/coroutines-flow.md +0 -0
- /package/skills/{jarvis/kotlin-specialist → kotlin-specialist}/references/dsl-idioms.md +0 -0
- /package/skills/{jarvis/kotlin-specialist → kotlin-specialist}/references/ktor-server.md +0 -0
- /package/skills/{jarvis/kotlin-specialist → kotlin-specialist}/references/multiplatform-kmp.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/SKILL.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/configuration.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/cost-optimization.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/custom-operators.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/gitops.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/helm-charts.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/multi-cluster.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/networking.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/service-mesh.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/storage.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/troubleshooting.md +0 -0
- /package/skills/{jarvis/kubernetes-specialist → kubernetes-specialist}/references/workloads.md +0 -0
- /package/skills/{jarvis/laravel-specialist → laravel-specialist}/SKILL.md +0 -0
- /package/skills/{jarvis/laravel-specialist → laravel-specialist}/references/eloquent.md +0 -0
- /package/skills/{jarvis/laravel-specialist → laravel-specialist}/references/livewire.md +0 -0
- /package/skills/{jarvis/laravel-specialist → laravel-specialist}/references/queues.md +0 -0
- /package/skills/{jarvis/laravel-specialist → laravel-specialist}/references/routing.md +0 -0
- /package/skills/{jarvis/laravel-specialist → laravel-specialist}/references/testing.md +0 -0
- /package/skills/{jarvis/legacy-modernizer → legacy-modernizer}/SKILL.md +0 -0
- /package/skills/{jarvis/legacy-modernizer → legacy-modernizer}/references/legacy-testing.md +0 -0
- /package/skills/{jarvis/legacy-modernizer → legacy-modernizer}/references/migration-strategies.md +0 -0
- /package/skills/{jarvis/legacy-modernizer → legacy-modernizer}/references/refactoring-patterns.md +0 -0
- /package/skills/{jarvis/legacy-modernizer → legacy-modernizer}/references/strangler-fig-pattern.md +0 -0
- /package/skills/{jarvis/legacy-modernizer → legacy-modernizer}/references/system-assessment.md +0 -0
- /package/skills/{jarvis/mcp-developer → mcp-developer}/SKILL.md +0 -0
- /package/skills/{jarvis/mcp-developer → mcp-developer}/references/protocol.md +0 -0
- /package/skills/{jarvis/mcp-developer → mcp-developer}/references/python-sdk.md +0 -0
- /package/skills/{jarvis/mcp-developer → mcp-developer}/references/resources.md +0 -0
- /package/skills/{jarvis/mcp-developer → mcp-developer}/references/tools.md +0 -0
- /package/skills/{jarvis/mcp-developer → mcp-developer}/references/typescript-sdk.md +0 -0
- /package/skills/{max/meeting-notes → meeting-notes}/SKILL.md +0 -0
- /package/skills/{jarvis/microservices-architect → microservices-architect}/SKILL.md +0 -0
- /package/skills/{jarvis/microservices-architect → microservices-architect}/references/communication.md +0 -0
- /package/skills/{jarvis/microservices-architect → microservices-architect}/references/data.md +0 -0
- /package/skills/{jarvis/microservices-architect → microservices-architect}/references/decomposition.md +0 -0
- /package/skills/{jarvis/microservices-architect → microservices-architect}/references/observability.md +0 -0
- /package/skills/{jarvis/microservices-architect → microservices-architect}/references/patterns.md +0 -0
- /package/skills/{jarvis/ml-pipeline → ml-pipeline}/SKILL.md +0 -0
- /package/skills/{jarvis/ml-pipeline → ml-pipeline}/references/experiment-tracking.md +0 -0
- /package/skills/{jarvis/ml-pipeline → ml-pipeline}/references/feature-engineering.md +0 -0
- /package/skills/{jarvis/ml-pipeline → ml-pipeline}/references/model-validation.md +0 -0
- /package/skills/{jarvis/ml-pipeline → ml-pipeline}/references/pipeline-orchestration.md +0 -0
- /package/skills/{jarvis/ml-pipeline → ml-pipeline}/references/training-pipelines.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/SKILL.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/references/alerting-rules.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/references/application-profiling.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/references/capacity-planning.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/references/dashboards.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/references/opentelemetry.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/references/performance-testing.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/references/prometheus-metrics.md +0 -0
- /package/skills/{jarvis/monitoring-expert → monitoring-expert}/references/structured-logging.md +0 -0
- /package/skills/{jarvis/nestjs-expert → nestjs-expert}/SKILL.md +0 -0
- /package/skills/{jarvis/nestjs-expert → nestjs-expert}/references/authentication.md +0 -0
- /package/skills/{jarvis/nestjs-expert → nestjs-expert}/references/controllers-routing.md +0 -0
- /package/skills/{jarvis/nestjs-expert → nestjs-expert}/references/dtos-validation.md +0 -0
- /package/skills/{jarvis/nestjs-expert → nestjs-expert}/references/migration-from-express.md +0 -0
- /package/skills/{jarvis/nestjs-expert → nestjs-expert}/references/services-di.md +0 -0
- /package/skills/{jarvis/nestjs-expert → nestjs-expert}/references/testing-patterns.md +0 -0
- /package/skills/{ella/nextjs-developer → nextjs-developer}/SKILL.md +0 -0
- /package/skills/{ella/nextjs-developer → nextjs-developer}/references/app-router.md +0 -0
- /package/skills/{ella/nextjs-developer → nextjs-developer}/references/data-fetching.md +0 -0
- /package/skills/{ella/nextjs-developer → nextjs-developer}/references/deployment.md +0 -0
- /package/skills/{ella/nextjs-developer → nextjs-developer}/references/server-actions.md +0 -0
- /package/skills/{ella/nextjs-developer → nextjs-developer}/references/server-components.md +0 -0
- /package/skills/{jarvis/pandas-pro → pandas-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/pandas-pro → pandas-pro}/references/aggregation-groupby.md +0 -0
- /package/skills/{jarvis/pandas-pro → pandas-pro}/references/data-cleaning.md +0 -0
- /package/skills/{jarvis/pandas-pro → pandas-pro}/references/dataframe-operations.md +0 -0
- /package/skills/{jarvis/pandas-pro → pandas-pro}/references/merging-joining.md +0 -0
- /package/skills/{jarvis/pandas-pro → pandas-pro}/references/performance-optimization.md +0 -0
- /package/skills/{jarvis/php-pro → php-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/php-pro → php-pro}/references/async-patterns.md +0 -0
- /package/skills/{jarvis/php-pro → php-pro}/references/laravel-patterns.md +0 -0
- /package/skills/{jarvis/php-pro → php-pro}/references/modern-php-features.md +0 -0
- /package/skills/{jarvis/php-pro → php-pro}/references/symfony-patterns.md +0 -0
- /package/skills/{jarvis/php-pro → php-pro}/references/testing-quality.md +0 -0
- /package/skills/{kyle/playwright-expert → playwright-expert}/SKILL.md +0 -0
- /package/skills/{kyle/playwright-expert → playwright-expert}/references/api-mocking.md +0 -0
- /package/skills/{kyle/playwright-expert → playwright-expert}/references/configuration.md +0 -0
- /package/skills/{kyle/playwright-expert → playwright-expert}/references/debugging-flaky.md +0 -0
- /package/skills/{kyle/playwright-expert → playwright-expert}/references/page-object-model.md +0 -0
- /package/skills/{kyle/playwright-expert → playwright-expert}/references/selectors-locators.md +0 -0
- /package/skills/{jarvis/postgres-pro → postgres-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/postgres-pro → postgres-pro}/references/extensions.md +0 -0
- /package/skills/{jarvis/postgres-pro → postgres-pro}/references/jsonb.md +0 -0
- /package/skills/{jarvis/postgres-pro → postgres-pro}/references/maintenance.md +0 -0
- /package/skills/{jarvis/postgres-pro → postgres-pro}/references/performance.md +0 -0
- /package/skills/{jarvis/postgres-pro → postgres-pro}/references/replication.md +0 -0
- /package/skills/{max/prd-template → prd-template}/SKILL.md +0 -0
- /package/skills/{jarvis/python-pro → python-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/python-pro → python-pro}/references/async-patterns.md +0 -0
- /package/skills/{jarvis/python-pro → python-pro}/references/packaging.md +0 -0
- /package/skills/{jarvis/python-pro → python-pro}/references/standard-library.md +0 -0
- /package/skills/{jarvis/python-pro → python-pro}/references/testing.md +0 -0
- /package/skills/{jarvis/python-pro → python-pro}/references/type-system.md +0 -0
- /package/skills/{jarvis/rag-architect → rag-architect}/SKILL.md +0 -0
- /package/skills/{jarvis/rag-architect → rag-architect}/references/chunking-strategies.md +0 -0
- /package/skills/{jarvis/rag-architect → rag-architect}/references/embedding-models.md +0 -0
- /package/skills/{jarvis/rag-architect → rag-architect}/references/rag-evaluation.md +0 -0
- /package/skills/{jarvis/rag-architect → rag-architect}/references/retrieval-optimization.md +0 -0
- /package/skills/{jarvis/rag-architect → rag-architect}/references/vector-databases.md +0 -0
- /package/skills/{jarvis/rails-expert → rails-expert}/SKILL.md +0 -0
- /package/skills/{jarvis/rails-expert → rails-expert}/references/active-record.md +0 -0
- /package/skills/{jarvis/rails-expert → rails-expert}/references/api-development.md +0 -0
- /package/skills/{jarvis/rails-expert → rails-expert}/references/background-jobs.md +0 -0
- /package/skills/{jarvis/rails-expert → rails-expert}/references/hotwire-turbo.md +0 -0
- /package/skills/{jarvis/rails-expert → rails-expert}/references/rspec-testing.md +0 -0
- /package/skills/{ella/react-expert → react-expert}/SKILL.md +0 -0
- /package/skills/{ella/react-expert → react-expert}/references/hooks-patterns.md +0 -0
- /package/skills/{ella/react-expert → react-expert}/references/migration-class-to-modern.md +0 -0
- /package/skills/{ella/react-expert → react-expert}/references/performance.md +0 -0
- /package/skills/{ella/react-expert → react-expert}/references/react-19-features.md +0 -0
- /package/skills/{ella/react-expert → react-expert}/references/server-components.md +0 -0
- /package/skills/{ella/react-expert → react-expert}/references/state-management.md +0 -0
- /package/skills/{ella/react-expert → react-expert}/references/testing-react.md +0 -0
- /package/skills/{ella/react-native-expert → react-native-expert}/SKILL.md +0 -0
- /package/skills/{ella/react-native-expert → react-native-expert}/references/expo-router.md +0 -0
- /package/skills/{ella/react-native-expert → react-native-expert}/references/list-optimization.md +0 -0
- /package/skills/{ella/react-native-expert → react-native-expert}/references/platform-handling.md +0 -0
- /package/skills/{ella/react-native-expert → react-native-expert}/references/project-structure.md +0 -0
- /package/skills/{ella/react-native-expert → react-native-expert}/references/storage-hooks.md +0 -0
- /package/skills/{jarvis/rust-engineer → rust-engineer}/SKILL.md +0 -0
- /package/skills/{jarvis/rust-engineer → rust-engineer}/references/async.md +0 -0
- /package/skills/{jarvis/rust-engineer → rust-engineer}/references/error-handling.md +0 -0
- /package/skills/{jarvis/rust-engineer → rust-engineer}/references/ownership.md +0 -0
- /package/skills/{jarvis/rust-engineer → rust-engineer}/references/testing.md +0 -0
- /package/skills/{jarvis/rust-engineer → rust-engineer}/references/traits.md +0 -0
- /package/skills/{jarvis/secure-code-guardian → secure-code-guardian}/SKILL.md +0 -0
- /package/skills/{jarvis/secure-code-guardian → secure-code-guardian}/references/authentication.md +0 -0
- /package/skills/{jarvis/secure-code-guardian → secure-code-guardian}/references/input-validation.md +0 -0
- /package/skills/{jarvis/secure-code-guardian → secure-code-guardian}/references/owasp-prevention.md +0 -0
- /package/skills/{jarvis/secure-code-guardian → secure-code-guardian}/references/security-headers.md +0 -0
- /package/skills/{jarvis/secure-code-guardian → secure-code-guardian}/references/xss-csrf.md +0 -0
- /package/skills/{kyle/security-reviewer → security-reviewer}/SKILL.md +0 -0
- /package/skills/{kyle/security-reviewer → security-reviewer}/references/infrastructure-security.md +0 -0
- /package/skills/{kyle/security-reviewer → security-reviewer}/references/penetration-testing.md +0 -0
- /package/skills/{kyle/security-reviewer → security-reviewer}/references/report-template.md +0 -0
- /package/skills/{kyle/security-reviewer → security-reviewer}/references/sast-tools.md +0 -0
- /package/skills/{kyle/security-reviewer → security-reviewer}/references/secret-scanning.md +0 -0
- /package/skills/{kyle/security-reviewer → security-reviewer}/references/vulnerability-patterns.md +0 -0
- /package/skills/{ella/senior-frontend → senior-frontend}/SKILL.md +0 -0
- /package/skills/{ella/senior-frontend → senior-frontend}/references/frontend_best_practices.md +0 -0
- /package/skills/{ella/senior-frontend → senior-frontend}/references/nextjs_optimization_guide.md +0 -0
- /package/skills/{ella/senior-frontend → senior-frontend}/references/react_patterns.md +0 -0
- /package/skills/{ella/senior-frontend → senior-frontend}/scripts/bundle_analyzer.py +0 -0
- /package/skills/{ella/senior-frontend → senior-frontend}/scripts/component_generator.py +0 -0
- /package/skills/{ella/senior-frontend → senior-frontend}/scripts/frontend_scaffolder.py +0 -0
- /package/skills/{kyle/senior-qa → senior-qa}/README.md +0 -0
- /package/skills/{kyle/senior-qa → senior-qa}/SKILL.md +0 -0
- /package/skills/{kyle/senior-qa → senior-qa}/references/qa_best_practices.md +0 -0
- /package/skills/{kyle/senior-qa → senior-qa}/references/test_automation_patterns.md +0 -0
- /package/skills/{kyle/senior-qa → senior-qa}/references/testing_strategies.md +0 -0
- /package/skills/{kyle/senior-qa → senior-qa}/scripts/coverage_analyzer.py +0 -0
- /package/skills/{kyle/senior-qa → senior-qa}/scripts/e2e_test_scaffolder.py +0 -0
- /package/skills/{kyle/senior-qa → senior-qa}/scripts/test_suite_generator.py +0 -0
- /package/skills/{jarvis/spark-engineer → spark-engineer}/SKILL.md +0 -0
- /package/skills/{jarvis/spark-engineer → spark-engineer}/references/partitioning-caching.md +0 -0
- /package/skills/{jarvis/spark-engineer → spark-engineer}/references/performance-tuning.md +0 -0
- /package/skills/{jarvis/spark-engineer → spark-engineer}/references/rdd-operations.md +0 -0
- /package/skills/{jarvis/spark-engineer → spark-engineer}/references/spark-sql-dataframes.md +0 -0
- /package/skills/{jarvis/spark-engineer → spark-engineer}/references/streaming-patterns.md +0 -0
- /package/skills/{jarvis/spring-boot-engineer → spring-boot-engineer}/SKILL.md +0 -0
- /package/skills/{jarvis/spring-boot-engineer → spring-boot-engineer}/references/cloud.md +0 -0
- /package/skills/{jarvis/spring-boot-engineer → spring-boot-engineer}/references/data.md +0 -0
- /package/skills/{jarvis/spring-boot-engineer → spring-boot-engineer}/references/security.md +0 -0
- /package/skills/{jarvis/spring-boot-engineer → spring-boot-engineer}/references/testing.md +0 -0
- /package/skills/{jarvis/spring-boot-engineer → spring-boot-engineer}/references/web.md +0 -0
- /package/skills/{jarvis/sql-pro → sql-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/sql-pro → sql-pro}/references/database-design.md +0 -0
- /package/skills/{jarvis/sql-pro → sql-pro}/references/dialect-differences.md +0 -0
- /package/skills/{jarvis/sql-pro → sql-pro}/references/optimization.md +0 -0
- /package/skills/{jarvis/sql-pro → sql-pro}/references/query-patterns.md +0 -0
- /package/skills/{jarvis/sql-pro → sql-pro}/references/window-functions.md +0 -0
- /package/skills/{jarvis/sre-engineer → sre-engineer}/SKILL.md +0 -0
- /package/skills/{jarvis/sre-engineer → sre-engineer}/references/automation-toil.md +0 -0
- /package/skills/{jarvis/sre-engineer → sre-engineer}/references/error-budget-policy.md +0 -0
- /package/skills/{jarvis/sre-engineer → sre-engineer}/references/incident-chaos.md +0 -0
- /package/skills/{jarvis/sre-engineer → sre-engineer}/references/monitoring-alerting.md +0 -0
- /package/skills/{jarvis/sre-engineer → sre-engineer}/references/slo-sli-management.md +0 -0
- /package/skills/{max/stakeholder-update → stakeholder-update}/SKILL.md +0 -0
- /package/skills/{jarvis/swift-expert → swift-expert}/SKILL.md +0 -0
- /package/skills/{jarvis/swift-expert → swift-expert}/references/async-concurrency.md +0 -0
- /package/skills/{jarvis/swift-expert → swift-expert}/references/memory-performance.md +0 -0
- /package/skills/{jarvis/swift-expert → swift-expert}/references/protocol-oriented.md +0 -0
- /package/skills/{jarvis/swift-expert → swift-expert}/references/swiftui-patterns.md +0 -0
- /package/skills/{jarvis/swift-expert → swift-expert}/references/testing-patterns.md +0 -0
- /package/skills/{max/workflow/systematic-debugging → systematic-debugging}/SKILL.md +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/HOW_TO_USE.md +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/README.md +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/SKILL.md +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/assets/expected_output.json +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/assets/sample_coverage_report.lcov +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/assets/sample_input_python.json +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/assets/sample_input_typescript.json +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/references/ci-integration.md +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/references/framework-guide.md +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/references/tdd-best-practices.md +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/scripts/coverage_analyzer.py +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/scripts/fixture_generator.py +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/scripts/format_detector.py +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/scripts/framework_adapter.py +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/scripts/metrics_calculator.py +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/scripts/output_formatter.py +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/scripts/tdd_workflow.py +0 -0
- /package/skills/{kyle/tdd-guide → tdd-guide}/scripts/test_generator.py +0 -0
- /package/skills/{jarvis/terraform-engineer → terraform-engineer}/SKILL.md +0 -0
- /package/skills/{jarvis/terraform-engineer → terraform-engineer}/references/best-practices.md +0 -0
- /package/skills/{jarvis/terraform-engineer → terraform-engineer}/references/module-patterns.md +0 -0
- /package/skills/{jarvis/terraform-engineer → terraform-engineer}/references/providers.md +0 -0
- /package/skills/{jarvis/terraform-engineer → terraform-engineer}/references/state-management.md +0 -0
- /package/skills/{jarvis/terraform-engineer → terraform-engineer}/references/testing.md +0 -0
- /package/skills/{kyle/test-master → test-master}/SKILL.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/automation-frameworks.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/e2e-testing.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/integration-testing.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/performance-testing.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/qa-methodology.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/security-testing.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/tdd-iron-laws.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/test-reports.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/testing-anti-patterns.md +0 -0
- /package/skills/{kyle/test-master → test-master}/references/unit-testing.md +0 -0
- /package/skills/{jarvis/typescript-pro → typescript-pro}/SKILL.md +0 -0
- /package/skills/{jarvis/typescript-pro → typescript-pro}/references/advanced-types.md +0 -0
- /package/skills/{jarvis/typescript-pro → typescript-pro}/references/configuration.md +0 -0
- /package/skills/{jarvis/typescript-pro → typescript-pro}/references/patterns.md +0 -0
- /package/skills/{jarvis/typescript-pro → typescript-pro}/references/type-guards.md +0 -0
- /package/skills/{jarvis/typescript-pro → typescript-pro}/references/utility-types.md +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/SKILL.md +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/charts.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/colors.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/icons.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/landing.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/products.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/react-performance.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/astro.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/flutter.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/html-tailwind.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/jetpack-compose.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/nextjs.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/nuxt-ui.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/nuxtjs.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/react-native.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/react.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/shadcn.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/svelte.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/swiftui.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/stacks/vue.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/styles.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/typography.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/ui-reasoning.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/ux-guidelines.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/data/web-interface.csv +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/scripts/__pycache__/core.cpython-39.pyc +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/scripts/__pycache__/design_system.cpython-39.pyc +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/scripts/core.py +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/scripts/design_system.py +0 -0
- /package/skills/{ella/ui-ux-pro-max → ui-ux-pro-max}/scripts/search.py +0 -0
- /package/skills/{max/user-research-synthesis → user-research-synthesis}/SKILL.md +0 -0
- /package/skills/{max/workflow/verification-before-completion → verification-before-completion}/SKILL.md +0 -0
- /package/skills/{ella/vue-expert → vue-expert}/SKILL.md +0 -0
- /package/skills/{ella/vue-expert → vue-expert}/references/build-tooling.md +0 -0
- /package/skills/{ella/vue-expert → vue-expert}/references/components.md +0 -0
- /package/skills/{ella/vue-expert → vue-expert}/references/composition-api.md +0 -0
- /package/skills/{ella/vue-expert → vue-expert}/references/mobile-hybrid.md +0 -0
- /package/skills/{ella/vue-expert → vue-expert}/references/nuxt.md +0 -0
- /package/skills/{ella/vue-expert → vue-expert}/references/state-management.md +0 -0
- /package/skills/{ella/vue-expert → vue-expert}/references/typescript.md +0 -0
- /package/skills/{ella/vue-expert-js → vue-expert-js}/SKILL.md +0 -0
- /package/skills/{ella/vue-expert-js → vue-expert-js}/references/component-architecture.md +0 -0
- /package/skills/{ella/vue-expert-js → vue-expert-js}/references/composables-patterns.md +0 -0
- /package/skills/{ella/vue-expert-js → vue-expert-js}/references/jsdoc-typing.md +0 -0
- /package/skills/{ella/vue-expert-js → vue-expert-js}/references/state-management.md +0 -0
- /package/skills/{ella/vue-expert-js → vue-expert-js}/references/testing-patterns.md +0 -0
- /package/skills/{jarvis/websocket-engineer → websocket-engineer}/SKILL.md +0 -0
- /package/skills/{jarvis/websocket-engineer → websocket-engineer}/references/alternatives.md +0 -0
- /package/skills/{jarvis/websocket-engineer → websocket-engineer}/references/patterns.md +0 -0
- /package/skills/{jarvis/websocket-engineer → websocket-engineer}/references/protocol.md +0 -0
- /package/skills/{jarvis/websocket-engineer → websocket-engineer}/references/scaling.md +0 -0
- /package/skills/{jarvis/websocket-engineer → websocket-engineer}/references/security.md +0 -0
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const fs = require('fs');
|
|
4
|
+
const path = require('path');
|
|
5
|
+
const { createReport, ROOT, relPosix } = require('../lib/runner.cjs');
|
|
6
|
+
|
|
7
|
+
const MIN_BYTES = 50;
|
|
8
|
+
|
|
9
|
+
function run() {
|
|
10
|
+
const report = createReport();
|
|
11
|
+
const docsDir = path.join(ROOT, 'docs');
|
|
12
|
+
let entries;
|
|
13
|
+
try {
|
|
14
|
+
entries = fs.readdirSync(docsDir, { withFileTypes: true });
|
|
15
|
+
} catch (_error) {
|
|
16
|
+
return report;
|
|
17
|
+
}
|
|
18
|
+
for (const entry of entries) {
|
|
19
|
+
if (!entry.isFile() || !entry.name.endsWith('.md')) continue;
|
|
20
|
+
const full = path.join(docsDir, entry.name);
|
|
21
|
+
const size = fs.statSync(full).size;
|
|
22
|
+
if (size < MIN_BYTES) {
|
|
23
|
+
report.fail(
|
|
24
|
+
`${relPosix(full)} 内容过少(${size} bytes)`,
|
|
25
|
+
'文档不应为空壳,请补充实质内容或删除'
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return report;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
module.exports = { run, section: 'docs 空壳检查' };
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const fs = require('fs');
|
|
4
|
+
const path = require('path');
|
|
5
|
+
const { createReport, ROOT, relPosix, dirExists } = require('../lib/runner.cjs');
|
|
6
|
+
|
|
7
|
+
const COORD_ROOT = path.join(ROOT, '.orchestration');
|
|
8
|
+
const STAGE1_RE = /(stage.?1|阶段.?1|规格符合)/i;
|
|
9
|
+
const STAGE2_RE = /(stage.?2|阶段.?2|代码质量)/i;
|
|
10
|
+
|
|
11
|
+
function run() {
|
|
12
|
+
const report = createReport();
|
|
13
|
+
if (!dirExists('.orchestration')) return report;
|
|
14
|
+
|
|
15
|
+
const sessions = fs.readdirSync(COORD_ROOT, { withFileTypes: true })
|
|
16
|
+
.filter(entry => entry.isDirectory() && !entry.name.startsWith('.'));
|
|
17
|
+
|
|
18
|
+
for (const session of sessions) {
|
|
19
|
+
const sessionDir = path.join(COORD_ROOT, session.name);
|
|
20
|
+
const workers = fs.readdirSync(sessionDir, { withFileTypes: true })
|
|
21
|
+
.filter(entry => entry.isDirectory());
|
|
22
|
+
|
|
23
|
+
for (const worker of workers) {
|
|
24
|
+
const workerDir = path.join(sessionDir, worker.name);
|
|
25
|
+
const statusFile = path.join(workerDir, 'status.md');
|
|
26
|
+
|
|
27
|
+
// 轻量 worker:只要求 handoff + status,跳过 task.md
|
|
28
|
+
let lightweight = false;
|
|
29
|
+
try {
|
|
30
|
+
const raw = fs.readFileSync(statusFile, 'utf8');
|
|
31
|
+
lightweight = /^\s*-\s*Lightweight:\s*true/m.test(raw);
|
|
32
|
+
} catch (_error) { /* fall through */ }
|
|
33
|
+
|
|
34
|
+
const required = lightweight
|
|
35
|
+
? ['handoff.md', 'status.md']
|
|
36
|
+
: ['task.md', 'handoff.md', 'status.md'];
|
|
37
|
+
|
|
38
|
+
for (const file of required) {
|
|
39
|
+
const full = path.join(workerDir, file);
|
|
40
|
+
if (!fs.existsSync(full)) {
|
|
41
|
+
report.fail(
|
|
42
|
+
`${relPosix(workerDir)}/ 缺失 ${file}${lightweight ? '(轻量 worker)' : ''}`,
|
|
43
|
+
'用 node scripts/orchestration/session.cjs add-worker 创建(轻量加 --lightweight)'
|
|
44
|
+
);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
if (worker.name === 'code-reviewer') {
|
|
49
|
+
const handoff = path.join(workerDir, 'handoff.md');
|
|
50
|
+
if (fs.existsSync(handoff)) {
|
|
51
|
+
const content = fs.readFileSync(handoff, 'utf8');
|
|
52
|
+
if (!STAGE1_RE.test(content) && !STAGE2_RE.test(content)) {
|
|
53
|
+
report.fail(
|
|
54
|
+
`${relPosix(handoff)} 缺少阶段标识`,
|
|
55
|
+
'审查报告必须含 Stage 1 (规格符合性) 和 Stage 2 (代码质量)'
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return report;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
module.exports = { run, section: 'Orchestration 产物检查' };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const { createReport, dirExists } = require('../lib/runner.cjs');
|
|
4
|
+
|
|
5
|
+
const REQUIRED_DIRS = [
|
|
6
|
+
{ path: '.orchestration', hint: 'mkdir -p .orchestration' },
|
|
7
|
+
{ path: '.orchestration/.logs', hint: 'mkdir -p .orchestration/.logs' },
|
|
8
|
+
{ path: '.claude/agents', hint: 'agent 定义根' },
|
|
9
|
+
{ path: 'skills', hint: 'skill 根(扁平结构)' },
|
|
10
|
+
{ path: 'docs/rules', hint: '强制规则集' }
|
|
11
|
+
];
|
|
12
|
+
|
|
13
|
+
function run() {
|
|
14
|
+
const report = createReport();
|
|
15
|
+
for (const entry of REQUIRED_DIRS) {
|
|
16
|
+
if (!dirExists(entry.path)) {
|
|
17
|
+
report.fail(`缺失目录 ${entry.path}/`, entry.hint);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return report;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
module.exports = { run, section: '基础结构检查' };
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const fs = require('fs');
|
|
4
|
+
const path = require('path');
|
|
5
|
+
const { createReport, ROOT, relPosix, dirExists } = require('../lib/runner.cjs');
|
|
6
|
+
|
|
7
|
+
// 真相源:.orchestration/<session>/<worker>/status.md
|
|
8
|
+
// 在 Stop 事件中:若任一 worker state=running,说明主会话要停但 worker 没走到终态。
|
|
9
|
+
// 终态:completed | failed | blocked (完成、失败、主动阻塞都允许 Stop)
|
|
10
|
+
|
|
11
|
+
const TERMINAL_STATES = new Set(['completed', 'failed', 'blocked']);
|
|
12
|
+
|
|
13
|
+
function readState(statusFile) {
|
|
14
|
+
try {
|
|
15
|
+
const content = fs.readFileSync(statusFile, 'utf8');
|
|
16
|
+
const match = content.match(/^\s*-\s*State:\s*(\S+)/m);
|
|
17
|
+
return match ? match[1].toLowerCase() : null;
|
|
18
|
+
} catch (_error) {
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
function run() {
|
|
24
|
+
const report = createReport();
|
|
25
|
+
if (!dirExists('.orchestration')) return report;
|
|
26
|
+
|
|
27
|
+
const coordRoot = path.join(ROOT, '.orchestration');
|
|
28
|
+
const sessions = fs.readdirSync(coordRoot, { withFileTypes: true })
|
|
29
|
+
.filter(entry => entry.isDirectory() && !entry.name.startsWith('.'));
|
|
30
|
+
|
|
31
|
+
const stuck = [];
|
|
32
|
+
for (const session of sessions) {
|
|
33
|
+
const sessionDir = path.join(coordRoot, session.name);
|
|
34
|
+
const workers = fs.readdirSync(sessionDir, { withFileTypes: true })
|
|
35
|
+
.filter(entry => entry.isDirectory());
|
|
36
|
+
|
|
37
|
+
for (const worker of workers) {
|
|
38
|
+
const statusFile = path.join(sessionDir, worker.name, 'status.md');
|
|
39
|
+
const state = readState(statusFile);
|
|
40
|
+
if (state === 'running') {
|
|
41
|
+
stuck.push(relPosix(statusFile));
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
if (stuck.length > 0) {
|
|
47
|
+
report.fail(
|
|
48
|
+
`以下 worker 仍在 running:${stuck.join(', ')}`,
|
|
49
|
+
'完成 worker 后运行 `node scripts/orchestration/session.cjs set-status <session> <worker> completed`;主动放弃用 `failed` 或 `blocked`'
|
|
50
|
+
);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
return report;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
module.exports = { run, section: '工作流 worker 状态检查' };
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
// Hook dispatcher —— 按事件类型路由到对应 checks。
|
|
5
|
+
// 每个 check 模块必须导出 { run(): Report, section: string }。
|
|
6
|
+
// 任一 FAIL → exit 2(错误回注 Claude 上下文);仅 WARN → exit 0。
|
|
7
|
+
|
|
8
|
+
const { readJsonStdinSync } = require('./lib/runner.cjs');
|
|
9
|
+
|
|
10
|
+
const DISPATCH = {
|
|
11
|
+
'post-edit': [
|
|
12
|
+
require('./checks/claude-md-size.cjs'),
|
|
13
|
+
require('./checks/empty-docs.cjs')
|
|
14
|
+
],
|
|
15
|
+
stop: [
|
|
16
|
+
require('./checks/structure.cjs'),
|
|
17
|
+
require('./checks/claude-md-size.cjs'),
|
|
18
|
+
require('./checks/empty-docs.cjs'),
|
|
19
|
+
require('./checks/delegation-antipatterns.cjs'),
|
|
20
|
+
require('./checks/workflow-state.cjs'),
|
|
21
|
+
require('./checks/orchestration-artifacts.cjs')
|
|
22
|
+
],
|
|
23
|
+
'subagent-stop': [
|
|
24
|
+
require('./checks/structure.cjs'),
|
|
25
|
+
require('./checks/orchestration-artifacts.cjs')
|
|
26
|
+
]
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
function main() {
|
|
30
|
+
const [, , event] = process.argv;
|
|
31
|
+
const checks = DISPATCH[event];
|
|
32
|
+
if (!checks) {
|
|
33
|
+
console.error(`unknown event: ${event}`);
|
|
34
|
+
process.exit(1);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
readJsonStdinSync();
|
|
38
|
+
|
|
39
|
+
const sections = [];
|
|
40
|
+
let hasFail = false;
|
|
41
|
+
for (const check of checks) {
|
|
42
|
+
const report = check.run();
|
|
43
|
+
if (!report.hasAny()) continue;
|
|
44
|
+
sections.push(report.render(check.section));
|
|
45
|
+
if (report.hasFail()) hasFail = true;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
if (sections.length === 0) process.exit(0);
|
|
49
|
+
|
|
50
|
+
const output = sections.join('\n\n');
|
|
51
|
+
if (hasFail) {
|
|
52
|
+
console.error('Harness 检测到问题:');
|
|
53
|
+
console.error('');
|
|
54
|
+
console.error(output);
|
|
55
|
+
console.error('');
|
|
56
|
+
console.error('修复上述 [FAIL] 项后重试。');
|
|
57
|
+
process.exit(2);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
console.log(output);
|
|
61
|
+
process.exit(0);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
main();
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const fs = require('fs');
|
|
4
|
+
const path = require('path');
|
|
5
|
+
|
|
6
|
+
const ROOT = path.resolve(__dirname, '..', '..', '..');
|
|
7
|
+
|
|
8
|
+
function readJsonStdinSync() {
|
|
9
|
+
try {
|
|
10
|
+
const raw = fs.readFileSync(0, 'utf8');
|
|
11
|
+
if (!raw.trim()) return {};
|
|
12
|
+
return JSON.parse(raw);
|
|
13
|
+
} catch (_error) {
|
|
14
|
+
return {};
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function createReport() {
|
|
19
|
+
const issues = [];
|
|
20
|
+
return {
|
|
21
|
+
fail(msg, fix) {
|
|
22
|
+
issues.push({ level: 'FAIL', msg, fix });
|
|
23
|
+
},
|
|
24
|
+
warn(msg, fix) {
|
|
25
|
+
issues.push({ level: 'WARN', msg, fix });
|
|
26
|
+
},
|
|
27
|
+
hasFail() {
|
|
28
|
+
return issues.some(i => i.level === 'FAIL');
|
|
29
|
+
},
|
|
30
|
+
hasAny() {
|
|
31
|
+
return issues.length > 0;
|
|
32
|
+
},
|
|
33
|
+
render(section) {
|
|
34
|
+
if (issues.length === 0) return '';
|
|
35
|
+
const lines = [`--- ${section} ---`];
|
|
36
|
+
for (const i of issues) {
|
|
37
|
+
lines.push(`[${i.level}] ${i.msg}`);
|
|
38
|
+
if (i.fix) lines.push(`[FIX] ${i.fix}`);
|
|
39
|
+
}
|
|
40
|
+
return lines.join('\n');
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function relPosix(p) {
|
|
46
|
+
return path.relative(ROOT, p).split(path.sep).join('/');
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
function fileExists(p) {
|
|
50
|
+
try {
|
|
51
|
+
return fs.statSync(path.resolve(ROOT, p)).isFile();
|
|
52
|
+
} catch (_error) {
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
function dirExists(p) {
|
|
58
|
+
try {
|
|
59
|
+
return fs.statSync(path.resolve(ROOT, p)).isDirectory();
|
|
60
|
+
} catch (_error) {
|
|
61
|
+
return false;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
function readFileSafe(p) {
|
|
66
|
+
try {
|
|
67
|
+
return fs.readFileSync(path.resolve(ROOT, p), 'utf8');
|
|
68
|
+
} catch (_error) {
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
module.exports = {
|
|
74
|
+
ROOT,
|
|
75
|
+
readJsonStdinSync,
|
|
76
|
+
createReport,
|
|
77
|
+
relPosix,
|
|
78
|
+
fileExists,
|
|
79
|
+
dirExists,
|
|
80
|
+
readFileSafe
|
|
81
|
+
};
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const fs = require('fs');
|
|
4
|
+
const path = require('path');
|
|
5
|
+
|
|
6
|
+
const ROOT = path.resolve(__dirname, '..', '..', '..');
|
|
7
|
+
const COORDINATION_ROOT = path.join(ROOT, '.orchestration');
|
|
8
|
+
|
|
9
|
+
function toPosix(p) {
|
|
10
|
+
return p.split(path.sep).join('/');
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
function relPosix(target) {
|
|
14
|
+
return toPosix(path.relative(ROOT, target));
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
function slugify(value, fallback = 'item') {
|
|
18
|
+
const normalized = String(value || '')
|
|
19
|
+
.trim()
|
|
20
|
+
.toLowerCase()
|
|
21
|
+
.replace(/[^a-z0-9]+/g, '-')
|
|
22
|
+
.replace(/^-+|-+$/g, '');
|
|
23
|
+
return normalized || fallback;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
function timestamp() {
|
|
27
|
+
return new Date().toISOString().replace(/\.\d+Z$/, 'Z');
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
function sessionDir(sessionName) {
|
|
31
|
+
const slug = slugify(sessionName, 'session');
|
|
32
|
+
return path.join(COORDINATION_ROOT, slug);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
function workerDir(sessionName, workerName) {
|
|
36
|
+
return path.join(sessionDir(sessionName), slugify(workerName, 'worker'));
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function workerArtifacts(sessionName, workerName) {
|
|
40
|
+
const dir = workerDir(sessionName, workerName);
|
|
41
|
+
return {
|
|
42
|
+
dir,
|
|
43
|
+
task: path.join(dir, 'task.md'),
|
|
44
|
+
handoff: path.join(dir, 'handoff.md'),
|
|
45
|
+
status: path.join(dir, 'status.md')
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
function ensureDir(dirPath) {
|
|
50
|
+
fs.mkdirSync(dirPath, { recursive: true });
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
function writeFile(filePath, content) {
|
|
54
|
+
ensureDir(path.dirname(filePath));
|
|
55
|
+
fs.writeFileSync(filePath, content.endsWith('\n') ? content : content + '\n', 'utf8');
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
function buildTaskFile({ sessionName, workerName, agent, objective, context = [], deliverables = [] }) {
|
|
59
|
+
const ctx = context.length > 0 ? context.map(line => `- ${line}`).join('\n') : '- _无_';
|
|
60
|
+
const deliv = deliverables.length > 0 ? deliverables.map(line => `- ${line}`).join('\n') : '- 见 handoff.md 模板';
|
|
61
|
+
const artifacts = workerArtifacts(sessionName, workerName);
|
|
62
|
+
return [
|
|
63
|
+
`# Worker Task: ${workerName}`,
|
|
64
|
+
'',
|
|
65
|
+
`- Session: \`${sessionName}\``,
|
|
66
|
+
`- Agent: \`${agent}\``,
|
|
67
|
+
`- Created: ${timestamp()}`,
|
|
68
|
+
`- Handoff: \`${relPosix(artifacts.handoff)}\``,
|
|
69
|
+
`- Status: \`${relPosix(artifacts.status)}\``,
|
|
70
|
+
'',
|
|
71
|
+
'## Objective',
|
|
72
|
+
objective.trim(),
|
|
73
|
+
'',
|
|
74
|
+
'## Context',
|
|
75
|
+
ctx,
|
|
76
|
+
'',
|
|
77
|
+
'## Deliverables',
|
|
78
|
+
deliv,
|
|
79
|
+
'',
|
|
80
|
+
'## Completion Rules',
|
|
81
|
+
'- 不再向下派遣 subagent,结果写进最终响应',
|
|
82
|
+
'- 主会话负责把响应抄写进 `handoff.md`',
|
|
83
|
+
'- 主会话负责更新 `status.md`'
|
|
84
|
+
].join('\n');
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
function buildHandoffFile({ workerName }) {
|
|
88
|
+
return [
|
|
89
|
+
`# Handoff: ${workerName}`,
|
|
90
|
+
'',
|
|
91
|
+
'## Summary',
|
|
92
|
+
'- Pending',
|
|
93
|
+
'',
|
|
94
|
+
'## Files Changed',
|
|
95
|
+
'- Pending',
|
|
96
|
+
'',
|
|
97
|
+
'## Validation',
|
|
98
|
+
'- Pending',
|
|
99
|
+
'',
|
|
100
|
+
'## Follow-ups',
|
|
101
|
+
'- Pending'
|
|
102
|
+
].join('\n');
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
function buildStatusFile({ workerName, state = 'not_started', lightweight = false }) {
|
|
106
|
+
const lines = [
|
|
107
|
+
`# Status: ${workerName}`,
|
|
108
|
+
'',
|
|
109
|
+
`- State: ${state}`,
|
|
110
|
+
`- Updated: ${timestamp()}`
|
|
111
|
+
];
|
|
112
|
+
if (lightweight) lines.push('- Lightweight: true');
|
|
113
|
+
return lines.join('\n');
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
function createWorker(spec) {
|
|
117
|
+
const { sessionName, workerName, lightweight = false } = spec;
|
|
118
|
+
if (!sessionName) throw new Error('sessionName is required');
|
|
119
|
+
if (!workerName) throw new Error('workerName is required');
|
|
120
|
+
if (!spec.agent) throw new Error('agent is required');
|
|
121
|
+
if (!spec.objective) throw new Error('objective is required');
|
|
122
|
+
|
|
123
|
+
const artifacts = workerArtifacts(sessionName, workerName);
|
|
124
|
+
ensureDir(artifacts.dir);
|
|
125
|
+
if (!lightweight) {
|
|
126
|
+
writeFile(artifacts.task, buildTaskFile(spec));
|
|
127
|
+
}
|
|
128
|
+
writeFile(artifacts.handoff, buildHandoffFile({ workerName }));
|
|
129
|
+
writeFile(artifacts.status, buildStatusFile({ workerName, lightweight }));
|
|
130
|
+
return { ...artifacts, lightweight };
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
function isLightweight(statusFile) {
|
|
134
|
+
try {
|
|
135
|
+
const raw = fs.readFileSync(statusFile, 'utf8');
|
|
136
|
+
return /^\s*-\s*Lightweight:\s*true/m.test(raw);
|
|
137
|
+
} catch (_error) {
|
|
138
|
+
return false;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
function updateStatus(sessionName, workerName, state, details = '') {
|
|
143
|
+
const artifacts = workerArtifacts(sessionName, workerName);
|
|
144
|
+
const lightweight = isLightweight(artifacts.status);
|
|
145
|
+
const body = [
|
|
146
|
+
`# Status: ${workerName}`,
|
|
147
|
+
'',
|
|
148
|
+
`- State: ${state}`,
|
|
149
|
+
`- Updated: ${timestamp()}`
|
|
150
|
+
];
|
|
151
|
+
if (lightweight) body.push('- Lightweight: true');
|
|
152
|
+
if (details) body.push('', details.trim());
|
|
153
|
+
writeFile(artifacts.status, body.join('\n'));
|
|
154
|
+
return artifacts.status;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
function appendHandoff(sessionName, workerName, sectionTitle, content) {
|
|
158
|
+
const artifacts = workerArtifacts(sessionName, workerName);
|
|
159
|
+
const existing = fs.existsSync(artifacts.handoff)
|
|
160
|
+
? fs.readFileSync(artifacts.handoff, 'utf8')
|
|
161
|
+
: buildHandoffFile({ workerName });
|
|
162
|
+
const block = `\n## ${sectionTitle} (${timestamp()})\n${content.trim()}\n`;
|
|
163
|
+
writeFile(artifacts.handoff, existing.replace(/\s+$/, '') + block);
|
|
164
|
+
return artifacts.handoff;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
module.exports = {
|
|
168
|
+
COORDINATION_ROOT,
|
|
169
|
+
ROOT,
|
|
170
|
+
sessionDir,
|
|
171
|
+
workerDir,
|
|
172
|
+
workerArtifacts,
|
|
173
|
+
createWorker,
|
|
174
|
+
updateStatus,
|
|
175
|
+
appendHandoff,
|
|
176
|
+
isLightweight,
|
|
177
|
+
slugify,
|
|
178
|
+
timestamp,
|
|
179
|
+
relPosix,
|
|
180
|
+
toPosix
|
|
181
|
+
};
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
'use strict';
|
|
3
|
+
|
|
4
|
+
const fs = require('fs');
|
|
5
|
+
const path = require('path');
|
|
6
|
+
const {
|
|
7
|
+
COORDINATION_ROOT,
|
|
8
|
+
ROOT,
|
|
9
|
+
sessionDir,
|
|
10
|
+
workerArtifacts,
|
|
11
|
+
createWorker,
|
|
12
|
+
updateStatus,
|
|
13
|
+
appendHandoff,
|
|
14
|
+
slugify,
|
|
15
|
+
relPosix
|
|
16
|
+
} = require('./lib/orchestrator.cjs');
|
|
17
|
+
|
|
18
|
+
const COMMANDS = ['init', 'add-worker', 'status', 'set-status', 'append', 'list', 'help'];
|
|
19
|
+
|
|
20
|
+
function usage() {
|
|
21
|
+
console.log([
|
|
22
|
+
'Usage:',
|
|
23
|
+
' node scripts/orchestration/session.js init <session-name>',
|
|
24
|
+
' node scripts/orchestration/session.cjs add-worker <session> <worker> --agent <name> --objective <text>',
|
|
25
|
+
' [--context <line>]... [--deliverable <line>]... [--lightweight]',
|
|
26
|
+
' node scripts/orchestration/session.js set-status <session> <worker> <state> [--details <text>]',
|
|
27
|
+
' node scripts/orchestration/session.js append <session> <worker> <section> --content <text>',
|
|
28
|
+
' node scripts/orchestration/session.js status <session>',
|
|
29
|
+
' node scripts/orchestration/session.js list',
|
|
30
|
+
'',
|
|
31
|
+
'States: not_started | running | blocked | completed | failed',
|
|
32
|
+
`Coordination root: ${relPosix(COORDINATION_ROOT)}/`
|
|
33
|
+
].join('\n'));
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const BOOLEAN_FLAGS = new Set(['lightweight']);
|
|
37
|
+
|
|
38
|
+
function parseFlags(args) {
|
|
39
|
+
const flags = { context: [], deliverable: [] };
|
|
40
|
+
const positional = [];
|
|
41
|
+
for (let i = 0; i < args.length; i += 1) {
|
|
42
|
+
const arg = args[i];
|
|
43
|
+
if (arg.startsWith('--')) {
|
|
44
|
+
const key = arg.slice(2);
|
|
45
|
+
if (BOOLEAN_FLAGS.has(key)) {
|
|
46
|
+
flags[key] = true;
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
const value = args[i + 1];
|
|
50
|
+
if (key === 'context' || key === 'deliverable') {
|
|
51
|
+
flags[key].push(value);
|
|
52
|
+
} else {
|
|
53
|
+
flags[key] = value;
|
|
54
|
+
}
|
|
55
|
+
i += 1;
|
|
56
|
+
} else {
|
|
57
|
+
positional.push(arg);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return { flags, positional };
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
function cmdInit(name) {
|
|
64
|
+
if (!name) throw new Error('session-name is required');
|
|
65
|
+
const dir = sessionDir(name);
|
|
66
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
67
|
+
const meta = path.join(dir, 'session.json');
|
|
68
|
+
if (!fs.existsSync(meta)) {
|
|
69
|
+
fs.writeFileSync(meta, JSON.stringify({
|
|
70
|
+
name: slugify(name, 'session'),
|
|
71
|
+
label: name,
|
|
72
|
+
createdAt: new Date().toISOString()
|
|
73
|
+
}, null, 2) + '\n', 'utf8');
|
|
74
|
+
}
|
|
75
|
+
console.log(relPosix(dir));
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
function cmdAddWorker(session, worker, flags) {
|
|
79
|
+
if (!session || !worker) throw new Error('session and worker names are required');
|
|
80
|
+
if (!flags.agent) throw new Error('--agent is required');
|
|
81
|
+
if (!flags.objective) throw new Error('--objective is required');
|
|
82
|
+
const artifacts = createWorker({
|
|
83
|
+
sessionName: session,
|
|
84
|
+
workerName: worker,
|
|
85
|
+
agent: flags.agent,
|
|
86
|
+
objective: flags.objective,
|
|
87
|
+
context: flags.context,
|
|
88
|
+
deliverables: flags.deliverable,
|
|
89
|
+
lightweight: Boolean(flags.lightweight)
|
|
90
|
+
});
|
|
91
|
+
const out = {
|
|
92
|
+
handoff: relPosix(artifacts.handoff),
|
|
93
|
+
status: relPosix(artifacts.status)
|
|
94
|
+
};
|
|
95
|
+
if (!artifacts.lightweight) out.task = relPosix(artifacts.task);
|
|
96
|
+
if (artifacts.lightweight) out.lightweight = true;
|
|
97
|
+
console.log(JSON.stringify(out, null, 2));
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
function cmdSetStatus(session, worker, state, flags) {
|
|
101
|
+
if (!session || !worker || !state) throw new Error('session, worker, state are required');
|
|
102
|
+
const file = updateStatus(session, worker, state, flags.details || '');
|
|
103
|
+
console.log(relPosix(file));
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
function cmdAppend(session, worker, section, flags) {
|
|
107
|
+
if (!session || !worker || !section) throw new Error('session, worker, section are required');
|
|
108
|
+
if (!flags.content) throw new Error('--content is required');
|
|
109
|
+
const file = appendHandoff(session, worker, section, flags.content);
|
|
110
|
+
console.log(relPosix(file));
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
function cmdStatus(session) {
|
|
114
|
+
if (!session) throw new Error('session-name is required');
|
|
115
|
+
const dir = sessionDir(session);
|
|
116
|
+
if (!fs.existsSync(dir)) {
|
|
117
|
+
console.log(`(no such session: ${session})`);
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
const workers = fs.readdirSync(dir, { withFileTypes: true })
|
|
121
|
+
.filter(entry => entry.isDirectory())
|
|
122
|
+
.map(entry => entry.name);
|
|
123
|
+
const out = workers.map(worker => {
|
|
124
|
+
const statusPath = workerArtifacts(session, worker).status;
|
|
125
|
+
const content = fs.existsSync(statusPath) ? fs.readFileSync(statusPath, 'utf8') : '(missing)';
|
|
126
|
+
const stateLine = content.split('\n').find(line => line.startsWith('- State:'));
|
|
127
|
+
return `${worker}\t${stateLine ? stateLine.replace('- State:', '').trim() : '?'}`;
|
|
128
|
+
});
|
|
129
|
+
console.log(out.join('\n') || '(no workers)');
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
function cmdList() {
|
|
133
|
+
if (!fs.existsSync(COORDINATION_ROOT)) {
|
|
134
|
+
console.log('(no sessions)');
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
const sessions = fs.readdirSync(COORDINATION_ROOT, { withFileTypes: true })
|
|
138
|
+
.filter(entry => entry.isDirectory() && !entry.name.startsWith('.'))
|
|
139
|
+
.map(entry => entry.name);
|
|
140
|
+
console.log(sessions.join('\n') || '(no sessions)');
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
function main() {
|
|
144
|
+
const [, , command, ...rest] = process.argv;
|
|
145
|
+
if (!command || command === 'help' || !COMMANDS.includes(command)) {
|
|
146
|
+
usage();
|
|
147
|
+
process.exit(command && command !== 'help' ? 1 : 0);
|
|
148
|
+
}
|
|
149
|
+
const { flags, positional } = parseFlags(rest);
|
|
150
|
+
try {
|
|
151
|
+
switch (command) {
|
|
152
|
+
case 'init':
|
|
153
|
+
cmdInit(positional[0]);
|
|
154
|
+
break;
|
|
155
|
+
case 'add-worker':
|
|
156
|
+
cmdAddWorker(positional[0], positional[1], flags);
|
|
157
|
+
break;
|
|
158
|
+
case 'set-status':
|
|
159
|
+
cmdSetStatus(positional[0], positional[1], positional[2], flags);
|
|
160
|
+
break;
|
|
161
|
+
case 'append':
|
|
162
|
+
cmdAppend(positional[0], positional[1], positional[2], flags);
|
|
163
|
+
break;
|
|
164
|
+
case 'status':
|
|
165
|
+
cmdStatus(positional[0]);
|
|
166
|
+
break;
|
|
167
|
+
case 'list':
|
|
168
|
+
cmdList();
|
|
169
|
+
break;
|
|
170
|
+
default:
|
|
171
|
+
usage();
|
|
172
|
+
process.exit(1);
|
|
173
|
+
}
|
|
174
|
+
} catch (error) {
|
|
175
|
+
console.error(`error: ${error.message}`);
|
|
176
|
+
process.exit(1);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
main();
|