timsquad 3.5.0 → 3.7.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/README.ko.md +103 -107
- package/README.md +100 -104
- package/dist/commands/daemon.d.ts.map +1 -1
- package/dist/commands/daemon.js +48 -2
- package/dist/commands/daemon.js.map +1 -1
- package/dist/commands/init.js +46 -14
- 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/context-writer.d.ts +14 -0
- package/dist/daemon/context-writer.d.ts.map +1 -1
- package/dist/daemon/context-writer.js +29 -0
- package/dist/daemon/context-writer.js.map +1 -1
- package/dist/daemon/event-queue.d.ts +7 -11
- package/dist/daemon/event-queue.d.ts.map +1 -1
- package/dist/daemon/event-queue.js +78 -118
- package/dist/daemon/event-queue.js.map +1 -1
- package/dist/daemon/file-watcher.d.ts +14 -8
- package/dist/daemon/file-watcher.d.ts.map +1 -1
- package/dist/daemon/file-watcher.js +78 -41
- package/dist/daemon/file-watcher.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 +54 -47
- package/dist/daemon/index.js.map +1 -1
- package/dist/index.js +3 -41
- package/dist/index.js.map +1 -1
- package/dist/lib/agent-generator.d.ts.map +1 -1
- package/dist/lib/agent-generator.js +21 -10
- package/dist/lib/agent-generator.js.map +1 -1
- package/dist/lib/compile-rules.d.ts +2 -0
- package/dist/lib/compile-rules.d.ts.map +1 -1
- package/dist/lib/compile-rules.js +39 -4
- package/dist/lib/compile-rules.js.map +1 -1
- package/dist/lib/compiler.d.ts +22 -1
- package/dist/lib/compiler.d.ts.map +1 -1
- package/dist/lib/compiler.js +178 -12
- package/dist/lib/compiler.js.map +1 -1
- package/dist/lib/config.d.ts +3 -0
- package/dist/lib/config.d.ts.map +1 -1
- package/dist/lib/config.js +17 -2
- package/dist/lib/config.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 +1 -1
- package/dist/lib/skill-generator.d.ts.map +1 -1
- package/dist/lib/skill-generator.js +19 -44
- package/dist/lib/skill-generator.js.map +1 -1
- package/dist/lib/ssot-map.d.ts +31 -0
- package/dist/lib/ssot-map.d.ts.map +1 -0
- package/dist/lib/ssot-map.js +79 -0
- package/dist/lib/ssot-map.js.map +1 -0
- package/dist/lib/template.d.ts +10 -3
- package/dist/lib/template.d.ts.map +1 -1
- package/dist/lib/template.js +137 -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/lib/workflow-state.d.ts +1 -1
- package/dist/lib/workflow-state.d.ts.map +1 -1
- package/dist/lib/workflow-state.js +1 -1
- package/dist/lib/workflow-state.js.map +1 -1
- package/dist/types/config.d.ts +10 -1
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.js +46 -41
- 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/index.d.ts +1 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/meta-index.d.ts +8 -0
- package/dist/types/meta-index.d.ts.map +1 -1
- package/dist/types/project.d.ts +6 -1
- 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 +30 -0
- package/dist/types/ssot-map.d.ts.map +1 -0
- package/dist/types/ssot-map.js +6 -0
- package/dist/types/ssot-map.js.map +1 -0
- 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 +45 -0
- 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/_shared/naming-conventions.md +49 -0
- package/templates/base/skills/_template/SKILL.md +31 -17
- 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/tsq-coding/SKILL.md +65 -0
- package/templates/base/skills/tsq-coding/rules/async-patterns.md +81 -0
- package/templates/base/skills/tsq-coding/rules/code-organization.md +80 -0
- package/templates/base/skills/tsq-coding/rules/error-handling.md +76 -0
- package/templates/base/skills/tsq-coding/rules/type-safety.md +85 -0
- package/templates/base/skills/tsq-controller/SKILL.md +81 -0
- package/templates/base/skills/tsq-controller/memory/.gitkeep +0 -0
- package/templates/base/skills/{mobile/dart → tsq-dart}/SKILL.md +5 -3
- package/templates/base/skills/{database → tsq-database}/SKILL.md +13 -27
- package/templates/base/skills/tsq-database/rules/query-optimization.md +32 -0
- package/templates/base/skills/tsq-database/rules/supabase-patterns.md +94 -0
- 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-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/tsq-product-audit/SKILL.md +113 -0
- package/templates/base/skills/tsq-product-audit/checklists/01-security.md +86 -0
- package/templates/base/skills/tsq-product-audit/checklists/02-performance.md +67 -0
- package/templates/base/skills/tsq-product-audit/checklists/03-seo.md +46 -0
- package/templates/base/skills/tsq-product-audit/checklists/04-accessibility.md +66 -0
- package/templates/base/skills/tsq-product-audit/checklists/05-ui-ux.md +50 -0
- package/templates/base/skills/tsq-product-audit/checklists/06-architecture.md +53 -0
- package/templates/base/skills/tsq-product-audit/checklists/07-functional-requirements.md +55 -0
- package/templates/base/skills/tsq-product-audit/rules/audit-protocol.md +136 -0
- package/templates/base/skills/tsq-product-audit/rules/false-positive-guard.md +81 -0
- package/templates/base/skills/tsq-product-audit/rules/scoring-criteria.md +113 -0
- package/templates/base/skills/tsq-product-audit/templates/improvement-plan-template.md +60 -0
- package/templates/base/skills/tsq-product-audit/templates/report-template.md +88 -0
- package/templates/base/skills/tsq-prompt/SKILL.md +86 -0
- package/templates/base/skills/tsq-protocol/SKILL.md +101 -33
- 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/tsq-retro/references/improvement-template.md +26 -0
- package/templates/base/skills/tsq-security/SKILL.md +66 -0
- package/templates/base/skills/tsq-security/rules/auth-patterns.md +62 -0
- package/templates/base/skills/tsq-security/rules/dependency-security.md +69 -0
- package/templates/base/skills/tsq-security/rules/input-validation.md +68 -0
- package/templates/base/skills/tsq-security/rules/secrets-management.md +65 -0
- package/templates/base/skills/tsq-spec/SKILL.md +58 -0
- 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 +12 -3
- package/templates/base/skills/tsq-testing/SKILL.md +69 -0
- package/templates/base/skills/tsq-testing/references/e2e-stability.md +33 -0
- package/templates/base/skills/{typescript → tsq-typescript}/SKILL.md +5 -11
- 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/test-spec.template.md +11 -1
- package/templates/base/timsquad/ssot/ui-ux-spec.template.md +43 -3
- package/templates/base/timsquad/ssot-map.template.yaml +69 -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/api-conventions.md +12 -0
- 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/librarian-constraints.md +11 -0
- 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/test-conventions.md +13 -0
- 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 +110 -0
- package/templates/platforms/claude-code/scripts/check-capability.sh +68 -0
- package/templates/platforms/claude-code/scripts/completion-guard.sh +134 -14
- package/templates/platforms/claude-code/scripts/context-restore.sh +95 -0
- package/templates/platforms/claude-code/scripts/e2e-commit-gate.sh +70 -0
- package/templates/platforms/claude-code/scripts/e2e-marker.sh +51 -0
- package/templates/platforms/claude-code/scripts/phase-guard.sh +3 -6
- package/templates/platforms/claude-code/scripts/pre-compact.sh +70 -0
- 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 +28 -56
- 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/compile.d.ts +0 -3
- package/dist/commands/compile.d.ts.map +0 -1
- package/dist/commands/compile.js +0 -170
- 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 -1436
- 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 -401
- 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 -828
- 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 -3
- package/dist/commands/workflow.d.ts.map +0 -1
- package/dist/commands/workflow.js +0 -607
- package/dist/commands/workflow.js.map +0 -1
- package/templates/base/skills/coding/SKILL.md +0 -47
- package/templates/base/skills/controller/SKILL.md +0 -111
- package/templates/base/skills/prompt-engineering/SKILL.md +0 -103
- package/templates/base/skills/retrospective/SKILL.md +0 -102
- package/templates/base/skills/security/SKILL.md +0 -55
- package/templates/base/skills/testing/SKILL.md +0 -63
- 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-rules.json +0 -85
- package/templates/platforms/claude-code/scripts/skill-suggest.sh +0 -105
- /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/patterns.md +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/{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/{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/{security → tsq-security}/rules/owasp-examples.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/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
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Audit Protocol
|
|
3
|
+
impact: HIGH
|
|
4
|
+
tags: audit, protocol, process
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Audit Protocol — 6단계 상세 절차
|
|
8
|
+
|
|
9
|
+
## Phase 1: Plan (감사 계획)
|
|
10
|
+
|
|
11
|
+
### 입력
|
|
12
|
+
- 프로젝트 코드베이스
|
|
13
|
+
- 이전 감사 리포트 (재감사 시)
|
|
14
|
+
- FP Registry (존재 시)
|
|
15
|
+
|
|
16
|
+
### 절차
|
|
17
|
+
|
|
18
|
+
1. **범위 결정**: 감사 대상 디렉토리, 모듈, 페이지 식별
|
|
19
|
+
2. **영역 선택**: 7개 영역 중 대상 선택 (전체 또는 부분)
|
|
20
|
+
3. **가중치 조정**: 프로젝트 타입에 따라 `scoring-criteria.md`의 가중치 조정
|
|
21
|
+
4. **기준 확인**: 각 영역의 체크리스트 버전 및 적용 기준 확인
|
|
22
|
+
5. **계획서 작성**: 아래 형식으로 작성
|
|
23
|
+
|
|
24
|
+
```markdown
|
|
25
|
+
## Audit Plan
|
|
26
|
+
|
|
27
|
+
- **일시**: {날짜}
|
|
28
|
+
- **범위**: {대상 모듈/페이지}
|
|
29
|
+
- **영역**: {선택된 영역 목록}
|
|
30
|
+
- **가중치**: {영역별 가중치}
|
|
31
|
+
- **도구**: {사용할 자동화 도구}
|
|
32
|
+
- **기준**: {gate 통과 기준}
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
6. **유저 컨펌**: 계획서를 유저에게 제시하고 승인 받은 후 진행
|
|
36
|
+
|
|
37
|
+
### 출력
|
|
38
|
+
- 승인된 감사 계획서
|
|
39
|
+
|
|
40
|
+
## Phase 2: Audit (감사 실행)
|
|
41
|
+
|
|
42
|
+
### 절차
|
|
43
|
+
|
|
44
|
+
1. **자동화 감사 실행** (가능한 영역)
|
|
45
|
+
|
|
46
|
+
| 영역 | 도구 | 측정 대상 |
|
|
47
|
+
|------|------|-----------|
|
|
48
|
+
| Security | eslint-plugin-security, npm audit, Snyk | 코드 패턴, 의존성 취약점 |
|
|
49
|
+
| Performance | Lighthouse, bundlesize | CWV, 번들 크기 |
|
|
50
|
+
| SEO | Lighthouse SEO, structured data validator | SEO 점수, 스키마 |
|
|
51
|
+
| Accessibility | axe-core, Lighthouse a11y | WCAG 위반 |
|
|
52
|
+
| Functional | test runner (vitest, jest, playwright) | 커버리지, 통과율 |
|
|
53
|
+
|
|
54
|
+
2. **수동 감사 실행** (자동화 불가 영역)
|
|
55
|
+
|
|
56
|
+
| 영역 | 방법 |
|
|
57
|
+
|------|------|
|
|
58
|
+
| UI/UX | Nielsen Heuristic 기반 코드 리뷰 |
|
|
59
|
+
| Architecture | 코드 구조, 의존성 그래프, 데이터 흐름 분석 |
|
|
60
|
+
| Requirements | 요구사항 ↔ 구현 ↔ 테스트 추적 |
|
|
61
|
+
|
|
62
|
+
3. **항목별 판정**
|
|
63
|
+
|
|
64
|
+
| 판정 | 의미 |
|
|
65
|
+
|------|------|
|
|
66
|
+
| pass | 기준 충족 |
|
|
67
|
+
| fail | 기준 미달 — severity 부여 |
|
|
68
|
+
| warning | 권고 사항 — 즉시 수정 불필요 |
|
|
69
|
+
| skip | 해당 없음 (근거 기재 필수) |
|
|
70
|
+
|
|
71
|
+
4. **source 명시**: 모든 항목에 `estimated` 또는 `measured` 표기
|
|
72
|
+
|
|
73
|
+
## Phase 3: Report (보고)
|
|
74
|
+
|
|
75
|
+
### 절차
|
|
76
|
+
|
|
77
|
+
1. 영역별 점수 산출 (`scoring-criteria.md` 기준)
|
|
78
|
+
2. 가중 평균으로 종합 점수 계산
|
|
79
|
+
3. Finding을 severity별 분류
|
|
80
|
+
4. 이전 감사 대비 diff 생성 (재감사 시)
|
|
81
|
+
5. `templates/report-template.md` 형식으로 보고서 작성
|
|
82
|
+
|
|
83
|
+
### 보고서 품질 기준
|
|
84
|
+
- `source` 필드 없는 항목 → 검증 실패
|
|
85
|
+
- `estimated` 비율 50% 초과 → 경고
|
|
86
|
+
- FP Registry 항목은 점수 산출에서 제외
|
|
87
|
+
|
|
88
|
+
## Phase 4: Remediation Plan (개선 계획)
|
|
89
|
+
|
|
90
|
+
### 절차
|
|
91
|
+
|
|
92
|
+
1. Finding을 severity 기준 내림차순 정렬
|
|
93
|
+
2. 각 finding에 대해:
|
|
94
|
+
- 원인 분석
|
|
95
|
+
- 수정 방법 제안 (코드 diff 포함)
|
|
96
|
+
- 예상 영향 범위
|
|
97
|
+
- 관련 테스트 식별
|
|
98
|
+
3. `templates/improvement-plan-template.md` 형식으로 작성
|
|
99
|
+
4. **유저 컨펌 필수** — 컨펌 없이 개선 실시 금지
|
|
100
|
+
|
|
101
|
+
### 우선순위 원칙
|
|
102
|
+
- Critical → 현재 Phase 내 즉시 수정
|
|
103
|
+
- High → 현재 Phase 내 수정
|
|
104
|
+
- Medium → 백로그 등록
|
|
105
|
+
- Low → 선택적
|
|
106
|
+
|
|
107
|
+
## Phase 5: Fix (개선 실시)
|
|
108
|
+
|
|
109
|
+
### 절차
|
|
110
|
+
|
|
111
|
+
1. 컨펌된 계획서의 항목을 순서대로 수정
|
|
112
|
+
2. 각 수정 후:
|
|
113
|
+
- 관련 단위 테스트 실행
|
|
114
|
+
- 수정이 다른 영역에 영향을 줄 경우 통합 테스트 실행
|
|
115
|
+
3. 전체 수정 완료 후:
|
|
116
|
+
- 전체 테스트 스위트 실행 (unit + integration)
|
|
117
|
+
- E2E 테스트 실행
|
|
118
|
+
4. 테스트 실패 시 → 수정 반복
|
|
119
|
+
5. 모든 테스트 통과 → Phase 6 진행
|
|
120
|
+
|
|
121
|
+
## Phase 6: Re-audit (재감사)
|
|
122
|
+
|
|
123
|
+
### 절차
|
|
124
|
+
|
|
125
|
+
1. Phase 2와 동일한 감사 절차 실행
|
|
126
|
+
2. 이전 결과와 항목별 diff 비교:
|
|
127
|
+
- `FAIL → PASS`: 개선됨
|
|
128
|
+
- `PASS → PASS`: 유지됨
|
|
129
|
+
- `PASS → FAIL`: 회귀 — 즉시 대응
|
|
130
|
+
- `FAIL → FAIL`: 미해결 — 원인 재분석
|
|
131
|
+
3. Gate 기준 충족 여부 판정:
|
|
132
|
+
- 종합 점수 >= 60점
|
|
133
|
+
- Critical 항목 0건
|
|
134
|
+
- PASS→FAIL 전환 0건
|
|
135
|
+
4. Gate 통과 → 감사 완료
|
|
136
|
+
5. Gate 미통과 → Phase 4로 복귀
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: False Positive Guard
|
|
3
|
+
impact: HIGH
|
|
4
|
+
tags: audit, false-positive, triage
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# False Positive Guard
|
|
8
|
+
|
|
9
|
+
## FP 관리 원칙
|
|
10
|
+
|
|
11
|
+
- False Positive로 등록된 항목은 재감사 시 자동 제외
|
|
12
|
+
- FP 등록 시 반드시 `reason`(근거)과 `verified_by`(검증 방법) 기재
|
|
13
|
+
- FP Registry는 프로젝트 단위로 유지, 감사 간 누적
|
|
14
|
+
|
|
15
|
+
## FP Registry 형식
|
|
16
|
+
|
|
17
|
+
```markdown
|
|
18
|
+
## FP Registry
|
|
19
|
+
|
|
20
|
+
| ID | 영역 | 항목 | Reason | Verified By | 등록일 |
|
|
21
|
+
|----|------|------|--------|-------------|--------|
|
|
22
|
+
| FP-001 | Security | SQL Injection in ORM query | ORM이 parameterized query 사용 | 코드 확인 | 2026-03-08 |
|
|
23
|
+
| FP-002 | A11y | Missing alt on decorative SVG | 장식용 아이콘, aria-hidden 적용 | axe-core 재검증 | 2026-03-08 |
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
## 계층적 검증 (Layered Verification)
|
|
27
|
+
|
|
28
|
+
FP 판정 전 3단계 검증을 거쳐 오탐을 최소화한다.
|
|
29
|
+
|
|
30
|
+
### Layer 1: 자동화 교차 검증
|
|
31
|
+
- 단일 도구의 결과만으로 fail 판정하지 않음
|
|
32
|
+
- 가능한 경우 2개 이상 도구로 교차 확인
|
|
33
|
+
- 예: eslint-plugin-security + npm audit 동시 플래그 → 높은 신뢰도
|
|
34
|
+
- 예: eslint만 플래그, npm audit 무반응 → FP 후보
|
|
35
|
+
|
|
36
|
+
### Layer 2: 컨텍스트 분석
|
|
37
|
+
- 플래그된 코드의 실제 실행 경로 확인
|
|
38
|
+
- 도달 불가능한 코드 경로의 취약점 → FP 후보
|
|
39
|
+
- 프레임워크/라이브러리가 이미 방어하는 패턴 → FP 후보
|
|
40
|
+
- 예: ORM의 parameterized query → SQL Injection FP
|
|
41
|
+
- 예: React의 자동 이스케이프 → XSS FP (단, dangerouslySetInnerHTML 제외)
|
|
42
|
+
|
|
43
|
+
### Layer 3: 수동 확인
|
|
44
|
+
- Layer 1, 2를 통과한 FP 후보에 대해 코드를 직접 확인
|
|
45
|
+
- 확인 결과를 `reason`에 구체적으로 기술
|
|
46
|
+
- 불확실한 경우 FP로 등록하지 않고 `warning`으로 유지
|
|
47
|
+
|
|
48
|
+
## FP 등록 규칙
|
|
49
|
+
|
|
50
|
+
### 등록 가능 조건
|
|
51
|
+
- 3단계 검증을 모두 통과한 경우
|
|
52
|
+
- 구체적 근거를 `reason`에 기술할 수 있는 경우
|
|
53
|
+
- 검증 방법을 `verified_by`에 명시할 수 있는 경우
|
|
54
|
+
|
|
55
|
+
### 등록 불가 조건
|
|
56
|
+
- "나중에 확인" 또는 "아마 괜찮을 것" 같은 모호한 근거
|
|
57
|
+
- Critical severity 항목 (Critical은 FP 등록 전 반드시 재현 시도)
|
|
58
|
+
- 검증 방법을 설명할 수 없는 경우
|
|
59
|
+
|
|
60
|
+
## FP 만료 정책
|
|
61
|
+
|
|
62
|
+
| 조건 | 처리 |
|
|
63
|
+
|------|------|
|
|
64
|
+
| 코드 변경으로 해당 영역 수정됨 | FP 자동 만료 → 재검증 필요 |
|
|
65
|
+
| 체크리스트 기준 버전 업데이트 | FP 재검토 필요 |
|
|
66
|
+
| 6개월 이상 미검토 | 만료 경고 |
|
|
67
|
+
|
|
68
|
+
## 보고서 내 FP 표기
|
|
69
|
+
|
|
70
|
+
FP 항목은 보고서에 별도 섹션으로 표기한다:
|
|
71
|
+
|
|
72
|
+
```markdown
|
|
73
|
+
### False Positives (점수 산출 제외)
|
|
74
|
+
|
|
75
|
+
| ID | 영역 | 항목 | Reason |
|
|
76
|
+
|----|------|------|--------|
|
|
77
|
+
| FP-001 | Security | SQL Injection in ORM query | ORM parameterized query 사용 확인 |
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
- FP 항목 수가 전체 항목의 20%를 초과하면 경고
|
|
81
|
+
- 이는 체크리스트 자체의 정확도 문제를 시사
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Scoring Criteria
|
|
3
|
+
impact: HIGH
|
|
4
|
+
tags: audit, scoring, metrics
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Scoring Criteria
|
|
8
|
+
|
|
9
|
+
## 스코어링 원칙
|
|
10
|
+
|
|
11
|
+
- **정량 70% + 정성 30%** 가중 평균
|
|
12
|
+
- 정량: 자동화 도구 결과, 메트릭 측정값 (source: measured)
|
|
13
|
+
- 정성: 코드 리뷰, 설계 판단 (source: estimated)
|
|
14
|
+
- 모든 점수는 0-100 스케일
|
|
15
|
+
|
|
16
|
+
## 영역별 기본 가중치
|
|
17
|
+
|
|
18
|
+
| # | 영역 | 기본 가중치 | 조정 범위 |
|
|
19
|
+
|---|------|:---------:|:---------:|
|
|
20
|
+
| 01 | Security | 25% | 15-35% |
|
|
21
|
+
| 02 | Performance | 15% | 10-25% |
|
|
22
|
+
| 03 | SEO | 10% | 5-15% |
|
|
23
|
+
| 04 | Accessibility | 10% | 5-20% |
|
|
24
|
+
| 05 | UI/UX | 10% | 5-15% |
|
|
25
|
+
| 06 | Architecture & DB | 15% | 10-25% |
|
|
26
|
+
| 07 | Functional & Requirements | 15% | 10-25% |
|
|
27
|
+
| | **합계** | **100%** | |
|
|
28
|
+
|
|
29
|
+
## 프로젝트 타입별 가중치 프리셋
|
|
30
|
+
|
|
31
|
+
### Web Service (기본)
|
|
32
|
+
기본 가중치 그대로 사용.
|
|
33
|
+
|
|
34
|
+
### Fintech / Healthcare
|
|
35
|
+
| 영역 | 가중치 |
|
|
36
|
+
|------|:------:|
|
|
37
|
+
| Security | 35% |
|
|
38
|
+
| Performance | 10% |
|
|
39
|
+
| SEO | 5% |
|
|
40
|
+
| Accessibility | 10% |
|
|
41
|
+
| UI/UX | 5% |
|
|
42
|
+
| Architecture & DB | 20% |
|
|
43
|
+
| Functional & Requirements | 15% |
|
|
44
|
+
|
|
45
|
+
### E-commerce
|
|
46
|
+
| 영역 | 가중치 |
|
|
47
|
+
|------|:------:|
|
|
48
|
+
| Security | 20% |
|
|
49
|
+
| Performance | 20% |
|
|
50
|
+
| SEO | 15% |
|
|
51
|
+
| Accessibility | 10% |
|
|
52
|
+
| UI/UX | 15% |
|
|
53
|
+
| Architecture & DB | 10% |
|
|
54
|
+
| Functional & Requirements | 10% |
|
|
55
|
+
|
|
56
|
+
### Internal Tool / Admin
|
|
57
|
+
| 영역 | 가중치 |
|
|
58
|
+
|------|:------:|
|
|
59
|
+
| Security | 20% |
|
|
60
|
+
| Performance | 10% |
|
|
61
|
+
| SEO | 5% |
|
|
62
|
+
| Accessibility | 10% |
|
|
63
|
+
| UI/UX | 10% |
|
|
64
|
+
| Architecture & DB | 20% |
|
|
65
|
+
| Functional & Requirements | 25% |
|
|
66
|
+
|
|
67
|
+
## 영역별 점수 산출
|
|
68
|
+
|
|
69
|
+
### 산출 공식
|
|
70
|
+
|
|
71
|
+
```
|
|
72
|
+
영역 점수 = (통과 항목 수 / 적용 항목 수) × 100
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
- `skip` 항목은 적용 항목에서 제외
|
|
76
|
+
- `warning` 항목은 0.5점 (pass = 1점, fail = 0점)
|
|
77
|
+
- FP Registry 등록 항목은 적용 항목에서 제외
|
|
78
|
+
|
|
79
|
+
### Severity 가중 감점
|
|
80
|
+
|
|
81
|
+
fail 항목은 severity에 따라 추가 감점:
|
|
82
|
+
|
|
83
|
+
| Severity | 감점 배수 |
|
|
84
|
+
|----------|:---------:|
|
|
85
|
+
| Critical | ×3 |
|
|
86
|
+
| High | ×2 |
|
|
87
|
+
| Medium | ×1 |
|
|
88
|
+
| Low | ×0.5 |
|
|
89
|
+
|
|
90
|
+
### 종합 점수 산출
|
|
91
|
+
|
|
92
|
+
```
|
|
93
|
+
종합 점수 = Σ(영역 점수 × 영역 가중치)
|
|
94
|
+
```
|
|
95
|
+
|
|
96
|
+
## Gate 기준
|
|
97
|
+
|
|
98
|
+
| 조건 | 기준 | 미충족 시 |
|
|
99
|
+
|------|:----:|-----------|
|
|
100
|
+
| Critical 항목 | 0건 | gate 차단 (점수 무관) |
|
|
101
|
+
| 종합 점수 | >= 60점 | gate 차단 |
|
|
102
|
+
| PASS→FAIL 전환 | 0건 | gate 차단 (재감사 시) |
|
|
103
|
+
| estimated 비율 | < 50% | 경고 (차단 아님) |
|
|
104
|
+
|
|
105
|
+
## 등급 분류
|
|
106
|
+
|
|
107
|
+
| 등급 | 점수 범위 | 의미 |
|
|
108
|
+
|:----:|:---------:|------|
|
|
109
|
+
| A | 90-100 | 우수 — 릴리스 가능 |
|
|
110
|
+
| B | 75-89 | 양호 — 경미한 개선 권장 |
|
|
111
|
+
| C | 60-74 | 보통 — gate 통과, 개선 필요 |
|
|
112
|
+
| D | 40-59 | 미흡 — gate 차단, 개선 필수 |
|
|
113
|
+
| F | 0-39 | 불합격 — 심각한 문제 존재 |
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Improvement Plan Template
|
|
3
|
+
category: template
|
|
4
|
+
source: internal
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Improvement Plan
|
|
8
|
+
|
|
9
|
+
## 개요
|
|
10
|
+
|
|
11
|
+
- **감사 보고서**: {보고서 참조}
|
|
12
|
+
- **작성일**: {날짜}
|
|
13
|
+
- **대상 Finding**: Critical {n}건, High {n}건
|
|
14
|
+
- **예상 영역**: {영향 받는 모듈/파일}
|
|
15
|
+
|
|
16
|
+
## 개선 항목
|
|
17
|
+
|
|
18
|
+
### IMP-001: {개선 제목}
|
|
19
|
+
|
|
20
|
+
- **Severity**: {Critical/High/Medium/Low}
|
|
21
|
+
- **영역**: {감사 영역}
|
|
22
|
+
- **Finding**: {항목 ID} — {문제 설명}
|
|
23
|
+
- **원인 분석**: {근본 원인}
|
|
24
|
+
- **수정 방법**:
|
|
25
|
+
|
|
26
|
+
```diff
|
|
27
|
+
- 현재 코드/설정
|
|
28
|
+
+ 개선된 코드/설정
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
- **영향 범위**: {변경으로 영향 받는 파일/모듈}
|
|
32
|
+
- **관련 테스트**: {실행할 테스트 목록}
|
|
33
|
+
- **예상 점수 변화**: {영역 점수 X → Y}
|
|
34
|
+
|
|
35
|
+
---
|
|
36
|
+
|
|
37
|
+
(항목 반복)
|
|
38
|
+
|
|
39
|
+
## 실행 순서
|
|
40
|
+
|
|
41
|
+
| 순서 | 항목 | Severity | 의존성 |
|
|
42
|
+
|:----:|------|:--------:|--------|
|
|
43
|
+
| 1 | IMP-{n} | Critical | 없음 |
|
|
44
|
+
| 2 | IMP-{n} | Critical | IMP-{n} 완료 후 |
|
|
45
|
+
| 3 | IMP-{n} | High | 없음 |
|
|
46
|
+
|
|
47
|
+
## 검증 계획
|
|
48
|
+
|
|
49
|
+
| 단계 | 실행 내용 |
|
|
50
|
+
|------|-----------|
|
|
51
|
+
| 1 | 각 IMP 수정 후 관련 단위 테스트 실행 |
|
|
52
|
+
| 2 | 전체 수정 완료 후 통합 테스트 실행 |
|
|
53
|
+
| 3 | E2E 테스트 실행 |
|
|
54
|
+
| 4 | 재감사 실시 (Phase 6) |
|
|
55
|
+
|
|
56
|
+
## 승인
|
|
57
|
+
|
|
58
|
+
- [ ] 개선 계획 검토 완료
|
|
59
|
+
- [ ] 실행 순서 합의
|
|
60
|
+
- [ ] 유저 컨펌
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Audit Report Template
|
|
3
|
+
category: template
|
|
4
|
+
source: internal
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Audit Report
|
|
8
|
+
|
|
9
|
+
## 개요
|
|
10
|
+
|
|
11
|
+
- **프로젝트**: {프로젝트명}
|
|
12
|
+
- **감사일**: {날짜}
|
|
13
|
+
- **범위**: {대상 모듈/페이지}
|
|
14
|
+
- **감사 유형**: 최초 감사 / 재감사
|
|
15
|
+
- **이전 감사일**: {재감사 시}
|
|
16
|
+
|
|
17
|
+
## 종합 결과
|
|
18
|
+
|
|
19
|
+
| 항목 | 값 |
|
|
20
|
+
|------|:--:|
|
|
21
|
+
| **종합 점수** | {점수}/100 |
|
|
22
|
+
| **등급** | {A/B/C/D/F} |
|
|
23
|
+
| **Gate 통과** | {PASS/FAIL} |
|
|
24
|
+
|
|
25
|
+
## 영역별 점수
|
|
26
|
+
|
|
27
|
+
| # | 영역 | 점수 | 가중치 | 가중 점수 |
|
|
28
|
+
|---|------|:----:|:------:|:---------:|
|
|
29
|
+
| 01 | Security | {점수} | {%} | {가중점수} |
|
|
30
|
+
| 02 | Performance | {점수} | {%} | {가중점수} |
|
|
31
|
+
| 03 | SEO | {점수} | {%} | {가중점수} |
|
|
32
|
+
| 04 | Accessibility | {점수} | {%} | {가중점수} |
|
|
33
|
+
| 05 | UI/UX | {점수} | {%} | {가중점수} |
|
|
34
|
+
| 06 | Architecture & DB | {점수} | {%} | {가중점수} |
|
|
35
|
+
| 07 | Functional & Requirements | {점수} | {%} | {가중점수} |
|
|
36
|
+
| | **합계** | | **100%** | **{종합}** |
|
|
37
|
+
|
|
38
|
+
## Severity 분포
|
|
39
|
+
|
|
40
|
+
| Severity | 건수 | 해결 | 미해결 |
|
|
41
|
+
|----------|:----:|:----:|:------:|
|
|
42
|
+
| Critical | {n} | {n} | {n} |
|
|
43
|
+
| High | {n} | {n} | {n} |
|
|
44
|
+
| Medium | {n} | {n} | {n} |
|
|
45
|
+
| Low | {n} | {n} | {n} |
|
|
46
|
+
|
|
47
|
+
## Findings
|
|
48
|
+
|
|
49
|
+
### Critical
|
|
50
|
+
|
|
51
|
+
| # | 영역 | 항목 | Source | 설명 |
|
|
52
|
+
|---|------|------|:------:|------|
|
|
53
|
+
| 1 | {영역} | {항목 ID} | {measured/estimated} | {상세 설명} |
|
|
54
|
+
|
|
55
|
+
### High
|
|
56
|
+
|
|
57
|
+
| # | 영역 | 항목 | Source | 설명 |
|
|
58
|
+
|---|------|------|:------:|------|
|
|
59
|
+
| 1 | {영역} | {항목 ID} | {measured/estimated} | {상세 설명} |
|
|
60
|
+
|
|
61
|
+
### Medium / Low
|
|
62
|
+
|
|
63
|
+
| # | 영역 | 항목 | Severity | Source | 설명 |
|
|
64
|
+
|---|------|------|:--------:|:------:|------|
|
|
65
|
+
| 1 | {영역} | {항목 ID} | {M/L} | {measured/estimated} | {상세 설명} |
|
|
66
|
+
|
|
67
|
+
## False Positives (점수 산출 제외)
|
|
68
|
+
|
|
69
|
+
| FP ID | 영역 | 항목 | Reason |
|
|
70
|
+
|-------|------|------|--------|
|
|
71
|
+
| FP-{n} | {영역} | {항목} | {근거} |
|
|
72
|
+
|
|
73
|
+
## 재감사 Diff (재감사 시)
|
|
74
|
+
|
|
75
|
+
| 변환 | 건수 | 비고 |
|
|
76
|
+
|------|:----:|------|
|
|
77
|
+
| FAIL → PASS | {n} | 개선됨 |
|
|
78
|
+
| PASS → PASS | {n} | 유지됨 |
|
|
79
|
+
| PASS → FAIL | {n} | 회귀 — 즉시 대응 |
|
|
80
|
+
| FAIL → FAIL | {n} | 미해결 |
|
|
81
|
+
|
|
82
|
+
## 품질 지표
|
|
83
|
+
|
|
84
|
+
| 지표 | 값 | 기준 |
|
|
85
|
+
|------|:--:|:----:|
|
|
86
|
+
| estimated 비율 | {%} | < 50% |
|
|
87
|
+
| FP 비율 | {%} | < 20% |
|
|
88
|
+
| 항목 적용률 | {%} | - |
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: tsq-prompt
|
|
3
|
+
description: |
|
|
4
|
+
에이전트/스킬 프롬프트 최적화, 템플릿 관리, 회고 기반 개선 가이드라인.
|
|
5
|
+
Use when: 프롬프트 작성·수정, 스킬 템플릿 작성, 회고에서 프롬프트 개선 대상이 발견됐을 때,
|
|
6
|
+
에이전트 응답 품질이 낮을 때, SKILL.md나 에이전트 .md 파일을 편집할 때.
|
|
7
|
+
version: "1.0.0"
|
|
8
|
+
tags: [tsq, prompt, optimization, retrospective]
|
|
9
|
+
user-invocable: false
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
# Prompt Engineering
|
|
13
|
+
|
|
14
|
+
에이전트와 스킬 프롬프트의 품질을 체계적으로 개선하기 위한 가이드라인.
|
|
15
|
+
|
|
16
|
+
## 최적화 원칙
|
|
17
|
+
|
|
18
|
+
### 구조화
|
|
19
|
+
역할 → 페르소나 → 작업 전 필수 → 핵심 원칙 → 작업 프로세스 → 출력 형식 → 금지 사항 → 예시
|
|
20
|
+
|
|
21
|
+
### 명확성
|
|
22
|
+
|
|
23
|
+
| Bad | Good |
|
|
24
|
+
|-----|------|
|
|
25
|
+
| "잘 작성해" | "3문장 이내로 요약해" |
|
|
26
|
+
| "좋은 코드" | "테스트 커버리지 80%" |
|
|
27
|
+
| 나열만 | "필수/권장/선택" 분류 |
|
|
28
|
+
|
|
29
|
+
모호한 표현은 측정 가능한 기준으로 바꾼다. 모델은 명확한 기준이 있을 때 더 일관된 결과를 낸다.
|
|
30
|
+
|
|
31
|
+
### 컨텍스트
|
|
32
|
+
프로젝트 정보, 참조 문서 경로, 제약 사항을 명시적으로 주입한다. 모델이 추측해야 하는 정보가 줄어들수록 정확도가 올라간다.
|
|
33
|
+
|
|
34
|
+
### 예시 포함
|
|
35
|
+
Good/Bad 예시를 함께 제공하여 기대 품질 수준을 명확화한다.
|
|
36
|
+
|
|
37
|
+
## 개선 매핑 프로세스
|
|
38
|
+
|
|
39
|
+
패턴에서 프롬프트 개선으로 이어지는 흐름:
|
|
40
|
+
|
|
41
|
+
1. 실패/성공 패턴 식별 (회고 스킬에서)
|
|
42
|
+
2. 대상 에이전트/스킬 .md 파일 특정
|
|
43
|
+
3. 변경 전/후 diff 작성
|
|
44
|
+
4. 기대 효과 및 검증 방법 명시
|
|
45
|
+
5. 사용자 승인 후 적용
|
|
46
|
+
|
|
47
|
+
## 품질 체크리스트
|
|
48
|
+
|
|
49
|
+
| 항목 | 검증 내용 |
|
|
50
|
+
|-----|----------|
|
|
51
|
+
| 명확성 | 모호한 표현이 없는가? |
|
|
52
|
+
| 완전성 | 필요한 정보가 모두 있는가? |
|
|
53
|
+
| 구조화 | 논리적 순서로 구성되었는가? |
|
|
54
|
+
| 예시 | Good/Bad 예시가 있는가? |
|
|
55
|
+
| 제약 | 금지 사항이 명시되었는가? |
|
|
56
|
+
| 출력 | 기대 출력 형식이 정의되었는가? |
|
|
57
|
+
|
|
58
|
+
## 템플릿 형식 (예시)
|
|
59
|
+
|
|
60
|
+
아래는 프롬프트 템플릿의 구조 예시입니다:
|
|
61
|
+
|
|
62
|
+
```markdown
|
|
63
|
+
---
|
|
64
|
+
name: {skill-name}
|
|
65
|
+
version: 1.0.0
|
|
66
|
+
agent: {target-agent}
|
|
67
|
+
task_type: {implementation|review|analysis}
|
|
68
|
+
---
|
|
69
|
+
|
|
70
|
+
# {Title}
|
|
71
|
+
|
|
72
|
+
## 컨텍스트 주입
|
|
73
|
+
{{CONTEXT}}
|
|
74
|
+
|
|
75
|
+
## 작업 정의
|
|
76
|
+
{{TASK_DESCRIPTION}}
|
|
77
|
+
|
|
78
|
+
## SSOT 참조
|
|
79
|
+
{{SSOT_REFERENCES}}
|
|
80
|
+
|
|
81
|
+
## 출력 요구사항
|
|
82
|
+
{{OUTPUT_REQUIREMENTS}}
|
|
83
|
+
|
|
84
|
+
## 검증 기준
|
|
85
|
+
{{VALIDATION_CRITERIA}}
|
|
86
|
+
```
|