@macpaw/cctk 1.0.0-beta.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 (415) hide show
  1. package/License +21 -0
  2. package/README.md +142 -0
  3. package/bin/index.js +5 -0
  4. package/dist/index.js +1 -0
  5. package/package.json +65 -0
  6. package/templates/claude/agents/brainstormer.md +113 -0
  7. package/templates/claude/agents/code-reviewer.md +157 -0
  8. package/templates/claude/agents/copywriter.md +110 -0
  9. package/templates/claude/agents/database-admin.md +92 -0
  10. package/templates/claude/agents/debugger.md +137 -0
  11. package/templates/claude/agents/docs-manager.md +208 -0
  12. package/templates/claude/agents/fullstack-developer.md +95 -0
  13. package/templates/claude/agents/git-manager.md +394 -0
  14. package/templates/claude/agents/journal-writer.md +113 -0
  15. package/templates/claude/agents/mcp-manager.md +89 -0
  16. package/templates/claude/agents/planner.md +108 -0
  17. package/templates/claude/agents/project-manager.md +125 -0
  18. package/templates/claude/agents/registry.json +304 -0
  19. package/templates/claude/agents/researcher.md +37 -0
  20. package/templates/claude/agents/scout-external.md +140 -0
  21. package/templates/claude/agents/scout.md +106 -0
  22. package/templates/claude/agents/tester.md +105 -0
  23. package/templates/claude/agents/ui-ux-designer.md +208 -0
  24. package/templates/claude/commands/ask.md +56 -0
  25. package/templates/claude/commands/bootstrap/auto/fast.md +106 -0
  26. package/templates/claude/commands/bootstrap/auto/parallel.md +64 -0
  27. package/templates/claude/commands/bootstrap/auto.md +110 -0
  28. package/templates/claude/commands/bootstrap.md +130 -0
  29. package/templates/claude/commands/brainstorm.md +75 -0
  30. package/templates/claude/commands/code/auto.md +198 -0
  31. package/templates/claude/commands/code/no-test.md +172 -0
  32. package/templates/claude/commands/code/parallel.md +100 -0
  33. package/templates/claude/commands/code.md +197 -0
  34. package/templates/claude/commands/coding-level.md +37 -0
  35. package/templates/claude/commands/content/cro.md +41 -0
  36. package/templates/claude/commands/content/enhance.md +12 -0
  37. package/templates/claude/commands/content/fast.md +11 -0
  38. package/templates/claude/commands/content/good.md +14 -0
  39. package/templates/claude/commands/cook/auto/fast.md +26 -0
  40. package/templates/claude/commands/cook/auto/parallel.md +49 -0
  41. package/templates/claude/commands/cook/auto.md +15 -0
  42. package/templates/claude/commands/cook.md +101 -0
  43. package/templates/claude/commands/debug.md +13 -0
  44. package/templates/claude/commands/docs/init.md +37 -0
  45. package/templates/claude/commands/docs/summarize.md +22 -0
  46. package/templates/claude/commands/docs/update.md +78 -0
  47. package/templates/claude/commands/fix/ci.md +17 -0
  48. package/templates/claude/commands/fix/fast.md +18 -0
  49. package/templates/claude/commands/fix/hard.md +35 -0
  50. package/templates/claude/commands/fix/logs.md +26 -0
  51. package/templates/claude/commands/fix/parallel.md +54 -0
  52. package/templates/claude/commands/fix/test.md +20 -0
  53. package/templates/claude/commands/fix/types.md +9 -0
  54. package/templates/claude/commands/fix/ui.md +33 -0
  55. package/templates/claude/commands/fix.md +43 -0
  56. package/templates/claude/commands/git/cm.md +5 -0
  57. package/templates/claude/commands/git/cp.md +4 -0
  58. package/templates/claude/commands/git/merge.md +40 -0
  59. package/templates/claude/commands/git/pr.md +50 -0
  60. package/templates/claude/commands/journal.md +7 -0
  61. package/templates/claude/commands/kanban.md +99 -0
  62. package/templates/claude/commands/plan/archive.md +57 -0
  63. package/templates/claude/commands/plan/ci.md +33 -0
  64. package/templates/claude/commands/plan/cro.md +67 -0
  65. package/templates/claude/commands/plan/fast.md +66 -0
  66. package/templates/claude/commands/plan/hard.md +92 -0
  67. package/templates/claude/commands/plan/parallel.md +129 -0
  68. package/templates/claude/commands/plan/two.md +45 -0
  69. package/templates/claude/commands/plan/validate.md +117 -0
  70. package/templates/claude/commands/plan.md +30 -0
  71. package/templates/claude/commands/preview.md +87 -0
  72. package/templates/claude/commands/registry.json +313 -0
  73. package/templates/claude/commands/review/codebase/parallel.md +122 -0
  74. package/templates/claude/commands/review/codebase.md +47 -0
  75. package/templates/claude/commands/scout/ext.md +35 -0
  76. package/templates/claude/commands/scout.md +28 -0
  77. package/templates/claude/commands/skill/add.md +36 -0
  78. package/templates/claude/commands/skill/create.md +29 -0
  79. package/templates/claude/commands/skill/fix-logs.md +22 -0
  80. package/templates/claude/commands/skill/optimize/auto.md +25 -0
  81. package/templates/claude/commands/skill/optimize.md +34 -0
  82. package/templates/claude/commands/skill/plan.md +45 -0
  83. package/templates/claude/commands/test/ui.md +91 -0
  84. package/templates/claude/commands/test.md +8 -0
  85. package/templates/claude/commands/use-mcp.md +34 -0
  86. package/templates/claude/commands/watzup.md +8 -0
  87. package/templates/claude/commands/worktree.md +126 -0
  88. package/templates/claude/hooks/dev-rules-reminder.cjs +258 -0
  89. package/templates/claude/hooks/docs/README.md +42 -0
  90. package/templates/claude/hooks/lib/cctk-config-utils.cjs +751 -0
  91. package/templates/claude/hooks/lib/cctk-paths.cjs +106 -0
  92. package/templates/claude/hooks/lib/context-tracker.cjs +346 -0
  93. package/templates/claude/hooks/privacy-block.cjs +289 -0
  94. package/templates/claude/hooks/registry.json +77 -0
  95. package/templates/claude/hooks/scout-block/broad-pattern-detector.cjs +293 -0
  96. package/templates/claude/hooks/scout-block/error-formatter.cjs +156 -0
  97. package/templates/claude/hooks/scout-block/path-extractor.cjs +359 -0
  98. package/templates/claude/hooks/scout-block/pattern-matcher.cjs +184 -0
  99. package/templates/claude/hooks/scout-block/vendor/ignore.js +626 -0
  100. package/templates/claude/hooks/scout-block.cjs +167 -0
  101. package/templates/claude/hooks/session-end.cjs +35 -0
  102. package/templates/claude/hooks/session-init.cjs +214 -0
  103. package/templates/claude/hooks/subagent-init.cjs +161 -0
  104. package/templates/claude/hooks/write-compact-marker.cjs +153 -0
  105. package/templates/claude/output-styles/coding-level-1.md +148 -0
  106. package/templates/claude/output-styles/coding-level-2.md +159 -0
  107. package/templates/claude/output-styles/coding-level-3.md +91 -0
  108. package/templates/claude/scripts/README.md +33 -0
  109. package/templates/claude/scripts/generate-catalogs.cjs +318 -0
  110. package/templates/claude/scripts/registry.json +48 -0
  111. package/templates/claude/scripts/set-active-plan.cjs +45 -0
  112. package/templates/claude/scripts/validate-docs.cjs +447 -0
  113. package/templates/claude/scripts/worktree.cjs +658 -0
  114. package/templates/claude/skills/README.md +112 -0
  115. package/templates/claude/skills/ai-artist/SKILL.md +75 -0
  116. package/templates/claude/skills/ai-artist/references/advanced-techniques.md +184 -0
  117. package/templates/claude/skills/ai-artist/references/domain-code.md +66 -0
  118. package/templates/claude/skills/ai-artist/references/domain-data.md +72 -0
  119. package/templates/claude/skills/ai-artist/references/domain-marketing.md +66 -0
  120. package/templates/claude/skills/ai-artist/references/domain-patterns.md +33 -0
  121. package/templates/claude/skills/ai-artist/references/domain-writing.md +68 -0
  122. package/templates/claude/skills/ai-artist/references/image-prompting.md +141 -0
  123. package/templates/claude/skills/ai-artist/references/llm-prompting.md +165 -0
  124. package/templates/claude/skills/ai-artist/references/nano-banana.md +59 -0
  125. package/templates/claude/skills/ai-artist/references/reasoning-techniques.md +201 -0
  126. package/templates/claude/skills/backend-development/SKILL.md +95 -0
  127. package/templates/claude/skills/backend-development/references/backend-api-design.md +495 -0
  128. package/templates/claude/skills/backend-development/references/backend-architecture.md +454 -0
  129. package/templates/claude/skills/backend-development/references/backend-authentication.md +338 -0
  130. package/templates/claude/skills/backend-development/references/backend-code-quality.md +659 -0
  131. package/templates/claude/skills/backend-development/references/backend-debugging.md +904 -0
  132. package/templates/claude/skills/backend-development/references/backend-devops.md +494 -0
  133. package/templates/claude/skills/backend-development/references/backend-mindset.md +387 -0
  134. package/templates/claude/skills/backend-development/references/backend-performance.md +397 -0
  135. package/templates/claude/skills/backend-development/references/backend-security.md +290 -0
  136. package/templates/claude/skills/backend-development/references/backend-technologies.md +256 -0
  137. package/templates/claude/skills/backend-development/references/backend-testing.md +429 -0
  138. package/templates/claude/skills/better-auth/SKILL.md +204 -0
  139. package/templates/claude/skills/better-auth/references/advanced-features.md +553 -0
  140. package/templates/claude/skills/better-auth/references/database-integration.md +577 -0
  141. package/templates/claude/skills/better-auth/references/email-password-auth.md +416 -0
  142. package/templates/claude/skills/better-auth/references/oauth-providers.md +430 -0
  143. package/templates/claude/skills/better-auth/scripts/better_auth_init.py +521 -0
  144. package/templates/claude/skills/chrome-devtools/SKILL.md +473 -0
  145. package/templates/claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
  146. package/templates/claude/skills/chrome-devtools/references/performance-guide.md +940 -0
  147. package/templates/claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
  148. package/templates/claude/skills/chrome-devtools/scripts/README.md +288 -0
  149. package/templates/claude/skills/chrome-devtools/scripts/aria-snapshot.js +368 -0
  150. package/templates/claude/skills/chrome-devtools/scripts/click.js +92 -0
  151. package/templates/claude/skills/chrome-devtools/scripts/console.js +85 -0
  152. package/templates/claude/skills/chrome-devtools/scripts/evaluate.js +59 -0
  153. package/templates/claude/skills/chrome-devtools/scripts/fill.js +84 -0
  154. package/templates/claude/skills/chrome-devtools/scripts/inject-auth.js +247 -0
  155. package/templates/claude/skills/chrome-devtools/scripts/install-deps.sh +11 -0
  156. package/templates/claude/skills/chrome-devtools/scripts/install.sh +36 -0
  157. package/templates/claude/skills/chrome-devtools/scripts/lib/browser.js +335 -0
  158. package/templates/claude/skills/chrome-devtools/scripts/lib/selector.js +183 -0
  159. package/templates/claude/skills/chrome-devtools/scripts/navigate.js +60 -0
  160. package/templates/claude/skills/chrome-devtools/scripts/network.js +113 -0
  161. package/templates/claude/skills/chrome-devtools/scripts/package.json +16 -0
  162. package/templates/claude/skills/chrome-devtools/scripts/performance.js +159 -0
  163. package/templates/claude/skills/chrome-devtools/scripts/screenshot.js +212 -0
  164. package/templates/claude/skills/chrome-devtools/scripts/select-ref.js +151 -0
  165. package/templates/claude/skills/chrome-devtools/scripts/snapshot.js +143 -0
  166. package/templates/claude/skills/chrome-devtools/scripts/ws-debug.js +47 -0
  167. package/templates/claude/skills/chrome-devtools/scripts/ws-full-debug.js +115 -0
  168. package/templates/claude/skills/claude-code/references/advanced-features.md +399 -0
  169. package/templates/claude/skills/claude-code/references/agent-skills.md +399 -0
  170. package/templates/claude/skills/claude-code/references/api-reference.md +498 -0
  171. package/templates/claude/skills/claude-code/references/best-practices.md +447 -0
  172. package/templates/claude/skills/claude-code/references/cicd-integration.md +428 -0
  173. package/templates/claude/skills/claude-code/references/common-workflows.md +107 -0
  174. package/templates/claude/skills/claude-code/references/configuration.md +480 -0
  175. package/templates/claude/skills/claude-code/references/enterprise-features.md +472 -0
  176. package/templates/claude/skills/claude-code/references/getting-started.md +244 -0
  177. package/templates/claude/skills/claude-code/references/hooks-and-plugins.md +444 -0
  178. package/templates/claude/skills/claude-code/references/hooks-comprehensive.md +622 -0
  179. package/templates/claude/skills/claude-code/references/ide-integration.md +316 -0
  180. package/templates/claude/skills/claude-code/references/mcp-integration.md +386 -0
  181. package/templates/claude/skills/claude-code/references/slash-commands.md +460 -0
  182. package/templates/claude/skills/claude-code/references/troubleshooting.md +455 -0
  183. package/templates/claude/skills/claude-code/skill.md +60 -0
  184. package/templates/claude/skills/code-review/SKILL.md +143 -0
  185. package/templates/claude/skills/code-review/references/code-review-reception.md +209 -0
  186. package/templates/claude/skills/code-review/references/requesting-code-review.md +105 -0
  187. package/templates/claude/skills/code-review/references/verification-before-completion.md +139 -0
  188. package/templates/claude/skills/context-engineering/SKILL.md +86 -0
  189. package/templates/claude/skills/context-engineering/references/context-compression.md +84 -0
  190. package/templates/claude/skills/context-engineering/references/context-degradation.md +93 -0
  191. package/templates/claude/skills/context-engineering/references/context-fundamentals.md +75 -0
  192. package/templates/claude/skills/context-engineering/references/context-optimization.md +82 -0
  193. package/templates/claude/skills/context-engineering/references/evaluation.md +89 -0
  194. package/templates/claude/skills/context-engineering/references/memory-systems.md +88 -0
  195. package/templates/claude/skills/context-engineering/references/multi-agent-patterns.md +90 -0
  196. package/templates/claude/skills/context-engineering/references/project-development.md +97 -0
  197. package/templates/claude/skills/context-engineering/references/tool-design.md +86 -0
  198. package/templates/claude/skills/context-engineering/scripts/compression_evaluator.py +329 -0
  199. package/templates/claude/skills/context-engineering/scripts/context_analyzer.py +294 -0
  200. package/templates/claude/skills/databases/SKILL.md +232 -0
  201. package/templates/claude/skills/databases/references/mongodb-aggregation.md +447 -0
  202. package/templates/claude/skills/databases/references/mongodb-atlas.md +465 -0
  203. package/templates/claude/skills/databases/references/mongodb-crud.md +408 -0
  204. package/templates/claude/skills/databases/references/mongodb-indexing.md +442 -0
  205. package/templates/claude/skills/databases/references/postgresql-administration.md +594 -0
  206. package/templates/claude/skills/databases/references/postgresql-performance.md +527 -0
  207. package/templates/claude/skills/databases/references/postgresql-psql-cli.md +467 -0
  208. package/templates/claude/skills/databases/references/postgresql-queries.md +475 -0
  209. package/templates/claude/skills/databases/scripts/db_backup.py +502 -0
  210. package/templates/claude/skills/databases/scripts/db_migrate.py +414 -0
  211. package/templates/claude/skills/databases/scripts/db_performance_check.py +445 -0
  212. package/templates/claude/skills/debugging/SKILL.md +84 -0
  213. package/templates/claude/skills/debugging/references/defense-in-depth.md +124 -0
  214. package/templates/claude/skills/debugging/references/root-cause-tracing.md +122 -0
  215. package/templates/claude/skills/debugging/references/systematic-debugging.md +102 -0
  216. package/templates/claude/skills/debugging/references/verification.md +123 -0
  217. package/templates/claude/skills/debugging/scripts/find-polluter.sh +63 -0
  218. package/templates/claude/skills/debugging/scripts/find-polluter.test.md +102 -0
  219. package/templates/claude/skills/devops/SKILL.md +293 -0
  220. package/templates/claude/skills/devops/references/browser-rendering.md +305 -0
  221. package/templates/claude/skills/devops/references/cloudflare-d1-kv.md +123 -0
  222. package/templates/claude/skills/devops/references/cloudflare-platform.md +271 -0
  223. package/templates/claude/skills/devops/references/cloudflare-r2-storage.md +280 -0
  224. package/templates/claude/skills/devops/references/cloudflare-workers-advanced.md +312 -0
  225. package/templates/claude/skills/devops/references/cloudflare-workers-apis.md +309 -0
  226. package/templates/claude/skills/devops/references/cloudflare-workers-basics.md +418 -0
  227. package/templates/claude/skills/devops/references/docker-basics.md +297 -0
  228. package/templates/claude/skills/devops/references/docker-compose.md +292 -0
  229. package/templates/claude/skills/devops/references/gcloud-platform.md +307 -0
  230. package/templates/claude/skills/devops/references/gcloud-services.md +304 -0
  231. package/templates/claude/skills/devops/scripts/cloudflare_deploy.py +269 -0
  232. package/templates/claude/skills/devops/scripts/docker_optimize.py +320 -0
  233. package/templates/claude/skills/docs-seeker/SKILL.md +95 -0
  234. package/templates/claude/skills/docs-seeker/package.json +24 -0
  235. package/templates/claude/skills/docs-seeker/references/advanced.md +78 -0
  236. package/templates/claude/skills/docs-seeker/references/context7-patterns.md +68 -0
  237. package/templates/claude/skills/docs-seeker/references/errors.md +68 -0
  238. package/templates/claude/skills/docs-seeker/scripts/analyze-llms-txt.js +245 -0
  239. package/templates/claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
  240. package/templates/claude/skills/docs-seeker/scripts/fetch-docs.js +212 -0
  241. package/templates/claude/skills/docs-seeker/workflows/library-search.md +87 -0
  242. package/templates/claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
  243. package/templates/claude/skills/docs-seeker/workflows/topic-search.md +77 -0
  244. package/templates/claude/skills/frontend-design/SKILL.md +85 -0
  245. package/templates/claude/skills/frontend-design/references/analysis-best-practices.md +80 -0
  246. package/templates/claude/skills/frontend-design/references/analysis-prompts.md +141 -0
  247. package/templates/claude/skills/frontend-design/references/analysis-techniques.md +118 -0
  248. package/templates/claude/skills/frontend-design/references/animejs.md +396 -0
  249. package/templates/claude/skills/frontend-design/references/design-extraction-overview.md +71 -0
  250. package/templates/claude/skills/frontend-design/references/extraction-best-practices.md +141 -0
  251. package/templates/claude/skills/frontend-design/references/extraction-output-templates.md +162 -0
  252. package/templates/claude/skills/frontend-design/references/extraction-prompts.md +127 -0
  253. package/templates/claude/skills/frontend-design/references/technical-accessibility.md +119 -0
  254. package/templates/claude/skills/frontend-design/references/technical-best-practices.md +97 -0
  255. package/templates/claude/skills/frontend-design/references/technical-optimization.md +44 -0
  256. package/templates/claude/skills/frontend-design/references/technical-overview.md +90 -0
  257. package/templates/claude/skills/frontend-design/references/technical-workflows.md +150 -0
  258. package/templates/claude/skills/frontend-design/references/visual-analysis-overview.md +95 -0
  259. package/templates/claude/skills/frontend-development/SKILL.md +399 -0
  260. package/templates/claude/skills/frontend-development/resources/common-patterns.md +331 -0
  261. package/templates/claude/skills/frontend-development/resources/complete-examples.md +872 -0
  262. package/templates/claude/skills/frontend-development/resources/component-patterns.md +502 -0
  263. package/templates/claude/skills/frontend-development/resources/data-fetching.md +767 -0
  264. package/templates/claude/skills/frontend-development/resources/file-organization.md +502 -0
  265. package/templates/claude/skills/frontend-development/resources/loading-and-error-states.md +501 -0
  266. package/templates/claude/skills/frontend-development/resources/performance.md +406 -0
  267. package/templates/claude/skills/frontend-development/resources/routing-guide.md +364 -0
  268. package/templates/claude/skills/frontend-development/resources/styling-guide.md +428 -0
  269. package/templates/claude/skills/frontend-development/resources/typescript-standards.md +418 -0
  270. package/templates/claude/skills/markdown-novel-viewer/SKILL.md +272 -0
  271. package/templates/claude/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
  272. package/templates/claude/skills/markdown-novel-viewer/assets/favicon.png +0 -0
  273. package/templates/claude/skills/markdown-novel-viewer/assets/novel-theme.css +872 -0
  274. package/templates/claude/skills/markdown-novel-viewer/assets/reader.js +378 -0
  275. package/templates/claude/skills/markdown-novel-viewer/assets/template.html +85 -0
  276. package/templates/claude/skills/markdown-novel-viewer/package.json +15 -0
  277. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
  278. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
  279. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +509 -0
  280. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +49 -0
  281. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
  282. package/templates/claude/skills/markdown-novel-viewer/scripts/server.cjs +398 -0
  283. package/templates/claude/skills/mcp-builder/SKILL.md +328 -0
  284. package/templates/claude/skills/mcp-builder/reference/evaluation.md +602 -0
  285. package/templates/claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
  286. package/templates/claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
  287. package/templates/claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
  288. package/templates/claude/skills/mcp-builder/scripts/connections.py +151 -0
  289. package/templates/claude/skills/mcp-builder/scripts/evaluation.py +381 -0
  290. package/templates/claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  291. package/templates/claude/skills/mcp-builder/scripts/requirements.txt +2 -0
  292. package/templates/claude/skills/mcp-management/README.md +219 -0
  293. package/templates/claude/skills/mcp-management/SKILL.md +209 -0
  294. package/templates/claude/skills/mcp-management/assets/tools.json +3146 -0
  295. package/templates/claude/skills/mcp-management/references/configuration.md +114 -0
  296. package/templates/claude/skills/mcp-management/references/gemini-cli-integration.md +209 -0
  297. package/templates/claude/skills/mcp-management/references/mcp-protocol.md +116 -0
  298. package/templates/claude/skills/mcp-management/scripts/.env.example +10 -0
  299. package/templates/claude/skills/mcp-management/scripts/cli.ts +202 -0
  300. package/templates/claude/skills/mcp-management/scripts/mcp-client.ts +247 -0
  301. package/templates/claude/skills/mcp-management/scripts/package.json +20 -0
  302. package/templates/claude/skills/mcp-management/scripts/tsconfig.json +15 -0
  303. package/templates/claude/skills/media-processing/SKILL.md +91 -0
  304. package/templates/claude/skills/media-processing/references/common-workflows.md +132 -0
  305. package/templates/claude/skills/media-processing/references/ffmpeg-encoding.md +358 -0
  306. package/templates/claude/skills/media-processing/references/ffmpeg-filters.md +503 -0
  307. package/templates/claude/skills/media-processing/references/ffmpeg-streaming.md +395 -0
  308. package/templates/claude/skills/media-processing/references/format-compatibility.md +375 -0
  309. package/templates/claude/skills/media-processing/references/imagemagick-batch.md +612 -0
  310. package/templates/claude/skills/media-processing/references/imagemagick-editing.md +623 -0
  311. package/templates/claude/skills/media-processing/references/rmbg-background-removal.md +66 -0
  312. package/templates/claude/skills/media-processing/references/troubleshooting.md +109 -0
  313. package/templates/claude/skills/media-processing/scripts/README.md +102 -0
  314. package/templates/claude/skills/media-processing/scripts/batch-remove-background.sh +124 -0
  315. package/templates/claude/skills/media-processing/scripts/batch_resize.py +342 -0
  316. package/templates/claude/skills/media-processing/scripts/media_convert.py +311 -0
  317. package/templates/claude/skills/media-processing/scripts/remove-background.sh +96 -0
  318. package/templates/claude/skills/media-processing/scripts/remove-bg-node.js +181 -0
  319. package/templates/claude/skills/mermaidjs-v11/SKILL.md +115 -0
  320. package/templates/claude/skills/mermaidjs-v11/references/cli-usage.md +228 -0
  321. package/templates/claude/skills/mermaidjs-v11/references/configuration.md +232 -0
  322. package/templates/claude/skills/mermaidjs-v11/references/diagram-types.md +315 -0
  323. package/templates/claude/skills/mermaidjs-v11/references/examples.md +344 -0
  324. package/templates/claude/skills/mermaidjs-v11/references/integration.md +310 -0
  325. package/templates/claude/skills/planning/SKILL.md +115 -0
  326. package/templates/claude/skills/planning/references/codebase-understanding.md +62 -0
  327. package/templates/claude/skills/planning/references/output-standards.md +127 -0
  328. package/templates/claude/skills/planning/references/plan-organization.md +150 -0
  329. package/templates/claude/skills/planning/references/research-phase.md +49 -0
  330. package/templates/claude/skills/planning/references/solution-design.md +63 -0
  331. package/templates/claude/skills/plans-kanban/SKILL.md +157 -0
  332. package/templates/claude/skills/plans-kanban/assets/dashboard-template.html +119 -0
  333. package/templates/claude/skills/plans-kanban/assets/dashboard.css +1594 -0
  334. package/templates/claude/skills/plans-kanban/assets/dashboard.js +659 -0
  335. package/templates/claude/skills/plans-kanban/assets/favicon.png +0 -0
  336. package/templates/claude/skills/plans-kanban/package.json +13 -0
  337. package/templates/claude/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +941 -0
  338. package/templates/claude/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
  339. package/templates/claude/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
  340. package/templates/claude/skills/plans-kanban/scripts/lib/plan-parser.cjs +194 -0
  341. package/templates/claude/skills/plans-kanban/scripts/lib/plan-scanner.cjs +277 -0
  342. package/templates/claude/skills/plans-kanban/scripts/lib/port-finder.cjs +49 -0
  343. package/templates/claude/skills/plans-kanban/scripts/lib/process-mgr.cjs +128 -0
  344. package/templates/claude/skills/plans-kanban/scripts/server.cjs +249 -0
  345. package/templates/claude/skills/problem-solving/SKILL.md +96 -0
  346. package/templates/claude/skills/problem-solving/references/attribution.md +69 -0
  347. package/templates/claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
  348. package/templates/claude/skills/problem-solving/references/inversion-exercise.md +91 -0
  349. package/templates/claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
  350. package/templates/claude/skills/problem-solving/references/scale-game.md +95 -0
  351. package/templates/claude/skills/problem-solving/references/simplification-cascades.md +80 -0
  352. package/templates/claude/skills/problem-solving/references/when-stuck.md +72 -0
  353. package/templates/claude/skills/registry.json +258 -0
  354. package/templates/claude/skills/repomix/SKILL.md +247 -0
  355. package/templates/claude/skills/repomix/references/configuration.md +211 -0
  356. package/templates/claude/skills/repomix/references/usage-patterns.md +232 -0
  357. package/templates/claude/skills/repomix/scripts/README.md +179 -0
  358. package/templates/claude/skills/repomix/scripts/repomix_batch.py +455 -0
  359. package/templates/claude/skills/repomix/scripts/repos.example.json +15 -0
  360. package/templates/claude/skills/research/SKILL.md +168 -0
  361. package/templates/claude/skills/sequential-thinking/.env.example +8 -0
  362. package/templates/claude/skills/sequential-thinking/README.md +183 -0
  363. package/templates/claude/skills/sequential-thinking/SKILL.md +94 -0
  364. package/templates/claude/skills/sequential-thinking/package.json +31 -0
  365. package/templates/claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
  366. package/templates/claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
  367. package/templates/claude/skills/sequential-thinking/references/core-patterns.md +95 -0
  368. package/templates/claude/skills/sequential-thinking/references/examples-api.md +88 -0
  369. package/templates/claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
  370. package/templates/claude/skills/sequential-thinking/references/examples-debug.md +90 -0
  371. package/templates/claude/skills/sequential-thinking/scripts/format-thought.js +182 -0
  372. package/templates/claude/skills/sequential-thinking/scripts/process-thought.js +252 -0
  373. package/templates/claude/skills/skill-creator/LICENSE.txt +202 -0
  374. package/templates/claude/skills/skill-creator/SKILL.md +266 -0
  375. package/templates/claude/skills/skill-creator/references/agent-skills-spec.md +51 -0
  376. package/templates/claude/skills/skill-creator/scripts/encoding_utils.py +21 -0
  377. package/templates/claude/skills/skill-creator/scripts/init_skill.py +304 -0
  378. package/templates/claude/skills/skill-creator/scripts/package_skill.py +110 -0
  379. package/templates/claude/skills/skill-creator/scripts/quick_validate.py +66 -0
  380. package/templates/claude/skills/template-skill/SKILL.md +6 -0
  381. package/templates/claude/skills/vitest/SKILL.md +595 -0
  382. package/templates/claude/skills/vitest/references/async-patterns.md +82 -0
  383. package/templates/claude/skills/vitest/references/mock-patterns.md +78 -0
  384. package/templates/claude/skills/vitest/references/monorepo-setup.md +185 -0
  385. package/templates/claude/skills/vitest/references/turborepo-setup.md +332 -0
  386. package/templates/claude/skills/web-frameworks/SKILL.md +324 -0
  387. package/templates/claude/skills/web-frameworks/references/nextjs-app-router.md +465 -0
  388. package/templates/claude/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
  389. package/templates/claude/skills/web-frameworks/references/nextjs-optimization.md +511 -0
  390. package/templates/claude/skills/web-frameworks/references/nextjs-server-components.md +495 -0
  391. package/templates/claude/skills/web-frameworks/references/remix-icon-integration.md +603 -0
  392. package/templates/claude/skills/web-frameworks/references/turborepo-caching.md +551 -0
  393. package/templates/claude/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
  394. package/templates/claude/skills/web-frameworks/references/turborepo-setup.md +542 -0
  395. package/templates/claude/skills/web-frameworks/scripts/nextjs_init.py +547 -0
  396. package/templates/claude/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
  397. package/templates/claude/workflows/development-rules.md +40 -0
  398. package/templates/claude/workflows/documentation-management.md +121 -0
  399. package/templates/claude/workflows/orchestration-protocol.md +16 -0
  400. package/templates/claude/workflows/primary-workflow.md +45 -0
  401. package/templates/claude/workflows/registry.json +37 -0
  402. package/templates/common/.cct.json +41 -0
  403. package/templates/common/.cctkignore +22 -0
  404. package/templates/common/.env.example +39 -0
  405. package/templates/common/.mcp.json.example +16 -0
  406. package/templates/common/metadata.json +15 -0
  407. package/templates/common/settings.json +79 -0
  408. package/templates/common/statusline.cjs +271 -0
  409. package/templates/config/.repomixignore +22 -0
  410. package/templates/config/AGENTS.md +55 -0
  411. package/templates/config/CLAUDE.md +87 -0
  412. package/templates/plans/bug-fix-template.md +69 -0
  413. package/templates/plans/feature-implementation-template.md +84 -0
  414. package/templates/plans/refactor-template.md +82 -0
  415. package/templates/plans/template-usage-guide.md +58 -0
@@ -0,0 +1,521 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Better Auth Initialization Script
4
+
5
+ Interactive script to initialize Better Auth configuration.
6
+ Supports multiple databases, ORMs, and authentication methods.
7
+
8
+ .env loading order: process.env > skill/.env > skills/.env > .claude/.env
9
+ """
10
+
11
+ import os
12
+ import sys
13
+ import json
14
+ import secrets
15
+ from pathlib import Path
16
+ from typing import Optional, Dict, Any, List
17
+ from dataclasses import dataclass
18
+
19
+
20
+ @dataclass
21
+ class EnvConfig:
22
+ """Environment configuration holder."""
23
+ secret: str
24
+ url: str
25
+ database_url: Optional[str] = None
26
+ github_client_id: Optional[str] = None
27
+ github_client_secret: Optional[str] = None
28
+ google_client_id: Optional[str] = None
29
+ google_client_secret: Optional[str] = None
30
+
31
+
32
+ class BetterAuthInit:
33
+ """Better Auth configuration initializer."""
34
+
35
+ def __init__(self, project_root: Optional[Path] = None):
36
+ """
37
+ Initialize the Better Auth configuration tool.
38
+
39
+ Args:
40
+ project_root: Project root directory. Auto-detected if not provided.
41
+ """
42
+ self.project_root = project_root or self._find_project_root()
43
+ self.env_config: Optional[EnvConfig] = None
44
+
45
+ @staticmethod
46
+ def _find_project_root() -> Path:
47
+ """
48
+ Find project root by looking for package.json.
49
+
50
+ Returns:
51
+ Path to project root.
52
+
53
+ Raises:
54
+ RuntimeError: If project root cannot be found.
55
+ """
56
+ current = Path.cwd()
57
+ while current != current.parent:
58
+ if (current / "package.json").exists():
59
+ return current
60
+ current = current.parent
61
+
62
+ raise RuntimeError("Could not find project root (no package.json found)")
63
+
64
+ def _load_env_files(self) -> Dict[str, str]:
65
+ """
66
+ Load environment variables from .env files in order.
67
+
68
+ Loading order: process.env > skill/.env > skills/.env > .claude/.env
69
+
70
+ Returns:
71
+ Dictionary of environment variables.
72
+ """
73
+ env_vars = {}
74
+
75
+ # Define search paths in reverse priority order
76
+ skill_dir = Path(__file__).parent.parent
77
+ env_paths = [
78
+ self.project_root / ".claude" / ".env",
79
+ self.project_root / ".claude" / "skills" / ".env",
80
+ skill_dir / ".env",
81
+ ]
82
+
83
+ # Load from files (lowest priority first)
84
+ for env_path in env_paths:
85
+ if env_path.exists():
86
+ env_vars.update(self._parse_env_file(env_path))
87
+
88
+ # Override with process environment (highest priority)
89
+ env_vars.update(os.environ)
90
+
91
+ return env_vars
92
+
93
+ @staticmethod
94
+ def _parse_env_file(path: Path) -> Dict[str, str]:
95
+ """
96
+ Parse .env file into dictionary.
97
+
98
+ Args:
99
+ path: Path to .env file.
100
+
101
+ Returns:
102
+ Dictionary of key-value pairs.
103
+ """
104
+ env_vars = {}
105
+ try:
106
+ with open(path, "r", encoding="utf-8") as f:
107
+ for line in f:
108
+ line = line.strip()
109
+ if line and not line.startswith("#") and "=" in line:
110
+ key, value = line.split("=", 1)
111
+ # Remove quotes if present
112
+ value = value.strip().strip('"').strip("'")
113
+ env_vars[key.strip()] = value
114
+ except Exception as e:
115
+ print(f"Warning: Could not parse {path}: {e}")
116
+
117
+ return env_vars
118
+
119
+ @staticmethod
120
+ def generate_secret(length: int = 32) -> str:
121
+ """
122
+ Generate cryptographically secure random secret.
123
+
124
+ Args:
125
+ length: Length of secret in bytes.
126
+
127
+ Returns:
128
+ Hex-encoded secret string.
129
+ """
130
+ return secrets.token_hex(length)
131
+
132
+ def prompt_database(self) -> Dict[str, Any]:
133
+ """
134
+ Prompt user for database configuration.
135
+
136
+ Returns:
137
+ Database configuration dictionary.
138
+ """
139
+ print("\nDatabase Configuration")
140
+ print("=" * 50)
141
+ print("1. Direct Connection (PostgreSQL/MySQL/SQLite)")
142
+ print("2. Drizzle ORM")
143
+ print("3. Prisma")
144
+ print("4. Kysely")
145
+ print("5. MongoDB")
146
+
147
+ choice = input("\nSelect database option (1-5): ").strip()
148
+
149
+ db_configs = {
150
+ "1": self._prompt_direct_db,
151
+ "2": self._prompt_drizzle,
152
+ "3": self._prompt_prisma,
153
+ "4": self._prompt_kysely,
154
+ "5": self._prompt_mongodb,
155
+ }
156
+
157
+ handler = db_configs.get(choice)
158
+ if not handler:
159
+ print("Invalid choice. Defaulting to direct PostgreSQL.")
160
+ return self._prompt_direct_db()
161
+
162
+ return handler()
163
+
164
+ def _prompt_direct_db(self) -> Dict[str, Any]:
165
+ """Prompt for direct database connection."""
166
+ print("\nDatabase Type:")
167
+ print("1. PostgreSQL")
168
+ print("2. MySQL")
169
+ print("3. SQLite")
170
+
171
+ db_type = input("Select (1-3): ").strip()
172
+
173
+ if db_type == "3":
174
+ db_path = input("SQLite file path [./dev.db]: ").strip() or "./dev.db"
175
+ return {
176
+ "type": "sqlite",
177
+ "import": "import Database from 'better-sqlite3';",
178
+ "config": f'database: new Database("{db_path}")'
179
+ }
180
+ elif db_type == "2":
181
+ db_url = input("MySQL connection string: ").strip()
182
+ return {
183
+ "type": "mysql",
184
+ "import": "import { createPool } from 'mysql2/promise';",
185
+ "config": f"database: createPool({{ connectionString: process.env.DATABASE_URL }})",
186
+ "env_var": ("DATABASE_URL", db_url)
187
+ }
188
+ else:
189
+ db_url = input("PostgreSQL connection string: ").strip()
190
+ return {
191
+ "type": "postgresql",
192
+ "import": "import { Pool } from 'pg';",
193
+ "config": "database: new Pool({ connectionString: process.env.DATABASE_URL })",
194
+ "env_var": ("DATABASE_URL", db_url)
195
+ }
196
+
197
+ def _prompt_drizzle(self) -> Dict[str, Any]:
198
+ """Prompt for Drizzle ORM configuration."""
199
+ print("\nDrizzle Provider:")
200
+ print("1. PostgreSQL")
201
+ print("2. MySQL")
202
+ print("3. SQLite")
203
+
204
+ provider = input("Select (1-3): ").strip()
205
+ provider_map = {"1": "pg", "2": "mysql", "3": "sqlite"}
206
+ provider_name = provider_map.get(provider, "pg")
207
+
208
+ return {
209
+ "type": "drizzle",
210
+ "provider": provider_name,
211
+ "import": "import { drizzleAdapter } from 'better-auth/adapters/drizzle';\nimport { db } from '@/db';",
212
+ "config": f"database: drizzleAdapter(db, {{ provider: '{provider_name}' }})"
213
+ }
214
+
215
+ def _prompt_prisma(self) -> Dict[str, Any]:
216
+ """Prompt for Prisma configuration."""
217
+ print("\nPrisma Provider:")
218
+ print("1. PostgreSQL")
219
+ print("2. MySQL")
220
+ print("3. SQLite")
221
+
222
+ provider = input("Select (1-3): ").strip()
223
+ provider_map = {"1": "postgresql", "2": "mysql", "3": "sqlite"}
224
+ provider_name = provider_map.get(provider, "postgresql")
225
+
226
+ return {
227
+ "type": "prisma",
228
+ "provider": provider_name,
229
+ "import": "import { prismaAdapter } from 'better-auth/adapters/prisma';\nimport { PrismaClient } from '@prisma/client';\n\nconst prisma = new PrismaClient();",
230
+ "config": f"database: prismaAdapter(prisma, {{ provider: '{provider_name}' }})"
231
+ }
232
+
233
+ def _prompt_kysely(self) -> Dict[str, Any]:
234
+ """Prompt for Kysely configuration."""
235
+ return {
236
+ "type": "kysely",
237
+ "import": "import { kyselyAdapter } from 'better-auth/adapters/kysely';\nimport { db } from '@/db';",
238
+ "config": "database: kyselyAdapter(db, { provider: 'pg' })"
239
+ }
240
+
241
+ def _prompt_mongodb(self) -> Dict[str, Any]:
242
+ """Prompt for MongoDB configuration."""
243
+ mongo_uri = input("MongoDB connection string: ").strip()
244
+ db_name = input("Database name: ").strip()
245
+
246
+ return {
247
+ "type": "mongodb",
248
+ "import": "import { mongodbAdapter } from 'better-auth/adapters/mongodb';\nimport { client } from '@/db';",
249
+ "config": f"database: mongodbAdapter(client, {{ databaseName: '{db_name}' }})",
250
+ "env_var": ("MONGODB_URI", mongo_uri)
251
+ }
252
+
253
+ def prompt_auth_methods(self) -> List[str]:
254
+ """
255
+ Prompt user for authentication methods.
256
+
257
+ Returns:
258
+ List of selected auth method codes.
259
+ """
260
+ print("\nAuthentication Methods")
261
+ print("=" * 50)
262
+ print("Select authentication methods (space-separated, e.g., '1 2 3'):")
263
+ print("1. Email/Password")
264
+ print("2. GitHub OAuth")
265
+ print("3. Google OAuth")
266
+ print("4. Discord OAuth")
267
+ print("5. Two-Factor Authentication (2FA)")
268
+ print("6. Passkeys (WebAuthn)")
269
+ print("7. Magic Link")
270
+ print("8. Username")
271
+
272
+ choices = input("\nYour selection: ").strip().split()
273
+ return [c for c in choices if c in "12345678"]
274
+
275
+ def generate_auth_config(
276
+ self,
277
+ db_config: Dict[str, Any],
278
+ auth_methods: List[str],
279
+ ) -> str:
280
+ """
281
+ Generate auth.ts configuration file content.
282
+
283
+ Args:
284
+ db_config: Database configuration.
285
+ auth_methods: Selected authentication methods.
286
+
287
+ Returns:
288
+ Generated TypeScript configuration code.
289
+ """
290
+ imports = ["import { betterAuth } from 'better-auth';"]
291
+ plugins = []
292
+ plugin_imports = []
293
+ config_parts = []
294
+
295
+ # Database import
296
+ if db_config.get("import"):
297
+ imports.append(db_config["import"])
298
+
299
+ # Email/Password
300
+ if "1" in auth_methods:
301
+ config_parts.append(""" emailAndPassword: {
302
+ enabled: true,
303
+ autoSignIn: true
304
+ }""")
305
+
306
+ # OAuth providers
307
+ social_providers = []
308
+ if "2" in auth_methods:
309
+ social_providers.append(""" github: {
310
+ clientId: process.env.GITHUB_CLIENT_ID!,
311
+ clientSecret: process.env.GITHUB_CLIENT_SECRET!,
312
+ }""")
313
+
314
+ if "3" in auth_methods:
315
+ social_providers.append(""" google: {
316
+ clientId: process.env.GOOGLE_CLIENT_ID!,
317
+ clientSecret: process.env.GOOGLE_CLIENT_SECRET!,
318
+ }""")
319
+
320
+ if "4" in auth_methods:
321
+ social_providers.append(""" discord: {
322
+ clientId: process.env.DISCORD_CLIENT_ID!,
323
+ clientSecret: process.env.DISCORD_CLIENT_SECRET!,
324
+ }""")
325
+
326
+ if social_providers:
327
+ config_parts.append(f" socialProviders: {{\n{',\\n'.join(social_providers)}\n }}")
328
+
329
+ # Plugins
330
+ if "5" in auth_methods:
331
+ plugin_imports.append("import { twoFactor } from 'better-auth/plugins';")
332
+ plugins.append("twoFactor()")
333
+
334
+ if "6" in auth_methods:
335
+ plugin_imports.append("import { passkey } from 'better-auth/plugins';")
336
+ plugins.append("passkey()")
337
+
338
+ if "7" in auth_methods:
339
+ plugin_imports.append("import { magicLink } from 'better-auth/plugins';")
340
+ plugins.append("""magicLink({
341
+ sendMagicLink: async ({ email, url }) => {
342
+ // TODO: Implement email sending
343
+ console.log(`Magic link for ${email}: ${url}`);
344
+ }
345
+ })""")
346
+
347
+ if "8" in auth_methods:
348
+ plugin_imports.append("import { username } from 'better-auth/plugins';")
349
+ plugins.append("username()")
350
+
351
+ # Combine all imports
352
+ all_imports = imports + plugin_imports
353
+
354
+ # Build config
355
+ config_body = ",\n".join(config_parts)
356
+
357
+ if plugins:
358
+ plugins_str = ",\n ".join(plugins)
359
+ config_body += f",\n plugins: [\n {plugins_str}\n ]"
360
+
361
+ # Final output
362
+ return f"""{chr(10).join(all_imports)}
363
+
364
+ export const auth = betterAuth({{
365
+ {db_config["config"]},
366
+ {config_body}
367
+ }});
368
+ """
369
+
370
+ def generate_env_file(
371
+ self,
372
+ db_config: Dict[str, Any],
373
+ auth_methods: List[str]
374
+ ) -> str:
375
+ """
376
+ Generate .env file content.
377
+
378
+ Args:
379
+ db_config: Database configuration.
380
+ auth_methods: Selected authentication methods.
381
+
382
+ Returns:
383
+ Generated .env file content.
384
+ """
385
+ env_vars = [
386
+ f"BETTER_AUTH_SECRET={self.generate_secret()}",
387
+ "BETTER_AUTH_URL=http://localhost:3000",
388
+ ]
389
+
390
+ # Database URL
391
+ if db_config.get("env_var"):
392
+ key, value = db_config["env_var"]
393
+ env_vars.append(f"{key}={value}")
394
+
395
+ # OAuth credentials
396
+ if "2" in auth_methods:
397
+ env_vars.extend([
398
+ "GITHUB_CLIENT_ID=your_github_client_id",
399
+ "GITHUB_CLIENT_SECRET=your_github_client_secret",
400
+ ])
401
+
402
+ if "3" in auth_methods:
403
+ env_vars.extend([
404
+ "GOOGLE_CLIENT_ID=your_google_client_id",
405
+ "GOOGLE_CLIENT_SECRET=your_google_client_secret",
406
+ ])
407
+
408
+ if "4" in auth_methods:
409
+ env_vars.extend([
410
+ "DISCORD_CLIENT_ID=your_discord_client_id",
411
+ "DISCORD_CLIENT_SECRET=your_discord_client_secret",
412
+ ])
413
+
414
+ return "\n".join(env_vars) + "\n"
415
+
416
+ def run(self) -> None:
417
+ """Run interactive initialization."""
418
+ print("=" * 50)
419
+ print("Better Auth Configuration Generator")
420
+ print("=" * 50)
421
+
422
+ # Load existing env
423
+ env_vars = self._load_env_files()
424
+
425
+ # Prompt for configuration
426
+ db_config = self.prompt_database()
427
+ auth_methods = self.prompt_auth_methods()
428
+
429
+ # Generate files
430
+ auth_config = self.generate_auth_config(db_config, auth_methods)
431
+ env_content = self.generate_env_file(db_config, auth_methods)
432
+
433
+ # Display output
434
+ print("\n" + "=" * 50)
435
+ print("Generated Configuration")
436
+ print("=" * 50)
437
+
438
+ print("\n--- auth.ts ---")
439
+ print(auth_config)
440
+
441
+ print("\n--- .env ---")
442
+ print(env_content)
443
+
444
+ # Offer to save
445
+ save = input("\nSave configuration files? (y/N): ").strip().lower()
446
+ if save == "y":
447
+ self._save_files(auth_config, env_content)
448
+ else:
449
+ print("Configuration not saved.")
450
+
451
+ def _save_files(self, auth_config: str, env_content: str) -> None:
452
+ """
453
+ Save generated configuration files.
454
+
455
+ Args:
456
+ auth_config: auth.ts content.
457
+ env_content: .env content.
458
+ """
459
+ # Save auth.ts
460
+ auth_locations = [
461
+ self.project_root / "lib" / "auth.ts",
462
+ self.project_root / "src" / "lib" / "auth.ts",
463
+ self.project_root / "utils" / "auth.ts",
464
+ self.project_root / "auth.ts",
465
+ ]
466
+
467
+ print("\nWhere to save auth.ts?")
468
+ for i, loc in enumerate(auth_locations, 1):
469
+ print(f"{i}. {loc}")
470
+ print("5. Custom path")
471
+
472
+ choice = input("Select (1-5): ").strip()
473
+ if choice == "5":
474
+ custom_path = input("Enter path: ").strip()
475
+ auth_path = Path(custom_path)
476
+ else:
477
+ idx = int(choice) - 1 if choice.isdigit() else 0
478
+ auth_path = auth_locations[idx]
479
+
480
+ auth_path.parent.mkdir(parents=True, exist_ok=True)
481
+ auth_path.write_text(auth_config, encoding="utf-8")
482
+ print(f"Saved: {auth_path}")
483
+
484
+ # Save .env
485
+ env_path = self.project_root / ".env"
486
+ if env_path.exists():
487
+ backup = self.project_root / ".env.backup"
488
+ env_path.rename(backup)
489
+ print(f"Backed up existing .env to {backup}")
490
+
491
+ env_path.write_text(env_content, encoding="utf-8")
492
+ print(f"Saved: {env_path}")
493
+
494
+ print("\nNext steps:")
495
+ print("1. Run: npx @better-auth/cli generate")
496
+ print("2. Apply database migrations")
497
+ print("3. Mount API handler in your framework")
498
+ print("4. Create client instance")
499
+
500
+
501
+ def main() -> int:
502
+ """
503
+ Main entry point.
504
+
505
+ Returns:
506
+ Exit code (0 for success, 1 for error).
507
+ """
508
+ try:
509
+ initializer = BetterAuthInit()
510
+ initializer.run()
511
+ return 0
512
+ except KeyboardInterrupt:
513
+ print("\n\nOperation cancelled.")
514
+ return 1
515
+ except Exception as e:
516
+ print(f"\nError: {e}", file=sys.stderr)
517
+ return 1
518
+
519
+
520
+ if __name__ == "__main__":
521
+ sys.exit(main())