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.
Files changed (438) hide show
  1. package/README.ko.md +288 -0
  2. package/README.md +170 -763
  3. package/dist/commands/compile.d.ts +3 -0
  4. package/dist/commands/compile.d.ts.map +1 -0
  5. package/dist/commands/compile.js +170 -0
  6. package/dist/commands/compile.js.map +1 -0
  7. package/dist/commands/daemon.d.ts +7 -0
  8. package/dist/commands/daemon.d.ts.map +1 -0
  9. package/dist/commands/daemon.js +229 -0
  10. package/dist/commands/daemon.js.map +1 -0
  11. package/dist/commands/feedback.d.ts +9 -0
  12. package/dist/commands/feedback.d.ts.map +1 -1
  13. package/dist/commands/feedback.js +235 -14
  14. package/dist/commands/feedback.js.map +1 -1
  15. package/dist/commands/full.js +2 -2
  16. package/dist/commands/full.js.map +1 -1
  17. package/dist/commands/init.d.ts.map +1 -1
  18. package/dist/commands/init.js +118 -22
  19. package/dist/commands/init.js.map +1 -1
  20. package/dist/commands/knowledge.d.ts +3 -0
  21. package/dist/commands/knowledge.d.ts.map +1 -0
  22. package/dist/commands/knowledge.js +316 -0
  23. package/dist/commands/knowledge.js.map +1 -0
  24. package/dist/commands/log.d.ts +27 -0
  25. package/dist/commands/log.d.ts.map +1 -1
  26. package/dist/commands/log.js +965 -0
  27. package/dist/commands/log.js.map +1 -1
  28. package/dist/commands/meta-index.d.ts +3 -0
  29. package/dist/commands/meta-index.d.ts.map +1 -0
  30. package/dist/commands/meta-index.js +401 -0
  31. package/dist/commands/meta-index.js.map +1 -0
  32. package/dist/commands/metrics.d.ts.map +1 -1
  33. package/dist/commands/metrics.js +239 -4
  34. package/dist/commands/metrics.js.map +1 -1
  35. package/dist/commands/retro.js +154 -6
  36. package/dist/commands/retro.js.map +1 -1
  37. package/dist/commands/skills.d.ts +12 -0
  38. package/dist/commands/skills.d.ts.map +1 -0
  39. package/dist/commands/skills.js +231 -0
  40. package/dist/commands/skills.js.map +1 -0
  41. package/dist/commands/upgrade.d.ts +8 -0
  42. package/dist/commands/upgrade.d.ts.map +1 -0
  43. package/dist/commands/upgrade.js +292 -0
  44. package/dist/commands/upgrade.js.map +1 -0
  45. package/dist/commands/workflow.d.ts +3 -0
  46. package/dist/commands/workflow.d.ts.map +1 -0
  47. package/dist/commands/workflow.js +607 -0
  48. package/dist/commands/workflow.js.map +1 -0
  49. package/dist/daemon/context-writer.d.ts +16 -0
  50. package/dist/daemon/context-writer.d.ts.map +1 -0
  51. package/dist/daemon/context-writer.js +35 -0
  52. package/dist/daemon/context-writer.js.map +1 -0
  53. package/dist/daemon/entry.d.ts +7 -0
  54. package/dist/daemon/entry.d.ts.map +1 -0
  55. package/dist/daemon/entry.js +17 -0
  56. package/dist/daemon/entry.js.map +1 -0
  57. package/dist/daemon/event-queue.d.ts +52 -0
  58. package/dist/daemon/event-queue.d.ts.map +1 -0
  59. package/dist/daemon/event-queue.js +255 -0
  60. package/dist/daemon/event-queue.js.map +1 -0
  61. package/dist/daemon/file-watcher.d.ts +19 -0
  62. package/dist/daemon/file-watcher.d.ts.map +1 -0
  63. package/dist/daemon/file-watcher.js +87 -0
  64. package/dist/daemon/file-watcher.js.map +1 -0
  65. package/dist/daemon/index.d.ts +29 -0
  66. package/dist/daemon/index.d.ts.map +1 -0
  67. package/dist/daemon/index.js +296 -0
  68. package/dist/daemon/index.js.map +1 -0
  69. package/dist/daemon/jsonl-watcher.d.ts +49 -0
  70. package/dist/daemon/jsonl-watcher.d.ts.map +1 -0
  71. package/dist/daemon/jsonl-watcher.js +258 -0
  72. package/dist/daemon/jsonl-watcher.js.map +1 -0
  73. package/dist/daemon/meta-cache.d.ts +63 -0
  74. package/dist/daemon/meta-cache.d.ts.map +1 -0
  75. package/dist/daemon/meta-cache.js +249 -0
  76. package/dist/daemon/meta-cache.js.map +1 -0
  77. package/dist/daemon/session-state.d.ts +19 -0
  78. package/dist/daemon/session-state.d.ts.map +1 -0
  79. package/dist/daemon/session-state.js +132 -0
  80. package/dist/daemon/session-state.js.map +1 -0
  81. package/dist/daemon/shutdown.d.ts +21 -0
  82. package/dist/daemon/shutdown.d.ts.map +1 -0
  83. package/dist/daemon/shutdown.js +164 -0
  84. package/dist/daemon/shutdown.js.map +1 -0
  85. package/dist/index.js +24 -3
  86. package/dist/index.js.map +1 -1
  87. package/dist/lib/agent-composer.d.ts +38 -0
  88. package/dist/lib/agent-composer.d.ts.map +1 -0
  89. package/dist/lib/agent-composer.js +128 -0
  90. package/dist/lib/agent-composer.js.map +1 -0
  91. package/dist/lib/agent-generator.d.ts +22 -0
  92. package/dist/lib/agent-generator.d.ts.map +1 -0
  93. package/dist/lib/agent-generator.js +150 -0
  94. package/dist/lib/agent-generator.js.map +1 -0
  95. package/dist/lib/ast-parser.d.ts +11 -0
  96. package/dist/lib/ast-parser.d.ts.map +1 -0
  97. package/dist/lib/ast-parser.js +282 -0
  98. package/dist/lib/ast-parser.js.map +1 -0
  99. package/dist/lib/compile-rules.d.ts +66 -0
  100. package/dist/lib/compile-rules.d.ts.map +1 -0
  101. package/dist/lib/compile-rules.js +114 -0
  102. package/dist/lib/compile-rules.js.map +1 -0
  103. package/dist/lib/compiler.d.ts +105 -0
  104. package/dist/lib/compiler.d.ts.map +1 -0
  105. package/dist/lib/compiler.js +368 -0
  106. package/dist/lib/compiler.js.map +1 -0
  107. package/dist/lib/config.d.ts +7 -2
  108. package/dist/lib/config.d.ts.map +1 -1
  109. package/dist/lib/config.js +34 -3
  110. package/dist/lib/config.js.map +1 -1
  111. package/dist/lib/meta-index.d.ts +19 -0
  112. package/dist/lib/meta-index.d.ts.map +1 -0
  113. package/dist/lib/meta-index.js +573 -0
  114. package/dist/lib/meta-index.js.map +1 -0
  115. package/dist/lib/project.js +1 -1
  116. package/dist/lib/project.js.map +1 -1
  117. package/dist/lib/skill-generator.d.ts +32 -0
  118. package/dist/lib/skill-generator.d.ts.map +1 -0
  119. package/dist/lib/skill-generator.js +187 -0
  120. package/dist/lib/skill-generator.js.map +1 -0
  121. package/dist/lib/template.d.ts +16 -2
  122. package/dist/lib/template.d.ts.map +1 -1
  123. package/dist/lib/template.js +115 -20
  124. package/dist/lib/template.js.map +1 -1
  125. package/dist/lib/ui-index.d.ts +12 -0
  126. package/dist/lib/ui-index.d.ts.map +1 -0
  127. package/dist/lib/ui-index.js +239 -0
  128. package/dist/lib/ui-index.js.map +1 -0
  129. package/dist/lib/ui-parser.d.ts +12 -0
  130. package/dist/lib/ui-parser.d.ts.map +1 -0
  131. package/dist/lib/ui-parser.js +472 -0
  132. package/dist/lib/ui-parser.js.map +1 -0
  133. package/dist/lib/update-check.d.ts +6 -0
  134. package/dist/lib/update-check.d.ts.map +1 -0
  135. package/dist/lib/update-check.js +121 -0
  136. package/dist/lib/update-check.js.map +1 -0
  137. package/dist/lib/upgrade-backup.d.ts +33 -0
  138. package/dist/lib/upgrade-backup.d.ts.map +1 -0
  139. package/dist/lib/upgrade-backup.js +101 -0
  140. package/dist/lib/upgrade-backup.js.map +1 -0
  141. package/dist/lib/version.d.ts +19 -0
  142. package/dist/lib/version.d.ts.map +1 -0
  143. package/dist/lib/version.js +35 -0
  144. package/dist/lib/version.js.map +1 -0
  145. package/dist/lib/workflow-state.d.ts +48 -0
  146. package/dist/lib/workflow-state.d.ts.map +1 -0
  147. package/dist/lib/workflow-state.js +67 -0
  148. package/dist/lib/workflow-state.js.map +1 -0
  149. package/dist/types/config.d.ts +103 -2
  150. package/dist/types/config.d.ts.map +1 -1
  151. package/dist/types/config.js +184 -9
  152. package/dist/types/config.js.map +1 -1
  153. package/dist/types/feedback.d.ts +7 -0
  154. package/dist/types/feedback.d.ts.map +1 -1
  155. package/dist/types/feedback.js +1 -1
  156. package/dist/types/feedback.js.map +1 -1
  157. package/dist/types/index.d.ts +3 -0
  158. package/dist/types/index.d.ts.map +1 -1
  159. package/dist/types/index.js +3 -0
  160. package/dist/types/index.js.map +1 -1
  161. package/dist/types/meta-index.d.ts +146 -0
  162. package/dist/types/meta-index.d.ts.map +1 -0
  163. package/dist/types/meta-index.js +7 -0
  164. package/dist/types/meta-index.js.map +1 -0
  165. package/dist/types/project.d.ts +19 -3
  166. package/dist/types/project.d.ts.map +1 -1
  167. package/dist/types/project.js +23 -0
  168. package/dist/types/project.js.map +1 -1
  169. package/dist/types/task-log.d.ts +208 -0
  170. package/dist/types/task-log.d.ts.map +1 -0
  171. package/dist/types/task-log.js +6 -0
  172. package/dist/types/task-log.js.map +1 -0
  173. package/dist/types/ui-meta.d.ts +118 -0
  174. package/dist/types/ui-meta.d.ts.map +1 -0
  175. package/dist/types/ui-meta.js +7 -0
  176. package/dist/types/ui-meta.js.map +1 -0
  177. package/package.json +12 -4
  178. package/templates/base/agents/base/tsq-architect.md +68 -0
  179. package/templates/base/agents/base/tsq-dba.md +56 -0
  180. package/templates/base/agents/base/tsq-designer.md +72 -0
  181. package/templates/base/agents/base/tsq-developer.md +67 -0
  182. package/templates/base/agents/base/tsq-qa.md +55 -0
  183. package/templates/base/agents/base/tsq-security.md +65 -0
  184. package/templates/base/agents/overlays/domain/general-web/_common.md +11 -0
  185. package/templates/base/agents/overlays/domain/mobile/_common.md +13 -0
  186. package/templates/base/agents/overlays/platform/claude-code.md +12 -0
  187. package/templates/base/config.template.yaml +213 -0
  188. package/templates/base/knowledge/checklists/accessibility.md +37 -0
  189. package/templates/base/knowledge/checklists/architecture-review.md +28 -0
  190. package/templates/base/knowledge/checklists/database-standards.md +84 -0
  191. package/templates/base/knowledge/checklists/design-reference.md +97 -0
  192. package/templates/base/knowledge/checklists/security.md +50 -0
  193. package/templates/base/knowledge/checklists/ssot-validation.md +19 -0
  194. package/templates/base/knowledge/domains/_template.md +16 -0
  195. package/templates/base/knowledge/platforms/_template.md +16 -0
  196. package/templates/base/knowledge/templates/sequence-report.md +44 -0
  197. package/templates/base/knowledge/templates/task-result.md +105 -0
  198. package/templates/base/skills/_template/SKILL.md +59 -0
  199. package/templates/base/skills/_template/references/_template.md +35 -0
  200. package/templates/base/skills/_template/rules/_sections.md +34 -0
  201. package/templates/base/skills/_template/rules/_template.md +32 -0
  202. package/templates/base/skills/_template/scripts/_template.sh +31 -0
  203. package/templates/base/skills/architecture/SKILL.md +54 -0
  204. package/templates/base/skills/architecture/references/adr-template.md +50 -0
  205. package/templates/base/skills/architecture/references/api-design.md +64 -0
  206. package/templates/base/skills/backend/node/SKILL.md +81 -0
  207. package/templates/base/skills/backend/node/rules/async-patterns.md +81 -0
  208. package/templates/base/skills/backend/node/rules/deployment.md +33 -0
  209. package/templates/base/skills/backend/node/rules/env-config.md +41 -0
  210. package/templates/base/skills/backend/node/rules/error-handling.md +83 -0
  211. package/templates/base/skills/backend/node/rules/hono-app-setup.md +98 -0
  212. package/templates/base/skills/backend/node/rules/jwt-auth.md +76 -0
  213. package/templates/base/skills/backend/node/rules/middleware.md +56 -0
  214. package/templates/base/skills/backend/node/rules/testing.md +82 -0
  215. package/templates/base/skills/coding/SKILL.md +47 -0
  216. package/templates/base/skills/coding/rules/patterns.md +81 -0
  217. package/templates/base/skills/controller/SKILL.md +111 -0
  218. package/templates/base/skills/controller/references/README.md +35 -0
  219. package/templates/base/skills/controller/rules/README.md +18 -0
  220. package/templates/base/skills/database/SKILL.md +98 -0
  221. package/templates/base/skills/database/prisma/SKILL.md +57 -0
  222. package/templates/base/skills/database/prisma/rules/queries.md +133 -0
  223. package/templates/base/skills/database/prisma/rules/schema-design.md +80 -0
  224. package/templates/base/skills/frontend/nextjs/SKILL.md +59 -0
  225. package/templates/base/skills/frontend/nextjs/rules/app-router.md +138 -0
  226. package/templates/base/skills/frontend/react/SKILL.md +86 -0
  227. package/templates/base/skills/frontend/react/rules/_sections.md +88 -0
  228. package/templates/base/skills/frontend/react/rules/anti-patterns.md +67 -0
  229. package/templates/base/skills/frontend/react/rules/async-api-routes.md +38 -0
  230. package/templates/base/skills/frontend/react/rules/async-defer-await.md +80 -0
  231. package/templates/base/skills/frontend/react/rules/async-dependencies.md +36 -0
  232. package/templates/base/skills/frontend/react/rules/async-parallel.md +28 -0
  233. package/templates/base/skills/frontend/react/rules/async-suspense-boundaries.md +99 -0
  234. package/templates/base/skills/frontend/react/rules/bundle-barrel-imports.md +59 -0
  235. package/templates/base/skills/frontend/react/rules/bundle-defer-third-party.md +49 -0
  236. package/templates/base/skills/frontend/react/rules/bundle-dynamic-imports.md +35 -0
  237. package/templates/base/skills/frontend/react/rules/component-conventions.md +74 -0
  238. package/templates/base/skills/frontend/react/rules/js-combine-iterations.md +32 -0
  239. package/templates/base/skills/frontend/react/rules/js-early-exit.md +50 -0
  240. package/templates/base/skills/frontend/react/rules/js-index-maps.md +37 -0
  241. package/templates/base/skills/frontend/react/rules/js-set-map-lookups.md +24 -0
  242. package/templates/base/skills/frontend/react/rules/rendering-conditional-render.md +40 -0
  243. package/templates/base/skills/frontend/react/rules/rendering-content-visibility.md +38 -0
  244. package/templates/base/skills/frontend/react/rules/rendering-hoist-jsx.md +46 -0
  245. package/templates/base/skills/frontend/react/rules/rerender-defer-reads.md +39 -0
  246. package/templates/base/skills/frontend/react/rules/rerender-derived-state.md +29 -0
  247. package/templates/base/skills/frontend/react/rules/rerender-memo.md +44 -0
  248. package/templates/base/skills/frontend/react/rules/rerender-transitions.md +40 -0
  249. package/templates/base/skills/frontend/react/rules/server-after-nonblocking.md +73 -0
  250. package/templates/base/skills/frontend/react/rules/server-cache-react.md +26 -0
  251. package/templates/base/skills/frontend/react/rules/server-parallel-fetching.md +79 -0
  252. package/templates/base/skills/frontend/react/rules/state-location.md +55 -0
  253. package/templates/base/skills/methodology/bdd/SKILL.md +69 -0
  254. package/templates/base/skills/methodology/bdd/rules/gherkin-patterns.md +113 -0
  255. package/templates/base/skills/methodology/ddd/SKILL.md +74 -0
  256. package/templates/base/skills/methodology/ddd/rules/strategic-patterns.md +98 -0
  257. package/templates/base/skills/methodology/debugging/SKILL.md +60 -0
  258. package/templates/base/skills/methodology/debugging/references/root-cause-tracing.md +84 -0
  259. package/templates/base/skills/methodology/tdd/SKILL.md +66 -0
  260. package/templates/base/skills/methodology/tdd/rules/real-world-example.md +88 -0
  261. package/templates/base/skills/methodology/tdd/rules/techniques.md +185 -0
  262. package/templates/base/skills/mobile/dart/SKILL.md +69 -0
  263. package/templates/base/skills/mobile/dart/rules/async-patterns.md +112 -0
  264. package/templates/base/skills/mobile/dart/rules/code-style.md +96 -0
  265. package/templates/base/skills/mobile/dart/rules/null-safety.md +84 -0
  266. package/templates/base/skills/mobile/dart/rules/type-system.md +111 -0
  267. package/templates/base/skills/mobile/flutter/SKILL.md +89 -0
  268. package/templates/base/skills/mobile/flutter/ci-cd/SKILL.md +82 -0
  269. package/templates/base/skills/mobile/flutter/ci-cd/references/ci-cd-pipeline.md +314 -0
  270. package/templates/base/skills/mobile/flutter/ci-cd/rules/code-signing.md +106 -0
  271. package/templates/base/skills/mobile/flutter/ci-cd/rules/codemagic-setup.md +116 -0
  272. package/templates/base/skills/mobile/flutter/ci-cd/rules/fastlane-setup.md +105 -0
  273. package/templates/base/skills/mobile/flutter/ci-cd/rules/github-actions.md +112 -0
  274. package/templates/base/skills/mobile/flutter/ci-cd/rules/store-deployment.md +106 -0
  275. package/templates/base/skills/mobile/flutter/ci-cd/rules/versioning.md +107 -0
  276. package/templates/base/skills/mobile/flutter/i18n/SKILL.md +78 -0
  277. package/templates/base/skills/mobile/flutter/i18n/references/i18n-architecture.md +225 -0
  278. package/templates/base/skills/mobile/flutter/i18n/rules/arb-files.md +182 -0
  279. package/templates/base/skills/mobile/flutter/i18n/rules/locale-switching.md +226 -0
  280. package/templates/base/skills/mobile/flutter/i18n/rules/localization-setup.md +137 -0
  281. package/templates/base/skills/mobile/flutter/i18n/rules/plural-gender.md +159 -0
  282. package/templates/base/skills/mobile/flutter/i18n/rules/text-direction.md +199 -0
  283. package/templates/base/skills/mobile/flutter/monitoring/SKILL.md +81 -0
  284. package/templates/base/skills/mobile/flutter/monitoring/references/monitoring-architecture.md +269 -0
  285. package/templates/base/skills/mobile/flutter/monitoring/rules/analytics.md +227 -0
  286. package/templates/base/skills/mobile/flutter/monitoring/rules/crashlytics-setup.md +195 -0
  287. package/templates/base/skills/mobile/flutter/monitoring/rules/logging.md +258 -0
  288. package/templates/base/skills/mobile/flutter/monitoring/rules/performance-monitoring.md +248 -0
  289. package/templates/base/skills/mobile/flutter/monitoring/rules/sentry-integration.md +249 -0
  290. package/templates/base/skills/mobile/flutter/networking/SKILL.md +88 -0
  291. package/templates/base/skills/mobile/flutter/networking/references/api-client-architecture.md +305 -0
  292. package/templates/base/skills/mobile/flutter/networking/rules/caching.md +212 -0
  293. package/templates/base/skills/mobile/flutter/networking/rules/connectivity.md +213 -0
  294. package/templates/base/skills/mobile/flutter/networking/rules/dio-setup.md +159 -0
  295. package/templates/base/skills/mobile/flutter/networking/rules/error-handling.md +209 -0
  296. package/templates/base/skills/mobile/flutter/networking/rules/interceptors.md +205 -0
  297. package/templates/base/skills/mobile/flutter/networking/rules/retrofit-patterns.md +194 -0
  298. package/templates/base/skills/mobile/flutter/push-notifications/SKILL.md +87 -0
  299. package/templates/base/skills/mobile/flutter/push-notifications/references/notification-architecture.md +340 -0
  300. package/templates/base/skills/mobile/flutter/push-notifications/references/platform-setup.md +286 -0
  301. package/templates/base/skills/mobile/flutter/push-notifications/rules/background-processing.md +308 -0
  302. package/templates/base/skills/mobile/flutter/push-notifications/rules/deep-linking.md +217 -0
  303. package/templates/base/skills/mobile/flutter/push-notifications/rules/fcm-setup.md +164 -0
  304. package/templates/base/skills/mobile/flutter/push-notifications/rules/local-notifications.md +262 -0
  305. package/templates/base/skills/mobile/flutter/push-notifications/rules/notification-handling.md +210 -0
  306. package/templates/base/skills/mobile/flutter/push-notifications/rules/notification-permissions.md +246 -0
  307. package/templates/base/skills/mobile/flutter/push-notifications/rules/rich-notifications.md +320 -0
  308. package/templates/base/skills/mobile/flutter/references/freezed-patterns.md +162 -0
  309. package/templates/base/skills/mobile/flutter/references/project-structure.md +170 -0
  310. package/templates/base/skills/mobile/flutter/rules/animations.md +112 -0
  311. package/templates/base/skills/mobile/flutter/rules/architecture.md +121 -0
  312. package/templates/base/skills/mobile/flutter/rules/navigation-routing.md +117 -0
  313. package/templates/base/skills/mobile/flutter/rules/performance.md +112 -0
  314. package/templates/base/skills/mobile/flutter/rules/platform-adaptive.md +126 -0
  315. package/templates/base/skills/mobile/flutter/rules/state-management.md +110 -0
  316. package/templates/base/skills/mobile/flutter/rules/testing.md +131 -0
  317. package/templates/base/skills/mobile/flutter/rules/widget-conventions.md +122 -0
  318. package/templates/base/skills/mobile/flutter/security/SKILL.md +86 -0
  319. package/templates/base/skills/mobile/flutter/security/references/mobile-security-checklist.md +168 -0
  320. package/templates/base/skills/mobile/flutter/security/rules/api-key-protection.md +206 -0
  321. package/templates/base/skills/mobile/flutter/security/rules/authentication.md +248 -0
  322. package/templates/base/skills/mobile/flutter/security/rules/data-protection.md +271 -0
  323. package/templates/base/skills/mobile/flutter/security/rules/obfuscation.md +213 -0
  324. package/templates/base/skills/mobile/flutter/security/rules/secure-storage.md +171 -0
  325. package/templates/base/skills/mobile/flutter/security/rules/ssl-pinning.md +197 -0
  326. package/templates/base/skills/planning/SKILL.md +58 -0
  327. package/templates/base/skills/planning/references/prd-guide.md +47 -0
  328. package/templates/base/skills/planning/references/requirements-guide.md +46 -0
  329. package/templates/base/skills/prompt-engineering/SKILL.md +103 -0
  330. package/templates/base/skills/retrospective/SKILL.md +102 -0
  331. package/templates/base/skills/security/SKILL.md +55 -0
  332. package/templates/base/skills/security/rules/owasp-examples.md +119 -0
  333. package/templates/base/skills/security/scripts/check-secrets.sh +55 -0
  334. package/templates/base/skills/testing/SKILL.md +63 -0
  335. package/templates/base/skills/testing/references/testing-patterns.md +103 -0
  336. package/templates/base/skills/tsq-protocol/SKILL.md +51 -0
  337. package/templates/base/skills/typescript/SKILL.md +67 -0
  338. package/templates/base/skills/typescript/rules/type-patterns.md +135 -0
  339. package/templates/base/skills/typescript/rules/utility-types.md +76 -0
  340. package/templates/base/skills/ui-design/SKILL.md +70 -0
  341. package/templates/{common → base}/timsquad/feedback/routing-rules.yaml +1 -1
  342. package/templates/{common → base}/timsquad/retrospective/metrics/metrics-schema.json +46 -1
  343. package/templates/platforms/claude-code/CLAUDE.md.template +89 -0
  344. package/templates/platforms/claude-code/rules/adr-rules.md +32 -0
  345. package/templates/platforms/claude-code/rules/feedback-routing.md +18 -0
  346. package/templates/platforms/claude-code/rules/phase-management.md +23 -0
  347. package/templates/platforms/claude-code/rules/reporting-format.md +26 -0
  348. package/templates/platforms/claude-code/rules/sequence-management.md +72 -0
  349. package/templates/platforms/claude-code/rules/workspace-sync.md +33 -0
  350. package/templates/platforms/claude-code/scripts/completion-guard.sh +57 -0
  351. package/templates/platforms/claude-code/scripts/phase-guard.sh +79 -0
  352. package/templates/platforms/claude-code/settings.json +98 -0
  353. package/templates/project-types/api-backend/config.yaml +227 -0
  354. package/templates/project-types/api-backend/process/workflow.xml +214 -0
  355. package/templates/project-types/fintech/config.yaml +151 -0
  356. package/templates/project-types/fintech/process/workflow.xml +316 -0
  357. package/templates/project-types/infra/config.yaml +327 -0
  358. package/templates/project-types/infra/process/workflow.xml +296 -0
  359. package/templates/project-types/mobile-app/config.yaml +123 -0
  360. package/templates/project-types/mobile-app/process/workflow.xml +191 -0
  361. package/templates/project-types/platform/config.yaml +254 -0
  362. package/templates/project-types/platform/process/workflow.xml +254 -0
  363. package/templates/project-types/web-app/config.yaml +198 -0
  364. package/templates/project-types/web-app/process/workflow.xml +210 -0
  365. package/templates/project-types/web-service/config.yaml +136 -0
  366. package/templates/project-types/web-service/process/workflow.xml +184 -0
  367. package/templates/common/CLAUDE.md.template +0 -254
  368. package/templates/common/claude/agents/tsq-dba.md +0 -311
  369. package/templates/common/claude/agents/tsq-designer.md +0 -323
  370. package/templates/common/claude/agents/tsq-developer.md +0 -177
  371. package/templates/common/claude/agents/tsq-planner.md +0 -190
  372. package/templates/common/claude/agents/tsq-prompter.md +0 -356
  373. package/templates/common/claude/agents/tsq-qa.md +0 -168
  374. package/templates/common/claude/agents/tsq-retro.md +0 -193
  375. package/templates/common/claude/agents/tsq-security.md +0 -221
  376. package/templates/common/claude/hooks/auto-metrics.sh +0 -165
  377. package/templates/common/claude/hooks/auto-worklog.sh +0 -245
  378. package/templates/common/claude/hooks/event-logger.sh +0 -208
  379. package/templates/common/claude/settings.json +0 -86
  380. package/templates/common/claude/skills/architecture/SKILL.md +0 -123
  381. package/templates/common/claude/skills/backend/node/SKILL.md +0 -1015
  382. package/templates/common/claude/skills/coding/SKILL.md +0 -171
  383. package/templates/common/claude/skills/database/prisma/SKILL.md +0 -357
  384. package/templates/common/claude/skills/frontend/nextjs/SKILL.md +0 -279
  385. package/templates/common/claude/skills/frontend/react/SKILL.md +0 -1729
  386. package/templates/common/claude/skills/methodology/bdd/SKILL.md +0 -234
  387. package/templates/common/claude/skills/methodology/ddd/SKILL.md +0 -311
  388. package/templates/common/claude/skills/methodology/tdd/SKILL.md +0 -512
  389. package/templates/common/claude/skills/planning/SKILL.md +0 -90
  390. package/templates/common/claude/skills/security/SKILL.md +0 -234
  391. package/templates/common/claude/skills/testing/SKILL.md +0 -146
  392. package/templates/common/claude/skills/typescript/SKILL.md +0 -435
  393. package/templates/common/config.template.yaml +0 -132
  394. /package/templates/{common → base}/timsquad/architectures/clean/ARCHITECTURE.md +0 -0
  395. /package/templates/{common → base}/timsquad/architectures/clean/backend.xml +0 -0
  396. /package/templates/{common → base}/timsquad/architectures/clean/frontend.xml +0 -0
  397. /package/templates/{common → base}/timsquad/architectures/fsd/ARCHITECTURE.md +0 -0
  398. /package/templates/{common → base}/timsquad/architectures/fsd/frontend.xml +0 -0
  399. /package/templates/{common → base}/timsquad/architectures/hexagonal/ARCHITECTURE.md +0 -0
  400. /package/templates/{common → base}/timsquad/architectures/hexagonal/backend.xml +0 -0
  401. /package/templates/{common → base}/timsquad/constraints/competency-framework.xml +0 -0
  402. /package/templates/{common → base}/timsquad/constraints/ssot-schema.xml +0 -0
  403. /package/templates/{common → base}/timsquad/feedback/feedback-router.sh +0 -0
  404. /package/templates/{common → base}/timsquad/generators/data-design.xml +0 -0
  405. /package/templates/{common → base}/timsquad/generators/prd.xml +0 -0
  406. /package/templates/{common → base}/timsquad/generators/requirements.xml +0 -0
  407. /package/templates/{common → base}/timsquad/generators/service-spec.xml +0 -0
  408. /package/templates/{common → base}/timsquad/logs/_example.md +0 -0
  409. /package/templates/{common → base}/timsquad/logs/_template.md +0 -0
  410. /package/templates/{common → base}/timsquad/patterns/cqrs.xml +0 -0
  411. /package/templates/{common → base}/timsquad/patterns/event-sourcing.xml +0 -0
  412. /package/templates/{common → base}/timsquad/patterns/repository.xml +0 -0
  413. /package/templates/{common → base}/timsquad/process/phase-checklist.yaml +0 -0
  414. /package/templates/{common → base}/timsquad/process/state-machine.xml +0 -0
  415. /package/templates/{common → base}/timsquad/process/validation-rules.xml +0 -0
  416. /package/templates/{common → base}/timsquad/process/workflow-base.xml +0 -0
  417. /package/templates/{common → base}/timsquad/retrospective/cycle-report.template.md +0 -0
  418. /package/templates/{common → base}/timsquad/retrospective/patterns/failure-patterns.md +0 -0
  419. /package/templates/{common → base}/timsquad/retrospective/patterns/success-patterns.md +0 -0
  420. /package/templates/{common → base}/timsquad/retrospective/retrospective-config.xml +0 -0
  421. /package/templates/{common → base}/timsquad/retrospective/retrospective-state.xml +0 -0
  422. /package/templates/{common → base}/timsquad/ssot/adr/ADR-000-template.md +0 -0
  423. /package/templates/{common → base}/timsquad/ssot/adr/ADR-001-example.md +0 -0
  424. /package/templates/{common → base}/timsquad/ssot/data-design.template.md +0 -0
  425. /package/templates/{common → base}/timsquad/ssot/deployment-spec.template.md +0 -0
  426. /package/templates/{common → base}/timsquad/ssot/env-config.template.md +0 -0
  427. /package/templates/{common → base}/timsquad/ssot/error-codes.template.md +0 -0
  428. /package/templates/{common → base}/timsquad/ssot/functional-spec.template.md +0 -0
  429. /package/templates/{common → base}/timsquad/ssot/glossary.template.md +0 -0
  430. /package/templates/{common → base}/timsquad/ssot/integration-spec.template.md +0 -0
  431. /package/templates/{common → base}/timsquad/ssot/planning.template.md +0 -0
  432. /package/templates/{common → base}/timsquad/ssot/prd.template.md +0 -0
  433. /package/templates/{common → base}/timsquad/ssot/requirements.template.md +0 -0
  434. /package/templates/{common → base}/timsquad/ssot/security-spec.template.md +0 -0
  435. /package/templates/{common → base}/timsquad/ssot/service-spec.template.md +0 -0
  436. /package/templates/{common → base}/timsquad/ssot/test-spec.template.md +0 -0
  437. /package/templates/{common → base}/timsquad/ssot/ui-ux-spec.template.md +0 -0
  438. /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) - 엔티티/용어 정의