timsquad 3.6.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 -111
- package/README.md +100 -108
- 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 +136 -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 +34 -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-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/{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
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
# [Feature Name] — Sub-PRD
|
|
2
|
+
|
|
3
|
+
**Parent PRD**: [prd.md](../prd.md)
|
|
4
|
+
**Created**: {{DATE}}
|
|
5
|
+
**Status**: Draft
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## 1. 기능 개요
|
|
10
|
+
|
|
11
|
+
### 1.1 목적
|
|
12
|
+
이 기능이 해결하는 문제:
|
|
13
|
+
|
|
14
|
+
### 1.2 사용자 스토리
|
|
15
|
+
> As a [사용자], I want [행동] so that [가치].
|
|
16
|
+
|
|
17
|
+
---
|
|
18
|
+
|
|
19
|
+
## 2. 요구사항
|
|
20
|
+
|
|
21
|
+
### 2.1 Must Have (P0)
|
|
22
|
+
| ID | 요건 | 성공 기준 |
|
|
23
|
+
|----|------|----------|
|
|
24
|
+
| | | |
|
|
25
|
+
|
|
26
|
+
### 2.2 Should Have (P1)
|
|
27
|
+
| ID | 요건 | 성공 기준 |
|
|
28
|
+
|----|------|----------|
|
|
29
|
+
| | | |
|
|
30
|
+
|
|
31
|
+
### 2.3 Nice to Have (P2)
|
|
32
|
+
| ID | 요건 |
|
|
33
|
+
|----|------|
|
|
34
|
+
| | |
|
|
35
|
+
|
|
36
|
+
---
|
|
37
|
+
|
|
38
|
+
## 3. 설계 결정
|
|
39
|
+
|
|
40
|
+
| 결정 | 선택지 | 결정 사항 | 이유 |
|
|
41
|
+
|------|--------|----------|------|
|
|
42
|
+
| | | | |
|
|
43
|
+
|
|
44
|
+
---
|
|
45
|
+
|
|
46
|
+
## 4. Mapped Artifacts
|
|
47
|
+
|
|
48
|
+
| Type | ID | Link |
|
|
49
|
+
|------|----|------|
|
|
50
|
+
| Requirement | FR-XXX-001~ | [requirements/xxx](../requirements/xxx.md) |
|
|
51
|
+
| Functional Spec | FS-XXX | [functional-spec/FS-XXX](../functional-spec/FS-XXX.md) |
|
|
52
|
+
| API Spec | xxx-api | [service-spec/xxx-api](../service-spec/xxx-api.md) |
|
|
53
|
+
| Screen | SCR-XXX | [ui-ux-spec/SCR-XXX](../ui-ux-spec/SCR-XXX.md) |
|
|
54
|
+
| Data | xxx tables | [data-design/xxx](../data-design/xxx.md) |
|
|
55
|
+
| Tasks | P?-S???-T???~ | [planning.md](../planning.md) |
|
|
56
|
+
|
|
57
|
+
---
|
|
58
|
+
|
|
59
|
+
## 5. 수용 기준 (Acceptance Criteria)
|
|
60
|
+
|
|
61
|
+
```gherkin
|
|
62
|
+
Feature: [Feature Name]
|
|
63
|
+
|
|
64
|
+
Scenario: [Happy Path]
|
|
65
|
+
Given [전제 조건]
|
|
66
|
+
When [행동]
|
|
67
|
+
Then [결과]
|
|
68
|
+
|
|
69
|
+
Scenario: [Exception Path]
|
|
70
|
+
Given [전제 조건]
|
|
71
|
+
When [예외 행동]
|
|
72
|
+
Then [에러 처리]
|
|
73
|
+
```
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
# {PROJECT_NAME} PRD
|
|
1
|
+
# {{PROJECT_NAME}} PRD
|
|
2
2
|
|
|
3
3
|
**Version**: 1.0
|
|
4
|
-
**Created**: {DATE}
|
|
4
|
+
**Created**: {{DATE}}
|
|
5
5
|
**Author**:
|
|
6
6
|
|
|
7
7
|
---
|
|
@@ -38,22 +38,15 @@
|
|
|
38
38
|
|
|
39
39
|
---
|
|
40
40
|
|
|
41
|
-
## 3.
|
|
41
|
+
## 3. 기능 인덱스
|
|
42
42
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|-----|------|----------|
|
|
46
|
-
| | | |
|
|
43
|
+
> 각 기능의 상세는 `prd/` 하위 Sub-PRD에 기술합니다.
|
|
44
|
+
> Level 1-2 프로젝트는 이 테이블에 직접 기술해도 됩니다.
|
|
47
45
|
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
| | | |
|
|
52
|
-
|
|
53
|
-
### 3.3 Nice to Have (P2)
|
|
54
|
-
| 기능 | 설명 |
|
|
55
|
-
|-----|------|
|
|
56
|
-
| | |
|
|
46
|
+
| Sub-PRD | 기능 | 우선순위 | 상태 | Link |
|
|
47
|
+
|---------|------|:--------:|:----:|------|
|
|
48
|
+
| auth | 인증/인가 | P0 | 🔲 | [prd/auth](./prd/auth.md) |
|
|
49
|
+
| | | | | |
|
|
57
50
|
|
|
58
51
|
---
|
|
59
52
|
|
|
@@ -91,12 +84,8 @@
|
|
|
91
84
|
|
|
92
85
|
---
|
|
93
86
|
|
|
94
|
-
## 7.
|
|
95
|
-
|
|
96
|
-
### 7.1 관련 문서
|
|
97
|
-
-
|
|
87
|
+
## 7. 용어 정의
|
|
98
88
|
|
|
99
|
-
### 7.2 용어 정의
|
|
100
89
|
| 용어 | 정의 |
|
|
101
90
|
|-----|------|
|
|
102
91
|
| | |
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
# {PROJECT_NAME} 요건 정의서
|
|
1
|
+
# {{PROJECT_NAME}} 요건 정의서
|
|
2
2
|
|
|
3
3
|
**Version**: 1.0
|
|
4
|
-
**Created**: {DATE}
|
|
4
|
+
**Created**: {{DATE}}
|
|
5
5
|
**PRD Reference**: [prd.md](./prd.md)
|
|
6
6
|
|
|
7
7
|
---
|
|
@@ -114,4 +114,4 @@
|
|
|
114
114
|
|
|
115
115
|
| 버전 | 날짜 | 변경 내용 | 작성자 |
|
|
116
116
|
|-----|-----|----------|-------|
|
|
117
|
-
| 1.0 | {DATE} | 최초 작성 | |
|
|
117
|
+
| 1.0 | {{DATE}} | 최초 작성 | |
|
|
@@ -0,0 +1,223 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "SDK 명세서 (SDK Specification)"
|
|
3
|
+
version: 1.0.0
|
|
4
|
+
last_updated: {{DATE}}
|
|
5
|
+
author: tsq-architect
|
|
6
|
+
status: draft
|
|
7
|
+
project: {{PROJECT_NAME}}
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# SDK 명세서 (SDK Specification)
|
|
11
|
+
|
|
12
|
+
> 외부 개발자가 사용하는 SDK/라이브러리의 공개 API, 사용법, 버전 정책을 정의합니다.
|
|
13
|
+
> 플랫폼/프레임워크 프로젝트에서 사용자 경험의 핵심 문서입니다.
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## 1. 개요
|
|
18
|
+
|
|
19
|
+
### 1.1 SDK 정보
|
|
20
|
+
|
|
21
|
+
| 항목 | 값 |
|
|
22
|
+
|-----|-----|
|
|
23
|
+
| 패키지명 | `@{{PROJECT_NAME}}/sdk` |
|
|
24
|
+
| 버전 | 1.0.0 |
|
|
25
|
+
| 지원 런타임 | Node.js 18+, Browser (ESM) |
|
|
26
|
+
| 번들 크기 | < 50KB (gzip) |
|
|
27
|
+
| 라이선스 | MIT |
|
|
28
|
+
|
|
29
|
+
### 1.2 설치
|
|
30
|
+
|
|
31
|
+
```bash
|
|
32
|
+
npm install @{{PROJECT_NAME}}/sdk
|
|
33
|
+
# or
|
|
34
|
+
yarn add @{{PROJECT_NAME}}/sdk
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
### 1.3 빠른 시작
|
|
38
|
+
|
|
39
|
+
```typescript
|
|
40
|
+
import { Client } from '@{{PROJECT_NAME}}/sdk';
|
|
41
|
+
|
|
42
|
+
const client = new Client({
|
|
43
|
+
apiKey: 'your-api-key',
|
|
44
|
+
baseUrl: 'https://api.example.com',
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
const result = await client.resource.list({ limit: 10 });
|
|
48
|
+
console.log(result.data);
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
---
|
|
52
|
+
|
|
53
|
+
## 2. 공개 API
|
|
54
|
+
|
|
55
|
+
### 2.1 Client
|
|
56
|
+
|
|
57
|
+
| 메서드 | 시그니처 | 설명 |
|
|
58
|
+
|-------|---------|------|
|
|
59
|
+
| `constructor` | `new Client(options: ClientOptions)` | 클라이언트 초기화 |
|
|
60
|
+
|
|
61
|
+
```typescript
|
|
62
|
+
interface ClientOptions {
|
|
63
|
+
apiKey: string;
|
|
64
|
+
baseUrl?: string; // default: 프로덕션 URL
|
|
65
|
+
timeout?: number; // default: 30000 (ms)
|
|
66
|
+
retries?: number; // default: 3
|
|
67
|
+
onError?: (error: SDKError) => void;
|
|
68
|
+
}
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
### 2.2 [Resource Name]
|
|
72
|
+
|
|
73
|
+
| 메서드 | 시그니처 | 설명 |
|
|
74
|
+
|-------|---------|------|
|
|
75
|
+
| `list` | `list(params?: ListParams): Promise<PaginatedResponse<T>>` | 목록 조회 |
|
|
76
|
+
| `get` | `get(id: string): Promise<T>` | 단건 조회 |
|
|
77
|
+
| `create` | `create(data: CreateInput): Promise<T>` | 생성 |
|
|
78
|
+
| `update` | `update(id: string, data: UpdateInput): Promise<T>` | 수정 |
|
|
79
|
+
| `delete` | `delete(id: string): Promise<void>` | 삭제 |
|
|
80
|
+
|
|
81
|
+
#### 사용 예시
|
|
82
|
+
|
|
83
|
+
```typescript
|
|
84
|
+
// 목록 조회 (페이지네이션)
|
|
85
|
+
const items = await client.resource.list({
|
|
86
|
+
page: 1,
|
|
87
|
+
limit: 20,
|
|
88
|
+
sort: 'createdAt',
|
|
89
|
+
order: 'desc',
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
// 단건 조회
|
|
93
|
+
const item = await client.resource.get('item_123');
|
|
94
|
+
|
|
95
|
+
// 생성
|
|
96
|
+
const newItem = await client.resource.create({
|
|
97
|
+
name: 'New Item',
|
|
98
|
+
description: 'Description',
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
// 수정
|
|
102
|
+
const updated = await client.resource.update('item_123', {
|
|
103
|
+
name: 'Updated Name',
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
// 삭제
|
|
107
|
+
await client.resource.delete('item_123');
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
---
|
|
111
|
+
|
|
112
|
+
## 3. 타입 정의
|
|
113
|
+
|
|
114
|
+
### 3.1 공통 타입
|
|
115
|
+
|
|
116
|
+
```typescript
|
|
117
|
+
interface PaginatedResponse<T> {
|
|
118
|
+
data: T[];
|
|
119
|
+
pagination: {
|
|
120
|
+
page: number;
|
|
121
|
+
limit: number;
|
|
122
|
+
total: number;
|
|
123
|
+
totalPages: number;
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
interface SDKError {
|
|
128
|
+
code: string;
|
|
129
|
+
message: string;
|
|
130
|
+
status: number;
|
|
131
|
+
details?: Record<string, unknown>;
|
|
132
|
+
}
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
### 3.2 리소스 타입
|
|
136
|
+
|
|
137
|
+
```typescript
|
|
138
|
+
interface Resource {
|
|
139
|
+
id: string;
|
|
140
|
+
name: string;
|
|
141
|
+
description: string;
|
|
142
|
+
createdAt: string;
|
|
143
|
+
updatedAt: string;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
interface CreateResourceInput {
|
|
147
|
+
name: string;
|
|
148
|
+
description?: string;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
interface UpdateResourceInput {
|
|
152
|
+
name?: string;
|
|
153
|
+
description?: string;
|
|
154
|
+
}
|
|
155
|
+
```
|
|
156
|
+
|
|
157
|
+
---
|
|
158
|
+
|
|
159
|
+
## 4. 에러 처리
|
|
160
|
+
|
|
161
|
+
### 4.1 에러 코드
|
|
162
|
+
|
|
163
|
+
| 코드 | HTTP | 설명 | 대응 |
|
|
164
|
+
|-----|:----:|------|------|
|
|
165
|
+
| `UNAUTHORIZED` | 401 | API 키 무효 | 키 확인 |
|
|
166
|
+
| `FORBIDDEN` | 403 | 권한 없음 | 권한 확인 |
|
|
167
|
+
| `NOT_FOUND` | 404 | 리소스 없음 | ID 확인 |
|
|
168
|
+
| `RATE_LIMITED` | 429 | 요청 제한 초과 | 재시도 (자동) |
|
|
169
|
+
| `SERVER_ERROR` | 500 | 서버 오류 | 재시도 (자동) |
|
|
170
|
+
|
|
171
|
+
### 4.2 에러 핸들링
|
|
172
|
+
|
|
173
|
+
```typescript
|
|
174
|
+
import { SDKError } from '@{{PROJECT_NAME}}/sdk';
|
|
175
|
+
|
|
176
|
+
try {
|
|
177
|
+
const item = await client.resource.get('invalid_id');
|
|
178
|
+
} catch (error) {
|
|
179
|
+
if (error instanceof SDKError) {
|
|
180
|
+
console.error(`[${error.code}] ${error.message}`);
|
|
181
|
+
// RATE_LIMITED인 경우 자동 재시도됨
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
---
|
|
187
|
+
|
|
188
|
+
## 5. 버전 정책
|
|
189
|
+
|
|
190
|
+
### 5.1 Semantic Versioning
|
|
191
|
+
|
|
192
|
+
| 변경 유형 | 버전 | 예시 |
|
|
193
|
+
|---------|------|------|
|
|
194
|
+
| Breaking change | Major (X.0.0) | 메서드 시그니처 변경 |
|
|
195
|
+
| 새 기능 | Minor (0.X.0) | 새 리소스 추가 |
|
|
196
|
+
| 버그 수정 | Patch (0.0.X) | 에러 수정 |
|
|
197
|
+
|
|
198
|
+
### 5.2 지원 정책
|
|
199
|
+
|
|
200
|
+
| 버전 | 상태 | 지원 종료 |
|
|
201
|
+
|-----|:----:|----------|
|
|
202
|
+
| v1.x | Active | - |
|
|
203
|
+
| v0.x | Deprecated | v1 출시 후 6개월 |
|
|
204
|
+
|
|
205
|
+
### 5.3 마이그레이션 가이드
|
|
206
|
+
|
|
207
|
+
Breaking change 시 마이그레이션 가이드를 `MIGRATION.md`에 제공합니다.
|
|
208
|
+
|
|
209
|
+
---
|
|
210
|
+
|
|
211
|
+
## 6. 관련 문서
|
|
212
|
+
|
|
213
|
+
- [서비스 명세](./service-spec.md) — 내부 API 상세
|
|
214
|
+
- [연동 명세](./integration-spec.md) — 외부 서비스 연동
|
|
215
|
+
- [에러 코드](./error-codes.md) — 전체 에러 코드
|
|
216
|
+
|
|
217
|
+
---
|
|
218
|
+
|
|
219
|
+
## 변경 이력
|
|
220
|
+
|
|
221
|
+
| 버전 | 날짜 | 작성자 | 변경 내용 |
|
|
222
|
+
|------|------|--------|----------|
|
|
223
|
+
| 1.0.0 | {{DATE}} | tsq-architect | 초기 작성 |
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
# {PROJECT_NAME} 서비스 명세서
|
|
1
|
+
# {{PROJECT_NAME}} 서비스 명세서
|
|
2
2
|
|
|
3
3
|
**Version**: 1.0
|
|
4
|
-
**Created**: {DATE}
|
|
4
|
+
**Created**: {{DATE}}
|
|
5
5
|
**Base URL**: `https://api.example.com/v1`
|
|
6
6
|
|
|
7
7
|
---
|
|
@@ -191,4 +191,4 @@
|
|
|
191
191
|
|
|
192
192
|
| 버전 | 날짜 | 변경 내용 | 작성자 |
|
|
193
193
|
|-----|-----|----------|-------|
|
|
194
|
-
| 1.0 | {DATE} | 최초 작성 | |
|
|
194
|
+
| 1.0 | {{DATE}} | 최초 작성 | |
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "상태 머신 명세서 (State Machine Specification)"
|
|
3
|
+
version: 1.0.0
|
|
4
|
+
last_updated: {{DATE}}
|
|
5
|
+
author: tsq-architect
|
|
6
|
+
status: draft
|
|
7
|
+
project: {{PROJECT_NAME}}
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# 상태 머신 명세서 (State Machine Specification)
|
|
11
|
+
|
|
12
|
+
> 시스템 내 주요 엔티티의 상태 전이(State Transition)를 정의합니다.
|
|
13
|
+
> 상태 전이 규칙, 가드 조건, 부수 효과를 명확히 하여 일관된 비즈니스 로직을 보장합니다.
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## 1. 개요
|
|
18
|
+
|
|
19
|
+
### 1.1 적용 대상
|
|
20
|
+
|
|
21
|
+
| 엔티티 | 상태 수 | 설명 |
|
|
22
|
+
|-------|:------:|------|
|
|
23
|
+
| Order | 6 | 주문 생명주기 |
|
|
24
|
+
| Payment | 5 | 결제 처리 흐름 |
|
|
25
|
+
| User | 4 | 사용자 계정 상태 |
|
|
26
|
+
|
|
27
|
+
### 1.2 용어
|
|
28
|
+
|
|
29
|
+
| 용어 | 설명 |
|
|
30
|
+
|-----|------|
|
|
31
|
+
| State | 엔티티가 가질 수 있는 상태 값 |
|
|
32
|
+
| Transition | 한 상태에서 다른 상태로의 전이 |
|
|
33
|
+
| Guard | 전이가 허용되는 조건 (사전 검증) |
|
|
34
|
+
| Action | 전이 시 실행되는 부수 효과 |
|
|
35
|
+
| Event | 전이를 트리거하는 외부/내부 이벤트 |
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## 2. [Entity Name] 상태 머신
|
|
40
|
+
|
|
41
|
+
### 2.1 상태 다이어그램
|
|
42
|
+
|
|
43
|
+
```
|
|
44
|
+
┌──────────┐
|
|
45
|
+
┌─────── │ CREATED │ ───────┐
|
|
46
|
+
│ └──────────┘ │
|
|
47
|
+
│ cancel │ confirm │ expire
|
|
48
|
+
▼ ▼ ▼
|
|
49
|
+
┌──────────┐ ┌──────────┐ ┌──────────┐
|
|
50
|
+
│ CANCELLED│ │ CONFIRMED│ │ EXPIRED │
|
|
51
|
+
└──────────┘ └─────┬────┘ └──────────┘
|
|
52
|
+
│ process
|
|
53
|
+
▼
|
|
54
|
+
┌──────────┐
|
|
55
|
+
│ COMPLETED│
|
|
56
|
+
└──────────┘
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
### 2.2 상태 정의
|
|
60
|
+
|
|
61
|
+
| 상태 | 코드 | 설명 | 진입 조건 |
|
|
62
|
+
|-----|------|------|----------|
|
|
63
|
+
| CREATED | `created` | 초기 생성 상태 | 생성 시 자동 |
|
|
64
|
+
| CONFIRMED | `confirmed` | 확인됨 | 검증 통과 |
|
|
65
|
+
| COMPLETED | `completed` | 처리 완료 | 모든 작업 완료 |
|
|
66
|
+
| CANCELLED | `cancelled` | 취소됨 | 사용자/시스템 취소 |
|
|
67
|
+
| EXPIRED | `expired` | 만료됨 | TTL 초과 |
|
|
68
|
+
|
|
69
|
+
### 2.3 전이 규칙
|
|
70
|
+
|
|
71
|
+
| From | Event | To | Guard | Action |
|
|
72
|
+
|------|-------|----|-------|--------|
|
|
73
|
+
| CREATED | `confirm` | CONFIRMED | 필수 필드 충족 | 알림 발송 |
|
|
74
|
+
| CREATED | `cancel` | CANCELLED | - | 관련 리소스 해제 |
|
|
75
|
+
| CREATED | `expire` | EXPIRED | TTL 초과 | 정리 작업 |
|
|
76
|
+
| CONFIRMED | `process` | COMPLETED | 처리 조건 충족 | 완료 알림 |
|
|
77
|
+
| CONFIRMED | `cancel` | CANCELLED | 취소 가능 기간 | 환불 처리 |
|
|
78
|
+
|
|
79
|
+
### 2.4 가드 조건 상세
|
|
80
|
+
|
|
81
|
+
| Guard | 로직 | 실패 시 |
|
|
82
|
+
|-------|------|--------|
|
|
83
|
+
| 필수 필드 충족 | `entity.requiredFields.every(f => !!f)` | 400 Bad Request |
|
|
84
|
+
| TTL 초과 | `now - entity.createdAt > TTL` | 스케줄러가 자동 전이 |
|
|
85
|
+
| 취소 가능 기간 | `now - entity.confirmedAt < CANCEL_WINDOW` | 409 Conflict |
|
|
86
|
+
|
|
87
|
+
### 2.5 부수 효과
|
|
88
|
+
|
|
89
|
+
| Action | 트리거 | 처리 | 실패 전략 |
|
|
90
|
+
|--------|-------|------|----------|
|
|
91
|
+
| 알림 발송 | confirm → CONFIRMED | 이메일/푸시 | 재시도 (3회) |
|
|
92
|
+
| 환불 처리 | cancel → CANCELLED | 결제 API 호출 | 수동 처리 큐 |
|
|
93
|
+
| 정리 작업 | expire → EXPIRED | 관련 데이터 정리 | 로그 + 재시도 |
|
|
94
|
+
|
|
95
|
+
---
|
|
96
|
+
|
|
97
|
+
## 3. 상태 전이 정합성
|
|
98
|
+
|
|
99
|
+
### 3.1 불변 규칙 (Invariants)
|
|
100
|
+
|
|
101
|
+
- [ ] 터미널 상태(COMPLETED, CANCELLED, EXPIRED)에서 다른 상태로 전이 불가
|
|
102
|
+
- [ ] 모든 전이는 감사 로그에 기록
|
|
103
|
+
- [ ] 동시 전이 충돌 시 낙관적 잠금(Optimistic Locking) 적용
|
|
104
|
+
|
|
105
|
+
### 3.2 동시성 처리
|
|
106
|
+
|
|
107
|
+
| 시나리오 | 해결 방법 |
|
|
108
|
+
|---------|----------|
|
|
109
|
+
| 동시 상태 변경 | 버전 기반 낙관적 잠금 |
|
|
110
|
+
| 이벤트 순서 역전 | 타임스탬프 검증 |
|
|
111
|
+
| 중복 이벤트 | 멱등성 키(idempotency key) |
|
|
112
|
+
|
|
113
|
+
---
|
|
114
|
+
|
|
115
|
+
## 4. 관련 문서
|
|
116
|
+
|
|
117
|
+
- [서비스 명세](./service-spec.md) — API 엔드포인트별 상태 변경
|
|
118
|
+
- [에러 코드](./error-codes.md) — 상태 전이 실패 에러 코드
|
|
119
|
+
- [데이터 설계](./data-design.md) — 상태 필드 스키마
|
|
120
|
+
|
|
121
|
+
---
|
|
122
|
+
|
|
123
|
+
## 변경 이력
|
|
124
|
+
|
|
125
|
+
| 버전 | 날짜 | 작성자 | 변경 내용 |
|
|
126
|
+
|------|------|--------|----------|
|
|
127
|
+
| 1.0.0 | {{DATE}} | tsq-architect | 초기 작성 |
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
title: "UI/UX 명세서"
|
|
3
3
|
version: 1.0.0
|
|
4
4
|
last_updated: {{DATE}}
|
|
5
|
-
author: tsq-
|
|
5
|
+
author: tsq-architect
|
|
6
6
|
status: draft
|
|
7
7
|
project: {{PROJECT_NAME}}
|
|
8
8
|
---
|
|
@@ -151,7 +151,47 @@ project: {{PROJECT_NAME}}
|
|
|
151
151
|
|
|
152
152
|
### SCR-002: [화면명]
|
|
153
153
|
|
|
154
|
-
|
|
154
|
+
#### 3.2.1 개요
|
|
155
|
+
|
|
156
|
+
| 항목 | 내용 |
|
|
157
|
+
|-----|------|
|
|
158
|
+
| **ID** | SCR-002 |
|
|
159
|
+
| **화면명** | |
|
|
160
|
+
| **경로** | |
|
|
161
|
+
| **관련 기능** | [FS-002](./functional-spec.md#FS-002) |
|
|
162
|
+
|
|
163
|
+
#### 3.2.2 와이어프레임
|
|
164
|
+
|
|
165
|
+
```
|
|
166
|
+
┌─────────────────────────────────────────────────┐
|
|
167
|
+
│ │
|
|
168
|
+
│ [와이어프레임 작성] │
|
|
169
|
+
│ │
|
|
170
|
+
└─────────────────────────────────────────────────┘
|
|
171
|
+
```
|
|
172
|
+
|
|
173
|
+
#### 3.2.3 UI 요소
|
|
174
|
+
|
|
175
|
+
| 요소 | 타입 | 설명 | 필수 |
|
|
176
|
+
|-----|------|------|:----:|
|
|
177
|
+
| | | | |
|
|
178
|
+
|
|
179
|
+
#### 3.2.4 상태별 UI
|
|
180
|
+
|
|
181
|
+
| 상태 | 설명 | UI 변화 |
|
|
182
|
+
|-----|------|--------|
|
|
183
|
+
| 기본 | | |
|
|
184
|
+
| 로딩 | | |
|
|
185
|
+
| 에러 | | |
|
|
186
|
+
| 성공 | | |
|
|
187
|
+
|
|
188
|
+
#### 3.2.5 반응형
|
|
189
|
+
|
|
190
|
+
| 브레이크포인트 | 레이아웃 변경 |
|
|
191
|
+
|--------------|-------------|
|
|
192
|
+
| Desktop (≥1024px) | |
|
|
193
|
+
| Tablet (768-1023px) | |
|
|
194
|
+
| Mobile (<768px) | |
|
|
155
195
|
|
|
156
196
|
---
|
|
157
197
|
|
|
@@ -259,4 +299,4 @@ graph LR
|
|
|
259
299
|
|
|
260
300
|
| 버전 | 날짜 | 작성자 | 변경 내용 |
|
|
261
301
|
|------|------|--------|----------|
|
|
262
|
-
| 1.0.0 | {{DATE}} | tsq-
|
|
302
|
+
| 1.0.0 | {{DATE}} | tsq-architect | 초기 작성 |
|
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
# Tier 1: Phase 시작 시 Controller가 주입
|
|
4
4
|
# Tier 2: Sequence 범위 문서 (Controller가 선택 주입)
|
|
5
5
|
# Tier 3: 개별 Task에 필요한 구체 spec (Controller가 선택 주입)
|
|
6
|
+
# optional: true → 타입별 선택 배포 문서 (미존재 시 건너뜀)
|
|
6
7
|
|
|
7
8
|
tier-0-always:
|
|
8
9
|
description: "모든 작업에 항상 주입되는 제약 문서"
|
|
@@ -21,6 +22,12 @@ tier-1-phase:
|
|
|
21
22
|
source: prd.md
|
|
22
23
|
- compiled: references/architecture.spec.md
|
|
23
24
|
source: planning.md
|
|
25
|
+
- compiled: references/compliance-matrix.spec.md
|
|
26
|
+
source: compliance-matrix.md
|
|
27
|
+
optional: true
|
|
28
|
+
- compiled: references/infra-topology.spec.md
|
|
29
|
+
source: infra-topology.md
|
|
30
|
+
optional: true
|
|
24
31
|
|
|
25
32
|
tier-2-sequence:
|
|
26
33
|
description: "Sequence 범위의 기능별 문서"
|
|
@@ -30,6 +37,21 @@ tier-2-sequence:
|
|
|
30
37
|
source: service-spec.md
|
|
31
38
|
- compiled: references/data-design.spec.md
|
|
32
39
|
source: data-design.md
|
|
40
|
+
- compiled: references/state-machine.spec.md
|
|
41
|
+
source: state-machine.md
|
|
42
|
+
optional: true
|
|
43
|
+
- compiled: references/performance-budget.spec.md
|
|
44
|
+
source: performance-budget.md
|
|
45
|
+
optional: true
|
|
46
|
+
- compiled: references/component-map.spec.md
|
|
47
|
+
source: component-map.md
|
|
48
|
+
optional: true
|
|
49
|
+
- compiled: references/navigation-map.spec.md
|
|
50
|
+
source: navigation-map.md
|
|
51
|
+
optional: true
|
|
52
|
+
- compiled: references/monitoring-spec.spec.md
|
|
53
|
+
source: monitoring-spec.md
|
|
54
|
+
optional: true
|
|
33
55
|
|
|
34
56
|
tier-3-task:
|
|
35
57
|
description: "개별 Task에 필요한 구체 spec"
|
|
@@ -39,3 +61,9 @@ tier-3-task:
|
|
|
39
61
|
source: error-codes.md
|
|
40
62
|
- compiled: references/functional.spec.md
|
|
41
63
|
source: functional-spec.md
|
|
64
|
+
- compiled: references/sdk-spec.spec.md
|
|
65
|
+
source: sdk-spec.md
|
|
66
|
+
optional: true
|
|
67
|
+
- compiled: references/audit-trail-spec.spec.md
|
|
68
|
+
source: audit-trail-spec.md
|
|
69
|
+
optional: true
|