codymaster 5.2.0 → 7.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (380) hide show
  1. package/CHANGELOG.md +276 -0
  2. package/README.md +216 -333
  3. package/dist/agent/antigravity.js +152 -0
  4. package/dist/agent/backend.js +2 -0
  5. package/dist/agent/claude.js +196 -0
  6. package/dist/agent/codex.js +204 -0
  7. package/dist/agent/copilot.js +284 -0
  8. package/dist/agent/cursor.js +211 -0
  9. package/dist/agent/factory.js +30 -0
  10. package/dist/agent/gemini.js +142 -0
  11. package/dist/agent/opencode.js +205 -0
  12. package/dist/agent/spawn-helper.js +237 -0
  13. package/dist/agent/version.js +25 -0
  14. package/dist/browse/adapter-factory.js +69 -0
  15. package/dist/browse/adapters/agent-browser-adapter.js +305 -0
  16. package/dist/browse/adapters/playwright-adapter.js +309 -0
  17. package/dist/browse/adapters/types.js +6 -0
  18. package/dist/browse/error-collector.js +132 -0
  19. package/dist/browse/event-log.js +109 -0
  20. package/dist/browse/index.js +17 -0
  21. package/dist/browse-server.js +204 -120
  22. package/dist/cli/command-registry.js +12 -0
  23. package/dist/cli/commands/dashboard.js +76 -2
  24. package/dist/cli/commands/engineering.js +218 -4
  25. package/dist/cli/commands/install.js +160 -0
  26. package/dist/cli/commands/learn.js +181 -0
  27. package/dist/cli/commands/parallel.js +138 -0
  28. package/dist/cli/commands/quality.js +105 -0
  29. package/dist/cli/commands/stack.js +49 -0
  30. package/dist/cli/commands/update.js +159 -0
  31. package/dist/cli/update-check.js +94 -10
  32. package/dist/continuity.js +3 -1
  33. package/dist/dashboard.js +47 -6
  34. package/dist/data.js +35 -0
  35. package/dist/execution/tdd-gate.js +113 -0
  36. package/dist/executor/cancel.js +34 -0
  37. package/dist/executor/gc.js +74 -0
  38. package/dist/executor/index.js +14 -0
  39. package/dist/executor/runner.js +70 -0
  40. package/dist/executor/workdir.js +31 -0
  41. package/dist/handoff/contracts.js +22 -0
  42. package/dist/handoff/index.js +18 -0
  43. package/dist/handoff/io.js +121 -0
  44. package/dist/index.js +7 -3
  45. package/dist/indexer/stack-detect.js +219 -0
  46. package/dist/install/copy.js +98 -0
  47. package/dist/install/engine.js +42 -0
  48. package/dist/install/paths.js +70 -0
  49. package/dist/install/platforms/_simple.js +85 -0
  50. package/dist/install/platforms/antigravity.js +91 -0
  51. package/dist/install/platforms/claude-code.js +107 -0
  52. package/dist/install/platforms/cursor.js +77 -0
  53. package/dist/install/platforms/index.js +27 -0
  54. package/dist/install/platforms/simple.js +163 -0
  55. package/dist/install/profiles.js +75 -0
  56. package/dist/install/types.js +2 -0
  57. package/dist/learnings.js +208 -0
  58. package/dist/mcp-context-server.js +1 -1
  59. package/dist/middleware/metrics.js +30 -0
  60. package/dist/middleware/security-headers.js +14 -0
  61. package/dist/realtime/event-bus.js +29 -0
  62. package/dist/realtime/ws-hub.js +91 -0
  63. package/dist/schemas/task-schema.js +48 -0
  64. package/dist/schemas/validate.js +18 -0
  65. package/dist/skills-lock.js +96 -0
  66. package/dist/sprint-pipeline.js +26 -0
  67. package/dist/storage/index.js +21 -0
  68. package/dist/storage/repos/activity-repo.js +46 -0
  69. package/dist/storage/repos/message-repo.js +39 -0
  70. package/dist/storage/repos/project-repo.js +56 -0
  71. package/dist/storage/repos/task-repo.js +142 -0
  72. package/dist/storage/services/project-service.js +49 -0
  73. package/dist/storage/services/task-service.js +97 -0
  74. package/dist/storage/sqlite.js +113 -0
  75. package/dist/tier-classify.js +131 -0
  76. package/dist/ui/onboarding.js +51 -15
  77. package/dist/utils/cli-utils.js +7 -2
  78. package/dist/utils/design-taste.js +108 -0
  79. package/dist/utils/output-compress.js +143 -0
  80. package/dist/vibecoding-index.js +126 -0
  81. package/package.json +27 -4
  82. package/public/dashboard/app.js +52 -1
  83. package/scripts/build-skills-lock.mjs +88 -0
  84. package/scripts/build-skills.mjs +187 -28
  85. package/scripts/compress-skill.mjs +73 -0
  86. package/scripts/deprecate-skill.mjs +72 -0
  87. package/scripts/install.sh +170 -0
  88. package/scripts/mcp-bridge.js +2 -2
  89. package/scripts/postinstall.js +54 -287
  90. package/scripts/release.sh +126 -0
  91. package/scripts/update-changelog.sh +88 -0
  92. package/scripts/validate-skills.mjs +101 -4
  93. package/skills/_shared/SKILL_TEMPLATE.md +62 -0
  94. package/skills/cm-autopilot/scripts/autopilot.py +19 -2
  95. package/skills/cm-brainstorm-idea/SKILL.md +9 -0
  96. package/skills/cm-clean-code/SKILL.md +20 -0
  97. package/skills/cm-code-review/SKILL.md +21 -0
  98. package/skills/cm-codeintell/SKILL.md +9 -0
  99. package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
  100. package/skills/cm-conductor-worktrees/SKILL.md +17 -19
  101. package/skills/cm-continuity/SKILL.md +9 -0
  102. package/skills/cm-dashboard/SKILL.archive.md +15 -0
  103. package/skills/cm-dashboard/SKILL.md +20 -9
  104. package/skills/cm-dashboard/ui/app.js +9 -1
  105. package/skills/cm-debugging/SKILL.md +9 -0
  106. package/skills/cm-design-studio/SKILL.archive.md +34 -0
  107. package/skills/cm-design-studio/SKILL.md +17 -25
  108. package/skills/cm-design-system/SKILL.md +1 -0
  109. package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
  110. package/skills/cm-engineering-meta/SKILL.md +16 -63
  111. package/skills/cm-execution/SKILL.md +98 -0
  112. package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
  113. package/skills/cm-git-worktrees/SKILL.md +15 -146
  114. package/skills/cm-identity-guard/SKILL.md +8 -0
  115. package/skills/cm-planning/SKILL.md +63 -92
  116. package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
  117. package/skills/cm-post-deploy-canary/SKILL.md +17 -13
  118. package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
  119. package/skills/cm-qa-visual-cli/SKILL.md +16 -12
  120. package/skills/cm-quality-gate/SKILL.md +38 -0
  121. package/skills/cm-safe-deploy/SKILL.md +9 -0
  122. package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
  123. package/skills/cm-second-opinion-cli/SKILL.md +17 -14
  124. package/skills/cm-secret-shield/SKILL.archive.md +580 -0
  125. package/skills/cm-secret-shield/SKILL.md +15 -569
  126. package/skills/cm-security-gate/SKILL.archive.md +239 -0
  127. package/skills/cm-security-gate/SKILL.md +15 -228
  128. package/skills/cm-skill-health/SKILL.archive.md +83 -0
  129. package/skills/cm-skill-health/SKILL.md +16 -73
  130. package/skills/cm-skill-index/SKILL.md +8 -0
  131. package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
  132. package/skills/cm-skill-mastery/SKILL.md +16 -146
  133. package/skills/cm-skill-search/SKILL.archive.md +49 -0
  134. package/skills/cm-skill-search/SKILL.md +17 -40
  135. package/skills/cm-skill-share/SKILL.archive.md +58 -0
  136. package/skills/cm-skill-share/SKILL.md +17 -49
  137. package/skills/cm-sprint-bus/SKILL.md +9 -0
  138. package/skills/cm-start/SKILL.md +17 -0
  139. package/skills/cm-tdd/SKILL.md +19 -0
  140. package/skills/cm-terminal/SKILL.md +15 -0
  141. package/skills/cm-test-gate/SKILL.archive.md +245 -0
  142. package/skills/cm-test-gate/SKILL.md +15 -234
  143. package/skills/cm-ui-preview/SKILL.archive.md +153 -0
  144. package/skills/cm-ui-preview/SKILL.md +16 -143
  145. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
  146. package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
  147. package/skills/cm-ux-master/mcp/server.py +2 -2
  148. package/skills/profiles/design.txt +1 -1
  149. package/skills/profiles/full.txt +0 -10
  150. package/skills/profiles/growth.txt +8 -8
  151. package/skills/profiles/knowledge.txt +1 -1
  152. package/skills/profiles/top35.json +41 -0
  153. package/adapters/antigravity.js +0 -15
  154. package/adapters/claude-code.js +0 -17
  155. package/adapters/cursor.js +0 -16
  156. package/skills/cm-ads-tracker/SKILL.md +0 -401
  157. package/skills/cm-ads-tracker/evals/evals.json +0 -55
  158. package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
  159. package/skills/cm-ads-tracker/references/industry-events.md +0 -294
  160. package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
  161. package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
  162. package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
  163. package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
  164. package/skills/cm-auto-publisher/SKILL.md +0 -81
  165. package/skills/cm-booking-calendar/SKILL.md +0 -521
  166. package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
  167. package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
  168. package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
  169. package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
  170. package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
  171. package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
  172. package/skills/cm-content-factory/.content-factory-state.json +0 -132
  173. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
  174. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
  175. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  176. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  177. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  178. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  179. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  180. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  181. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  182. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  183. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  184. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  185. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  186. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  187. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  188. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  189. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  190. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  191. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  192. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  193. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  194. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  195. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  196. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  197. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  198. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  199. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  200. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  201. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  202. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  203. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  204. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  205. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  206. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  207. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  208. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  209. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  210. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  211. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  212. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  213. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  214. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  215. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  216. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  217. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  218. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
  219. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  220. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  221. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  222. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  223. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  224. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  225. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  226. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  227. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  228. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  229. package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
  230. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
  231. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
  232. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
  233. package/skills/cm-content-factory/AGENTS.md +0 -61
  234. package/skills/cm-content-factory/CLAUDE.md +0 -63
  235. package/skills/cm-content-factory/CURSOR.md +0 -43
  236. package/skills/cm-content-factory/Content Factory.zip +0 -0
  237. package/skills/cm-content-factory/SKILL.md +0 -416
  238. package/skills/cm-content-factory/cf +0 -313
  239. package/skills/cm-content-factory/config.schema.json +0 -397
  240. package/skills/cm-content-factory/dashboard/app.js +0 -556
  241. package/skills/cm-content-factory/dashboard/index.html +0 -397
  242. package/skills/cm-content-factory/dashboard/style.css +0 -1211
  243. package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
  244. package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
  245. package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
  246. package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
  247. package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
  248. package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
  249. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
  250. package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
  251. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
  252. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
  253. package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
  254. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
  255. package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
  256. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
  257. package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
  258. package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
  259. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
  260. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
  261. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
  262. package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
  263. package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
  264. package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
  265. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
  266. package/skills/cm-content-factory/extensions/hooks.py +0 -126
  267. package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
  268. package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
  269. package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
  270. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
  271. package/skills/cm-content-factory/landing/docs/content/memory-system.md +0 -38
  272. package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
  273. package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
  274. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
  275. package/skills/cm-content-factory/landing/docs/index.html +0 -240
  276. package/skills/cm-content-factory/landing/index.html +0 -680
  277. package/skills/cm-content-factory/landing/script.js +0 -143
  278. package/skills/cm-content-factory/landing/style.css +0 -1216
  279. package/skills/cm-content-factory/landing/translations.js +0 -508
  280. package/skills/cm-content-factory/logs/events.jsonl +0 -11
  281. package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
  282. package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
  283. package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
  284. package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
  285. package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
  286. package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
  287. package/skills/cm-content-factory/scripts/audit.py +0 -106
  288. package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
  289. package/skills/cm-content-factory/scripts/deploy.py +0 -146
  290. package/skills/cm-content-factory/scripts/extract.py +0 -132
  291. package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
  292. package/skills/cm-content-factory/scripts/memory.py +0 -521
  293. package/skills/cm-content-factory/scripts/monetize.py +0 -239
  294. package/skills/cm-content-factory/scripts/pipeline.py +0 -357
  295. package/skills/cm-content-factory/scripts/plan.py +0 -163
  296. package/skills/cm-content-factory/scripts/publish.py +0 -145
  297. package/skills/cm-content-factory/scripts/research.py +0 -337
  298. package/skills/cm-content-factory/scripts/scaffold.py +0 -464
  299. package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
  300. package/skills/cm-content-factory/scripts/seo.py +0 -90
  301. package/skills/cm-content-factory/scripts/state_manager.py +0 -320
  302. package/skills/cm-content-factory/scripts/token_manager.py +0 -268
  303. package/skills/cm-content-factory/scripts/validate.py +0 -221
  304. package/skills/cm-content-factory/scripts/wizard.py +0 -329
  305. package/skills/cm-content-factory/scripts/write.py +0 -93
  306. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  307. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
  308. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
  309. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
  310. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
  311. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
  312. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
  313. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
  314. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
  315. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
  316. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
  317. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
  318. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
  319. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
  320. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
  321. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
  322. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
  323. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
  324. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
  325. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
  326. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
  327. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
  328. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
  329. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
  330. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
  331. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
  332. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
  333. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
  334. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
  335. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
  336. package/skills/cm-content-factory/tests/conftest.py +0 -66
  337. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
  338. package/skills/cm-content-factory/tests/test_memory.py +0 -128
  339. package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
  340. package/skills/cm-content-factory/tests/test_research.py +0 -56
  341. package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
  342. package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
  343. package/skills/cm-content-factory/tests/test_wizard.py +0 -121
  344. package/skills/cm-cro-methodology/SKILL.md +0 -290
  345. package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
  346. package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
  347. package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
  348. package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
  349. package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
  350. package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
  351. package/skills/cm-google-form/SKILL.md +0 -266
  352. package/skills/cm-google-form/templates/apps-script.js +0 -55
  353. package/skills/cm-google-form/templates/form-markup.html +0 -110
  354. package/skills/cm-google-form/templates/form-submit.js +0 -201
  355. package/skills/cm-google-form/templates/toast.css +0 -152
  356. package/skills/cm-growth-hacking/SKILL.md +0 -282
  357. package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
  358. package/skills/cm-growth-hacking/calendar-integration.md +0 -264
  359. package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
  360. package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
  361. package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
  362. package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
  363. package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
  364. package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
  365. package/skills/cm-growth-hacking/tracking-events.md +0 -246
  366. package/skills/cm-growth-hacking/trigger-system.md +0 -342
  367. package/skills/cm-jtbd/SKILL.md +0 -98
  368. package/skills/cm-notebooklm/SKILL.md +0 -156
  369. package/skills/cm-notebooklm/references/command_reference.md +0 -94
  370. package/skills/cm-notebooklm/references/workflows.md +0 -60
  371. package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
  372. package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
  373. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
  374. package/skills/cm-readit/SKILL.md +0 -289
  375. package/skills/cm-readit/audio-player.md +0 -206
  376. package/skills/cm-readit/examples/blog-reader.js +0 -352
  377. package/skills/cm-readit/examples/voice-cro.js +0 -390
  378. package/skills/cm-readit/tts-engine.md +0 -262
  379. package/skills/cm-readit/ui-patterns.md +0 -362
  380. package/skills/cm-readit/voice-cro.md +0 -223
@@ -0,0 +1,580 @@
1
+ ---
2
+ name: cm-secret-shield
3
+ description: "Defense-in-depth security for AI-assisted development. Pre-commit secret scanning (Gitleaks + native fallback), repo-wide pattern detection, token lifecycle management, and AI agent safety rules. Prevents secret leaks at every stage: write → commit → push → deploy. Use BEFORE any git push or deploy, or when setting up new projects."
4
+ ---
5
+
6
+ # 🛡️ Secret Shield — Defense-in-Depth Security
7
+
8
+ > **Secrets leak at FIVE stages. Guard ALL five.**
9
+ > Write → Commit → Push → Deploy → Runtime
10
+ > One missed stage = one leaked key = one compromised system.
11
+
12
+ ## The Iron Laws
13
+
14
+ ```
15
+ NEVER commit secrets. EVER.
16
+ NEVER output secrets in logs, chat, or AI responses.
17
+ NEVER trust .gitignore alone — it doesn't protect git history.
18
+ PRE-COMMIT HOOKS are your FIRST line of defense.
19
+ ROTATION is not optional after a leak.
20
+ ```
21
+
22
+ ## When to Use
23
+
24
+ **ALWAYS** when:
25
+ - Setting up a new project (called by `cm-project-bootstrap` Phase 0.5)
26
+ - Before first `git push` on any project
27
+ - After discovering a potential secret leak
28
+ - Setting up CI/CD pipelines
29
+ - Reviewing security posture of existing projects
30
+ - User says: "check secrets", "security audit", "leaked key", "rotate token"
31
+
32
+ **Integrates with:**
33
+ - `cm-project-bootstrap` — Security Foundation phase
34
+ - `cm-safe-deploy` — Gate 0 enhanced secret hygiene
35
+ - `cm-test-gate` — Layer 5 security scan
36
+ - `cm-identity-guard` — Token lifecycle management
37
+
38
+ ---
39
+
40
+ ## The 5 Defense Layers
41
+
42
+ ```
43
+ ┌─────────────────────────────────────────────────────────┐
44
+ │ Layer 1: WRITE GUARD — AI agent behavior rules │
45
+ │ Layer 2: PRE-COMMIT GUARD — Block secrets at commit │
46
+ │ Layer 3: REPO SCAN — Full repo pattern check │
47
+ │ Layer 4: DEPLOY GATE — Pre-deploy secret audit │
48
+ │ Layer 5: RUNTIME GUARD — Env var hygiene & rotation│
49
+ └─────────────────────────────────────────────────────────┘
50
+ ```
51
+
52
+ ---
53
+
54
+ ## Layer 1: Write Guard — AI Agent Safety Rules
55
+
56
+ > **Goal:** Prevent the AI agent itself from introducing secrets into code.
57
+
58
+ ### Rules for AI Agents
59
+
60
+ ```
61
+ ✅ DO:
62
+ - Use environment variables: process.env.SECRET_KEY
63
+ - Use .dev.vars for local development
64
+ - Use platform-specific secret stores: wrangler secret put, Supabase vault
65
+ - Mask secrets in logs: console.log('Key:', key.slice(0,4) + '***')
66
+ - Reference secret NAMES, not VALUES
67
+
68
+ ❌ NEVER:
69
+ - Hardcode API keys, tokens, or passwords in source code
70
+ - Put secrets in wrangler.jsonc, package.json, or any tracked file
71
+ - Output full secret values in chat, logs, or error messages
72
+ - Use placeholder secrets that look real (e.g., sk-1234567890abcdef)
73
+ - Store secrets in i18n files, README, or documentation
74
+ ```
75
+
76
+ ### Secret Patterns to NEVER Generate
77
+
78
+ ```javascript
79
+ // ❌ NEVER write code like this:
80
+ const API_KEY = "sk-proj-abc123def456ghi789";
81
+ const SUPABASE_KEY = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...";
82
+ const DB_PASSWORD = "<YOUR_SECURE_PASSWORD>";
83
+ fetch('https://api.example.com', { headers: { Authorization: 'Bearer <YOUR_TOKEN>' } });
84
+
85
+ // ✅ ALWAYS write code like this:
86
+ const API_KEY = process.env.API_KEY;
87
+ const SUPABASE_KEY = process.env.SUPABASE_ANON_KEY;
88
+ // For Cloudflare Workers:
89
+ export default { async fetch(req, env) { const key = env.API_KEY; } };
90
+ ```
91
+
92
+ ---
93
+
94
+ ## Layer 2: Pre-Commit Guard — Block Secrets at Commit
95
+
96
+ > **Goal:** Automatically scan staged files BEFORE they enter git history.
97
+
98
+ ### Option A: Gitleaks (Recommended — Industry Standard)
99
+
100
+ #### Step 1: Install Gitleaks
101
+
102
+ ```bash
103
+ # macOS
104
+ brew install gitleaks
105
+
106
+ # Linux
107
+ # Download from https://github.com/gitleaks/gitleaks/releases
108
+
109
+ # Verify installation
110
+ gitleaks version
111
+ ```
112
+
113
+ #### Step 2: Create `.gitleaks.toml` (Project Root)
114
+
115
+ ```toml
116
+ # .gitleaks.toml — Cody Master Secret Shield Configuration
117
+ title = "CM Secret Shield — Gitleaks Config"
118
+
119
+ # Extend default rules (catches 100+ known patterns)
120
+ [extend]
121
+ useDefault = true
122
+
123
+ # Custom rules for Cody Master projects
124
+ [[rules]]
125
+ id = "supabase-service-key"
126
+ description = "Supabase Service Role Key"
127
+ regex = '''eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9\.[a-zA-Z0-9_-]+\.[a-zA-Z0-9_-]+'''
128
+ tags = ["supabase", "jwt"]
129
+
130
+ [[rules]]
131
+ id = "cloudflare-api-token"
132
+ description = "Cloudflare API Token"
133
+ regex = '''[A-Za-z0-9_-]{40}'''
134
+ entropy = 4.5
135
+ secretGroup = 0
136
+ tags = ["cloudflare"]
137
+
138
+ [[rules]]
139
+ id = "generic-high-entropy"
140
+ description = "High entropy string that may be a secret"
141
+ regex = '''(?i)(api[_-]?key|secret[_-]?key|access[_-]?token|private[_-]?key|auth[_-]?token)\s*[=:]\s*['"][a-zA-Z0-9/+=]{20,}['"]'''
142
+ tags = ["generic"]
143
+
144
+ # Allow patterns (reduce false positives)
145
+ [allowlist]
146
+ paths = [
147
+ '''\.gitleaks\.toml$''',
148
+ '''\.dev\.vars\.example$''',
149
+ '''node_modules/''',
150
+ '''dist/''',
151
+ '''\.git/'''
152
+ ]
153
+ ```
154
+
155
+ #### Step 3: Setup Git Pre-Commit Hook
156
+
157
+ ```bash
158
+ # Create the hook
159
+ cat > .git/hooks/pre-commit << 'EOF'
160
+ #!/bin/bash
161
+ # CM Secret Shield — Pre-Commit Guard
162
+ # Scans staged files for secrets before allowing commit
163
+
164
+ echo "🛡️ Secret Shield: scanning staged files..."
165
+
166
+ # Check if gitleaks is installed
167
+ if command -v gitleaks >/dev/null 2>&1; then
168
+ gitleaks git --pre-commit --staged --verbose
169
+ if [ $? -ne 0 ]; then
170
+ echo ""
171
+ echo "❌ SECRET DETECTED! Commit blocked."
172
+ echo ""
173
+ echo "To fix:"
174
+ echo " 1. Remove the secret from your code"
175
+ echo " 2. Use environment variables instead"
176
+ echo " 3. If false positive: add to .gitleaks.toml allowlist"
177
+ echo ""
178
+ echo "To bypass (DANGEROUS): git commit --no-verify"
179
+ exit 1
180
+ fi
181
+ echo "✅ Secret Shield: no secrets detected"
182
+ else
183
+ # Fallback: basic pattern check without gitleaks
184
+ echo "⚠️ Gitleaks not installed. Running basic checks..."
185
+ STAGED=$(git diff --cached --name-only --diff-filter=ACM)
186
+ PATTERNS="SERVICE_KEY|ANON_KEY|PRIVATE_KEY|DB_PASSWORD|SECRET_KEY|API_SECRET|sk-[a-zA-Z0-9]{20,}|-----BEGIN.*KEY-----"
187
+
188
+ for file in $STAGED; do
189
+ if echo "$file" | grep -qE '\.(js|ts|jsx|tsx|json|toml|yaml|yml|env|cfg|conf|ini)$'; then
190
+ if git diff --cached "$file" | grep -qE "$PATTERNS"; then
191
+ echo "❌ Potential secret found in: $file"
192
+ echo " Run: git diff --cached $file | grep -E '$PATTERNS'"
193
+ exit 1
194
+ fi
195
+ fi
196
+ done
197
+ echo "✅ Basic check passed (install gitleaks for deeper scanning)"
198
+ fi
199
+ EOF
200
+
201
+ chmod +x .git/hooks/pre-commit
202
+ echo "✅ Pre-commit hook installed"
203
+ ```
204
+
205
+ ### Option B: Native Git Hook Only (No Dependencies)
206
+
207
+ For projects that can't install Gitleaks, the basic pattern check in the hook above works as a fallback.
208
+
209
+ ---
210
+
211
+ ## Layer 3: Repo Scan — Full Repository Audit
212
+
213
+ > **Goal:** Scan the entire repository for secrets that may have been committed before the pre-commit hook was set up.
214
+
215
+ ### Quick Scan Script
216
+
217
+ ```bash
218
+ # scripts/security-scan.js — Repo-wide secret detection
219
+ node -e "
220
+ const fs = require('fs');
221
+ const path = require('path');
222
+
223
+ const DANGEROUS_PATTERNS = [
224
+ { name: 'Service Key Variable', regex: /(?:SERVICE_KEY|SERVICE_ROLE)\s*[=:]\s*['\"][a-zA-Z0-9._\/-]{20,}/g },
225
+ { name: 'Anon Key Variable', regex: /ANON_KEY\s*[=:]\s*['\"][a-zA-Z0-9._\/-]{20,}/g },
226
+ { name: 'Private Key Block', regex: /-----BEGIN\s+(RSA|EC|DSA|OPENSSH)?\s*PRIVATE KEY-----/g },
227
+ { name: 'JWT Token', regex: /eyJ[a-zA-Z0-9_-]{10,}\.[a-zA-Z0-9_-]{10,}\.[a-zA-Z0-9_-]{10,}/g },
228
+ { name: 'Generic API Key', regex: /(?:api[_-]?key|api[_-]?secret|access[_-]?token)\s*[=:]\s*['\"][a-zA-Z0-9\/+=]{20,}['\"/]/gi },
229
+ { name: 'AWS Key', regex: /AKIA[0-9A-Z]{16}/g },
230
+ { name: 'Slack Token', regex: /xox[baprs]-[0-9a-zA-Z-]{10,}/g },
231
+ { name: 'GitHub Token', regex: /gh[ps]_[a-zA-Z0-9]{36,}/g },
232
+ { name: 'Stripe Key', regex: /[sr]k_(test|live)_[a-zA-Z0-9]{20,}/g },
233
+ { name: 'DB Password', regex: /(?:DB_PASSWORD|DATABASE_URL)\s*[=:]\s*['\"][^'\"]{8,}/gi },
234
+ ];
235
+
236
+ const SKIP_DIRS = ['node_modules', '.git', 'dist', '.wrangler', '.next', 'coverage'];
237
+ const SCAN_EXTS = ['.js', '.ts', '.jsx', '.tsx', '.json', '.toml', '.yaml', '.yml',
238
+ '.env', '.cfg', '.conf', '.ini', '.md', '.html', '.jsonc'];
239
+
240
+ let findings = [];
241
+
242
+ function scanDir(dir) {
243
+ try {
244
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
245
+ for (const entry of entries) {
246
+ if (SKIP_DIRS.includes(entry.name)) continue;
247
+ const fullPath = path.join(dir, entry.name);
248
+ if (entry.isDirectory()) {
249
+ scanDir(fullPath);
250
+ } else if (entry.isFile() && SCAN_EXTS.some(ext => entry.name.endsWith(ext))) {
251
+ const content = fs.readFileSync(fullPath, 'utf-8');
252
+ for (const pattern of DANGEROUS_PATTERNS) {
253
+ const matches = content.match(pattern.regex);
254
+ if (matches) {
255
+ findings.push({ file: fullPath, pattern: pattern.name, count: matches.length });
256
+ }
257
+ }
258
+ }
259
+ }
260
+ } catch (e) { /* skip unreadable dirs */ }
261
+ }
262
+
263
+ scanDir('.');
264
+
265
+ if (findings.length > 0) {
266
+ console.error('❌ SECRET SCAN FOUND ' + findings.length + ' POTENTIAL ISSUES:');
267
+ findings.forEach(f => {
268
+ console.error(' ⚠ ' + f.file + ' — ' + f.pattern + ' (' + f.count + ' match(es))');
269
+ });
270
+ console.error('');
271
+ console.error('Actions:');
272
+ console.error(' 1. Review each finding — some may be false positives');
273
+ console.error(' 2. Move real secrets to .dev.vars (local) or platform secrets (production)');
274
+ console.error(' 3. If secret was committed, rotate it IMMEDIATELY');
275
+ process.exit(1);
276
+ } else {
277
+ console.log('✅ Repo scan: no secrets detected in ' + SCAN_EXTS.length + ' file types');
278
+ }
279
+ "
280
+ ```
281
+
282
+ ### Add to package.json
283
+
284
+ ```json
285
+ {
286
+ "scripts": {
287
+ "security:scan": "node scripts/security-scan.js",
288
+ "security:precommit": "gitleaks git --pre-commit --staged || echo 'Install gitleaks for deep scan'"
289
+ }
290
+ }
291
+ ```
292
+
293
+ ---
294
+
295
+ ## Layer 4: Deploy Gate — Pre-Deploy Secret Audit
296
+
297
+ > **Goal:** Final check before code leaves the machine. Integrated with `cm-safe-deploy` Gate 0.
298
+
299
+ ### Enhanced Gate 0 Check
300
+
301
+ ```bash
302
+ # Run BEFORE deploy — catches what pre-commit might have missed
303
+ node -e "
304
+ const fs = require('fs');
305
+
306
+ // 1. Check tracked files for secrets
307
+ const dangerous = ['SERVICE_KEY', 'ANON_KEY', 'DB_PASSWORD', 'SECRET_KEY',
308
+ 'PRIVATE_KEY', 'API_SECRET', 'AUTH_TOKEN'];
309
+
310
+ const filesToCheck = [
311
+ 'wrangler.jsonc', 'wrangler.toml', 'wrangler.json',
312
+ 'package.json', 'tsconfig.json',
313
+ ...fs.readdirSync('src').filter(f => f.endsWith('.ts') || f.endsWith('.js')).map(f => 'src/' + f)
314
+ ].filter(f => fs.existsSync(f));
315
+
316
+ let failed = false;
317
+
318
+ for (const file of filesToCheck) {
319
+ const content = fs.readFileSync(file, 'utf-8');
320
+ for (const key of dangerous) {
321
+ // Check for actual values (not just variable names)
322
+ const valuePattern = new RegExp(key + '\\\\s*[=:]\\\\s*[\"\\'][a-zA-Z0-9/+=]{20,}', 'g');
323
+ if (valuePattern.test(content)) {
324
+ console.error('❌ DANGER: ' + file + ' contains a ' + key + ' VALUE');
325
+ failed = true;
326
+ }
327
+ }
328
+ }
329
+
330
+ // 2. Check .gitignore has required patterns
331
+ if (fs.existsSync('.gitignore')) {
332
+ const gitignore = fs.readFileSync('.gitignore', 'utf-8');
333
+ const required = ['.env', '.dev.vars'];
334
+ const missing = required.filter(r => !gitignore.includes(r));
335
+ if (missing.length > 0) {
336
+ console.error('❌ .gitignore missing: ' + missing.join(', '));
337
+ failed = true;
338
+ }
339
+ }
340
+
341
+ // 3. Check .env files aren't tracked
342
+ const { execSync } = require('child_process');
343
+ try {
344
+ const tracked = execSync('git ls-files', { encoding: 'utf-8' });
345
+ const badFiles = ['.env', '.dev.vars', '.env.local', '.env.production'];
346
+ const trackedBad = badFiles.filter(f => tracked.split('\\n').includes(f));
347
+ if (trackedBad.length > 0) {
348
+ console.error('❌ CRITICAL: Secret files tracked by git: ' + trackedBad.join(', '));
349
+ console.error(' Fix: git rm --cached ' + trackedBad.join(' '));
350
+ failed = true;
351
+ }
352
+ } catch (e) { /* not a git repo */ }
353
+
354
+ if (failed) {
355
+ console.error('\\n🛡️ Secret Shield: Deploy blocked. Fix issues above.');
356
+ process.exit(1);
357
+ }
358
+ console.log('✅ Secret Shield: deploy gate passed');
359
+ "
360
+ ```
361
+
362
+ ---
363
+
364
+ ## Layer 5: Runtime Guard — Token Lifecycle Management
365
+
366
+ > **Goal:** Manage secrets throughout their lifecycle — creation, usage, rotation, revocation.
367
+
368
+ ### Token Rotation Schedule
369
+
370
+ | Platform | Token Type | Max Lifetime | Rotation Trigger |
371
+ |----------|-----------|-------------|-----------------|
372
+ | **Supabase** | `anon_key` | 90 days | Dashboard → Settings → API |
373
+ | **Supabase** | `service_role_key` | 30 days | Dashboard → Settings → API |
374
+ | **Cloudflare** | API Token | 90 days | Dashboard → My Profile → API Tokens |
375
+ | **GitHub** | Personal Access Token | 90 days | Settings → Developer Settings → PAT |
376
+ | **GitHub** | Fine-grained Token | 30-90 days | Use expiring tokens when possible |
377
+ | **OpenAI/Gemini** | API Key | 90 days | Rotate in platform dashboard |
378
+
379
+ ### Secret Lifecycle File
380
+
381
+ Track secrets in `.secret-lifecycle.json` (add to `.gitignore`!):
382
+
383
+ ```json
384
+ {
385
+ "_WARNING": "This file tracks secret metadata ONLY. NEVER put actual values here.",
386
+ "secrets": [
387
+ {
388
+ "name": "SUPABASE_ANON_KEY",
389
+ "platform": "supabase",
390
+ "store": "cloudflare-secrets",
391
+ "createdAt": "2026-03-01",
392
+ "rotateBy": "2026-06-01",
393
+ "lastRotated": "2026-03-01",
394
+ "status": "active"
395
+ },
396
+ {
397
+ "name": "SUPABASE_SERVICE_KEY",
398
+ "platform": "supabase",
399
+ "store": "cloudflare-secrets",
400
+ "createdAt": "2026-03-01",
401
+ "rotateBy": "2026-04-01",
402
+ "lastRotated": "2026-03-01",
403
+ "status": "active"
404
+ }
405
+ ]
406
+ }
407
+ ```
408
+
409
+ ### Emergency Rotation Playbook
410
+
411
+ When a secret is leaked, follow this sequence **immediately**:
412
+
413
+ ```
414
+ ┌─────────────────────────────────────────────────────┐
415
+ │ 1. REVOKE — Disable the old key in platform dashboard│
416
+ │ 2. ROTATE — Generate a new key │
417
+ │ 3. UPDATE — Push new key to secret store │
418
+ │ 4. DEPLOY — Redeploy affected services │
419
+ │ 5. SCAN — Check git history for the old key │
420
+ │ 6. SCRUB — Remove from git history if needed │
421
+ │ 7. AUDIT — Review access logs for unauthorized use │
422
+ └─────────────────────────────────────────────────────┘
423
+ ```
424
+
425
+ #### Per-Platform Rotation Commands
426
+
427
+ **Supabase:**
428
+ ```bash
429
+ # 1. Go to Supabase Dashboard → Project Settings → API
430
+ # 2. Click "Regenerate" on the compromised key
431
+ # 3. Update Cloudflare Secrets:
432
+ wrangler secret put SUPABASE_ANON_KEY # Paste new value
433
+ wrangler secret put SUPABASE_SERVICE_KEY # Paste new value
434
+ # 4. Update local .dev.vars with new values
435
+ # 5. Redeploy
436
+ npm run deploy:staging
437
+ ```
438
+
439
+ **Cloudflare API Token:**
440
+ ```bash
441
+ # 1. Dashboard → My Profile → API Tokens → Roll
442
+ # 2. Update any CI/CD systems using this token
443
+ # 3. Verify with: wrangler whoami
444
+ ```
445
+
446
+ **GitHub Token:**
447
+ ```bash
448
+ # 1. Settings → Developer Settings → PAT → Regenerate
449
+ # 2. Update gh auth: gh auth login
450
+ # 3. Verify: gh auth status
451
+ ```
452
+
453
+ ---
454
+
455
+ ## Security Audit Checklist
456
+
457
+ Run this checklist for any project to assess its security posture:
458
+
459
+ ```markdown
460
+ ## 🛡️ Secret Shield Audit
461
+
462
+ ### Layer 1: Write Guard
463
+ - [ ] No hardcoded secrets in source files
464
+ - [ ] Environment variables used for all secrets
465
+ - [ ] .dev.vars exists with local secrets (not committed)
466
+ - [ ] .dev.vars.example exists with placeholder names (committed)
467
+
468
+ ### Layer 2: Pre-Commit Guard
469
+ - [ ] .git/hooks/pre-commit exists and is executable
470
+ - [ ] Gitleaks installed OR native fallback hook active
471
+ - [ ] .gitleaks.toml configured for project
472
+
473
+ ### Layer 3: Repo Scan
474
+ - [ ] `npm run security:scan` passes clean
475
+ - [ ] No JWT tokens in tracked files
476
+ - [ ] No API keys in configuration files
477
+ - [ ] No private keys in repository
478
+
479
+ ### Layer 4: Deploy Gate
480
+ - [ ] Gate 0 checks ALL source files (not just wrangler.jsonc)
481
+ - [ ] .gitignore includes: .env, .dev.vars, .env.local, .env.production
482
+ - [ ] No .env files tracked by git
483
+ - [ ] Cloudflare Secrets used for production values
484
+
485
+ ### Layer 5: Runtime Guard
486
+ - [ ] .secret-lifecycle.json tracks all secrets (metadata only)
487
+ - [ ] No secrets past rotation deadline
488
+ - [ ] Emergency rotation playbook known by team
489
+ - [ ] Post-incident: keys rotated, history scrubbed
490
+ ```
491
+
492
+ ---
493
+
494
+ ## Hardened .gitignore Template
495
+
496
+ Every project using Secret Shield should have AT MINIMUM these patterns:
497
+
498
+ ```gitignore
499
+ # === Secret Shield: Mandatory Ignores ===
500
+
501
+ # Environment & secret files
502
+ .env
503
+ .env.*
504
+ !.env.example
505
+ !.env.test
506
+ .dev.vars
507
+ !.dev.vars.example
508
+
509
+ # Secret lifecycle tracking (contains metadata, not values)
510
+ .secret-lifecycle.json
511
+
512
+ # Platform-specific
513
+ .wrangler/
514
+ *.pem
515
+ *.key
516
+ *.p12
517
+ *.pfx
518
+
519
+ # OS artifacts
520
+ .DS_Store
521
+ Thumbs.db
522
+
523
+ # Dependencies
524
+ node_modules/
525
+
526
+ # Build output
527
+ dist/
528
+ build/
529
+ .next/
530
+ .nuxt/
531
+
532
+ # IDE
533
+ .vscode/settings.json
534
+ .idea/
535
+ ```
536
+
537
+ ---
538
+
539
+ ## Red Flags — STOP
540
+
541
+ | Thought | Reality |
542
+ |---------|---------|
543
+ | "It's just a dev key" | Dev keys have the same permissions as prod keys |
544
+ | ".gitignore will protect me" | It can't remove what's already in git history |
545
+ | "I'll rotate it later" | Later = never. Rotate NOW. |
546
+ | "It was only exposed briefly" | Bots scan GitHub in real-time for leaked keys |
547
+ | "This is a private repo" | Private doesn't mean secured. Colleagues, CI, forks all have access |
548
+ | "The pre-commit hook is annoying" | 3-second scan vs. hours of incident response |
549
+ | "I'll add --no-verify just this once" | That "once" is when the leak happens |
550
+
551
+ ---
552
+
553
+ ## Integration
554
+
555
+ | Skill | Relationship |
556
+ |-------|-------------|
557
+ | `cm-project-bootstrap` | Phase 0.5 calls Secret Shield for initial security setup |
558
+ | `cm-safe-deploy` | Gate 0 uses Layer 4 enhanced secret audit |
559
+ | `cm-test-gate` | Layer 5 security test uses Layer 3 patterns |
560
+ | `cm-identity-guard` | Layer 5 token rotation extends identity lifecycle |
561
+ | `cm-quality-gate` | Secret shield is a prerequisite gate |
562
+
563
+ ### Lifecycle Position
564
+
565
+ ```
566
+ cm-project-bootstrap → cm-secret-shield (setup) → development cycle
567
+
568
+ cm-secret-shield (pre-commit) ← git commit
569
+ cm-secret-shield (gate 0) ← cm-safe-deploy
570
+ cm-secret-shield (scan) ← cm-test-gate
571
+ cm-secret-shield (rotation) ← cm-identity-guard
572
+ ```
573
+
574
+ ## The Bottom Line
575
+
576
+ **5 layers. Every stage. No exceptions.**
577
+
578
+ Write Guard → Pre-Commit → Repo Scan → Deploy Gate → Runtime Guard.
579
+
580
+ A 3-second scan prevents a 3-day incident. This is non-negotiable.