nodejs-quickstart-structure 1.18.1 → 1.19.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 (235) hide show
  1. package/CHANGELOG.md +309 -294
  2. package/LICENSE +15 -15
  3. package/README.md +2 -1
  4. package/lib/generator.js +139 -139
  5. package/lib/modules/app-setup.js +401 -401
  6. package/lib/modules/caching-setup.js +76 -73
  7. package/lib/modules/config-files.js +151 -151
  8. package/lib/modules/database-setup.js +116 -116
  9. package/lib/modules/kafka-setup.js +249 -191
  10. package/lib/modules/project-setup.js +32 -31
  11. package/lib/prompts.js +100 -100
  12. package/package.json +78 -67
  13. package/templates/clean-architecture/js/src/domain/models/User.js +9 -9
  14. package/templates/clean-architecture/js/src/errors/ApiError.js +14 -14
  15. package/templates/clean-architecture/js/src/errors/BadRequestError.js +11 -10
  16. package/templates/clean-architecture/js/src/errors/BadRequestError.spec.js.ejs +22 -21
  17. package/templates/clean-architecture/js/src/errors/NotFoundError.js +11 -10
  18. package/templates/clean-architecture/js/src/errors/NotFoundError.spec.js.ejs +22 -21
  19. package/templates/clean-architecture/js/src/index.js.ejs +55 -55
  20. package/templates/clean-architecture/js/src/infrastructure/config/env.js.ejs +47 -47
  21. package/templates/clean-architecture/js/src/infrastructure/log/logger.js +36 -36
  22. package/templates/clean-architecture/js/src/infrastructure/log/logger.spec.js.ejs +63 -63
  23. package/templates/clean-architecture/js/src/infrastructure/repositories/UserRepository.js.ejs +69 -39
  24. package/templates/clean-architecture/js/src/infrastructure/repositories/UserRepository.spec.js.ejs +142 -81
  25. package/templates/clean-architecture/js/src/infrastructure/webserver/middleware/errorMiddleware.js +30 -30
  26. package/templates/clean-architecture/js/src/infrastructure/webserver/server.js.ejs +89 -89
  27. package/templates/clean-architecture/js/src/infrastructure/webserver/swagger.js.ejs +6 -6
  28. package/templates/clean-architecture/js/src/interfaces/controllers/userController.js.ejs +156 -75
  29. package/templates/clean-architecture/js/src/interfaces/controllers/userController.spec.js.ejs +234 -138
  30. package/templates/clean-architecture/js/src/interfaces/graphql/context.js.ejs +13 -13
  31. package/templates/clean-architecture/js/src/interfaces/graphql/context.spec.js.ejs +31 -31
  32. package/templates/clean-architecture/js/src/interfaces/graphql/index.js.ejs +5 -5
  33. package/templates/clean-architecture/js/src/interfaces/graphql/resolvers/index.js.ejs +6 -6
  34. package/templates/clean-architecture/js/src/interfaces/graphql/resolvers/user.resolvers.js.ejs +27 -21
  35. package/templates/clean-architecture/js/src/interfaces/graphql/resolvers/user.resolvers.spec.js.ejs +66 -49
  36. package/templates/clean-architecture/js/src/interfaces/graphql/typeDefs/index.js.ejs +6 -6
  37. package/templates/clean-architecture/js/src/interfaces/graphql/typeDefs/user.types.js.ejs +19 -17
  38. package/templates/clean-architecture/js/src/interfaces/routes/api.js +12 -10
  39. package/templates/clean-architecture/js/src/interfaces/routes/api.spec.js.ejs +38 -38
  40. package/templates/clean-architecture/js/src/usecases/CreateUser.js +14 -14
  41. package/templates/clean-architecture/js/src/usecases/CreateUser.spec.js.ejs +51 -51
  42. package/templates/clean-architecture/js/src/usecases/DeleteUser.js +11 -0
  43. package/templates/clean-architecture/js/src/usecases/DeleteUser.spec.js.ejs +47 -0
  44. package/templates/clean-architecture/js/src/usecases/GetAllUsers.js +12 -12
  45. package/templates/clean-architecture/js/src/usecases/GetAllUsers.spec.js.ejs +61 -61
  46. package/templates/clean-architecture/js/src/usecases/UpdateUser.js +11 -0
  47. package/templates/clean-architecture/js/src/usecases/UpdateUser.spec.js.ejs +48 -0
  48. package/templates/clean-architecture/js/src/utils/errorMessages.js +14 -0
  49. package/templates/clean-architecture/js/src/utils/httpCodes.js +9 -9
  50. package/templates/clean-architecture/ts/src/config/env.ts.ejs +46 -46
  51. package/templates/clean-architecture/ts/src/config/swagger.ts.ejs +6 -6
  52. package/templates/clean-architecture/ts/src/domain/user.ts +7 -7
  53. package/templates/clean-architecture/ts/src/errors/ApiError.ts +15 -15
  54. package/templates/clean-architecture/ts/src/errors/BadRequestError.spec.ts.ejs +22 -21
  55. package/templates/clean-architecture/ts/src/errors/BadRequestError.ts +9 -8
  56. package/templates/clean-architecture/ts/src/errors/NotFoundError.spec.ts.ejs +22 -21
  57. package/templates/clean-architecture/ts/src/errors/NotFoundError.ts +9 -8
  58. package/templates/clean-architecture/ts/src/index.ts.ejs +139 -139
  59. package/templates/clean-architecture/ts/src/infrastructure/log/logger.spec.ts.ejs +63 -63
  60. package/templates/clean-architecture/ts/src/infrastructure/log/logger.ts +36 -36
  61. package/templates/clean-architecture/ts/src/infrastructure/repositories/UserRepository.spec.ts.ejs +175 -85
  62. package/templates/clean-architecture/ts/src/infrastructure/repositories/userRepository.ts.ejs +74 -0
  63. package/templates/clean-architecture/ts/src/interfaces/controllers/userController.spec.ts.ejs +331 -185
  64. package/templates/clean-architecture/ts/src/interfaces/controllers/userController.ts.ejs +173 -84
  65. package/templates/clean-architecture/ts/src/interfaces/graphql/context.spec.ts.ejs +32 -32
  66. package/templates/clean-architecture/ts/src/interfaces/graphql/context.ts.ejs +17 -17
  67. package/templates/clean-architecture/ts/src/interfaces/graphql/index.ts.ejs +3 -3
  68. package/templates/clean-architecture/ts/src/interfaces/graphql/resolvers/index.ts.ejs +4 -4
  69. package/templates/clean-architecture/ts/src/interfaces/graphql/resolvers/user.resolvers.spec.ts.ejs +68 -51
  70. package/templates/clean-architecture/ts/src/interfaces/graphql/resolvers/user.resolvers.ts.ejs +29 -21
  71. package/templates/clean-architecture/ts/src/interfaces/graphql/typeDefs/index.ts.ejs +4 -4
  72. package/templates/clean-architecture/ts/src/interfaces/graphql/typeDefs/user.types.ts.ejs +17 -15
  73. package/templates/clean-architecture/ts/src/interfaces/routes/userRoutes.spec.ts.ejs +40 -40
  74. package/templates/clean-architecture/ts/src/interfaces/routes/userRoutes.ts +13 -11
  75. package/templates/clean-architecture/ts/src/usecases/createUser.spec.ts.ejs +51 -51
  76. package/templates/clean-architecture/ts/src/usecases/createUser.ts +13 -13
  77. package/templates/clean-architecture/ts/src/usecases/deleteUser.spec.ts.ejs +47 -0
  78. package/templates/clean-architecture/ts/src/usecases/deleteUser.ts +9 -0
  79. package/templates/clean-architecture/ts/src/usecases/getAllUsers.spec.ts.ejs +63 -63
  80. package/templates/clean-architecture/ts/src/usecases/getAllUsers.ts +10 -10
  81. package/templates/clean-architecture/ts/src/usecases/updateUser.spec.ts.ejs +48 -0
  82. package/templates/clean-architecture/ts/src/usecases/updateUser.ts +9 -0
  83. package/templates/clean-architecture/ts/src/utils/errorMessages.ts +12 -0
  84. package/templates/clean-architecture/ts/src/utils/errorMiddleware.ts.ejs +27 -27
  85. package/templates/clean-architecture/ts/src/utils/httpCodes.ts +7 -7
  86. package/templates/common/.cursorrules.ejs +60 -60
  87. package/templates/common/.dockerignore +12 -12
  88. package/templates/common/.env.example.ejs +41 -41
  89. package/templates/common/.gitattributes +46 -0
  90. package/templates/common/.gitlab-ci.yml.ejs +86 -86
  91. package/templates/common/.lintstagedrc +6 -6
  92. package/templates/common/.prettierrc +7 -7
  93. package/templates/common/Dockerfile +73 -73
  94. package/templates/common/Jenkinsfile.ejs +87 -87
  95. package/templates/common/README.md.ejs +294 -270
  96. package/templates/common/SECURITY.md +20 -20
  97. package/templates/common/_github/workflows/ci.yml.ejs +46 -46
  98. package/templates/common/_github/workflows/security.yml.ejs +36 -36
  99. package/templates/common/_gitignore +5 -5
  100. package/templates/common/_husky/pre-commit +4 -4
  101. package/templates/common/caching/clean/js/CreateUser.js.ejs +29 -29
  102. package/templates/common/caching/clean/js/DeleteUser.js.ejs +27 -0
  103. package/templates/common/caching/clean/js/GetAllUsers.js.ejs +37 -37
  104. package/templates/common/caching/clean/js/UpdateUser.js.ejs +27 -0
  105. package/templates/common/caching/clean/ts/createUser.ts.ejs +27 -27
  106. package/templates/common/caching/clean/ts/deleteUser.ts.ejs +24 -0
  107. package/templates/common/caching/clean/ts/getAllUsers.ts.ejs +34 -34
  108. package/templates/common/caching/clean/ts/updateUser.ts.ejs +25 -0
  109. package/templates/common/caching/js/memoryCache.js.ejs +60 -60
  110. package/templates/common/caching/js/memoryCache.spec.js.ejs +101 -101
  111. package/templates/common/caching/js/redisClient.js.ejs +75 -75
  112. package/templates/common/caching/js/redisClient.spec.js.ejs +147 -147
  113. package/templates/common/caching/ts/memoryCache.spec.ts.ejs +102 -102
  114. package/templates/common/caching/ts/memoryCache.ts.ejs +73 -64
  115. package/templates/common/caching/ts/redisClient.spec.ts.ejs +157 -157
  116. package/templates/common/caching/ts/redisClient.ts.ejs +89 -80
  117. package/templates/common/database/js/database.js.ejs +19 -19
  118. package/templates/common/database/js/database.spec.js.ejs +56 -56
  119. package/templates/common/database/js/models/User.js.ejs +79 -53
  120. package/templates/common/database/js/models/User.js.mongoose.ejs +23 -19
  121. package/templates/common/database/js/models/User.spec.js.ejs +94 -84
  122. package/templates/common/database/js/mongoose.js.ejs +33 -33
  123. package/templates/common/database/js/mongoose.spec.js.ejs +43 -43
  124. package/templates/common/database/ts/database.spec.ts.ejs +56 -56
  125. package/templates/common/database/ts/database.ts.ejs +21 -21
  126. package/templates/common/database/ts/models/User.spec.ts.ejs +100 -84
  127. package/templates/common/database/ts/models/User.ts.ejs +87 -61
  128. package/templates/common/database/ts/models/User.ts.mongoose.ejs +30 -25
  129. package/templates/common/database/ts/mongoose.spec.ts.ejs +42 -42
  130. package/templates/common/database/ts/mongoose.ts.ejs +28 -28
  131. package/templates/common/docker-compose.yml.ejs +159 -159
  132. package/templates/common/ecosystem.config.js.ejs +40 -40
  133. package/templates/common/eslint.config.mjs.ejs +77 -77
  134. package/templates/common/health/js/healthRoute.js.ejs +50 -47
  135. package/templates/common/health/js/healthRoute.spec.js.ejs +70 -70
  136. package/templates/common/health/ts/healthRoute.spec.ts.ejs +76 -76
  137. package/templates/common/health/ts/healthRoute.ts.ejs +49 -46
  138. package/templates/common/jest.config.js.ejs +32 -32
  139. package/templates/common/jest.e2e.config.js.ejs +8 -8
  140. package/templates/common/kafka/js/config/kafka.js +9 -9
  141. package/templates/common/kafka/js/config/kafka.spec.js.ejs +27 -27
  142. package/templates/common/kafka/js/messaging/baseConsumer.js.ejs +30 -30
  143. package/templates/common/kafka/js/messaging/baseConsumer.spec.js.ejs +58 -58
  144. package/templates/common/kafka/js/messaging/userEventSchema.js.ejs +12 -11
  145. package/templates/common/kafka/js/messaging/userEventSchema.spec.js.ejs +27 -27
  146. package/templates/common/kafka/js/messaging/welcomeEmailConsumer.js.ejs +44 -31
  147. package/templates/common/kafka/js/messaging/welcomeEmailConsumer.spec.js.ejs +86 -49
  148. package/templates/common/kafka/js/services/kafkaService.js.ejs +93 -93
  149. package/templates/common/kafka/js/services/kafkaService.spec.js.ejs +106 -106
  150. package/templates/common/kafka/js/utils/kafkaEvents.js.ejs +7 -0
  151. package/templates/common/kafka/ts/config/kafka.spec.ts.ejs +27 -27
  152. package/templates/common/kafka/ts/config/kafka.ts +7 -7
  153. package/templates/common/kafka/ts/messaging/baseConsumer.spec.ts.ejs +50 -50
  154. package/templates/common/kafka/ts/messaging/baseConsumer.ts.ejs +27 -27
  155. package/templates/common/kafka/ts/messaging/userEventSchema.spec.ts.ejs +51 -51
  156. package/templates/common/kafka/ts/messaging/userEventSchema.ts.ejs +12 -11
  157. package/templates/common/kafka/ts/messaging/welcomeEmailConsumer.spec.ts.ejs +86 -49
  158. package/templates/common/kafka/ts/messaging/welcomeEmailConsumer.ts.ejs +38 -25
  159. package/templates/common/kafka/ts/services/kafkaService.spec.ts.ejs +81 -81
  160. package/templates/common/kafka/ts/services/kafkaService.ts.ejs +95 -95
  161. package/templates/common/kafka/ts/utils/kafkaEvents.ts.ejs +5 -0
  162. package/templates/common/migrate-mongo-config.js.ejs +31 -31
  163. package/templates/common/migrations/init.js.ejs +23 -23
  164. package/templates/common/package.json.ejs +119 -118
  165. package/templates/common/prompts/add-feature.md.ejs +26 -26
  166. package/templates/common/prompts/project-context.md.ejs +43 -43
  167. package/templates/common/prompts/troubleshoot.md.ejs +28 -28
  168. package/templates/common/public/css/style.css +147 -147
  169. package/templates/common/scripts/run-e2e.js.ejs +63 -63
  170. package/templates/common/shutdown/js/gracefulShutdown.js.ejs +65 -61
  171. package/templates/common/shutdown/js/gracefulShutdown.spec.js.ejs +149 -160
  172. package/templates/common/shutdown/ts/gracefulShutdown.spec.ts.ejs +179 -158
  173. package/templates/common/shutdown/ts/gracefulShutdown.ts.ejs +59 -55
  174. package/templates/common/sonar-project.properties.ejs +27 -27
  175. package/templates/common/src/tests/e2e/e2e.users.test.js.ejs +120 -49
  176. package/templates/common/src/tests/e2e/e2e.users.test.ts.ejs +120 -49
  177. package/templates/common/src/utils/errorMiddleware.spec.js.ejs +79 -79
  178. package/templates/common/src/utils/errorMiddleware.spec.ts.ejs +94 -94
  179. package/templates/common/swagger.yml.ejs +118 -66
  180. package/templates/common/tsconfig.json +22 -22
  181. package/templates/common/views/ejs/index.ejs +55 -55
  182. package/templates/common/views/pug/index.pug +40 -40
  183. package/templates/db/mysql/V1__Initial_Setup.sql.ejs +10 -9
  184. package/templates/db/postgres/V1__Initial_Setup.sql.ejs +10 -9
  185. package/templates/mvc/js/src/config/env.js.ejs +46 -46
  186. package/templates/mvc/js/src/config/swagger.js.ejs +6 -6
  187. package/templates/mvc/js/src/controllers/userController.js.ejs +246 -105
  188. package/templates/mvc/js/src/controllers/userController.spec.js.ejs +481 -209
  189. package/templates/mvc/js/src/errors/ApiError.js +14 -14
  190. package/templates/mvc/js/src/errors/BadRequestError.js +11 -10
  191. package/templates/mvc/js/src/errors/BadRequestError.spec.js.ejs +22 -21
  192. package/templates/mvc/js/src/errors/NotFoundError.js +11 -10
  193. package/templates/mvc/js/src/errors/NotFoundError.spec.js.ejs +22 -21
  194. package/templates/mvc/js/src/graphql/context.js.ejs +7 -7
  195. package/templates/mvc/js/src/graphql/context.spec.js.ejs +29 -29
  196. package/templates/mvc/js/src/graphql/index.js.ejs +5 -5
  197. package/templates/mvc/js/src/graphql/resolvers/index.js.ejs +6 -6
  198. package/templates/mvc/js/src/graphql/resolvers/user.resolvers.js.ejs +25 -19
  199. package/templates/mvc/js/src/graphql/resolvers/user.resolvers.spec.js.ejs +64 -47
  200. package/templates/mvc/js/src/graphql/typeDefs/index.js.ejs +6 -6
  201. package/templates/mvc/js/src/graphql/typeDefs/user.types.js.ejs +19 -17
  202. package/templates/mvc/js/src/index.js.ejs +136 -136
  203. package/templates/mvc/js/src/routes/api.js +10 -8
  204. package/templates/mvc/js/src/routes/api.spec.js.ejs +41 -36
  205. package/templates/mvc/js/src/utils/errorMessages.js +14 -0
  206. package/templates/mvc/js/src/utils/errorMiddleware.js +29 -29
  207. package/templates/mvc/js/src/utils/httpCodes.js +9 -9
  208. package/templates/mvc/js/src/utils/logger.js +40 -40
  209. package/templates/mvc/js/src/utils/logger.spec.js.ejs +63 -63
  210. package/templates/mvc/ts/src/config/env.ts.ejs +45 -45
  211. package/templates/mvc/ts/src/config/swagger.ts.ejs +6 -6
  212. package/templates/mvc/ts/src/controllers/userController.spec.ts.ejs +481 -203
  213. package/templates/mvc/ts/src/controllers/userController.ts.ejs +248 -107
  214. package/templates/mvc/ts/src/errors/ApiError.ts +15 -15
  215. package/templates/mvc/ts/src/errors/BadRequestError.spec.ts.ejs +22 -21
  216. package/templates/mvc/ts/src/errors/BadRequestError.ts +9 -8
  217. package/templates/mvc/ts/src/errors/NotFoundError.spec.ts.ejs +27 -21
  218. package/templates/mvc/ts/src/errors/NotFoundError.ts +9 -8
  219. package/templates/mvc/ts/src/graphql/context.spec.ts.ejs +30 -30
  220. package/templates/mvc/ts/src/graphql/context.ts.ejs +12 -12
  221. package/templates/mvc/ts/src/graphql/index.ts.ejs +3 -3
  222. package/templates/mvc/ts/src/graphql/resolvers/index.ts.ejs +4 -4
  223. package/templates/mvc/ts/src/graphql/resolvers/user.resolvers.spec.ts.ejs +68 -51
  224. package/templates/mvc/ts/src/graphql/resolvers/user.resolvers.ts.ejs +29 -21
  225. package/templates/mvc/ts/src/graphql/typeDefs/index.ts.ejs +4 -4
  226. package/templates/mvc/ts/src/graphql/typeDefs/user.types.ts.ejs +17 -15
  227. package/templates/mvc/ts/src/index.ts.ejs +156 -153
  228. package/templates/mvc/ts/src/routes/api.spec.ts.ejs +59 -40
  229. package/templates/mvc/ts/src/routes/api.ts +12 -10
  230. package/templates/mvc/ts/src/utils/errorMessages.ts +12 -0
  231. package/templates/mvc/ts/src/utils/errorMiddleware.ts.ejs +27 -27
  232. package/templates/mvc/ts/src/utils/httpCodes.ts +7 -7
  233. package/templates/mvc/ts/src/utils/logger.spec.ts.ejs +63 -63
  234. package/templates/mvc/ts/src/utils/logger.ts +36 -36
  235. package/templates/clean-architecture/ts/src/infrastructure/repositories/UserRepository.ts.ejs +0 -37
@@ -1,159 +1,159 @@
1
- services:
2
- app:
3
- build: .
4
- ports:
5
- - "${PORT:-3000}:3000"
6
- <%_ if (database !== 'None' || communication === 'Kafka') { -%>
7
- depends_on:
8
- <%_ if (database !== 'None') { -%>
9
- - db
10
- <%_ } -%>
11
- <%_ if (communication === 'Kafka') { -%>
12
- - kafka
13
- <%_ } -%>
14
- <%_ } -%>
15
- <%_ if (communication === 'Kafka') { -%>
16
- environment:
17
- - KAFKA_BROKER=kafka:9092
18
- - KAFKAJS_NO_PARTITIONER_WARNING=1
19
- - PORT=3000
20
- <%_ if (caching === 'Redis') { -%>
21
- - REDIS_HOST=redis
22
- - REDIS_PORT=6379
23
- - REDIS_PASSWORD=
24
- <%_ } -%>
25
- <%_ if (database !== 'None') { -%>
26
- - DB_HOST=db
27
- <%_ if (database === 'MySQL') { -%>
28
- - DB_USER=root
29
- - DB_PASSWORD=root
30
- - DB_NAME=<%= dbName %>
31
- - DB_PORT=3306
32
- <%_ } -%><%_ if (database === 'PostgreSQL') { -%>
33
- - DB_USER=postgres
34
- - DB_PASSWORD=root
35
- - DB_NAME=<%= dbName %>
36
- - DB_PORT=5432
37
- <%_ } -%><%_ if (database === 'MongoDB') { -%>
38
- - DB_NAME=<%= dbName %>
39
- - DB_PORT=27017
40
- <%_ } -%>
41
- <%_ } -%>
42
- <%_ } else { -%>
43
- environment:
44
- - PORT=3000
45
- <%_ if (caching === 'Redis') { -%>
46
- - REDIS_HOST=redis
47
- - REDIS_PORT=6379
48
- - REDIS_PASSWORD=
49
- <%_ } -%>
50
- <%_ if (database !== 'None') { -%>
51
- - DB_HOST=db
52
- <%_ if (database === 'MySQL') { -%>
53
- - DB_USER=root
54
- - DB_PASSWORD=root
55
- - DB_NAME=<%= dbName %>
56
- - DB_PORT=3306
57
- <%_ } -%><%_ if (database === 'PostgreSQL') { -%>
58
- - DB_USER=postgres
59
- - DB_PASSWORD=root
60
- - DB_NAME=<%= dbName %>
61
- - DB_PORT=5432
62
- <%_ } -%><%_ if (database === 'MongoDB') { -%>
63
- - DB_NAME=<%= dbName %>
64
- - DB_PORT=27017
65
- <%_ } -%>
66
- <%_ } -%>
67
- <%_ } -%>
68
- <%_ if (database !== 'None') { -%>
69
- db:
70
- <%_ if (database === 'MySQL') { -%>
71
- image: mysql:8.0
72
- restart: always
73
- environment:
74
- MYSQL_ROOT_PASSWORD: root
75
- MYSQL_DATABASE: <%= dbName %>
76
- ports:
77
- - "${DB_PORT:-3306}:3306"
78
- volumes:
79
- - ./flyway/sql:/docker-entrypoint-initdb.d
80
- <%_ } else if (database === 'PostgreSQL') { -%>
81
- image: postgres:15
82
- restart: always
83
- environment:
84
- POSTGRES_USER: postgres
85
- POSTGRES_PASSWORD: root
86
- POSTGRES_DB: <%= dbName %>
87
- ports:
88
- - "${DB_PORT:-5432}:5432"
89
- volumes:
90
- - ./flyway/sql:/docker-entrypoint-initdb.d
91
- <%_ } else if (database === 'MongoDB') { -%>
92
- image: mongo:latest
93
- restart: always
94
- environment:
95
- MONGO_INITDB_DATABASE: <%= dbName %>
96
- ports:
97
- - "${DB_PORT:-27017}:27017"
98
- volumes:
99
- - mongodb_data:/data/db
100
-
101
- mongo-migrate:
102
- image: node:22-slim
103
- working_dir: /app
104
- volumes:
105
- - .:/app
106
- command: sh -c "npm install migrate-mongo && npm run migrate"
107
- environment:
108
- - DB_HOST=db
109
- - DB_NAME=<%= dbName %>
110
- depends_on:
111
- - db
112
- <%_ } -%>
113
- <%_ } -%>
114
- <%_ if (database !== 'MongoDB' && database !== 'None') { -%>
115
- flyway:
116
- image: flyway/flyway
117
- command: -connectRetries=60 migrate
118
- volumes:
119
- - ./flyway/sql:/flyway/sql
120
- environment:
121
- <%_ if (database === 'MySQL') { -%>
122
- FLYWAY_URL: jdbc:mysql://db:3306/<%= dbName %>
123
- FLYWAY_USER: root
124
- FLYWAY_PASSWORD: root
125
- <%_ } -%><%_ if (database === 'PostgreSQL') { -%>
126
- FLYWAY_URL: jdbc:postgresql://db:5432/<%= dbName %>
127
- FLYWAY_USER: postgres
128
- FLYWAY_PASSWORD: root
129
- <%_ } -%>
130
- depends_on:
131
- - db
132
- <%_ } -%>
133
- <%_ if (communication === 'Kafka') { -%>
134
- kafka:
135
- image: bitnamilegacy/kafka:3.4.1-debian-12-r39
136
- ports:
137
- - "${KAFKA_EXTERNAL_PORT:-9093}:9093"
138
- environment:
139
- - KAFKA_ENABLE_KRAFT=yes
140
- - KAFKA_CFG_PROCESS_ROLES=broker,controller
141
- - KAFKA_CFG_CONTROLLER_QUORUM_VOTERS=1@localhost:9094
142
- - KAFKA_CFG_NODE_ID=1
143
- - KAFKA_CFG_ADVERTISED_LISTENERS=PLAINTEXT://kafka:9092,PLAINTEXT_HOST://localhost:${KAFKA_PORT:-9093}
144
- - KAFKA_CFG_LISTENERS=PLAINTEXT://:9092,PLAINTEXT_HOST://:9093,CONTROLLER://:9094
145
- - KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT
146
- - KAFKA_CFG_CONTROLLER_LISTENER_NAMES=CONTROLLER
147
- - KAFKA_CFG_INTER_BROKER_LISTENER_NAME=PLAINTEXT
148
- <%_ } -%>
149
- <%_ if (caching === 'Redis') { -%>
150
- redis:
151
- image: redis:alpine
152
- restart: always
153
- ports:
154
- - "${REDIS_PORT:-6379}:6379"
155
- <%_ } -%>
156
- <%_ if (database !== 'None') { -%>
157
- volumes:
158
- <%= database.toLowerCase() %>_data:
159
- <%_ } -%>
1
+ services:
2
+ app:
3
+ build: .
4
+ ports:
5
+ - "${PORT:-3000}:3000"
6
+ <%_ if (database !== 'None' || communication === 'Kafka') { -%>
7
+ depends_on:
8
+ <%_ if (database !== 'None') { -%>
9
+ - db
10
+ <%_ } -%>
11
+ <%_ if (communication === 'Kafka') { -%>
12
+ - kafka
13
+ <%_ } -%>
14
+ <%_ } -%>
15
+ <%_ if (communication === 'Kafka') { -%>
16
+ environment:
17
+ - KAFKA_BROKER=kafka:9092
18
+ - KAFKAJS_NO_PARTITIONER_WARNING=1
19
+ - PORT=3000
20
+ <%_ if (caching === 'Redis') { -%>
21
+ - REDIS_HOST=redis
22
+ - REDIS_PORT=6379
23
+ - REDIS_PASSWORD=
24
+ <%_ } -%>
25
+ <%_ if (database !== 'None') { -%>
26
+ - DB_HOST=db
27
+ <%_ if (database === 'MySQL') { -%>
28
+ - DB_USER=root
29
+ - DB_PASSWORD=root
30
+ - DB_NAME=<%= dbName %>
31
+ - DB_PORT=3306
32
+ <%_ } -%><%_ if (database === 'PostgreSQL') { -%>
33
+ - DB_USER=postgres
34
+ - DB_PASSWORD=root
35
+ - DB_NAME=<%= dbName %>
36
+ - DB_PORT=5432
37
+ <%_ } -%><%_ if (database === 'MongoDB') { -%>
38
+ - DB_NAME=<%= dbName %>
39
+ - DB_PORT=27017
40
+ <%_ } -%>
41
+ <%_ } -%>
42
+ <%_ } else { -%>
43
+ environment:
44
+ - PORT=3000
45
+ <%_ if (caching === 'Redis') { -%>
46
+ - REDIS_HOST=redis
47
+ - REDIS_PORT=6379
48
+ - REDIS_PASSWORD=
49
+ <%_ } -%>
50
+ <%_ if (database !== 'None') { -%>
51
+ - DB_HOST=db
52
+ <%_ if (database === 'MySQL') { -%>
53
+ - DB_USER=root
54
+ - DB_PASSWORD=root
55
+ - DB_NAME=<%= dbName %>
56
+ - DB_PORT=3306
57
+ <%_ } -%><%_ if (database === 'PostgreSQL') { -%>
58
+ - DB_USER=postgres
59
+ - DB_PASSWORD=root
60
+ - DB_NAME=<%= dbName %>
61
+ - DB_PORT=5432
62
+ <%_ } -%><%_ if (database === 'MongoDB') { -%>
63
+ - DB_NAME=<%= dbName %>
64
+ - DB_PORT=27017
65
+ <%_ } -%>
66
+ <%_ } -%>
67
+ <%_ } -%>
68
+ <%_ if (database !== 'None') { -%>
69
+ db:
70
+ <%_ if (database === 'MySQL') { -%>
71
+ image: mysql:8.0
72
+ restart: always
73
+ environment:
74
+ MYSQL_ROOT_PASSWORD: root
75
+ MYSQL_DATABASE: <%= dbName %>
76
+ ports:
77
+ - "${DB_PORT:-3306}:3306"
78
+ volumes:
79
+ - ./flyway/sql:/docker-entrypoint-initdb.d
80
+ <%_ } else if (database === 'PostgreSQL') { -%>
81
+ image: postgres:15
82
+ restart: always
83
+ environment:
84
+ POSTGRES_USER: postgres
85
+ POSTGRES_PASSWORD: root
86
+ POSTGRES_DB: <%= dbName %>
87
+ ports:
88
+ - "${DB_PORT:-5432}:5432"
89
+ volumes:
90
+ - ./flyway/sql:/docker-entrypoint-initdb.d
91
+ <%_ } else if (database === 'MongoDB') { -%>
92
+ image: mongo:latest
93
+ restart: always
94
+ environment:
95
+ MONGO_INITDB_DATABASE: <%= dbName %>
96
+ ports:
97
+ - "${DB_PORT:-27017}:27017"
98
+ volumes:
99
+ - mongodb_data:/data/db
100
+
101
+ mongo-migrate:
102
+ image: node:22-slim
103
+ working_dir: /app
104
+ volumes:
105
+ - .:/app
106
+ command: sh -c "npm install migrate-mongo && npm run migrate"
107
+ environment:
108
+ - DB_HOST=db
109
+ - DB_NAME=<%= dbName %>
110
+ depends_on:
111
+ - db
112
+ <%_ } -%>
113
+ <%_ } -%>
114
+ <%_ if (database !== 'MongoDB' && database !== 'None') { -%>
115
+ flyway:
116
+ image: flyway/flyway
117
+ command: -connectRetries=60 migrate
118
+ volumes:
119
+ - ./flyway/sql:/flyway/sql
120
+ environment:
121
+ <%_ if (database === 'MySQL') { -%>
122
+ FLYWAY_URL: jdbc:mysql://db:3306/<%= dbName %>
123
+ FLYWAY_USER: root
124
+ FLYWAY_PASSWORD: root
125
+ <%_ } -%><%_ if (database === 'PostgreSQL') { -%>
126
+ FLYWAY_URL: jdbc:postgresql://db:5432/<%= dbName %>
127
+ FLYWAY_USER: postgres
128
+ FLYWAY_PASSWORD: root
129
+ <%_ } -%>
130
+ depends_on:
131
+ - db
132
+ <%_ } -%>
133
+ <%_ if (communication === 'Kafka') { -%>
134
+ kafka:
135
+ image: bitnamilegacy/kafka:3.4.1-debian-12-r39
136
+ ports:
137
+ - "${KAFKA_EXTERNAL_PORT:-9093}:9093"
138
+ environment:
139
+ - KAFKA_ENABLE_KRAFT=yes
140
+ - KAFKA_CFG_PROCESS_ROLES=broker,controller
141
+ - KAFKA_CFG_CONTROLLER_QUORUM_VOTERS=1@localhost:9094
142
+ - KAFKA_CFG_NODE_ID=1
143
+ - KAFKA_CFG_ADVERTISED_LISTENERS=PLAINTEXT://kafka:9092,PLAINTEXT_HOST://localhost:${KAFKA_PORT:-9093}
144
+ - KAFKA_CFG_LISTENERS=PLAINTEXT://:9092,PLAINTEXT_HOST://:9093,CONTROLLER://:9094
145
+ - KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT
146
+ - KAFKA_CFG_CONTROLLER_LISTENER_NAMES=CONTROLLER
147
+ - KAFKA_CFG_INTER_BROKER_LISTENER_NAME=PLAINTEXT
148
+ <%_ } -%>
149
+ <%_ if (caching === 'Redis') { -%>
150
+ redis:
151
+ image: redis:alpine
152
+ restart: always
153
+ ports:
154
+ - "${REDIS_PORT:-6379}:6379"
155
+ <%_ } -%>
156
+ <%_ if (database !== 'None') { -%>
157
+ volumes:
158
+ <%= database.toLowerCase() %>_data:
159
+ <%_ } -%>
@@ -1,40 +1,40 @@
1
- module.exports = {
2
- apps: [{
3
- name: "<%= projectName %>",
4
- script: "<% if (language === 'TypeScript') { %>./dist/index.js<% } else { %>./src/index.js<% } %>", // Entry point
5
- instances: "max", // Run in Cluster Mode to utilize all CPUs (Note: On Windows, cluster mode may throw `spawn wmic ENOENT` errors due to missing WMIC in Windows 11. To fix, change instances to 1, or install wmic)
6
- exec_mode: "cluster",
7
- watch: false, // Disable watch in production
8
- max_memory_restart: "1G",
9
- env_production: {
10
- NODE_ENV: "production",
11
- PORT: 3000,
12
- <%_ if (caching === 'Redis') { -%>
13
- REDIS_HOST: "127.0.0.1",
14
- REDIS_PORT: 6379,
15
- REDIS_PASSWORD: "",
16
- <%_ } -%>
17
- <%_ if (communication === 'Kafka') { -%>
18
- KAFKA_BROKER: "127.0.0.1:9093",
19
- KAFKAJS_NO_PARTITIONER_WARNING: 1,
20
- <%_ } -%>
21
- <%_ if (database !== 'None') { -%>
22
- DB_HOST: "127.0.0.1",
23
- <%_ if (database === 'MySQL') { -%>
24
- DB_USER: "root",
25
- DB_PASSWORD: "root",
26
- DB_NAME: "<%= dbName %>",
27
- DB_PORT: 3306
28
- <%_ } else if (database === 'PostgreSQL') { -%>
29
- DB_USER: "postgres",
30
- DB_PASSWORD: "root",
31
- DB_NAME: "<%= dbName %>",
32
- DB_PORT: 5432
33
- <%_ } else if (database === 'MongoDB') { -%>
34
- DB_NAME: "<%= dbName %>",
35
- DB_PORT: 27017
36
- <%_ } -%>
37
- <%_ } -%>
38
- }
39
- }]
40
- };
1
+ module.exports = {
2
+ apps: [{
3
+ name: "<%= projectName %>",
4
+ script: "<% if (language === 'TypeScript') { %>./dist/index.js<% } else { %>./src/index.js<% } %>", // Entry point
5
+ instances: "max", // Run in Cluster Mode to utilize all CPUs (Note: On Windows, cluster mode may throw `spawn wmic ENOENT` errors due to missing WMIC in Windows 11. To fix, change instances to 1, or install wmic)
6
+ exec_mode: "cluster",
7
+ watch: false, // Disable watch in production
8
+ max_memory_restart: "1G",
9
+ env_production: {
10
+ NODE_ENV: "production",
11
+ PORT: 3000,
12
+ <%_ if (caching === 'Redis') { -%>
13
+ REDIS_HOST: "127.0.0.1",
14
+ REDIS_PORT: 6379,
15
+ REDIS_PASSWORD: "",
16
+ <%_ } -%>
17
+ <%_ if (communication === 'Kafka') { -%>
18
+ KAFKA_BROKER: "127.0.0.1:9093",
19
+ KAFKAJS_NO_PARTITIONER_WARNING: 1,
20
+ <%_ } -%>
21
+ <%_ if (database !== 'None') { -%>
22
+ DB_HOST: "127.0.0.1",
23
+ <%_ if (database === 'MySQL') { -%>
24
+ DB_USER: "root",
25
+ DB_PASSWORD: "root",
26
+ DB_NAME: "<%= dbName %>",
27
+ DB_PORT: 3306
28
+ <%_ } else if (database === 'PostgreSQL') { -%>
29
+ DB_USER: "postgres",
30
+ DB_PASSWORD: "root",
31
+ DB_NAME: "<%= dbName %>",
32
+ DB_PORT: 5432
33
+ <%_ } else if (database === 'MongoDB') { -%>
34
+ DB_NAME: "<%= dbName %>",
35
+ DB_PORT: 27017
36
+ <%_ } -%>
37
+ <%_ } -%>
38
+ }
39
+ }]
40
+ };
@@ -1,77 +1,77 @@
1
- import eslint from '@eslint/js';
2
- import eslintConfigPrettier from 'eslint-config-prettier';
3
- import globals from 'globals';
4
- import importPlugin from 'eslint-plugin-import-x';
5
- <% if (language === 'TypeScript') { %>import tseslint from 'typescript-eslint';
6
-
7
- export default tseslint.config(
8
- eslint.configs.recommended,
9
- ...tseslint.configs.recommended,
10
- eslintConfigPrettier,
11
- {
12
- plugins: {
13
- import: importPlugin,
14
- },
15
- settings: {
16
- 'import-x/resolver': {
17
- typescript: true,
18
- node: true,
19
- },
20
- },
21
- languageOptions: {
22
- globals: {
23
- ...globals.node,
24
- ...globals.jest,
25
- },
26
- },
27
- rules: {
28
- "no-console": "warn",
29
- "no-unused-vars": "off",
30
- "@typescript-eslint/no-unused-vars": ["warn", {
31
- "argsIgnorePattern": "^_",
32
- "varsIgnorePattern": "^_"
33
- }],
34
- "@typescript-eslint/no-require-imports": "error",
35
- "import/no-unresolved": [2, { "caseSensitive": false }]
36
- },
37
- },
38
- {
39
- files: ["**/*.test.ts", "**/*.spec.ts", "tests/**/*.ts"],
40
- rules: {
41
- "@typescript-eslint/no-require-imports": "off",
42
- "@typescript-eslint/no-unused-vars": ["warn", {
43
- "argsIgnorePattern": "^_",
44
- "varsIgnorePattern": "^_"
45
- }],
46
- "@typescript-eslint/no-explicit-any": "off",
47
- "import/no-unresolved": [2, { "caseSensitive": false }]
48
- },
49
- }
50
- );<% } else { %>
51
- export default [
52
- eslint.configs.recommended,
53
- eslintConfigPrettier,
54
- {
55
- plugins: {
56
- import: importPlugin,
57
- },
58
- settings: {
59
- 'import-x/resolver': {
60
- node: true,
61
- },
62
- },
63
- languageOptions: {
64
- ecmaVersion: 'latest',
65
- sourceType: 'module',
66
- globals: {
67
- ...globals.node,
68
- ...globals.jest,
69
- },
70
- },
71
- rules: {
72
- "no-console": "warn",
73
- "no-unused-vars": "warn",
74
- "import/no-unresolved": [2, { "caseSensitive": false }]
75
- }
76
- }
77
- ];<% } %>
1
+ import eslint from '@eslint/js';
2
+ import eslintConfigPrettier from 'eslint-config-prettier';
3
+ import globals from 'globals';
4
+ import importPlugin from 'eslint-plugin-import-x';
5
+ <% if (language === 'TypeScript') { %>import tseslint from 'typescript-eslint';
6
+
7
+ export default tseslint.config(
8
+ eslint.configs.recommended,
9
+ ...tseslint.configs.recommended,
10
+ eslintConfigPrettier,
11
+ {
12
+ plugins: {
13
+ import: importPlugin,
14
+ },
15
+ settings: {
16
+ 'import-x/resolver': {
17
+ typescript: true,
18
+ node: true,
19
+ },
20
+ },
21
+ languageOptions: {
22
+ globals: {
23
+ ...globals.node,
24
+ ...globals.jest,
25
+ },
26
+ },
27
+ rules: {
28
+ "no-console": "warn",
29
+ "no-unused-vars": "off",
30
+ "@typescript-eslint/no-unused-vars": ["warn", {
31
+ "argsIgnorePattern": "^_",
32
+ "varsIgnorePattern": "^_"
33
+ }],
34
+ "@typescript-eslint/no-require-imports": "error",
35
+ "import/no-unresolved": [2, { "caseSensitive": false }]
36
+ },
37
+ },
38
+ {
39
+ files: ["**/*.test.ts", "**/*.spec.ts", "tests/**/*.ts"],
40
+ rules: {
41
+ "@typescript-eslint/no-require-imports": "off",
42
+ "@typescript-eslint/no-unused-vars": ["warn", {
43
+ "argsIgnorePattern": "^_",
44
+ "varsIgnorePattern": "^_"
45
+ }],
46
+ "@typescript-eslint/no-explicit-any": "off",
47
+ "import/no-unresolved": [2, { "caseSensitive": false }]
48
+ },
49
+ }
50
+ );<% } else { %>
51
+ export default [
52
+ eslint.configs.recommended,
53
+ eslintConfigPrettier,
54
+ {
55
+ plugins: {
56
+ import: importPlugin,
57
+ },
58
+ settings: {
59
+ 'import-x/resolver': {
60
+ node: true,
61
+ },
62
+ },
63
+ languageOptions: {
64
+ ecmaVersion: 'latest',
65
+ sourceType: 'module',
66
+ globals: {
67
+ ...globals.node,
68
+ ...globals.jest,
69
+ },
70
+ },
71
+ rules: {
72
+ "no-console": "warn",
73
+ "no-unused-vars": "warn",
74
+ "import/no-unresolved": [2, { "caseSensitive": false }]
75
+ }
76
+ }
77
+ ];<% } %>
@@ -1,47 +1,50 @@
1
- const express = require('express');
2
- const router = express.Router();
3
- const logger = require('<% if (architecture === "MVC") { %>../utils/logger<% } else { %>../../infrastructure/log/logger<% } %>');
4
- const HTTP_STATUS = require('<% if (architecture === "MVC") { %>../utils/httpCodes<% } else { %>../../utils/httpCodes<% } %>');
5
- <%_ if (database === 'MongoDB') { -%>
6
- const mongoose = require('mongoose');
7
- <%_ } else if (database !== 'None') { -%>
8
- const sequelize = require('<% if (architecture === "MVC") { %>../config/database<% } else { %>../../infrastructure/database/database<% } %>');
9
- <%_ } -%>
10
-
11
- router.get('/', async (req, res) => {
12
- const healthData = {
13
- status: 'UP',
14
- uptime: process.uptime(),
15
- memory: process.memoryUsage(),
16
- database: 'disconnected',
17
- timestamp: Date.now()
18
- };
19
- logger.info('Health Check');
20
-
21
- <%_ if (database !== 'None') { -%>
22
- try {
23
- <%_ if (database === 'MongoDB') { -%>
24
- if (mongoose.connection.readyState === 1) {
25
- if (mongoose.connection.db && mongoose.connection.db.admin) {
26
- await mongoose.connection.db.admin().ping();
27
- }
28
- healthData.database = 'connected';
29
- }
30
- <%_ } else { -%>
31
- await sequelize.authenticate();
32
- healthData.database = 'connected';
33
- <%_ } -%>
34
- } catch (err) {
35
- healthData.database = 'error';
36
- healthData.status = 'DOWN';
37
- logger.error('Health Check Database Ping Failed:', err);
38
- return res.status(HTTP_STATUS.INTERNAL_SERVER_ERROR).json(healthData);
39
- }
40
- <%_ } else { -%>
41
- healthData.database = 'None';
42
- <%_ } -%>
43
-
44
- res.status(HTTP_STATUS.OK).json(healthData);
45
- });
46
-
47
- module.exports = router;
1
+ const express = require('express');
2
+ const router = express.Router();
3
+ const logger = require('<% if (architecture === "MVC") { %>../utils/logger<% } else { %>../../infrastructure/log/logger<% } %>');
4
+ const HTTP_STATUS = require('<% if (architecture === "MVC") { %>../utils/httpCodes<% } else { %>../../utils/httpCodes<% } %>');
5
+ <%_ if (database !== 'None') { -%>
6
+ const ERROR_MESSAGES = require('<% if (architecture === "MVC") { %>../utils/errorMessages<% } else { %>../../utils/errorMessages<% } %>');
7
+ <%_ } -%>
8
+ <%_ if (database === 'MongoDB') { -%>
9
+ const mongoose = require('mongoose');
10
+ <%_ } else if (database !== 'None') { -%>
11
+ const sequelize = require('<% if (architecture === "MVC") { %>../config/database<% } else { %>../../infrastructure/database/database<% } %>');
12
+ <%_ } -%>
13
+
14
+ router.get('/', async (req, res) => {
15
+ const healthData = {
16
+ status: 'UP',
17
+ uptime: process.uptime(),
18
+ memory: process.memoryUsage(),
19
+ database: 'disconnected',
20
+ timestamp: Date.now()
21
+ };
22
+ logger.info('Health Check');
23
+
24
+ <%_ if (database !== 'None') { -%>
25
+ try {
26
+ <%_ if (database === 'MongoDB') { -%>
27
+ if (mongoose.connection.readyState === 1) {
28
+ if (mongoose.connection.db && mongoose.connection.db.admin) {
29
+ await mongoose.connection.db.admin().ping();
30
+ }
31
+ healthData.database = 'connected';
32
+ }
33
+ <%_ } else { -%>
34
+ await sequelize.authenticate();
35
+ healthData.database = 'connected';
36
+ <%_ } -%>
37
+ } catch (err) {
38
+ healthData.database = 'error';
39
+ healthData.status = 'DOWN';
40
+ logger.error(`${ERROR_MESSAGES.DATABASE_PING_FAILED}:`, err);
41
+ return res.status(HTTP_STATUS.INTERNAL_SERVER_ERROR).json(healthData);
42
+ }
43
+ <%_ } else { -%>
44
+ healthData.database = 'None';
45
+ <%_ } -%>
46
+
47
+ res.status(HTTP_STATUS.OK).json(healthData);
48
+ });
49
+
50
+ module.exports = router;