timsquad 3.6.0 → 3.7.1
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/README.ko.md +103 -113
- package/README.md +100 -110
- package/dist/commands/init.js +4 -8
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/{upgrade.d.ts → update.d.ts} +3 -3
- package/dist/commands/update.d.ts.map +1 -0
- package/dist/commands/{upgrade.js → update.js} +12 -17
- package/dist/commands/update.js.map +1 -0
- package/dist/daemon/event-queue.d.ts +3 -11
- package/dist/daemon/event-queue.d.ts.map +1 -1
- package/dist/daemon/event-queue.js +62 -203
- package/dist/daemon/event-queue.js.map +1 -1
- package/dist/daemon/index.d.ts +1 -1
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +15 -14
- package/dist/daemon/index.js.map +1 -1
- package/dist/index.js +3 -43
- package/dist/index.js.map +1 -1
- package/dist/lib/agent-generator.d.ts.map +1 -1
- package/dist/lib/agent-generator.js +10 -10
- package/dist/lib/agent-generator.js.map +1 -1
- package/dist/lib/compile-rules.d.ts.map +1 -1
- package/dist/lib/compile-rules.js +37 -4
- package/dist/lib/compile-rules.js.map +1 -1
- package/dist/lib/compiler.d.ts +1 -0
- package/dist/lib/compiler.d.ts.map +1 -1
- package/dist/lib/compiler.js +67 -11
- package/dist/lib/compiler.js.map +1 -1
- package/dist/{commands/log.d.ts → lib/log-utils.d.ts} +7 -15
- package/dist/lib/log-utils.d.ts.map +1 -0
- package/dist/lib/log-utils.js +347 -0
- package/dist/lib/log-utils.js.map +1 -0
- package/dist/lib/skill-generator.d.ts.map +1 -1
- package/dist/lib/skill-generator.js +4 -44
- package/dist/lib/skill-generator.js.map +1 -1
- package/dist/lib/ssot-map.d.ts.map +1 -1
- package/dist/lib/ssot-map.js +3 -0
- package/dist/lib/ssot-map.js.map +1 -1
- package/dist/lib/template.d.ts +10 -3
- package/dist/lib/template.d.ts.map +1 -1
- package/dist/lib/template.js +142 -22
- package/dist/lib/template.js.map +1 -1
- package/dist/lib/upgrade-backup.js +1 -1
- package/dist/lib/upgrade-backup.js.map +1 -1
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.js +37 -34
- package/dist/types/config.js.map +1 -1
- package/dist/types/feedback.d.ts +1 -54
- package/dist/types/feedback.d.ts.map +1 -1
- package/dist/types/feedback.js +1 -22
- package/dist/types/feedback.js.map +1 -1
- package/dist/types/project.d.ts +5 -0
- package/dist/types/project.d.ts.map +1 -1
- package/dist/types/project.js +15 -0
- package/dist/types/project.js.map +1 -1
- package/dist/types/ssot-map.d.ts +2 -0
- package/dist/types/ssot-map.d.ts.map +1 -1
- package/package.json +1 -1
- package/templates/base/agents/base/tsq-architect.md +1 -1
- package/templates/base/agents/base/tsq-dba.md +3 -1
- package/templates/base/agents/base/tsq-designer.md +3 -1
- package/templates/base/agents/base/tsq-developer.md +3 -1
- package/templates/base/agents/base/tsq-librarian.md +1 -1
- package/templates/base/agents/base/tsq-qa.md +3 -1
- package/templates/base/agents/base/tsq-security.md +3 -1
- package/templates/base/agents/overlays/platform/claude-code.md +2 -2
- package/templates/base/config.template.yaml +17 -28
- package/templates/base/knowledge/templates/task-result.md +5 -10
- package/templates/base/skills/_template/SKILL.md +1 -3
- package/templates/base/skills/{architecture → tsq-architecture}/SKILL.md +2 -2
- package/templates/base/skills/tsq-audit/SKILL.md +74 -0
- package/templates/base/skills/{methodology/bdd → tsq-bdd}/SKILL.md +14 -9
- package/templates/base/skills/{coding → tsq-coding}/SKILL.md +2 -4
- package/templates/base/skills/tsq-controller/SKILL.md +81 -0
- package/templates/base/skills/{mobile/dart → tsq-dart}/SKILL.md +5 -3
- package/templates/base/skills/{database → tsq-database}/SKILL.md +5 -2
- package/templates/base/skills/{methodology/ddd → tsq-ddd}/SKILL.md +15 -10
- package/templates/base/skills/{methodology/debugging → tsq-debugging}/SKILL.md +2 -2
- package/templates/base/skills/tsq-decompose/SKILL.md +117 -0
- package/templates/base/skills/tsq-delete/SKILL.md +72 -0
- package/templates/base/skills/{mobile/flutter → tsq-flutter}/SKILL.md +6 -3
- package/templates/base/skills/tsq-full/SKILL.md +67 -0
- package/templates/base/skills/tsq-grill/SKILL.md +86 -0
- package/templates/base/skills/{backend/node → tsq-hono}/SKILL.md +6 -4
- package/templates/base/skills/tsq-librarian/SKILL.md +78 -0
- package/templates/base/skills/tsq-log/SKILL.md +30 -0
- package/templates/base/skills/{frontend/nextjs → tsq-nextjs}/SKILL.md +14 -9
- package/templates/base/skills/{planning → tsq-planning}/SKILL.md +2 -2
- package/templates/base/skills/{database/prisma → tsq-prisma}/SKILL.md +15 -9
- package/templates/base/skills/{product-audit → tsq-product-audit}/SKILL.md +2 -4
- package/templates/base/skills/{prompt-engineering → tsq-prompt}/SKILL.md +6 -4
- package/templates/base/skills/tsq-protocol/SKILL.md +85 -33
- package/templates/base/skills/tsq-quick/SKILL.md +58 -0
- package/templates/base/skills/{frontend/react → tsq-react}/SKILL.md +6 -3
- package/templates/base/skills/tsq-retro/SKILL.md +86 -0
- package/templates/base/skills/tsq-retro/references/feedback-guide.md +58 -0
- package/templates/base/skills/tsq-retro/references/improve-protocol.md +87 -0
- package/templates/base/skills/{security → tsq-security}/SKILL.md +2 -4
- package/templates/base/skills/{spec → tsq-spec}/SKILL.md +4 -6
- package/templates/base/skills/{stability-verification → tsq-stability}/SKILL.md +3 -3
- package/templates/base/skills/tsq-start/SKILL.md +90 -0
- package/templates/base/skills/tsq-start/references/onboarding-questions.md +177 -0
- package/templates/base/skills/tsq-status/SKILL.md +32 -0
- package/templates/base/skills/{methodology/tdd → tsq-tdd}/SKILL.md +6 -3
- package/templates/base/skills/{testing → tsq-testing}/SKILL.md +5 -7
- package/templates/base/skills/{typescript → tsq-typescript}/SKILL.md +2 -2
- package/templates/base/skills/{ui-design → tsq-ui}/SKILL.md +2 -2
- package/templates/base/skills/tsq-update/SKILL.md +48 -0
- package/templates/base/timsquad/constraints/competency-framework.xml +2 -2
- package/templates/base/timsquad/constraints/ssot-schema.xml +2 -2
- package/templates/base/timsquad/process/phase-checklist.yaml +1 -1
- package/templates/base/timsquad/process/state-machine.xml +2 -2
- package/templates/base/timsquad/process/validation-rules.xml +8 -8
- package/templates/base/timsquad/process/workflow-base.xml +8 -8
- package/templates/base/timsquad/retrospective/cycle-report.template.md +2 -2
- package/templates/base/timsquad/retrospective/patterns/failure-patterns.md +1 -1
- package/templates/base/timsquad/retrospective/patterns/success-patterns.md +2 -2
- package/templates/base/timsquad/retrospective/retrospective-state.xml +2 -2
- package/templates/base/timsquad/ssot/audit-trail-spec.template.md +155 -0
- package/templates/base/timsquad/ssot/compliance-matrix.template.md +105 -0
- package/templates/base/timsquad/ssot/component-map.template.md +181 -0
- package/templates/base/timsquad/ssot/data-design.template.md +4 -4
- package/templates/base/timsquad/ssot/deployment-spec.template.md +29 -22
- package/templates/base/timsquad/ssot/env-config.template.md +4 -2
- package/templates/base/timsquad/ssot/error-codes.template.md +3 -3
- package/templates/base/timsquad/ssot/functional-spec.template.md +40 -3
- package/templates/base/timsquad/ssot/glossary.template.md +2 -2
- package/templates/base/timsquad/ssot/infra-topology.template.md +191 -0
- package/templates/base/timsquad/ssot/integration-spec.template.md +2 -2
- package/templates/base/timsquad/ssot/monitoring-spec.template.md +185 -0
- package/templates/base/timsquad/ssot/navigation-map.template.md +154 -0
- package/templates/base/timsquad/ssot/performance-budget.template.md +132 -0
- package/templates/base/timsquad/ssot/planning.template.md +3 -3
- package/templates/base/timsquad/ssot/prd/_template.md +73 -0
- package/templates/base/timsquad/ssot/prd.template.md +10 -21
- package/templates/base/timsquad/ssot/requirements.template.md +3 -3
- package/templates/base/timsquad/ssot/sdk-spec.template.md +223 -0
- package/templates/base/timsquad/ssot/service-spec.template.md +3 -3
- package/templates/base/timsquad/ssot/state-machine.template.md +127 -0
- package/templates/base/timsquad/ssot/ui-ux-spec.template.md +43 -3
- package/templates/base/timsquad/ssot-map.template.yaml +28 -0
- package/templates/base/timsquad/state/workspace.xml +11 -11
- package/templates/platforms/claude-code/rules/adr-rules.md +1 -1
- package/templates/platforms/claude-code/rules/build-gate.md +1 -1
- package/templates/platforms/claude-code/rules/completion-verification.md +0 -2
- package/templates/platforms/claude-code/rules/context-monitor.md +1 -1
- package/templates/platforms/claude-code/rules/feedback-routing.md +2 -2
- package/templates/platforms/claude-code/rules/phase-management.md +2 -2
- package/templates/platforms/claude-code/rules/plan-review.md +2 -2
- package/templates/platforms/claude-code/rules/quality-guards.md +0 -2
- package/templates/platforms/claude-code/rules/sequence-management.md +15 -15
- package/templates/platforms/claude-code/rules/session-notes.md +1 -1
- package/templates/platforms/claude-code/rules/workspace-sync.md +1 -1
- package/templates/platforms/claude-code/scripts/build-gate.sh +6 -1
- package/templates/platforms/claude-code/scripts/change-scope-guard.sh +1 -4
- package/templates/platforms/claude-code/scripts/check-capability.sh +68 -0
- package/templates/platforms/claude-code/scripts/completion-guard.sh +62 -4
- package/templates/platforms/claude-code/scripts/context-restore.sh +33 -6
- package/templates/platforms/claude-code/scripts/phase-guard.sh +2 -5
- package/templates/platforms/claude-code/scripts/pre-compact.sh +3 -3
- package/templates/platforms/claude-code/scripts/safe-guard.sh +2 -5
- package/templates/platforms/claude-code/scripts/subagent-start.sh +11 -0
- package/templates/platforms/claude-code/scripts/subagent-stop.sh +11 -0
- package/templates/platforms/claude-code/settings.json +20 -74
- package/templates/project-types/api-backend/config.yaml +9 -5
- package/templates/project-types/api-backend/process/workflow.xml +2 -2
- package/templates/project-types/fintech/config.yaml +13 -19
- package/templates/project-types/fintech/ssot/audit-trail-spec.template.md +207 -0
- package/templates/project-types/fintech/ssot/compliance-matrix.template.md +187 -0
- package/templates/project-types/infra/config.yaml +7 -4
- package/templates/project-types/infra/process/workflow.xml +3 -3
- package/templates/project-types/mobile-app/config.yaml +8 -14
- package/templates/project-types/mobile-app/process/workflow.xml +4 -4
- package/templates/project-types/platform/config.yaml +8 -5
- package/templates/project-types/platform/process/workflow.xml +3 -3
- package/templates/project-types/web-app/config.yaml +9 -15
- package/templates/project-types/web-app/process/workflow.xml +6 -6
- package/templates/project-types/web-service/config.yaml +10 -19
- package/templates/project-types/web-service/process/workflow.xml +6 -6
- package/dist/commands/audit.d.ts +0 -22
- package/dist/commands/audit.d.ts.map +0 -1
- package/dist/commands/audit.js +0 -233
- package/dist/commands/audit.js.map +0 -1
- package/dist/commands/compile.d.ts +0 -3
- package/dist/commands/compile.d.ts.map +0 -1
- package/dist/commands/compile.js +0 -251
- package/dist/commands/compile.js.map +0 -1
- package/dist/commands/feedback.d.ts +0 -12
- package/dist/commands/feedback.d.ts.map +0 -1
- package/dist/commands/feedback.js +0 -382
- package/dist/commands/feedback.js.map +0 -1
- package/dist/commands/full.d.ts +0 -3
- package/dist/commands/full.d.ts.map +0 -1
- package/dist/commands/full.js +0 -88
- package/dist/commands/full.js.map +0 -1
- package/dist/commands/git/commit.d.ts +0 -3
- package/dist/commands/git/commit.d.ts.map +0 -1
- package/dist/commands/git/commit.js +0 -85
- package/dist/commands/git/commit.js.map +0 -1
- package/dist/commands/git/index.d.ts +0 -5
- package/dist/commands/git/index.d.ts.map +0 -1
- package/dist/commands/git/index.js +0 -5
- package/dist/commands/git/index.js.map +0 -1
- package/dist/commands/git/pr.d.ts +0 -3
- package/dist/commands/git/pr.d.ts.map +0 -1
- package/dist/commands/git/pr.js +0 -139
- package/dist/commands/git/pr.js.map +0 -1
- package/dist/commands/git/release.d.ts +0 -3
- package/dist/commands/git/release.d.ts.map +0 -1
- package/dist/commands/git/release.js +0 -153
- package/dist/commands/git/release.js.map +0 -1
- package/dist/commands/git/sync.d.ts +0 -3
- package/dist/commands/git/sync.d.ts.map +0 -1
- package/dist/commands/git/sync.js +0 -132
- package/dist/commands/git/sync.js.map +0 -1
- package/dist/commands/improve.d.ts +0 -3
- package/dist/commands/improve.d.ts.map +0 -1
- package/dist/commands/improve.js +0 -286
- package/dist/commands/improve.js.map +0 -1
- package/dist/commands/knowledge.d.ts +0 -3
- package/dist/commands/knowledge.d.ts.map +0 -1
- package/dist/commands/knowledge.js +0 -316
- package/dist/commands/knowledge.js.map +0 -1
- package/dist/commands/log.d.ts.map +0 -1
- package/dist/commands/log.js +0 -1468
- package/dist/commands/log.js.map +0 -1
- package/dist/commands/meta-index.d.ts +0 -3
- package/dist/commands/meta-index.d.ts.map +0 -1
- package/dist/commands/meta-index.js +0 -431
- package/dist/commands/meta-index.js.map +0 -1
- package/dist/commands/metrics.d.ts +0 -3
- package/dist/commands/metrics.d.ts.map +0 -1
- package/dist/commands/metrics.js +0 -843
- package/dist/commands/metrics.js.map +0 -1
- package/dist/commands/quick.d.ts +0 -3
- package/dist/commands/quick.d.ts.map +0 -1
- package/dist/commands/quick.js +0 -136
- package/dist/commands/quick.js.map +0 -1
- package/dist/commands/retro.d.ts +0 -3
- package/dist/commands/retro.d.ts.map +0 -1
- package/dist/commands/retro.js +0 -885
- package/dist/commands/retro.js.map +0 -1
- package/dist/commands/session.d.ts +0 -3
- package/dist/commands/session.d.ts.map +0 -1
- package/dist/commands/session.js +0 -346
- package/dist/commands/session.js.map +0 -1
- package/dist/commands/skills.d.ts +0 -12
- package/dist/commands/skills.d.ts.map +0 -1
- package/dist/commands/skills.js +0 -228
- package/dist/commands/skills.js.map +0 -1
- package/dist/commands/status.d.ts +0 -3
- package/dist/commands/status.d.ts.map +0 -1
- package/dist/commands/status.js +0 -127
- package/dist/commands/status.js.map +0 -1
- package/dist/commands/upgrade.d.ts.map +0 -1
- package/dist/commands/upgrade.js.map +0 -1
- package/dist/commands/watch.d.ts +0 -3
- package/dist/commands/watch.d.ts.map +0 -1
- package/dist/commands/watch.js +0 -213
- package/dist/commands/watch.js.map +0 -1
- package/dist/commands/workflow.d.ts +0 -5
- package/dist/commands/workflow.d.ts.map +0 -1
- package/dist/commands/workflow.js +0 -781
- package/dist/commands/workflow.js.map +0 -1
- package/templates/base/skills/audit/SKILL.md +0 -66
- package/templates/base/skills/controller/SKILL.md +0 -77
- package/templates/base/skills/controller/delegation/developer.md +0 -25
- package/templates/base/skills/controller/delegation/librarian.md +0 -33
- package/templates/base/skills/controller/delegation/reviewer.md +0 -19
- package/templates/base/skills/controller/triggers/phase-complete.md +0 -25
- package/templates/base/skills/controller/triggers/sequence-complete.md +0 -15
- package/templates/base/skills/controller/triggers/ssot-changed.md +0 -14
- package/templates/base/skills/controller/triggers/task-complete.md +0 -14
- package/templates/base/skills/librarian/SKILL.md +0 -53
- package/templates/base/skills/main-session-constraints/SKILL.md +0 -62
- package/templates/base/skills/retrospective/SKILL.md +0 -77
- package/templates/base/skills/review/SKILL.md +0 -72
- package/templates/base/skills/tsq-cli/SKILL.md +0 -73
- package/templates/base/skills/tsq-cli/references/cli-reference.md +0 -92
- package/templates/base/timsquad/feedback/feedback-router.sh +0 -341
- package/templates/base/timsquad/feedback/routing-rules.yaml +0 -352
- package/templates/platforms/claude-code/CLAUDE.md.template +0 -89
- package/templates/platforms/claude-code/rules/skill-suggest.md +0 -27
- package/templates/platforms/claude-code/scripts/skill-inject.sh +0 -216
- package/templates/platforms/claude-code/scripts/skill-rules.json +0 -95
- package/templates/platforms/claude-code/scripts/skill-suggest.sh +0 -105
- package/templates/platforms/claude-code/scripts/subagent-inject.sh +0 -53
- /package/templates/base/skills/{architecture → tsq-architecture}/references/adr-template.md +0 -0
- /package/templates/base/skills/{architecture → tsq-architecture}/references/api-design.md +0 -0
- /package/templates/base/skills/{methodology/bdd → tsq-bdd}/rules/gherkin-patterns.md +0 -0
- /package/templates/base/skills/{coding → tsq-coding}/rules/async-patterns.md +0 -0
- /package/templates/base/skills/{coding → tsq-coding}/rules/code-organization.md +0 -0
- /package/templates/base/skills/{coding → tsq-coding}/rules/error-handling.md +0 -0
- /package/templates/base/skills/{coding → tsq-coding}/rules/patterns.md +0 -0
- /package/templates/base/skills/{coding → tsq-coding}/rules/type-safety.md +0 -0
- /package/templates/base/skills/{controller → tsq-controller}/memory/.gitkeep +0 -0
- /package/templates/base/skills/{controller → tsq-controller}/references/README.md +0 -0
- /package/templates/base/skills/{controller → tsq-controller}/rules/README.md +0 -0
- /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/async-patterns.md +0 -0
- /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/code-style.md +0 -0
- /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/null-safety.md +0 -0
- /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/type-system.md +0 -0
- /package/templates/base/skills/{database → tsq-database}/rules/query-optimization.md +0 -0
- /package/templates/base/skills/{database → tsq-database}/rules/supabase-patterns.md +0 -0
- /package/templates/base/skills/{methodology/ddd → tsq-ddd}/rules/strategic-patterns.md +0 -0
- /package/templates/base/skills/{methodology/debugging → tsq-debugging}/references/root-cause-tracing.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/SKILL.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/references/ci-cd-pipeline.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/code-signing.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/codemagic-setup.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/fastlane-setup.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/github-actions.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/store-deployment.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/versioning.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/SKILL.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/references/i18n-architecture.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/arb-files.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/locale-switching.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/localization-setup.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/plural-gender.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/text-direction.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/SKILL.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/references/monitoring-architecture.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/analytics.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/crashlytics-setup.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/logging.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/performance-monitoring.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/sentry-integration.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/SKILL.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/references/api-client-architecture.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/caching.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/connectivity.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/dio-setup.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/error-handling.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/interceptors.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/retrofit-patterns.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/SKILL.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/references/notification-architecture.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/references/platform-setup.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/background-processing.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/deep-linking.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/fcm-setup.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/local-notifications.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/notification-handling.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/notification-permissions.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/rich-notifications.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/references/freezed-patterns.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/references/project-structure.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/animations.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/architecture.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/navigation-routing.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/performance.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/platform-adaptive.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/state-management.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/testing.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/widget-conventions.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/SKILL.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/references/mobile-security-checklist.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/api-key-protection.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/authentication.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/data-protection.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/obfuscation.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/secure-storage.md +0 -0
- /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/ssl-pinning.md +0 -0
- /package/templates/base/skills/{backend/node → tsq-hono}/rules/async-patterns.md +0 -0
- /package/templates/base/skills/{backend/node → tsq-hono}/rules/deployment.md +0 -0
- /package/templates/base/skills/{backend/node → tsq-hono}/rules/env-config.md +0 -0
- /package/templates/base/skills/{backend/node → tsq-hono}/rules/error-handling.md +0 -0
- /package/templates/base/skills/{backend/node → tsq-hono}/rules/hono-app-setup.md +0 -0
- /package/templates/base/skills/{backend/node → tsq-hono}/rules/jwt-auth.md +0 -0
- /package/templates/base/skills/{backend/node → tsq-hono}/rules/middleware.md +0 -0
- /package/templates/base/skills/{backend/node → tsq-hono}/rules/testing.md +0 -0
- /package/templates/base/skills/{frontend/nextjs → tsq-nextjs}/rules/app-router.md +0 -0
- /package/templates/base/skills/{planning → tsq-planning}/references/prd-guide.md +0 -0
- /package/templates/base/skills/{planning → tsq-planning}/references/requirements-guide.md +0 -0
- /package/templates/base/skills/{database/prisma → tsq-prisma}/rules/queries.md +0 -0
- /package/templates/base/skills/{database/prisma → tsq-prisma}/rules/schema-design.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/01-security.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/02-performance.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/03-seo.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/04-accessibility.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/05-ui-ux.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/06-architecture.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/07-functional-requirements.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/audit-protocol.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/false-positive-guard.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/scoring-criteria.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/templates/improvement-plan-template.md +0 -0
- /package/templates/base/skills/{product-audit → tsq-product-audit}/templates/report-template.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/_sections.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/anti-patterns.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-api-routes.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-defer-await.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-dependencies.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-parallel.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-suspense-boundaries.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-barrel-imports.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-defer-third-party.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-dynamic-imports.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/component-conventions.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-combine-iterations.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-early-exit.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-index-maps.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-set-map-lookups.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-conditional-render.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-content-visibility.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-hoist-jsx.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-defer-reads.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-derived-state.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-memo.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-transitions.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-after-nonblocking.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-cache-react.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-parallel-fetching.md +0 -0
- /package/templates/base/skills/{frontend/react → tsq-react}/rules/state-location.md +0 -0
- /package/templates/base/skills/{retrospective → tsq-retro}/references/improvement-template.md +0 -0
- /package/templates/base/skills/{security → tsq-security}/rules/auth-patterns.md +0 -0
- /package/templates/base/skills/{security → tsq-security}/rules/dependency-security.md +0 -0
- /package/templates/base/skills/{security → tsq-security}/rules/input-validation.md +0 -0
- /package/templates/base/skills/{security → tsq-security}/rules/owasp-examples.md +0 -0
- /package/templates/base/skills/{security → tsq-security}/rules/secrets-management.md +0 -0
- /package/templates/base/skills/{security → tsq-security}/scripts/check-secrets.sh +0 -0
- /package/templates/base/skills/{stability-verification → tsq-stability}/references/release-checklist.md +0 -0
- /package/templates/base/skills/{stability-verification → tsq-stability}/references/security-fix-patterns.md +0 -0
- /package/templates/base/skills/{stability-verification → tsq-stability}/rules/verification-layers.md +0 -0
- /package/templates/base/skills/{stability-verification → tsq-stability}/rules/verification-workflow.md +0 -0
- /package/templates/base/skills/{stability-verification → tsq-stability}/scripts/verify.sh +0 -0
- /package/templates/base/skills/{methodology/tdd → tsq-tdd}/rules/real-world-example.md +0 -0
- /package/templates/base/skills/{methodology/tdd → tsq-tdd}/rules/techniques.md +0 -0
- /package/templates/base/skills/{testing → tsq-testing}/references/e2e-stability.md +0 -0
- /package/templates/base/skills/{testing → tsq-testing}/references/testing-patterns.md +0 -0
- /package/templates/base/skills/{typescript → tsq-typescript}/rules/type-patterns.md +0 -0
- /package/templates/base/skills/{typescript → tsq-typescript}/rules/utility-types.md +0 -0
|
@@ -1,352 +0,0 @@
|
|
|
1
|
-
# TimSquad Feedback Routing Rules
|
|
2
|
-
# 피드백을 적절한 담당자에게 자동 라우팅하는 규칙 정의
|
|
3
|
-
#
|
|
4
|
-
# 이론적 기반:
|
|
5
|
-
# - FRAME (Feedback-Driven Refinement): 레벨별 피드백 분류
|
|
6
|
-
# - Agentsway: Agent specialization에 따른 라우팅
|
|
7
|
-
#
|
|
8
|
-
# 사용법:
|
|
9
|
-
# 1. 피드백 발생 시 triggers 매칭
|
|
10
|
-
# 2. 매칭된 레벨의 route_to로 전달
|
|
11
|
-
# 3. 필요 시 사용자 승인 요청
|
|
12
|
-
|
|
13
|
-
version: "1.0"
|
|
14
|
-
|
|
15
|
-
# ============================================================
|
|
16
|
-
# 피드백 레벨 정의
|
|
17
|
-
# ============================================================
|
|
18
|
-
levels:
|
|
19
|
-
level_1:
|
|
20
|
-
name: "구현 수정"
|
|
21
|
-
description: "코드 레벨 수정, 설계 변경 없음"
|
|
22
|
-
approval_required: false
|
|
23
|
-
ssot_update: false
|
|
24
|
-
|
|
25
|
-
level_2:
|
|
26
|
-
name: "설계 수정"
|
|
27
|
-
description: "아키텍처/API 설계 변경 필요"
|
|
28
|
-
approval_required: false
|
|
29
|
-
ssot_update: true
|
|
30
|
-
|
|
31
|
-
level_3:
|
|
32
|
-
name: "기획 수정"
|
|
33
|
-
description: "요구사항/기획 변경 필요, 사용자 승인 필수"
|
|
34
|
-
approval_required: true
|
|
35
|
-
ssot_update: true
|
|
36
|
-
|
|
37
|
-
# ============================================================
|
|
38
|
-
# 라우팅 규칙
|
|
39
|
-
# ============================================================
|
|
40
|
-
routing:
|
|
41
|
-
# --------------------------------------------------------
|
|
42
|
-
# Level 1: 구현 수정 → Developer
|
|
43
|
-
# --------------------------------------------------------
|
|
44
|
-
level_1:
|
|
45
|
-
triggers:
|
|
46
|
-
# 테스트 관련
|
|
47
|
-
- pattern: "test_failure"
|
|
48
|
-
keywords: ["test failed", "assertion error", "expected", "actual"]
|
|
49
|
-
|
|
50
|
-
- pattern: "test_coverage"
|
|
51
|
-
keywords: ["coverage below", "uncovered lines", "missing tests"]
|
|
52
|
-
|
|
53
|
-
# 코드 품질
|
|
54
|
-
- pattern: "lint_error"
|
|
55
|
-
keywords: ["eslint", "prettier", "formatting", "lint error"]
|
|
56
|
-
|
|
57
|
-
- pattern: "type_error"
|
|
58
|
-
keywords: ["type error", "typescript", "cannot assign", "is not assignable"]
|
|
59
|
-
|
|
60
|
-
- pattern: "runtime_error"
|
|
61
|
-
keywords: ["runtime error", "exception", "crash", "undefined is not"]
|
|
62
|
-
|
|
63
|
-
# 코드 스타일
|
|
64
|
-
- pattern: "code_style"
|
|
65
|
-
keywords: ["naming convention", "code style", "formatting issue"]
|
|
66
|
-
|
|
67
|
-
- pattern: "code_smell"
|
|
68
|
-
keywords: ["code smell", "duplicate code", "long method", "complex"]
|
|
69
|
-
|
|
70
|
-
# 성능 (minor)
|
|
71
|
-
- pattern: "minor_performance"
|
|
72
|
-
keywords: ["slow query", "n+1", "unnecessary loop"]
|
|
73
|
-
|
|
74
|
-
route_to: "tsq-developer"
|
|
75
|
-
|
|
76
|
-
actions:
|
|
77
|
-
- type: "auto_fix"
|
|
78
|
-
enabled: true
|
|
79
|
-
max_attempts: 3
|
|
80
|
-
|
|
81
|
-
- type: "log"
|
|
82
|
-
destination: ".timsquad/logs/"
|
|
83
|
-
|
|
84
|
-
escalation:
|
|
85
|
-
condition: "attempts >= 3"
|
|
86
|
-
escalate_to: "level_2"
|
|
87
|
-
notify: ["tsq-planner"]
|
|
88
|
-
|
|
89
|
-
# --------------------------------------------------------
|
|
90
|
-
# Level 2: 설계 수정 → Planner (Architect 모드)
|
|
91
|
-
# --------------------------------------------------------
|
|
92
|
-
level_2:
|
|
93
|
-
triggers:
|
|
94
|
-
# 아키텍처 관련
|
|
95
|
-
- pattern: "architecture_issue"
|
|
96
|
-
keywords: ["architecture", "design pattern", "dependency", "coupling"]
|
|
97
|
-
|
|
98
|
-
- pattern: "api_mismatch"
|
|
99
|
-
keywords: ["api mismatch", "contract violation", "interface change"]
|
|
100
|
-
|
|
101
|
-
- pattern: "schema_mismatch"
|
|
102
|
-
keywords: ["schema mismatch", "migration needed", "db change"]
|
|
103
|
-
|
|
104
|
-
# 성능 (major)
|
|
105
|
-
- pattern: "performance_issue"
|
|
106
|
-
keywords: ["performance degradation", "timeout", "memory leak", "bottleneck"]
|
|
107
|
-
|
|
108
|
-
- pattern: "scalability_concern"
|
|
109
|
-
keywords: ["scalability", "load handling", "concurrent users"]
|
|
110
|
-
|
|
111
|
-
# 보안 (implementation level)
|
|
112
|
-
- pattern: "security_vulnerability"
|
|
113
|
-
keywords: ["vulnerability", "security issue", "injection", "xss", "csrf"]
|
|
114
|
-
|
|
115
|
-
# 통합 문제
|
|
116
|
-
- pattern: "integration_issue"
|
|
117
|
-
keywords: ["integration failed", "external api", "third party"]
|
|
118
|
-
|
|
119
|
-
# SSOT 불일치
|
|
120
|
-
- pattern: "ssot_violation"
|
|
121
|
-
keywords: ["ssot mismatch", "spec violation", "documentation outdated"]
|
|
122
|
-
|
|
123
|
-
route_to: "tsq-planner"
|
|
124
|
-
planner_mode: "architect"
|
|
125
|
-
|
|
126
|
-
actions:
|
|
127
|
-
- type: "analyze"
|
|
128
|
-
agent: "tsq-planner"
|
|
129
|
-
|
|
130
|
-
- type: "update_ssot"
|
|
131
|
-
documents: ["service-spec.md", "data-design.md", "error-codes.md"]
|
|
132
|
-
|
|
133
|
-
- type: "create_adr"
|
|
134
|
-
enabled: true
|
|
135
|
-
template: "ADR-000-template.md"
|
|
136
|
-
|
|
137
|
-
- type: "log"
|
|
138
|
-
destination: ".timsquad/logs/"
|
|
139
|
-
|
|
140
|
-
escalation:
|
|
141
|
-
condition: "impact >= high OR user_facing == true"
|
|
142
|
-
escalate_to: "level_3"
|
|
143
|
-
notify: ["user"]
|
|
144
|
-
|
|
145
|
-
# --------------------------------------------------------
|
|
146
|
-
# Level 3: 기획 수정 → User 승인 필요
|
|
147
|
-
# --------------------------------------------------------
|
|
148
|
-
level_3:
|
|
149
|
-
triggers:
|
|
150
|
-
# 요구사항 관련
|
|
151
|
-
- pattern: "requirement_ambiguity"
|
|
152
|
-
keywords: ["unclear requirement", "ambiguous", "need clarification"]
|
|
153
|
-
|
|
154
|
-
- pattern: "requirement_change"
|
|
155
|
-
keywords: ["requirement change", "scope change", "new feature"]
|
|
156
|
-
|
|
157
|
-
- pattern: "scope_creep"
|
|
158
|
-
keywords: ["scope creep", "out of scope", "additional feature"]
|
|
159
|
-
|
|
160
|
-
# 비즈니스 로직
|
|
161
|
-
- pattern: "business_logic_error"
|
|
162
|
-
keywords: ["business logic", "business rule", "domain error"]
|
|
163
|
-
|
|
164
|
-
- pattern: "stakeholder_feedback"
|
|
165
|
-
keywords: ["stakeholder", "client feedback", "user feedback"]
|
|
166
|
-
|
|
167
|
-
# 우선순위/일정
|
|
168
|
-
- pattern: "priority_change"
|
|
169
|
-
keywords: ["priority change", "timeline", "deadline", "milestone"]
|
|
170
|
-
|
|
171
|
-
# 기술 결정
|
|
172
|
-
- pattern: "technology_decision"
|
|
173
|
-
keywords: ["technology choice", "framework", "library selection"]
|
|
174
|
-
|
|
175
|
-
# 비용/리소스
|
|
176
|
-
- pattern: "resource_constraint"
|
|
177
|
-
keywords: ["budget", "resource", "cost", "infrastructure"]
|
|
178
|
-
|
|
179
|
-
route_to: "tsq-planner"
|
|
180
|
-
planner_mode: "planning"
|
|
181
|
-
|
|
182
|
-
actions:
|
|
183
|
-
- type: "notify_user"
|
|
184
|
-
priority: "high"
|
|
185
|
-
|
|
186
|
-
- type: "prepare_summary"
|
|
187
|
-
include: ["impact", "options", "recommendation"]
|
|
188
|
-
|
|
189
|
-
- type: "await_approval"
|
|
190
|
-
timeout: "24h"
|
|
191
|
-
reminder: "4h"
|
|
192
|
-
|
|
193
|
-
- type: "update_ssot"
|
|
194
|
-
documents: ["prd.md", "requirements.md", "planning.md"]
|
|
195
|
-
requires_approval: true
|
|
196
|
-
|
|
197
|
-
- type: "log"
|
|
198
|
-
destination: ".timsquad/logs/"
|
|
199
|
-
|
|
200
|
-
approval_flow:
|
|
201
|
-
- step: "present_options"
|
|
202
|
-
agent: "tsq-planner"
|
|
203
|
-
|
|
204
|
-
- step: "user_decision"
|
|
205
|
-
timeout: "24h"
|
|
206
|
-
|
|
207
|
-
- step: "apply_changes"
|
|
208
|
-
condition: "approved == true"
|
|
209
|
-
|
|
210
|
-
- step: "cascade_updates"
|
|
211
|
-
documents: ["affected_ssot_documents"]
|
|
212
|
-
|
|
213
|
-
# ============================================================
|
|
214
|
-
# 키워드 기반 자동 분류
|
|
215
|
-
# ============================================================
|
|
216
|
-
classification:
|
|
217
|
-
# 자동 분류 활성화
|
|
218
|
-
auto_classify: true
|
|
219
|
-
|
|
220
|
-
# 신뢰도 임계값 (0-1)
|
|
221
|
-
confidence_threshold: 0.7
|
|
222
|
-
|
|
223
|
-
# 낮은 신뢰도 시 동작
|
|
224
|
-
low_confidence_action: "ask_user"
|
|
225
|
-
|
|
226
|
-
# 분류 우선순위 (높은 레벨 우선)
|
|
227
|
-
priority: ["level_3", "level_2", "level_1"]
|
|
228
|
-
|
|
229
|
-
# 복합 패턴 처리
|
|
230
|
-
compound_patterns:
|
|
231
|
-
- patterns: ["security_vulnerability", "architecture_issue"]
|
|
232
|
-
result_level: "level_2"
|
|
233
|
-
priority: "critical"
|
|
234
|
-
|
|
235
|
-
- patterns: ["requirement_change", "scope_creep"]
|
|
236
|
-
result_level: "level_3"
|
|
237
|
-
priority: "high"
|
|
238
|
-
|
|
239
|
-
# ============================================================
|
|
240
|
-
# 에스컬레이션 규칙
|
|
241
|
-
# ============================================================
|
|
242
|
-
escalation:
|
|
243
|
-
# 시간 기반 에스컬레이션
|
|
244
|
-
time_based:
|
|
245
|
-
level_1:
|
|
246
|
-
timeout: "2h"
|
|
247
|
-
escalate_to: "level_2"
|
|
248
|
-
|
|
249
|
-
level_2:
|
|
250
|
-
timeout: "8h"
|
|
251
|
-
escalate_to: "level_3"
|
|
252
|
-
|
|
253
|
-
# 반복 기반 에스컬레이션
|
|
254
|
-
recurrence_based:
|
|
255
|
-
threshold: 3
|
|
256
|
-
window: "7d"
|
|
257
|
-
action: "escalate_and_create_pattern"
|
|
258
|
-
|
|
259
|
-
# 심각도 기반 에스컬레이션
|
|
260
|
-
severity_based:
|
|
261
|
-
critical:
|
|
262
|
-
immediate_escalate_to: "level_3"
|
|
263
|
-
notify: ["user", "tsq-planner"]
|
|
264
|
-
|
|
265
|
-
high:
|
|
266
|
-
escalate_after: "1h"
|
|
267
|
-
|
|
268
|
-
medium:
|
|
269
|
-
follow_normal_flow: true
|
|
270
|
-
|
|
271
|
-
low:
|
|
272
|
-
batch_process: true
|
|
273
|
-
batch_interval: "4h"
|
|
274
|
-
|
|
275
|
-
# ============================================================
|
|
276
|
-
# 알림 설정
|
|
277
|
-
# ============================================================
|
|
278
|
-
notifications:
|
|
279
|
-
channels:
|
|
280
|
-
# 콘솔 출력
|
|
281
|
-
console:
|
|
282
|
-
enabled: true
|
|
283
|
-
levels: ["level_1", "level_2", "level_3"]
|
|
284
|
-
|
|
285
|
-
# 로그 파일
|
|
286
|
-
log_file:
|
|
287
|
-
enabled: true
|
|
288
|
-
path: ".timsquad/logs/feedback.log"
|
|
289
|
-
|
|
290
|
-
# 사용자 프롬프트
|
|
291
|
-
user_prompt:
|
|
292
|
-
enabled: true
|
|
293
|
-
levels: ["level_3"]
|
|
294
|
-
|
|
295
|
-
templates:
|
|
296
|
-
level_1: |
|
|
297
|
-
[Level 1] 구현 수정 필요
|
|
298
|
-
패턴: {{pattern}}
|
|
299
|
-
대상: {{target_file}}
|
|
300
|
-
담당: @tsq-developer
|
|
301
|
-
|
|
302
|
-
level_2: |
|
|
303
|
-
[Level 2] 설계 수정 필요
|
|
304
|
-
패턴: {{pattern}}
|
|
305
|
-
영향: {{impact}}
|
|
306
|
-
담당: 메인세션(PM) - SSOT 직접 수정
|
|
307
|
-
SSOT 업데이트 필요
|
|
308
|
-
|
|
309
|
-
level_3: |
|
|
310
|
-
[Level 3] 기획 검토 필요 - 사용자 승인 대기
|
|
311
|
-
패턴: {{pattern}}
|
|
312
|
-
영향: {{impact}}
|
|
313
|
-
옵션: {{options}}
|
|
314
|
-
|
|
315
|
-
승인 대기 중...
|
|
316
|
-
|
|
317
|
-
# ============================================================
|
|
318
|
-
# 메트릭 수집
|
|
319
|
-
# ============================================================
|
|
320
|
-
metrics:
|
|
321
|
-
collect:
|
|
322
|
-
- feedback_count_by_level
|
|
323
|
-
- feedback_count_by_pattern
|
|
324
|
-
- resolution_time
|
|
325
|
-
- escalation_rate
|
|
326
|
-
- recurrence_rate
|
|
327
|
-
|
|
328
|
-
storage: ".timsquad/retrospective/metrics/feedback-stats.json"
|
|
329
|
-
|
|
330
|
-
aggregation:
|
|
331
|
-
interval: "daily"
|
|
332
|
-
retention: "90d"
|
|
333
|
-
|
|
334
|
-
# ============================================================
|
|
335
|
-
# 학습/개선
|
|
336
|
-
# ============================================================
|
|
337
|
-
learning:
|
|
338
|
-
# 패턴 자동 등록
|
|
339
|
-
auto_pattern_registration:
|
|
340
|
-
enabled: true
|
|
341
|
-
threshold: 3 # 3회 이상 반복 시
|
|
342
|
-
|
|
343
|
-
# 회고 시스템 연동
|
|
344
|
-
retrospective_integration:
|
|
345
|
-
enabled: true
|
|
346
|
-
report_to: ".timsquad/retrospective/patterns/"
|
|
347
|
-
|
|
348
|
-
# 라우팅 규칙 개선 제안
|
|
349
|
-
rule_improvement:
|
|
350
|
-
enabled: true
|
|
351
|
-
suggest_new_keywords: true
|
|
352
|
-
suggest_threshold_adjustments: true
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
# {{PROJECT_NAME}}
|
|
2
|
-
|
|
3
|
-
> TimSquad v3.1으로 관리되는 프로젝트입니다.
|
|
4
|
-
|
|
5
|
-
<timsquad-initialization>
|
|
6
|
-
이 프로젝트는 TimSquad 프레임워크를 사용합니다.
|
|
7
|
-
`.timsquad/` 디렉토리가 없으면 진행을 중단하고 사용자에게 알리세요:
|
|
8
|
-
"TimSquad 프로젝트가 초기화되지 않았습니다. `tsq init --type {{PROJECT_TYPE}}`을 실행하세요."
|
|
9
|
-
</timsquad-initialization>
|
|
10
|
-
|
|
11
|
-
## 역할: Project Manager
|
|
12
|
-
|
|
13
|
-
당신은 이 프로젝트의 PM입니다. 사용자와 직접 소통하며, 작업을 분류하여 서브에이전트에 위임합니다.
|
|
14
|
-
|
|
15
|
-
### 핵심 책임
|
|
16
|
-
1. **요구사항 수집** — 사용자와 소통, 진행 보고, 승인 요청
|
|
17
|
-
2. **작업 위임** — 적절한 서브에이전트에게 배분
|
|
18
|
-
3. **기획** — 최초 기획 + 변경 시 (`skills/planning/` 활용)
|
|
19
|
-
4. **리뷰** — architect 보고서 기반 시퀀스 검토
|
|
20
|
-
5. **SSOT 관리** — 문서 일관성과 최신성 유지
|
|
21
|
-
6. **피드백 라우팅** — L1/L2/L3 분류 후 적절한 담당자 전달
|
|
22
|
-
|
|
23
|
-
### 활성 서브에이전트
|
|
24
|
-
|
|
25
|
-
{{ACTIVE_AGENTS}}
|
|
26
|
-
|
|
27
|
-
---
|
|
28
|
-
|
|
29
|
-
## 필수 참조 파일
|
|
30
|
-
|
|
31
|
-
작업 전 반드시 확인:
|
|
32
|
-
- `.timsquad/config.yaml` — 프로젝트 설정
|
|
33
|
-
- `.timsquad/state/current-phase.json` — 현재 Phase
|
|
34
|
-
- `.timsquad/state/workspace.xml` — 실시간 작업 상태
|
|
35
|
-
- `.timsquad/ssot/` — SSOT 문서들
|
|
36
|
-
- `.claude/knowledge/` — 참조 지식
|
|
37
|
-
|
|
38
|
-
## 서브에이전트 위임 규칙
|
|
39
|
-
|
|
40
|
-
<rules>
|
|
41
|
-
<must>서브에이전트 위임은 controller skill의 프로세스를 따를 것</must>
|
|
42
|
-
<must>위임 전 해당 에이전트의 prerequisites가 compiled spec으로 존재하는지 확인</must>
|
|
43
|
-
<must>compiled spec의 stale 여부를 .compile-manifest.json으로 확인</must>
|
|
44
|
-
<must-not>controller 우회하여 Task() 직접 호출</must-not>
|
|
45
|
-
<must-not>compiled spec 없이 서브에이전트 실행</must-not>
|
|
46
|
-
</rules>
|
|
47
|
-
|
|
48
|
-
{{DELEGATION_RULES}}
|
|
49
|
-
|
|
50
|
-
---
|
|
51
|
-
|
|
52
|
-
## 작업 모드 분류
|
|
53
|
-
|
|
54
|
-
<task-classification>
|
|
55
|
-
사용자가 `tsq f` 또는 `tsq q` 없이 직접 작업을 지시하면, 실행 전에 반드시 모드를 분류한다.
|
|
56
|
-
|
|
57
|
-
<quick-indicators>CSS, 스타일, 오타, typo, 색상, 텍스트, 변수명, 간단한 버그, 1-2줄 수정</quick-indicators>
|
|
58
|
-
<full-indicators>새 기능, API, DB, 구조 변경, 인증, 아키텍처, 리팩토링, 여러 파일 수정</full-indicators>
|
|
59
|
-
|
|
60
|
-
<rules>
|
|
61
|
-
<must>Full로 판단되면 사용자에게 확인 후 진행:
|
|
62
|
-
"이 작업은 Full 모드로 진행합니다 (SSOT 검증 + controller 경유). 진행할까요?"</must>
|
|
63
|
-
<must>Quick으로 판단되면 바로 진행하되 모드를 명시:
|
|
64
|
-
"Quick 모드로 바로 진행합니다."</must>
|
|
65
|
-
<must>판단이 모호하면 사용자에게 선택지를 제시</must>
|
|
66
|
-
</rules>
|
|
67
|
-
</task-classification>
|
|
68
|
-
|
|
69
|
-
## 작업 원칙
|
|
70
|
-
|
|
71
|
-
1. 요구사항에 여러 해석이 가능하면 조용히 선택하지 말고 **선택지를 제시**하라
|
|
72
|
-
2. 구현 전에 **검증 기준**(테스트 or 확인 방법)을 먼저 명시하라
|
|
73
|
-
|
|
74
|
-
## 금지 사항
|
|
75
|
-
|
|
76
|
-
- SSOT 문서 없이 구현 시작 금지
|
|
77
|
-
- User 승인 없이 Level 3 변경 금지
|
|
78
|
-
- 에이전트 간 직접 통신 금지 (모든 조율은 PM 통해)
|
|
79
|
-
- 로그 기록 없이 작업 완료 선언 금지
|
|
80
|
-
- Phase 전환 조건 미충족 시 다음 Phase 진행 금지
|
|
81
|
-
|
|
82
|
-
## 상세 규칙
|
|
83
|
-
|
|
84
|
-
Phase 관리, 시퀀스 관리, workspace 동기화, 피드백 라우팅, ADR, 보고 형식 등
|
|
85
|
-
상세 규칙은 `.claude/rules/`에 정의되어 있습니다. 관련 작업 시 자동 로드됩니다.
|
|
86
|
-
|
|
87
|
-
---
|
|
88
|
-
|
|
89
|
-
**타입**: {{PROJECT_TYPE}} | **레벨**: {{PROJECT_LEVEL}} | **초기화**: {{INIT_DATE}}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
description: 런타임 스킬 제안. 프롬프트 분석 후 관련 스킬 자동 추천.
|
|
3
|
-
globs:
|
|
4
|
-
- "**/*"
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# 런타임 스킬 제안 (Skill Suggest)
|
|
8
|
-
|
|
9
|
-
## 자동 감지
|
|
10
|
-
|
|
11
|
-
매 프롬프트 제출 시 `[Skill Suggest]` 메시지가 주입될 수 있습니다.
|
|
12
|
-
- 사용자 프롬프트의 키워드/패턴을 분석하여 관련 스킬 추천
|
|
13
|
-
- 배포된 스킬만 추천 (프로젝트에 없는 스킬은 무시)
|
|
14
|
-
|
|
15
|
-
## 제안 수신 시 대응
|
|
16
|
-
|
|
17
|
-
`[Skill Suggest] 관련 스킬이 감지되었습니다: ...` 메시지를 받으면:
|
|
18
|
-
1. 추천된 스킬의 `rules/` 디렉토리를 확인하세요
|
|
19
|
-
2. 현재 태스크에 관련된 규칙을 참조하여 품질을 높이세요
|
|
20
|
-
3. 스킬이 현재 작업과 무관하면 무시해도 됩니다
|
|
21
|
-
|
|
22
|
-
## 스킬 규칙 위치
|
|
23
|
-
|
|
24
|
-
배포된 스킬: `.claude/skills/{skill-name}/`
|
|
25
|
-
- `SKILL.md` — 스킬 개요
|
|
26
|
-
- `rules/` — 구체적 규칙 (on-demand 참조)
|
|
27
|
-
- `references/` — 참고 자료
|
|
@@ -1,216 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# Skill Inject — UserPromptSubmit Hook
|
|
3
|
-
# 사용자 프롬프트를 분석하여 매칭 스킬의 Contract/Protocol/Verification을
|
|
4
|
-
# systemMessage로 강제 주입한다 (advisory → mandatory 전환).
|
|
5
|
-
#
|
|
6
|
-
# 기존 skill-suggest.sh를 대체 (상위 호환).
|
|
7
|
-
# Input: JSON via stdin (Claude Code hook protocol, .prompt 필드 포함)
|
|
8
|
-
# Output: JSON with systemMessage (스킬 강제 주입)
|
|
9
|
-
|
|
10
|
-
set -e
|
|
11
|
-
|
|
12
|
-
# Read hook input
|
|
13
|
-
INPUT=$(cat 2>/dev/null || echo "")
|
|
14
|
-
if [ -z "$INPUT" ]; then
|
|
15
|
-
exit 0
|
|
16
|
-
fi
|
|
17
|
-
|
|
18
|
-
PROMPT=$(echo "$INPUT" | jq -r '.prompt // ""' 2>/dev/null || echo "")
|
|
19
|
-
if [ -z "$PROMPT" ] || [ "$PROMPT" = "null" ]; then
|
|
20
|
-
exit 0
|
|
21
|
-
fi
|
|
22
|
-
|
|
23
|
-
# Find project root
|
|
24
|
-
PROJECT_ROOT="$(pwd)"
|
|
25
|
-
while [ "$PROJECT_ROOT" != "/" ]; do
|
|
26
|
-
if [ -d "$PROJECT_ROOT/.timsquad" ]; then
|
|
27
|
-
break
|
|
28
|
-
fi
|
|
29
|
-
PROJECT_ROOT="$(dirname "$PROJECT_ROOT")"
|
|
30
|
-
done
|
|
31
|
-
|
|
32
|
-
if [ ! -d "$PROJECT_ROOT/.timsquad" ]; then
|
|
33
|
-
exit 0
|
|
34
|
-
fi
|
|
35
|
-
|
|
36
|
-
# Load skill rules
|
|
37
|
-
RULES_FILE="$PROJECT_ROOT/.claude/scripts/skill-rules.json"
|
|
38
|
-
if [ ! -f "$RULES_FILE" ]; then
|
|
39
|
-
exit 0
|
|
40
|
-
fi
|
|
41
|
-
|
|
42
|
-
THRESHOLD=$(jq -r '.threshold // 2' "$RULES_FILE" 2>/dev/null || echo "2")
|
|
43
|
-
PROMPT_LOWER=$(echo "$PROMPT" | tr '[:upper:]' '[:lower:]')
|
|
44
|
-
|
|
45
|
-
# Match skills and collect top matches with scores
|
|
46
|
-
declare -a MATCH_SKILLS=()
|
|
47
|
-
declare -a MATCH_SCORES=()
|
|
48
|
-
|
|
49
|
-
RULE_COUNT=$(jq '.rules | length' "$RULES_FILE" 2>/dev/null || echo "0")
|
|
50
|
-
|
|
51
|
-
i=0
|
|
52
|
-
while [ "$i" -lt "$RULE_COUNT" ]; do
|
|
53
|
-
SKILL=$(jq -r ".rules[$i].skill" "$RULES_FILE" 2>/dev/null)
|
|
54
|
-
SCORE=0
|
|
55
|
-
|
|
56
|
-
# Check if skill is deployed
|
|
57
|
-
SKILL_DIR="$PROJECT_ROOT/.claude/skills/$SKILL"
|
|
58
|
-
if [ ! -d "$SKILL_DIR" ]; then
|
|
59
|
-
i=$((i + 1))
|
|
60
|
-
continue
|
|
61
|
-
fi
|
|
62
|
-
|
|
63
|
-
# Keyword matching (3 points each)
|
|
64
|
-
KW_COUNT=$(jq ".rules[$i].keywords | length" "$RULES_FILE" 2>/dev/null || echo "0")
|
|
65
|
-
j=0
|
|
66
|
-
while [ "$j" -lt "$KW_COUNT" ]; do
|
|
67
|
-
KW=$(jq -r ".rules[$i].keywords[$j]" "$RULES_FILE" 2>/dev/null)
|
|
68
|
-
if echo "$PROMPT_LOWER" | grep -qi -- "$KW" 2>/dev/null; then
|
|
69
|
-
SCORE=$((SCORE + 3))
|
|
70
|
-
fi
|
|
71
|
-
j=$((j + 1))
|
|
72
|
-
done
|
|
73
|
-
|
|
74
|
-
# Pattern matching (5 points each)
|
|
75
|
-
PAT_COUNT=$(jq ".rules[$i].patterns | length" "$RULES_FILE" 2>/dev/null || echo "0")
|
|
76
|
-
k=0
|
|
77
|
-
while [ "$k" -lt "$PAT_COUNT" ]; do
|
|
78
|
-
PAT=$(jq -r ".rules[$i].patterns[$k]" "$RULES_FILE" 2>/dev/null)
|
|
79
|
-
if [ -n "$PAT" ] && echo "$PROMPT_LOWER" | grep -qiE -- "$PAT" 2>/dev/null; then
|
|
80
|
-
SCORE=$((SCORE + 5))
|
|
81
|
-
fi
|
|
82
|
-
k=$((k + 1))
|
|
83
|
-
done
|
|
84
|
-
|
|
85
|
-
# Threshold check
|
|
86
|
-
if [ "$SCORE" -ge "$THRESHOLD" ]; then
|
|
87
|
-
MATCH_SKILLS+=("$SKILL")
|
|
88
|
-
MATCH_SCORES+=("$SCORE")
|
|
89
|
-
fi
|
|
90
|
-
|
|
91
|
-
i=$((i + 1))
|
|
92
|
-
done
|
|
93
|
-
|
|
94
|
-
# Sort by score descending and take top 3
|
|
95
|
-
SORTED_INDICES=""
|
|
96
|
-
if [ ${#MATCH_SKILLS[@]} -gt 0 ]; then
|
|
97
|
-
SORTED_INDICES=$(
|
|
98
|
-
for idx in "${!MATCH_SCORES[@]}"; do
|
|
99
|
-
echo "${MATCH_SCORES[$idx]} $idx"
|
|
100
|
-
done | sort -rn | head -3 | awk '{print $2}'
|
|
101
|
-
)
|
|
102
|
-
fi
|
|
103
|
-
|
|
104
|
-
# Extract Contract + Protocol + Verification sections from matched skills
|
|
105
|
-
INJECTION=""
|
|
106
|
-
CHAR_COUNT=0
|
|
107
|
-
MAX_CHARS=1500
|
|
108
|
-
|
|
109
|
-
for idx in $SORTED_INDICES; do
|
|
110
|
-
SKILL="${MATCH_SKILLS[$idx]}"
|
|
111
|
-
SKILL_FILE="$PROJECT_ROOT/.claude/skills/$SKILL/SKILL.md"
|
|
112
|
-
|
|
113
|
-
if [ ! -f "$SKILL_FILE" ]; then
|
|
114
|
-
continue
|
|
115
|
-
fi
|
|
116
|
-
|
|
117
|
-
# Extract key sections (Contract + Protocol + Verification)
|
|
118
|
-
SECTIONS=$(awk '
|
|
119
|
-
/^## Contract/ { capture=1; next }
|
|
120
|
-
/^## Protocol/ { capture=1; next }
|
|
121
|
-
/^## Verification/ { capture=1; next }
|
|
122
|
-
/^## / { capture=0 }
|
|
123
|
-
capture { print }
|
|
124
|
-
' "$SKILL_FILE" 2>/dev/null | head -20)
|
|
125
|
-
|
|
126
|
-
if [ -z "$SECTIONS" ]; then
|
|
127
|
-
continue
|
|
128
|
-
fi
|
|
129
|
-
|
|
130
|
-
# Append memory/ contents if exists (project-specific decisions)
|
|
131
|
-
MEMORY_DIR="$PROJECT_ROOT/.claude/skills/$SKILL/memory"
|
|
132
|
-
MEMORY_CONTENT=""
|
|
133
|
-
if [ -d "$MEMORY_DIR" ]; then
|
|
134
|
-
for MEM_FILE in "$MEMORY_DIR"/*.md; do
|
|
135
|
-
[ ! -f "$MEM_FILE" ] && continue
|
|
136
|
-
MEM_TEXT=$(head -10 "$MEM_FILE" 2>/dev/null || echo "")
|
|
137
|
-
if [ -n "$MEM_TEXT" ]; then
|
|
138
|
-
MEMORY_CONTENT="$MEMORY_CONTENT
|
|
139
|
-
$MEM_TEXT"
|
|
140
|
-
fi
|
|
141
|
-
done
|
|
142
|
-
fi
|
|
143
|
-
|
|
144
|
-
ENTRY="[Skill: $SKILL] $SECTIONS"
|
|
145
|
-
if [ -n "$MEMORY_CONTENT" ]; then
|
|
146
|
-
ENTRY="$ENTRY
|
|
147
|
-
[Memory] $MEMORY_CONTENT"
|
|
148
|
-
fi
|
|
149
|
-
ENTRY_LEN=${#ENTRY}
|
|
150
|
-
|
|
151
|
-
if [ $((CHAR_COUNT + ENTRY_LEN)) -gt "$MAX_CHARS" ]; then
|
|
152
|
-
break
|
|
153
|
-
fi
|
|
154
|
-
|
|
155
|
-
if [ -n "$INJECTION" ]; then
|
|
156
|
-
INJECTION="$INJECTION
|
|
157
|
-
---
|
|
158
|
-
$ENTRY"
|
|
159
|
-
else
|
|
160
|
-
INJECTION="$ENTRY"
|
|
161
|
-
fi
|
|
162
|
-
CHAR_COUNT=$((CHAR_COUNT + ENTRY_LEN))
|
|
163
|
-
done
|
|
164
|
-
|
|
165
|
-
# SSOT Map Tier 0 injection (always injected regardless of skill match)
|
|
166
|
-
SSOT_MAP="$PROJECT_ROOT/.timsquad/ssot-map.yaml"
|
|
167
|
-
if [ -f "$SSOT_MAP" ]; then
|
|
168
|
-
# Parse tier-0-always compiled paths from YAML
|
|
169
|
-
TIER0_PATHS=$(awk '
|
|
170
|
-
/^tier-0-always:/ { in_tier0=1; next }
|
|
171
|
-
/^tier-[0-9]/ { in_tier0=0 }
|
|
172
|
-
in_tier0 && /compiled:/ { gsub(/.*compiled: */, ""); gsub(/^ *| *$/, ""); print }
|
|
173
|
-
' "$SSOT_MAP" 2>/dev/null)
|
|
174
|
-
|
|
175
|
-
TIER0_CONTENT=""
|
|
176
|
-
while IFS= read -r REL_PATH; do
|
|
177
|
-
[ -z "$REL_PATH" ] && continue
|
|
178
|
-
COMPILED_FILE="$PROJECT_ROOT/.claude/skills/controller/$REL_PATH"
|
|
179
|
-
if [ -f "$COMPILED_FILE" ]; then
|
|
180
|
-
FILE_CONTENT=$(cat "$COMPILED_FILE" 2>/dev/null || echo "")
|
|
181
|
-
if [ -n "$FILE_CONTENT" ]; then
|
|
182
|
-
if [ -n "$TIER0_CONTENT" ]; then
|
|
183
|
-
TIER0_CONTENT="$TIER0_CONTENT
|
|
184
|
-
---
|
|
185
|
-
$FILE_CONTENT"
|
|
186
|
-
else
|
|
187
|
-
TIER0_CONTENT="$FILE_CONTENT"
|
|
188
|
-
fi
|
|
189
|
-
fi
|
|
190
|
-
fi
|
|
191
|
-
done <<< "$TIER0_PATHS"
|
|
192
|
-
|
|
193
|
-
if [ -n "$TIER0_CONTENT" ]; then
|
|
194
|
-
if [ -n "$INJECTION" ]; then
|
|
195
|
-
INJECTION="[SSOT Tier-0 Constraints]
|
|
196
|
-
$TIER0_CONTENT
|
|
197
|
-
---
|
|
198
|
-
$INJECTION"
|
|
199
|
-
else
|
|
200
|
-
INJECTION="[SSOT Tier-0 Constraints]
|
|
201
|
-
$TIER0_CONTENT"
|
|
202
|
-
fi
|
|
203
|
-
fi
|
|
204
|
-
fi
|
|
205
|
-
|
|
206
|
-
# Output as systemMessage (mandatory injection)
|
|
207
|
-
if [ -n "$INJECTION" ]; then
|
|
208
|
-
jq -n --arg msg "$INJECTION" '{
|
|
209
|
-
hookSpecificOutput: {
|
|
210
|
-
hookEventName: "UserPromptSubmit",
|
|
211
|
-
systemMessage: $msg
|
|
212
|
-
}
|
|
213
|
-
}'
|
|
214
|
-
fi
|
|
215
|
-
|
|
216
|
-
exit 0
|