timsquad 3.6.0 → 3.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (431) hide show
  1. package/README.ko.md +103 -111
  2. package/README.md +100 -108
  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 +136 -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 +34 -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-grill/SKILL.md +86 -0
  83. package/templates/base/skills/{backend/node → tsq-hono}/SKILL.md +6 -4
  84. package/templates/base/skills/tsq-librarian/SKILL.md +78 -0
  85. package/templates/base/skills/tsq-log/SKILL.md +30 -0
  86. package/templates/base/skills/{frontend/nextjs → tsq-nextjs}/SKILL.md +14 -9
  87. package/templates/base/skills/{planning → tsq-planning}/SKILL.md +2 -2
  88. package/templates/base/skills/{database/prisma → tsq-prisma}/SKILL.md +15 -9
  89. package/templates/base/skills/{product-audit → tsq-product-audit}/SKILL.md +2 -4
  90. package/templates/base/skills/{prompt-engineering → tsq-prompt}/SKILL.md +6 -4
  91. package/templates/base/skills/tsq-protocol/SKILL.md +85 -33
  92. package/templates/base/skills/{frontend/react → tsq-react}/SKILL.md +6 -3
  93. package/templates/base/skills/tsq-retro/SKILL.md +86 -0
  94. package/templates/base/skills/tsq-retro/references/feedback-guide.md +58 -0
  95. package/templates/base/skills/tsq-retro/references/improve-protocol.md +87 -0
  96. package/templates/base/skills/{security → tsq-security}/SKILL.md +2 -4
  97. package/templates/base/skills/{spec → tsq-spec}/SKILL.md +4 -6
  98. package/templates/base/skills/{stability-verification → tsq-stability}/SKILL.md +3 -3
  99. package/templates/base/skills/tsq-start/SKILL.md +90 -0
  100. package/templates/base/skills/tsq-start/references/onboarding-questions.md +177 -0
  101. package/templates/base/skills/tsq-status/SKILL.md +32 -0
  102. package/templates/base/skills/{methodology/tdd → tsq-tdd}/SKILL.md +6 -3
  103. package/templates/base/skills/{testing → tsq-testing}/SKILL.md +5 -7
  104. package/templates/base/skills/{typescript → tsq-typescript}/SKILL.md +2 -2
  105. package/templates/base/skills/{ui-design → tsq-ui}/SKILL.md +2 -2
  106. package/templates/base/skills/tsq-update/SKILL.md +48 -0
  107. package/templates/base/timsquad/constraints/competency-framework.xml +2 -2
  108. package/templates/base/timsquad/constraints/ssot-schema.xml +2 -2
  109. package/templates/base/timsquad/process/phase-checklist.yaml +1 -1
  110. package/templates/base/timsquad/process/state-machine.xml +2 -2
  111. package/templates/base/timsquad/process/validation-rules.xml +8 -8
  112. package/templates/base/timsquad/process/workflow-base.xml +8 -8
  113. package/templates/base/timsquad/retrospective/cycle-report.template.md +2 -2
  114. package/templates/base/timsquad/retrospective/patterns/failure-patterns.md +1 -1
  115. package/templates/base/timsquad/retrospective/patterns/success-patterns.md +2 -2
  116. package/templates/base/timsquad/retrospective/retrospective-state.xml +2 -2
  117. package/templates/base/timsquad/ssot/audit-trail-spec.template.md +155 -0
  118. package/templates/base/timsquad/ssot/compliance-matrix.template.md +105 -0
  119. package/templates/base/timsquad/ssot/component-map.template.md +181 -0
  120. package/templates/base/timsquad/ssot/data-design.template.md +4 -4
  121. package/templates/base/timsquad/ssot/deployment-spec.template.md +29 -22
  122. package/templates/base/timsquad/ssot/env-config.template.md +4 -2
  123. package/templates/base/timsquad/ssot/error-codes.template.md +3 -3
  124. package/templates/base/timsquad/ssot/functional-spec.template.md +40 -3
  125. package/templates/base/timsquad/ssot/glossary.template.md +2 -2
  126. package/templates/base/timsquad/ssot/infra-topology.template.md +191 -0
  127. package/templates/base/timsquad/ssot/integration-spec.template.md +2 -2
  128. package/templates/base/timsquad/ssot/monitoring-spec.template.md +185 -0
  129. package/templates/base/timsquad/ssot/navigation-map.template.md +154 -0
  130. package/templates/base/timsquad/ssot/performance-budget.template.md +132 -0
  131. package/templates/base/timsquad/ssot/planning.template.md +3 -3
  132. package/templates/base/timsquad/ssot/prd/_template.md +73 -0
  133. package/templates/base/timsquad/ssot/prd.template.md +10 -21
  134. package/templates/base/timsquad/ssot/requirements.template.md +3 -3
  135. package/templates/base/timsquad/ssot/sdk-spec.template.md +223 -0
  136. package/templates/base/timsquad/ssot/service-spec.template.md +3 -3
  137. package/templates/base/timsquad/ssot/state-machine.template.md +127 -0
  138. package/templates/base/timsquad/ssot/ui-ux-spec.template.md +43 -3
  139. package/templates/base/timsquad/ssot-map.template.yaml +28 -0
  140. package/templates/base/timsquad/state/workspace.xml +11 -11
  141. package/templates/platforms/claude-code/rules/adr-rules.md +1 -1
  142. package/templates/platforms/claude-code/rules/build-gate.md +1 -1
  143. package/templates/platforms/claude-code/rules/completion-verification.md +0 -2
  144. package/templates/platforms/claude-code/rules/context-monitor.md +1 -1
  145. package/templates/platforms/claude-code/rules/feedback-routing.md +2 -2
  146. package/templates/platforms/claude-code/rules/phase-management.md +2 -2
  147. package/templates/platforms/claude-code/rules/plan-review.md +2 -2
  148. package/templates/platforms/claude-code/rules/quality-guards.md +0 -2
  149. package/templates/platforms/claude-code/rules/sequence-management.md +15 -15
  150. package/templates/platforms/claude-code/rules/session-notes.md +1 -1
  151. package/templates/platforms/claude-code/rules/workspace-sync.md +1 -1
  152. package/templates/platforms/claude-code/scripts/build-gate.sh +6 -1
  153. package/templates/platforms/claude-code/scripts/change-scope-guard.sh +1 -4
  154. package/templates/platforms/claude-code/scripts/check-capability.sh +68 -0
  155. package/templates/platforms/claude-code/scripts/completion-guard.sh +62 -4
  156. package/templates/platforms/claude-code/scripts/context-restore.sh +33 -6
  157. package/templates/platforms/claude-code/scripts/phase-guard.sh +2 -5
  158. package/templates/platforms/claude-code/scripts/pre-compact.sh +3 -3
  159. package/templates/platforms/claude-code/scripts/safe-guard.sh +2 -5
  160. package/templates/platforms/claude-code/scripts/subagent-start.sh +11 -0
  161. package/templates/platforms/claude-code/scripts/subagent-stop.sh +11 -0
  162. package/templates/platforms/claude-code/settings.json +20 -74
  163. package/templates/project-types/api-backend/config.yaml +9 -5
  164. package/templates/project-types/api-backend/process/workflow.xml +2 -2
  165. package/templates/project-types/fintech/config.yaml +13 -19
  166. package/templates/project-types/fintech/ssot/audit-trail-spec.template.md +207 -0
  167. package/templates/project-types/fintech/ssot/compliance-matrix.template.md +187 -0
  168. package/templates/project-types/infra/config.yaml +7 -4
  169. package/templates/project-types/infra/process/workflow.xml +3 -3
  170. package/templates/project-types/mobile-app/config.yaml +8 -14
  171. package/templates/project-types/mobile-app/process/workflow.xml +4 -4
  172. package/templates/project-types/platform/config.yaml +8 -5
  173. package/templates/project-types/platform/process/workflow.xml +3 -3
  174. package/templates/project-types/web-app/config.yaml +9 -15
  175. package/templates/project-types/web-app/process/workflow.xml +6 -6
  176. package/templates/project-types/web-service/config.yaml +10 -19
  177. package/templates/project-types/web-service/process/workflow.xml +6 -6
  178. package/dist/commands/audit.d.ts +0 -22
  179. package/dist/commands/audit.d.ts.map +0 -1
  180. package/dist/commands/audit.js +0 -233
  181. package/dist/commands/audit.js.map +0 -1
  182. package/dist/commands/compile.d.ts +0 -3
  183. package/dist/commands/compile.d.ts.map +0 -1
  184. package/dist/commands/compile.js +0 -251
  185. package/dist/commands/compile.js.map +0 -1
  186. package/dist/commands/feedback.d.ts +0 -12
  187. package/dist/commands/feedback.d.ts.map +0 -1
  188. package/dist/commands/feedback.js +0 -382
  189. package/dist/commands/feedback.js.map +0 -1
  190. package/dist/commands/full.d.ts +0 -3
  191. package/dist/commands/full.d.ts.map +0 -1
  192. package/dist/commands/full.js +0 -88
  193. package/dist/commands/full.js.map +0 -1
  194. package/dist/commands/git/commit.d.ts +0 -3
  195. package/dist/commands/git/commit.d.ts.map +0 -1
  196. package/dist/commands/git/commit.js +0 -85
  197. package/dist/commands/git/commit.js.map +0 -1
  198. package/dist/commands/git/index.d.ts +0 -5
  199. package/dist/commands/git/index.d.ts.map +0 -1
  200. package/dist/commands/git/index.js +0 -5
  201. package/dist/commands/git/index.js.map +0 -1
  202. package/dist/commands/git/pr.d.ts +0 -3
  203. package/dist/commands/git/pr.d.ts.map +0 -1
  204. package/dist/commands/git/pr.js +0 -139
  205. package/dist/commands/git/pr.js.map +0 -1
  206. package/dist/commands/git/release.d.ts +0 -3
  207. package/dist/commands/git/release.d.ts.map +0 -1
  208. package/dist/commands/git/release.js +0 -153
  209. package/dist/commands/git/release.js.map +0 -1
  210. package/dist/commands/git/sync.d.ts +0 -3
  211. package/dist/commands/git/sync.d.ts.map +0 -1
  212. package/dist/commands/git/sync.js +0 -132
  213. package/dist/commands/git/sync.js.map +0 -1
  214. package/dist/commands/improve.d.ts +0 -3
  215. package/dist/commands/improve.d.ts.map +0 -1
  216. package/dist/commands/improve.js +0 -286
  217. package/dist/commands/improve.js.map +0 -1
  218. package/dist/commands/knowledge.d.ts +0 -3
  219. package/dist/commands/knowledge.d.ts.map +0 -1
  220. package/dist/commands/knowledge.js +0 -316
  221. package/dist/commands/knowledge.js.map +0 -1
  222. package/dist/commands/log.d.ts.map +0 -1
  223. package/dist/commands/log.js +0 -1468
  224. package/dist/commands/log.js.map +0 -1
  225. package/dist/commands/meta-index.d.ts +0 -3
  226. package/dist/commands/meta-index.d.ts.map +0 -1
  227. package/dist/commands/meta-index.js +0 -431
  228. package/dist/commands/meta-index.js.map +0 -1
  229. package/dist/commands/metrics.d.ts +0 -3
  230. package/dist/commands/metrics.d.ts.map +0 -1
  231. package/dist/commands/metrics.js +0 -843
  232. package/dist/commands/metrics.js.map +0 -1
  233. package/dist/commands/quick.d.ts +0 -3
  234. package/dist/commands/quick.d.ts.map +0 -1
  235. package/dist/commands/quick.js +0 -136
  236. package/dist/commands/quick.js.map +0 -1
  237. package/dist/commands/retro.d.ts +0 -3
  238. package/dist/commands/retro.d.ts.map +0 -1
  239. package/dist/commands/retro.js +0 -885
  240. package/dist/commands/retro.js.map +0 -1
  241. package/dist/commands/session.d.ts +0 -3
  242. package/dist/commands/session.d.ts.map +0 -1
  243. package/dist/commands/session.js +0 -346
  244. package/dist/commands/session.js.map +0 -1
  245. package/dist/commands/skills.d.ts +0 -12
  246. package/dist/commands/skills.d.ts.map +0 -1
  247. package/dist/commands/skills.js +0 -228
  248. package/dist/commands/skills.js.map +0 -1
  249. package/dist/commands/status.d.ts +0 -3
  250. package/dist/commands/status.d.ts.map +0 -1
  251. package/dist/commands/status.js +0 -127
  252. package/dist/commands/status.js.map +0 -1
  253. package/dist/commands/upgrade.d.ts.map +0 -1
  254. package/dist/commands/upgrade.js.map +0 -1
  255. package/dist/commands/watch.d.ts +0 -3
  256. package/dist/commands/watch.d.ts.map +0 -1
  257. package/dist/commands/watch.js +0 -213
  258. package/dist/commands/watch.js.map +0 -1
  259. package/dist/commands/workflow.d.ts +0 -5
  260. package/dist/commands/workflow.d.ts.map +0 -1
  261. package/dist/commands/workflow.js +0 -781
  262. package/dist/commands/workflow.js.map +0 -1
  263. package/templates/base/skills/audit/SKILL.md +0 -66
  264. package/templates/base/skills/controller/SKILL.md +0 -77
  265. package/templates/base/skills/controller/delegation/developer.md +0 -25
  266. package/templates/base/skills/controller/delegation/librarian.md +0 -33
  267. package/templates/base/skills/controller/delegation/reviewer.md +0 -19
  268. package/templates/base/skills/controller/triggers/phase-complete.md +0 -25
  269. package/templates/base/skills/controller/triggers/sequence-complete.md +0 -15
  270. package/templates/base/skills/controller/triggers/ssot-changed.md +0 -14
  271. package/templates/base/skills/controller/triggers/task-complete.md +0 -14
  272. package/templates/base/skills/librarian/SKILL.md +0 -53
  273. package/templates/base/skills/main-session-constraints/SKILL.md +0 -62
  274. package/templates/base/skills/retrospective/SKILL.md +0 -77
  275. package/templates/base/skills/review/SKILL.md +0 -72
  276. package/templates/base/skills/tsq-cli/SKILL.md +0 -73
  277. package/templates/base/skills/tsq-cli/references/cli-reference.md +0 -92
  278. package/templates/base/timsquad/feedback/feedback-router.sh +0 -341
  279. package/templates/base/timsquad/feedback/routing-rules.yaml +0 -352
  280. package/templates/platforms/claude-code/CLAUDE.md.template +0 -89
  281. package/templates/platforms/claude-code/rules/skill-suggest.md +0 -27
  282. package/templates/platforms/claude-code/scripts/skill-inject.sh +0 -216
  283. package/templates/platforms/claude-code/scripts/skill-rules.json +0 -95
  284. package/templates/platforms/claude-code/scripts/skill-suggest.sh +0 -105
  285. package/templates/platforms/claude-code/scripts/subagent-inject.sh +0 -53
  286. /package/templates/base/skills/{architecture → tsq-architecture}/references/adr-template.md +0 -0
  287. /package/templates/base/skills/{architecture → tsq-architecture}/references/api-design.md +0 -0
  288. /package/templates/base/skills/{methodology/bdd → tsq-bdd}/rules/gherkin-patterns.md +0 -0
  289. /package/templates/base/skills/{coding → tsq-coding}/rules/async-patterns.md +0 -0
  290. /package/templates/base/skills/{coding → tsq-coding}/rules/code-organization.md +0 -0
  291. /package/templates/base/skills/{coding → tsq-coding}/rules/error-handling.md +0 -0
  292. /package/templates/base/skills/{coding → tsq-coding}/rules/patterns.md +0 -0
  293. /package/templates/base/skills/{coding → tsq-coding}/rules/type-safety.md +0 -0
  294. /package/templates/base/skills/{controller → tsq-controller}/memory/.gitkeep +0 -0
  295. /package/templates/base/skills/{controller → tsq-controller}/references/README.md +0 -0
  296. /package/templates/base/skills/{controller → tsq-controller}/rules/README.md +0 -0
  297. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/async-patterns.md +0 -0
  298. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/code-style.md +0 -0
  299. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/null-safety.md +0 -0
  300. /package/templates/base/skills/{mobile/dart → tsq-dart}/rules/type-system.md +0 -0
  301. /package/templates/base/skills/{database → tsq-database}/rules/query-optimization.md +0 -0
  302. /package/templates/base/skills/{database → tsq-database}/rules/supabase-patterns.md +0 -0
  303. /package/templates/base/skills/{methodology/ddd → tsq-ddd}/rules/strategic-patterns.md +0 -0
  304. /package/templates/base/skills/{methodology/debugging → tsq-debugging}/references/root-cause-tracing.md +0 -0
  305. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/SKILL.md +0 -0
  306. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/references/ci-cd-pipeline.md +0 -0
  307. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/code-signing.md +0 -0
  308. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/codemagic-setup.md +0 -0
  309. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/fastlane-setup.md +0 -0
  310. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/github-actions.md +0 -0
  311. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/store-deployment.md +0 -0
  312. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/ci-cd/rules/versioning.md +0 -0
  313. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/SKILL.md +0 -0
  314. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/references/i18n-architecture.md +0 -0
  315. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/arb-files.md +0 -0
  316. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/locale-switching.md +0 -0
  317. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/localization-setup.md +0 -0
  318. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/plural-gender.md +0 -0
  319. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/i18n/rules/text-direction.md +0 -0
  320. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/SKILL.md +0 -0
  321. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/references/monitoring-architecture.md +0 -0
  322. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/analytics.md +0 -0
  323. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/crashlytics-setup.md +0 -0
  324. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/logging.md +0 -0
  325. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/performance-monitoring.md +0 -0
  326. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/monitoring/rules/sentry-integration.md +0 -0
  327. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/SKILL.md +0 -0
  328. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/references/api-client-architecture.md +0 -0
  329. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/caching.md +0 -0
  330. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/connectivity.md +0 -0
  331. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/dio-setup.md +0 -0
  332. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/error-handling.md +0 -0
  333. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/interceptors.md +0 -0
  334. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/networking/rules/retrofit-patterns.md +0 -0
  335. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/SKILL.md +0 -0
  336. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/references/notification-architecture.md +0 -0
  337. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/references/platform-setup.md +0 -0
  338. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/background-processing.md +0 -0
  339. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/deep-linking.md +0 -0
  340. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/fcm-setup.md +0 -0
  341. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/local-notifications.md +0 -0
  342. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/notification-handling.md +0 -0
  343. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/notification-permissions.md +0 -0
  344. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/push-notifications/rules/rich-notifications.md +0 -0
  345. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/references/freezed-patterns.md +0 -0
  346. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/references/project-structure.md +0 -0
  347. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/animations.md +0 -0
  348. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/architecture.md +0 -0
  349. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/navigation-routing.md +0 -0
  350. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/performance.md +0 -0
  351. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/platform-adaptive.md +0 -0
  352. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/state-management.md +0 -0
  353. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/testing.md +0 -0
  354. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/rules/widget-conventions.md +0 -0
  355. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/SKILL.md +0 -0
  356. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/references/mobile-security-checklist.md +0 -0
  357. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/api-key-protection.md +0 -0
  358. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/authentication.md +0 -0
  359. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/data-protection.md +0 -0
  360. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/obfuscation.md +0 -0
  361. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/secure-storage.md +0 -0
  362. /package/templates/base/skills/{mobile/flutter → tsq-flutter}/security/rules/ssl-pinning.md +0 -0
  363. /package/templates/base/skills/{backend/node → tsq-hono}/rules/async-patterns.md +0 -0
  364. /package/templates/base/skills/{backend/node → tsq-hono}/rules/deployment.md +0 -0
  365. /package/templates/base/skills/{backend/node → tsq-hono}/rules/env-config.md +0 -0
  366. /package/templates/base/skills/{backend/node → tsq-hono}/rules/error-handling.md +0 -0
  367. /package/templates/base/skills/{backend/node → tsq-hono}/rules/hono-app-setup.md +0 -0
  368. /package/templates/base/skills/{backend/node → tsq-hono}/rules/jwt-auth.md +0 -0
  369. /package/templates/base/skills/{backend/node → tsq-hono}/rules/middleware.md +0 -0
  370. /package/templates/base/skills/{backend/node → tsq-hono}/rules/testing.md +0 -0
  371. /package/templates/base/skills/{frontend/nextjs → tsq-nextjs}/rules/app-router.md +0 -0
  372. /package/templates/base/skills/{planning → tsq-planning}/references/prd-guide.md +0 -0
  373. /package/templates/base/skills/{planning → tsq-planning}/references/requirements-guide.md +0 -0
  374. /package/templates/base/skills/{database/prisma → tsq-prisma}/rules/queries.md +0 -0
  375. /package/templates/base/skills/{database/prisma → tsq-prisma}/rules/schema-design.md +0 -0
  376. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/01-security.md +0 -0
  377. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/02-performance.md +0 -0
  378. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/03-seo.md +0 -0
  379. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/04-accessibility.md +0 -0
  380. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/05-ui-ux.md +0 -0
  381. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/06-architecture.md +0 -0
  382. /package/templates/base/skills/{product-audit → tsq-product-audit}/checklists/07-functional-requirements.md +0 -0
  383. /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/audit-protocol.md +0 -0
  384. /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/false-positive-guard.md +0 -0
  385. /package/templates/base/skills/{product-audit → tsq-product-audit}/rules/scoring-criteria.md +0 -0
  386. /package/templates/base/skills/{product-audit → tsq-product-audit}/templates/improvement-plan-template.md +0 -0
  387. /package/templates/base/skills/{product-audit → tsq-product-audit}/templates/report-template.md +0 -0
  388. /package/templates/base/skills/{frontend/react → tsq-react}/rules/_sections.md +0 -0
  389. /package/templates/base/skills/{frontend/react → tsq-react}/rules/anti-patterns.md +0 -0
  390. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-api-routes.md +0 -0
  391. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-defer-await.md +0 -0
  392. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-dependencies.md +0 -0
  393. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-parallel.md +0 -0
  394. /package/templates/base/skills/{frontend/react → tsq-react}/rules/async-suspense-boundaries.md +0 -0
  395. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-barrel-imports.md +0 -0
  396. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-defer-third-party.md +0 -0
  397. /package/templates/base/skills/{frontend/react → tsq-react}/rules/bundle-dynamic-imports.md +0 -0
  398. /package/templates/base/skills/{frontend/react → tsq-react}/rules/component-conventions.md +0 -0
  399. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-combine-iterations.md +0 -0
  400. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-early-exit.md +0 -0
  401. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-index-maps.md +0 -0
  402. /package/templates/base/skills/{frontend/react → tsq-react}/rules/js-set-map-lookups.md +0 -0
  403. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-conditional-render.md +0 -0
  404. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-content-visibility.md +0 -0
  405. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rendering-hoist-jsx.md +0 -0
  406. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-defer-reads.md +0 -0
  407. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-derived-state.md +0 -0
  408. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-memo.md +0 -0
  409. /package/templates/base/skills/{frontend/react → tsq-react}/rules/rerender-transitions.md +0 -0
  410. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-after-nonblocking.md +0 -0
  411. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-cache-react.md +0 -0
  412. /package/templates/base/skills/{frontend/react → tsq-react}/rules/server-parallel-fetching.md +0 -0
  413. /package/templates/base/skills/{frontend/react → tsq-react}/rules/state-location.md +0 -0
  414. /package/templates/base/skills/{retrospective → tsq-retro}/references/improvement-template.md +0 -0
  415. /package/templates/base/skills/{security → tsq-security}/rules/auth-patterns.md +0 -0
  416. /package/templates/base/skills/{security → tsq-security}/rules/dependency-security.md +0 -0
  417. /package/templates/base/skills/{security → tsq-security}/rules/input-validation.md +0 -0
  418. /package/templates/base/skills/{security → tsq-security}/rules/owasp-examples.md +0 -0
  419. /package/templates/base/skills/{security → tsq-security}/rules/secrets-management.md +0 -0
  420. /package/templates/base/skills/{security → tsq-security}/scripts/check-secrets.sh +0 -0
  421. /package/templates/base/skills/{stability-verification → tsq-stability}/references/release-checklist.md +0 -0
  422. /package/templates/base/skills/{stability-verification → tsq-stability}/references/security-fix-patterns.md +0 -0
  423. /package/templates/base/skills/{stability-verification → tsq-stability}/rules/verification-layers.md +0 -0
  424. /package/templates/base/skills/{stability-verification → tsq-stability}/rules/verification-workflow.md +0 -0
  425. /package/templates/base/skills/{stability-verification → tsq-stability}/scripts/verify.sh +0 -0
  426. /package/templates/base/skills/{methodology/tdd → tsq-tdd}/rules/real-world-example.md +0 -0
  427. /package/templates/base/skills/{methodology/tdd → tsq-tdd}/rules/techniques.md +0 -0
  428. /package/templates/base/skills/{testing → tsq-testing}/references/e2e-stability.md +0 -0
  429. /package/templates/base/skills/{testing → tsq-testing}/references/testing-patterns.md +0 -0
  430. /package/templates/base/skills/{typescript → tsq-typescript}/rules/type-patterns.md +0 -0
  431. /package/templates/base/skills/{typescript → tsq-typescript}/rules/utility-types.md +0 -0
@@ -1,16 +1,5 @@
1
1
  {
2
2
  "hooks": {
3
- "UserPromptSubmit": [
4
- {
5
- "hooks": [
6
- {
7
- "type": "command",
8
- "command": "bash .claude/scripts/skill-inject.sh",
9
- "timeout": 5
10
- }
11
- ]
12
- }
13
- ],
14
3
  "PreToolUse": [
15
4
  {
16
5
  "matcher": "Write|Edit",
@@ -19,52 +8,25 @@
19
8
  "type": "command",
20
9
  "command": "bash .claude/scripts/phase-guard.sh",
21
10
  "timeout": 3
22
- }
23
- ]
24
- },
25
- {
26
- "matcher": "Bash",
27
- "hooks": [
28
- {
29
- "type": "command",
30
- "command": "bash .claude/scripts/safe-guard.sh",
31
- "timeout": 3
32
- }
33
- ]
34
- },
35
- {
36
- "matcher": "Task",
37
- "hooks": [
38
- {
39
- "type": "command",
40
- "command": "tsq daemon notify subagent-start 2>/dev/null || true",
41
- "timeout": 3
42
- }
43
- ]
44
- }
45
- ],
46
- "SubagentStart": [
47
- {
48
- "hooks": [
11
+ },
49
12
  {
50
13
  "type": "command",
51
- "command": "tsq daemon notify subagent-start 2>/dev/null || true",
14
+ "command": "bash .claude/scripts/check-capability.sh",
52
15
  "timeout": 3
53
16
  },
54
17
  {
55
18
  "type": "command",
56
- "command": "bash .claude/scripts/subagent-inject.sh",
57
- "timeout": 5
19
+ "command": "bash .claude/scripts/change-scope-guard.sh 2>/dev/null || true",
20
+ "timeout": 3
58
21
  }
59
22
  ]
60
- }
61
- ],
62
- "SubagentStop": [
23
+ },
63
24
  {
25
+ "matcher": "Bash",
64
26
  "hooks": [
65
27
  {
66
28
  "type": "command",
67
- "command": "tsq daemon notify subagent-stop 2>/dev/null || true",
29
+ "command": "bash .claude/scripts/safe-guard.sh",
68
30
  "timeout": 3
69
31
  }
70
32
  ]
@@ -91,45 +53,40 @@
91
53
  ]
92
54
  }
93
55
  ],
94
- "PostToolUse": [
56
+ "Stop": [
95
57
  {
96
58
  "hooks": [
97
59
  {
98
60
  "type": "command",
99
- "command": "tsq daemon notify tool-use --status success 2>/dev/null || true",
100
- "timeout": 3
61
+ "command": "bash .claude/scripts/completion-guard.sh",
62
+ "timeout": 5
63
+ },
64
+ {
65
+ "type": "command",
66
+ "command": "bash .claude/scripts/build-gate.sh",
67
+ "timeout": 30
101
68
  }
102
69
  ]
103
70
  }
104
71
  ],
105
- "PostToolUseFailure": [
72
+ "SubagentStart": [
106
73
  {
107
74
  "hooks": [
108
75
  {
109
76
  "type": "command",
110
- "command": "tsq daemon notify tool-use --status failure 2>/dev/null || true",
111
- "timeout": 3
77
+ "command": "bash .claude/scripts/subagent-start.sh 2>/dev/null || true",
78
+ "timeout": 2
112
79
  }
113
80
  ]
114
81
  }
115
82
  ],
116
- "Stop": [
83
+ "SubagentStop": [
117
84
  {
118
85
  "hooks": [
119
86
  {
120
87
  "type": "command",
121
- "command": "tsq daemon notify stop 2>/dev/null || true",
88
+ "command": "bash .claude/scripts/subagent-stop.sh 2>/dev/null || true",
122
89
  "timeout": 3
123
- },
124
- {
125
- "type": "command",
126
- "command": "bash .claude/scripts/completion-guard.sh",
127
- "timeout": 5
128
- },
129
- {
130
- "type": "command",
131
- "command": "bash .claude/scripts/build-gate.sh",
132
- "timeout": 30
133
90
  }
134
91
  ]
135
92
  }
@@ -144,17 +101,6 @@
144
101
  }
145
102
  ]
146
103
  }
147
- ],
148
- "SessionEnd": [
149
- {
150
- "hooks": [
151
- {
152
- "type": "command",
153
- "command": "tsq daemon notify session-end 2>/dev/null || true",
154
- "timeout": 5
155
- }
156
- ]
157
- }
158
104
  ]
159
105
  }
160
106
  }
@@ -8,8 +8,8 @@ description: "API 서버, 마이크로서비스, REST/GraphQL 백엔드"
8
8
  # 에이전트 설정
9
9
  # ============================================================
10
10
  agents:
11
- # Planner는 API 설계에 집중
12
- planner:
11
+ # Architect는 API 설계에 집중
12
+ architect:
13
13
  model: opus
14
14
  focus:
15
15
  - api_design
@@ -24,9 +24,9 @@ agents:
24
24
  developer:
25
25
  model: sonnet
26
26
  skills:
27
- - coding
28
- - testing
29
- - backend/node # 또는 적절한 백엔드 기술
27
+ - tsq-coding
28
+ - tsq-testing
29
+ - tsq-hono # 또는 적절한 백엔드 기술
30
30
  focus:
31
31
  - api_implementation
32
32
  - database_queries
@@ -78,6 +78,10 @@ ssot:
78
78
  optional:
79
79
  - ui-ux-spec.md # API만이므로 불필요
80
80
  - deployment-spec.md
81
+
82
+ # 타입×레벨 자동 배포 (SSOT_TYPE_LEVEL_MAP 기반):
83
+ # L2+: state-machine, performance-budget
84
+ # L3: monitoring-spec
81
85
  - integration-spec.md
82
86
 
83
87
  # ============================================================
@@ -21,7 +21,7 @@
21
21
  <tasks>
22
22
  <task id="api-spec" required="true">
23
23
  <name>API 명세 작성</name>
24
- <agent>tsq-planner</agent>
24
+ <agent>tsq-architect</agent>
25
25
  <output>service-spec.md</output>
26
26
  <checklist>
27
27
  <item>엔드포인트 정의</item>
@@ -45,7 +45,7 @@
45
45
 
46
46
  <task id="error-codes" required="true">
47
47
  <name>에러 코드 정의</name>
48
- <agent>tsq-planner</agent>
48
+ <agent>tsq-architect</agent>
49
49
  <output>error-codes.md</output>
50
50
  <checklist>
51
51
  <item>에러 코드 체계</item>
@@ -4,7 +4,7 @@
4
4
  template:
5
5
  name: fintech
6
6
  description: 금융/결제 시스템을 위한 보안 강화 템플릿
7
- version: 2.0.0
7
+ version: 3.7.0
8
8
 
9
9
  # ============================================================
10
10
  # 프로젝트 기본값
@@ -57,21 +57,10 @@ stack:
57
57
  # ============================================================
58
58
  # 스킬 자동 로딩 규칙
59
59
  # ============================================================
60
- skills:
61
- base:
62
- - coding
63
- - testing
64
- - security # 보안 필수
65
- - planning
66
- - architecture
67
-
68
- # fintech 타입 추가 스킬
69
- type-specific:
70
- - typescript
71
- - backend/node
72
- - database/prisma
73
- - methodology/tdd
74
- - methodology/ddd # 복잡한 도메인 필수
60
+ # 스킬은 project.type으로 자동 결정됩니다 (이 섹션은 참고용).
61
+ # skills:
62
+ # base: [tsq-coding, tsq-testing, tsq-security, tsq-planning, tsq-architecture]
63
+ # type-specific: [tsq-typescript, tsq-hono, tsq-prisma, tsq-tdd, tsq-ddd]
75
64
 
76
65
  # ============================================================
77
66
  # 추가 SSOT 문서 (필수)
@@ -79,9 +68,14 @@ skills:
79
68
  ssot:
80
69
  additional:
81
70
  - security-spec.md # 보안 명세 필수
82
- - compliance-spec.md # 컴플라이언스 명세
83
- - audit-log-spec.md # 감사 로그 명세
84
71
  - error-codes.md # 에러 코드 (상세)
72
+ # 타입×레벨 자동 배포 (SSOT_TYPE_LEVEL_MAP 기반):
73
+ # L1+: compliance-matrix, audit-trail-spec, state-machine
74
+ # L2+: performance-budget
75
+ # L3: monitoring-spec, infra-topology
76
+ # fintech 특화 오버라이드 (project-types/fintech/ssot/):
77
+ # compliance-matrix — 전자금융거래법, PCI DSS 사전 구성
78
+ # audit-trail-spec — 금융 거래 감사 로그, FDS 연동
85
79
 
86
80
  # ============================================================
87
81
  # 추가 에이전트
@@ -94,7 +88,7 @@ additional_agents:
94
88
 
95
89
  - name: tsq-auditor
96
90
  description: 감사/컴플라이언스 전문가
97
- skills: [security, compliance]
91
+ skills: [tsq-security]
98
92
 
99
93
  # ============================================================
100
94
  # Consensus 설정 (fintech 필수)
@@ -0,0 +1,207 @@
1
+ ---
2
+ title: "감사 추적 명세서 (Audit Trail Specification) — Fintech"
3
+ version: 1.0.0
4
+ last_updated: {{DATE}}
5
+ author: tsq-security
6
+ status: draft
7
+ project: {{PROJECT_NAME}}
8
+ type_override: fintech
9
+ ---
10
+
11
+ # 감사 추적 명세서 (Audit Trail Specification)
12
+
13
+ > 금융 거래 시스템의 감사 추적을 설계합니다.
14
+ > 전자금융거래법 §22 (거래기록 5년 보존), PCI DSS Req 10 (감사 로그) 요구사항이 사전 구성되어 있습니다.
15
+
16
+ ---
17
+
18
+ ## 1. 감사 대상
19
+
20
+ ### 1.1 이벤트 분류
21
+
22
+ | 분류 | 이벤트 | 보존 기간 | 법적 근거 |
23
+ |-----|--------|:--------:|----------|
24
+ | 인증 | 로그인, 로그아웃, MFA | 5년 | 전자금융감독규정 §13 |
25
+ | 인가 | 권한 변경, 역할 부여/회수 | 영구 | PCI DSS 10.2 |
26
+ | 금융 거래 | 주문, 체결, 정산, 입출금 | 5년 | 전자금융거래법 §22 |
27
+ | 결제 | 카드 결제, 환불, 취소 | 5년 | PCI DSS 10.2 |
28
+ | 자금 이동 | 입금, 출금, 이체 | 5년 | 특정금융정보법 |
29
+ | KYC | 본인인증, 서류 제출/검토 | 5년 | 특정금융정보법 §5의2 |
30
+ | FDS | 이상거래 탐지, 차단, 해제 | 5년 | 전자금융거래법 §21의3 |
31
+ | 데이터 접근 | 민감 데이터 조회 | 5년 | 개인정보보호법 §29 |
32
+ | 시스템 | 배포, 설정 변경, 장애 | 3년 | ISMS-P |
33
+ | 관리자 | 관리자 패널 모든 작업 | 영구 | PCI DSS 10.2 |
34
+
35
+ ### 1.2 감사 레벨
36
+
37
+ | 레벨 | 설명 | 적용 |
38
+ |-----|------|------|
39
+ | L1 | 이벤트 기록 (who, when, what) | 모든 이벤트 |
40
+ | L2 | 변경 전/후 데이터 (before/after) | 데이터 변경, 설정 변경 |
41
+ | L3 | 전체 요청/응답 페이로드 | 금융 거래, 결제, 자금 이동 |
42
+
43
+ ---
44
+
45
+ ## 2. 감사 로그 스키마
46
+
47
+ ### 2.1 금융 거래 로그
48
+
49
+ ```json
50
+ {
51
+ "id": "audit_abc123",
52
+ "timestamp": "2026-01-01T00:00:00.000Z",
53
+ "event_type": "TRADE_EXECUTED",
54
+ "category": "financial_transaction",
55
+ "level": "L3",
56
+ "actor": {
57
+ "user_id": "user_123",
58
+ "ip_address": "1.2.3.4",
59
+ "user_agent": "Mozilla/5.0...",
60
+ "session_id": "sess_456",
61
+ "device_fingerprint": "fp_789",
62
+ "kyc_level": "verified"
63
+ },
64
+ "target": {
65
+ "entity_type": "trade",
66
+ "entity_id": "trade_001",
67
+ "path": "/api/trades"
68
+ },
69
+ "transaction": {
70
+ "type": "buy",
71
+ "asset": "BTC/KRW",
72
+ "quantity": "0.5",
73
+ "price": "50000000",
74
+ "total_amount": "25000000",
75
+ "fee": "25000",
76
+ "currency": "KRW"
77
+ },
78
+ "changes": {
79
+ "before": { "balance": "100000000" },
80
+ "after": { "balance": "74975000" }
81
+ },
82
+ "risk": {
83
+ "fds_score": 15,
84
+ "fds_rules_triggered": [],
85
+ "risk_level": "low"
86
+ },
87
+ "metadata": {
88
+ "trace_id": "trace_xyz",
89
+ "service": "trade-service",
90
+ "version": "1.2.3",
91
+ "correlation_id": "corr_abc"
92
+ },
93
+ "result": "success"
94
+ }
95
+ ```
96
+
97
+ ### 2.2 이벤트 타입 (금융 특화)
98
+
99
+ | 카테고리 | 이벤트 타입 | 레벨 | 설명 |
100
+ |---------|-----------|:----:|------|
101
+ | auth | `LOGIN_SUCCESS` | L1 | 로그인 성공 |
102
+ | auth | `LOGIN_FAILURE` | L1 | 로그인 실패 (사유 포함) |
103
+ | auth | `MFA_VERIFIED` | L1 | MFA 인증 완료 |
104
+ | auth | `SESSION_EXPIRED` | L1 | 세션 만료 |
105
+ | kyc | `KYC_SUBMITTED` | L2 | KYC 서류 제출 |
106
+ | kyc | `KYC_APPROVED` | L2 | KYC 승인 |
107
+ | kyc | `KYC_REJECTED` | L2 | KYC 거부 (사유 포함) |
108
+ | txn | `ORDER_PLACED` | L3 | 주문 접수 |
109
+ | txn | `TRADE_EXECUTED` | L3 | 체결 완료 |
110
+ | txn | `ORDER_CANCELLED` | L3 | 주문 취소 |
111
+ | payment | `DEPOSIT_REQUESTED` | L3 | 입금 요청 |
112
+ | payment | `DEPOSIT_CONFIRMED` | L3 | 입금 확인 |
113
+ | payment | `WITHDRAWAL_REQUESTED` | L3 | 출금 요청 |
114
+ | payment | `WITHDRAWAL_APPROVED` | L3 | 출금 승인 |
115
+ | payment | `WITHDRAWAL_COMPLETED` | L3 | 출금 완료 |
116
+ | fds | `FDS_ALERT` | L2 | 이상거래 탐지 |
117
+ | fds | `FDS_BLOCKED` | L2 | 거래 차단 |
118
+ | fds | `FDS_RELEASED` | L2 | 차단 해제 (심사 후) |
119
+ | admin | `BALANCE_ADJUSTED` | L3 | 잔고 수동 조정 |
120
+ | admin | `FEE_CHANGED` | L2 | 수수료 변경 |
121
+ | admin | `LIMIT_CHANGED` | L2 | 거래 한도 변경 |
122
+
123
+ ---
124
+
125
+ ## 3. 저장 아키텍처
126
+
127
+ ### 3.1 저장소 구성 (5년 법적 보관)
128
+
129
+ | 저장소 | 용도 | 보존 | 접근 | 비고 |
130
+ |-------|------|------|------|------|
131
+ | Hot (DB) | 최근 로그 조회 | 90일 | 실시간 검색 | 인덱싱 완전 |
132
+ | Warm (Object Storage) | 중기 보관 | 2년 | 일괄 검색 | 압축 저장 |
133
+ | Cold (Archive) | 장기 보관 | 5년+ | 복원 후 검색 | 규제 준수 |
134
+
135
+ ### 3.2 무결성 보장 (PCI DSS 10.5)
136
+
137
+ | 방법 | 설명 | 구현 |
138
+ |-----|------|------|
139
+ | 쓰기 전용 | append-only, 수정/삭제 불가 | DB trigger + 정책 |
140
+ | 해시 체인 | 각 로그에 이전 블록 해시 포함 | SHA-256 체인 |
141
+ | 타임스탬프 서명 | 신뢰할 수 있는 시간 + 서명 | NTP + HSM |
142
+ | 접근 제어 | 쓰기: 시스템만 / 읽기: 감사 권한 | IAM + RBAC |
143
+ | 이중 저장 | 별도 보안 저장소에 복제 | S3 Cross-Region |
144
+ | 변조 감지 | 정기 무결성 검증 배치 | 일간 스케줄러 |
145
+
146
+ ---
147
+
148
+ ## 4. FDS 연동
149
+
150
+ ### 4.1 FDS → 감사 로그 흐름
151
+
152
+ ```
153
+ 거래 요청 → FDS 분석 → 점수 산출 → 감사 로그 기록
154
+ ├─ 정상 → 거래 실행 → L3 로그
155
+ ├─ 의심 → 보류 + 알림 → L2 로그
156
+ └─ 차단 → 거래 거부 → L2 로그 + STR 검토 큐
157
+ ```
158
+
159
+ ### 4.2 FDS 규칙 감사
160
+
161
+ | 이벤트 | 기록 항목 | 보존 |
162
+ |-------|----------|------|
163
+ | 규칙 변경 | 변경자, 이전/이후 규칙, 사유 | 영구 |
164
+ | 규칙 트리거 | 거래 ID, 트리거된 규칙, 점수 | 5년 |
165
+ | 수동 해제 | 해제자, 사유, 승인자 | 영구 |
166
+
167
+ ---
168
+
169
+ ## 5. 규제 보고용 조회
170
+
171
+ ### 5.1 조회 API
172
+
173
+ | 엔드포인트 | 용도 | 권한 |
174
+ |-----------|------|------|
175
+ | `GET /api/audit/search` | 조건부 검색 | AUDITOR+ |
176
+ | `GET /api/audit/transaction/:id` | 거래 전체 이력 | AUDITOR+ |
177
+ | `GET /api/audit/user/:id/activity` | 사용자 활동 | AUDITOR+ |
178
+ | `POST /api/audit/report/str` | STR 보고용 데이터 추출 | COMPLIANCE |
179
+ | `POST /api/audit/report/regulatory` | 규제 보고용 데이터 | COMPLIANCE |
180
+ | `POST /api/audit/export` | CSV/JSON 내보내기 | ADMIN |
181
+
182
+ ### 5.2 보고서 템플릿
183
+
184
+ | 보고서 | 대상 | 주기 | 자동화 |
185
+ |-------|------|------|:------:|
186
+ | 거래 현황 보고 | 경영진 | 일간 | ✅ |
187
+ | FDS 탐지 보고 | 보안팀 | 일간 | ✅ |
188
+ | 규제 준수 보고 | 금융감독원 | 분기 | 수동 |
189
+ | STR 보고 | FIU | 수시 | 반자동 |
190
+ | 감사 무결성 검증 | 내부 감사 | 월간 | ✅ |
191
+
192
+ ---
193
+
194
+ ## 6. 관련 문서
195
+
196
+ - [컴플라이언스 매트릭스](./compliance-matrix.md) — 규제 요구사항 매트릭스
197
+ - [보안 명세](./security-spec.md) — 접근 제어 정책
198
+ - [상태 머신](./state-machine.md) — 거래 상태 전이
199
+ - [데이터 설계](./data-design.md) — 감사 테이블 스키마
200
+
201
+ ---
202
+
203
+ ## 변경 이력
204
+
205
+ | 버전 | 날짜 | 작성자 | 변경 내용 |
206
+ |------|------|--------|----------|
207
+ | 1.0.0 | {{DATE}} | tsq-security | 초기 작성 (fintech 특화) |
@@ -0,0 +1,187 @@
1
+ ---
2
+ title: "컴플라이언스 매트릭스 (Compliance Matrix) — Fintech"
3
+ version: 1.0.0
4
+ last_updated: {{DATE}}
5
+ author: tsq-security
6
+ status: draft
7
+ project: {{PROJECT_NAME}}
8
+ type_override: fintech
9
+ ---
10
+
11
+ # 컴플라이언스 매트릭스 (Compliance Matrix)
12
+
13
+ > 금융/결제 서비스에 적용되는 법규, 산업 표준, 내부 정책의 준수 현황을 추적합니다.
14
+ > 이 문서는 fintech 타입에 특화된 버전으로, 전자금융거래법 및 PCI DSS 요구사항이 사전 구성되어 있습니다.
15
+
16
+ ---
17
+
18
+ ## 1. 적용 규제
19
+
20
+ ### 1.1 필수 법률/규정
21
+
22
+ | 규제 | 관할 | 적용 범위 | 필수 여부 | 상태 |
23
+ |-----|------|----------|:--------:|:----:|
24
+ | 전자금융거래법 | 대한민국 | 전자금융 서비스 전체 | ✅ | ⏳ |
25
+ | 전자금융감독규정 | 대한민국 | 전자금융업자 감독 | ✅ | ⏳ |
26
+ | 개인정보보호법 | 대한민국 | 개인정보 처리 | ✅ | ⏳ |
27
+ | 정보통신망법 | 대한민국 | 정보통신 서비스 | ✅ | ⏳ |
28
+ | 신용정보법 | 대한민국 | 신용정보 수집/이용 | ✅ | ⏳ |
29
+ | 특정금융정보법 | 대한민국 | 자금세탁 방지 (AML) | ✅ | ⏳ |
30
+ | GDPR | EU | EU 사용자 대상 서비스 | 조건부 | - |
31
+
32
+ ### 1.2 산업 표준/인증
33
+
34
+ | 표준 | 적용 범위 | 인증 필요 | 갱신 주기 | 상태 |
35
+ |-----|----------|:--------:|---------|:----:|
36
+ | PCI DSS v4.0 | 카드 결제 처리 | ✅ | 연간 | ⏳ |
37
+ | ISMS-P | 정보보안 관리 체계 | ✅ | 연간 | ⏳ |
38
+ | ISO 27001 | 정보보안 관리 | 권장 | 3년 | - |
39
+ | SOC 2 Type II | 서비스 신뢰성 | 권장 | 연간 | - |
40
+
41
+ ---
42
+
43
+ ## 2. 전자금융거래법 요구사항
44
+
45
+ ### 2.1 전자금융거래 안전성 (법 §21)
46
+
47
+ | 요구사항 | 조항 | 구현 방법 | 담당 | 상태 |
48
+ |---------|------|----------|------|:----:|
49
+ | 접근 권한 관리 | §21①1 | RBAC + 최소 권한 | 개발팀 | ⏳ |
50
+ | 전자적 침해 방지 | §21①2 | WAF + IDS/IPS | 인프라 | ⏳ |
51
+ | 거래 데이터 암호화 | §21①3 | AES-256 + TLS 1.3 | 개발팀 | ⏳ |
52
+ | 전자서명 | §21①4 | RSA-2048 / Ed25519 | 개발팀 | ⏳ |
53
+ | 거래 기록 보존 | §22 | 5년 보관 + 아카이브 | 인프라 | ⏳ |
54
+
55
+ ### 2.2 이상거래 탐지 (법 §21의3)
56
+
57
+ | 요구사항 | 구현 방법 | 임계값 | 담당 | 상태 |
58
+ |---------|----------|--------|------|:----:|
59
+ | 이상거래 탐지 시스템 (FDS) | 규칙 엔진 + ML | 설정 필요 | 개발팀 | ⏳ |
60
+ | 실시간 모니터링 | 대시보드 + 알림 | P1: 1분 | 운영팀 | ⏳ |
61
+ | 거래 차단/보류 | 자동 차단 + 수동 검토 | 규칙 기반 | 운영팀 | ⏳ |
62
+ | 사후 분석 | 로그 분석 + 리포트 | 일간 | 보안팀 | ⏳ |
63
+
64
+ ### 2.3 전자금융사고 대응 (법 §39)
65
+
66
+ | 요구사항 | 보고 대상 | 보고 시한 | 담당 | 상태 |
67
+ |---------|----------|----------|------|:----:|
68
+ | 사고 인지 즉시 보고 | 금융감독원 | 1시간 | CISO | ⏳ |
69
+ | 사고 원인 분석 | 금융감독원 | 24시간 | 보안팀 | ⏳ |
70
+ | 피해 복구 완료 보고 | 금융감독원 | 완료 즉시 | CISO | ⏳ |
71
+ | 재발 방지 대책 | 금융감독원 | 30일 | 보안팀 | ⏳ |
72
+
73
+ ---
74
+
75
+ ## 3. PCI DSS v4.0 요구사항
76
+
77
+ ### 3.1 네트워크 보안 (Req 1-2)
78
+
79
+ | 요구사항 | ID | 구현 방법 | 상태 |
80
+ |---------|-----|----------|:----:|
81
+ | 카드 데이터 환경(CDE) 분리 | 1.2.1 | VPC 서브넷 분리 | ⏳ |
82
+ | 방화벽 규칙 최소화 | 1.2.5 | Security Group 화이트리스트 | ⏳ |
83
+ | 기본 비밀번호 변경 | 2.2.2 | 자동화된 초기화 | ⏳ |
84
+ | 불필요한 서비스 비활성화 | 2.2.4 | 컨테이너 최소 이미지 | ⏳ |
85
+
86
+ ### 3.2 데이터 보호 (Req 3-4)
87
+
88
+ | 요구사항 | ID | 구현 방법 | 상태 |
89
+ |---------|-----|----------|:----:|
90
+ | 카드 데이터 저장 최소화 | 3.1 | 토큰화 (PG 위임) | ⏳ |
91
+ | PAN 마스킹 | 3.4 | 앞 6자리 + 뒤 4자리만 표시 | ⏳ |
92
+ | 암호화 키 관리 | 3.6.1 | AWS KMS / Vault | ⏳ |
93
+ | 전송 중 암호화 | 4.1 | TLS 1.2+ 필수 | ⏳ |
94
+
95
+ ### 3.3 접근 제어 (Req 7-8)
96
+
97
+ | 요구사항 | ID | 구현 방법 | 상태 |
98
+ |---------|-----|----------|:----:|
99
+ | 업무 필요 기반 접근 | 7.1 | RBAC + 정기 리뷰 | ⏳ |
100
+ | 고유 ID 부여 | 8.1 | 공유 계정 금지 | ⏳ |
101
+ | 다중 인증 (MFA) | 8.3.1 | TOTP 필수 (CDE 접근) | ⏳ |
102
+ | 세션 타임아웃 | 8.2.8 | 15분 (CDE) | ⏳ |
103
+
104
+ ### 3.4 모니터링 (Req 10-11)
105
+
106
+ | 요구사항 | ID | 구현 방법 | 상태 |
107
+ |---------|-----|----------|:----:|
108
+ | 감사 로그 기록 | 10.2 | 모든 CDE 접근 기록 | ⏳ |
109
+ | 로그 변조 방지 | 10.5 | 쓰기 전용 + 해시 체인 | ⏳ |
110
+ | 정기 취약점 스캔 | 11.3 | ASV 스캔 (분기별) | ⏳ |
111
+ | 침투 테스트 | 11.4 | 외부 업체 (연간) | ⏳ |
112
+
113
+ ---
114
+
115
+ ## 4. 자금세탁 방지 (AML/CFT)
116
+
117
+ ### 4.1 고객 확인 (KYC)
118
+
119
+ | 요구사항 | 구현 방법 | 적용 조건 | 상태 |
120
+ |---------|----------|----------|:----:|
121
+ | 실명 확인 | 본인인증 API | 회원가입 시 | ⏳ |
122
+ | 고객 확인 의무 (CDD) | 신분증 + 증빙 | 일정 금액 이상 | ⏳ |
123
+ | 강화된 확인 (EDD) | 추가 심사 | 고위험 고객 | ⏳ |
124
+ | 주기적 갱신 | 재인증 요청 | 연간 | ⏳ |
125
+
126
+ ### 4.2 의심 거래 보고 (STR)
127
+
128
+ | 요구사항 | 보고 대상 | 보고 시한 | 상태 |
129
+ |---------|----------|----------|:----:|
130
+ | 의심 거래 탐지 | FIU (금융정보분석원) | 3영업일 | ⏳ |
131
+ | 고액 현금거래 보고 (CTR) | FIU | 영업일 +15일 | ⏳ |
132
+
133
+ ---
134
+
135
+ ## 5. 인증/심사 일정
136
+
137
+ | 인증 | 심사 유형 | 준비 시작 | 심사 예정 | 담당 | 상태 |
138
+ |-----|---------|----------|---------|------|:----:|
139
+ | PCI DSS | SAQ-A / ROC | TBD | TBD | 보안팀 | 준비 중 |
140
+ | ISMS-P | 최초 인증 | TBD | TBD | 보안팀 | 계획 |
141
+ | 전자금융업 등록 | 금융위 등록 | TBD | TBD | 법무팀 | 계획 |
142
+
143
+ ---
144
+
145
+ ## 6. 준수 체크리스트
146
+
147
+ ### 6.1 출시 전 필수 (금융 서비스)
148
+
149
+ - [ ] 전자금융업 등록/허가
150
+ - [ ] 개인정보 처리방침 작성 및 게시
151
+ - [ ] 이용약관 법률 검토 완료
152
+ - [ ] 이상거래 탐지 시스템(FDS) 운영
153
+ - [ ] 거래 로그 5년 보존 정책 적용
154
+ - [ ] 고객 확인(KYC) 프로세스 구축
155
+ - [ ] 암호화 적용 확인 (저장 + 전송)
156
+ - [ ] 접근 통제 매트릭스 작성
157
+ - [ ] 보안 취약점 점검 완료
158
+ - [ ] 비상 대응 계획(BCP/DR) 수립
159
+ - [ ] 금융감독원 보고 체계 수립
160
+
161
+ ### 6.2 운영 중 정기
162
+
163
+ | 주기 | 점검 항목 |
164
+ |-----|----------|
165
+ | 일간 | FDS 탐지 결과 리뷰 |
166
+ | 주간 | 접근 로그 리뷰 |
167
+ | 월간 | 접근 권한 리뷰, 취약점 스캔 |
168
+ | 분기 | 침투 테스트, ASV 스캔 (PCI DSS) |
169
+ | 반기 | 개인정보 처리 현황 점검 |
170
+ | 연간 | PCI DSS 심사, ISMS-P 갱신, BCP 훈련 |
171
+
172
+ ---
173
+
174
+ ## 7. 관련 문서
175
+
176
+ - [보안 명세](./security-spec.md) — 보안 정책 상세
177
+ - [감사 추적 명세](./audit-trail-spec.md) — 감사 로그 설계
178
+ - [데이터 설계](./data-design.md) — 암호화 필드
179
+ - [에러 코드](./error-codes.md) — 거래 에러 코드
180
+
181
+ ---
182
+
183
+ ## 변경 이력
184
+
185
+ | 버전 | 날짜 | 작성자 | 변경 내용 |
186
+ |------|------|--------|----------|
187
+ | 1.0.0 | {{DATE}} | tsq-security | 초기 작성 (fintech 특화) |
@@ -8,8 +8,8 @@ description: "DevOps, IaC, CI/CD 파이프라인, 모니터링, 자동화"
8
8
  # 에이전트 설정
9
9
  # ============================================================
10
10
  agents:
11
- # Planner는 인프라 아키텍처에 집중
12
- planner:
11
+ # Architect는 인프라 아키텍처에 집중
12
+ architect:
13
13
  model: opus
14
14
  focus:
15
15
  - infrastructure_architecture
@@ -25,8 +25,8 @@ agents:
25
25
  developer:
26
26
  model: sonnet
27
27
  skills:
28
- - coding
29
- - terraform # 또는 적절한 IaC
28
+ - tsq-coding
29
+ # terraform: 프로젝트에 맞는 IaC 스킬 추가
30
30
  focus:
31
31
  - iac_implementation
32
32
  - automation_scripts
@@ -71,6 +71,9 @@ ssot:
71
71
  - data-design.md
72
72
  - functional-spec.md
73
73
 
74
+ # 타입×레벨 자동 배포 (SSOT_TYPE_LEVEL_MAP 기반):
75
+ # L1+: infra-topology, monitoring-spec
76
+
74
77
  # ============================================================
75
78
  # 워크플로우 설정
76
79
  # ============================================================