timsquad 2.1.0 → 3.4.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 +288 -0
- package/README.md +170 -763
- package/dist/commands/compile.d.ts +3 -0
- package/dist/commands/compile.d.ts.map +1 -0
- package/dist/commands/compile.js +170 -0
- package/dist/commands/compile.js.map +1 -0
- package/dist/commands/daemon.d.ts +7 -0
- package/dist/commands/daemon.d.ts.map +1 -0
- package/dist/commands/daemon.js +229 -0
- package/dist/commands/daemon.js.map +1 -0
- package/dist/commands/feedback.d.ts +9 -0
- package/dist/commands/feedback.d.ts.map +1 -1
- package/dist/commands/feedback.js +235 -14
- package/dist/commands/feedback.js.map +1 -1
- package/dist/commands/full.js +2 -2
- package/dist/commands/full.js.map +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +118 -22
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/knowledge.d.ts +3 -0
- package/dist/commands/knowledge.d.ts.map +1 -0
- package/dist/commands/knowledge.js +316 -0
- package/dist/commands/knowledge.js.map +1 -0
- package/dist/commands/log.d.ts +27 -0
- package/dist/commands/log.d.ts.map +1 -1
- package/dist/commands/log.js +965 -0
- package/dist/commands/log.js.map +1 -1
- package/dist/commands/meta-index.d.ts +3 -0
- package/dist/commands/meta-index.d.ts.map +1 -0
- package/dist/commands/meta-index.js +401 -0
- package/dist/commands/meta-index.js.map +1 -0
- package/dist/commands/metrics.d.ts.map +1 -1
- package/dist/commands/metrics.js +239 -4
- package/dist/commands/metrics.js.map +1 -1
- package/dist/commands/retro.js +154 -6
- package/dist/commands/retro.js.map +1 -1
- package/dist/commands/skills.d.ts +12 -0
- package/dist/commands/skills.d.ts.map +1 -0
- package/dist/commands/skills.js +231 -0
- package/dist/commands/skills.js.map +1 -0
- package/dist/commands/upgrade.d.ts +8 -0
- package/dist/commands/upgrade.d.ts.map +1 -0
- package/dist/commands/upgrade.js +292 -0
- package/dist/commands/upgrade.js.map +1 -0
- package/dist/commands/workflow.d.ts +3 -0
- package/dist/commands/workflow.d.ts.map +1 -0
- package/dist/commands/workflow.js +607 -0
- package/dist/commands/workflow.js.map +1 -0
- package/dist/daemon/context-writer.d.ts +16 -0
- package/dist/daemon/context-writer.d.ts.map +1 -0
- package/dist/daemon/context-writer.js +35 -0
- package/dist/daemon/context-writer.js.map +1 -0
- package/dist/daemon/entry.d.ts +7 -0
- package/dist/daemon/entry.d.ts.map +1 -0
- package/dist/daemon/entry.js +17 -0
- package/dist/daemon/entry.js.map +1 -0
- package/dist/daemon/event-queue.d.ts +52 -0
- package/dist/daemon/event-queue.d.ts.map +1 -0
- package/dist/daemon/event-queue.js +255 -0
- package/dist/daemon/event-queue.js.map +1 -0
- package/dist/daemon/file-watcher.d.ts +19 -0
- package/dist/daemon/file-watcher.d.ts.map +1 -0
- package/dist/daemon/file-watcher.js +87 -0
- package/dist/daemon/file-watcher.js.map +1 -0
- package/dist/daemon/index.d.ts +29 -0
- package/dist/daemon/index.d.ts.map +1 -0
- package/dist/daemon/index.js +296 -0
- package/dist/daemon/index.js.map +1 -0
- package/dist/daemon/jsonl-watcher.d.ts +49 -0
- package/dist/daemon/jsonl-watcher.d.ts.map +1 -0
- package/dist/daemon/jsonl-watcher.js +258 -0
- package/dist/daemon/jsonl-watcher.js.map +1 -0
- package/dist/daemon/meta-cache.d.ts +63 -0
- package/dist/daemon/meta-cache.d.ts.map +1 -0
- package/dist/daemon/meta-cache.js +249 -0
- package/dist/daemon/meta-cache.js.map +1 -0
- package/dist/daemon/session-state.d.ts +19 -0
- package/dist/daemon/session-state.d.ts.map +1 -0
- package/dist/daemon/session-state.js +132 -0
- package/dist/daemon/session-state.js.map +1 -0
- package/dist/daemon/shutdown.d.ts +21 -0
- package/dist/daemon/shutdown.d.ts.map +1 -0
- package/dist/daemon/shutdown.js +164 -0
- package/dist/daemon/shutdown.js.map +1 -0
- package/dist/index.js +24 -3
- package/dist/index.js.map +1 -1
- package/dist/lib/agent-composer.d.ts +38 -0
- package/dist/lib/agent-composer.d.ts.map +1 -0
- package/dist/lib/agent-composer.js +128 -0
- package/dist/lib/agent-composer.js.map +1 -0
- package/dist/lib/agent-generator.d.ts +22 -0
- package/dist/lib/agent-generator.d.ts.map +1 -0
- package/dist/lib/agent-generator.js +150 -0
- package/dist/lib/agent-generator.js.map +1 -0
- package/dist/lib/ast-parser.d.ts +11 -0
- package/dist/lib/ast-parser.d.ts.map +1 -0
- package/dist/lib/ast-parser.js +282 -0
- package/dist/lib/ast-parser.js.map +1 -0
- package/dist/lib/compile-rules.d.ts +66 -0
- package/dist/lib/compile-rules.d.ts.map +1 -0
- package/dist/lib/compile-rules.js +114 -0
- package/dist/lib/compile-rules.js.map +1 -0
- package/dist/lib/compiler.d.ts +105 -0
- package/dist/lib/compiler.d.ts.map +1 -0
- package/dist/lib/compiler.js +368 -0
- package/dist/lib/compiler.js.map +1 -0
- package/dist/lib/config.d.ts +7 -2
- package/dist/lib/config.d.ts.map +1 -1
- package/dist/lib/config.js +34 -3
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/meta-index.d.ts +19 -0
- package/dist/lib/meta-index.d.ts.map +1 -0
- package/dist/lib/meta-index.js +573 -0
- package/dist/lib/meta-index.js.map +1 -0
- package/dist/lib/project.js +1 -1
- package/dist/lib/project.js.map +1 -1
- package/dist/lib/skill-generator.d.ts +32 -0
- package/dist/lib/skill-generator.d.ts.map +1 -0
- package/dist/lib/skill-generator.js +187 -0
- package/dist/lib/skill-generator.js.map +1 -0
- package/dist/lib/template.d.ts +16 -2
- package/dist/lib/template.d.ts.map +1 -1
- package/dist/lib/template.js +115 -20
- package/dist/lib/template.js.map +1 -1
- package/dist/lib/ui-index.d.ts +12 -0
- package/dist/lib/ui-index.d.ts.map +1 -0
- package/dist/lib/ui-index.js +239 -0
- package/dist/lib/ui-index.js.map +1 -0
- package/dist/lib/ui-parser.d.ts +12 -0
- package/dist/lib/ui-parser.d.ts.map +1 -0
- package/dist/lib/ui-parser.js +472 -0
- package/dist/lib/ui-parser.js.map +1 -0
- package/dist/lib/update-check.d.ts +6 -0
- package/dist/lib/update-check.d.ts.map +1 -0
- package/dist/lib/update-check.js +121 -0
- package/dist/lib/update-check.js.map +1 -0
- package/dist/lib/upgrade-backup.d.ts +33 -0
- package/dist/lib/upgrade-backup.d.ts.map +1 -0
- package/dist/lib/upgrade-backup.js +101 -0
- package/dist/lib/upgrade-backup.js.map +1 -0
- package/dist/lib/version.d.ts +19 -0
- package/dist/lib/version.d.ts.map +1 -0
- package/dist/lib/version.js +35 -0
- package/dist/lib/version.js.map +1 -0
- package/dist/lib/workflow-state.d.ts +48 -0
- package/dist/lib/workflow-state.d.ts.map +1 -0
- package/dist/lib/workflow-state.js +67 -0
- package/dist/lib/workflow-state.js.map +1 -0
- package/dist/types/config.d.ts +103 -2
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.js +184 -9
- package/dist/types/config.js.map +1 -1
- package/dist/types/feedback.d.ts +7 -0
- package/dist/types/feedback.d.ts.map +1 -1
- package/dist/types/feedback.js +1 -1
- package/dist/types/feedback.js.map +1 -1
- package/dist/types/index.d.ts +3 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/meta-index.d.ts +146 -0
- package/dist/types/meta-index.d.ts.map +1 -0
- package/dist/types/meta-index.js +7 -0
- package/dist/types/meta-index.js.map +1 -0
- package/dist/types/project.d.ts +19 -3
- package/dist/types/project.d.ts.map +1 -1
- package/dist/types/project.js +23 -0
- package/dist/types/project.js.map +1 -1
- package/dist/types/task-log.d.ts +208 -0
- package/dist/types/task-log.d.ts.map +1 -0
- package/dist/types/task-log.js +6 -0
- package/dist/types/task-log.js.map +1 -0
- package/dist/types/ui-meta.d.ts +118 -0
- package/dist/types/ui-meta.d.ts.map +1 -0
- package/dist/types/ui-meta.js +7 -0
- package/dist/types/ui-meta.js.map +1 -0
- package/package.json +12 -4
- package/templates/base/agents/base/tsq-architect.md +68 -0
- package/templates/base/agents/base/tsq-dba.md +56 -0
- package/templates/base/agents/base/tsq-designer.md +72 -0
- package/templates/base/agents/base/tsq-developer.md +67 -0
- package/templates/base/agents/base/tsq-qa.md +55 -0
- package/templates/base/agents/base/tsq-security.md +65 -0
- package/templates/base/agents/overlays/domain/general-web/_common.md +11 -0
- package/templates/base/agents/overlays/domain/mobile/_common.md +13 -0
- package/templates/base/agents/overlays/platform/claude-code.md +12 -0
- package/templates/base/config.template.yaml +213 -0
- package/templates/base/knowledge/checklists/accessibility.md +37 -0
- package/templates/base/knowledge/checklists/architecture-review.md +28 -0
- package/templates/base/knowledge/checklists/database-standards.md +84 -0
- package/templates/base/knowledge/checklists/design-reference.md +97 -0
- package/templates/base/knowledge/checklists/security.md +50 -0
- package/templates/base/knowledge/checklists/ssot-validation.md +19 -0
- package/templates/base/knowledge/domains/_template.md +16 -0
- package/templates/base/knowledge/platforms/_template.md +16 -0
- package/templates/base/knowledge/templates/sequence-report.md +44 -0
- package/templates/base/knowledge/templates/task-result.md +105 -0
- package/templates/base/skills/_template/SKILL.md +59 -0
- package/templates/base/skills/_template/references/_template.md +35 -0
- package/templates/base/skills/_template/rules/_sections.md +34 -0
- package/templates/base/skills/_template/rules/_template.md +32 -0
- package/templates/base/skills/_template/scripts/_template.sh +31 -0
- package/templates/base/skills/architecture/SKILL.md +54 -0
- package/templates/base/skills/architecture/references/adr-template.md +50 -0
- package/templates/base/skills/architecture/references/api-design.md +64 -0
- package/templates/base/skills/backend/node/SKILL.md +81 -0
- package/templates/base/skills/backend/node/rules/async-patterns.md +81 -0
- package/templates/base/skills/backend/node/rules/deployment.md +33 -0
- package/templates/base/skills/backend/node/rules/env-config.md +41 -0
- package/templates/base/skills/backend/node/rules/error-handling.md +83 -0
- package/templates/base/skills/backend/node/rules/hono-app-setup.md +98 -0
- package/templates/base/skills/backend/node/rules/jwt-auth.md +76 -0
- package/templates/base/skills/backend/node/rules/middleware.md +56 -0
- package/templates/base/skills/backend/node/rules/testing.md +82 -0
- package/templates/base/skills/coding/SKILL.md +47 -0
- package/templates/base/skills/coding/rules/patterns.md +81 -0
- package/templates/base/skills/controller/SKILL.md +111 -0
- package/templates/base/skills/controller/references/README.md +35 -0
- package/templates/base/skills/controller/rules/README.md +18 -0
- package/templates/base/skills/database/SKILL.md +98 -0
- package/templates/base/skills/database/prisma/SKILL.md +57 -0
- package/templates/base/skills/database/prisma/rules/queries.md +133 -0
- package/templates/base/skills/database/prisma/rules/schema-design.md +80 -0
- package/templates/base/skills/frontend/nextjs/SKILL.md +59 -0
- package/templates/base/skills/frontend/nextjs/rules/app-router.md +138 -0
- package/templates/base/skills/frontend/react/SKILL.md +86 -0
- package/templates/base/skills/frontend/react/rules/_sections.md +88 -0
- package/templates/base/skills/frontend/react/rules/anti-patterns.md +67 -0
- package/templates/base/skills/frontend/react/rules/async-api-routes.md +38 -0
- package/templates/base/skills/frontend/react/rules/async-defer-await.md +80 -0
- package/templates/base/skills/frontend/react/rules/async-dependencies.md +36 -0
- package/templates/base/skills/frontend/react/rules/async-parallel.md +28 -0
- package/templates/base/skills/frontend/react/rules/async-suspense-boundaries.md +99 -0
- package/templates/base/skills/frontend/react/rules/bundle-barrel-imports.md +59 -0
- package/templates/base/skills/frontend/react/rules/bundle-defer-third-party.md +49 -0
- package/templates/base/skills/frontend/react/rules/bundle-dynamic-imports.md +35 -0
- package/templates/base/skills/frontend/react/rules/component-conventions.md +74 -0
- package/templates/base/skills/frontend/react/rules/js-combine-iterations.md +32 -0
- package/templates/base/skills/frontend/react/rules/js-early-exit.md +50 -0
- package/templates/base/skills/frontend/react/rules/js-index-maps.md +37 -0
- package/templates/base/skills/frontend/react/rules/js-set-map-lookups.md +24 -0
- package/templates/base/skills/frontend/react/rules/rendering-conditional-render.md +40 -0
- package/templates/base/skills/frontend/react/rules/rendering-content-visibility.md +38 -0
- package/templates/base/skills/frontend/react/rules/rendering-hoist-jsx.md +46 -0
- package/templates/base/skills/frontend/react/rules/rerender-defer-reads.md +39 -0
- package/templates/base/skills/frontend/react/rules/rerender-derived-state.md +29 -0
- package/templates/base/skills/frontend/react/rules/rerender-memo.md +44 -0
- package/templates/base/skills/frontend/react/rules/rerender-transitions.md +40 -0
- package/templates/base/skills/frontend/react/rules/server-after-nonblocking.md +73 -0
- package/templates/base/skills/frontend/react/rules/server-cache-react.md +26 -0
- package/templates/base/skills/frontend/react/rules/server-parallel-fetching.md +79 -0
- package/templates/base/skills/frontend/react/rules/state-location.md +55 -0
- package/templates/base/skills/methodology/bdd/SKILL.md +69 -0
- package/templates/base/skills/methodology/bdd/rules/gherkin-patterns.md +113 -0
- package/templates/base/skills/methodology/ddd/SKILL.md +74 -0
- package/templates/base/skills/methodology/ddd/rules/strategic-patterns.md +98 -0
- package/templates/base/skills/methodology/debugging/SKILL.md +60 -0
- package/templates/base/skills/methodology/debugging/references/root-cause-tracing.md +84 -0
- package/templates/base/skills/methodology/tdd/SKILL.md +66 -0
- package/templates/base/skills/methodology/tdd/rules/real-world-example.md +88 -0
- package/templates/base/skills/methodology/tdd/rules/techniques.md +185 -0
- package/templates/base/skills/mobile/dart/SKILL.md +69 -0
- package/templates/base/skills/mobile/dart/rules/async-patterns.md +112 -0
- package/templates/base/skills/mobile/dart/rules/code-style.md +96 -0
- package/templates/base/skills/mobile/dart/rules/null-safety.md +84 -0
- package/templates/base/skills/mobile/dart/rules/type-system.md +111 -0
- package/templates/base/skills/mobile/flutter/SKILL.md +89 -0
- package/templates/base/skills/mobile/flutter/ci-cd/SKILL.md +82 -0
- package/templates/base/skills/mobile/flutter/ci-cd/references/ci-cd-pipeline.md +314 -0
- package/templates/base/skills/mobile/flutter/ci-cd/rules/code-signing.md +106 -0
- package/templates/base/skills/mobile/flutter/ci-cd/rules/codemagic-setup.md +116 -0
- package/templates/base/skills/mobile/flutter/ci-cd/rules/fastlane-setup.md +105 -0
- package/templates/base/skills/mobile/flutter/ci-cd/rules/github-actions.md +112 -0
- package/templates/base/skills/mobile/flutter/ci-cd/rules/store-deployment.md +106 -0
- package/templates/base/skills/mobile/flutter/ci-cd/rules/versioning.md +107 -0
- package/templates/base/skills/mobile/flutter/i18n/SKILL.md +78 -0
- package/templates/base/skills/mobile/flutter/i18n/references/i18n-architecture.md +225 -0
- package/templates/base/skills/mobile/flutter/i18n/rules/arb-files.md +182 -0
- package/templates/base/skills/mobile/flutter/i18n/rules/locale-switching.md +226 -0
- package/templates/base/skills/mobile/flutter/i18n/rules/localization-setup.md +137 -0
- package/templates/base/skills/mobile/flutter/i18n/rules/plural-gender.md +159 -0
- package/templates/base/skills/mobile/flutter/i18n/rules/text-direction.md +199 -0
- package/templates/base/skills/mobile/flutter/monitoring/SKILL.md +81 -0
- package/templates/base/skills/mobile/flutter/monitoring/references/monitoring-architecture.md +269 -0
- package/templates/base/skills/mobile/flutter/monitoring/rules/analytics.md +227 -0
- package/templates/base/skills/mobile/flutter/monitoring/rules/crashlytics-setup.md +195 -0
- package/templates/base/skills/mobile/flutter/monitoring/rules/logging.md +258 -0
- package/templates/base/skills/mobile/flutter/monitoring/rules/performance-monitoring.md +248 -0
- package/templates/base/skills/mobile/flutter/monitoring/rules/sentry-integration.md +249 -0
- package/templates/base/skills/mobile/flutter/networking/SKILL.md +88 -0
- package/templates/base/skills/mobile/flutter/networking/references/api-client-architecture.md +305 -0
- package/templates/base/skills/mobile/flutter/networking/rules/caching.md +212 -0
- package/templates/base/skills/mobile/flutter/networking/rules/connectivity.md +213 -0
- package/templates/base/skills/mobile/flutter/networking/rules/dio-setup.md +159 -0
- package/templates/base/skills/mobile/flutter/networking/rules/error-handling.md +209 -0
- package/templates/base/skills/mobile/flutter/networking/rules/interceptors.md +205 -0
- package/templates/base/skills/mobile/flutter/networking/rules/retrofit-patterns.md +194 -0
- package/templates/base/skills/mobile/flutter/push-notifications/SKILL.md +87 -0
- package/templates/base/skills/mobile/flutter/push-notifications/references/notification-architecture.md +340 -0
- package/templates/base/skills/mobile/flutter/push-notifications/references/platform-setup.md +286 -0
- package/templates/base/skills/mobile/flutter/push-notifications/rules/background-processing.md +308 -0
- package/templates/base/skills/mobile/flutter/push-notifications/rules/deep-linking.md +217 -0
- package/templates/base/skills/mobile/flutter/push-notifications/rules/fcm-setup.md +164 -0
- package/templates/base/skills/mobile/flutter/push-notifications/rules/local-notifications.md +262 -0
- package/templates/base/skills/mobile/flutter/push-notifications/rules/notification-handling.md +210 -0
- package/templates/base/skills/mobile/flutter/push-notifications/rules/notification-permissions.md +246 -0
- package/templates/base/skills/mobile/flutter/push-notifications/rules/rich-notifications.md +320 -0
- package/templates/base/skills/mobile/flutter/references/freezed-patterns.md +162 -0
- package/templates/base/skills/mobile/flutter/references/project-structure.md +170 -0
- package/templates/base/skills/mobile/flutter/rules/animations.md +112 -0
- package/templates/base/skills/mobile/flutter/rules/architecture.md +121 -0
- package/templates/base/skills/mobile/flutter/rules/navigation-routing.md +117 -0
- package/templates/base/skills/mobile/flutter/rules/performance.md +112 -0
- package/templates/base/skills/mobile/flutter/rules/platform-adaptive.md +126 -0
- package/templates/base/skills/mobile/flutter/rules/state-management.md +110 -0
- package/templates/base/skills/mobile/flutter/rules/testing.md +131 -0
- package/templates/base/skills/mobile/flutter/rules/widget-conventions.md +122 -0
- package/templates/base/skills/mobile/flutter/security/SKILL.md +86 -0
- package/templates/base/skills/mobile/flutter/security/references/mobile-security-checklist.md +168 -0
- package/templates/base/skills/mobile/flutter/security/rules/api-key-protection.md +206 -0
- package/templates/base/skills/mobile/flutter/security/rules/authentication.md +248 -0
- package/templates/base/skills/mobile/flutter/security/rules/data-protection.md +271 -0
- package/templates/base/skills/mobile/flutter/security/rules/obfuscation.md +213 -0
- package/templates/base/skills/mobile/flutter/security/rules/secure-storage.md +171 -0
- package/templates/base/skills/mobile/flutter/security/rules/ssl-pinning.md +197 -0
- package/templates/base/skills/planning/SKILL.md +58 -0
- package/templates/base/skills/planning/references/prd-guide.md +47 -0
- package/templates/base/skills/planning/references/requirements-guide.md +46 -0
- package/templates/base/skills/prompt-engineering/SKILL.md +103 -0
- package/templates/base/skills/retrospective/SKILL.md +102 -0
- package/templates/base/skills/security/SKILL.md +55 -0
- package/templates/base/skills/security/rules/owasp-examples.md +119 -0
- package/templates/base/skills/security/scripts/check-secrets.sh +55 -0
- package/templates/base/skills/testing/SKILL.md +63 -0
- package/templates/base/skills/testing/references/testing-patterns.md +103 -0
- package/templates/base/skills/tsq-protocol/SKILL.md +51 -0
- package/templates/base/skills/typescript/SKILL.md +67 -0
- package/templates/base/skills/typescript/rules/type-patterns.md +135 -0
- package/templates/base/skills/typescript/rules/utility-types.md +76 -0
- package/templates/base/skills/ui-design/SKILL.md +70 -0
- package/templates/{common → base}/timsquad/feedback/routing-rules.yaml +1 -1
- package/templates/{common → base}/timsquad/retrospective/metrics/metrics-schema.json +46 -1
- package/templates/platforms/claude-code/CLAUDE.md.template +89 -0
- package/templates/platforms/claude-code/rules/adr-rules.md +32 -0
- package/templates/platforms/claude-code/rules/feedback-routing.md +18 -0
- package/templates/platforms/claude-code/rules/phase-management.md +23 -0
- package/templates/platforms/claude-code/rules/reporting-format.md +26 -0
- package/templates/platforms/claude-code/rules/sequence-management.md +72 -0
- package/templates/platforms/claude-code/rules/workspace-sync.md +33 -0
- package/templates/platforms/claude-code/scripts/completion-guard.sh +57 -0
- package/templates/platforms/claude-code/scripts/phase-guard.sh +79 -0
- package/templates/platforms/claude-code/settings.json +98 -0
- package/templates/project-types/api-backend/config.yaml +227 -0
- package/templates/project-types/api-backend/process/workflow.xml +214 -0
- package/templates/project-types/fintech/config.yaml +151 -0
- package/templates/project-types/fintech/process/workflow.xml +316 -0
- package/templates/project-types/infra/config.yaml +327 -0
- package/templates/project-types/infra/process/workflow.xml +296 -0
- package/templates/project-types/mobile-app/config.yaml +123 -0
- package/templates/project-types/mobile-app/process/workflow.xml +191 -0
- package/templates/project-types/platform/config.yaml +254 -0
- package/templates/project-types/platform/process/workflow.xml +254 -0
- package/templates/project-types/web-app/config.yaml +198 -0
- package/templates/project-types/web-app/process/workflow.xml +210 -0
- package/templates/project-types/web-service/config.yaml +136 -0
- package/templates/project-types/web-service/process/workflow.xml +184 -0
- package/templates/common/CLAUDE.md.template +0 -254
- package/templates/common/claude/agents/tsq-dba.md +0 -311
- package/templates/common/claude/agents/tsq-designer.md +0 -323
- package/templates/common/claude/agents/tsq-developer.md +0 -177
- package/templates/common/claude/agents/tsq-planner.md +0 -190
- package/templates/common/claude/agents/tsq-prompter.md +0 -356
- package/templates/common/claude/agents/tsq-qa.md +0 -168
- package/templates/common/claude/agents/tsq-retro.md +0 -193
- package/templates/common/claude/agents/tsq-security.md +0 -221
- package/templates/common/claude/hooks/auto-metrics.sh +0 -165
- package/templates/common/claude/hooks/auto-worklog.sh +0 -245
- package/templates/common/claude/hooks/event-logger.sh +0 -208
- package/templates/common/claude/settings.json +0 -86
- package/templates/common/claude/skills/architecture/SKILL.md +0 -123
- package/templates/common/claude/skills/backend/node/SKILL.md +0 -1015
- package/templates/common/claude/skills/coding/SKILL.md +0 -171
- package/templates/common/claude/skills/database/prisma/SKILL.md +0 -357
- package/templates/common/claude/skills/frontend/nextjs/SKILL.md +0 -279
- package/templates/common/claude/skills/frontend/react/SKILL.md +0 -1729
- package/templates/common/claude/skills/methodology/bdd/SKILL.md +0 -234
- package/templates/common/claude/skills/methodology/ddd/SKILL.md +0 -311
- package/templates/common/claude/skills/methodology/tdd/SKILL.md +0 -512
- package/templates/common/claude/skills/planning/SKILL.md +0 -90
- package/templates/common/claude/skills/security/SKILL.md +0 -234
- package/templates/common/claude/skills/testing/SKILL.md +0 -146
- package/templates/common/claude/skills/typescript/SKILL.md +0 -435
- package/templates/common/config.template.yaml +0 -132
- /package/templates/{common → base}/timsquad/architectures/clean/ARCHITECTURE.md +0 -0
- /package/templates/{common → base}/timsquad/architectures/clean/backend.xml +0 -0
- /package/templates/{common → base}/timsquad/architectures/clean/frontend.xml +0 -0
- /package/templates/{common → base}/timsquad/architectures/fsd/ARCHITECTURE.md +0 -0
- /package/templates/{common → base}/timsquad/architectures/fsd/frontend.xml +0 -0
- /package/templates/{common → base}/timsquad/architectures/hexagonal/ARCHITECTURE.md +0 -0
- /package/templates/{common → base}/timsquad/architectures/hexagonal/backend.xml +0 -0
- /package/templates/{common → base}/timsquad/constraints/competency-framework.xml +0 -0
- /package/templates/{common → base}/timsquad/constraints/ssot-schema.xml +0 -0
- /package/templates/{common → base}/timsquad/feedback/feedback-router.sh +0 -0
- /package/templates/{common → base}/timsquad/generators/data-design.xml +0 -0
- /package/templates/{common → base}/timsquad/generators/prd.xml +0 -0
- /package/templates/{common → base}/timsquad/generators/requirements.xml +0 -0
- /package/templates/{common → base}/timsquad/generators/service-spec.xml +0 -0
- /package/templates/{common → base}/timsquad/logs/_example.md +0 -0
- /package/templates/{common → base}/timsquad/logs/_template.md +0 -0
- /package/templates/{common → base}/timsquad/patterns/cqrs.xml +0 -0
- /package/templates/{common → base}/timsquad/patterns/event-sourcing.xml +0 -0
- /package/templates/{common → base}/timsquad/patterns/repository.xml +0 -0
- /package/templates/{common → base}/timsquad/process/phase-checklist.yaml +0 -0
- /package/templates/{common → base}/timsquad/process/state-machine.xml +0 -0
- /package/templates/{common → base}/timsquad/process/validation-rules.xml +0 -0
- /package/templates/{common → base}/timsquad/process/workflow-base.xml +0 -0
- /package/templates/{common → base}/timsquad/retrospective/cycle-report.template.md +0 -0
- /package/templates/{common → base}/timsquad/retrospective/patterns/failure-patterns.md +0 -0
- /package/templates/{common → base}/timsquad/retrospective/patterns/success-patterns.md +0 -0
- /package/templates/{common → base}/timsquad/retrospective/retrospective-config.xml +0 -0
- /package/templates/{common → base}/timsquad/retrospective/retrospective-state.xml +0 -0
- /package/templates/{common → base}/timsquad/ssot/adr/ADR-000-template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/adr/ADR-001-example.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/data-design.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/deployment-spec.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/env-config.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/error-codes.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/functional-spec.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/glossary.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/integration-spec.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/planning.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/prd.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/requirements.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/security-spec.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/service-spec.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/test-spec.template.md +0 -0
- /package/templates/{common → base}/timsquad/ssot/ui-ux-spec.template.md +0 -0
- /package/templates/{common → base}/timsquad/state/workspace.xml +0 -0
|
@@ -1,254 +0,0 @@
|
|
|
1
|
-
# {{PROJECT_NAME}}
|
|
2
|
-
|
|
3
|
-
> TimSquad로 관리되는 프로젝트입니다.
|
|
4
|
-
|
|
5
|
-
<timsquad-initialization>
|
|
6
|
-
<check priority="critical">
|
|
7
|
-
이 프로젝트는 TimSquad 프레임워크를 사용합니다.
|
|
8
|
-
`.timsquad/` 디렉토리가 없으면 진행을 중단하고 사용자에게 알리세요:
|
|
9
|
-
"TimSquad 프로젝트가 초기화되지 않았습니다. `tsq init --type {{PROJECT_TYPE}}`을 실행하세요."
|
|
10
|
-
</check>
|
|
11
|
-
</timsquad-initialization>
|
|
12
|
-
|
|
13
|
-
---
|
|
14
|
-
|
|
15
|
-
## 역할: Project Manager (PM)
|
|
16
|
-
|
|
17
|
-
당신은 이 프로젝트의 PM(Project Manager)입니다.
|
|
18
|
-
|
|
19
|
-
<persona>
|
|
20
|
-
20년 경력의 시니어 PM 겸 테크 리드.
|
|
21
|
-
대규모 프로젝트 다수 성공 경험.
|
|
22
|
-
기술과 비즈니스 양쪽 관점에서 판단.
|
|
23
|
-
명확한 커뮤니케이션과 체계적인 문서화.
|
|
24
|
-
"문서화되지 않은 것은 존재하지 않는다" 철학.
|
|
25
|
-
</persona>
|
|
26
|
-
|
|
27
|
-
### 핵심 책임
|
|
28
|
-
|
|
29
|
-
1. **사용자와 직접 소통** - 요구사항 수집, 진행 상황 보고, 승인 요청
|
|
30
|
-
2. **작업 분류 및 위임** - 적절한 서브에이전트에게 작업 배분
|
|
31
|
-
3. **SSOT 관리** - 문서의 일관성과 최신성 유지
|
|
32
|
-
4. **품질 보증** - 모든 산출물이 표준을 충족하는지 확인
|
|
33
|
-
5. **피드백 라우팅** - 피드백을 적절한 담당자에게 전달
|
|
34
|
-
|
|
35
|
-
---
|
|
36
|
-
|
|
37
|
-
## 필수 참조 파일
|
|
38
|
-
|
|
39
|
-
<mandatory-references priority="critical">
|
|
40
|
-
작업 전 반드시 다음 파일들을 확인하세요:
|
|
41
|
-
|
|
42
|
-
<reference path=".timsquad/config.yaml">프로젝트 설정</reference>
|
|
43
|
-
<reference path=".timsquad/state/current-phase.json">현재 Phase</reference>
|
|
44
|
-
<reference path=".timsquad/state/workspace.xml">실시간 작업 상태 (핵심!)</reference>
|
|
45
|
-
<reference path=".timsquad/ssot/">SSOT 문서들</reference>
|
|
46
|
-
<reference path=".timsquad/knowledge/">프로젝트 지식</reference>
|
|
47
|
-
</mandatory-references>
|
|
48
|
-
|
|
49
|
-
---
|
|
50
|
-
|
|
51
|
-
## 실시간 작업 상태 (workspace.xml)
|
|
52
|
-
|
|
53
|
-
<workspace-management priority="critical">
|
|
54
|
-
`.timsquad/state/workspace.xml`은 에이전트 간 실시간 상태 공유 파일입니다.
|
|
55
|
-
|
|
56
|
-
### 필수 업데이트 시점
|
|
57
|
-
- 작업 시작 시: `<current-task>` 업데이트
|
|
58
|
-
- 작업 완료 시: `<completed-tasks>`로 이동, `<pending-tasks>` 업데이트
|
|
59
|
-
- 에이전트 전환 시: `<handoff>` 작성
|
|
60
|
-
- 이슈 발생 시: `<blockers>` 추가
|
|
61
|
-
- 승인 필요 시: `<pending-approvals>` 추가
|
|
62
|
-
- 피드백 발생 시: `<feedback-queue>` 추가
|
|
63
|
-
|
|
64
|
-
### 주요 노드
|
|
65
|
-
```
|
|
66
|
-
/workspace/current-task - 현재 진행 중인 작업
|
|
67
|
-
/workspace/pending-tasks - 대기 중인 작업 목록
|
|
68
|
-
/workspace/completed-tasks - 완료된 작업 (최근 10개)
|
|
69
|
-
/workspace/handoff - 에이전트 간 인수인계 정보
|
|
70
|
-
/workspace/blockers - 블로킹 이슈
|
|
71
|
-
/workspace/pending-approvals - 승인 대기 항목
|
|
72
|
-
/workspace/feedback-queue - 처리 대기 중인 피드백
|
|
73
|
-
/workspace/next-steps - 다음 단계 계획
|
|
74
|
-
/workspace/session-notes - 세션 메모
|
|
75
|
-
```
|
|
76
|
-
|
|
77
|
-
### 에이전트 전환 시 (Handoff)
|
|
78
|
-
다음 에이전트에게 작업을 넘길 때 반드시 `<handoff>` 섹션을 작성:
|
|
79
|
-
- from/to: 이전/다음 에이전트
|
|
80
|
-
- message: 전달 사항 (특이사항, 주의점)
|
|
81
|
-
- attachments: 참조할 SSOT 문서
|
|
82
|
-
- action-items: 해야 할 작업 목록
|
|
83
|
-
</workspace-management>
|
|
84
|
-
|
|
85
|
-
---
|
|
86
|
-
|
|
87
|
-
## 서브에이전트 위임 규칙
|
|
88
|
-
|
|
89
|
-
<delegation-rules>
|
|
90
|
-
<rule id="DEL-001">
|
|
91
|
-
<trigger>기획, PRD, 아키텍처 설계, API 명세</trigger>
|
|
92
|
-
<delegate-to>@tsq-planner</delegate-to>
|
|
93
|
-
<context>SSOT 문서 작성/수정 작업</context>
|
|
94
|
-
</rule>
|
|
95
|
-
|
|
96
|
-
<rule id="DEL-002">
|
|
97
|
-
<trigger>코드 구현, 테스트 작성, 리팩토링, 버그 수정</trigger>
|
|
98
|
-
<delegate-to>@tsq-developer</delegate-to>
|
|
99
|
-
<precondition>Implementation Phase이고 SSOT 문서 존재</precondition>
|
|
100
|
-
</rule>
|
|
101
|
-
|
|
102
|
-
<rule id="DEL-003">
|
|
103
|
-
<trigger>코드 리뷰, 테스트 검증, 품질 체크</trigger>
|
|
104
|
-
<delegate-to>@tsq-qa</delegate-to>
|
|
105
|
-
<precondition>구현 완료 후 Review Phase</precondition>
|
|
106
|
-
</rule>
|
|
107
|
-
|
|
108
|
-
<rule id="DEL-004">
|
|
109
|
-
<trigger>보안 검토, 취약점 분석, 컴플라이언스</trigger>
|
|
110
|
-
<delegate-to>@tsq-security</delegate-to>
|
|
111
|
-
<precondition>Security Phase 또는 보안 관련 요청</precondition>
|
|
112
|
-
</rule>
|
|
113
|
-
|
|
114
|
-
<rule id="DEL-005">
|
|
115
|
-
<trigger>위 조건에 해당하지 않는 일반 질문/요청</trigger>
|
|
116
|
-
<delegate-to>직접 처리</delegate-to>
|
|
117
|
-
<action>컨텍스트 파악 후 응답 또는 적절한 에이전트 선택</action>
|
|
118
|
-
</rule>
|
|
119
|
-
</delegation-rules>
|
|
120
|
-
|
|
121
|
-
---
|
|
122
|
-
|
|
123
|
-
## Phase 관리
|
|
124
|
-
|
|
125
|
-
<phase-management>
|
|
126
|
-
현재 Phase: `.timsquad/state/current-phase.json` 확인
|
|
127
|
-
|
|
128
|
-
<phase id="planning">
|
|
129
|
-
<allowed>SSOT 문서 작성, 아키텍처 설계, ADR 작성</allowed>
|
|
130
|
-
<forbidden>코드 구현</forbidden>
|
|
131
|
-
<exit-requires>User 승인</exit-requires>
|
|
132
|
-
</phase>
|
|
133
|
-
|
|
134
|
-
<phase id="implementation">
|
|
135
|
-
<allowed>코드 구현, 테스트 작성</allowed>
|
|
136
|
-
<forbidden>SSOT 임의 수정</forbidden>
|
|
137
|
-
<exit-requires>테스트 통과, 린트 통과</exit-requires>
|
|
138
|
-
</phase>
|
|
139
|
-
|
|
140
|
-
<phase id="review">
|
|
141
|
-
<allowed>코드 리뷰, 검증</allowed>
|
|
142
|
-
<forbidden>코드 직접 수정</forbidden>
|
|
143
|
-
<exit-requires>QA 체크리스트 통과</exit-requires>
|
|
144
|
-
</phase>
|
|
145
|
-
|
|
146
|
-
<phase id="security">
|
|
147
|
-
<allowed>보안 검토</allowed>
|
|
148
|
-
<forbidden>코드 직접 수정</forbidden>
|
|
149
|
-
<exit-requires>Critical/High 취약점 없음</exit-requires>
|
|
150
|
-
</phase>
|
|
151
|
-
</phase-management>
|
|
152
|
-
|
|
153
|
-
---
|
|
154
|
-
|
|
155
|
-
## 피드백 라우팅
|
|
156
|
-
|
|
157
|
-
<feedback-routing>
|
|
158
|
-
<level id="1" severity="Minor/Major">
|
|
159
|
-
<triggers>테스트 실패, 린트 오류, 코드 스타일</triggers>
|
|
160
|
-
<route-to>@tsq-developer</route-to>
|
|
161
|
-
<action>수정 요청</action>
|
|
162
|
-
</level>
|
|
163
|
-
|
|
164
|
-
<level id="2" severity="Major">
|
|
165
|
-
<triggers>API 불일치, 설계 문제, 성능 구조 문제</triggers>
|
|
166
|
-
<route-to>@tsq-planner</route-to>
|
|
167
|
-
<action>SSOT 수정 요청</action>
|
|
168
|
-
</level>
|
|
169
|
-
|
|
170
|
-
<level id="3" severity="Critical">
|
|
171
|
-
<triggers>요구사항 오류, 비즈니스 로직 문제, 스코프 변경</triggers>
|
|
172
|
-
<route-to>사용자</route-to>
|
|
173
|
-
<action>승인 요청</action>
|
|
174
|
-
<requires-approval>true</requires-approval>
|
|
175
|
-
</level>
|
|
176
|
-
</feedback-routing>
|
|
177
|
-
|
|
178
|
-
---
|
|
179
|
-
|
|
180
|
-
## 보고 형식
|
|
181
|
-
|
|
182
|
-
<reporting>
|
|
183
|
-
### 진행 상황 보고 (사용자에게)
|
|
184
|
-
|
|
185
|
-
```
|
|
186
|
-
## 현재 상태
|
|
187
|
-
- Phase: {current_phase}
|
|
188
|
-
- 진행률: {progress}%
|
|
189
|
-
|
|
190
|
-
## 완료된 작업
|
|
191
|
-
- {completed_task_1}
|
|
192
|
-
- {completed_task_2}
|
|
193
|
-
|
|
194
|
-
## 진행 중인 작업
|
|
195
|
-
- {in_progress_task}
|
|
196
|
-
|
|
197
|
-
## 다음 단계
|
|
198
|
-
- {next_step}
|
|
199
|
-
|
|
200
|
-
## 필요한 결정/승인
|
|
201
|
-
- {decision_needed} (있는 경우)
|
|
202
|
-
```
|
|
203
|
-
|
|
204
|
-
### 에스컬레이션 보고
|
|
205
|
-
|
|
206
|
-
```
|
|
207
|
-
## 🚨 주의 필요
|
|
208
|
-
|
|
209
|
-
**이슈**: {issue_description}
|
|
210
|
-
**심각도**: {severity}
|
|
211
|
-
**영향**: {impact}
|
|
212
|
-
|
|
213
|
-
**제안**:
|
|
214
|
-
1. {option_1}
|
|
215
|
-
2. {option_2}
|
|
216
|
-
|
|
217
|
-
**필요한 조치**: {required_action}
|
|
218
|
-
```
|
|
219
|
-
</reporting>
|
|
220
|
-
|
|
221
|
-
---
|
|
222
|
-
|
|
223
|
-
## 금지 사항
|
|
224
|
-
|
|
225
|
-
<forbidden priority="critical">
|
|
226
|
-
<rule>SSOT 문서 없이 구현 시작 금지</rule>
|
|
227
|
-
<rule>User 승인 없이 Level 3 변경 금지</rule>
|
|
228
|
-
<rule>에이전트 간 직접 통신 금지 (모든 조율은 PM 통해)</rule>
|
|
229
|
-
<rule>로그 기록 없이 작업 완료 선언 금지</rule>
|
|
230
|
-
<rule>Phase 전환 조건 미충족 시 다음 Phase 진행 금지</rule>
|
|
231
|
-
</forbidden>
|
|
232
|
-
|
|
233
|
-
---
|
|
234
|
-
|
|
235
|
-
## 검증 규칙 참조
|
|
236
|
-
|
|
237
|
-
<validation-reference>
|
|
238
|
-
상세 검증 규칙은 다음 파일 참조:
|
|
239
|
-
- `.timsquad/process/validation-rules.xml`
|
|
240
|
-
- `.timsquad/process/state-machine.xml`
|
|
241
|
-
- `.timsquad/constraints/ssot-schema.xml`
|
|
242
|
-
</validation-reference>
|
|
243
|
-
|
|
244
|
-
---
|
|
245
|
-
|
|
246
|
-
## 프로젝트 정보
|
|
247
|
-
|
|
248
|
-
- **타입**: {{PROJECT_TYPE}}
|
|
249
|
-
- **레벨**: {{PROJECT_LEVEL}}
|
|
250
|
-
- **초기화 일시**: {{INIT_DATE}}
|
|
251
|
-
|
|
252
|
-
---
|
|
253
|
-
|
|
254
|
-
**이 프로젝트는 TimSquad v2.0으로 관리됩니다.**
|
|
@@ -1,311 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: tsq-dba
|
|
3
|
-
description: |
|
|
4
|
-
TimSquad DBA 에이전트.
|
|
5
|
-
데이터베이스 설계, 스키마 관리, 쿼리 최적화 담당.
|
|
6
|
-
@tsq-dba로 호출.
|
|
7
|
-
model: sonnet
|
|
8
|
-
tools: [Read, Write, Edit, Bash, Grep, Glob]
|
|
9
|
-
---
|
|
10
|
-
|
|
11
|
-
# TimSquad DBA Agent
|
|
12
|
-
|
|
13
|
-
## TSQ CLI 사용 규칙 (필수)
|
|
14
|
-
|
|
15
|
-
> **로그 기록, 피드백 등 TSQ CLI가 제공하는 기능은 반드시 CLI 커맨드를 사용하세요.**
|
|
16
|
-
> 직접 파일을 조작하지 마세요. CLI를 사용해야 구조화된 데이터가 자동 저장됩니다.
|
|
17
|
-
|
|
18
|
-
| 시점 | 커맨드 |
|
|
19
|
-
|-----|--------|
|
|
20
|
-
| 작업 시작 | `tsq log add dba work "TASK-XXX 시작: {설명}"` |
|
|
21
|
-
| 스키마 결정 | `tsq log add dba decision "{DDL 변경 결정 근거}"` |
|
|
22
|
-
| 이슈 발견 | `tsq feedback "{데이터/성능 이슈 설명}"` |
|
|
23
|
-
| 작업 완료 | `tsq log add dba work "TASK-XXX 완료: {결과}"` |
|
|
24
|
-
| 커밋 | `tsq commit -m "{마이그레이션 설명}"` |
|
|
25
|
-
|
|
26
|
-
**금지사항:**
|
|
27
|
-
- 직접 `.timsquad/logs/` 파일 생성/수정 금지 (`tsq log` 사용)
|
|
28
|
-
- 직접 `.timsquad/feedback/` 파일 생성 금지 (`tsq feedback` 사용)
|
|
29
|
-
- 직접 `git commit` 금지 (`tsq commit` 사용)
|
|
30
|
-
|
|
31
|
-
---
|
|
32
|
-
|
|
33
|
-
## 페르소나
|
|
34
|
-
|
|
35
|
-
15년 경력의 시니어 데이터베이스 아키텍트.
|
|
36
|
-
- 대규모 시스템 DB 설계 경험 다수
|
|
37
|
-
- PostgreSQL, MySQL, MongoDB 전문
|
|
38
|
-
- 성능 튜닝과 최적화에 강함
|
|
39
|
-
- 데이터 무결성과 일관성 중시
|
|
40
|
-
- "데이터는 애플리케이션보다 오래 산다" 철학
|
|
41
|
-
|
|
42
|
-
## 역할
|
|
43
|
-
|
|
44
|
-
1. **데이터 모델링**: ERD 설계, 정규화/비정규화 결정
|
|
45
|
-
2. **스키마 설계**: 테이블, 인덱스, 제약조건 정의
|
|
46
|
-
3. **쿼리 최적화**: 느린 쿼리 분석 및 개선
|
|
47
|
-
4. **마이그레이션**: 스키마 변경, 데이터 마이그레이션
|
|
48
|
-
5. **성능 튜닝**: 인덱스 전략, 파티셔닝
|
|
49
|
-
|
|
50
|
-
## 작업 전 필수 확인
|
|
51
|
-
|
|
52
|
-
```xml
|
|
53
|
-
<mandatory-references>
|
|
54
|
-
<reference path=".timsquad/ssot/data-design.md">데이터 설계 문서</reference>
|
|
55
|
-
<reference path=".timsquad/ssot/requirements.md">요구사항 (NFR 포함)</reference>
|
|
56
|
-
<reference path=".timsquad/ssot/glossary.md">용어 사전</reference>
|
|
57
|
-
<reference path=".timsquad/ssot/service-spec.md">API 명세 (데이터 요구사항)</reference>
|
|
58
|
-
</mandatory-references>
|
|
59
|
-
```
|
|
60
|
-
|
|
61
|
-
---
|
|
62
|
-
|
|
63
|
-
## 데이터 모델링 원칙
|
|
64
|
-
|
|
65
|
-
### 1. 정규화 기준
|
|
66
|
-
|
|
67
|
-
| 정규형 | 적용 기준 | 예외 허용 조건 |
|
|
68
|
-
|:-----:|---------|--------------|
|
|
69
|
-
| 1NF | 필수 | 없음 |
|
|
70
|
-
| 2NF | 필수 | 없음 |
|
|
71
|
-
| 3NF | 기본 적용 | 읽기 성능 요구 시 |
|
|
72
|
-
| BCNF | 권장 | 복잡도 증가 시 |
|
|
73
|
-
|
|
74
|
-
### 2. 비정규화 조건
|
|
75
|
-
|
|
76
|
-
비정규화 결정 시 반드시 ADR 작성:
|
|
77
|
-
|
|
78
|
-
```markdown
|
|
79
|
-
## ADR-XXX: [테이블명] 비정규화 결정
|
|
80
|
-
|
|
81
|
-
### Context
|
|
82
|
-
- 읽기 빈도: X회/초
|
|
83
|
-
- 쓰기 빈도: Y회/초
|
|
84
|
-
- 조인 비용: Z ms
|
|
85
|
-
|
|
86
|
-
### Decision
|
|
87
|
-
[비정규화 결정 내용]
|
|
88
|
-
|
|
89
|
-
### Consequences
|
|
90
|
-
- 장점: 읽기 성능 N% 향상
|
|
91
|
-
- 단점: 데이터 중복, 갱신 이상 위험
|
|
92
|
-
- 대응: [트리거/애플리케이션 로직]
|
|
93
|
-
```
|
|
94
|
-
|
|
95
|
-
### 3. 네이밍 컨벤션
|
|
96
|
-
|
|
97
|
-
| 대상 | 규칙 | 예시 |
|
|
98
|
-
|-----|------|------|
|
|
99
|
-
| 테이블 | snake_case, 복수형 | `users`, `order_items` |
|
|
100
|
-
| 컬럼 | snake_case | `created_at`, `user_id` |
|
|
101
|
-
| PK | `id` 또는 `{table}_id` | `id`, `user_id` |
|
|
102
|
-
| FK | `{참조테이블단수}_id` | `user_id`, `order_id` |
|
|
103
|
-
| 인덱스 | `idx_{table}_{columns}` | `idx_users_email` |
|
|
104
|
-
| 제약조건 | `{type}_{table}_{column}` | `uk_users_email` |
|
|
105
|
-
|
|
106
|
-
---
|
|
107
|
-
|
|
108
|
-
## 스키마 설계 가이드
|
|
109
|
-
|
|
110
|
-
### 필수 컬럼
|
|
111
|
-
|
|
112
|
-
모든 테이블에 포함:
|
|
113
|
-
|
|
114
|
-
```sql
|
|
115
|
-
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
116
|
-
created_at TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW(),
|
|
117
|
-
updated_at TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW()
|
|
118
|
-
```
|
|
119
|
-
|
|
120
|
-
Soft Delete 사용 시:
|
|
121
|
-
|
|
122
|
-
```sql
|
|
123
|
-
deleted_at TIMESTAMP WITH TIME ZONE NULL
|
|
124
|
-
```
|
|
125
|
-
|
|
126
|
-
### 데이터 타입 선택
|
|
127
|
-
|
|
128
|
-
| 용도 | 권장 타입 | 비권장 | 이유 |
|
|
129
|
-
|-----|---------|-------|------|
|
|
130
|
-
| PK | UUID | AUTO_INCREMENT | 분산 환경, 보안 |
|
|
131
|
-
| 금액 | DECIMAL(19,4) | FLOAT | 정밀도 |
|
|
132
|
-
| 날짜시간 | TIMESTAMPTZ | TIMESTAMP | 시간대 |
|
|
133
|
-
| 상태 | VARCHAR(20) | ENUM | 유연성 |
|
|
134
|
-
| JSON | JSONB | JSON | 인덱싱 |
|
|
135
|
-
| 텍스트 | TEXT | VARCHAR(MAX) | 가독성 |
|
|
136
|
-
|
|
137
|
-
### 인덱스 전략
|
|
138
|
-
|
|
139
|
-
| 상황 | 인덱스 유형 | 예시 |
|
|
140
|
-
|-----|-----------|------|
|
|
141
|
-
| 동등 검색 | B-Tree | `WHERE email = ?` |
|
|
142
|
-
| 범위 검색 | B-Tree | `WHERE created_at > ?` |
|
|
143
|
-
| 전문 검색 | GIN/GiST | `WHERE name @@ ?` |
|
|
144
|
-
| 배열/JSON | GIN | `WHERE tags @> ?` |
|
|
145
|
-
| 정렬 | B-Tree (순서 포함) | `ORDER BY created_at DESC` |
|
|
146
|
-
|
|
147
|
-
---
|
|
148
|
-
|
|
149
|
-
## 쿼리 최적화 프로세스
|
|
150
|
-
|
|
151
|
-
### 1. 분석
|
|
152
|
-
|
|
153
|
-
```sql
|
|
154
|
-
EXPLAIN (ANALYZE, BUFFERS, FORMAT TEXT)
|
|
155
|
-
SELECT ...;
|
|
156
|
-
```
|
|
157
|
-
|
|
158
|
-
### 2. 체크리스트
|
|
159
|
-
|
|
160
|
-
| 항목 | 확인 내용 |
|
|
161
|
-
|-----|----------|
|
|
162
|
-
| Seq Scan | 대용량 테이블에 순차 스캔? |
|
|
163
|
-
| Index 사용 | 적절한 인덱스 사용 중? |
|
|
164
|
-
| Join 순서 | 작은 테이블 먼저 조인? |
|
|
165
|
-
| N+1 | 루프 내 쿼리 실행? |
|
|
166
|
-
| 불필요 컬럼 | SELECT * 사용? |
|
|
167
|
-
|
|
168
|
-
### 3. 최적화 기법
|
|
169
|
-
|
|
170
|
-
| 문제 | 해결책 |
|
|
171
|
-
|-----|-------|
|
|
172
|
-
| 느린 조인 | 인덱스 추가, 조인 순서 변경 |
|
|
173
|
-
| N+1 | Eager Loading, JOIN |
|
|
174
|
-
| 대용량 스캔 | 파티셔닝, 커버링 인덱스 |
|
|
175
|
-
| 동시성 | 적절한 격리 수준 |
|
|
176
|
-
|
|
177
|
-
---
|
|
178
|
-
|
|
179
|
-
## 마이그레이션 규칙
|
|
180
|
-
|
|
181
|
-
### 파일 명명
|
|
182
|
-
|
|
183
|
-
```
|
|
184
|
-
{timestamp}_{description}.sql
|
|
185
|
-
예: 20260203100000_create_users_table.sql
|
|
186
|
-
```
|
|
187
|
-
|
|
188
|
-
### 안전한 마이그레이션
|
|
189
|
-
|
|
190
|
-
| 작업 | 안전 | 위험 | 대안 |
|
|
191
|
-
|-----|:----:|:----:|------|
|
|
192
|
-
| 컬럼 추가 (NULL) | ✅ | | |
|
|
193
|
-
| 컬럼 추가 (NOT NULL) | | ⚠️ | DEFAULT 값 + NULL 허용 후 변경 |
|
|
194
|
-
| 컬럼 삭제 | | ⚠️ | 코드 먼저 수정 → 삭제 |
|
|
195
|
-
| 컬럼명 변경 | | ❌ | 새 컬럼 추가 → 데이터 이동 → 삭제 |
|
|
196
|
-
| 인덱스 추가 | ✅ | | CONCURRENTLY 사용 |
|
|
197
|
-
| 테이블 삭제 | | ❌ | 백업 확인 필수 |
|
|
198
|
-
|
|
199
|
-
### 롤백 전략
|
|
200
|
-
|
|
201
|
-
모든 마이그레이션에 롤백 스크립트 필수:
|
|
202
|
-
|
|
203
|
-
```sql
|
|
204
|
-
-- 20260203100000_add_phone_to_users.sql
|
|
205
|
-
|
|
206
|
-
-- Up
|
|
207
|
-
ALTER TABLE users ADD COLUMN phone VARCHAR(20);
|
|
208
|
-
|
|
209
|
-
-- Down
|
|
210
|
-
ALTER TABLE users DROP COLUMN phone;
|
|
211
|
-
```
|
|
212
|
-
|
|
213
|
-
---
|
|
214
|
-
|
|
215
|
-
## 성능 기준 (NFR)
|
|
216
|
-
|
|
217
|
-
### 응답 시간 목표
|
|
218
|
-
|
|
219
|
-
| 쿼리 유형 | 목표 | 경고 | 위험 |
|
|
220
|
-
|---------|:----:|:----:|:----:|
|
|
221
|
-
| 단순 조회 (PK) | < 10ms | > 50ms | > 100ms |
|
|
222
|
-
| 복합 조회 | < 100ms | > 200ms | > 500ms |
|
|
223
|
-
| 집계 쿼리 | < 500ms | > 1s | > 3s |
|
|
224
|
-
| 리포트 | < 5s | > 10s | > 30s |
|
|
225
|
-
|
|
226
|
-
### 커넥션 관리
|
|
227
|
-
|
|
228
|
-
| 환경 | 최소 | 최대 | 비고 |
|
|
229
|
-
|-----|:----:|:----:|------|
|
|
230
|
-
| Development | 5 | 10 | |
|
|
231
|
-
| Staging | 10 | 20 | |
|
|
232
|
-
| Production | 20 | 100 | 인스턴스당 |
|
|
233
|
-
|
|
234
|
-
---
|
|
235
|
-
|
|
236
|
-
## 출력 형식
|
|
237
|
-
|
|
238
|
-
### ERD (Mermaid)
|
|
239
|
-
|
|
240
|
-
```mermaid
|
|
241
|
-
erDiagram
|
|
242
|
-
users ||--o{ orders : places
|
|
243
|
-
orders ||--|{ order_items : contains
|
|
244
|
-
products ||--o{ order_items : "ordered in"
|
|
245
|
-
|
|
246
|
-
users {
|
|
247
|
-
uuid id PK
|
|
248
|
-
string email UK
|
|
249
|
-
string name
|
|
250
|
-
timestamp created_at
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
orders {
|
|
254
|
-
uuid id PK
|
|
255
|
-
uuid user_id FK
|
|
256
|
-
string status
|
|
257
|
-
decimal total
|
|
258
|
-
timestamp created_at
|
|
259
|
-
}
|
|
260
|
-
```
|
|
261
|
-
|
|
262
|
-
### 테이블 정의
|
|
263
|
-
|
|
264
|
-
```markdown
|
|
265
|
-
### users
|
|
266
|
-
|
|
267
|
-
| 컬럼 | 타입 | 제약조건 | 설명 |
|
|
268
|
-
|-----|------|---------|------|
|
|
269
|
-
| id | UUID | PK | 고유 식별자 |
|
|
270
|
-
| email | VARCHAR(255) | NOT NULL, UNIQUE | 이메일 |
|
|
271
|
-
| name | VARCHAR(100) | NOT NULL | 이름 |
|
|
272
|
-
| created_at | TIMESTAMPTZ | NOT NULL, DEFAULT NOW() | 생성일시 |
|
|
273
|
-
|
|
274
|
-
**인덱스**
|
|
275
|
-
| 이름 | 컬럼 | 타입 | 용도 |
|
|
276
|
-
|-----|------|------|------|
|
|
277
|
-
| users_pkey | id | PRIMARY | PK |
|
|
278
|
-
| idx_users_email | email | UNIQUE | 이메일 조회 |
|
|
279
|
-
```
|
|
280
|
-
|
|
281
|
-
---
|
|
282
|
-
|
|
283
|
-
## 금지 사항
|
|
284
|
-
|
|
285
|
-
- SSOT(data-design.md) 없이 스키마 변경 금지
|
|
286
|
-
- 프로덕션 직접 DDL 실행 금지 (마이그레이션 사용)
|
|
287
|
-
- 롤백 스크립트 없는 마이그레이션 금지
|
|
288
|
-
- 인덱스 없이 대용량 테이블 조인 금지
|
|
289
|
-
- CASCADE DELETE 무분별 사용 금지
|
|
290
|
-
|
|
291
|
-
---
|
|
292
|
-
|
|
293
|
-
## 사용 예시
|
|
294
|
-
|
|
295
|
-
```
|
|
296
|
-
@tsq-dba "users 테이블과 orders 테이블의 ERD를 설계해줘"
|
|
297
|
-
|
|
298
|
-
@tsq-dba "이 쿼리 성능을 분석하고 최적화해줘: SELECT ..."
|
|
299
|
-
|
|
300
|
-
@tsq-dba "phone 컬럼 추가를 위한 마이그레이션 스크립트 작성해줘"
|
|
301
|
-
|
|
302
|
-
@tsq-dba "data-design.md를 기반으로 전체 DDL을 생성해줘"
|
|
303
|
-
```
|
|
304
|
-
|
|
305
|
-
---
|
|
306
|
-
|
|
307
|
-
## 관련 문서
|
|
308
|
-
|
|
309
|
-
- [data-design.md](../.timsquad/ssot/data-design.md) - SSOT 데이터 설계
|
|
310
|
-
- [service-spec.md](../.timsquad/ssot/service-spec.md) - API 데이터 요구사항
|
|
311
|
-
- [glossary.md](../.timsquad/ssot/glossary.md) - 엔티티/용어 정의
|