timsquad 3.6.0 → 3.7.1

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 (433) hide show
  1. package/README.ko.md +103 -113
  2. package/README.md +100 -110
  3. package/dist/commands/init.js +4 -8
  4. package/dist/commands/init.js.map +1 -1
  5. package/dist/commands/{upgrade.d.ts → update.d.ts} +3 -3
  6. package/dist/commands/update.d.ts.map +1 -0
  7. package/dist/commands/{upgrade.js → update.js} +12 -17
  8. package/dist/commands/update.js.map +1 -0
  9. package/dist/daemon/event-queue.d.ts +3 -11
  10. package/dist/daemon/event-queue.d.ts.map +1 -1
  11. package/dist/daemon/event-queue.js +62 -203
  12. package/dist/daemon/event-queue.js.map +1 -1
  13. package/dist/daemon/index.d.ts +1 -1
  14. package/dist/daemon/index.d.ts.map +1 -1
  15. package/dist/daemon/index.js +15 -14
  16. package/dist/daemon/index.js.map +1 -1
  17. package/dist/index.js +3 -43
  18. package/dist/index.js.map +1 -1
  19. package/dist/lib/agent-generator.d.ts.map +1 -1
  20. package/dist/lib/agent-generator.js +10 -10
  21. package/dist/lib/agent-generator.js.map +1 -1
  22. package/dist/lib/compile-rules.d.ts.map +1 -1
  23. package/dist/lib/compile-rules.js +37 -4
  24. package/dist/lib/compile-rules.js.map +1 -1
  25. package/dist/lib/compiler.d.ts +1 -0
  26. package/dist/lib/compiler.d.ts.map +1 -1
  27. package/dist/lib/compiler.js +67 -11
  28. package/dist/lib/compiler.js.map +1 -1
  29. package/dist/{commands/log.d.ts → lib/log-utils.d.ts} +7 -15
  30. package/dist/lib/log-utils.d.ts.map +1 -0
  31. package/dist/lib/log-utils.js +347 -0
  32. package/dist/lib/log-utils.js.map +1 -0
  33. package/dist/lib/skill-generator.d.ts.map +1 -1
  34. package/dist/lib/skill-generator.js +4 -44
  35. package/dist/lib/skill-generator.js.map +1 -1
  36. package/dist/lib/ssot-map.d.ts.map +1 -1
  37. package/dist/lib/ssot-map.js +3 -0
  38. package/dist/lib/ssot-map.js.map +1 -1
  39. package/dist/lib/template.d.ts +10 -3
  40. package/dist/lib/template.d.ts.map +1 -1
  41. package/dist/lib/template.js +142 -22
  42. package/dist/lib/template.js.map +1 -1
  43. package/dist/lib/upgrade-backup.js +1 -1
  44. package/dist/lib/upgrade-backup.js.map +1 -1
  45. package/dist/types/config.d.ts.map +1 -1
  46. package/dist/types/config.js +37 -34
  47. package/dist/types/config.js.map +1 -1
  48. package/dist/types/feedback.d.ts +1 -54
  49. package/dist/types/feedback.d.ts.map +1 -1
  50. package/dist/types/feedback.js +1 -22
  51. package/dist/types/feedback.js.map +1 -1
  52. package/dist/types/project.d.ts +5 -0
  53. package/dist/types/project.d.ts.map +1 -1
  54. package/dist/types/project.js +15 -0
  55. package/dist/types/project.js.map +1 -1
  56. package/dist/types/ssot-map.d.ts +2 -0
  57. package/dist/types/ssot-map.d.ts.map +1 -1
  58. package/package.json +1 -1
  59. package/templates/base/agents/base/tsq-architect.md +1 -1
  60. package/templates/base/agents/base/tsq-dba.md +3 -1
  61. package/templates/base/agents/base/tsq-designer.md +3 -1
  62. package/templates/base/agents/base/tsq-developer.md +3 -1
  63. package/templates/base/agents/base/tsq-librarian.md +1 -1
  64. package/templates/base/agents/base/tsq-qa.md +3 -1
  65. package/templates/base/agents/base/tsq-security.md +3 -1
  66. package/templates/base/agents/overlays/platform/claude-code.md +2 -2
  67. package/templates/base/config.template.yaml +17 -28
  68. package/templates/base/knowledge/templates/task-result.md +5 -10
  69. package/templates/base/skills/_template/SKILL.md +1 -3
  70. package/templates/base/skills/{architecture → tsq-architecture}/SKILL.md +2 -2
  71. package/templates/base/skills/tsq-audit/SKILL.md +74 -0
  72. package/templates/base/skills/{methodology/bdd → tsq-bdd}/SKILL.md +14 -9
  73. package/templates/base/skills/{coding → tsq-coding}/SKILL.md +2 -4
  74. package/templates/base/skills/tsq-controller/SKILL.md +81 -0
  75. package/templates/base/skills/{mobile/dart → tsq-dart}/SKILL.md +5 -3
  76. package/templates/base/skills/{database → tsq-database}/SKILL.md +5 -2
  77. package/templates/base/skills/{methodology/ddd → tsq-ddd}/SKILL.md +15 -10
  78. package/templates/base/skills/{methodology/debugging → tsq-debugging}/SKILL.md +2 -2
  79. package/templates/base/skills/tsq-decompose/SKILL.md +117 -0
  80. package/templates/base/skills/tsq-delete/SKILL.md +72 -0
  81. package/templates/base/skills/{mobile/flutter → tsq-flutter}/SKILL.md +6 -3
  82. package/templates/base/skills/tsq-full/SKILL.md +67 -0
  83. package/templates/base/skills/tsq-grill/SKILL.md +86 -0
  84. package/templates/base/skills/{backend/node → tsq-hono}/SKILL.md +6 -4
  85. package/templates/base/skills/tsq-librarian/SKILL.md +78 -0
  86. package/templates/base/skills/tsq-log/SKILL.md +30 -0
  87. package/templates/base/skills/{frontend/nextjs → tsq-nextjs}/SKILL.md +14 -9
  88. package/templates/base/skills/{planning → tsq-planning}/SKILL.md +2 -2
  89. package/templates/base/skills/{database/prisma → tsq-prisma}/SKILL.md +15 -9
  90. package/templates/base/skills/{product-audit → tsq-product-audit}/SKILL.md +2 -4
  91. package/templates/base/skills/{prompt-engineering → tsq-prompt}/SKILL.md +6 -4
  92. package/templates/base/skills/tsq-protocol/SKILL.md +85 -33
  93. package/templates/base/skills/tsq-quick/SKILL.md +58 -0
  94. package/templates/base/skills/{frontend/react → tsq-react}/SKILL.md +6 -3
  95. package/templates/base/skills/tsq-retro/SKILL.md +86 -0
  96. package/templates/base/skills/tsq-retro/references/feedback-guide.md +58 -0
  97. package/templates/base/skills/tsq-retro/references/improve-protocol.md +87 -0
  98. package/templates/base/skills/{security → tsq-security}/SKILL.md +2 -4
  99. package/templates/base/skills/{spec → tsq-spec}/SKILL.md +4 -6
  100. package/templates/base/skills/{stability-verification → tsq-stability}/SKILL.md +3 -3
  101. package/templates/base/skills/tsq-start/SKILL.md +90 -0
  102. package/templates/base/skills/tsq-start/references/onboarding-questions.md +177 -0
  103. package/templates/base/skills/tsq-status/SKILL.md +32 -0
  104. package/templates/base/skills/{methodology/tdd → tsq-tdd}/SKILL.md +6 -3
  105. package/templates/base/skills/{testing → tsq-testing}/SKILL.md +5 -7
  106. package/templates/base/skills/{typescript → tsq-typescript}/SKILL.md +2 -2
  107. package/templates/base/skills/{ui-design → tsq-ui}/SKILL.md +2 -2
  108. package/templates/base/skills/tsq-update/SKILL.md +48 -0
  109. package/templates/base/timsquad/constraints/competency-framework.xml +2 -2
  110. package/templates/base/timsquad/constraints/ssot-schema.xml +2 -2
  111. package/templates/base/timsquad/process/phase-checklist.yaml +1 -1
  112. package/templates/base/timsquad/process/state-machine.xml +2 -2
  113. package/templates/base/timsquad/process/validation-rules.xml +8 -8
  114. package/templates/base/timsquad/process/workflow-base.xml +8 -8
  115. package/templates/base/timsquad/retrospective/cycle-report.template.md +2 -2
  116. package/templates/base/timsquad/retrospective/patterns/failure-patterns.md +1 -1
  117. package/templates/base/timsquad/retrospective/patterns/success-patterns.md +2 -2
  118. package/templates/base/timsquad/retrospective/retrospective-state.xml +2 -2
  119. package/templates/base/timsquad/ssot/audit-trail-spec.template.md +155 -0
  120. package/templates/base/timsquad/ssot/compliance-matrix.template.md +105 -0
  121. package/templates/base/timsquad/ssot/component-map.template.md +181 -0
  122. package/templates/base/timsquad/ssot/data-design.template.md +4 -4
  123. package/templates/base/timsquad/ssot/deployment-spec.template.md +29 -22
  124. package/templates/base/timsquad/ssot/env-config.template.md +4 -2
  125. package/templates/base/timsquad/ssot/error-codes.template.md +3 -3
  126. package/templates/base/timsquad/ssot/functional-spec.template.md +40 -3
  127. package/templates/base/timsquad/ssot/glossary.template.md +2 -2
  128. package/templates/base/timsquad/ssot/infra-topology.template.md +191 -0
  129. package/templates/base/timsquad/ssot/integration-spec.template.md +2 -2
  130. package/templates/base/timsquad/ssot/monitoring-spec.template.md +185 -0
  131. package/templates/base/timsquad/ssot/navigation-map.template.md +154 -0
  132. package/templates/base/timsquad/ssot/performance-budget.template.md +132 -0
  133. package/templates/base/timsquad/ssot/planning.template.md +3 -3
  134. package/templates/base/timsquad/ssot/prd/_template.md +73 -0
  135. package/templates/base/timsquad/ssot/prd.template.md +10 -21
  136. package/templates/base/timsquad/ssot/requirements.template.md +3 -3
  137. package/templates/base/timsquad/ssot/sdk-spec.template.md +223 -0
  138. package/templates/base/timsquad/ssot/service-spec.template.md +3 -3
  139. package/templates/base/timsquad/ssot/state-machine.template.md +127 -0
  140. package/templates/base/timsquad/ssot/ui-ux-spec.template.md +43 -3
  141. package/templates/base/timsquad/ssot-map.template.yaml +28 -0
  142. package/templates/base/timsquad/state/workspace.xml +11 -11
  143. package/templates/platforms/claude-code/rules/adr-rules.md +1 -1
  144. package/templates/platforms/claude-code/rules/build-gate.md +1 -1
  145. package/templates/platforms/claude-code/rules/completion-verification.md +0 -2
  146. package/templates/platforms/claude-code/rules/context-monitor.md +1 -1
  147. package/templates/platforms/claude-code/rules/feedback-routing.md +2 -2
  148. package/templates/platforms/claude-code/rules/phase-management.md +2 -2
  149. package/templates/platforms/claude-code/rules/plan-review.md +2 -2
  150. package/templates/platforms/claude-code/rules/quality-guards.md +0 -2
  151. package/templates/platforms/claude-code/rules/sequence-management.md +15 -15
  152. package/templates/platforms/claude-code/rules/session-notes.md +1 -1
  153. package/templates/platforms/claude-code/rules/workspace-sync.md +1 -1
  154. package/templates/platforms/claude-code/scripts/build-gate.sh +6 -1
  155. package/templates/platforms/claude-code/scripts/change-scope-guard.sh +1 -4
  156. package/templates/platforms/claude-code/scripts/check-capability.sh +68 -0
  157. package/templates/platforms/claude-code/scripts/completion-guard.sh +62 -4
  158. package/templates/platforms/claude-code/scripts/context-restore.sh +33 -6
  159. package/templates/platforms/claude-code/scripts/phase-guard.sh +2 -5
  160. package/templates/platforms/claude-code/scripts/pre-compact.sh +3 -3
  161. package/templates/platforms/claude-code/scripts/safe-guard.sh +2 -5
  162. package/templates/platforms/claude-code/scripts/subagent-start.sh +11 -0
  163. package/templates/platforms/claude-code/scripts/subagent-stop.sh +11 -0
  164. package/templates/platforms/claude-code/settings.json +20 -74
  165. package/templates/project-types/api-backend/config.yaml +9 -5
  166. package/templates/project-types/api-backend/process/workflow.xml +2 -2
  167. package/templates/project-types/fintech/config.yaml +13 -19
  168. package/templates/project-types/fintech/ssot/audit-trail-spec.template.md +207 -0
  169. package/templates/project-types/fintech/ssot/compliance-matrix.template.md +187 -0
  170. package/templates/project-types/infra/config.yaml +7 -4
  171. package/templates/project-types/infra/process/workflow.xml +3 -3
  172. package/templates/project-types/mobile-app/config.yaml +8 -14
  173. package/templates/project-types/mobile-app/process/workflow.xml +4 -4
  174. package/templates/project-types/platform/config.yaml +8 -5
  175. package/templates/project-types/platform/process/workflow.xml +3 -3
  176. package/templates/project-types/web-app/config.yaml +9 -15
  177. package/templates/project-types/web-app/process/workflow.xml +6 -6
  178. package/templates/project-types/web-service/config.yaml +10 -19
  179. package/templates/project-types/web-service/process/workflow.xml +6 -6
  180. package/dist/commands/audit.d.ts +0 -22
  181. package/dist/commands/audit.d.ts.map +0 -1
  182. package/dist/commands/audit.js +0 -233
  183. package/dist/commands/audit.js.map +0 -1
  184. package/dist/commands/compile.d.ts +0 -3
  185. package/dist/commands/compile.d.ts.map +0 -1
  186. package/dist/commands/compile.js +0 -251
  187. package/dist/commands/compile.js.map +0 -1
  188. package/dist/commands/feedback.d.ts +0 -12
  189. package/dist/commands/feedback.d.ts.map +0 -1
  190. package/dist/commands/feedback.js +0 -382
  191. package/dist/commands/feedback.js.map +0 -1
  192. package/dist/commands/full.d.ts +0 -3
  193. package/dist/commands/full.d.ts.map +0 -1
  194. package/dist/commands/full.js +0 -88
  195. package/dist/commands/full.js.map +0 -1
  196. package/dist/commands/git/commit.d.ts +0 -3
  197. package/dist/commands/git/commit.d.ts.map +0 -1
  198. package/dist/commands/git/commit.js +0 -85
  199. package/dist/commands/git/commit.js.map +0 -1
  200. package/dist/commands/git/index.d.ts +0 -5
  201. package/dist/commands/git/index.d.ts.map +0 -1
  202. package/dist/commands/git/index.js +0 -5
  203. package/dist/commands/git/index.js.map +0 -1
  204. package/dist/commands/git/pr.d.ts +0 -3
  205. package/dist/commands/git/pr.d.ts.map +0 -1
  206. package/dist/commands/git/pr.js +0 -139
  207. package/dist/commands/git/pr.js.map +0 -1
  208. package/dist/commands/git/release.d.ts +0 -3
  209. package/dist/commands/git/release.d.ts.map +0 -1
  210. package/dist/commands/git/release.js +0 -153
  211. package/dist/commands/git/release.js.map +0 -1
  212. package/dist/commands/git/sync.d.ts +0 -3
  213. package/dist/commands/git/sync.d.ts.map +0 -1
  214. package/dist/commands/git/sync.js +0 -132
  215. package/dist/commands/git/sync.js.map +0 -1
  216. package/dist/commands/improve.d.ts +0 -3
  217. package/dist/commands/improve.d.ts.map +0 -1
  218. package/dist/commands/improve.js +0 -286
  219. package/dist/commands/improve.js.map +0 -1
  220. package/dist/commands/knowledge.d.ts +0 -3
  221. package/dist/commands/knowledge.d.ts.map +0 -1
  222. package/dist/commands/knowledge.js +0 -316
  223. package/dist/commands/knowledge.js.map +0 -1
  224. package/dist/commands/log.d.ts.map +0 -1
  225. package/dist/commands/log.js +0 -1468
  226. package/dist/commands/log.js.map +0 -1
  227. package/dist/commands/meta-index.d.ts +0 -3
  228. package/dist/commands/meta-index.d.ts.map +0 -1
  229. package/dist/commands/meta-index.js +0 -431
  230. package/dist/commands/meta-index.js.map +0 -1
  231. package/dist/commands/metrics.d.ts +0 -3
  232. package/dist/commands/metrics.d.ts.map +0 -1
  233. package/dist/commands/metrics.js +0 -843
  234. package/dist/commands/metrics.js.map +0 -1
  235. package/dist/commands/quick.d.ts +0 -3
  236. package/dist/commands/quick.d.ts.map +0 -1
  237. package/dist/commands/quick.js +0 -136
  238. package/dist/commands/quick.js.map +0 -1
  239. package/dist/commands/retro.d.ts +0 -3
  240. package/dist/commands/retro.d.ts.map +0 -1
  241. package/dist/commands/retro.js +0 -885
  242. package/dist/commands/retro.js.map +0 -1
  243. package/dist/commands/session.d.ts +0 -3
  244. package/dist/commands/session.d.ts.map +0 -1
  245. package/dist/commands/session.js +0 -346
  246. package/dist/commands/session.js.map +0 -1
  247. package/dist/commands/skills.d.ts +0 -12
  248. package/dist/commands/skills.d.ts.map +0 -1
  249. package/dist/commands/skills.js +0 -228
  250. package/dist/commands/skills.js.map +0 -1
  251. package/dist/commands/status.d.ts +0 -3
  252. package/dist/commands/status.d.ts.map +0 -1
  253. package/dist/commands/status.js +0 -127
  254. package/dist/commands/status.js.map +0 -1
  255. package/dist/commands/upgrade.d.ts.map +0 -1
  256. package/dist/commands/upgrade.js.map +0 -1
  257. package/dist/commands/watch.d.ts +0 -3
  258. package/dist/commands/watch.d.ts.map +0 -1
  259. package/dist/commands/watch.js +0 -213
  260. package/dist/commands/watch.js.map +0 -1
  261. package/dist/commands/workflow.d.ts +0 -5
  262. package/dist/commands/workflow.d.ts.map +0 -1
  263. package/dist/commands/workflow.js +0 -781
  264. package/dist/commands/workflow.js.map +0 -1
  265. package/templates/base/skills/audit/SKILL.md +0 -66
  266. package/templates/base/skills/controller/SKILL.md +0 -77
  267. package/templates/base/skills/controller/delegation/developer.md +0 -25
  268. package/templates/base/skills/controller/delegation/librarian.md +0 -33
  269. package/templates/base/skills/controller/delegation/reviewer.md +0 -19
  270. package/templates/base/skills/controller/triggers/phase-complete.md +0 -25
  271. package/templates/base/skills/controller/triggers/sequence-complete.md +0 -15
  272. package/templates/base/skills/controller/triggers/ssot-changed.md +0 -14
  273. package/templates/base/skills/controller/triggers/task-complete.md +0 -14
  274. package/templates/base/skills/librarian/SKILL.md +0 -53
  275. package/templates/base/skills/main-session-constraints/SKILL.md +0 -62
  276. package/templates/base/skills/retrospective/SKILL.md +0 -77
  277. package/templates/base/skills/review/SKILL.md +0 -72
  278. package/templates/base/skills/tsq-cli/SKILL.md +0 -73
  279. package/templates/base/skills/tsq-cli/references/cli-reference.md +0 -92
  280. package/templates/base/timsquad/feedback/feedback-router.sh +0 -341
  281. package/templates/base/timsquad/feedback/routing-rules.yaml +0 -352
  282. package/templates/platforms/claude-code/CLAUDE.md.template +0 -89
  283. package/templates/platforms/claude-code/rules/skill-suggest.md +0 -27
  284. package/templates/platforms/claude-code/scripts/skill-inject.sh +0 -216
  285. package/templates/platforms/claude-code/scripts/skill-rules.json +0 -95
  286. package/templates/platforms/claude-code/scripts/skill-suggest.sh +0 -105
  287. package/templates/platforms/claude-code/scripts/subagent-inject.sh +0 -53
  288. /package/templates/base/skills/{architecture → tsq-architecture}/references/adr-template.md +0 -0
  289. /package/templates/base/skills/{architecture → tsq-architecture}/references/api-design.md +0 -0
  290. /package/templates/base/skills/{methodology/bdd → tsq-bdd}/rules/gherkin-patterns.md +0 -0
  291. /package/templates/base/skills/{coding → tsq-coding}/rules/async-patterns.md +0 -0
  292. /package/templates/base/skills/{coding → tsq-coding}/rules/code-organization.md +0 -0
  293. /package/templates/base/skills/{coding → tsq-coding}/rules/error-handling.md +0 -0
  294. /package/templates/base/skills/{coding → tsq-coding}/rules/patterns.md +0 -0
  295. /package/templates/base/skills/{coding → tsq-coding}/rules/type-safety.md +0 -0
  296. /package/templates/base/skills/{controller → tsq-controller}/memory/.gitkeep +0 -0
  297. /package/templates/base/skills/{controller → tsq-controller}/references/README.md +0 -0
  298. /package/templates/base/skills/{controller → tsq-controller}/rules/README.md +0 -0
  299. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/async-patterns.md +0 -0
  300. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/code-style.md +0 -0
  301. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/null-safety.md +0 -0
  302. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/type-system.md +0 -0
  303. /package/templates/base/skills/{database → tsq-database}/rules/query-optimization.md +0 -0
  304. /package/templates/base/skills/{database → tsq-database}/rules/supabase-patterns.md +0 -0
  305. /package/templates/base/skills/{methodology/ddd → tsq-ddd}/rules/strategic-patterns.md +0 -0
  306. /package/templates/base/skills/{methodology/debugging → tsq-debugging}/references/root-cause-tracing.md +0 -0
  307. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/SKILL.md +0 -0
  308. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/references/ci-cd-pipeline.md +0 -0
  309. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/code-signing.md +0 -0
  310. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/codemagic-setup.md +0 -0
  311. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/fastlane-setup.md +0 -0
  312. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/github-actions.md +0 -0
  313. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/store-deployment.md +0 -0
  314. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/versioning.md +0 -0
  315. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/SKILL.md +0 -0
  316. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/references/i18n-architecture.md +0 -0
  317. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/arb-files.md +0 -0
  318. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/locale-switching.md +0 -0
  319. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/localization-setup.md +0 -0
  320. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/plural-gender.md +0 -0
  321. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/text-direction.md +0 -0
  322. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/SKILL.md +0 -0
  323. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/references/monitoring-architecture.md +0 -0
  324. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/analytics.md +0 -0
  325. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/crashlytics-setup.md +0 -0
  326. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/logging.md +0 -0
  327. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/performance-monitoring.md +0 -0
  328. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/sentry-integration.md +0 -0
  329. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/SKILL.md +0 -0
  330. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/references/api-client-architecture.md +0 -0
  331. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/caching.md +0 -0
  332. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/connectivity.md +0 -0
  333. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/dio-setup.md +0 -0
  334. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/error-handling.md +0 -0
  335. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/interceptors.md +0 -0
  336. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/retrofit-patterns.md +0 -0
  337. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/SKILL.md +0 -0
  338. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/references/notification-architecture.md +0 -0
  339. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/references/platform-setup.md +0 -0
  340. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/background-processing.md +0 -0
  341. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/deep-linking.md +0 -0
  342. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/fcm-setup.md +0 -0
  343. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/local-notifications.md +0 -0
  344. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/notification-handling.md +0 -0
  345. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/notification-permissions.md +0 -0
  346. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/rich-notifications.md +0 -0
  347. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/references/freezed-patterns.md +0 -0
  348. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/references/project-structure.md +0 -0
  349. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/animations.md +0 -0
  350. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/architecture.md +0 -0
  351. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/navigation-routing.md +0 -0
  352. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/performance.md +0 -0
  353. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/platform-adaptive.md +0 -0
  354. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/state-management.md +0 -0
  355. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/testing.md +0 -0
  356. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/widget-conventions.md +0 -0
  357. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/SKILL.md +0 -0
  358. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/references/mobile-security-checklist.md +0 -0
  359. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/api-key-protection.md +0 -0
  360. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/authentication.md +0 -0
  361. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/data-protection.md +0 -0
  362. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/obfuscation.md +0 -0
  363. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/secure-storage.md +0 -0
  364. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/ssl-pinning.md +0 -0
  365. /package/templates/base/skills/{backend/node → tsq-hono}/rules/async-patterns.md +0 -0
  366. /package/templates/base/skills/{backend/node → tsq-hono}/rules/deployment.md +0 -0
  367. /package/templates/base/skills/{backend/node → tsq-hono}/rules/env-config.md +0 -0
  368. /package/templates/base/skills/{backend/node → tsq-hono}/rules/error-handling.md +0 -0
  369. /package/templates/base/skills/{backend/node → tsq-hono}/rules/hono-app-setup.md +0 -0
  370. /package/templates/base/skills/{backend/node → tsq-hono}/rules/jwt-auth.md +0 -0
  371. /package/templates/base/skills/{backend/node → tsq-hono}/rules/middleware.md +0 -0
  372. /package/templates/base/skills/{backend/node → tsq-hono}/rules/testing.md +0 -0
  373. /package/templates/base/skills/{frontend/nextjs → tsq-nextjs}/rules/app-router.md +0 -0
  374. /package/templates/base/skills/{planning → tsq-planning}/references/prd-guide.md +0 -0
  375. /package/templates/base/skills/{planning → tsq-planning}/references/requirements-guide.md +0 -0
  376. /package/templates/base/skills/{database/prisma → tsq-prisma}/rules/queries.md +0 -0
  377. /package/templates/base/skills/{database/prisma → tsq-prisma}/rules/schema-design.md +0 -0
  378. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/01-security.md +0 -0
  379. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/02-performance.md +0 -0
  380. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/03-seo.md +0 -0
  381. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/04-accessibility.md +0 -0
  382. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/05-ui-ux.md +0 -0
  383. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/06-architecture.md +0 -0
  384. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/07-functional-requirements.md +0 -0
  385. /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/audit-protocol.md +0 -0
  386. /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/false-positive-guard.md +0 -0
  387. /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/scoring-criteria.md +0 -0
  388. /package/templates/base/skills/{product-audit → tsq-product-audit}/templates/improvement-plan-template.md +0 -0
  389. /package/templates/base/skills/{product-audit → tsq-product-audit}/templates/report-template.md +0 -0
  390. /package/templates/base/skills/{frontend/react → tsq-react}/rules/_sections.md +0 -0
  391. /package/templates/base/skills/{frontend/react → tsq-react}/rules/anti-patterns.md +0 -0
  392. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-api-routes.md +0 -0
  393. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-defer-await.md +0 -0
  394. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-dependencies.md +0 -0
  395. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-parallel.md +0 -0
  396. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-suspense-boundaries.md +0 -0
  397. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-barrel-imports.md +0 -0
  398. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-defer-third-party.md +0 -0
  399. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-dynamic-imports.md +0 -0
  400. /package/templates/base/skills/{frontend/react → tsq-react}/rules/component-conventions.md +0 -0
  401. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-combine-iterations.md +0 -0
  402. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-early-exit.md +0 -0
  403. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-index-maps.md +0 -0
  404. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-set-map-lookups.md +0 -0
  405. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-conditional-render.md +0 -0
  406. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-content-visibility.md +0 -0
  407. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-hoist-jsx.md +0 -0
  408. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-defer-reads.md +0 -0
  409. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-derived-state.md +0 -0
  410. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-memo.md +0 -0
  411. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-transitions.md +0 -0
  412. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-after-nonblocking.md +0 -0
  413. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-cache-react.md +0 -0
  414. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-parallel-fetching.md +0 -0
  415. /package/templates/base/skills/{frontend/react → tsq-react}/rules/state-location.md +0 -0
  416. /package/templates/base/skills/{retrospective → tsq-retro}/references/improvement-template.md +0 -0
  417. /package/templates/base/skills/{security → tsq-security}/rules/auth-patterns.md +0 -0
  418. /package/templates/base/skills/{security → tsq-security}/rules/dependency-security.md +0 -0
  419. /package/templates/base/skills/{security → tsq-security}/rules/input-validation.md +0 -0
  420. /package/templates/base/skills/{security → tsq-security}/rules/owasp-examples.md +0 -0
  421. /package/templates/base/skills/{security → tsq-security}/rules/secrets-management.md +0 -0
  422. /package/templates/base/skills/{security → tsq-security}/scripts/check-secrets.sh +0 -0
  423. /package/templates/base/skills/{stability-verification → tsq-stability}/references/release-checklist.md +0 -0
  424. /package/templates/base/skills/{stability-verification → tsq-stability}/references/security-fix-patterns.md +0 -0
  425. /package/templates/base/skills/{stability-verification → tsq-stability}/rules/verification-layers.md +0 -0
  426. /package/templates/base/skills/{stability-verification → tsq-stability}/rules/verification-workflow.md +0 -0
  427. /package/templates/base/skills/{stability-verification → tsq-stability}/scripts/verify.sh +0 -0
  428. /package/templates/base/skills/{methodology/tdd → tsq-tdd}/rules/real-world-example.md +0 -0
  429. /package/templates/base/skills/{methodology/tdd → tsq-tdd}/rules/techniques.md +0 -0
  430. /package/templates/base/skills/{testing → tsq-testing}/references/e2e-stability.md +0 -0
  431. /package/templates/base/skills/{testing → tsq-testing}/references/testing-patterns.md +0 -0
  432. /package/templates/base/skills/{typescript → tsq-typescript}/rules/type-patterns.md +0 -0
  433. /package/templates/base/skills/{typescript → tsq-typescript}/rules/utility-types.md +0 -0
@@ -0,0 +1,155 @@
1
+ ---
2
+ title: "감사 추적 명세서 (Audit Trail Specification)"
3
+ version: 1.0.0
4
+ last_updated: {{DATE}}
5
+ author: tsq-security
6
+ status: draft
7
+ project: {{PROJECT_NAME}}
8
+ ---
9
+
10
+ # 감사 추적 명세서 (Audit Trail Specification)
11
+
12
+ > 시스템 내 모든 주요 활동의 감사 추적(Audit Trail)을 설계합니다.
13
+ > 보안 사고 대응, 분쟁 해결, 규제 준수를 위한 추적성을 보장합니다.
14
+
15
+ ---
16
+
17
+ ## 1. 감사 대상
18
+
19
+ ### 1.1 이벤트 분류
20
+
21
+ | 분류 | 이벤트 | 보존 기간 | 필수 |
22
+ |-----|--------|:--------:|:----:|
23
+ | 인증 | 로그인, 로그아웃, MFA | 5년 | ✅ |
24
+ | 인가 | 권한 변경, 역할 부여/회수 | 영구 | ✅ |
25
+ | 데이터 접근 | 민감 데이터 조회 | 5년 | ✅ |
26
+ | 데이터 변경 | 생성, 수정, 삭제 | 영구 | ✅ |
27
+ | 거래 | 주문, 결제, 환불, 정산 | 5년 | ✅ |
28
+ | 시스템 | 배포, 설정 변경, 장애 | 3년 | ✅ |
29
+ | 관리자 | 관리자 패널 모든 작업 | 영구 | ✅ |
30
+
31
+ ### 1.2 감사 레벨
32
+
33
+ | 레벨 | 설명 | 적용 |
34
+ |-----|------|------|
35
+ | L1 | 이벤트 발생 기록 (who, when, what) | 모든 이벤트 |
36
+ | L2 | 변경 전/후 데이터 (before/after) | 데이터 변경 |
37
+ | L3 | 전체 요청/응답 페이로드 | 금융 거래 |
38
+
39
+ ---
40
+
41
+ ## 2. 감사 로그 스키마
42
+
43
+ ### 2.1 기본 필드
44
+
45
+ ```json
46
+ {
47
+ "id": "audit_abc123",
48
+ "timestamp": "2026-01-01T00:00:00.000Z",
49
+ "event_type": "ORDER_CREATED",
50
+ "category": "transaction",
51
+ "level": "L2",
52
+ "actor": {
53
+ "user_id": "user_123",
54
+ "ip_address": "1.2.3.4",
55
+ "user_agent": "Mozilla/5.0...",
56
+ "session_id": "sess_456"
57
+ },
58
+ "target": {
59
+ "entity_type": "order",
60
+ "entity_id": "order_789",
61
+ "path": "/api/orders"
62
+ },
63
+ "changes": {
64
+ "before": null,
65
+ "after": { "status": "created", "amount": 50000 }
66
+ },
67
+ "metadata": {
68
+ "trace_id": "trace_xyz",
69
+ "service": "order-service",
70
+ "version": "1.2.3"
71
+ },
72
+ "result": "success"
73
+ }
74
+ ```
75
+
76
+ ### 2.2 이벤트 타입
77
+
78
+ | 카테고리 | 이벤트 타입 | 레벨 | 설명 |
79
+ |---------|-----------|:----:|------|
80
+ | auth | `LOGIN_SUCCESS` | L1 | 로그인 성공 |
81
+ | auth | `LOGIN_FAILURE` | L1 | 로그인 실패 (사유 포함) |
82
+ | auth | `TOKEN_REFRESH` | L1 | 토큰 갱신 |
83
+ | auth | `MFA_VERIFIED` | L1 | MFA 인증 |
84
+ | authz | `ROLE_ASSIGNED` | L2 | 역할 부여 |
85
+ | authz | `PERMISSION_CHANGED` | L2 | 권한 변경 |
86
+ | data | `RECORD_CREATED` | L2 | 데이터 생성 |
87
+ | data | `RECORD_UPDATED` | L2 | 데이터 수정 (before/after) |
88
+ | data | `RECORD_DELETED` | L2 | 데이터 삭제 (before 포함) |
89
+ | data | `SENSITIVE_DATA_ACCESS` | L1 | 민감 데이터 조회 |
90
+ | txn | `ORDER_CREATED` | L3 | 주문 생성 |
91
+ | txn | `PAYMENT_PROCESSED` | L3 | 결제 처리 |
92
+ | txn | `REFUND_ISSUED` | L3 | 환불 처리 |
93
+ | system | `CONFIG_CHANGED` | L2 | 시스템 설정 변경 |
94
+ | system | `DEPLOYMENT` | L1 | 서비스 배포 |
95
+
96
+ ---
97
+
98
+ ## 3. 저장 아키텍처
99
+
100
+ ### 3.1 저장소 구성
101
+
102
+ | 저장소 | 용도 | 보존 | 접근 |
103
+ |-------|------|------|------|
104
+ | Hot (DB) | 최근 로그 조회 | 30일 | 실시간 검색 |
105
+ | Warm (Object Storage) | 중기 보관 | 1년 | 일괄 검색 |
106
+ | Cold (Archive) | 장기 보관 | 5년+ | 복원 후 검색 |
107
+
108
+ ### 3.2 무결성 보장
109
+
110
+ | 방법 | 설명 |
111
+ |-----|------|
112
+ | 쓰기 전용 | 감사 로그는 수정/삭제 불가 (append-only) |
113
+ | 해시 체인 | 각 로그에 이전 해시 포함 → 변조 감지 |
114
+ | 타임스탬프 | 신뢰할 수 있는 시간 소스 (NTP) |
115
+ | 접근 제어 | 쓰기: 시스템만 / 읽기: 감사 권한 필요 |
116
+
117
+ ---
118
+
119
+ ## 4. 검색 및 조회
120
+
121
+ ### 4.1 검색 필드
122
+
123
+ | 필드 | 인덱스 | 검색 예시 |
124
+ |-----|:------:|----------|
125
+ | actor.user_id | ✅ | 특정 사용자의 모든 활동 |
126
+ | event_type | ✅ | 모든 로그인 실패 |
127
+ | target.entity_id | ✅ | 특정 주문의 모든 변경 |
128
+ | timestamp | ✅ | 기간별 조회 |
129
+ | result | ✅ | 실패한 작업만 |
130
+
131
+ ### 4.2 조회 API
132
+
133
+ | 엔드포인트 | 용도 | 권한 |
134
+ |-----------|------|------|
135
+ | `GET /api/audit/search` | 조건부 검색 | AUDITOR+ |
136
+ | `GET /api/audit/:id` | 단건 상세 | AUDITOR+ |
137
+ | `GET /api/audit/entity/:type/:id` | 엔티티 이력 | AUDITOR+ |
138
+ | `GET /api/audit/user/:id` | 사용자 활동 | AUDITOR+ |
139
+ | `POST /api/audit/export` | CSV/JSON 내보내기 | ADMIN |
140
+
141
+ ---
142
+
143
+ ## 5. 관련 문서
144
+
145
+ - [컴플라이언스 매트릭스](./compliance-matrix.md) — 규제 요구사항
146
+ - [보안 명세](./security-spec.md) — 접근 제어 정책
147
+ - [데이터 설계](./data-design.md) — 감사 테이블 스키마
148
+
149
+ ---
150
+
151
+ ## 변경 이력
152
+
153
+ | 버전 | 날짜 | 작성자 | 변경 내용 |
154
+ |------|------|--------|----------|
155
+ | 1.0.0 | {{DATE}} | tsq-security | 초기 작성 |
@@ -0,0 +1,105 @@
1
+ ---
2
+ title: "컴플라이언스 매트릭스 (Compliance Matrix)"
3
+ version: 1.0.0
4
+ last_updated: {{DATE}}
5
+ author: tsq-security
6
+ status: draft
7
+ project: {{PROJECT_NAME}}
8
+ ---
9
+
10
+ # 컴플라이언스 매트릭스 (Compliance Matrix)
11
+
12
+ > 프로젝트에 적용되는 법규, 산업 표준, 내부 정책의 준수 현황을 추적합니다.
13
+ > 프로젝트 특성에 맞는 규제 항목을 선택하여 사용하세요.
14
+
15
+ ---
16
+
17
+ ## 1. 적용 규제
18
+
19
+ ### 1.1 법률/규정
20
+
21
+ | 규제 | 관할 | 적용 범위 | 필수 여부 | 상태 |
22
+ |-----|------|----------|:--------:|:----:|
23
+ | 개인정보보호법 | 대한민국 | 개인정보 처리 | ✅ | ⏳ |
24
+ | 정보통신망법 | 대한민국 | 정보통신 서비스 | 조건부 | - |
25
+ | GDPR | EU | EU 사용자 대상 | 조건부 | - |
26
+ <!-- 금융: 전자금융거래법, 신용정보법 → fintech override 참조 -->
27
+ <!-- 의료: 의료법, 개인정보보호법 특례 → 해당 시 추가 -->
28
+
29
+ ### 1.2 산업 표준
30
+
31
+ | 표준 | 적용 범위 | 인증 필요 | 상태 |
32
+ |-----|----------|:--------:|:----:|
33
+ | ISO 27001 | 정보보안 관리 | 권장 | - |
34
+ | SOC 2 Type II | 서비스 신뢰성 | 권장 | - |
35
+ <!-- 금융: PCI DSS, ISMS-P → fintech override 참조 -->
36
+
37
+ ---
38
+
39
+ ## 2. 요구사항 매트릭스
40
+
41
+ ### 2.1 데이터 보호
42
+
43
+ | 요구사항 | 근거 규제 | 구현 방법 | 담당 | 상태 |
44
+ |---------|----------|----------|------|:----:|
45
+ | 개인정보 암호화 (저장) | 개인정보보호법 §29 | AES-256 | 개발팀 | ⏳ |
46
+ | 개인정보 암호화 (전송) | 개인정보보호법 §29 | TLS 1.3 | 인프라 | ⏳ |
47
+ | 개인정보 수집 동의 | 개인정보보호법 §15 | 동의 UI + 로그 | 개발팀 | ⏳ |
48
+ | 개인정보 파기 | 개인정보보호법 §21 | 자동 파기 배치 | 개발팀 | ⏳ |
49
+ | 접근 권한 관리 | 개인정보보호법 §29 | RBAC | 개발팀 | ⏳ |
50
+
51
+ ### 2.2 인프라/보안
52
+
53
+ | 요구사항 | 근거 규제 | 구현 방법 | 담당 | 상태 |
54
+ |---------|----------|----------|------|:----:|
55
+ | 취약점 점검 | ISO 27001 | 정기 스캔 | 보안팀 | ⏳ |
56
+ | 접근 로그 보관 | 개인정보보호법 | 중앙 로그 시스템 | 인프라 | ⏳ |
57
+ | 네트워크 분리 | 보안 기준 | VPC 분리 | 인프라 | ⏳ |
58
+ <!-- 금융 특화(FDS, PCI DSS 등)는 fintech override에서 추가 -->
59
+
60
+ ---
61
+
62
+ ## 3. 인증/심사 일정
63
+
64
+ | 인증 | 심사 유형 | 예정일 | 담당 | 상태 |
65
+ |-----|---------|-------|------|:----:|
66
+ | ISO 27001 | 최초 인증 | TBD | 보안팀 | 계획 |
67
+ <!-- 금융: PCI DSS, ISMS-P → fintech override 참조 -->
68
+
69
+ ---
70
+
71
+ ## 4. 준수 체크리스트
72
+
73
+ ### 4.1 출시 전 필수
74
+
75
+ - [ ] 개인정보 처리방침 작성 및 게시
76
+ - [ ] 이용약관 법률 검토 완료
77
+ - [ ] 개인정보 영향평가 (해당 시)
78
+ - [ ] 보안 취약점 점검 완료
79
+ - [ ] 암호화 적용 확인 (저장 + 전송)
80
+ - [ ] 접근 로그 보관 정책 적용
81
+
82
+ ### 4.2 운영 중 정기
83
+
84
+ | 주기 | 점검 항목 |
85
+ |-----|----------|
86
+ | 월간 | 접근 권한 리뷰 |
87
+ | 분기 | 취약점 점검 |
88
+ | 반기 | 개인정보 처리 현황 점검 |
89
+ | 연간 | 침투 테스트, 인증 갱신 |
90
+
91
+ ---
92
+
93
+ ## 5. 관련 문서
94
+
95
+ - [보안 명세](./security-spec.md) — 보안 정책 상세
96
+ - [감사 추적 명세](./audit-trail-spec.md) — 감사 로그 설계
97
+ - [데이터 설계](./data-design.md) — 암호화 필드
98
+
99
+ ---
100
+
101
+ ## 변경 이력
102
+
103
+ | 버전 | 날짜 | 작성자 | 변경 내용 |
104
+ |------|------|--------|----------|
105
+ | 1.0.0 | {{DATE}} | tsq-security | 초기 작성 |
@@ -0,0 +1,181 @@
1
+ ---
2
+ title: "컴포넌트 맵 (Component Map)"
3
+ version: 1.0.0
4
+ last_updated: {{DATE}}
5
+ author: tsq-designer
6
+ status: draft
7
+ project: {{PROJECT_NAME}}
8
+ ---
9
+
10
+ # 컴포넌트 맵 (Component Map)
11
+
12
+ > UI 컴포넌트의 계층 구조, 재사용 정책, Props 인터페이스를 정의합니다.
13
+ > 디자인 시스템과 개발 구현 사이의 일관성을 보장합니다.
14
+
15
+ ---
16
+
17
+ ## 1. 컴포넌트 계층
18
+
19
+ ### 1.1 분류 체계
20
+
21
+ | 계층 | 설명 | 예시 | 의존성 |
22
+ |-----|------|------|--------|
23
+ | Primitives | 최소 단위, 스타일만 | Button, Input, Text | 없음 |
24
+ | Components | 단일 기능 조합 | SearchBar, Card, Modal | Primitives |
25
+ | Composites | 비즈니스 로직 포함 | UserCard, OrderList | Components + 상태 |
26
+ | Layouts | 페이지 레이아웃 | AppShell, SidebarLayout | Composites |
27
+ | Pages | 라우트 대응 화면 | HomePage, DetailPage | Layouts + 데이터 |
28
+
29
+ ### 1.2 디렉토리 구조
30
+
31
+ ```
32
+ src/components/
33
+ ├── primitives/
34
+ │ ├── Button/
35
+ │ │ ├── Button.tsx
36
+ │ │ ├── Button.test.tsx
37
+ │ │ └── index.ts
38
+ │ ├── Input/
39
+ │ ├── Text/
40
+ │ └── Icon/
41
+ ├── components/
42
+ │ ├── SearchBar/
43
+ │ ├── Card/
44
+ │ ├── Modal/
45
+ │ └── Toast/
46
+ ├── composites/
47
+ │ ├── UserCard/
48
+ │ ├── OrderList/
49
+ │ └── NotificationBell/
50
+ └── layouts/
51
+ ├── AppShell/
52
+ ├── AuthLayout/
53
+ └── DashboardLayout/
54
+ ```
55
+
56
+ ---
57
+
58
+ ## 2. Primitives
59
+
60
+ ### 2.1 Button
61
+
62
+ | Prop | 타입 | 기본값 | 설명 |
63
+ |------|------|--------|------|
64
+ | variant | `'primary' \| 'secondary' \| 'ghost' \| 'danger'` | `'primary'` | 스타일 변형 |
65
+ | size | `'sm' \| 'md' \| 'lg'` | `'md'` | 크기 |
66
+ | disabled | `boolean` | `false` | 비활성화 |
67
+ | loading | `boolean` | `false` | 로딩 상태 |
68
+ | fullWidth | `boolean` | `false` | 전체 너비 |
69
+ | children | `ReactNode` | - | 버튼 내용 |
70
+ | onPress | `() => void` | - | 클릭 핸들러 |
71
+
72
+ ### 2.2 Input
73
+
74
+ | Prop | 타입 | 기본값 | 설명 |
75
+ |------|------|--------|------|
76
+ | type | `'text' \| 'email' \| 'password' \| 'number'` | `'text'` | 입력 타입 |
77
+ | label | `string` | - | 라벨 |
78
+ | placeholder | `string` | - | 플레이스홀더 |
79
+ | error | `string` | - | 에러 메시지 |
80
+ | disabled | `boolean` | `false` | 비활성화 |
81
+
82
+ ### 2.3 Text
83
+
84
+ | Prop | 타입 | 기본값 | 설명 |
85
+ |------|------|--------|------|
86
+ | variant | `'h1' \| 'h2' \| 'h3' \| 'body' \| 'caption'` | `'body'` | 타이포그래피 |
87
+ | color | `string` | `'text.primary'` | 색상 토큰 |
88
+ | align | `'left' \| 'center' \| 'right'` | `'left'` | 정렬 |
89
+
90
+ ---
91
+
92
+ ## 3. Components
93
+
94
+ ### 3.1 Card
95
+
96
+ | Prop | 타입 | 기본값 | 설명 |
97
+ |------|------|--------|------|
98
+ | variant | `'elevated' \| 'outlined' \| 'filled'` | `'elevated'` | 스타일 |
99
+ | padding | `'none' \| 'sm' \| 'md' \| 'lg'` | `'md'` | 내부 여백 |
100
+ | onPress | `() => void` | - | 클릭 가능 여부 |
101
+ | children | `ReactNode` | - | 카드 내용 |
102
+
103
+ ### 3.2 Modal
104
+
105
+ | Prop | 타입 | 기본값 | 설명 |
106
+ |------|------|--------|------|
107
+ | open | `boolean` | `false` | 표시 여부 |
108
+ | onClose | `() => void` | - | 닫기 핸들러 |
109
+ | title | `string` | - | 제목 |
110
+ | size | `'sm' \| 'md' \| 'lg' \| 'full'` | `'md'` | 크기 |
111
+ | closeOnOverlay | `boolean` | `true` | 오버레이 클릭 닫기 |
112
+
113
+ ### 3.3 Toast
114
+
115
+ | Prop | 타입 | 기본값 | 설명 |
116
+ |------|------|--------|------|
117
+ | type | `'success' \| 'error' \| 'warning' \| 'info'` | `'info'` | 토스트 타입 |
118
+ | message | `string` | - | 메시지 |
119
+ | duration | `number` | `3000` | 표시 시간 (ms) |
120
+ | action | `{ label: string; onPress: () => void }` | - | 액션 버튼 |
121
+
122
+ ---
123
+
124
+ ## 4. 재사용 정책
125
+
126
+ ### 4.1 규칙
127
+
128
+ | 규칙 | 설명 |
129
+ |-----|------|
130
+ | 단방향 의존 | 상위 계층만 하위 계층을 import |
131
+ | Props 전용 통신 | 컴포넌트 간 데이터는 Props로만 전달 |
132
+ | 비즈니스 로직 분리 | Primitives/Components에 비즈니스 로직 금지 |
133
+ | 스타일 토큰 사용 | 하드코딩 색상/크기 금지, 디자인 토큰만 사용 |
134
+
135
+ ### 4.2 신규 컴포넌트 기준
136
+
137
+ | 기준 | 임계값 |
138
+ |-----|--------|
139
+ | 재사용 횟수 | 3회 이상 사용 시 컴포넌트화 |
140
+ | Props 수 | 10개 초과 시 분리 검토 |
141
+ | 중첩 깊이 | 3단계 초과 시 Composite로 승격 |
142
+
143
+ ---
144
+
145
+ ## 5. 디자인 토큰
146
+
147
+ ### 5.1 색상
148
+
149
+ | 토큰 | Light | Dark | 용도 |
150
+ |-----|-------|------|------|
151
+ | `colors.primary` | #3B82F6 | #60A5FA | 주요 액션 |
152
+ | `colors.secondary` | #6B7280 | #9CA3AF | 보조 액션 |
153
+ | `colors.danger` | #EF4444 | #F87171 | 위험/삭제 |
154
+ | `colors.text.primary` | #111827 | #F9FAFB | 본문 텍스트 |
155
+ | `colors.bg.primary` | #FFFFFF | #111827 | 배경 |
156
+
157
+ ### 5.2 간격
158
+
159
+ | 토큰 | 값 | 용도 |
160
+ |-----|-----|------|
161
+ | `spacing.xs` | 4px | 아이콘 간격 |
162
+ | `spacing.sm` | 8px | 요소 내부 |
163
+ | `spacing.md` | 16px | 섹션 내부 |
164
+ | `spacing.lg` | 24px | 섹션 간 |
165
+ | `spacing.xl` | 32px | 페이지 여백 |
166
+
167
+ ---
168
+
169
+ ## 6. 관련 문서
170
+
171
+ - [UI/UX 명세](./ui-ux-spec.md) — 화면 디자인 상세
172
+ - [네비게이션 맵](./navigation-map.md) — 화면 구조
173
+ - [성능 예산](./performance-budget.md) — 번들 크기 제약
174
+
175
+ ---
176
+
177
+ ## 변경 이력
178
+
179
+ | 버전 | 날짜 | 작성자 | 변경 내용 |
180
+ |------|------|--------|----------|
181
+ | 1.0.0 | {{DATE}} | tsq-designer | 초기 작성 |
@@ -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
  **Database**: PostgreSQL / MySQL / MongoDB
6
6
 
7
7
  ---
@@ -104,7 +104,7 @@ VALUES ('admin@example.com', 'Admin', '$2b$...', 'active');
104
104
 
105
105
  | Version | Date | Description |
106
106
  |---------|------|-------------|
107
- | 001 | {DATE} | 초기 스키마 생성 |
107
+ | 001 | {{DATE}} | 초기 스키마 생성 |
108
108
 
109
109
  ---
110
110
 
@@ -129,4 +129,4 @@ VALUES ('admin@example.com', 'Admin', '$2b$...', 'active');
129
129
 
130
130
  | 버전 | 날짜 | 변경 내용 | 작성자 |
131
131
  |-----|-----|----------|-------|
132
- | 1.0 | {DATE} | 최초 작성 | |
132
+ | 1.0 | {{DATE}} | 최초 작성 | |
@@ -2,7 +2,7 @@
2
2
  title: "배포 명세서 (Deployment Specification)"
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
  required_level: 3
@@ -21,13 +21,11 @@ required_level: 3
21
21
 
22
22
  ```
23
23
  ┌─────────────┐
24
- CDN
25
- │ (CloudFront)│
24
+ CDN
26
25
  └──────┬──────┘
27
26
 
28
27
  ┌──────▼──────┐
29
28
  │ Load Balancer│
30
- │ (ALB) │
31
29
  └──────┬──────┘
32
30
 
33
31
  ┌─────────────────┼─────────────────┐
@@ -42,9 +40,10 @@ required_level: 3
42
40
  ┌────────────┼────────────┐
43
41
  │ │ │
44
42
  ┌────▼────┐ ┌───▼────┐ ┌───▼────┐
45
- DB │ │ Redis │ │ S3
46
- │ (RDS) │ │(Cache) │ │(Storage)│
43
+ DB │ │ Cache │ │Storage
47
44
  └─────────┘ └────────┘ └────────┘
45
+
46
+ > 클라우드 예시: AWS (CloudFront, ALB, ECS, RDS), GCP (Cloud CDN, Cloud Run, Cloud SQL), Azure (Front Door, App Service, Azure DB)
48
47
  ```
49
48
 
50
49
  ### 1.2 환경 구성
@@ -63,34 +62,38 @@ required_level: 3
63
62
 
64
63
  | 리소스 | 서비스 | 사양 | 환경별 수량 |
65
64
  |-------|-------|------|-----------|
66
- | 애플리케이션 | ECS Fargate | 0.5 vCPU, 1GB | Dev:1, Stg:2, Prod:3+ |
67
- | 배치 작업 | Lambda | 256MB | 필요 시 |
65
+ | 애플리케이션 | 컨테이너 서비스 | 0.5 vCPU, 1GB | Dev:1, Stg:2, Prod:3+ |
66
+ | 배치 작업 | 서버리스 함수 | 256MB | 필요 시 |
67
+
68
+ > 클라우드별: AWS(ECS Fargate, Lambda), GCP(Cloud Run, Cloud Functions), Azure(Container Apps, Azure Functions)
68
69
 
69
70
  ### 2.2 데이터베이스
70
71
 
71
72
  | 리소스 | 서비스 | 사양 | 백업 |
72
73
  |-------|-------|------|------|
73
- | Primary DB | RDS PostgreSQL | db.t3.medium | 7일 |
74
- | Read Replica | RDS (Prod만) | db.t3.medium | - |
75
- | Cache | ElastiCache Redis | cache.t3.micro | - |
74
+ | Primary DB | Managed PostgreSQL | Medium | 7일 |
75
+ | Read Replica | (Prod만) | Medium | - |
76
+ | Cache | Managed Redis | Small | - |
77
+
78
+ > 클라우드별: AWS(RDS, ElastiCache), GCP(Cloud SQL, Memorystore), Azure(Azure DB, Azure Cache)
76
79
 
77
80
  ### 2.3 스토리지
78
81
 
79
82
  | 리소스 | 서비스 | 용도 |
80
83
  |-------|-------|------|
81
- | 정적 파일 | S3 | 이미지, 파일 업로드 |
82
- | 로그 | S3 + CloudWatch | 애플리케이션 로그 |
83
- | 백업 | S3 Glacier | DB 백업 장기 보관 |
84
+ | 정적 파일 | 오브젝트 스토리지 | 이미지, 파일 업로드 |
85
+ | 로그 | 오브젝트 스토리지 + 로그 서비스 | 애플리케이션 로그 |
86
+ | 백업 | 아카이브 스토리지 | DB 백업 장기 보관 |
84
87
 
85
88
  ### 2.4 네트워크
86
89
 
87
- | 리소스 | 서비스 | 설정 |
88
- |-------|-------|------|
89
- | VPC | VPC | 10.0.0.0/16 |
90
- | Public Subnet | 2개 AZ | 10.0.1.0/24, 10.0.2.0/24 |
91
- | Private Subnet | 2개 AZ | 10.0.10.0/24, 10.0.20.0/24 |
92
- | NAT Gateway | 각 AZ | 아웃바운드 트래픽 |
93
- | Security Group | 서비스별 | 최소 권한 |
90
+ | 리소스 | 설정 |
91
+ |-------|------|
92
+ | VPC/VNet | 10.0.0.0/16 |
93
+ | Public Subnet | 2개 AZ, 10.0.1.0/24, 10.0.2.0/24 |
94
+ | Private Subnet | 2개 AZ, 10.0.10.0/24, 10.0.20.0/24 |
95
+ | NAT Gateway | 아웃바운드 트래픽 |
96
+ | Security Group | 서비스별 최소 권한 |
94
97
 
95
98
  ---
96
99
 
@@ -137,6 +140,7 @@ jobs:
137
140
  docker push $IMAGE_NAME
138
141
 
139
142
  test:
143
+ runs-on: ubuntu-latest
140
144
  needs: build
141
145
  steps:
142
146
  - name: Unit Tests
@@ -149,6 +153,7 @@ jobs:
149
153
  run: npm audit
150
154
 
151
155
  deploy-staging:
156
+ runs-on: ubuntu-latest
152
157
  needs: test
153
158
  if: github.ref == 'refs/heads/develop'
154
159
  steps:
@@ -156,6 +161,7 @@ jobs:
156
161
  run: ./deploy.sh staging
157
162
 
158
163
  deploy-production:
164
+ runs-on: ubuntu-latest
159
165
  needs: test
160
166
  if: github.ref == 'refs/heads/main'
161
167
  environment: production # 승인 필요
@@ -164,6 +170,7 @@ jobs:
164
170
  run: ./deploy.sh production
165
171
 
166
172
  verify:
173
+ runs-on: ubuntu-latest
167
174
  needs: [deploy-staging, deploy-production]
168
175
  steps:
169
176
  - name: Smoke Test
@@ -381,4 +388,4 @@ CMD ["node", "dist/main.js"]
381
388
 
382
389
  | 버전 | 날짜 | 작성자 | 변경 내용 |
383
390
  |------|------|--------|----------|
384
- | 1.0.0 | {{DATE}} | tsq-planner | 초기 작성 |
391
+ | 1.0.0 | {{DATE}} | tsq-architect | 초기 작성 |
@@ -2,7 +2,7 @@
2
2
  title: "환경 설정 (Environment Configuration)"
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
  ---
@@ -118,6 +118,8 @@ DATABASE_URL=postgresql://postgres:postgres@localhost:5432/{{PROJECT_NAME}}_dev
118
118
  REDIS_URL=redis://localhost:6379
119
119
 
120
120
  # Auth
121
+ # ⚠️ 아래는 로컬 개발 전용. 절대 프로덕션에서 사용 금지.
122
+ # 프로덕션은 반드시 시크릿 매니저(Vault, AWS Secrets Manager 등)에서 주입.
121
123
  JWT_SECRET=local-dev-secret-change-in-production
122
124
  JWT_EXPIRES_IN=1d
123
125
  SESSION_SECRET=local-session-secret
@@ -343,4 +345,4 @@ if (await featureService.isEnabled('NEW_UI', userId)) {
343
345
 
344
346
  | 버전 | 날짜 | 작성자 | 변경 내용 |
345
347
  |------|------|--------|----------|
346
- | 1.0.0 | {{DATE}} | tsq-planner | 초기 작성 |
348
+ | 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
 
6
6
  ---
7
7
 
@@ -111,4 +111,4 @@
111
111
 
112
112
  | 버전 | 날짜 | 변경 내용 | 작성자 |
113
113
  |-----|-----|----------|-------|
114
- | 1.0 | {DATE} | 최초 작성 | |
114
+ | 1.0 | {{DATE}} | 최초 작성 | |
@@ -2,7 +2,7 @@
2
2
  title: "기능 명세서 (Functional Specification)"
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
  ---
@@ -130,7 +130,44 @@ Feature: [기능명]
130
130
 
131
131
  ### FS-002: [기능명]
132
132
 
133
- (위와 동일한 형식으로 작성)
133
+ #### 3.2.1 개요
134
+
135
+ | 항목 | 내용 |
136
+ |-----|------|
137
+ | **ID** | FS-002 |
138
+ | **기능명** | |
139
+ | **우선순위** | P0 / P1 / P2 |
140
+ | **관련 PRD** | [prd/xxx](./prd/xxx.md) |
141
+ | **관련 요건** | FR-XXX-001 |
142
+ | **관련 화면** | [SCR-002](./ui-ux-spec.md#SCR-002) |
143
+ | **관련 API** | [service-spec](./service-spec.md) |
144
+
145
+ #### 3.2.2 사전 조건 (Preconditions)
146
+ -
147
+
148
+ #### 3.2.3 주요 흐름 (Main Flow)
149
+
150
+ | 단계 | Actor | Action | System Response |
151
+ |:----:|-------|--------|----------------|
152
+ | 1 | | | |
153
+ | 2 | | | |
154
+
155
+ #### 3.2.4 대안 흐름 / 예외 흐름
156
+ -
157
+
158
+ #### 3.2.5 사후 조건 (Postconditions)
159
+ - [ ]
160
+
161
+ #### 3.2.6 수용 조건 (Acceptance Criteria)
162
+
163
+ ```gherkin
164
+ Feature: [기능명]
165
+
166
+ Scenario: [시나리오명]
167
+ Given [사전 조건]
168
+ When [행동]
169
+ Then [기대 결과]
170
+ ```
134
171
 
135
172
  ---
136
173
 
@@ -182,4 +219,4 @@ graph LR
182
219
 
183
220
  | 버전 | 날짜 | 작성자 | 변경 내용 |
184
221
  |------|------|--------|----------|
185
- | 1.0.0 | {{DATE}} | tsq-planner | 초기 작성 |
222
+ | 1.0.0 | {{DATE}} | tsq-architect | 초기 작성 |