@luanpdd/kit-mcp 1.33.0 → 1.35.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 (379) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +168 -168
  3. package/gates/agent-no-recursive-dispatch.md +84 -84
  4. package/kit/COMANDOS.md +138 -138
  5. package/kit/COMPATIBILITY.md +70 -70
  6. package/kit/README.md +76 -76
  7. package/kit/agents/advisor-researcher.md +109 -109
  8. package/kit/agents/ai-mutation-tester.md +289 -289
  9. package/kit/agents/assumptions-analyzer.md +110 -110
  10. package/kit/agents/audit-log-implementer.md +314 -314
  11. package/kit/agents/auditor-consistencia-isolamento.md +414 -414
  12. package/kit/agents/b2b-saas-architect.md +157 -157
  13. package/kit/agents/burn-rate-forecaster.md +153 -153
  14. package/kit/agents/cascading-failures-auditor.md +299 -299
  15. package/kit/agents/codebase-mapper.md +769 -769
  16. package/kit/agents/crm-pipeline-implementer.md +257 -257
  17. package/kit/agents/debugger.md +814 -814
  18. package/kit/agents/designer-ui.md +216 -216
  19. package/kit/agents/detector-tenant-quente.md +338 -338
  20. package/kit/agents/evolution-go-integrator.md +201 -201
  21. package/kit/agents/example-reviewer.md +22 -22
  22. package/kit/agents/executor.md +565 -565
  23. package/kit/agents/golden-signals-instrumenter.md +232 -232
  24. package/kit/agents/incident-investigator.md +238 -238
  25. package/kit/agents/integration-checker.md +203 -203
  26. package/kit/agents/invite-flow-implementer.md +190 -190
  27. package/kit/agents/legacy-characterizer.md +369 -369
  28. package/kit/agents/lgpd-compliance-auditor.md +296 -296
  29. package/kit/agents/load-shedding-instrumenter.md +290 -290
  30. package/kit/agents/multi-tenant-isolation-auditor.md +254 -254
  31. package/kit/agents/multi-tenant-rls-writer.md +341 -341
  32. package/kit/agents/nyquist-auditor.md +181 -181
  33. package/kit/agents/observability-coverage-auditor.md +316 -316
  34. package/kit/agents/observability-instrumenter.md +191 -191
  35. package/kit/agents/omm-auditor.md +291 -291
  36. package/kit/agents/org-onboarding-implementer.md +224 -224
  37. package/kit/agents/payload-capture-instrumenter.md +274 -274
  38. package/kit/agents/phase-researcher.md +697 -697
  39. package/kit/agents/plan-checker.md +275 -275
  40. package/kit/agents/planner.md +923 -923
  41. package/kit/agents/postmortem-writer.md +273 -273
  42. package/kit/agents/project-researcher.md +653 -653
  43. package/kit/agents/prr-conductor.md +287 -287
  44. package/kit/agents/refactor-safety-auditor.md +405 -405
  45. package/kit/agents/release-pipeline-auditor.md +364 -364
  46. package/kit/agents/research-synthesizer.md +246 -246
  47. package/kit/agents/roadmapper.md +678 -678
  48. package/kit/agents/schema-checker.md +160 -160
  49. package/kit/agents/seam-finder.md +360 -360
  50. package/kit/agents/shotgun-surgery-detector.md +350 -350
  51. package/kit/agents/slo-engineer.md +217 -217
  52. package/kit/agents/storytelling-analyst.md +300 -300
  53. package/kit/agents/supabase-architect.md +249 -249
  54. package/kit/agents/supabase-auth-bootstrapper.md +400 -400
  55. package/kit/agents/supabase-auth-hook-writer.md +418 -418
  56. package/kit/agents/supabase-branching-architect.md +563 -563
  57. package/kit/agents/supabase-cicd-pipeline-implementer.md +778 -778
  58. package/kit/agents/supabase-column-privileges-writer.md +400 -400
  59. package/kit/agents/supabase-edge-fn-tester.md +288 -288
  60. package/kit/agents/supabase-edge-fn-writer.md +341 -341
  61. package/kit/agents/supabase-mfa-implementer.md +439 -439
  62. package/kit/agents/supabase-migration-writer.md +386 -386
  63. package/kit/agents/supabase-oauth-server-implementer.md +507 -507
  64. package/kit/agents/supabase-rbac-implementer.md +393 -393
  65. package/kit/agents/supabase-realtime-implementer.md +364 -364
  66. package/kit/agents/supabase-rls-hardener.md +522 -522
  67. package/kit/agents/supabase-rls-writer.md +324 -324
  68. package/kit/agents/supabase-roles-implementer.md +356 -356
  69. package/kit/agents/supabase-social-auth-implementer.md +451 -451
  70. package/kit/agents/supabase-sso-saml-architect.md +549 -549
  71. package/kit/agents/supabase-storage-implementer.md +407 -407
  72. package/kit/agents/super-admin-implementer.md +282 -282
  73. package/kit/agents/toil-auditor.md +268 -268
  74. package/kit/agents/ui-auditor.md +438 -438
  75. package/kit/agents/ui-checker.md +305 -305
  76. package/kit/agents/ui-researcher.md +356 -356
  77. package/kit/agents/user-profiler.md +176 -176
  78. package/kit/agents/validador-evolucao-schema.md +336 -336
  79. package/kit/agents/verifier.md +729 -729
  80. package/kit/agents/workflow-generator.md +167 -0
  81. package/kit/commands/adicionar-backlog.md +75 -75
  82. package/kit/commands/adicionar-fase.md +42 -42
  83. package/kit/commands/adicionar-tarefa.md +45 -45
  84. package/kit/commands/adicionar-testes.md +41 -41
  85. package/kit/commands/ajuda.md +21 -21
  86. package/kit/commands/atualizar.md +37 -37
  87. package/kit/commands/auditar-cascading.md +111 -111
  88. package/kit/commands/auditar-marco.md +179 -179
  89. package/kit/commands/auditar-observabilidade-cobertura-workflow.md +121 -0
  90. package/kit/commands/auditar-observabilidade-cobertura.md +183 -183
  91. package/kit/commands/auditar-refactor.md +219 -219
  92. package/kit/commands/auditar-release.md +109 -109
  93. package/kit/commands/auditar-uat.md +23 -23
  94. package/kit/commands/autonomo.md +40 -40
  95. package/kit/commands/branch-pr.md +24 -24
  96. package/kit/commands/burn-rate-status.md +408 -408
  97. package/kit/commands/capturar-payloads.md +193 -193
  98. package/kit/commands/caracterizar.md +212 -212
  99. package/kit/commands/concluir-marco.md +247 -247
  100. package/kit/commands/configuracoes.md +36 -36
  101. package/kit/commands/criar-workflow.md +158 -0
  102. package/kit/commands/dados-distribuidos.md +188 -188
  103. package/kit/commands/definir-perfil.md +10 -10
  104. package/kit/commands/depurar.md +190 -190
  105. package/kit/commands/detectar-duplicacao.md +197 -197
  106. package/kit/commands/discutir-fase.md +131 -131
  107. package/kit/commands/encontrar-seams.md +136 -136
  108. package/kit/commands/entrar-discord.md +17 -17
  109. package/kit/commands/estatisticas.md +18 -18
  110. package/kit/commands/example-greeting.md +33 -33
  111. package/kit/commands/executar-fase.md +58 -58
  112. package/kit/commands/expresso.md +56 -56
  113. package/kit/commands/fase-ui.md +34 -34
  114. package/kit/commands/fazer.md +57 -57
  115. package/kit/commands/fio.md +125 -125
  116. package/kit/commands/fluxos-trabalho.md +64 -64
  117. package/kit/commands/forense.md +176 -176
  118. package/kit/commands/gerenciador.md +38 -38
  119. package/kit/commands/inserir-fase.md +31 -31
  120. package/kit/commands/legacy.md +263 -263
  121. package/kit/commands/limpeza.md +17 -17
  122. package/kit/commands/listar-hipoteses-fase.md +45 -45
  123. package/kit/commands/listar-workspaces.md +18 -18
  124. package/kit/commands/load-shedding.md +117 -117
  125. package/kit/commands/mapear-codebase.md +70 -70
  126. package/kit/commands/multi-tenant.md +163 -163
  127. package/kit/commands/nota.md +33 -33
  128. package/kit/commands/novo-marco.md +43 -43
  129. package/kit/commands/novo-projeto.md +41 -41
  130. package/kit/commands/novo-workspace.md +43 -43
  131. package/kit/commands/pausar-trabalho.md +37 -37
  132. package/kit/commands/perfil-usuario.md +45 -45
  133. package/kit/commands/pesquisar-fase.md +195 -195
  134. package/kit/commands/planejar-fase.md +67 -67
  135. package/kit/commands/planejar-lacunas.md +33 -33
  136. package/kit/commands/plantar-ideia.md +25 -25
  137. package/kit/commands/progresso.md +24 -24
  138. package/kit/commands/proximo.md +30 -30
  139. package/kit/commands/publicar.md +490 -490
  140. package/kit/commands/rapido.md +35 -35
  141. package/kit/commands/reaplicar-patches.md +124 -124
  142. package/kit/commands/refactor-seguro.md +321 -321
  143. package/kit/commands/relatorio-sessao.md +19 -19
  144. package/kit/commands/remover-fase.md +31 -31
  145. package/kit/commands/remover-workspace.md +26 -26
  146. package/kit/commands/resumo-marco.md +50 -50
  147. package/kit/commands/retomar-trabalho.md +40 -40
  148. package/kit/commands/revisar-backlog.md +60 -60
  149. package/kit/commands/revisar-ui.md +32 -32
  150. package/kit/commands/revisar.md +37 -37
  151. package/kit/commands/saude.md +21 -21
  152. package/kit/commands/setup-notion.md +93 -93
  153. package/kit/commands/storytelling.md +179 -179
  154. package/kit/commands/supabase.md +238 -238
  155. package/kit/commands/sync-main.md +68 -68
  156. package/kit/commands/validar-fase.md +35 -35
  157. package/kit/commands/verificar-tarefas.md +44 -44
  158. package/kit/commands/verificar-trabalho.md +64 -64
  159. package/kit/file-manifest.json +424 -419
  160. package/kit/framework/bin/lib/commands.cjs +959 -959
  161. package/kit/framework/bin/lib/config.cjs +442 -442
  162. package/kit/framework/bin/lib/core.cjs +1230 -1230
  163. package/kit/framework/bin/lib/frontmatter.cjs +336 -336
  164. package/kit/framework/bin/lib/init.cjs +1442 -1442
  165. package/kit/framework/bin/lib/milestone.cjs +252 -252
  166. package/kit/framework/bin/lib/model-profiles.cjs +68 -68
  167. package/kit/framework/bin/lib/phase.cjs +888 -888
  168. package/kit/framework/bin/lib/profile-output.cjs +952 -952
  169. package/kit/framework/bin/lib/profile-pipeline.cjs +539 -539
  170. package/kit/framework/bin/lib/roadmap.cjs +329 -329
  171. package/kit/framework/bin/lib/security.cjs +382 -382
  172. package/kit/framework/bin/lib/state.cjs +1031 -1031
  173. package/kit/framework/bin/lib/template.cjs +222 -222
  174. package/kit/framework/bin/lib/uat.cjs +282 -282
  175. package/kit/framework/bin/lib/verify.cjs +888 -888
  176. package/kit/framework/bin/lib/workstream.cjs +491 -491
  177. package/kit/framework/bin/tools.cjs +918 -918
  178. package/kit/framework/commands/workstreams.md +63 -63
  179. package/kit/framework/references/checkpoints.md +778 -778
  180. package/kit/framework/references/continuation-format.md +249 -249
  181. package/kit/framework/references/decimal-phase-calculation.md +64 -64
  182. package/kit/framework/references/git-integration.md +295 -295
  183. package/kit/framework/references/git-planning-commit.md +38 -38
  184. package/kit/framework/references/model-profile-resolution.md +36 -36
  185. package/kit/framework/references/model-profiles.md +139 -139
  186. package/kit/framework/references/phase-argument-parsing.md +61 -61
  187. package/kit/framework/references/planning-config.md +202 -202
  188. package/kit/framework/references/questioning.md +162 -162
  189. package/kit/framework/references/tdd.md +263 -263
  190. package/kit/framework/references/ui-brand.md +160 -160
  191. package/kit/framework/references/user-profiling.md +657 -657
  192. package/kit/framework/references/verification-patterns.md +612 -612
  193. package/kit/framework/references/workstream-flag.md +58 -58
  194. package/kit/framework/templates/DEBUG.md +164 -164
  195. package/kit/framework/templates/UAT.md +265 -265
  196. package/kit/framework/templates/UI-SPEC.md +100 -100
  197. package/kit/framework/templates/VALIDATION.md +76 -76
  198. package/kit/framework/templates/claude-md.md +122 -122
  199. package/kit/framework/templates/codebase/architecture.md +185 -185
  200. package/kit/framework/templates/codebase/concerns.md +205 -205
  201. package/kit/framework/templates/codebase/conventions.md +204 -204
  202. package/kit/framework/templates/codebase/integrations.md +192 -192
  203. package/kit/framework/templates/codebase/stack.md +158 -158
  204. package/kit/framework/templates/codebase/structure.md +199 -199
  205. package/kit/framework/templates/codebase/testing.md +301 -301
  206. package/kit/framework/templates/config.json +44 -44
  207. package/kit/framework/templates/context.md +352 -352
  208. package/kit/framework/templates/continue-here.md +78 -78
  209. package/kit/framework/templates/copilot-instructions.md +7 -7
  210. package/kit/framework/templates/debug-subagent-prompt.md +91 -91
  211. package/kit/framework/templates/dev-preferences.md +20 -20
  212. package/kit/framework/templates/discovery.md +146 -146
  213. package/kit/framework/templates/discussion-log.md +63 -63
  214. package/kit/framework/templates/milestone-archive.md +123 -123
  215. package/kit/framework/templates/milestone.md +115 -115
  216. package/kit/framework/templates/phase-prompt.md +610 -610
  217. package/kit/framework/templates/planner-subagent-prompt.md +117 -117
  218. package/kit/framework/templates/project.md +186 -186
  219. package/kit/framework/templates/requirements.md +231 -231
  220. package/kit/framework/templates/research-project/ARCHITECTURE.md +204 -204
  221. package/kit/framework/templates/research-project/FEATURES.md +147 -147
  222. package/kit/framework/templates/research-project/PITFALLS.md +200 -200
  223. package/kit/framework/templates/research-project/STACK.md +120 -120
  224. package/kit/framework/templates/research-project/SUMMARY.md +170 -170
  225. package/kit/framework/templates/research.md +419 -419
  226. package/kit/framework/templates/retrospective.md +54 -54
  227. package/kit/framework/templates/roadmap.md +202 -202
  228. package/kit/framework/templates/state.md +176 -176
  229. package/kit/framework/templates/summary-complex.md +59 -59
  230. package/kit/framework/templates/summary-minimal.md +41 -41
  231. package/kit/framework/templates/summary-standard.md +48 -48
  232. package/kit/framework/templates/summary.md +209 -209
  233. package/kit/framework/templates/user-profile.md +146 -146
  234. package/kit/framework/templates/user-setup.md +256 -256
  235. package/kit/framework/templates/verification-report.md +258 -258
  236. package/kit/framework/workflows/add-phase.md +112 -112
  237. package/kit/framework/workflows/add-tests.md +351 -351
  238. package/kit/framework/workflows/add-todo.md +158 -158
  239. package/kit/framework/workflows/audit-milestone.md +340 -340
  240. package/kit/framework/workflows/audit-uat.md +109 -109
  241. package/kit/framework/workflows/autonomous.md +891 -891
  242. package/kit/framework/workflows/check-todos.md +177 -177
  243. package/kit/framework/workflows/cleanup.md +152 -152
  244. package/kit/framework/workflows/complete-milestone.md +696 -696
  245. package/kit/framework/workflows/diagnose-issues.md +231 -231
  246. package/kit/framework/workflows/discovery-phase.md +289 -289
  247. package/kit/framework/workflows/discuss-phase-assumptions.md +653 -653
  248. package/kit/framework/workflows/discuss-phase.md +784 -784
  249. package/kit/framework/workflows/do.md +104 -104
  250. package/kit/framework/workflows/execute-phase.md +838 -838
  251. package/kit/framework/workflows/execute-plan.md +510 -510
  252. package/kit/framework/workflows/fast.md +102 -102
  253. package/kit/framework/workflows/forensics.md +265 -265
  254. package/kit/framework/workflows/health.md +181 -181
  255. package/kit/framework/workflows/help.md +619 -619
  256. package/kit/framework/workflows/insert-phase.md +130 -130
  257. package/kit/framework/workflows/list-phase-assumptions.md +178 -178
  258. package/kit/framework/workflows/list-workspaces.md +56 -56
  259. package/kit/framework/workflows/manager.md +362 -362
  260. package/kit/framework/workflows/map-codebase.md +377 -377
  261. package/kit/framework/workflows/milestone-summary.md +223 -223
  262. package/kit/framework/workflows/new-milestone.md +486 -486
  263. package/kit/framework/workflows/new-project.md +1159 -1159
  264. package/kit/framework/workflows/new-workspace.md +237 -237
  265. package/kit/framework/workflows/next.md +97 -97
  266. package/kit/framework/workflows/node-repair.md +92 -92
  267. package/kit/framework/workflows/note.md +156 -156
  268. package/kit/framework/workflows/pause-work.md +176 -176
  269. package/kit/framework/workflows/plan-milestone-gaps.md +273 -273
  270. package/kit/framework/workflows/plan-phase.md +765 -765
  271. package/kit/framework/workflows/plant-seed.md +169 -169
  272. package/kit/framework/workflows/pr-branch.md +129 -129
  273. package/kit/framework/workflows/profile-user.md +450 -450
  274. package/kit/framework/workflows/progress.md +507 -507
  275. package/kit/framework/workflows/quick.md +757 -757
  276. package/kit/framework/workflows/remove-phase.md +155 -155
  277. package/kit/framework/workflows/remove-workspace.md +90 -90
  278. package/kit/framework/workflows/research-phase.md +82 -82
  279. package/kit/framework/workflows/resume-project.md +326 -326
  280. package/kit/framework/workflows/review.md +228 -228
  281. package/kit/framework/workflows/session-report.md +146 -146
  282. package/kit/framework/workflows/settings.md +283 -283
  283. package/kit/framework/workflows/ship.md +228 -228
  284. package/kit/framework/workflows/stats.md +60 -60
  285. package/kit/framework/workflows/transition.md +671 -671
  286. package/kit/framework/workflows/ui-phase.md +302 -302
  287. package/kit/framework/workflows/ui-review.md +165 -165
  288. package/kit/framework/workflows/update.md +323 -323
  289. package/kit/framework/workflows/validate-phase.md +174 -174
  290. package/kit/framework/workflows/verify-phase.md +252 -252
  291. package/kit/framework/workflows/verify-work.md +637 -637
  292. package/kit/hooks/check-update.js +118 -118
  293. package/kit/hooks/context-monitor.js +163 -163
  294. package/kit/hooks/kit-attribution-reminder.cjs +92 -92
  295. package/kit/hooks/kit-router.cjs +137 -137
  296. package/kit/hooks/prompt-guard.js +103 -103
  297. package/kit/hooks/statusline.js +125 -125
  298. package/kit/hooks/workflow-guard.js +101 -101
  299. package/kit/settings.json +45 -45
  300. package/kit/skills/ai-prompt-characterization/SKILL.md +335 -335
  301. package/kit/skills/armadilhas-sistemas-distribuidos/SKILL.md +447 -447
  302. package/kit/skills/audit-log-multi-tenant/SKILL.md +340 -340
  303. package/kit/skills/b2b-saas-architecture/SKILL.md +300 -300
  304. package/kit/skills/consistencia-leitura-replica/SKILL.md +385 -385
  305. package/kit/skills/crm-lead-pipeline-patterns/SKILL.md +343 -343
  306. package/kit/skills/dynamic-workflow-authoring/SKILL.md +223 -0
  307. package/kit/skills/escolha-modelo-consistencia/SKILL.md +494 -494
  308. package/kit/skills/evolucao-schema-compativel/SKILL.md +448 -448
  309. package/kit/skills/evolution-go-whatsapp-integration/SKILL.md +322 -322
  310. package/kit/skills/example-skill/SKILL.md +42 -42
  311. package/kit/skills/legacy-api-only-applications/SKILL.md +358 -358
  312. package/kit/skills/legacy-characterization-tests/SKILL.md +330 -330
  313. package/kit/skills/legacy-effect-analysis/SKILL.md +331 -331
  314. package/kit/skills/legacy-extract-class/SKILL.md +203 -203
  315. package/kit/skills/legacy-programming-by-difference/SKILL.md +252 -252
  316. package/kit/skills/legacy-seams-and-test-harness/SKILL.md +460 -460
  317. package/kit/skills/legacy-shotgun-surgery/SKILL.md +286 -286
  318. package/kit/skills/legacy-sprout-wrap-techniques/SKILL.md +434 -434
  319. package/kit/skills/legacy-storytelling-naked-crc/SKILL.md +270 -270
  320. package/kit/skills/lgpd-multi-tenant-compliance/SKILL.md +340 -340
  321. package/kit/skills/member-invite-flow/SKILL.md +305 -305
  322. package/kit/skills/member-management-react-shadcn/SKILL.md +328 -328
  323. package/kit/skills/multi-tenant-performance-scaling/SKILL.md +316 -316
  324. package/kit/skills/multi-tenant-rls-hierarchy/SKILL.md +342 -342
  325. package/kit/skills/org-onboarding-flow/SKILL.md +257 -257
  326. package/kit/skills/org-switcher-react-pattern/SKILL.md +349 -349
  327. package/kit/skills/permission-gate-react-pattern/SKILL.md +271 -271
  328. package/kit/skills/postgres-isolamento-concorrencia/SKILL.md +552 -552
  329. package/kit/skills/pre-refactor-characterization/SKILL.md +421 -421
  330. package/kit/skills/rbac-permissions-matrix-supabase/SKILL.md +338 -338
  331. package/kit/skills/streams-eventos-cdc/SKILL.md +711 -711
  332. package/kit/skills/supabase-auth-hardening/SKILL.md +674 -674
  333. package/kit/skills/supabase-auth-hooks/SKILL.md +875 -875
  334. package/kit/skills/supabase-auth-methods/SKILL.md +486 -486
  335. package/kit/skills/supabase-auth-sessions/SKILL.md +579 -579
  336. package/kit/skills/supabase-auth-ssr/SKILL.md +306 -306
  337. package/kit/skills/supabase-branching-workflow/SKILL.md +544 -544
  338. package/kit/skills/supabase-ci-cd-github-actions/SKILL.md +880 -880
  339. package/kit/skills/supabase-column-level-security/SKILL.md +426 -426
  340. package/kit/skills/supabase-config-toml-remotes/SKILL.md +807 -807
  341. package/kit/skills/supabase-custom-claims-rbac/SKILL.md +472 -472
  342. package/kit/skills/supabase-edge-functions/SKILL.md +330 -330
  343. package/kit/skills/supabase-edge-functions-auth/SKILL.md +309 -309
  344. package/kit/skills/supabase-edge-functions-limits/SKILL.md +302 -302
  345. package/kit/skills/supabase-edge-functions-mcp-server/SKILL.md +279 -279
  346. package/kit/skills/supabase-edge-functions-testing/SKILL.md +277 -277
  347. package/kit/skills/supabase-edge-runtime-builtins/SKILL.md +357 -357
  348. package/kit/skills/supabase-enterprise-sso-saml/SKILL.md +545 -545
  349. package/kit/skills/supabase-jwt-signing-keys/SKILL.md +399 -399
  350. package/kit/skills/supabase-mfa/SKILL.md +488 -488
  351. package/kit/skills/supabase-migration-repair/SKILL.md +823 -823
  352. package/kit/skills/supabase-migrations/SKILL.md +297 -297
  353. package/kit/skills/supabase-oauth-server/SKILL.md +537 -537
  354. package/kit/skills/supabase-pgtap-testing/SKILL.md +1053 -1053
  355. package/kit/skills/supabase-postgres-roles/SKILL.md +392 -392
  356. package/kit/skills/supabase-realtime/SKILL.md +460 -460
  357. package/kit/skills/supabase-rls-defense-in-depth/SKILL.md +418 -418
  358. package/kit/skills/supabase-rls-policies/SKILL.md +635 -635
  359. package/kit/skills/supabase-social-oauth/SKILL.md +480 -480
  360. package/kit/skills/supabase-third-party-auth/SKILL.md +450 -450
  361. package/kit/skills/super-admin-platform-pattern/SKILL.md +326 -326
  362. package/kit/skills/tenant-quente-mitigacao/SKILL.md +605 -605
  363. package/kit/skills/ui-anti-padroes-ia/SKILL.md +261 -261
  364. package/kit/skills/ui-contexto-produto/SKILL.md +248 -248
  365. package/kit/skills/ui-cor-estrategia/SKILL.md +213 -213
  366. package/kit/skills/ui-critica-auditoria/SKILL.md +260 -260
  367. package/kit/skills/ui-motion-funcional/SKILL.md +264 -264
  368. package/kit/skills/ui-ritmo-espacial/SKILL.md +259 -259
  369. package/kit/skills/ui-tipografia/SKILL.md +211 -211
  370. package/kit/skills/whatsapp-conversation-state-machine/SKILL.md +287 -287
  371. package/kit/workflows/auditar-observabilidade-cobertura.workflow.js +250 -0
  372. package/package.json +65 -63
  373. package/src/core/kit.js +333 -216
  374. package/src/core/reflect.js +247 -247
  375. package/src/core/registry.js +123 -112
  376. package/src/core/reverse-sync.js +448 -372
  377. package/src/core/sync.js +477 -437
  378. package/src/core/watch.js +121 -121
  379. package/src/mcp-server/index.js +794 -794
@@ -1,490 +1,490 @@
1
- ---
2
- name: publicar
3
- description: Publica o milestone atual — cria documentação no Notion, abre PR no GitHub com link Notion na descrição
4
- argument-hint: "[versão opcional, ex: 'v1.1']"
5
- allowed-tools:
6
- - Read
7
- - Bash
8
- - Grep
9
- - Glob
10
- - Write
11
- - AskUserQuestion
12
- - mcp__claude_ai_Notion__notion-create-pages
13
- ---
14
-
15
- # /publicar — Publicar Milestone com Documentação Notion + GitHub
16
-
17
- Publica o milestone atual: cria documentação no Notion, abre PR no GitHub e inclui o link Notion na descrição do PR.
18
-
19
- ## Quando usar
20
-
21
- Após concluir e arquivar um milestone com `/concluir-marco`.
22
-
23
- **Heurística de gatilho (importante):** quando o usuário diz "publicar" depois de aplicar mudanças de código (commits novos, migration aplicada, branch atual com diff vs `main`), interprete como **pipeline completo** — não apenas `git push`. Faça Notion + PR + Obsidian. Para push isolado em outra branch sem cerimônia, o usuário deve pedir explicitamente "só fazer push" ou usar `git push` ele mesmo. Para fix expresso sem milestone, use `/publicar-rapido` (variante leve sem dependência de ROADMAP/MILESTONE-AUDIT).
24
-
25
- ## Dependências obrigatórias
26
-
27
- - `.claude/notion-config.json` presente e preenchido — **fluxo de fallback novo (1.4):** se ausente, NÃO encerre. Em vez disso, vá para o **Passo 0.5 (auto-detect Notion)** abaixo: tente buscar a página do projeto via Notion MCP `notion-search` no workspace e ofereça gerar o config automaticamente. Encerrar é fallback de último recurso.
28
- - Notion MCP configurado na sessão Claude Code
29
- - `gh` CLI autenticado (`gh auth status`)
30
- - Milestone arquivado com `/concluir-marco`
31
-
32
- ## Dependências opcionais
33
-
34
- - `$OBSIDIAN_TEAM_VAULT` — caminho absoluto do cofre Obsidian do time (sincronizado via Git).
35
- - **Fallback novo (1.4):** se ausente, antes de pular o Passo 5, o **Passo 0.7 (auto-detect Obsidian)** tenta caminhos canônicos (`~/Documentos/Obsidian/chat-trynux/`, `~/Documents/Obsidian/chat-trynux/`, e variantes Windows). Só se nenhum bater é que o Passo 5 é pulado com aviso.
36
-
37
- ## Processo
38
-
39
- ### Passo 0 — Pre-flight: sincronizar com `main` ⚠️ NOVO 1.4
40
-
41
- **Por que isso existe:** vários devs trabalhando no mesmo projeto significa que `origin/main` pode ter avançado desde sua última sincronização. Antes de abrir PR, descubra se há trabalho novo e dê ao dev a chance de integrar (evita conflitos grandes mais tarde).
42
-
43
- **Quando pular:** se `BRANCH = main` (vai pushar direto pra main, sem PR), pode pular este passo. Em qualquer outro fluxo, execute.
44
-
45
- #### 0.1 — Buscar atualizações de origin
46
-
47
- ```bash
48
- git fetch origin main 2>&1
49
- ```
50
-
51
- #### 0.2 — Detectar commits novos em main
52
-
53
- ```bash
54
- NEW_COMMITS=$(git log HEAD..origin/main --oneline 2>/dev/null)
55
- COUNT=$(echo "$NEW_COMMITS" | grep -c . 2>/dev/null || echo 0)
56
- ```
57
-
58
- #### 0.3 — Roteamento
59
-
60
- **Se `COUNT == 0`:** sem commits novos. Continue silenciosamente para o Passo 1.
61
-
62
- **Se `COUNT > 0`:** apresente a lista ao usuário e pergunte como prosseguir.
63
-
64
- ```
65
- ⚠️ {COUNT} commit(s) novo(s) em origin/main desde sua última sync:
66
-
67
- {lista dos commits, primeiros 10}
68
-
69
- Como deseja prosseguir?
70
- ```
71
-
72
- Use `AskUserQuestion`:
73
- - **header:** "Sync"
74
- - **question:** "Há {COUNT} commit(s) novo(s) em main. Como prosseguir antes de abrir PR?"
75
- - **options:**
76
- - **"Integrar agora (Recomendado)"** — `git rebase origin/main` na branch atual. Se conflito: pausa, instrui resolver, retoma.
77
- - **"Mesclar via merge commit"** — `git merge origin/main` (preserva histórico ao custo de um merge commit no PR).
78
- - **"Ignorar e continuar"** — segue direto para Passo 1 (assume responsabilidade pelo conflito tardio).
79
- - **"Cancelar publicação"** — exit limpo. Dev integra manualmente, depois reroda /publicar.
80
-
81
- **Em "Integrar agora":**
82
- ```bash
83
- git rebase origin/main
84
- ```
85
- - Se exit 0: continue para Passo 1 com confirmação `✓ Rebase OK`.
86
- - Se conflito: imprima `⚠️ Conflito durante rebase. Resolva os arquivos listados, rode \`git rebase --continue\` (ou \`git rebase --abort\` para desfazer), e reinvoque /publicar.` e exit limpo.
87
-
88
- **Em "Mesclar":**
89
- ```bash
90
- git merge origin/main --no-edit
91
- ```
92
- - Mesmo tratamento de conflito.
93
-
94
- **Em "Ignorar":** registre `SYNC_SKIPPED = true` (será mencionado na descrição do PR como heads-up: "PR aberto sem sync com main — possível conflito ao revisar").
95
-
96
- **Em "Cancelar":** exit limpo, sem efeito colateral.
97
-
98
- ### Passo 0.5 — Auto-detect notion-config.json (se ausente) ⚠️ NOVO 1.4
99
-
100
- Se `.claude/notion-config.json` existe, pule para Passo 0.7.
101
-
102
- Se ausente:
103
-
104
- #### 0.5.1 — Buscar página do projeto via Notion MCP
105
-
106
- ```
107
- notion-search { query: "{NOME_PROJETO}", filter: "page" }
108
- ```
109
-
110
- Onde `{NOME_PROJETO}` vem do `.planning/PROJECT.md` (campo `name` ou primeira frase).
111
-
112
- #### 0.5.2 — Apresentar candidatos
113
-
114
- Filtre resultados pra páginas com título que contenha o nome do projeto (case-insensitive). Mostre top 3 com URL e last-edited.
115
-
116
- Use `AskUserQuestion`:
117
- - **question:** "Encontrei essas páginas no Notion. Qual é a página raiz deste projeto?"
118
- - **options:** uma por candidato + "Nenhuma — abrir /setup-notion"
119
-
120
- Em candidato escolhido:
121
- - Use `notion-fetch` na página escolhida pra listar subpáginas (espera-se `changelog/`, `features/`, `adr/`, `runbooks/`).
122
- - Para cada subpágina conhecida, capture o ID.
123
- - Gere `.claude/notion-config.json` com o template do `/setup-notion`.
124
- - Confirme: "✓ notion-config.json criado a partir das páginas existentes."
125
-
126
- Em "Nenhuma": exit limpo com mensagem `⛔ Execute /setup-notion para criar a estrutura Notion deste projeto, depois rerun /publicar.`
127
-
128
- ### Passo 0.7 — Auto-detect cofre Obsidian (se env var ausente) ⚠️ NOVO 1.4
129
-
130
- Se `$OBSIDIAN_TEAM_VAULT` está definida E o caminho existe, pule para Passo 1.
131
-
132
- Se ausente, tente caminhos canônicos em ordem (primeiro que existir vence):
133
-
134
- | Plataforma | Caminho |
135
- |---|---|
136
- | Linux/macOS | `$HOME/Documentos/Obsidian/chat-trynux` |
137
- | Linux/macOS | `$HOME/Documents/Obsidian/chat-trynux` |
138
- | Windows | `$USERPROFILE/Documentos/Obsidian/chat-trynux` |
139
- | Windows | `$USERPROFILE/Documents/Obsidian/chat-trynux` |
140
- | WSL | `/mnt/c/Users/$USER/Documents/Obsidian/chat-trynux` |
141
-
142
- ```bash
143
- for CANDIDATE in \
144
- "$HOME/Documentos/Obsidian/chat-trynux" \
145
- "$HOME/Documents/Obsidian/chat-trynux" \
146
- "$USERPROFILE/Documentos/Obsidian/chat-trynux" \
147
- "$USERPROFILE/Documents/Obsidian/chat-trynux" \
148
- "/mnt/c/Users/$USER/Documents/Obsidian/chat-trynux"; do
149
- [ -n "$CANDIDATE" ] && [ -d "$CANDIDATE" ] && { export OBSIDIAN_TEAM_VAULT="$CANDIDATE"; break; }
150
- done
151
- ```
152
-
153
- - Se uma das variantes bateu: registre `OBSIDIAN_AUTO_DETECTED = true` e prossiga normalmente para Passo 1.
154
- - Se nenhuma bateu: comportamento legado (Passo 5 será pulado com `OBSIDIAN_SKIP_REASON = "OBSIDIAN_TEAM_VAULT não configurada e nenhum caminho canônico encontrado"`).
155
-
156
- > **Nota:** o nome `chat-trynux` é o cofre canônico padrão. Para usar outro nome, defina `$OBSIDIAN_TEAM_VAULT` explicitamente — a auto-detecção não tenta diretórios alternativos.
157
-
158
- ### Passo 1 — Ler contexto
159
-
160
- Leia os seguintes arquivos:
161
- - `.claude/notion-config.json` → IDs das páginas Notion
162
- - `.planning/STATE.md` → versão e nome do milestone
163
- - `.planning/PROJECT.md` → nome e stack do projeto
164
- - `.planning/milestones/` → arquivos do último milestone arquivado (ROADMAP + REQUIREMENTS)
165
- - `.planning/milestones/vX.X-MILESTONE-AUDIT.md` → cobertura de requisitos e métricas
166
-
167
- Extraia:
168
- - `VERSION` — ex: `v1.1`
169
- - `MILESTONE_NAME` — ex: `Nome do Milestone`
170
- - `NOTION_CHANGELOG_PAGE_ID` — do notion-config.json
171
- - Realizações principais (das SUMMARY.md ou do ROADMAP arquivado)
172
- - Decisões arquiteturais (do STATE.md ou SUMMARYs)
173
- - Dívidas técnicas
174
- - Métricas (testes, arquivos, fases, planos)
175
-
176
- ### Passo 2 — Decidir branch de publicação
177
-
178
- Execute `git branch --show-current` para identificar a branch local atual.
179
-
180
- Use `AskUserQuestion` com opções para perguntar ao usuário:
181
-
182
- ```
183
- question: "Branch atual: {BRANCH_ATUAL}. Como deseja publicar?"
184
- header: "Branch"
185
- options:
186
- - label: "Usar branch atual"
187
- description: "Commit, push e PR na branch {BRANCH_ATUAL}"
188
- - label: "Criar nova branch"
189
- description: "Criar uma branch a partir da main com nome baseado nas mudanças"
190
- ```
191
-
192
- #### Se "Usar branch atual"
193
-
194
- - Verifique mudanças não commitadas: `git status --porcelain`
195
- - Se houver, use `AskUserQuestion`:
196
- ```
197
- question: "Há mudanças não commitadas. Deseja incluí-las no commit?"
198
- header: "Commit"
199
- options:
200
- - label: "Sim, incluir tudo"
201
- description: "git add . — o commit será feito após criar o Notion (para incluir o link)"
202
- - label: "Não, só fazer push"
203
- description: "Pular o commit e ir direto para o push"
204
- ```
205
- - Se "Sim": guarde `PENDENTE_COMMIT = true`. O commit será executado no Passo 3, depois de ter o `NOTION_URL`.
206
- - Prossiga para o Passo 3 com `BRANCH = {BRANCH_ATUAL}`
207
-
208
- #### Se "Criar nova branch"
209
-
210
- Analise o conteúdo do milestone para inferir tipo e escopo e gere o nome sugerido:
211
-
212
- **Regras de nomenclatura:**
213
-
214
- | Tipo de mudança | Prefixo | Exemplo |
215
- |---|---|---|
216
- | Correção de bug | `fix` | `fix-sidebar-v2` |
217
- | Nova feature | `feat` | `feat-dashboard-icons` |
218
- | Refatoração | `refactor` | `refactor-auth-flow` |
219
- | Melhoria de performance | `perf` | `perf-sidebar` |
220
- | Mudança visual / UI | `ui` | `ui-dashboard-icons` |
221
- | Atualização de conteúdo/texto | `content` | `content-onboarding` |
222
-
223
- **Formato:** `{prefixo}-{nome-da-aba-modal-ou-area}-{versão se houver mais de uma branch do mesmo tipo}`
224
-
225
- Use `AskUserQuestion` para confirmar o nome sugerido:
226
-
227
- ```
228
- question: "Nome sugerido para a nova branch: {NOME_SUGERIDO}. Confirma?"
229
- header: "Nome da branch"
230
- options:
231
- - label: "{NOME_SUGERIDO}"
232
- description: "Usar o nome sugerido"
233
- - label: "Outro nome"
234
- description: "Digitar um nome diferente"
235
- ```
236
-
237
- Se "Outro nome" → aguarde o usuário digitar via campo "Other" do modal.
238
-
239
- Após confirmação:
240
- ```bash
241
- git fetch origin
242
- git checkout -b {NOVA_BRANCH} origin/main
243
- ```
244
-
245
- - Se havia mudanças não commitadas na branch anterior, use `AskUserQuestion`:
246
- ```
247
- question: "Deseja levar as mudanças não commitadas para a nova branch?"
248
- header: "Mudanças"
249
- options:
250
- - label: "Sim, transportar"
251
- description: "git stash → checkout → git stash pop"
252
- - label: "Não, descartar"
253
- description: "Deixar as mudanças na branch anterior"
254
- ```
255
- - Prossiga para o Passo 3 com `BRANCH = {NOVA_BRANCH}`
256
-
257
- ### Passo 3 — Criar página Notion ⚠️ OBRIGATÓRIO — não pule esta etapa
258
-
259
- **Esta etapa deve ser executada ANTES do push e do PR.** O link do Notion precisa estar disponível para incluir na descrição do PR.
260
-
261
- Use o Notion MCP (`notion-create-pages`) para criar uma subpágina em `NOTION_CHANGELOG_PAGE_ID` (a página `changelog/` do projeto).
262
-
263
- Após chamar `notion-create-pages`, armazene a URL retornada como `NOTION_URL`.
264
-
265
- Se `PENDENTE_COMMIT = true`, execute o commit agora com o link incluído:
266
- ```bash
267
- git add .
268
- git commit -m "{tipo}: {MILESTONE_NAME}
269
-
270
- Notion: {NOTION_URL}"
271
- ```
272
-
273
- **Template da página:**
274
-
275
- ```
276
- Título: {VERSION} — {MILESTONE_NAME}
277
- Ícone: 🚀
278
-
279
- [Callout verde] Entregue em: {DATA} | Requisitos: X/X | Testes: N passando
280
-
281
- ---
282
-
283
- # Para o Time de Produto
284
-
285
- ## O que você consegue fazer agora
286
- [Para cada feature entregue: 1 parágrafo em linguagem de produto, sem jargão técnico]
287
- [Se houver UI nova: inclua passo a passo "Como usar"]
288
-
289
- ---
290
-
291
- # Para o Time Técnico
292
-
293
- ## O que mudou no código
294
- [Tabela: Arquivo | O que mudou]
295
- [Code snippet do padrão principal implementado, se relevante]
296
-
297
- ## Decisões Arquiteturais
298
- [Toggle para cada decisão relevante: contexto + decisão + consequências]
299
-
300
- ## Dívidas Técnicas Registradas
301
- [Tabela: Item | Impacto | Quando tratar]
302
-
303
- ---
304
-
305
- ## Referências
306
- - Branch: `{BRANCH}`
307
- - Tag git: `{VERSION}`
308
- - Testes: N passando
309
- - Auditoria: `.planning/{VERSION}-MILESTONE-AUDIT.md`
310
- ```
311
-
312
- **Regras de voz:**
313
- - Seção "Produto": sem nomes de arquivo, sem SQL, sem termos de código. Foco em "antes X, agora Y".
314
- - Seção "Técnico": arquivos reais, commits, decisões de implementação.
315
-
316
- ### Passo 4 — Push e PR no GitHub
317
-
318
- ⚠️ Só execute este passo após ter o `NOTION_URL` do Passo 3.
319
-
320
- ```bash
321
- git push origin {BRANCH}
322
-
323
- gh pr create \
324
- --title "{VERSION}: {MILESTONE_NAME}" \
325
- --body "..."
326
- ```
327
-
328
- **Template do body do PR:**
329
-
330
- ```markdown
331
- ## {VERSION} — {MILESTONE_NAME}
332
-
333
- ### O que muda
334
- [3-5 bullet points em linguagem de negócio]
335
-
336
- ### Cobertura
337
- - Requisitos: X/X satisfeitos
338
- - Testes: N passando
339
- - TypeScript: limpo (0 erros)
340
-
341
- ### Documentação
342
- 📄 Notion: {NOTION_URL}
343
-
344
- ### Como testar
345
- [Checklist de smoke tests manuais do MILESTONE-AUDIT.md]
346
- ```
347
-
348
- **Regras para o PR:**
349
- - Sem rodapé de assinatura de IA
350
- - Sem menção a ferramentas ou geradores
351
- - Linguagem direta, como se fosse escrito pelo dev
352
-
353
- ### Passo 5 — 📚 Atualizar cofre Obsidian do time
354
-
355
- ⚠️ **Este passo é "bônus".** Se falhar por qualquer motivo (variável ausente, caminho inválido, conflito Git não-resolvível, push rejeitado após retry), **armazene o motivo em `OBSIDIAN_SKIP_REASON` e prossiga para o Passo 6**. PR e Notion já estão feitos — o dev atualiza o cofre manualmente depois.
356
-
357
- #### 5.1 — Validar ambiente
358
-
359
- - Ler `$OBSIDIAN_TEAM_VAULT`.
360
- - Se a variável não estiver definida:
361
- > ⚠️ Variável OBSIDIAN_TEAM_VAULT não configurada. Pule para os próximos passos do onboarding no README do cofre.
362
-
363
- Defina `OBSIDIAN_SKIP_REASON = "OBSIDIAN_TEAM_VAULT não configurada"` e vá para o Passo 6.
364
- - Se definida mas o caminho não existir (`test -d "$OBSIDIAN_TEAM_VAULT"` falha):
365
- > ⚠️ Cofre Obsidian não encontrado em: {caminho}. Verifique se o clone local existe.
366
-
367
- Defina `OBSIDIAN_SKIP_REASON = "Cofre não encontrado em {caminho}"` e vá para o Passo 6.
368
-
369
- #### 5.2 — Sincronizar com remoto
370
-
371
- ```bash
372
- git -C "$OBSIDIAN_TEAM_VAULT" pull --rebase
373
- ```
374
-
375
- - Se o `pull --rebase` falhar com conflito, tentar resolução automática:
376
- ```bash
377
- git -C "$OBSIDIAN_TEAM_VAULT" rebase --abort 2>/dev/null || true
378
- git -C "$OBSIDIAN_TEAM_VAULT" pull --rebase -X theirs
379
- ```
380
- - Se ainda assim falhar: defina `OBSIDIAN_SKIP_REASON = "Conflito Git no cofre — resolver manualmente"` e vá para o Passo 6.
381
-
382
- #### 5.3 — Ler CLAUDE.md do cofre
383
-
384
- Ler `$OBSIDIAN_TEAM_VAULT/CLAUDE.md`. Esse arquivo contém as convenções de documentação do time (nomenclatura, estrutura de pastas, templates, convenções de commit). **As regras vivem lá** — siga o que o CLAUDE.md mandar, não o que este prompt diz de cor.
385
-
386
- Se o `CLAUDE.md` não existir: defina `OBSIDIAN_SKIP_REASON = "CLAUDE.md ausente no cofre — estrutura desconhecida"` e vá para o Passo 6.
387
-
388
- #### 5.4 — Criar/atualizar as notas
389
-
390
- Baseado no contexto do PR que acabou de ser publicado (número, título, arquivos tocados, `MILESTONE_NAME`, `NOTION_URL`):
391
-
392
- **a) Nota do PR** (obrigatória)
393
-
394
- Caminho: `01 - PRs/YYYY/YYYY-MM-DD-pr-{PR_NUMBER}-{slug-do-titulo}.md`
395
-
396
- - `YYYY` / `YYYY-MM-DD` = data do merge/criação do PR.
397
- - `slug-do-titulo` = título do PR em kebab-case (lowercase, sem acentos, espaços → `-`, sem pontuação).
398
- - Usar `09 - Templates/template-pr.md` como base.
399
- - **Frontmatter DEVE conter `notion: {NOTION_URL}`** para ponte bidirecional entre as duas bases.
400
-
401
- **b) Changelog** (obrigatório)
402
-
403
- Caminho: `03 - Changelog/YYYY.md`
404
-
405
- - Adicionar entrada na seção `## Não lançado`, nas subseções apropriadas:
406
- - `### Adicionado` — features novas
407
- - `### Alterado` — mudanças de comportamento existente
408
- - `### Corrigido` — bugs
409
- - `### Removido` — remoções
410
- - Cada entrada deve referenciar o número do PR.
411
-
412
- **c) Notas de componentes/endpoints afetados** (condicional)
413
-
414
- Se o PR tocar componentes/páginas/endpoints existentes:
415
- - Localizar a nota correspondente em `05 - Frontend/` e/ou `06 - Backend/`.
416
- - Atualizar a seção `## Histórico de mudanças` com a data (`YYYY-MM-DD`) e o link do PR.
417
-
418
- Se o PR introduzir algo **novo**:
419
- - Criar nova nota em `05 - Frontend/` ou `06 - Backend/` usando `09 - Templates/template-funcionalidade.md`.
420
-
421
- #### 5.5 — Commit e push
422
-
423
- ```bash
424
- cd "$OBSIDIAN_TEAM_VAULT"
425
- git add .
426
- git commit -m "docs(pr-{PR_NUMBER}): {título-curto}"
427
- git push
428
- ```
429
-
430
- - Título curto = slug do título do PR truncado em ~60 chars, seguindo convenções de commit do `CLAUDE.md` do cofre.
431
- - Se o `git push` falhar por divergência:
432
- ```bash
433
- git pull --rebase
434
- git push
435
- ```
436
- - Se ainda falhar: defina `OBSIDIAN_SKIP_REASON = "Push rejeitado após rebase — resolver manualmente"` e vá para o Passo 6.
437
-
438
- #### 5.6 — Capturar link da nota de PR
439
-
440
- Construir a URL pública da nota no GitHub. Defina o repositório do cofre via env var `OBSIDIAN_VAULT_REPO` (formato `owner/repo`):
441
-
442
- ```
443
- OBSIDIAN_URL = https://github.com/${OBSIDIAN_VAULT_REPO}/blob/main/01%20-%20PRs/YYYY/YYYY-MM-DD-pr-{PR_NUMBER}-{slug}.md
444
- ```
445
-
446
- Se `OBSIDIAN_VAULT_REPO` não estiver definida, defina `OBSIDIAN_SKIP_REASON = "OBSIDIAN_VAULT_REPO não configurada"` e vá para o Passo 6.
447
-
448
- - Encode: espaços → `%20`. Barras internas permanecem literais.
449
- - Armazene como `OBSIDIAN_URL` para uso no Passo 6.
450
-
451
- ### Passo 6 — Reportar resultado
452
-
453
- Exiba ao usuário:
454
-
455
- ```
456
- ✅ Milestone {VERSION} publicado
457
-
458
- 📄 Notion: {NOTION_URL}
459
- 🔗 PR: {PR_URL}
460
- 📚 Obsidian: {OBSIDIAN_URL}
461
- 🌿 Branch: {BRANCH}
462
- ```
463
-
464
- Se o Passo 5 foi pulado, substitua a linha do Obsidian por:
465
-
466
- ```
467
- ⚠️ Obsidian: pulado — {OBSIDIAN_SKIP_REASON}
468
- ```
469
-
470
- (mantendo as demais linhas intactas)
471
-
472
- ## Para outros projetos
473
-
474
- Copie `.claude/notion-config.json` para o projeto e preencha com os IDs corretos:
475
-
476
- ```json
477
- {
478
- "project": "NomeDoProjeto",
479
- "notion": {
480
- "root": "ID_DA_PAGINA_PRINCIPAL",
481
- "root_url": "https://www.notion.so/...",
482
- "changelog": "ID_DA_PAGINA_CHANGELOG",
483
- "features": "ID_DA_PAGINA_FEATURES",
484
- "adr": "ID_DA_PAGINA_ADR",
485
- "runbooks": "ID_DA_PAGINA_RUNBOOKS"
486
- }
487
- }
488
- ```
489
-
490
- Para criar a estrutura de um novo projeto no Notion, execute `/setup-notion`.
1
+ ---
2
+ name: publicar
3
+ description: Publica o milestone atual — cria documentação no Notion, abre PR no GitHub com link Notion na descrição
4
+ argument-hint: "[versão opcional, ex: 'v1.1']"
5
+ allowed-tools:
6
+ - Read
7
+ - Bash
8
+ - Grep
9
+ - Glob
10
+ - Write
11
+ - AskUserQuestion
12
+ - mcp__claude_ai_Notion__notion-create-pages
13
+ ---
14
+
15
+ # /publicar — Publicar Milestone com Documentação Notion + GitHub
16
+
17
+ Publica o milestone atual: cria documentação no Notion, abre PR no GitHub e inclui o link Notion na descrição do PR.
18
+
19
+ ## Quando usar
20
+
21
+ Após concluir e arquivar um milestone com `/concluir-marco`.
22
+
23
+ **Heurística de gatilho (importante):** quando o usuário diz "publicar" depois de aplicar mudanças de código (commits novos, migration aplicada, branch atual com diff vs `main`), interprete como **pipeline completo** — não apenas `git push`. Faça Notion + PR + Obsidian. Para push isolado em outra branch sem cerimônia, o usuário deve pedir explicitamente "só fazer push" ou usar `git push` ele mesmo. Para fix expresso sem milestone, use `/publicar-rapido` (variante leve sem dependência de ROADMAP/MILESTONE-AUDIT).
24
+
25
+ ## Dependências obrigatórias
26
+
27
+ - `.claude/notion-config.json` presente e preenchido — **fluxo de fallback novo (1.4):** se ausente, NÃO encerre. Em vez disso, vá para o **Passo 0.5 (auto-detect Notion)** abaixo: tente buscar a página do projeto via Notion MCP `notion-search` no workspace e ofereça gerar o config automaticamente. Encerrar é fallback de último recurso.
28
+ - Notion MCP configurado na sessão Claude Code
29
+ - `gh` CLI autenticado (`gh auth status`)
30
+ - Milestone arquivado com `/concluir-marco`
31
+
32
+ ## Dependências opcionais
33
+
34
+ - `$OBSIDIAN_TEAM_VAULT` — caminho absoluto do cofre Obsidian do time (sincronizado via Git).
35
+ - **Fallback novo (1.4):** se ausente, antes de pular o Passo 5, o **Passo 0.7 (auto-detect Obsidian)** tenta caminhos canônicos (`~/Documentos/Obsidian/chat-trynux/`, `~/Documents/Obsidian/chat-trynux/`, e variantes Windows). Só se nenhum bater é que o Passo 5 é pulado com aviso.
36
+
37
+ ## Processo
38
+
39
+ ### Passo 0 — Pre-flight: sincronizar com `main` ⚠️ NOVO 1.4
40
+
41
+ **Por que isso existe:** vários devs trabalhando no mesmo projeto significa que `origin/main` pode ter avançado desde sua última sincronização. Antes de abrir PR, descubra se há trabalho novo e dê ao dev a chance de integrar (evita conflitos grandes mais tarde).
42
+
43
+ **Quando pular:** se `BRANCH = main` (vai pushar direto pra main, sem PR), pode pular este passo. Em qualquer outro fluxo, execute.
44
+
45
+ #### 0.1 — Buscar atualizações de origin
46
+
47
+ ```bash
48
+ git fetch origin main 2>&1
49
+ ```
50
+
51
+ #### 0.2 — Detectar commits novos em main
52
+
53
+ ```bash
54
+ NEW_COMMITS=$(git log HEAD..origin/main --oneline 2>/dev/null)
55
+ COUNT=$(echo "$NEW_COMMITS" | grep -c . 2>/dev/null || echo 0)
56
+ ```
57
+
58
+ #### 0.3 — Roteamento
59
+
60
+ **Se `COUNT == 0`:** sem commits novos. Continue silenciosamente para o Passo 1.
61
+
62
+ **Se `COUNT > 0`:** apresente a lista ao usuário e pergunte como prosseguir.
63
+
64
+ ```
65
+ ⚠️ {COUNT} commit(s) novo(s) em origin/main desde sua última sync:
66
+
67
+ {lista dos commits, primeiros 10}
68
+
69
+ Como deseja prosseguir?
70
+ ```
71
+
72
+ Use `AskUserQuestion`:
73
+ - **header:** "Sync"
74
+ - **question:** "Há {COUNT} commit(s) novo(s) em main. Como prosseguir antes de abrir PR?"
75
+ - **options:**
76
+ - **"Integrar agora (Recomendado)"** — `git rebase origin/main` na branch atual. Se conflito: pausa, instrui resolver, retoma.
77
+ - **"Mesclar via merge commit"** — `git merge origin/main` (preserva histórico ao custo de um merge commit no PR).
78
+ - **"Ignorar e continuar"** — segue direto para Passo 1 (assume responsabilidade pelo conflito tardio).
79
+ - **"Cancelar publicação"** — exit limpo. Dev integra manualmente, depois reroda /publicar.
80
+
81
+ **Em "Integrar agora":**
82
+ ```bash
83
+ git rebase origin/main
84
+ ```
85
+ - Se exit 0: continue para Passo 1 com confirmação `✓ Rebase OK`.
86
+ - Se conflito: imprima `⚠️ Conflito durante rebase. Resolva os arquivos listados, rode \`git rebase --continue\` (ou \`git rebase --abort\` para desfazer), e reinvoque /publicar.` e exit limpo.
87
+
88
+ **Em "Mesclar":**
89
+ ```bash
90
+ git merge origin/main --no-edit
91
+ ```
92
+ - Mesmo tratamento de conflito.
93
+
94
+ **Em "Ignorar":** registre `SYNC_SKIPPED = true` (será mencionado na descrição do PR como heads-up: "PR aberto sem sync com main — possível conflito ao revisar").
95
+
96
+ **Em "Cancelar":** exit limpo, sem efeito colateral.
97
+
98
+ ### Passo 0.5 — Auto-detect notion-config.json (se ausente) ⚠️ NOVO 1.4
99
+
100
+ Se `.claude/notion-config.json` existe, pule para Passo 0.7.
101
+
102
+ Se ausente:
103
+
104
+ #### 0.5.1 — Buscar página do projeto via Notion MCP
105
+
106
+ ```
107
+ notion-search { query: "{NOME_PROJETO}", filter: "page" }
108
+ ```
109
+
110
+ Onde `{NOME_PROJETO}` vem do `.planning/PROJECT.md` (campo `name` ou primeira frase).
111
+
112
+ #### 0.5.2 — Apresentar candidatos
113
+
114
+ Filtre resultados pra páginas com título que contenha o nome do projeto (case-insensitive). Mostre top 3 com URL e last-edited.
115
+
116
+ Use `AskUserQuestion`:
117
+ - **question:** "Encontrei essas páginas no Notion. Qual é a página raiz deste projeto?"
118
+ - **options:** uma por candidato + "Nenhuma — abrir /setup-notion"
119
+
120
+ Em candidato escolhido:
121
+ - Use `notion-fetch` na página escolhida pra listar subpáginas (espera-se `changelog/`, `features/`, `adr/`, `runbooks/`).
122
+ - Para cada subpágina conhecida, capture o ID.
123
+ - Gere `.claude/notion-config.json` com o template do `/setup-notion`.
124
+ - Confirme: "✓ notion-config.json criado a partir das páginas existentes."
125
+
126
+ Em "Nenhuma": exit limpo com mensagem `⛔ Execute /setup-notion para criar a estrutura Notion deste projeto, depois rerun /publicar.`
127
+
128
+ ### Passo 0.7 — Auto-detect cofre Obsidian (se env var ausente) ⚠️ NOVO 1.4
129
+
130
+ Se `$OBSIDIAN_TEAM_VAULT` está definida E o caminho existe, pule para Passo 1.
131
+
132
+ Se ausente, tente caminhos canônicos em ordem (primeiro que existir vence):
133
+
134
+ | Plataforma | Caminho |
135
+ |---|---|
136
+ | Linux/macOS | `$HOME/Documentos/Obsidian/chat-trynux` |
137
+ | Linux/macOS | `$HOME/Documents/Obsidian/chat-trynux` |
138
+ | Windows | `$USERPROFILE/Documentos/Obsidian/chat-trynux` |
139
+ | Windows | `$USERPROFILE/Documents/Obsidian/chat-trynux` |
140
+ | WSL | `/mnt/c/Users/$USER/Documents/Obsidian/chat-trynux` |
141
+
142
+ ```bash
143
+ for CANDIDATE in \
144
+ "$HOME/Documentos/Obsidian/chat-trynux" \
145
+ "$HOME/Documents/Obsidian/chat-trynux" \
146
+ "$USERPROFILE/Documentos/Obsidian/chat-trynux" \
147
+ "$USERPROFILE/Documents/Obsidian/chat-trynux" \
148
+ "/mnt/c/Users/$USER/Documents/Obsidian/chat-trynux"; do
149
+ [ -n "$CANDIDATE" ] && [ -d "$CANDIDATE" ] && { export OBSIDIAN_TEAM_VAULT="$CANDIDATE"; break; }
150
+ done
151
+ ```
152
+
153
+ - Se uma das variantes bateu: registre `OBSIDIAN_AUTO_DETECTED = true` e prossiga normalmente para Passo 1.
154
+ - Se nenhuma bateu: comportamento legado (Passo 5 será pulado com `OBSIDIAN_SKIP_REASON = "OBSIDIAN_TEAM_VAULT não configurada e nenhum caminho canônico encontrado"`).
155
+
156
+ > **Nota:** o nome `chat-trynux` é o cofre canônico padrão. Para usar outro nome, defina `$OBSIDIAN_TEAM_VAULT` explicitamente — a auto-detecção não tenta diretórios alternativos.
157
+
158
+ ### Passo 1 — Ler contexto
159
+
160
+ Leia os seguintes arquivos:
161
+ - `.claude/notion-config.json` → IDs das páginas Notion
162
+ - `.planning/STATE.md` → versão e nome do milestone
163
+ - `.planning/PROJECT.md` → nome e stack do projeto
164
+ - `.planning/milestones/` → arquivos do último milestone arquivado (ROADMAP + REQUIREMENTS)
165
+ - `.planning/milestones/vX.X-MILESTONE-AUDIT.md` → cobertura de requisitos e métricas
166
+
167
+ Extraia:
168
+ - `VERSION` — ex: `v1.1`
169
+ - `MILESTONE_NAME` — ex: `Nome do Milestone`
170
+ - `NOTION_CHANGELOG_PAGE_ID` — do notion-config.json
171
+ - Realizações principais (das SUMMARY.md ou do ROADMAP arquivado)
172
+ - Decisões arquiteturais (do STATE.md ou SUMMARYs)
173
+ - Dívidas técnicas
174
+ - Métricas (testes, arquivos, fases, planos)
175
+
176
+ ### Passo 2 — Decidir branch de publicação
177
+
178
+ Execute `git branch --show-current` para identificar a branch local atual.
179
+
180
+ Use `AskUserQuestion` com opções para perguntar ao usuário:
181
+
182
+ ```
183
+ question: "Branch atual: {BRANCH_ATUAL}. Como deseja publicar?"
184
+ header: "Branch"
185
+ options:
186
+ - label: "Usar branch atual"
187
+ description: "Commit, push e PR na branch {BRANCH_ATUAL}"
188
+ - label: "Criar nova branch"
189
+ description: "Criar uma branch a partir da main com nome baseado nas mudanças"
190
+ ```
191
+
192
+ #### Se "Usar branch atual"
193
+
194
+ - Verifique mudanças não commitadas: `git status --porcelain`
195
+ - Se houver, use `AskUserQuestion`:
196
+ ```
197
+ question: "Há mudanças não commitadas. Deseja incluí-las no commit?"
198
+ header: "Commit"
199
+ options:
200
+ - label: "Sim, incluir tudo"
201
+ description: "git add . — o commit será feito após criar o Notion (para incluir o link)"
202
+ - label: "Não, só fazer push"
203
+ description: "Pular o commit e ir direto para o push"
204
+ ```
205
+ - Se "Sim": guarde `PENDENTE_COMMIT = true`. O commit será executado no Passo 3, depois de ter o `NOTION_URL`.
206
+ - Prossiga para o Passo 3 com `BRANCH = {BRANCH_ATUAL}`
207
+
208
+ #### Se "Criar nova branch"
209
+
210
+ Analise o conteúdo do milestone para inferir tipo e escopo e gere o nome sugerido:
211
+
212
+ **Regras de nomenclatura:**
213
+
214
+ | Tipo de mudança | Prefixo | Exemplo |
215
+ |---|---|---|
216
+ | Correção de bug | `fix` | `fix-sidebar-v2` |
217
+ | Nova feature | `feat` | `feat-dashboard-icons` |
218
+ | Refatoração | `refactor` | `refactor-auth-flow` |
219
+ | Melhoria de performance | `perf` | `perf-sidebar` |
220
+ | Mudança visual / UI | `ui` | `ui-dashboard-icons` |
221
+ | Atualização de conteúdo/texto | `content` | `content-onboarding` |
222
+
223
+ **Formato:** `{prefixo}-{nome-da-aba-modal-ou-area}-{versão se houver mais de uma branch do mesmo tipo}`
224
+
225
+ Use `AskUserQuestion` para confirmar o nome sugerido:
226
+
227
+ ```
228
+ question: "Nome sugerido para a nova branch: {NOME_SUGERIDO}. Confirma?"
229
+ header: "Nome da branch"
230
+ options:
231
+ - label: "{NOME_SUGERIDO}"
232
+ description: "Usar o nome sugerido"
233
+ - label: "Outro nome"
234
+ description: "Digitar um nome diferente"
235
+ ```
236
+
237
+ Se "Outro nome" → aguarde o usuário digitar via campo "Other" do modal.
238
+
239
+ Após confirmação:
240
+ ```bash
241
+ git fetch origin
242
+ git checkout -b {NOVA_BRANCH} origin/main
243
+ ```
244
+
245
+ - Se havia mudanças não commitadas na branch anterior, use `AskUserQuestion`:
246
+ ```
247
+ question: "Deseja levar as mudanças não commitadas para a nova branch?"
248
+ header: "Mudanças"
249
+ options:
250
+ - label: "Sim, transportar"
251
+ description: "git stash → checkout → git stash pop"
252
+ - label: "Não, descartar"
253
+ description: "Deixar as mudanças na branch anterior"
254
+ ```
255
+ - Prossiga para o Passo 3 com `BRANCH = {NOVA_BRANCH}`
256
+
257
+ ### Passo 3 — Criar página Notion ⚠️ OBRIGATÓRIO — não pule esta etapa
258
+
259
+ **Esta etapa deve ser executada ANTES do push e do PR.** O link do Notion precisa estar disponível para incluir na descrição do PR.
260
+
261
+ Use o Notion MCP (`notion-create-pages`) para criar uma subpágina em `NOTION_CHANGELOG_PAGE_ID` (a página `changelog/` do projeto).
262
+
263
+ Após chamar `notion-create-pages`, armazene a URL retornada como `NOTION_URL`.
264
+
265
+ Se `PENDENTE_COMMIT = true`, execute o commit agora com o link incluído:
266
+ ```bash
267
+ git add .
268
+ git commit -m "{tipo}: {MILESTONE_NAME}
269
+
270
+ Notion: {NOTION_URL}"
271
+ ```
272
+
273
+ **Template da página:**
274
+
275
+ ```
276
+ Título: {VERSION} — {MILESTONE_NAME}
277
+ Ícone: 🚀
278
+
279
+ [Callout verde] Entregue em: {DATA} | Requisitos: X/X | Testes: N passando
280
+
281
+ ---
282
+
283
+ # Para o Time de Produto
284
+
285
+ ## O que você consegue fazer agora
286
+ [Para cada feature entregue: 1 parágrafo em linguagem de produto, sem jargão técnico]
287
+ [Se houver UI nova: inclua passo a passo "Como usar"]
288
+
289
+ ---
290
+
291
+ # Para o Time Técnico
292
+
293
+ ## O que mudou no código
294
+ [Tabela: Arquivo | O que mudou]
295
+ [Code snippet do padrão principal implementado, se relevante]
296
+
297
+ ## Decisões Arquiteturais
298
+ [Toggle para cada decisão relevante: contexto + decisão + consequências]
299
+
300
+ ## Dívidas Técnicas Registradas
301
+ [Tabela: Item | Impacto | Quando tratar]
302
+
303
+ ---
304
+
305
+ ## Referências
306
+ - Branch: `{BRANCH}`
307
+ - Tag git: `{VERSION}`
308
+ - Testes: N passando
309
+ - Auditoria: `.planning/{VERSION}-MILESTONE-AUDIT.md`
310
+ ```
311
+
312
+ **Regras de voz:**
313
+ - Seção "Produto": sem nomes de arquivo, sem SQL, sem termos de código. Foco em "antes X, agora Y".
314
+ - Seção "Técnico": arquivos reais, commits, decisões de implementação.
315
+
316
+ ### Passo 4 — Push e PR no GitHub
317
+
318
+ ⚠️ Só execute este passo após ter o `NOTION_URL` do Passo 3.
319
+
320
+ ```bash
321
+ git push origin {BRANCH}
322
+
323
+ gh pr create \
324
+ --title "{VERSION}: {MILESTONE_NAME}" \
325
+ --body "..."
326
+ ```
327
+
328
+ **Template do body do PR:**
329
+
330
+ ```markdown
331
+ ## {VERSION} — {MILESTONE_NAME}
332
+
333
+ ### O que muda
334
+ [3-5 bullet points em linguagem de negócio]
335
+
336
+ ### Cobertura
337
+ - Requisitos: X/X satisfeitos
338
+ - Testes: N passando
339
+ - TypeScript: limpo (0 erros)
340
+
341
+ ### Documentação
342
+ 📄 Notion: {NOTION_URL}
343
+
344
+ ### Como testar
345
+ [Checklist de smoke tests manuais do MILESTONE-AUDIT.md]
346
+ ```
347
+
348
+ **Regras para o PR:**
349
+ - Sem rodapé de assinatura de IA
350
+ - Sem menção a ferramentas ou geradores
351
+ - Linguagem direta, como se fosse escrito pelo dev
352
+
353
+ ### Passo 5 — 📚 Atualizar cofre Obsidian do time
354
+
355
+ ⚠️ **Este passo é "bônus".** Se falhar por qualquer motivo (variável ausente, caminho inválido, conflito Git não-resolvível, push rejeitado após retry), **armazene o motivo em `OBSIDIAN_SKIP_REASON` e prossiga para o Passo 6**. PR e Notion já estão feitos — o dev atualiza o cofre manualmente depois.
356
+
357
+ #### 5.1 — Validar ambiente
358
+
359
+ - Ler `$OBSIDIAN_TEAM_VAULT`.
360
+ - Se a variável não estiver definida:
361
+ > ⚠️ Variável OBSIDIAN_TEAM_VAULT não configurada. Pule para os próximos passos do onboarding no README do cofre.
362
+
363
+ Defina `OBSIDIAN_SKIP_REASON = "OBSIDIAN_TEAM_VAULT não configurada"` e vá para o Passo 6.
364
+ - Se definida mas o caminho não existir (`test -d "$OBSIDIAN_TEAM_VAULT"` falha):
365
+ > ⚠️ Cofre Obsidian não encontrado em: {caminho}. Verifique se o clone local existe.
366
+
367
+ Defina `OBSIDIAN_SKIP_REASON = "Cofre não encontrado em {caminho}"` e vá para o Passo 6.
368
+
369
+ #### 5.2 — Sincronizar com remoto
370
+
371
+ ```bash
372
+ git -C "$OBSIDIAN_TEAM_VAULT" pull --rebase
373
+ ```
374
+
375
+ - Se o `pull --rebase` falhar com conflito, tentar resolução automática:
376
+ ```bash
377
+ git -C "$OBSIDIAN_TEAM_VAULT" rebase --abort 2>/dev/null || true
378
+ git -C "$OBSIDIAN_TEAM_VAULT" pull --rebase -X theirs
379
+ ```
380
+ - Se ainda assim falhar: defina `OBSIDIAN_SKIP_REASON = "Conflito Git no cofre — resolver manualmente"` e vá para o Passo 6.
381
+
382
+ #### 5.3 — Ler CLAUDE.md do cofre
383
+
384
+ Ler `$OBSIDIAN_TEAM_VAULT/CLAUDE.md`. Esse arquivo contém as convenções de documentação do time (nomenclatura, estrutura de pastas, templates, convenções de commit). **As regras vivem lá** — siga o que o CLAUDE.md mandar, não o que este prompt diz de cor.
385
+
386
+ Se o `CLAUDE.md` não existir: defina `OBSIDIAN_SKIP_REASON = "CLAUDE.md ausente no cofre — estrutura desconhecida"` e vá para o Passo 6.
387
+
388
+ #### 5.4 — Criar/atualizar as notas
389
+
390
+ Baseado no contexto do PR que acabou de ser publicado (número, título, arquivos tocados, `MILESTONE_NAME`, `NOTION_URL`):
391
+
392
+ **a) Nota do PR** (obrigatória)
393
+
394
+ Caminho: `01 - PRs/YYYY/YYYY-MM-DD-pr-{PR_NUMBER}-{slug-do-titulo}.md`
395
+
396
+ - `YYYY` / `YYYY-MM-DD` = data do merge/criação do PR.
397
+ - `slug-do-titulo` = título do PR em kebab-case (lowercase, sem acentos, espaços → `-`, sem pontuação).
398
+ - Usar `09 - Templates/template-pr.md` como base.
399
+ - **Frontmatter DEVE conter `notion: {NOTION_URL}`** para ponte bidirecional entre as duas bases.
400
+
401
+ **b) Changelog** (obrigatório)
402
+
403
+ Caminho: `03 - Changelog/YYYY.md`
404
+
405
+ - Adicionar entrada na seção `## Não lançado`, nas subseções apropriadas:
406
+ - `### Adicionado` — features novas
407
+ - `### Alterado` — mudanças de comportamento existente
408
+ - `### Corrigido` — bugs
409
+ - `### Removido` — remoções
410
+ - Cada entrada deve referenciar o número do PR.
411
+
412
+ **c) Notas de componentes/endpoints afetados** (condicional)
413
+
414
+ Se o PR tocar componentes/páginas/endpoints existentes:
415
+ - Localizar a nota correspondente em `05 - Frontend/` e/ou `06 - Backend/`.
416
+ - Atualizar a seção `## Histórico de mudanças` com a data (`YYYY-MM-DD`) e o link do PR.
417
+
418
+ Se o PR introduzir algo **novo**:
419
+ - Criar nova nota em `05 - Frontend/` ou `06 - Backend/` usando `09 - Templates/template-funcionalidade.md`.
420
+
421
+ #### 5.5 — Commit e push
422
+
423
+ ```bash
424
+ cd "$OBSIDIAN_TEAM_VAULT"
425
+ git add .
426
+ git commit -m "docs(pr-{PR_NUMBER}): {título-curto}"
427
+ git push
428
+ ```
429
+
430
+ - Título curto = slug do título do PR truncado em ~60 chars, seguindo convenções de commit do `CLAUDE.md` do cofre.
431
+ - Se o `git push` falhar por divergência:
432
+ ```bash
433
+ git pull --rebase
434
+ git push
435
+ ```
436
+ - Se ainda falhar: defina `OBSIDIAN_SKIP_REASON = "Push rejeitado após rebase — resolver manualmente"` e vá para o Passo 6.
437
+
438
+ #### 5.6 — Capturar link da nota de PR
439
+
440
+ Construir a URL pública da nota no GitHub. Defina o repositório do cofre via env var `OBSIDIAN_VAULT_REPO` (formato `owner/repo`):
441
+
442
+ ```
443
+ OBSIDIAN_URL = https://github.com/${OBSIDIAN_VAULT_REPO}/blob/main/01%20-%20PRs/YYYY/YYYY-MM-DD-pr-{PR_NUMBER}-{slug}.md
444
+ ```
445
+
446
+ Se `OBSIDIAN_VAULT_REPO` não estiver definida, defina `OBSIDIAN_SKIP_REASON = "OBSIDIAN_VAULT_REPO não configurada"` e vá para o Passo 6.
447
+
448
+ - Encode: espaços → `%20`. Barras internas permanecem literais.
449
+ - Armazene como `OBSIDIAN_URL` para uso no Passo 6.
450
+
451
+ ### Passo 6 — Reportar resultado
452
+
453
+ Exiba ao usuário:
454
+
455
+ ```
456
+ ✅ Milestone {VERSION} publicado
457
+
458
+ 📄 Notion: {NOTION_URL}
459
+ 🔗 PR: {PR_URL}
460
+ 📚 Obsidian: {OBSIDIAN_URL}
461
+ 🌿 Branch: {BRANCH}
462
+ ```
463
+
464
+ Se o Passo 5 foi pulado, substitua a linha do Obsidian por:
465
+
466
+ ```
467
+ ⚠️ Obsidian: pulado — {OBSIDIAN_SKIP_REASON}
468
+ ```
469
+
470
+ (mantendo as demais linhas intactas)
471
+
472
+ ## Para outros projetos
473
+
474
+ Copie `.claude/notion-config.json` para o projeto e preencha com os IDs corretos:
475
+
476
+ ```json
477
+ {
478
+ "project": "NomeDoProjeto",
479
+ "notion": {
480
+ "root": "ID_DA_PAGINA_PRINCIPAL",
481
+ "root_url": "https://www.notion.so/...",
482
+ "changelog": "ID_DA_PAGINA_CHANGELOG",
483
+ "features": "ID_DA_PAGINA_FEATURES",
484
+ "adr": "ID_DA_PAGINA_ADR",
485
+ "runbooks": "ID_DA_PAGINA_RUNBOOKS"
486
+ }
487
+ }
488
+ ```
489
+
490
+ Para criar a estrutura de um novo projeto no Notion, execute `/setup-notion`.