kybernus 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (407) hide show
  1. package/README.md +321 -0
  2. package/dist/cli/commands/init.d.ts +12 -0
  3. package/dist/cli/commands/init.d.ts.map +1 -0
  4. package/dist/cli/commands/init.js +71 -0
  5. package/dist/cli/commands/init.js.map +1 -0
  6. package/dist/cli/commands/login.d.ts +6 -0
  7. package/dist/cli/commands/login.d.ts.map +1 -0
  8. package/dist/cli/commands/login.js +42 -0
  9. package/dist/cli/commands/login.js.map +1 -0
  10. package/dist/cli/commands/logout.d.ts +2 -0
  11. package/dist/cli/commands/logout.d.ts.map +1 -0
  12. package/dist/cli/commands/logout.js +22 -0
  13. package/dist/cli/commands/logout.js.map +1 -0
  14. package/dist/cli/commands/register.d.ts +2 -0
  15. package/dist/cli/commands/register.d.ts.map +1 -0
  16. package/dist/cli/commands/register.js +69 -0
  17. package/dist/cli/commands/register.js.map +1 -0
  18. package/dist/cli/commands/status.d.ts +2 -0
  19. package/dist/cli/commands/status.d.ts.map +1 -0
  20. package/dist/cli/commands/status.js +46 -0
  21. package/dist/cli/commands/status.js.map +1 -0
  22. package/dist/cli/commands/upgrade.d.ts +2 -0
  23. package/dist/cli/commands/upgrade.d.ts.map +1 -0
  24. package/dist/cli/commands/upgrade.js +62 -0
  25. package/dist/cli/commands/upgrade.js.map +1 -0
  26. package/dist/cli/prompts/wizard.d.ts +3 -0
  27. package/dist/cli/prompts/wizard.d.ts.map +1 -0
  28. package/dist/cli/prompts/wizard.js +121 -0
  29. package/dist/cli/prompts/wizard.js.map +1 -0
  30. package/dist/cli/services/AnalyticsClient.d.ts +11 -0
  31. package/dist/cli/services/AnalyticsClient.d.ts.map +1 -0
  32. package/dist/cli/services/AnalyticsClient.js +32 -0
  33. package/dist/cli/services/AnalyticsClient.js.map +1 -0
  34. package/dist/core/ai/documentation-generator.d.ts +36 -0
  35. package/dist/core/ai/documentation-generator.d.ts.map +1 -0
  36. package/dist/core/ai/documentation-generator.js +111 -0
  37. package/dist/core/ai/documentation-generator.js.map +1 -0
  38. package/dist/core/ai/gemini-service.d.ts +17 -0
  39. package/dist/core/ai/gemini-service.d.ts.map +1 -0
  40. package/dist/core/ai/gemini-service.js +68 -0
  41. package/dist/core/ai/gemini-service.js.map +1 -0
  42. package/dist/core/ai/prompts/documentation-prompts.d.ts +17 -0
  43. package/dist/core/ai/prompts/documentation-prompts.d.ts.map +1 -0
  44. package/dist/core/ai/prompts/documentation-prompts.js +195 -0
  45. package/dist/core/ai/prompts/documentation-prompts.js.map +1 -0
  46. package/dist/core/auth/license-validator.d.ts +33 -0
  47. package/dist/core/auth/license-validator.d.ts.map +1 -0
  48. package/dist/core/auth/license-validator.js +81 -0
  49. package/dist/core/auth/license-validator.js.map +1 -0
  50. package/dist/core/config/config-manager.d.ts +24 -0
  51. package/dist/core/config/config-manager.d.ts.map +1 -0
  52. package/dist/core/config/config-manager.js +56 -0
  53. package/dist/core/config/config-manager.js.map +1 -0
  54. package/dist/core/generator/context-builder.d.ts +10 -0
  55. package/dist/core/generator/context-builder.d.ts.map +1 -0
  56. package/dist/core/generator/context-builder.js +43 -0
  57. package/dist/core/generator/context-builder.js.map +1 -0
  58. package/dist/core/generator/project.d.ts +42 -0
  59. package/dist/core/generator/project.d.ts.map +1 -0
  60. package/dist/core/generator/project.js +278 -0
  61. package/dist/core/generator/project.js.map +1 -0
  62. package/dist/core/templates/engine.d.ts +25 -0
  63. package/dist/core/templates/engine.d.ts.map +1 -0
  64. package/dist/core/templates/engine.js +78 -0
  65. package/dist/core/templates/engine.js.map +1 -0
  66. package/dist/core/templates/helpers.d.ts +6 -0
  67. package/dist/core/templates/helpers.d.ts.map +1 -0
  68. package/dist/core/templates/helpers.js +63 -0
  69. package/dist/core/templates/helpers.js.map +1 -0
  70. package/dist/index.d.ts +3 -0
  71. package/dist/index.d.ts.map +1 -0
  72. package/dist/index.js +48 -0
  73. package/dist/index.js.map +1 -0
  74. package/dist/models/config.d.ts +38 -0
  75. package/dist/models/config.d.ts.map +1 -0
  76. package/dist/models/config.js +2 -0
  77. package/dist/models/config.js.map +1 -0
  78. package/package.json +66 -0
  79. package/templates/java-spring/free/mvc/.gitignore.hbs +39 -0
  80. package/templates/java-spring/free/mvc/README.md.hbs +116 -0
  81. package/templates/java-spring/free/mvc/docker-compose.yml.hbs +18 -0
  82. package/templates/java-spring/free/mvc/pom.xml.hbs +92 -0
  83. package/templates/java-spring/free/mvc/src/main/java/{{packagePath}}/config/GlobalExceptionHandler.java.hbs +39 -0
  84. package/templates/java-spring/free/mvc/src/main/java/{{packagePath}}/config/WebConfig.java.hbs +30 -0
  85. package/templates/java-spring/free/mvc/src/main/java/{{packagePath}}/controller/HealthController.java.hbs +30 -0
  86. package/templates/java-spring/free/mvc/src/main/java/{{packagePath}}/model/.gitkeep +0 -0
  87. package/templates/java-spring/free/mvc/src/main/java/{{packagePath}}/repository/.gitkeep +0 -0
  88. package/templates/java-spring/free/mvc/src/main/java/{{packagePath}}/service/.gitkeep +0 -0
  89. package/templates/java-spring/free/mvc/src/main/java/{{packagePath}}/{{projectNamePascalCase}}Application.java.hbs +13 -0
  90. package/templates/java-spring/free/mvc/src/main/resources/application.yml.hbs +32 -0
  91. package/templates/java-spring/free/mvc/src/test/java/{{packagePath}}/{{projectNamePascalCase}}ApplicationTests.java.hbs +13 -0
  92. package/templates/java-spring/free/mvc/src/test/resources/application.yml.hbs +10 -0
  93. package/templates/java-spring/free/mvc/template.json +14 -0
  94. package/templates/java-spring/pro/clean/.github/workflows/ci-cd.yml.hbs +88 -0
  95. package/templates/java-spring/pro/clean/Dockerfile.hbs +45 -0
  96. package/templates/java-spring/pro/clean/README.md.hbs +31 -0
  97. package/templates/java-spring/pro/clean/docker-compose.yml.hbs +18 -0
  98. package/templates/java-spring/pro/clean/infra/main.tf.hbs +83 -0
  99. package/templates/java-spring/pro/clean/infra/modules/ecs/main.tf.hbs +54 -0
  100. package/templates/java-spring/pro/clean/infra/modules/rds/main.tf.hbs +88 -0
  101. package/templates/java-spring/pro/clean/infra/modules/vpc/main.tf.hbs +107 -0
  102. package/templates/java-spring/pro/clean/pom.xml.hbs +130 -0
  103. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/application/service/AuthService.java.hbs +36 -0
  104. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/domain/entity/User.java.hbs +77 -0
  105. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/domain/repository/UserRepository.java.hbs +15 -0
  106. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/domain/usecase/LoginUserUseCase.java.hbs +36 -0
  107. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/domain/usecase/RegisterUserUseCase.java.hbs +46 -0
  108. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/infrastructure/persistence/InMemoryUserRepository.java.hbs +41 -0
  109. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/infrastructure/security/SecurityAdapters.java.hbs +53 -0
  110. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/infrastructure/web/controller/AuthController.java.hbs +41 -0
  111. package/templates/java-spring/pro/clean/src/main/java/{{packagePath}}/{{projectNamePascalCase}}Application.java.hbs +14 -0
  112. package/templates/java-spring/pro/hexagonal/.github/workflows/ci-cd.yml.hbs +88 -0
  113. package/templates/java-spring/pro/hexagonal/Dockerfile.hbs +45 -0
  114. package/templates/java-spring/pro/hexagonal/README.md.hbs +38 -0
  115. package/templates/java-spring/pro/hexagonal/docker-compose.yml.hbs +18 -0
  116. package/templates/java-spring/pro/hexagonal/infra/main.tf.hbs +83 -0
  117. package/templates/java-spring/pro/hexagonal/infra/modules/ecs/main.tf.hbs +54 -0
  118. package/templates/java-spring/pro/hexagonal/infra/modules/rds/main.tf.hbs +88 -0
  119. package/templates/java-spring/pro/hexagonal/infra/modules/vpc/main.tf.hbs +107 -0
  120. package/templates/java-spring/pro/hexagonal/pom.xml.hbs +130 -0
  121. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/application/service/AuthService.java.hbs +36 -0
  122. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/domain/entity/User.java.hbs +77 -0
  123. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/domain/repository/UserRepository.java.hbs +15 -0
  124. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/domain/usecase/LoginUserUseCase.java.hbs +36 -0
  125. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/domain/usecase/RegisterUserUseCase.java.hbs +46 -0
  126. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/infrastructure/persistence/InMemoryUserRepository.java.hbs +41 -0
  127. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/infrastructure/security/SecurityAdapters.java.hbs +53 -0
  128. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/infrastructure/web/controller/AuthController.java.hbs +41 -0
  129. package/templates/java-spring/pro/hexagonal/src/main/java/{{packagePath}}/{{projectNamePascalCase}}Application.java.hbs +14 -0
  130. package/templates/java-spring/pro/mvc/.github/workflows/ci-cd.yml.hbs +88 -0
  131. package/templates/java-spring/pro/mvc/Dockerfile.hbs +45 -0
  132. package/templates/java-spring/pro/mvc/README.md.hbs +116 -0
  133. package/templates/java-spring/pro/mvc/docker-compose.yml.hbs +18 -0
  134. package/templates/java-spring/pro/mvc/infra/main.tf.hbs +83 -0
  135. package/templates/java-spring/pro/mvc/infra/modules/ecs/main.tf.hbs +54 -0
  136. package/templates/java-spring/pro/mvc/infra/modules/rds/main.tf.hbs +88 -0
  137. package/templates/java-spring/pro/mvc/infra/modules/vpc/main.tf.hbs +107 -0
  138. package/templates/java-spring/pro/mvc/pom.xml.hbs +130 -0
  139. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/config/GlobalExceptionHandler.java.hbs +39 -0
  140. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/config/SecurityConfig.java.hbs +44 -0
  141. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/config/WebConfig.java.hbs +30 -0
  142. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/controller/AuthController.java.hbs +69 -0
  143. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/controller/HealthController.java.hbs +30 -0
  144. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/controller/PaymentsController.java.hbs +49 -0
  145. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/dto/AuthRequest.java.hbs +3 -0
  146. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/dto/AuthResponse.java.hbs +3 -0
  147. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/model/.gitkeep +0 -0
  148. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/repository/.gitkeep +0 -0
  149. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/security/JwtAuthenticationFilter.java.hbs +56 -0
  150. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/security/JwtTokenProvider.java.hbs +59 -0
  151. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/service/.gitkeep +0 -0
  152. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/service/StripeService.java.hbs +67 -0
  153. package/templates/java-spring/pro/mvc/src/main/java/{{packagePath}}/{{projectNamePascalCase}}Application.java.hbs +13 -0
  154. package/templates/java-spring/pro/mvc/src/main/resources/application.yml.hbs +32 -0
  155. package/templates/java-spring/pro/mvc/src/test/java/{{packagePath}}/{{projectNamePascalCase}}ApplicationTests.java.hbs +13 -0
  156. package/templates/java-spring/pro/mvc/src/test/resources/application.yml.hbs +10 -0
  157. package/templates/java-spring/pro/mvc/template.json +14 -0
  158. package/templates/nestjs/free/mvc/README.md.hbs +28 -0
  159. package/templates/nestjs/free/mvc/package.json.hbs +29 -0
  160. package/templates/nestjs/free/mvc/src/app.module.ts.hbs +13 -0
  161. package/templates/nestjs/free/mvc/src/controllers/health.controller.ts.hbs +9 -0
  162. package/templates/nestjs/free/mvc/src/controllers/items.controller.ts.hbs +32 -0
  163. package/templates/nestjs/free/mvc/src/main.ts.hbs +17 -0
  164. package/templates/nestjs/free/mvc/src/models/create-item.dto.ts.hbs +10 -0
  165. package/templates/nestjs/free/mvc/src/models/item.model.ts.hbs +6 -0
  166. package/templates/nestjs/free/mvc/src/modules/items.module.ts.hbs +9 -0
  167. package/templates/nestjs/free/mvc/src/services/items.service.ts.hbs +32 -0
  168. package/templates/nestjs/free/mvc/tsconfig.json.hbs +21 -0
  169. package/templates/nestjs/pro/clean/.env.example.hbs +19 -0
  170. package/templates/nestjs/pro/clean/.github/workflows/ci-cd.yml.hbs +88 -0
  171. package/templates/nestjs/pro/clean/Dockerfile.hbs +45 -0
  172. package/templates/nestjs/pro/clean/infra/main.tf.hbs +83 -0
  173. package/templates/nestjs/pro/clean/infra/modules/ecs/main.tf.hbs +54 -0
  174. package/templates/nestjs/pro/clean/infra/modules/rds/main.tf.hbs +88 -0
  175. package/templates/nestjs/pro/clean/infra/modules/vpc/main.tf.hbs +107 -0
  176. package/templates/nestjs/pro/clean/package.json.hbs +37 -0
  177. package/templates/nestjs/pro/clean/src/auth.module.ts.hbs +17 -0
  178. package/templates/nestjs/pro/clean/src/domain/entities/user.entity.ts.hbs +12 -0
  179. package/templates/nestjs/pro/clean/src/domain/repositories/user.repository.ts.hbs +6 -0
  180. package/templates/nestjs/pro/clean/src/domain/use-cases/register.use-case.ts.hbs +18 -0
  181. package/templates/nestjs/pro/clean/src/infrastructure/database/in-memory.repository.ts.hbs +17 -0
  182. package/templates/nestjs/pro/clean/src/infrastructure/http/auth.controller.ts.hbs +16 -0
  183. package/templates/nestjs/pro/clean/tsconfig.json.hbs +21 -0
  184. package/templates/nestjs/pro/hexagonal/.env.example.hbs +19 -0
  185. package/templates/nestjs/pro/hexagonal/.github/workflows/ci-cd.yml.hbs +88 -0
  186. package/templates/nestjs/pro/hexagonal/Dockerfile.hbs +45 -0
  187. package/templates/nestjs/pro/hexagonal/infra/main.tf.hbs +83 -0
  188. package/templates/nestjs/pro/hexagonal/infra/modules/ecs/main.tf.hbs +54 -0
  189. package/templates/nestjs/pro/hexagonal/infra/modules/rds/main.tf.hbs +88 -0
  190. package/templates/nestjs/pro/hexagonal/infra/modules/vpc/main.tf.hbs +107 -0
  191. package/templates/nestjs/pro/hexagonal/package.json.hbs +37 -0
  192. package/templates/nestjs/pro/hexagonal/src/adapters/inbound/http.adapter.ts.hbs +12 -0
  193. package/templates/nestjs/pro/hexagonal/src/adapters/outbound/persistence.adapter.ts.hbs +13 -0
  194. package/templates/nestjs/pro/hexagonal/src/auth.module.ts.hbs +19 -0
  195. package/templates/nestjs/pro/hexagonal/src/core/auth.service.ts.hbs +16 -0
  196. package/templates/nestjs/pro/hexagonal/src/core/domain/user.entity.ts.hbs +8 -0
  197. package/templates/nestjs/pro/hexagonal/src/core/ports/ports.ts.hbs +9 -0
  198. package/templates/nestjs/pro/hexagonal/tsconfig.json.hbs +21 -0
  199. package/templates/nestjs/pro/mvc/.env.example.hbs +19 -0
  200. package/templates/nestjs/pro/mvc/.github/workflows/ci-cd.yml.hbs +88 -0
  201. package/templates/nestjs/pro/mvc/Dockerfile.hbs +45 -0
  202. package/templates/nestjs/pro/mvc/README.md.hbs +28 -0
  203. package/templates/nestjs/pro/mvc/infra/main.tf.hbs +83 -0
  204. package/templates/nestjs/pro/mvc/infra/modules/ecs/main.tf.hbs +54 -0
  205. package/templates/nestjs/pro/mvc/infra/modules/rds/main.tf.hbs +88 -0
  206. package/templates/nestjs/pro/mvc/infra/modules/vpc/main.tf.hbs +107 -0
  207. package/templates/nestjs/pro/mvc/package.json.hbs +37 -0
  208. package/templates/nestjs/pro/mvc/src/app.module.ts.hbs +17 -0
  209. package/templates/nestjs/pro/mvc/src/auth/auth.controller.ts.hbs +35 -0
  210. package/templates/nestjs/pro/mvc/src/auth/auth.module.ts.hbs +25 -0
  211. package/templates/nestjs/pro/mvc/src/auth/auth.service.ts.hbs +55 -0
  212. package/templates/nestjs/pro/mvc/src/auth/jwt.strategy.ts.hbs +19 -0
  213. package/templates/nestjs/pro/mvc/src/controllers/health.controller.ts.hbs +9 -0
  214. package/templates/nestjs/pro/mvc/src/controllers/items.controller.ts.hbs +32 -0
  215. package/templates/nestjs/pro/mvc/src/main.ts.hbs +17 -0
  216. package/templates/nestjs/pro/mvc/src/models/create-item.dto.ts.hbs +10 -0
  217. package/templates/nestjs/pro/mvc/src/models/item.model.ts.hbs +6 -0
  218. package/templates/nestjs/pro/mvc/src/modules/items.module.ts.hbs +9 -0
  219. package/templates/nestjs/pro/mvc/src/payments/payments.controller.ts.hbs +26 -0
  220. package/templates/nestjs/pro/mvc/src/payments/payments.module.ts.hbs +11 -0
  221. package/templates/nestjs/pro/mvc/src/payments/payments.service.ts.hbs +43 -0
  222. package/templates/nestjs/pro/mvc/src/services/items.service.ts.hbs +32 -0
  223. package/templates/nestjs/pro/mvc/tsconfig.json.hbs +21 -0
  224. package/templates/nextjs/free/default/.env.example.hbs +1 -0
  225. package/templates/nextjs/free/default/.gitignore.hbs +8 -0
  226. package/templates/nextjs/free/default/README.md.hbs +96 -0
  227. package/templates/nextjs/free/default/docker-compose.yml.hbs +18 -0
  228. package/templates/nextjs/free/default/next.config.js.hbs +4 -0
  229. package/templates/nextjs/free/default/package.json.hbs +32 -0
  230. package/templates/nextjs/free/default/postcss.config.js.hbs +6 -0
  231. package/templates/nextjs/free/default/prisma/schema.prisma.hbs +18 -0
  232. package/templates/nextjs/free/default/public/.gitkeep +0 -0
  233. package/templates/nextjs/free/default/src/app/api/health/route.ts.hbs +9 -0
  234. package/templates/nextjs/free/default/src/app/globals.css.hbs +3 -0
  235. package/templates/nextjs/free/default/src/app/layout.tsx.hbs +22 -0
  236. package/templates/nextjs/free/default/src/app/page.tsx.hbs +38 -0
  237. package/templates/nextjs/free/default/src/components/.gitkeep +0 -0
  238. package/templates/nextjs/free/default/src/lib/prisma.ts.hbs +13 -0
  239. package/templates/nextjs/free/default/src/proxy.ts.hbs +22 -0
  240. package/templates/nextjs/free/default/tailwind.config.ts.hbs +15 -0
  241. package/templates/nextjs/free/default/template.json +18 -0
  242. package/templates/nextjs/free/default/tsconfig.json.hbs +23 -0
  243. package/templates/nextjs/pro/default/.env.example.hbs +20 -0
  244. package/templates/nextjs/pro/default/.github/workflows/ci-cd.yml.hbs +88 -0
  245. package/templates/nextjs/pro/default/Dockerfile.hbs +45 -0
  246. package/templates/nextjs/pro/default/README.md.hbs +96 -0
  247. package/templates/nextjs/pro/default/docker-compose.yml.hbs +18 -0
  248. package/templates/nextjs/pro/default/infra/main.tf.hbs +83 -0
  249. package/templates/nextjs/pro/default/infra/modules/ecs/main.tf.hbs +54 -0
  250. package/templates/nextjs/pro/default/infra/modules/rds/main.tf.hbs +88 -0
  251. package/templates/nextjs/pro/default/infra/modules/vpc/main.tf.hbs +107 -0
  252. package/templates/nextjs/pro/default/next.config.js.hbs +4 -0
  253. package/templates/nextjs/pro/default/package.json.hbs +34 -0
  254. package/templates/nextjs/pro/default/postcss.config.js.hbs +6 -0
  255. package/templates/nextjs/pro/default/prisma/schema.prisma.hbs +18 -0
  256. package/templates/nextjs/pro/default/public/.gitkeep +0 -0
  257. package/templates/nextjs/pro/default/src/app/api/auth/[...nextauth]/route.ts.hbs +61 -0
  258. package/templates/nextjs/pro/default/src/app/api/checkout/route.ts.hbs +30 -0
  259. package/templates/nextjs/pro/default/src/app/api/health/route.ts.hbs +9 -0
  260. package/templates/nextjs/pro/default/src/app/api/webhook/route.ts.hbs +51 -0
  261. package/templates/nextjs/pro/default/src/app/dashboard/page.tsx.hbs +52 -0
  262. package/templates/nextjs/pro/default/src/app/globals.css.hbs +3 -0
  263. package/templates/nextjs/pro/default/src/app/layout.tsx.hbs +22 -0
  264. package/templates/nextjs/pro/default/src/app/page.tsx.hbs +38 -0
  265. package/templates/nextjs/pro/default/src/components/.gitkeep +0 -0
  266. package/templates/nextjs/pro/default/src/components/AuthButton.tsx.hbs +34 -0
  267. package/templates/nextjs/pro/default/src/components/Providers.tsx.hbs +7 -0
  268. package/templates/nextjs/pro/default/src/lib/prisma.ts.hbs +13 -0
  269. package/templates/nextjs/pro/default/src/proxy.ts.hbs +22 -0
  270. package/templates/nextjs/pro/default/tailwind.config.ts.hbs +15 -0
  271. package/templates/nextjs/pro/default/template.json +18 -0
  272. package/templates/nextjs/pro/default/tsconfig.json.hbs +40 -0
  273. package/templates/nodejs-express/free/mvc/.env.example.hbs +3 -0
  274. package/templates/nodejs-express/free/mvc/.gitignore.hbs +6 -0
  275. package/templates/nodejs-express/free/mvc/README.md.hbs +128 -0
  276. package/templates/nodejs-express/free/mvc/docker-compose.yml.hbs +18 -0
  277. package/templates/nodejs-express/free/mvc/package.json.hbs +39 -0
  278. package/templates/nodejs-express/free/mvc/src/app.ts.hbs +29 -0
  279. package/templates/nodejs-express/free/mvc/src/config/database.ts.hbs +10 -0
  280. package/templates/nodejs-express/free/mvc/src/controllers/healthController.ts.hbs +20 -0
  281. package/templates/nodejs-express/free/mvc/src/index.ts.hbs +12 -0
  282. package/templates/nodejs-express/free/mvc/src/middleware/errorHandler.ts.hbs +22 -0
  283. package/templates/nodejs-express/free/mvc/src/models/.gitkeep +0 -0
  284. package/templates/nodejs-express/free/mvc/src/routes/index.ts.hbs +14 -0
  285. package/templates/nodejs-express/free/mvc/src/services/.gitkeep +0 -0
  286. package/templates/nodejs-express/free/mvc/template.json +18 -0
  287. package/templates/nodejs-express/free/mvc/tsconfig.json.hbs +18 -0
  288. package/templates/nodejs-express/pro/clean/.env.example.hbs +19 -0
  289. package/templates/nodejs-express/pro/clean/.github/workflows/ci-cd.yml.hbs +88 -0
  290. package/templates/nodejs-express/pro/clean/Dockerfile.hbs +45 -0
  291. package/templates/nodejs-express/pro/clean/README.md.hbs +41 -0
  292. package/templates/nodejs-express/pro/clean/docker-compose.yml.hbs +18 -0
  293. package/templates/nodejs-express/pro/clean/infra/main.tf.hbs +83 -0
  294. package/templates/nodejs-express/pro/clean/infra/modules/ecs/main.tf.hbs +54 -0
  295. package/templates/nodejs-express/pro/clean/infra/modules/rds/main.tf.hbs +88 -0
  296. package/templates/nodejs-express/pro/clean/infra/modules/vpc/main.tf.hbs +107 -0
  297. package/templates/nodejs-express/pro/clean/package.json.hbs +55 -0
  298. package/templates/nodejs-express/pro/clean/src/application/services/AuthService.ts.hbs +66 -0
  299. package/templates/nodejs-express/pro/clean/src/domain/entities/User.ts.hbs +38 -0
  300. package/templates/nodejs-express/pro/clean/src/domain/repositories/IUserRepository.ts.hbs +13 -0
  301. package/templates/nodejs-express/pro/clean/src/domain/usecases/LoginUserUseCase.ts.hbs +39 -0
  302. package/templates/nodejs-express/pro/clean/src/domain/usecases/RegisterUserUseCase.ts.hbs +51 -0
  303. package/templates/nodejs-express/pro/clean/src/index.ts.hbs +40 -0
  304. package/templates/nodejs-express/pro/clean/src/infrastructure/database/InMemoryUserRepository.ts.hbs +46 -0
  305. package/templates/nodejs-express/pro/clean/src/infrastructure/http/controllers/AuthController.ts.hbs +45 -0
  306. package/templates/nodejs-express/pro/clean/src/infrastructure/http/middlewares/AuthMiddleware.ts.hbs +27 -0
  307. package/templates/nodejs-express/pro/clean/src/infrastructure/providers/PasswordHasher.ts.hbs +14 -0
  308. package/templates/nodejs-express/pro/clean/src/infrastructure/providers/TokenGenerator.ts.hbs +25 -0
  309. package/templates/nodejs-express/pro/clean/tsconfig.json.hbs +27 -0
  310. package/templates/nodejs-express/pro/hexagonal/.env.example.hbs +19 -0
  311. package/templates/nodejs-express/pro/hexagonal/.github/workflows/ci-cd.yml.hbs +88 -0
  312. package/templates/nodejs-express/pro/hexagonal/Dockerfile.hbs +45 -0
  313. package/templates/nodejs-express/pro/hexagonal/README.md.hbs +42 -0
  314. package/templates/nodejs-express/pro/hexagonal/docker-compose.yml.hbs +18 -0
  315. package/templates/nodejs-express/pro/hexagonal/infra/main.tf.hbs +83 -0
  316. package/templates/nodejs-express/pro/hexagonal/infra/modules/ecs/main.tf.hbs +54 -0
  317. package/templates/nodejs-express/pro/hexagonal/infra/modules/rds/main.tf.hbs +88 -0
  318. package/templates/nodejs-express/pro/hexagonal/infra/modules/vpc/main.tf.hbs +107 -0
  319. package/templates/nodejs-express/pro/hexagonal/package.json.hbs +55 -0
  320. package/templates/nodejs-express/pro/hexagonal/src/adapters/inbound/http/AuthController.ts.hbs +48 -0
  321. package/templates/nodejs-express/pro/hexagonal/src/adapters/outbound/SecurityAdapters.ts.hbs +31 -0
  322. package/templates/nodejs-express/pro/hexagonal/src/adapters/outbound/persistence/InMemoryUserAdapter.ts.hbs +38 -0
  323. package/templates/nodejs-express/pro/hexagonal/src/core/AuthService.ts.hbs +51 -0
  324. package/templates/nodejs-express/pro/hexagonal/src/core/domain/entities/User.ts.hbs +28 -0
  325. package/templates/nodejs-express/pro/hexagonal/src/core/ports/inbound/IAuthPort.ts.hbs +11 -0
  326. package/templates/nodejs-express/pro/hexagonal/src/core/ports/outbound/ISecurityPorts.ts.hbs +15 -0
  327. package/templates/nodejs-express/pro/hexagonal/src/core/ports/outbound/IUserRepositoryPort.ts.hbs +13 -0
  328. package/templates/nodejs-express/pro/hexagonal/src/index.ts.hbs +41 -0
  329. package/templates/nodejs-express/pro/hexagonal/tsconfig.json.hbs +27 -0
  330. package/templates/nodejs-express/pro/mvc/.env.example.hbs +19 -0
  331. package/templates/nodejs-express/pro/mvc/.github/workflows/ci-cd.yml.hbs +88 -0
  332. package/templates/nodejs-express/pro/mvc/Dockerfile.hbs +45 -0
  333. package/templates/nodejs-express/pro/mvc/README.md.hbs +85 -0
  334. package/templates/nodejs-express/pro/mvc/docker-compose.yml.hbs +18 -0
  335. package/templates/nodejs-express/pro/mvc/infra/main.tf.hbs +83 -0
  336. package/templates/nodejs-express/pro/mvc/infra/modules/ecs/main.tf.hbs +54 -0
  337. package/templates/nodejs-express/pro/mvc/infra/modules/rds/main.tf.hbs +88 -0
  338. package/templates/nodejs-express/pro/mvc/infra/modules/vpc/main.tf.hbs +107 -0
  339. package/templates/nodejs-express/pro/mvc/package.json.hbs +55 -0
  340. package/templates/nodejs-express/pro/mvc/src/app.ts.hbs +34 -0
  341. package/templates/nodejs-express/pro/mvc/src/config/database.ts.hbs +10 -0
  342. package/templates/nodejs-express/pro/mvc/src/controllers/auth.controller.ts.hbs +91 -0
  343. package/templates/nodejs-express/pro/mvc/src/controllers/healthController.ts.hbs +20 -0
  344. package/templates/nodejs-express/pro/mvc/src/controllers/payments.controller.ts.hbs +72 -0
  345. package/templates/nodejs-express/pro/mvc/src/index.ts.hbs +12 -0
  346. package/templates/nodejs-express/pro/mvc/src/middleware/errorHandler.ts.hbs +22 -0
  347. package/templates/nodejs-express/pro/mvc/src/middlewares/auth.middleware.ts.hbs +31 -0
  348. package/templates/nodejs-express/pro/mvc/src/models/.gitkeep +0 -0
  349. package/templates/nodejs-express/pro/mvc/src/routes/index.ts.hbs +14 -0
  350. package/templates/nodejs-express/pro/mvc/src/services/.gitkeep +0 -0
  351. package/templates/nodejs-express/pro/mvc/src/services/stripe.service.ts.hbs +102 -0
  352. package/templates/nodejs-express/pro/mvc/template.json +18 -0
  353. package/templates/nodejs-express/pro/mvc/tsconfig.json.hbs +27 -0
  354. package/templates/python-fastapi/free/mvc/README.md.hbs +41 -0
  355. package/templates/python-fastapi/free/mvc/app/controllers/health.py.hbs +7 -0
  356. package/templates/python-fastapi/free/mvc/app/controllers/items.py.hbs +27 -0
  357. package/templates/python-fastapi/free/mvc/app/main.py.hbs +26 -0
  358. package/templates/python-fastapi/free/mvc/app/models/item.py.hbs +11 -0
  359. package/templates/python-fastapi/free/mvc/app/schemas/item.py.hbs +17 -0
  360. package/templates/python-fastapi/free/mvc/app/services/item_service.py.hbs +33 -0
  361. package/templates/python-fastapi/free/mvc/requirements.txt.hbs +4 -0
  362. package/templates/python-fastapi/pro/clean/.env.example.hbs +17 -0
  363. package/templates/python-fastapi/pro/clean/.github/workflows/ci-cd.yml.hbs +88 -0
  364. package/templates/python-fastapi/pro/clean/Dockerfile.hbs +20 -0
  365. package/templates/python-fastapi/pro/clean/app/domain/entities/user.py.hbs +23 -0
  366. package/templates/python-fastapi/pro/clean/app/domain/repositories/user_repository.py.hbs +22 -0
  367. package/templates/python-fastapi/pro/clean/app/domain/usecases/register_user.py.hbs +30 -0
  368. package/templates/python-fastapi/pro/clean/app/infrastructure/database/in_memory_repository.py.hbs +26 -0
  369. package/templates/python-fastapi/pro/clean/app/infrastructure/http/auth_controller.py.hbs +26 -0
  370. package/templates/python-fastapi/pro/clean/app/infrastructure/security/adapters.py.hbs +23 -0
  371. package/templates/python-fastapi/pro/clean/app/main.py.hbs +10 -0
  372. package/templates/python-fastapi/pro/clean/infra/main.tf.hbs +83 -0
  373. package/templates/python-fastapi/pro/clean/infra/modules/ecs/main.tf.hbs +54 -0
  374. package/templates/python-fastapi/pro/clean/infra/modules/rds/main.tf.hbs +88 -0
  375. package/templates/python-fastapi/pro/clean/infra/modules/vpc/main.tf.hbs +107 -0
  376. package/templates/python-fastapi/pro/clean/requirements.txt.hbs +12 -0
  377. package/templates/python-fastapi/pro/hexagonal/.env.example.hbs +17 -0
  378. package/templates/python-fastapi/pro/hexagonal/.github/workflows/ci-cd.yml.hbs +88 -0
  379. package/templates/python-fastapi/pro/hexagonal/Dockerfile.hbs +20 -0
  380. package/templates/python-fastapi/pro/hexagonal/app/adapters/inbound/http_adapter.py.hbs +29 -0
  381. package/templates/python-fastapi/pro/hexagonal/app/core/domain/user.py.hbs +15 -0
  382. package/templates/python-fastapi/pro/hexagonal/app/core/ports.py.hbs +25 -0
  383. package/templates/python-fastapi/pro/hexagonal/app/core/service.py.hbs +28 -0
  384. package/templates/python-fastapi/pro/hexagonal/app/main.py.hbs +22 -0
  385. package/templates/python-fastapi/pro/hexagonal/infra/main.tf.hbs +83 -0
  386. package/templates/python-fastapi/pro/hexagonal/infra/modules/ecs/main.tf.hbs +54 -0
  387. package/templates/python-fastapi/pro/hexagonal/infra/modules/rds/main.tf.hbs +88 -0
  388. package/templates/python-fastapi/pro/hexagonal/infra/modules/vpc/main.tf.hbs +107 -0
  389. package/templates/python-fastapi/pro/hexagonal/requirements.txt.hbs +12 -0
  390. package/templates/python-fastapi/pro/mvc/.env.example.hbs +17 -0
  391. package/templates/python-fastapi/pro/mvc/.github/workflows/ci-cd.yml.hbs +88 -0
  392. package/templates/python-fastapi/pro/mvc/Dockerfile.hbs +20 -0
  393. package/templates/python-fastapi/pro/mvc/README.md.hbs +41 -0
  394. package/templates/python-fastapi/pro/mvc/app/controllers/auth.py.hbs +46 -0
  395. package/templates/python-fastapi/pro/mvc/app/controllers/health.py.hbs +7 -0
  396. package/templates/python-fastapi/pro/mvc/app/controllers/items.py.hbs +21 -0
  397. package/templates/python-fastapi/pro/mvc/app/controllers/payments.py.hbs +32 -0
  398. package/templates/python-fastapi/pro/mvc/app/main.py.hbs +20 -0
  399. package/templates/python-fastapi/pro/mvc/app/middleware/security.py.hbs +39 -0
  400. package/templates/python-fastapi/pro/mvc/app/models/item.py.hbs +11 -0
  401. package/templates/python-fastapi/pro/mvc/app/schemas/item.py.hbs +16 -0
  402. package/templates/python-fastapi/pro/mvc/app/services/item_service.py.hbs +24 -0
  403. package/templates/python-fastapi/pro/mvc/infra/main.tf.hbs +83 -0
  404. package/templates/python-fastapi/pro/mvc/infra/modules/ecs/main.tf.hbs +54 -0
  405. package/templates/python-fastapi/pro/mvc/infra/modules/rds/main.tf.hbs +88 -0
  406. package/templates/python-fastapi/pro/mvc/infra/modules/vpc/main.tf.hbs +107 -0
  407. package/templates/python-fastapi/pro/mvc/requirements.txt.hbs +12 -0
@@ -0,0 +1,55 @@
1
+ {
2
+ "name": "{{kebabCase projectName}}",
3
+ "version": "1.0.0",
4
+ "description": "Generated by Kybernus CLI (Pro)",
5
+ "main": "dist/index.js",
6
+ "scripts": {
7
+ "dev": "tsx watch src/index.ts",
8
+ "build": "rimraf dist && tsc",
9
+ "start": "node dist/index.js",
10
+ "lint": "eslint src --ext .ts",
11
+ "format": "prettier --write \"src/**/*.ts\"",
12
+ "test": "jest"
13
+ },
14
+ "keywords": [
15
+ "express",
16
+ "api",
17
+ "typescript",
18
+ "mvc",
19
+ "saas",
20
+ "stripe",
21
+ "auth"
22
+ ],
23
+ "author": "",
24
+ "license": "MIT",
25
+ "dependencies": {
26
+ "express": "^4.18.2",
27
+ "dotenv": "^16.4.5",
28
+ "cors": "^2.8.5",
29
+ "helmet": "^7.1.0",
30
+ "morgan": "^1.10.0",
31
+ "jsonwebtoken": "^9.0.2",
32
+ "bcryptjs": "^2.4.3",
33
+ "stripe": "^14.14.0"
34
+ },
35
+ "devDependencies": {
36
+ "@types/express": "^4.17.21",
37
+ "@types/node": "^20.11.19",
38
+ "@types/cors": "^2.8.17",
39
+ "@types/morgan": "^1.9.9",
40
+ "@types/jsonwebtoken": "^9.0.5",
41
+ "@types/bcryptjs": "^2.4.6",
42
+ "typescript": "^5.3.3",
43
+ "tsx": "^4.7.1",
44
+ "rimraf": "^5.0.5",
45
+ "eslint": "^8.56.0",
46
+ "@typescript-eslint/eslint-plugin": "^6.21.0",
47
+ "@typescript-eslint/parser": "^6.21.0",
48
+ "prettier": "^3.2.5",
49
+ "jest": "^29.7.0",
50
+ "@types/jest": "^29.5.12"
51
+ },
52
+ "engines": {
53
+ "node": ">=18.0.0"
54
+ }
55
+ }
@@ -0,0 +1,66 @@
1
+ import { IUserRepository } from '../../domain/repositories/IUserRepository';
2
+ import { RegisterUserUseCase } from '../../domain/usecases/RegisterUserUseCase';
3
+ import { LoginUserUseCase } from '../../domain/usecases/LoginUserUseCase';
4
+
5
+ export interface RegisterDTO {
6
+ email: string;
7
+ name: string;
8
+ password: string;
9
+ }
10
+
11
+ export interface LoginDTO {
12
+ email: string;
13
+ password: string;
14
+ }
15
+
16
+ export interface AuthResponseDTO {
17
+ token: string;
18
+ user: {
19
+ id: string;
20
+ email: string;
21
+ name: string;
22
+ };
23
+ }
24
+
25
+ /**
26
+ * Auth Service - Application Layer
27
+ * Orchestrates use cases and handles DTOs
28
+ */
29
+ export class AuthService {
30
+ private registerUseCase: RegisterUserUseCase;
31
+ private loginUseCase: LoginUserUseCase;
32
+
33
+ constructor(
34
+ userRepository: IUserRepository,
35
+ passwordHasher: { hash: (password: string) => Promise<string>; compare: (password: string, hash: string) => Promise
36
+ <boolean> },
37
+ tokenGenerator: { generate: (userId: string, email: string) => string }
38
+ ) {
39
+ this.registerUseCase = new RegisterUserUseCase(userRepository, passwordHasher, tokenGenerator);
40
+ this.loginUseCase = new LoginUserUseCase(userRepository, passwordHasher, tokenGenerator);
41
+ }
42
+
43
+ async register(dto: RegisterDTO): Promise<AuthResponseDTO> {
44
+ const result = await this.registerUseCase.execute(dto);
45
+ return {
46
+ token: result.token,
47
+ user: {
48
+ id: result.user.id!,
49
+ email: result.user.email,
50
+ name: result.user.name,
51
+ },
52
+ };
53
+ }
54
+
55
+ async login(dto: LoginDTO): Promise<AuthResponseDTO> {
56
+ const result = await this.loginUseCase.execute(dto);
57
+ return {
58
+ token: result.token,
59
+ user: {
60
+ id: result.user.id!,
61
+ email: result.user.email,
62
+ name: result.user.name,
63
+ },
64
+ };
65
+ }
66
+ }
@@ -0,0 +1,38 @@
1
+ /**
2
+ * User Entity - Domain Layer
3
+ * Pure business logic, no framework dependencies
4
+ */
5
+ export interface UserProps {
6
+ id?: string;
7
+ email: string;
8
+ name: string;
9
+ password: string;
10
+ stripeCustomerId?: string;
11
+ createdAt?: Date;
12
+ updatedAt?: Date;
13
+ }
14
+
15
+ export class User {
16
+ private props: UserProps;
17
+
18
+ private constructor(props: UserProps) {
19
+ this.props = {
20
+ ...props,
21
+ createdAt: props.createdAt || new Date(),
22
+ updatedAt: props.updatedAt || new Date(),
23
+ };
24
+ }
25
+
26
+ static create(props: UserProps): User {
27
+ // Domain validation
28
+ if (!props.email || !props.email.includes('@')) {
29
+ throw new Error('Invalid email format');
30
+ }
31
+ if (!props.password || props.password.length < 8) { throw new Error('Password must be at least 8 characters'); } return
32
+ new User(props); } static restore(props: UserProps): User { return new User(props); } get id(): string | undefined {
33
+ return this.props.id; } get email(): string { return this.props.email; } get name(): string { return
34
+ this.props.name; } get password(): string { return this.props.password; } get stripeCustomerId(): string | undefined
35
+ { return this.props.stripeCustomerId; } setStripeCustomerId(customerId: string): void {
36
+ this.props.stripeCustomerId=customerId; this.props.updatedAt=new Date(); } toJSON() { return { id: this.props.id,
37
+ email: this.props.email, name: this.props.name, stripeCustomerId: this.props.stripeCustomerId, createdAt:
38
+ this.props.createdAt, updatedAt: this.props.updatedAt, }; } }
@@ -0,0 +1,13 @@
1
+ import { User } from '../entities/User';
2
+
3
+ /**
4
+ * User Repository Interface - Domain Layer
5
+ * Defines the contract for user persistence
6
+ */
7
+ export interface IUserRepository {
8
+ findById(id: string): Promise<User | null>;
9
+ findByEmail(email: string): Promise<User | null>;
10
+ save(user: User): Promise<User>;
11
+ update(user: User): Promise<User>;
12
+ delete(id: string): Promise<void>;
13
+ }
@@ -0,0 +1,39 @@
1
+ import { User } from '../entities/User';
2
+ import { IUserRepository } from '../repositories/IUserRepository';
3
+
4
+ export interface LoginUserInput {
5
+ email: string;
6
+ password: string;
7
+ }
8
+
9
+ export interface LoginUserOutput {
10
+ user: User;
11
+ token: string;
12
+ }
13
+
14
+ /**
15
+ * Login User Use Case - Domain Layer
16
+ */
17
+ export class LoginUserUseCase {
18
+ constructor(
19
+ private userRepository: IUserRepository,
20
+ private passwordHasher: { compare: (password: string, hash: string) => Promise<boolean> },
21
+ private tokenGenerator: { generate: (userId: string, email: string) => string }
22
+ ) {}
23
+
24
+ async execute(input: LoginUserInput): Promise<LoginUserOutput> {
25
+ const user = await this.userRepository.findByEmail(input.email);
26
+ if (!user) {
27
+ throw new Error('Invalid credentials');
28
+ }
29
+
30
+ const isValidPassword = await this.passwordHasher.compare(input.password, user.password);
31
+ if (!isValidPassword) {
32
+ throw new Error('Invalid credentials');
33
+ }
34
+
35
+ const token = this.tokenGenerator.generate(user.id!, user.email);
36
+
37
+ return { user, token };
38
+ }
39
+ }
@@ -0,0 +1,51 @@
1
+ import { User } from '../entities/User';
2
+ import { IUserRepository } from '../repositories/IUserRepository';
3
+
4
+ export interface RegisterUserInput {
5
+ email: string;
6
+ name: string;
7
+ password: string;
8
+ }
9
+
10
+ export interface RegisterUserOutput {
11
+ user: User;
12
+ token: string;
13
+ }
14
+
15
+ /**
16
+ * Register User Use Case - Domain Layer
17
+ * Pure business logic for user registration
18
+ */
19
+ export class RegisterUserUseCase {
20
+ constructor(
21
+ private userRepository: IUserRepository,
22
+ private passwordHasher: { hash: (password: string) => Promise<string> },
23
+ private tokenGenerator: { generate: (userId: string, email: string) => string }
24
+ ) {}
25
+
26
+ async execute(input: RegisterUserInput): Promise<RegisterUserOutput> {
27
+ // Check if user already exists
28
+ const existingUser = await this.userRepository.findByEmail(input.email);
29
+ if (existingUser) {
30
+ throw new Error('User already exists');
31
+ }
32
+
33
+ // Hash password
34
+ const hashedPassword = await this.passwordHasher.hash(input.password);
35
+
36
+ // Create user entity
37
+ const user = User.create({
38
+ email: input.email,
39
+ name: input.name,
40
+ password: hashedPassword,
41
+ });
42
+
43
+ // Persist user
44
+ const savedUser = await this.userRepository.save(user);
45
+
46
+ // Generate token
47
+ const token = this.tokenGenerator.generate(savedUser.id!, savedUser.email);
48
+
49
+ return { user: savedUser, token };
50
+ }
51
+ }
@@ -0,0 +1,40 @@
1
+ import express from 'express';
2
+ import cors from 'cors';
3
+ import helmet from 'helmet';
4
+ import morgan from 'morgan';
5
+ import dotenv from 'dotenv';
6
+
7
+ import authRoutes from './infrastructure/http/controllers/AuthController';
8
+
9
+ dotenv.config();
10
+
11
+ const app = express();
12
+
13
+ // Security
14
+ app.use(helmet());
15
+ app.use(cors());
16
+ app.use(morgan('dev'));
17
+
18
+ // Body parsing
19
+ app.use(express.json());
20
+ app.use(express.urlencoded({ extended: true }));
21
+
22
+ // Health check
23
+ app.get('/health', (_, res) => res.json({ status: 'ok' }));
24
+
25
+ // Routes
26
+ app.use('/api/auth', authRoutes);
27
+
28
+ // Error handling
29
+ app.use((err: any, req: express.Request, res: express.Response, next: express.NextFunction) => {
30
+ console.error(err.stack);
31
+ res.status(500).json({ error: 'Internal server error' });
32
+ });
33
+
34
+ const PORT = process.env.PORT || 3000;
35
+
36
+ app.listen(PORT, () => {
37
+ console.log(`🚀 {{pascalCase projectName}} running on port ${PORT}`);
38
+ console.log(`📐 Architecture: Clean Architecture`);
39
+ console.log(`🔗 Health check: http://localhost:${PORT}/health`);
40
+ });
@@ -0,0 +1,46 @@
1
+ import { User } from '../../domain/entities/User';
2
+ import { IUserRepository } from '../../domain/repositories/IUserRepository';
3
+
4
+ /**
5
+ * In-Memory User Repository - Infrastructure Layer
6
+ * Replace with actual database implementation (Prisma, TypeORM, etc.)
7
+ */
8
+ export class InMemoryUserRepository implements IUserRepository {
9
+ private users: Map<string, User> = new Map();
10
+
11
+ async findById(id: string): Promise<User | null> {
12
+ return this.users.get(id) || null;
13
+ }
14
+
15
+ async findByEmail(email: string): Promise<User | null> {
16
+ for (const user of this.users.values()) {
17
+ if (user.email === email) {
18
+ return user;
19
+ }
20
+ }
21
+ return null;
22
+ }
23
+
24
+ async save(user: User): Promise<User> {
25
+ const id = Date.now().toString();
26
+ const savedUser = User.restore({
27
+ id,
28
+ email: user.email,
29
+ name: user.name,
30
+ password: user.password,
31
+ stripeCustomerId: user.stripeCustomerId,
32
+ });
33
+ this.users.set(id, savedUser);
34
+ return savedUser;
35
+ }
36
+
37
+ async update(user: User): Promise<User> {
38
+ if (!user.id) throw new Error('User must have an ID to update');
39
+ this.users.set(user.id, user);
40
+ return user;
41
+ }
42
+
43
+ async delete(id: string): Promise<void> {
44
+ this.users.delete(id);
45
+ }
46
+ }
@@ -0,0 +1,45 @@
1
+ import { Router, Request, Response } from 'express';
2
+ import { AuthService } from '../../../application/services/AuthService';
3
+ import { InMemoryUserRepository } from '../../database/InMemoryUserRepository';
4
+ import { bcryptPasswordHasher } from '../../providers/PasswordHasher';
5
+ import { jwtTokenGenerator } from '../../providers/TokenGenerator';
6
+ import { authMiddleware, AuthRequest } from '../middlewares/AuthMiddleware';
7
+
8
+ const router = Router();
9
+
10
+ // Dependency Injection
11
+ const userRepository = new InMemoryUserRepository();
12
+ const authService = new AuthService(userRepository, bcryptPasswordHasher, jwtTokenGenerator);
13
+
14
+ /**
15
+ * @route POST /api/auth/register
16
+ */
17
+ router.post('/register', async (req: Request, res: Response) => {
18
+ try {
19
+ const result = await authService.register(req.body);
20
+ res.status(201).json(result);
21
+ } catch (error: any) {
22
+ res.status(400).json({ error: error.message });
23
+ }
24
+ });
25
+
26
+ /**
27
+ * @route POST /api/auth/login
28
+ */
29
+ router.post('/login', async (req: Request, res: Response) => {
30
+ try {
31
+ const result = await authService.login(req.body);
32
+ res.json(result);
33
+ } catch (error: any) {
34
+ res.status(401).json({ error: error.message });
35
+ }
36
+ });
37
+
38
+ /**
39
+ * @route GET /api/auth/me
40
+ */
41
+ router.get('/me', authMiddleware, (req: AuthRequest, res: Response) => {
42
+ res.json({ user: req.user });
43
+ });
44
+
45
+ export default router;
@@ -0,0 +1,27 @@
1
+ import { Request, Response, NextFunction } from 'express';
2
+ import { jwtTokenGenerator } from '../../providers/TokenGenerator';
3
+
4
+ export interface AuthRequest extends Request {
5
+ user?: {
6
+ id: string;
7
+ email: string;
8
+ };
9
+ }
10
+
11
+ export function authMiddleware(req: AuthRequest, res: Response, next: NextFunction) {
12
+ const authHeader = req.headers.authorization;
13
+
14
+ if (!authHeader || !authHeader.startsWith('Bearer ')) {
15
+ return res.status(401).json({ error: 'Token not provided' });
16
+ }
17
+
18
+ const token = authHeader.split(' ')[1];
19
+ const decoded = jwtTokenGenerator.verify(token);
20
+
21
+ if (!decoded) {
22
+ return res.status(401).json({ error: 'Invalid token' });
23
+ }
24
+
25
+ req.user = decoded;
26
+ next();
27
+ }
@@ -0,0 +1,14 @@
1
+ import bcrypt from 'bcryptjs';
2
+
3
+ /**
4
+ * Bcrypt Password Hasher - Infrastructure Provider
5
+ */
6
+ export const bcryptPasswordHasher = {
7
+ async hash(password: string): Promise<string> {
8
+ return bcrypt.hash(password, 10);
9
+ },
10
+
11
+ async compare(password: string, hash: string): Promise<boolean> {
12
+ return bcrypt.compare(password, hash);
13
+ },
14
+ };
@@ -0,0 +1,25 @@
1
+ import jwt from 'jsonwebtoken';
2
+
3
+ /**
4
+ * JWT Token Generator - Infrastructure Provider
5
+ */
6
+ export const jwtTokenGenerator = {
7
+ generate(userId: string, email: string): string {
8
+ return jwt.sign(
9
+ { id: userId, email },
10
+ process.env.JWT_SECRET || 'your-secret-key',
11
+ { expiresIn: '7d' }
12
+ );
13
+ },
14
+
15
+ verify(token: string): { id: string; email: string } | null {
16
+ try {
17
+ return jwt.verify(token, process.env.JWT_SECRET || 'your-secret-key') as {
18
+ id: string;
19
+ email: string;
20
+ };
21
+ } catch {
22
+ return null;
23
+ }
24
+ },
25
+ };
@@ -0,0 +1,27 @@
1
+ {
2
+ "compilerOptions": {
3
+ "target": "ES2022",
4
+ "module": "commonjs",
5
+ "lib": [
6
+ "ES2022"
7
+ ],
8
+ "outDir": "./dist",
9
+ "rootDir": "./src",
10
+ "strict": true,
11
+ "esModuleInterop": true,
12
+ "skipLibCheck": true,
13
+ "forceConsistentCasingInFileNames": true,
14
+ "resolveJsonModule": true,
15
+ "moduleResolution": "node",
16
+ "types": [
17
+ "node"
18
+ ]
19
+ },
20
+ "include": [
21
+ "src/**/*"
22
+ ],
23
+ "exclude": [
24
+ "node_modules",
25
+ "dist"
26
+ ]
27
+ }
@@ -0,0 +1,19 @@
1
+ # {{projectName}} Environment Variables
2
+
3
+ # Server
4
+ NODE_ENV=development
5
+ PORT=3000
6
+
7
+ # Database
8
+ DATABASE_URL=postgresql://postgres:postgres@localhost:5432/{{projectNameSnakeCase}}
9
+
10
+ # Authentication
11
+ JWT_SECRET=your-super-secret-jwt-key-change-in-production
12
+
13
+ # Stripe
14
+ STRIPE_SECRET_KEY=sk_test_your_stripe_secret_key
15
+ STRIPE_WEBHOOK_SECRET=whsec_your_webhook_secret
16
+ STRIPE_PRICE_ID=price_your_price_id
17
+
18
+ # Frontend URL (for redirects)
19
+ FRONTEND_URL=http://localhost:3001
@@ -0,0 +1,88 @@
1
+ name: CI/CD Pipeline
2
+
3
+ on:
4
+ push:
5
+ branches: [main, develop]
6
+ pull_request:
7
+ branches: [main]
8
+
9
+ env:
10
+ NODE_VERSION: '20'
11
+ AWS_REGION: 'us-east-1'
12
+
13
+ jobs:
14
+ test:
15
+ runs-on: ubuntu-latest
16
+
17
+ steps:
18
+ - uses: actions/checkout@v4
19
+
20
+ - name: Setup Node.js
21
+ uses: actions/setup-node@v4
22
+ with:
23
+ node-version: $\{{ env.NODE_VERSION }}
24
+ cache: 'npm'
25
+
26
+ - name: Install dependencies
27
+ run: npm ci
28
+
29
+ - name: Run linter
30
+ run: npm run lint --if-present
31
+
32
+ - name: Run tests
33
+ run: npm test --if-present
34
+
35
+ - name: Build
36
+ run: npm run build
37
+
38
+ build-and-push:
39
+ needs: test
40
+ runs-on: ubuntu-latest
41
+ if: github.ref == 'refs/heads/main'
42
+
43
+ steps:
44
+ - uses: actions/checkout@v4
45
+
46
+ - name: Configure AWS credentials
47
+ uses: aws-actions/configure-aws-credentials@v4
48
+ with:
49
+ aws-access-key-id: $\{{ secrets.AWS_ACCESS_KEY_ID }}
50
+ aws-secret-access-key: $\{{ secrets.AWS_SECRET_ACCESS_KEY }}
51
+ aws-region: $\{{ env.AWS_REGION }}
52
+
53
+ - name: Login to Amazon ECR
54
+ id: login-ecr
55
+ uses: aws-actions/amazon-ecr-login@v2
56
+
57
+ - name: Build, tag, and push image to Amazon ECR
58
+ env:
59
+ ECR_REGISTRY: $\{{ steps.login-ecr.outputs.registry }}
60
+ ECR_REPOSITORY: {{projectNameKebabCase}}
61
+ IMAGE_TAG: $\{{ github.sha }}
62
+ run: |
63
+ docker build -t $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG .
64
+ docker build -t $ECR_REGISTRY/$ECR_REPOSITORY:latest .
65
+ docker push $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG
66
+ docker push $ECR_REGISTRY/$ECR_REPOSITORY:latest
67
+
68
+ deploy:
69
+ needs: build-and-push
70
+ runs-on: ubuntu-latest
71
+ if: github.ref == 'refs/heads/main'
72
+
73
+ steps:
74
+ - uses: actions/checkout@v4
75
+
76
+ - name: Configure AWS credentials
77
+ uses: aws-actions/configure-aws-credentials@v4
78
+ with:
79
+ aws-access-key-id: $\{{ secrets.AWS_ACCESS_KEY_ID }}
80
+ aws-secret-access-key: $\{{ secrets.AWS_SECRET_ACCESS_KEY }}
81
+ aws-region: $\{{ env.AWS_REGION }}
82
+
83
+ - name: Deploy to ECS
84
+ run: |
85
+ aws ecs update-service \
86
+ --cluster {{projectNameKebabCase}}-prod \
87
+ --service {{projectNameKebabCase}}-api \
88
+ --force-new-deployment
@@ -0,0 +1,45 @@
1
+ # Production Dockerfile for {{projectName}}
2
+
3
+ # Build stage
4
+ FROM node:20-alpine AS builder
5
+
6
+ WORKDIR /app
7
+
8
+ # Copy package files
9
+ COPY package*.json ./
10
+
11
+ # Install dependencies
12
+ RUN npm ci --only=production
13
+
14
+ # Copy source code
15
+ COPY . .
16
+
17
+ # Build TypeScript
18
+ RUN npm run build
19
+
20
+ # Production stage
21
+ FROM node:20-alpine AS production
22
+
23
+ WORKDIR /app
24
+
25
+ # Create non-root user
26
+ RUN addgroup -g 1001 -S nodejs && \
27
+ adduser -S nodejs -u 1001
28
+
29
+ # Copy built application
30
+ COPY --from=builder --chown=nodejs:nodejs /app/dist ./dist
31
+ COPY --from=builder --chown=nodejs:nodejs /app/node_modules ./node_modules
32
+ COPY --from=builder --chown=nodejs:nodejs /app/package.json ./
33
+
34
+ # Switch to non-root user
35
+ USER nodejs
36
+
37
+ # Expose port
38
+ EXPOSE 3000
39
+
40
+ # Health check
41
+ HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
42
+ CMD wget --no-verbose --tries=1 --spider http://localhost:3000/health || exit 1
43
+
44
+ # Start application
45
+ CMD ["node", "dist/index.js"]