timsquad 3.5.0 → 3.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (454) hide show
  1. package/README.ko.md +103 -107
  2. package/README.md +100 -104
  3. package/dist/commands/daemon.d.ts.map +1 -1
  4. package/dist/commands/daemon.js +48 -2
  5. package/dist/commands/daemon.js.map +1 -1
  6. package/dist/commands/init.js +46 -14
  7. package/dist/commands/init.js.map +1 -1
  8. package/dist/commands/{upgrade.d.ts → update.d.ts} +3 -3
  9. package/dist/commands/update.d.ts.map +1 -0
  10. package/dist/commands/{upgrade.js → update.js} +12 -17
  11. package/dist/commands/update.js.map +1 -0
  12. package/dist/daemon/context-writer.d.ts +14 -0
  13. package/dist/daemon/context-writer.d.ts.map +1 -1
  14. package/dist/daemon/context-writer.js +29 -0
  15. package/dist/daemon/context-writer.js.map +1 -1
  16. package/dist/daemon/event-queue.d.ts +7 -11
  17. package/dist/daemon/event-queue.d.ts.map +1 -1
  18. package/dist/daemon/event-queue.js +78 -118
  19. package/dist/daemon/event-queue.js.map +1 -1
  20. package/dist/daemon/file-watcher.d.ts +14 -8
  21. package/dist/daemon/file-watcher.d.ts.map +1 -1
  22. package/dist/daemon/file-watcher.js +78 -41
  23. package/dist/daemon/file-watcher.js.map +1 -1
  24. package/dist/daemon/index.d.ts +1 -1
  25. package/dist/daemon/index.d.ts.map +1 -1
  26. package/dist/daemon/index.js +54 -47
  27. package/dist/daemon/index.js.map +1 -1
  28. package/dist/index.js +3 -41
  29. package/dist/index.js.map +1 -1
  30. package/dist/lib/agent-generator.d.ts.map +1 -1
  31. package/dist/lib/agent-generator.js +21 -10
  32. package/dist/lib/agent-generator.js.map +1 -1
  33. package/dist/lib/compile-rules.d.ts +2 -0
  34. package/dist/lib/compile-rules.d.ts.map +1 -1
  35. package/dist/lib/compile-rules.js +39 -4
  36. package/dist/lib/compile-rules.js.map +1 -1
  37. package/dist/lib/compiler.d.ts +22 -1
  38. package/dist/lib/compiler.d.ts.map +1 -1
  39. package/dist/lib/compiler.js +178 -12
  40. package/dist/lib/compiler.js.map +1 -1
  41. package/dist/lib/config.d.ts +3 -0
  42. package/dist/lib/config.d.ts.map +1 -1
  43. package/dist/lib/config.js +17 -2
  44. package/dist/lib/config.js.map +1 -1
  45. package/dist/{commands/log.d.ts → lib/log-utils.d.ts} +7 -15
  46. package/dist/lib/log-utils.d.ts.map +1 -0
  47. package/dist/lib/log-utils.js +347 -0
  48. package/dist/lib/log-utils.js.map +1 -0
  49. package/dist/lib/skill-generator.d.ts +1 -1
  50. package/dist/lib/skill-generator.d.ts.map +1 -1
  51. package/dist/lib/skill-generator.js +19 -44
  52. package/dist/lib/skill-generator.js.map +1 -1
  53. package/dist/lib/ssot-map.d.ts +31 -0
  54. package/dist/lib/ssot-map.d.ts.map +1 -0
  55. package/dist/lib/ssot-map.js +79 -0
  56. package/dist/lib/ssot-map.js.map +1 -0
  57. package/dist/lib/template.d.ts +10 -3
  58. package/dist/lib/template.d.ts.map +1 -1
  59. package/dist/lib/template.js +137 -22
  60. package/dist/lib/template.js.map +1 -1
  61. package/dist/lib/upgrade-backup.js +1 -1
  62. package/dist/lib/upgrade-backup.js.map +1 -1
  63. package/dist/lib/workflow-state.d.ts +1 -1
  64. package/dist/lib/workflow-state.d.ts.map +1 -1
  65. package/dist/lib/workflow-state.js +1 -1
  66. package/dist/lib/workflow-state.js.map +1 -1
  67. package/dist/types/config.d.ts +10 -1
  68. package/dist/types/config.d.ts.map +1 -1
  69. package/dist/types/config.js +46 -41
  70. package/dist/types/config.js.map +1 -1
  71. package/dist/types/feedback.d.ts +1 -54
  72. package/dist/types/feedback.d.ts.map +1 -1
  73. package/dist/types/feedback.js +1 -22
  74. package/dist/types/feedback.js.map +1 -1
  75. package/dist/types/index.d.ts +1 -0
  76. package/dist/types/index.d.ts.map +1 -1
  77. package/dist/types/index.js +1 -0
  78. package/dist/types/index.js.map +1 -1
  79. package/dist/types/meta-index.d.ts +8 -0
  80. package/dist/types/meta-index.d.ts.map +1 -1
  81. package/dist/types/project.d.ts +6 -1
  82. package/dist/types/project.d.ts.map +1 -1
  83. package/dist/types/project.js +15 -0
  84. package/dist/types/project.js.map +1 -1
  85. package/dist/types/ssot-map.d.ts +30 -0
  86. package/dist/types/ssot-map.d.ts.map +1 -0
  87. package/dist/types/ssot-map.js +6 -0
  88. package/dist/types/ssot-map.js.map +1 -0
  89. package/package.json +1 -1
  90. package/templates/base/agents/base/tsq-architect.md +1 -1
  91. package/templates/base/agents/base/tsq-dba.md +3 -1
  92. package/templates/base/agents/base/tsq-designer.md +3 -1
  93. package/templates/base/agents/base/tsq-developer.md +3 -1
  94. package/templates/base/agents/base/tsq-librarian.md +45 -0
  95. package/templates/base/agents/base/tsq-qa.md +3 -1
  96. package/templates/base/agents/base/tsq-security.md +3 -1
  97. package/templates/base/agents/overlays/platform/claude-code.md +2 -2
  98. package/templates/base/config.template.yaml +17 -28
  99. package/templates/base/knowledge/templates/task-result.md +5 -10
  100. package/templates/base/skills/_shared/naming-conventions.md +49 -0
  101. package/templates/base/skills/_template/SKILL.md +31 -17
  102. package/templates/base/skills/{architecture → tsq-architecture}/SKILL.md +2 -2
  103. package/templates/base/skills/tsq-audit/SKILL.md +74 -0
  104. package/templates/base/skills/{methodology/bdd → tsq-bdd}/SKILL.md +14 -9
  105. package/templates/base/skills/tsq-coding/SKILL.md +65 -0
  106. package/templates/base/skills/tsq-coding/rules/async-patterns.md +81 -0
  107. package/templates/base/skills/tsq-coding/rules/code-organization.md +80 -0
  108. package/templates/base/skills/tsq-coding/rules/error-handling.md +76 -0
  109. package/templates/base/skills/tsq-coding/rules/type-safety.md +85 -0
  110. package/templates/base/skills/tsq-controller/SKILL.md +81 -0
  111. package/templates/base/skills/tsq-controller/memory/.gitkeep +0 -0
  112. package/templates/base/skills/{mobile/dart → tsq-dart}/SKILL.md +5 -3
  113. package/templates/base/skills/{database → tsq-database}/SKILL.md +13 -27
  114. package/templates/base/skills/tsq-database/rules/query-optimization.md +32 -0
  115. package/templates/base/skills/tsq-database/rules/supabase-patterns.md +94 -0
  116. package/templates/base/skills/{methodology/ddd → tsq-ddd}/SKILL.md +15 -10
  117. package/templates/base/skills/{methodology/debugging → tsq-debugging}/SKILL.md +2 -2
  118. package/templates/base/skills/tsq-decompose/SKILL.md +117 -0
  119. package/templates/base/skills/tsq-delete/SKILL.md +72 -0
  120. package/templates/base/skills/{mobile/flutter → tsq-flutter}/SKILL.md +6 -3
  121. package/templates/base/skills/tsq-grill/SKILL.md +86 -0
  122. package/templates/base/skills/{backend/node → tsq-hono}/SKILL.md +6 -4
  123. package/templates/base/skills/tsq-librarian/SKILL.md +78 -0
  124. package/templates/base/skills/tsq-log/SKILL.md +30 -0
  125. package/templates/base/skills/{frontend/nextjs → tsq-nextjs}/SKILL.md +14 -9
  126. package/templates/base/skills/{planning → tsq-planning}/SKILL.md +2 -2
  127. package/templates/base/skills/{database/prisma → tsq-prisma}/SKILL.md +15 -9
  128. package/templates/base/skills/tsq-product-audit/SKILL.md +113 -0
  129. package/templates/base/skills/tsq-product-audit/checklists/01-security.md +86 -0
  130. package/templates/base/skills/tsq-product-audit/checklists/02-performance.md +67 -0
  131. package/templates/base/skills/tsq-product-audit/checklists/03-seo.md +46 -0
  132. package/templates/base/skills/tsq-product-audit/checklists/04-accessibility.md +66 -0
  133. package/templates/base/skills/tsq-product-audit/checklists/05-ui-ux.md +50 -0
  134. package/templates/base/skills/tsq-product-audit/checklists/06-architecture.md +53 -0
  135. package/templates/base/skills/tsq-product-audit/checklists/07-functional-requirements.md +55 -0
  136. package/templates/base/skills/tsq-product-audit/rules/audit-protocol.md +136 -0
  137. package/templates/base/skills/tsq-product-audit/rules/false-positive-guard.md +81 -0
  138. package/templates/base/skills/tsq-product-audit/rules/scoring-criteria.md +113 -0
  139. package/templates/base/skills/tsq-product-audit/templates/improvement-plan-template.md +60 -0
  140. package/templates/base/skills/tsq-product-audit/templates/report-template.md +88 -0
  141. package/templates/base/skills/tsq-prompt/SKILL.md +86 -0
  142. package/templates/base/skills/tsq-protocol/SKILL.md +101 -33
  143. package/templates/base/skills/{frontend/react → tsq-react}/SKILL.md +6 -3
  144. package/templates/base/skills/tsq-retro/SKILL.md +86 -0
  145. package/templates/base/skills/tsq-retro/references/feedback-guide.md +58 -0
  146. package/templates/base/skills/tsq-retro/references/improve-protocol.md +87 -0
  147. package/templates/base/skills/tsq-retro/references/improvement-template.md +26 -0
  148. package/templates/base/skills/tsq-security/SKILL.md +66 -0
  149. package/templates/base/skills/tsq-security/rules/auth-patterns.md +62 -0
  150. package/templates/base/skills/tsq-security/rules/dependency-security.md +69 -0
  151. package/templates/base/skills/tsq-security/rules/input-validation.md +68 -0
  152. package/templates/base/skills/tsq-security/rules/secrets-management.md +65 -0
  153. package/templates/base/skills/tsq-spec/SKILL.md +58 -0
  154. package/templates/base/skills/{stability-verification → tsq-stability}/SKILL.md +3 -3
  155. package/templates/base/skills/tsq-start/SKILL.md +90 -0
  156. package/templates/base/skills/tsq-start/references/onboarding-questions.md +177 -0
  157. package/templates/base/skills/tsq-status/SKILL.md +32 -0
  158. package/templates/base/skills/{methodology/tdd → tsq-tdd}/SKILL.md +12 -3
  159. package/templates/base/skills/tsq-testing/SKILL.md +69 -0
  160. package/templates/base/skills/tsq-testing/references/e2e-stability.md +33 -0
  161. package/templates/base/skills/{typescript → tsq-typescript}/SKILL.md +5 -11
  162. package/templates/base/skills/{ui-design → tsq-ui}/SKILL.md +2 -2
  163. package/templates/base/skills/tsq-update/SKILL.md +48 -0
  164. package/templates/base/timsquad/constraints/competency-framework.xml +2 -2
  165. package/templates/base/timsquad/constraints/ssot-schema.xml +2 -2
  166. package/templates/base/timsquad/process/phase-checklist.yaml +1 -1
  167. package/templates/base/timsquad/process/state-machine.xml +2 -2
  168. package/templates/base/timsquad/process/validation-rules.xml +8 -8
  169. package/templates/base/timsquad/process/workflow-base.xml +8 -8
  170. package/templates/base/timsquad/retrospective/cycle-report.template.md +2 -2
  171. package/templates/base/timsquad/retrospective/patterns/failure-patterns.md +1 -1
  172. package/templates/base/timsquad/retrospective/patterns/success-patterns.md +2 -2
  173. package/templates/base/timsquad/retrospective/retrospective-state.xml +2 -2
  174. package/templates/base/timsquad/ssot/audit-trail-spec.template.md +155 -0
  175. package/templates/base/timsquad/ssot/compliance-matrix.template.md +105 -0
  176. package/templates/base/timsquad/ssot/component-map.template.md +181 -0
  177. package/templates/base/timsquad/ssot/data-design.template.md +4 -4
  178. package/templates/base/timsquad/ssot/deployment-spec.template.md +29 -22
  179. package/templates/base/timsquad/ssot/env-config.template.md +4 -2
  180. package/templates/base/timsquad/ssot/error-codes.template.md +3 -3
  181. package/templates/base/timsquad/ssot/functional-spec.template.md +40 -3
  182. package/templates/base/timsquad/ssot/glossary.template.md +2 -2
  183. package/templates/base/timsquad/ssot/infra-topology.template.md +191 -0
  184. package/templates/base/timsquad/ssot/integration-spec.template.md +2 -2
  185. package/templates/base/timsquad/ssot/monitoring-spec.template.md +185 -0
  186. package/templates/base/timsquad/ssot/navigation-map.template.md +154 -0
  187. package/templates/base/timsquad/ssot/performance-budget.template.md +132 -0
  188. package/templates/base/timsquad/ssot/planning.template.md +3 -3
  189. package/templates/base/timsquad/ssot/prd/_template.md +73 -0
  190. package/templates/base/timsquad/ssot/prd.template.md +10 -21
  191. package/templates/base/timsquad/ssot/requirements.template.md +3 -3
  192. package/templates/base/timsquad/ssot/sdk-spec.template.md +223 -0
  193. package/templates/base/timsquad/ssot/service-spec.template.md +3 -3
  194. package/templates/base/timsquad/ssot/state-machine.template.md +127 -0
  195. package/templates/base/timsquad/ssot/test-spec.template.md +11 -1
  196. package/templates/base/timsquad/ssot/ui-ux-spec.template.md +43 -3
  197. package/templates/base/timsquad/ssot-map.template.yaml +69 -0
  198. package/templates/base/timsquad/state/workspace.xml +11 -11
  199. package/templates/platforms/claude-code/rules/adr-rules.md +1 -1
  200. package/templates/platforms/claude-code/rules/api-conventions.md +12 -0
  201. package/templates/platforms/claude-code/rules/build-gate.md +1 -1
  202. package/templates/platforms/claude-code/rules/completion-verification.md +0 -2
  203. package/templates/platforms/claude-code/rules/context-monitor.md +1 -1
  204. package/templates/platforms/claude-code/rules/feedback-routing.md +2 -2
  205. package/templates/platforms/claude-code/rules/librarian-constraints.md +11 -0
  206. package/templates/platforms/claude-code/rules/phase-management.md +2 -2
  207. package/templates/platforms/claude-code/rules/plan-review.md +2 -2
  208. package/templates/platforms/claude-code/rules/quality-guards.md +0 -2
  209. package/templates/platforms/claude-code/rules/sequence-management.md +15 -15
  210. package/templates/platforms/claude-code/rules/session-notes.md +1 -1
  211. package/templates/platforms/claude-code/rules/test-conventions.md +13 -0
  212. package/templates/platforms/claude-code/rules/workspace-sync.md +1 -1
  213. package/templates/platforms/claude-code/scripts/build-gate.sh +6 -1
  214. package/templates/platforms/claude-code/scripts/change-scope-guard.sh +110 -0
  215. package/templates/platforms/claude-code/scripts/check-capability.sh +68 -0
  216. package/templates/platforms/claude-code/scripts/completion-guard.sh +134 -14
  217. package/templates/platforms/claude-code/scripts/context-restore.sh +95 -0
  218. package/templates/platforms/claude-code/scripts/e2e-commit-gate.sh +70 -0
  219. package/templates/platforms/claude-code/scripts/e2e-marker.sh +51 -0
  220. package/templates/platforms/claude-code/scripts/phase-guard.sh +3 -6
  221. package/templates/platforms/claude-code/scripts/pre-compact.sh +70 -0
  222. package/templates/platforms/claude-code/scripts/safe-guard.sh +2 -5
  223. package/templates/platforms/claude-code/scripts/subagent-start.sh +11 -0
  224. package/templates/platforms/claude-code/scripts/subagent-stop.sh +11 -0
  225. package/templates/platforms/claude-code/settings.json +28 -56
  226. package/templates/project-types/api-backend/config.yaml +9 -5
  227. package/templates/project-types/api-backend/process/workflow.xml +2 -2
  228. package/templates/project-types/fintech/config.yaml +13 -19
  229. package/templates/project-types/fintech/ssot/audit-trail-spec.template.md +207 -0
  230. package/templates/project-types/fintech/ssot/compliance-matrix.template.md +187 -0
  231. package/templates/project-types/infra/config.yaml +7 -4
  232. package/templates/project-types/infra/process/workflow.xml +3 -3
  233. package/templates/project-types/mobile-app/config.yaml +8 -14
  234. package/templates/project-types/mobile-app/process/workflow.xml +4 -4
  235. package/templates/project-types/platform/config.yaml +8 -5
  236. package/templates/project-types/platform/process/workflow.xml +3 -3
  237. package/templates/project-types/web-app/config.yaml +9 -15
  238. package/templates/project-types/web-app/process/workflow.xml +6 -6
  239. package/templates/project-types/web-service/config.yaml +10 -19
  240. package/templates/project-types/web-service/process/workflow.xml +6 -6
  241. package/dist/commands/compile.d.ts +0 -3
  242. package/dist/commands/compile.d.ts.map +0 -1
  243. package/dist/commands/compile.js +0 -170
  244. package/dist/commands/compile.js.map +0 -1
  245. package/dist/commands/feedback.d.ts +0 -12
  246. package/dist/commands/feedback.d.ts.map +0 -1
  247. package/dist/commands/feedback.js +0 -382
  248. package/dist/commands/feedback.js.map +0 -1
  249. package/dist/commands/full.d.ts +0 -3
  250. package/dist/commands/full.d.ts.map +0 -1
  251. package/dist/commands/full.js +0 -88
  252. package/dist/commands/full.js.map +0 -1
  253. package/dist/commands/git/commit.d.ts +0 -3
  254. package/dist/commands/git/commit.d.ts.map +0 -1
  255. package/dist/commands/git/commit.js +0 -85
  256. package/dist/commands/git/commit.js.map +0 -1
  257. package/dist/commands/git/index.d.ts +0 -5
  258. package/dist/commands/git/index.d.ts.map +0 -1
  259. package/dist/commands/git/index.js +0 -5
  260. package/dist/commands/git/index.js.map +0 -1
  261. package/dist/commands/git/pr.d.ts +0 -3
  262. package/dist/commands/git/pr.d.ts.map +0 -1
  263. package/dist/commands/git/pr.js +0 -139
  264. package/dist/commands/git/pr.js.map +0 -1
  265. package/dist/commands/git/release.d.ts +0 -3
  266. package/dist/commands/git/release.d.ts.map +0 -1
  267. package/dist/commands/git/release.js +0 -153
  268. package/dist/commands/git/release.js.map +0 -1
  269. package/dist/commands/git/sync.d.ts +0 -3
  270. package/dist/commands/git/sync.d.ts.map +0 -1
  271. package/dist/commands/git/sync.js +0 -132
  272. package/dist/commands/git/sync.js.map +0 -1
  273. package/dist/commands/improve.d.ts +0 -3
  274. package/dist/commands/improve.d.ts.map +0 -1
  275. package/dist/commands/improve.js +0 -286
  276. package/dist/commands/improve.js.map +0 -1
  277. package/dist/commands/knowledge.d.ts +0 -3
  278. package/dist/commands/knowledge.d.ts.map +0 -1
  279. package/dist/commands/knowledge.js +0 -316
  280. package/dist/commands/knowledge.js.map +0 -1
  281. package/dist/commands/log.d.ts.map +0 -1
  282. package/dist/commands/log.js +0 -1436
  283. package/dist/commands/log.js.map +0 -1
  284. package/dist/commands/meta-index.d.ts +0 -3
  285. package/dist/commands/meta-index.d.ts.map +0 -1
  286. package/dist/commands/meta-index.js +0 -401
  287. package/dist/commands/meta-index.js.map +0 -1
  288. package/dist/commands/metrics.d.ts +0 -3
  289. package/dist/commands/metrics.d.ts.map +0 -1
  290. package/dist/commands/metrics.js +0 -843
  291. package/dist/commands/metrics.js.map +0 -1
  292. package/dist/commands/quick.d.ts +0 -3
  293. package/dist/commands/quick.d.ts.map +0 -1
  294. package/dist/commands/quick.js +0 -136
  295. package/dist/commands/quick.js.map +0 -1
  296. package/dist/commands/retro.d.ts +0 -3
  297. package/dist/commands/retro.d.ts.map +0 -1
  298. package/dist/commands/retro.js +0 -828
  299. package/dist/commands/retro.js.map +0 -1
  300. package/dist/commands/session.d.ts +0 -3
  301. package/dist/commands/session.d.ts.map +0 -1
  302. package/dist/commands/session.js +0 -346
  303. package/dist/commands/session.js.map +0 -1
  304. package/dist/commands/skills.d.ts +0 -12
  305. package/dist/commands/skills.d.ts.map +0 -1
  306. package/dist/commands/skills.js +0 -228
  307. package/dist/commands/skills.js.map +0 -1
  308. package/dist/commands/status.d.ts +0 -3
  309. package/dist/commands/status.d.ts.map +0 -1
  310. package/dist/commands/status.js +0 -127
  311. package/dist/commands/status.js.map +0 -1
  312. package/dist/commands/upgrade.d.ts.map +0 -1
  313. package/dist/commands/upgrade.js.map +0 -1
  314. package/dist/commands/watch.d.ts +0 -3
  315. package/dist/commands/watch.d.ts.map +0 -1
  316. package/dist/commands/watch.js +0 -213
  317. package/dist/commands/watch.js.map +0 -1
  318. package/dist/commands/workflow.d.ts +0 -3
  319. package/dist/commands/workflow.d.ts.map +0 -1
  320. package/dist/commands/workflow.js +0 -607
  321. package/dist/commands/workflow.js.map +0 -1
  322. package/templates/base/skills/coding/SKILL.md +0 -47
  323. package/templates/base/skills/controller/SKILL.md +0 -111
  324. package/templates/base/skills/prompt-engineering/SKILL.md +0 -103
  325. package/templates/base/skills/retrospective/SKILL.md +0 -102
  326. package/templates/base/skills/security/SKILL.md +0 -55
  327. package/templates/base/skills/testing/SKILL.md +0 -63
  328. package/templates/base/timsquad/feedback/feedback-router.sh +0 -341
  329. package/templates/base/timsquad/feedback/routing-rules.yaml +0 -352
  330. package/templates/platforms/claude-code/CLAUDE.md.template +0 -89
  331. package/templates/platforms/claude-code/rules/skill-suggest.md +0 -27
  332. package/templates/platforms/claude-code/scripts/skill-rules.json +0 -85
  333. package/templates/platforms/claude-code/scripts/skill-suggest.sh +0 -105
  334. /package/templates/base/skills/{architecture → tsq-architecture}/references/adr-template.md +0 -0
  335. /package/templates/base/skills/{architecture → tsq-architecture}/references/api-design.md +0 -0
  336. /package/templates/base/skills/{methodology/bdd → tsq-bdd}/rules/gherkin-patterns.md +0 -0
  337. /package/templates/base/skills/{coding → tsq-coding}/rules/patterns.md +0 -0
  338. /package/templates/base/skills/{controller → tsq-controller}/references/README.md +0 -0
  339. /package/templates/base/skills/{controller → tsq-controller}/rules/README.md +0 -0
  340. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/async-patterns.md +0 -0
  341. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/code-style.md +0 -0
  342. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/null-safety.md +0 -0
  343. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/type-system.md +0 -0
  344. /package/templates/base/skills/{methodology/ddd → tsq-ddd}/rules/strategic-patterns.md +0 -0
  345. /package/templates/base/skills/{methodology/debugging → tsq-debugging}/references/root-cause-tracing.md +0 -0
  346. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/SKILL.md +0 -0
  347. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/references/ci-cd-pipeline.md +0 -0
  348. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/code-signing.md +0 -0
  349. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/codemagic-setup.md +0 -0
  350. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/fastlane-setup.md +0 -0
  351. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/github-actions.md +0 -0
  352. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/store-deployment.md +0 -0
  353. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/versioning.md +0 -0
  354. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/SKILL.md +0 -0
  355. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/references/i18n-architecture.md +0 -0
  356. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/arb-files.md +0 -0
  357. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/locale-switching.md +0 -0
  358. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/localization-setup.md +0 -0
  359. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/plural-gender.md +0 -0
  360. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/text-direction.md +0 -0
  361. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/SKILL.md +0 -0
  362. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/references/monitoring-architecture.md +0 -0
  363. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/analytics.md +0 -0
  364. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/crashlytics-setup.md +0 -0
  365. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/logging.md +0 -0
  366. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/performance-monitoring.md +0 -0
  367. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/sentry-integration.md +0 -0
  368. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/SKILL.md +0 -0
  369. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/references/api-client-architecture.md +0 -0
  370. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/caching.md +0 -0
  371. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/connectivity.md +0 -0
  372. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/dio-setup.md +0 -0
  373. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/error-handling.md +0 -0
  374. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/interceptors.md +0 -0
  375. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/retrofit-patterns.md +0 -0
  376. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/SKILL.md +0 -0
  377. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/references/notification-architecture.md +0 -0
  378. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/references/platform-setup.md +0 -0
  379. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/background-processing.md +0 -0
  380. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/deep-linking.md +0 -0
  381. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/fcm-setup.md +0 -0
  382. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/local-notifications.md +0 -0
  383. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/notification-handling.md +0 -0
  384. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/notification-permissions.md +0 -0
  385. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/rich-notifications.md +0 -0
  386. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/references/freezed-patterns.md +0 -0
  387. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/references/project-structure.md +0 -0
  388. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/animations.md +0 -0
  389. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/architecture.md +0 -0
  390. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/navigation-routing.md +0 -0
  391. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/performance.md +0 -0
  392. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/platform-adaptive.md +0 -0
  393. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/state-management.md +0 -0
  394. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/testing.md +0 -0
  395. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/widget-conventions.md +0 -0
  396. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/SKILL.md +0 -0
  397. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/references/mobile-security-checklist.md +0 -0
  398. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/api-key-protection.md +0 -0
  399. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/authentication.md +0 -0
  400. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/data-protection.md +0 -0
  401. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/obfuscation.md +0 -0
  402. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/secure-storage.md +0 -0
  403. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/ssl-pinning.md +0 -0
  404. /package/templates/base/skills/{backend/node → tsq-hono}/rules/async-patterns.md +0 -0
  405. /package/templates/base/skills/{backend/node → tsq-hono}/rules/deployment.md +0 -0
  406. /package/templates/base/skills/{backend/node → tsq-hono}/rules/env-config.md +0 -0
  407. /package/templates/base/skills/{backend/node → tsq-hono}/rules/error-handling.md +0 -0
  408. /package/templates/base/skills/{backend/node → tsq-hono}/rules/hono-app-setup.md +0 -0
  409. /package/templates/base/skills/{backend/node → tsq-hono}/rules/jwt-auth.md +0 -0
  410. /package/templates/base/skills/{backend/node → tsq-hono}/rules/middleware.md +0 -0
  411. /package/templates/base/skills/{backend/node → tsq-hono}/rules/testing.md +0 -0
  412. /package/templates/base/skills/{frontend/nextjs → tsq-nextjs}/rules/app-router.md +0 -0
  413. /package/templates/base/skills/{planning → tsq-planning}/references/prd-guide.md +0 -0
  414. /package/templates/base/skills/{planning → tsq-planning}/references/requirements-guide.md +0 -0
  415. /package/templates/base/skills/{database/prisma → tsq-prisma}/rules/queries.md +0 -0
  416. /package/templates/base/skills/{database/prisma → tsq-prisma}/rules/schema-design.md +0 -0
  417. /package/templates/base/skills/{frontend/react → tsq-react}/rules/_sections.md +0 -0
  418. /package/templates/base/skills/{frontend/react → tsq-react}/rules/anti-patterns.md +0 -0
  419. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-api-routes.md +0 -0
  420. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-defer-await.md +0 -0
  421. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-dependencies.md +0 -0
  422. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-parallel.md +0 -0
  423. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-suspense-boundaries.md +0 -0
  424. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-barrel-imports.md +0 -0
  425. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-defer-third-party.md +0 -0
  426. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-dynamic-imports.md +0 -0
  427. /package/templates/base/skills/{frontend/react → tsq-react}/rules/component-conventions.md +0 -0
  428. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-combine-iterations.md +0 -0
  429. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-early-exit.md +0 -0
  430. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-index-maps.md +0 -0
  431. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-set-map-lookups.md +0 -0
  432. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-conditional-render.md +0 -0
  433. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-content-visibility.md +0 -0
  434. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-hoist-jsx.md +0 -0
  435. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-defer-reads.md +0 -0
  436. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-derived-state.md +0 -0
  437. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-memo.md +0 -0
  438. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-transitions.md +0 -0
  439. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-after-nonblocking.md +0 -0
  440. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-cache-react.md +0 -0
  441. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-parallel-fetching.md +0 -0
  442. /package/templates/base/skills/{frontend/react → tsq-react}/rules/state-location.md +0 -0
  443. /package/templates/base/skills/{security → tsq-security}/rules/owasp-examples.md +0 -0
  444. /package/templates/base/skills/{security → tsq-security}/scripts/check-secrets.sh +0 -0
  445. /package/templates/base/skills/{stability-verification → tsq-stability}/references/release-checklist.md +0 -0
  446. /package/templates/base/skills/{stability-verification → tsq-stability}/references/security-fix-patterns.md +0 -0
  447. /package/templates/base/skills/{stability-verification → tsq-stability}/rules/verification-layers.md +0 -0
  448. /package/templates/base/skills/{stability-verification → tsq-stability}/rules/verification-workflow.md +0 -0
  449. /package/templates/base/skills/{stability-verification → tsq-stability}/scripts/verify.sh +0 -0
  450. /package/templates/base/skills/{methodology/tdd → tsq-tdd}/rules/real-world-example.md +0 -0
  451. /package/templates/base/skills/{methodology/tdd → tsq-tdd}/rules/techniques.md +0 -0
  452. /package/templates/base/skills/{testing → tsq-testing}/references/testing-patterns.md +0 -0
  453. /package/templates/base/skills/{typescript → tsq-typescript}/rules/type-patterns.md +0 -0
  454. /package/templates/base/skills/{typescript → tsq-typescript}/rules/utility-types.md +0 -0
@@ -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 | 초기 작성 |
@@ -178,7 +178,17 @@ describe('UserService', () => {
178
178
 
179
179
  ---
180
180
 
181
- ## 5. 테스트 자동화
181
+ ## 5. 테스트 게이트
182
+
183
+ TimSquad 워크플로우에서 자동 실행되는 테스트 게이트 설정.
184
+
185
+ ### 5.0 게이트별 실행 명령
186
+
187
+ | 게이트 | 실행 시점 | 명령 | 타임아웃 |
188
+ |--------|----------|------|---------|
189
+ | Task (Unit) | Task 완료 시 | `npm run test:unit` | 120s |
190
+ | Sequence (Integration + Build) | Sequence 완료 시 | `npm run test:integration` + `tsc --noEmit` | 300s |
191
+ | Phase (E2E) | Phase 완료 시 | `npm run test:e2e` | 300s |
182
192
 
183
193
  ### 5.1 CI 파이프라인
184
194
 
@@ -2,7 +2,7 @@
2
2
  title: "UI/UX 명세서"
3
3
  version: 1.0.0
4
4
  last_updated: {{DATE}}
5
- author: tsq-planner
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-planner | 초기 작성 |
302
+ | 1.0.0 | {{DATE}} | tsq-architect | 초기 작성 |
@@ -0,0 +1,69 @@
1
+ # SSOT Map — 티어별 문서 주입 기준
2
+ # Tier 0: 모든 작업에 항상 주입 (Hook → systemMessage)
3
+ # Tier 1: Phase 시작 시 Controller가 주입
4
+ # Tier 2: Sequence 범위 문서 (Controller가 선택 주입)
5
+ # Tier 3: 개별 Task에 필요한 구체 spec (Controller가 선택 주입)
6
+ # optional: true → 타입별 선택 배포 문서 (미존재 시 건너뜀)
7
+
8
+ tier-0-always:
9
+ description: "모든 작업에 항상 주입되는 제약 문서"
10
+ inject_via: hook
11
+ documents:
12
+ - compiled: rules/security-constraints.md
13
+ source: security-spec.md
14
+ - compiled: rules/completion-criteria.md
15
+ source: requirements.md
16
+
17
+ tier-1-phase:
18
+ description: "Phase 시작 시 controller가 주입하는 방향성 문서"
19
+ inject_via: controller
20
+ documents:
21
+ - compiled: references/prd-summary.spec.md
22
+ source: prd.md
23
+ - compiled: references/architecture.spec.md
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
31
+
32
+ tier-2-sequence:
33
+ description: "Sequence 범위의 기능별 문서"
34
+ inject_via: controller
35
+ documents:
36
+ - compiled: references/service.spec.md
37
+ source: service-spec.md
38
+ - compiled: references/data-design.spec.md
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
55
+
56
+ tier-3-task:
57
+ description: "개별 Task에 필요한 구체 spec"
58
+ inject_via: controller
59
+ documents:
60
+ - compiled: references/error-codes.spec.md
61
+ source: error-codes.md
62
+ - compiled: references/functional.spec.md
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
@@ -9,7 +9,7 @@
9
9
 
10
10
  <!-- 현재 활성 에이전트 -->
11
11
  <active-session>
12
- <agent>tsq-planner</agent>
12
+ <agent>tsq-architect</agent>
13
13
  <started-at>{{TIMESTAMP}}</started-at>
14
14
  <mode>planning</mode>
15
15
  </active-session>
@@ -21,7 +21,7 @@
21
21
  <id>TASK-001</id>
22
22
  <title>PRD 작성</title>
23
23
  <description>제품 요구사항 정의서 초안 작성</description>
24
- <agent>tsq-planner</agent>
24
+ <agent>tsq-architect</agent>
25
25
  <phase>planning</phase>
26
26
  <started-at>{{TIMESTAMP}}</started-at>
27
27
  <status>in_progress</status>
@@ -44,7 +44,7 @@
44
44
  <task id="TASK-002" priority="1">
45
45
  <title>요구사항 정의</title>
46
46
  <description>기능/비기능 요건 작성</description>
47
- <assigned-to>tsq-planner</assigned-to>
47
+ <assigned-to>tsq-architect</assigned-to>
48
48
  <phase>planning</phase>
49
49
  <depends-on>TASK-001</depends-on>
50
50
  <estimated-effort>medium</estimated-effort>
@@ -73,7 +73,7 @@
73
73
  <!--
74
74
  현재 에이전트가 다음 에이전트에게 전달할 내용
75
75
 
76
- <from>tsq-planner</from>
76
+ <from>tsq-architect</from>
77
77
  <to>tsq-developer</to>
78
78
  <timestamp>{{TIMESTAMP}}</timestamp>
79
79
  <message>
@@ -124,7 +124,7 @@
124
124
  <approval id="APV-001" type="phase-transition">
125
125
  <from-phase>planning</from-phase>
126
126
  <to-phase>implementation</to-phase>
127
- <requested-by>tsq-planner</requested-by>
127
+ <requested-by>tsq-architect</requested-by>
128
128
  <requested-at>{{TIMESTAMP}}</requested-at>
129
129
  <reason>SSOT 문서 작성 완료, 구현 단계 진입 요청</reason>
130
130
  <checklist>
@@ -174,27 +174,27 @@
174
174
  <next-steps>
175
175
  <step order="1">
176
176
  <action>PRD 작성 완료</action>
177
- <agent>tsq-planner</agent>
177
+ <agent>tsq-architect</agent>
178
178
  <output>ssot/prd.md</output>
179
179
  </step>
180
180
  <step order="2">
181
181
  <action>요구사항 정의</action>
182
- <agent>tsq-planner</agent>
182
+ <agent>tsq-architect</agent>
183
183
  <output>ssot/requirements.md</output>
184
184
  </step>
185
185
  <step order="3">
186
186
  <action>API 명세 작성</action>
187
- <agent>tsq-planner</agent>
187
+ <agent>tsq-architect</agent>
188
188
  <output>ssot/service-spec.md</output>
189
189
  </step>
190
190
  <step order="4">
191
191
  <action>데이터 설계</action>
192
- <agent>tsq-planner</agent>
192
+ <agent>tsq-architect</agent>
193
193
  <output>ssot/data-design.md</output>
194
194
  </step>
195
195
  <step order="5">
196
196
  <action>User 승인 요청</action>
197
- <agent>tsq-planner</agent>
197
+ <agent>tsq-architect</agent>
198
198
  <requires-approval>true</requires-approval>
199
199
  </step>
200
200
  <step order="6">
@@ -209,7 +209,7 @@
209
209
  ============================================================ -->
210
210
  <session-notes>
211
211
  <!--
212
- <note timestamp="{{TIMESTAMP}}" agent="tsq-planner">
212
+ <note timestamp="{{TIMESTAMP}}" agent="tsq-architect">
213
213
  사용자가 MVP 우선 요청. 소셜 로그인은 v2로 미룸.
214
214
  </note>
215
215
  -->
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  description: ADR (Architecture Decision Record) 작성 규칙.
3
- globs:
3
+ paths:
4
4
  - ".timsquad/ssot/ADR-*"
5
5
  ---
6
6
 
@@ -0,0 +1,12 @@
1
+ ---
2
+ paths:
3
+ - "src/api/**/*.ts"
4
+ - "src/routes/**/*.ts"
5
+ - "src/controllers/**/*.ts"
6
+ ---
7
+
8
+ - RESTful 네이밍 사용 (복수형 리소스, kebab-case)
9
+ - 에러 응답 표준 형식: `{ code: string, message: string, details?: unknown }`
10
+ - HTTP 상태 코드 정확히 매핑 (200/201/400/401/403/404/500)
11
+ - 요청 validation은 엔드포인트 진입 시점에서 수행
12
+ - 비즈니스 로직은 서비스 레이어에 위치 (컨트롤러에 직접 작성 금지)
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  description: 빌드 게이트. 변경 파일의 TypeScript 에러를 자동 감지하여 완료 차단.
3
- globs:
3
+ paths:
4
4
  - "src/**/*.ts"
5
5
  - "src/**/*.tsx"
6
6
  ---
@@ -1,7 +1,5 @@
1
1
  ---
2
2
  description: 완료 검증 루프. 자기 보고 금지, exit code로 완료 판정.
3
- globs:
4
- - "**/*"
5
3
  ---
6
4
 
7
5
  # 완료 검증 루프 (Completion Verification)
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  description: 컨텍스트 윈도우 모니터. 85% 임계값 도달 시 사전 대응.
3
- globs:
3
+ paths:
4
4
  - ".timsquad/.daemon/**"
5
5
  ---
6
6
 
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  description: 피드백 라우팅 규칙. Level 1/2/3 분류 기준과 라우팅.
3
- globs:
3
+ paths:
4
4
  - ".timsquad/feedback/**"
5
5
  ---
6
6
 
@@ -15,4 +15,4 @@ globs:
15
15
  ## 규칙
16
16
  - User 승인 없이 Level 3 변경 금지
17
17
  - 모든 피드백에 Level 분류 필수
18
- - `tsq feedback "{설명}"` 으로 기록 (직접 파일 생성 금지)
18
+ - 피드백은 `.timsquad/state/decisions.jsonl`에 기록
@@ -0,0 +1,11 @@
1
+ ---
2
+ paths:
3
+ - ".timsquad/**"
4
+ - "docs/**"
5
+ ---
6
+
7
+ Librarian 에이전트가 이 경로에서 작업할 때:
8
+ - 문서 작성/갱신 허용
9
+ - 소스 코드(src/, lib/, app/) 수정 절대 금지
10
+ - 기록, 분석, 리포트 작성만 수행
11
+ - 코드 변경이 필요한 사항은 피드백으로 라우팅
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  description: Phase 관리 규칙. Phase 전환, 허용/금지 작업, 종료 조건.
3
- globs:
3
+ paths:
4
4
  - ".timsquad/state/**"
5
5
  - ".timsquad/ssot/**"
6
6
  ---
@@ -19,5 +19,5 @@ globs:
19
19
  | deployment | 배포 | - | 배포 완료 |
20
20
 
21
21
  ## Phase 종료 시
22
- - `skills/retrospective/SKILL.md`를 활용하여 회고 실행
22
+ - `/retro` (tsq-retro 스킬)를 활용하여 회고 실행
23
23
  - Phase 전환 조건 미충족 시 다음 Phase 진행 금지