underpost 2.6.3 → 2.7.2

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 (216) hide show
  1. package/.dockerignore +13 -13
  2. package/.env.development +7 -7
  3. package/.env.production +7 -7
  4. package/.env.test +7 -7
  5. package/.github/workflows/publish.yml +26 -0
  6. package/.nycrc +9 -9
  7. package/.prettierignore +12 -12
  8. package/.prettierrc +9 -9
  9. package/.vscode/extensions.json +72 -72
  10. package/.vscode/settings.json +100 -99
  11. package/AUTHORS.md +10 -0
  12. package/CHANGELOG.md +91 -0
  13. package/Dockerfile +89 -89
  14. package/LICENSE +21 -21
  15. package/README.md +96 -96
  16. package/bin/db.js +172 -119
  17. package/bin/deploy.js +582 -626
  18. package/bin/dns.js +1 -1
  19. package/bin/file.js +92 -92
  20. package/bin/index.js +53 -34
  21. package/bin/install.js +398 -357
  22. package/bin/shortcut.js +44 -44
  23. package/bin/ssl.js +65 -61
  24. package/bin/util.js +182 -182
  25. package/bin/vs.js +35 -35
  26. package/conf.js +251 -249
  27. package/docker-compose.yml +67 -67
  28. package/jsconfig.json +7 -7
  29. package/jsdoc.json +32 -32
  30. package/nodemon.json +6 -6
  31. package/package.json +137 -128
  32. package/prometheus.yml +36 -36
  33. package/setup.sh +24 -24
  34. package/src/api/core/core.controller.js +69 -69
  35. package/src/api/core/core.model.js +11 -11
  36. package/src/api/core/core.router.js +23 -23
  37. package/src/api/core/core.service.js +29 -29
  38. package/src/api/crypto/crypto.controller.js +51 -51
  39. package/src/api/crypto/crypto.model.js +23 -23
  40. package/src/api/crypto/crypto.router.js +20 -20
  41. package/src/api/crypto/crypto.service.js +64 -64
  42. package/src/api/default/default.controller.js +69 -69
  43. package/src/api/default/default.model.js +20 -20
  44. package/src/api/default/default.router.js +23 -23
  45. package/src/api/default/default.service.js +31 -31
  46. package/src/api/file/file.controller.js +53 -51
  47. package/src/api/file/file.model.js +19 -19
  48. package/src/api/file/file.router.js +21 -20
  49. package/src/api/file/file.service.js +76 -70
  50. package/src/api/instance/instance.controller.js +69 -69
  51. package/src/api/instance/instance.model.js +36 -36
  52. package/src/api/instance/instance.router.js +33 -33
  53. package/src/api/instance/instance.service.js +48 -48
  54. package/src/api/test/test.controller.js +59 -59
  55. package/src/api/test/test.model.js +14 -14
  56. package/src/api/test/test.router.js +21 -21
  57. package/src/api/test/test.service.js +35 -35
  58. package/src/api/user/user.build.js +16 -0
  59. package/src/api/user/user.controller.js +70 -70
  60. package/src/api/user/user.model.js +65 -65
  61. package/src/api/user/user.router.js +345 -345
  62. package/src/api/user/user.service.js +479 -479
  63. package/src/api.js +23 -23
  64. package/src/client/Default.index.js +40 -40
  65. package/src/client/components/core/Account.js +290 -290
  66. package/src/client/components/core/AgGrid.js +160 -160
  67. package/src/client/components/core/Auth.js +19 -19
  68. package/src/client/components/core/Badge.js +32 -32
  69. package/src/client/components/core/BlockChain.js +41 -41
  70. package/src/client/components/core/Blog.js +9 -9
  71. package/src/client/components/core/BtnIcon.js +101 -94
  72. package/src/client/components/core/CalendarCore.js +458 -319
  73. package/src/client/components/core/Chat.js +64 -64
  74. package/src/client/components/core/ColorPalette.js +5267 -5267
  75. package/src/client/components/core/CommonJs.js +735 -732
  76. package/src/client/components/core/Content.js +193 -49
  77. package/src/client/components/core/Css.js +1064 -1027
  78. package/src/client/components/core/CssCore.js +817 -796
  79. package/src/client/components/core/D3Chart.js +44 -44
  80. package/src/client/components/core/Docs.js +229 -229
  81. package/src/client/components/core/DropDown.js +164 -164
  82. package/src/client/components/core/EventsUI.js +46 -54
  83. package/src/client/components/core/FileExplorer.js +699 -624
  84. package/src/client/components/core/FullScreen.js +45 -45
  85. package/src/client/components/core/Input.js +346 -259
  86. package/src/client/components/core/JoyStick.js +77 -77
  87. package/src/client/components/core/Keyboard.js +73 -73
  88. package/src/client/components/core/LoadingAnimation.js +179 -157
  89. package/src/client/components/core/LogIn.js +187 -181
  90. package/src/client/components/core/LogOut.js +58 -52
  91. package/src/client/components/core/Logger.js +26 -26
  92. package/src/client/components/core/Modal.js +1612 -1596
  93. package/src/client/components/core/NotificationManager.js +84 -84
  94. package/src/client/components/core/Panel.js +613 -413
  95. package/src/client/components/core/PanelForm.js +468 -0
  96. package/src/client/components/core/Polyhedron.js +162 -162
  97. package/src/client/components/core/Recover.js +204 -204
  98. package/src/client/components/core/Responsive.js +53 -53
  99. package/src/client/components/core/RichText.js +51 -27
  100. package/src/client/components/core/Router.js +76 -77
  101. package/src/client/components/core/Scroll.js +34 -0
  102. package/src/client/components/core/SignUp.js +125 -125
  103. package/src/client/components/core/SocketIo.js +72 -72
  104. package/src/client/components/core/Stream.js +113 -113
  105. package/src/client/components/core/ToggleSwitch.js +87 -87
  106. package/src/client/components/core/ToolTip.js +26 -26
  107. package/src/client/components/core/Translate.js +437 -408
  108. package/src/client/components/core/Validator.js +100 -100
  109. package/src/client/components/core/VanillaJs.js +460 -457
  110. package/src/client/components/core/Wallet.js +106 -106
  111. package/src/client/components/core/Webhook.js +25 -25
  112. package/src/client/components/core/Worker.js +272 -272
  113. package/src/client/components/default/CommonDefault.js +29 -29
  114. package/src/client/components/default/CssDefault.js +13 -13
  115. package/src/client/components/default/ElementsDefault.js +38 -38
  116. package/src/client/components/default/LogInDefault.js +41 -41
  117. package/src/client/components/default/LogOutDefault.js +28 -28
  118. package/src/client/components/default/MenuDefault.js +389 -389
  119. package/src/client/components/default/RoutesDefault.js +48 -48
  120. package/src/client/components/default/SettingsDefault.js +16 -16
  121. package/src/client/components/default/SignUpDefault.js +9 -9
  122. package/src/client/components/default/SocketIoDefault.js +54 -54
  123. package/src/client/components/default/TranslateDefault.js +7 -7
  124. package/src/client/public/default/assets/mailer/api-user-check.png +0 -0
  125. package/src/client/public/default/assets/mailer/api-user-invalid-token.png +0 -0
  126. package/src/client/public/default/assets/mailer/api-user-recover.png +0 -0
  127. package/src/client/public/default/browserconfig.xml +11 -11
  128. package/src/client/public/default/manifest.webmanifest +68 -68
  129. package/src/client/public/default/plantuml/client-conf.svg +1 -0
  130. package/src/client/public/default/plantuml/client-schema.svg +1 -0
  131. package/src/client/public/default/plantuml/cron-conf.svg +1 -0
  132. package/src/client/public/default/plantuml/cron-schema.svg +1 -0
  133. package/src/client/public/default/plantuml/server-conf.svg +1 -0
  134. package/src/client/public/default/plantuml/server-schema.svg +1 -0
  135. package/src/client/public/default/plantuml/ssr-conf.svg +1 -0
  136. package/src/client/public/default/plantuml/ssr-schema.svg +1 -0
  137. package/src/client/public/default/sitemap +147 -147
  138. package/src/client/public/default/yandex-browser-manifest.json +8 -8
  139. package/src/client/public/doc/sitemap +147 -147
  140. package/src/client/public/test/sitemap +147 -147
  141. package/src/client/services/core/core.service.js +170 -152
  142. package/src/client/services/crypto/crypto.service.js +70 -70
  143. package/src/client/services/default/default.management.js +345 -345
  144. package/src/client/services/default/default.service.js +89 -89
  145. package/src/client/services/file/file.service.js +70 -70
  146. package/src/client/services/instance/instance.management.js +74 -74
  147. package/src/client/services/instance/instance.service.js +89 -89
  148. package/src/client/services/test/test.service.js +70 -70
  149. package/src/client/services/user/user.management.js +50 -50
  150. package/src/client/services/user/user.service.js +89 -89
  151. package/src/client/ssr/Render.js +16 -16
  152. package/src/client/ssr/body-components/CacheControl.js +114 -113
  153. package/src/client/ssr/body-components/DefaultSplashScreen.js +79 -79
  154. package/src/client/ssr/email-components/DefaultRecoverEmail.js +21 -21
  155. package/src/client/ssr/email-components/DefaultVerifyEmail.js +17 -17
  156. package/src/client/ssr/head-components/Css.js +241 -241
  157. package/src/client/ssr/head-components/DefaultScripts.js +3 -3
  158. package/src/client/ssr/head-components/Microdata.js +11 -11
  159. package/src/client/ssr/head-components/Production.js +1 -1
  160. package/src/client/ssr/head-components/PwaDefault.js +59 -59
  161. package/src/client/ssr/head-components/Seo.js +14 -14
  162. package/src/client/sw/default.sw.js +201 -201
  163. package/src/client/sw/template.sw.js +84 -84
  164. package/src/client.build.js +22 -22
  165. package/src/client.dev.js +21 -21
  166. package/src/cron.js +25 -25
  167. package/src/db/DataBaseProvider.js +34 -34
  168. package/src/db/mariadb/MariaDB.js +33 -33
  169. package/src/db/mongo/MongooseDB.js +46 -46
  170. package/src/dns.js +22 -22
  171. package/src/index.js +42 -0
  172. package/src/mailer/EmailRender.js +69 -69
  173. package/src/mailer/MailerProvider.js +96 -96
  174. package/src/proxy.js +22 -22
  175. package/src/runtime/lampp/Lampp.js +69 -44
  176. package/src/runtime/nginx/Nginx.js +3 -3
  177. package/src/runtime/xampp/Xampp.js +49 -49
  178. package/src/server/auth.js +235 -204
  179. package/src/server/backup.js +101 -84
  180. package/src/server/client-build-live.js +72 -72
  181. package/src/server/client-build.js +705 -699
  182. package/src/server/client-dev-server.js +60 -58
  183. package/src/server/client-formatted.js +48 -48
  184. package/src/server/client-icons.js +149 -150
  185. package/src/server/conf.js +860 -611
  186. package/src/server/dns.js +98 -87
  187. package/src/server/downloader.js +42 -42
  188. package/src/server/logger.js +180 -135
  189. package/src/server/network.js +122 -122
  190. package/src/server/peer.js +33 -33
  191. package/src/server/process.js +66 -66
  192. package/src/server/prompt-optimizer.js +28 -0
  193. package/src/server/proxy.js +118 -118
  194. package/src/server/runtime.js +444 -393
  195. package/src/server/ssl.js +109 -107
  196. package/src/server.js +25 -25
  197. package/src/ws/IoInterface.js +45 -45
  198. package/src/ws/IoServer.js +39 -39
  199. package/src/ws/core/channels/core.ws.chat.js +23 -23
  200. package/src/ws/core/channels/core.ws.mailer.js +35 -35
  201. package/src/ws/core/channels/core.ws.stream.js +31 -31
  202. package/src/ws/core/core.ws.connection.js +28 -28
  203. package/src/ws/core/core.ws.emit.js +14 -14
  204. package/src/ws/core/core.ws.server.js +24 -24
  205. package/src/ws/core/management/core.ws.chat.js +8 -8
  206. package/src/ws/core/management/core.ws.mailer.js +16 -16
  207. package/src/ws/core/management/core.ws.stream.js +8 -8
  208. package/src/ws/default/channels/default.ws.main.js +16 -16
  209. package/src/ws/default/default.ws.connection.js +22 -22
  210. package/src/ws/default/default.ws.emit.js +14 -14
  211. package/src/ws/default/default.ws.server.js +20 -20
  212. package/src/ws/default/management/default.ws.main.js +8 -8
  213. package/startup.js +11 -11
  214. package/supervisord-openssh-server.conf +4 -4
  215. package/test/api.test.js +60 -60
  216. package/bin/help.js +0 -110
@@ -1,345 +1,345 @@
1
- import { authMiddleware } from '../../server/auth.js';
2
- import { faBase64Png, getBufferPngText } from '../../server/client-icons.js';
3
- import { loggerFactory } from '../../server/logger.js';
4
- import { UserController } from './user.controller.js';
5
- import express from 'express';
6
-
7
- const logger = loggerFactory(import.meta);
8
-
9
- const UserRouter = (options) => {
10
- const router = express.Router();
11
-
12
- (async () => {
13
- options.png = {
14
- buffer: {
15
- 'invalid-token': await getBufferPngText({ text: 'Invalid token', textColor: '#ff0000' }),
16
- recover: Buffer.from(faBase64Png('rotate-left', 50, 50, '#ffffff'), 'base64'),
17
- check: Buffer.from(faBase64Png('check', 50, 50), 'base64'),
18
- },
19
- header: (res) => {
20
- res.set('Content-Type', 'image/png');
21
- },
22
- };
23
- })();
24
-
25
- router.post(`/mailer/:id`, authMiddleware, async (req, res) => {
26
- /*
27
- #swagger.ignore = true
28
- */
29
- return await UserController.post(req, res, options);
30
- });
31
-
32
- router.get(`/mailer/:id`, async (req, res) => {
33
- /*
34
- #swagger.ignore = true
35
- */
36
- return await UserController.get(req, res, options);
37
- });
38
-
39
- router.get(`/email/:email`, authMiddleware, async (req, res) => {
40
- /*
41
- #swagger.ignore = true
42
- */
43
- return await UserController.get(req, res, options);
44
- });
45
-
46
- router.post(`/:id`, async (req, res) => {
47
- /*
48
- #swagger.ignore = true
49
- */
50
- return await UserController.post(req, res, options);
51
- });
52
-
53
- // #swagger.start
54
-
55
- /*
56
- #swagger.auto = false
57
- #swagger.tags = ['user']
58
- #swagger.summary = 'Log in'
59
- #swagger.description = 'This endpoint get a JWT for authenticated user'
60
- #swagger.path = '/user/auth'
61
- #swagger.method = 'post'
62
- #swagger.produces = ['application/json']
63
- #swagger.consumes = ['application/json']
64
-
65
- #swagger.requestBody = {
66
- in: 'body',
67
- description: 'User data',
68
- required: true,
69
- content: {
70
- 'application/json': {
71
- schema: {
72
- $ref: '#/components/schemas/userLogInRequest'
73
- }
74
- }
75
- }
76
- }
77
-
78
- #swagger.responses[200] = {
79
- description: 'User created successfully',
80
- content: {
81
- 'application/json': {
82
- schema: {
83
- $ref: '#/components/schemas/userResponse'
84
- }
85
- }
86
- }
87
- }
88
-
89
- #swagger.responses[400] = {
90
- description: 'Bad request. Please check the input data',
91
- content: {
92
- 'application/json': {
93
- schema: {
94
- $ref: '#/components/schemas/userBadRequestResponse'
95
- }
96
- }
97
- }
98
- }
99
- */
100
-
101
- // #swagger.end
102
-
103
- router.post(`/`, async (req, res) => {
104
- /*
105
- #swagger.auto = false
106
- #swagger.tags = ['user']
107
- #swagger.summary = 'Create user'
108
- #swagger.description = 'This endpoint will create a new user account'
109
- #swagger.path = '/user'
110
- #swagger.method = 'post'
111
- #swagger.produces = ['application/json']
112
- #swagger.consumes = ['application/json']
113
-
114
- #swagger.requestBody = {
115
- in: 'body',
116
- description: 'User data',
117
- required: true,
118
- content: {
119
- 'application/json': {
120
- schema: {
121
- $ref: '#/components/schemas/userRequest'
122
- }
123
- }
124
- }
125
- }
126
-
127
- #swagger.responses[200] = {
128
- description: 'User created successfully',
129
- content: {
130
- 'application/json': {
131
- schema: {
132
- $ref: '#/components/schemas/userResponse'
133
- }
134
- }
135
- }
136
- }
137
-
138
- #swagger.responses[400] = {
139
- description: 'Bad request. Please check the input data',
140
- content: {
141
- 'application/json': {
142
- schema: {
143
- $ref: '#/components/schemas/userBadRequestResponse'
144
- }
145
- }
146
- }
147
- }
148
- */
149
- return await UserController.post(req, res, options);
150
- });
151
-
152
- router.get(`/recover/:id`, async (req, res) => {
153
- /*
154
- #swagger.ignore = true
155
- */
156
- return await UserController.get(req, res, options);
157
- });
158
-
159
- router.get(`/:id`, authMiddleware, async (req, res) => {
160
- /*
161
- #swagger.auto = false
162
- #swagger.tags = ['user']
163
- #swagger.summary = 'Get user data by ID'
164
- #swagger.description = 'This endpoint get user data by ID'
165
- #swagger.path = '/user/{id}'
166
- #swagger.method = 'get'
167
- #swagger.produces = ['application/json']
168
- #swagger.consumes = ['application/json']
169
- #swagger.security = [{
170
- 'bearerAuth': []
171
- }]
172
-
173
- #swagger.parameters['id'] = {
174
- in: 'path',
175
- description: 'User ID',
176
- required: true,
177
- type: 'string'
178
- }
179
-
180
- #swagger.responses[200] = {
181
- description: 'get user successfully',
182
- content: {
183
- 'application/json': {
184
- schema: {
185
- $ref: '#/components/schemas/userGetResponse'
186
- }
187
- }
188
- }
189
- }
190
-
191
- #swagger.responses[400] = {
192
- description: 'Bad request. Please check the input data',
193
- content: {
194
- 'application/json': {
195
- schema: {
196
- $ref: '#/components/schemas/userBadRequestResponse'
197
- }
198
- }
199
- }
200
- }
201
- */
202
- return await UserController.get(req, res, options);
203
- });
204
- router.get(`/`, authMiddleware, async (req, res) => {
205
- /*
206
- #swagger.ignore = true
207
- */
208
- return await UserController.get(req, res, options);
209
- });
210
- router.put(`/recover/:id`, async (req, res) => {
211
- /*
212
- #swagger.ignore = true
213
- */
214
- return await UserController.put(req, res, options);
215
- });
216
- router.put(`/profile-image/:id`, authMiddleware, async (req, res) => {
217
- /*
218
- #swagger.ignore = true
219
- */
220
- return await UserController.put(req, res, options);
221
- });
222
- router.put(`/:id`, authMiddleware, async (req, res) => {
223
- /*
224
- #swagger.auto = false
225
- #swagger.tags = ['user']
226
- #swagger.summary = 'Update user data by ID'
227
- #swagger.description = 'This endpoint will update user data by ID'
228
- #swagger.path = '/user/{id}'
229
- #swagger.method = 'put'
230
- #swagger.produces = ['application/json']
231
- #swagger.consumes = ['application/json']
232
- #swagger.security = [{
233
- 'bearerAuth': []
234
- }]
235
-
236
- #swagger.parameters['id'] = {
237
- in: 'path',
238
- description: 'User ID',
239
- required: true,
240
- type: 'string'
241
- }
242
-
243
- #swagger.requestBody = {
244
- in: 'body',
245
- description: 'User data',
246
- required: true,
247
- content: {
248
- 'application/json': {
249
- schema: {
250
- $ref: '#/components/schemas/userRequest'
251
- }
252
- }
253
- }
254
- }
255
-
256
- #swagger.responses[200] = {
257
- description: 'User updated successfully',
258
- content: {
259
- 'application/json': {
260
- schema: {
261
- $ref: '#/components/schemas/userUpdateResponse'
262
- }
263
- }
264
- }
265
- }
266
-
267
- #swagger.responses[400] = {
268
- description: 'Bad request. Please check the input data',
269
- content: {
270
- 'application/json': {
271
- schema: {
272
- $ref: '#/components/schemas/userBadRequestResponse'
273
- }
274
- }
275
- }
276
- }
277
- */
278
- return await UserController.put(req, res, options);
279
- });
280
- router.put(`/`, authMiddleware, async (req, res) => {
281
- /*
282
- #swagger.ignore = true
283
- */
284
- return await UserController.put(req, res, options);
285
- });
286
-
287
- router.delete(`/:id`, authMiddleware, async (req, res) => {
288
- /*
289
- #swagger.auto = false
290
- #swagger.tags = ['user']
291
- #swagger.summary = 'Delete user data by ID'
292
- #swagger.description = 'This endpoint deletes user data by ID, the path ID must match with the ID of the authenticated user'
293
- #swagger.path = '/user/{id}'
294
- #swagger.method = 'delete'
295
- #swagger.produces = ['application/json']
296
- #swagger.consumes = ['application/json']
297
- #swagger.security = [{
298
- 'bearerAuth': []
299
- }]
300
-
301
- #swagger.parameters['id'] = {
302
- in: 'path',
303
- description: 'User ID',
304
- required: true,
305
- type: 'string'
306
- }
307
-
308
- #swagger.responses[200] = {
309
- description: 'get user successfully',
310
- content: {
311
- 'application/json': {
312
- schema: {
313
- $ref: '#/components/schemas/userGetResponse'
314
- }
315
- }
316
- }
317
- }
318
-
319
- #swagger.responses[400] = {
320
- description: 'Bad request. Please check the input data',
321
- content: {
322
- 'application/json': {
323
- schema: {
324
- $ref: '#/components/schemas/userBadRequestResponse'
325
- }
326
- }
327
- }
328
- }
329
- */
330
- return await UserController.delete(req, res, options);
331
- });
332
-
333
- router.delete(`/`, authMiddleware, async (req, res) => {
334
- /*
335
- #swagger.ignore = true
336
- */
337
- return await UserController.delete(req, res, options);
338
- });
339
-
340
- return router;
341
- };
342
-
343
- const ApiRouter = UserRouter;
344
-
345
- export { ApiRouter, UserRouter };
1
+ import { authMiddleware } from '../../server/auth.js';
2
+ import fs from 'fs-extra';
3
+ import { loggerFactory } from '../../server/logger.js';
4
+ import { UserController } from './user.controller.js';
5
+ import express from 'express';
6
+
7
+ const logger = loggerFactory(import.meta);
8
+
9
+ const UserRouter = (options) => {
10
+ const router = express.Router();
11
+
12
+ (async () => {
13
+ options.png = {
14
+ buffer: {
15
+ 'invalid-token': fs.readFileSync(`./src/client/public/default/assets/mailer/api-user-invalid-token.png`),
16
+ recover: fs.readFileSync(`./src/client/public/default/assets/mailer/api-user-recover.png`),
17
+ check: fs.readFileSync(`./src/client/public/default/assets/mailer/api-user-check.png`),
18
+ },
19
+ header: (res) => {
20
+ res.set('Content-Type', 'image/png');
21
+ },
22
+ };
23
+ })();
24
+
25
+ router.post(`/mailer/:id`, authMiddleware, async (req, res) => {
26
+ /*
27
+ #swagger.ignore = true
28
+ */
29
+ return await UserController.post(req, res, options);
30
+ });
31
+
32
+ router.get(`/mailer/:id`, async (req, res) => {
33
+ /*
34
+ #swagger.ignore = true
35
+ */
36
+ return await UserController.get(req, res, options);
37
+ });
38
+
39
+ router.get(`/email/:email`, authMiddleware, async (req, res) => {
40
+ /*
41
+ #swagger.ignore = true
42
+ */
43
+ return await UserController.get(req, res, options);
44
+ });
45
+
46
+ router.post(`/:id`, async (req, res) => {
47
+ /*
48
+ #swagger.ignore = true
49
+ */
50
+ return await UserController.post(req, res, options);
51
+ });
52
+
53
+ // #swagger.start
54
+
55
+ /*
56
+ #swagger.auto = false
57
+ #swagger.tags = ['user']
58
+ #swagger.summary = 'Log in'
59
+ #swagger.description = 'This endpoint get a JWT for authenticated user'
60
+ #swagger.path = '/user/auth'
61
+ #swagger.method = 'post'
62
+ #swagger.produces = ['application/json']
63
+ #swagger.consumes = ['application/json']
64
+
65
+ #swagger.requestBody = {
66
+ in: 'body',
67
+ description: 'User data',
68
+ required: true,
69
+ content: {
70
+ 'application/json': {
71
+ schema: {
72
+ $ref: '#/components/schemas/userLogInRequest'
73
+ }
74
+ }
75
+ }
76
+ }
77
+
78
+ #swagger.responses[200] = {
79
+ description: 'User created successfully',
80
+ content: {
81
+ 'application/json': {
82
+ schema: {
83
+ $ref: '#/components/schemas/userResponse'
84
+ }
85
+ }
86
+ }
87
+ }
88
+
89
+ #swagger.responses[400] = {
90
+ description: 'Bad request. Please check the input data',
91
+ content: {
92
+ 'application/json': {
93
+ schema: {
94
+ $ref: '#/components/schemas/userBadRequestResponse'
95
+ }
96
+ }
97
+ }
98
+ }
99
+ */
100
+
101
+ // #swagger.end
102
+
103
+ router.post(`/`, async (req, res) => {
104
+ /*
105
+ #swagger.auto = false
106
+ #swagger.tags = ['user']
107
+ #swagger.summary = 'Create user'
108
+ #swagger.description = 'This endpoint will create a new user account'
109
+ #swagger.path = '/user'
110
+ #swagger.method = 'post'
111
+ #swagger.produces = ['application/json']
112
+ #swagger.consumes = ['application/json']
113
+
114
+ #swagger.requestBody = {
115
+ in: 'body',
116
+ description: 'User data',
117
+ required: true,
118
+ content: {
119
+ 'application/json': {
120
+ schema: {
121
+ $ref: '#/components/schemas/userRequest'
122
+ }
123
+ }
124
+ }
125
+ }
126
+
127
+ #swagger.responses[200] = {
128
+ description: 'User created successfully',
129
+ content: {
130
+ 'application/json': {
131
+ schema: {
132
+ $ref: '#/components/schemas/userResponse'
133
+ }
134
+ }
135
+ }
136
+ }
137
+
138
+ #swagger.responses[400] = {
139
+ description: 'Bad request. Please check the input data',
140
+ content: {
141
+ 'application/json': {
142
+ schema: {
143
+ $ref: '#/components/schemas/userBadRequestResponse'
144
+ }
145
+ }
146
+ }
147
+ }
148
+ */
149
+ return await UserController.post(req, res, options);
150
+ });
151
+
152
+ router.get(`/recover/:id`, async (req, res) => {
153
+ /*
154
+ #swagger.ignore = true
155
+ */
156
+ return await UserController.get(req, res, options);
157
+ });
158
+
159
+ router.get(`/:id`, authMiddleware, async (req, res) => {
160
+ /*
161
+ #swagger.auto = false
162
+ #swagger.tags = ['user']
163
+ #swagger.summary = 'Get user data by ID'
164
+ #swagger.description = 'This endpoint get user data by ID'
165
+ #swagger.path = '/user/{id}'
166
+ #swagger.method = 'get'
167
+ #swagger.produces = ['application/json']
168
+ #swagger.consumes = ['application/json']
169
+ #swagger.security = [{
170
+ 'bearerAuth': []
171
+ }]
172
+
173
+ #swagger.parameters['id'] = {
174
+ in: 'path',
175
+ description: 'User ID',
176
+ required: true,
177
+ type: 'string'
178
+ }
179
+
180
+ #swagger.responses[200] = {
181
+ description: 'get user successfully',
182
+ content: {
183
+ 'application/json': {
184
+ schema: {
185
+ $ref: '#/components/schemas/userGetResponse'
186
+ }
187
+ }
188
+ }
189
+ }
190
+
191
+ #swagger.responses[400] = {
192
+ description: 'Bad request. Please check the input data',
193
+ content: {
194
+ 'application/json': {
195
+ schema: {
196
+ $ref: '#/components/schemas/userBadRequestResponse'
197
+ }
198
+ }
199
+ }
200
+ }
201
+ */
202
+ return await UserController.get(req, res, options);
203
+ });
204
+ router.get(`/`, authMiddleware, async (req, res) => {
205
+ /*
206
+ #swagger.ignore = true
207
+ */
208
+ return await UserController.get(req, res, options);
209
+ });
210
+ router.put(`/recover/:id`, async (req, res) => {
211
+ /*
212
+ #swagger.ignore = true
213
+ */
214
+ return await UserController.put(req, res, options);
215
+ });
216
+ router.put(`/profile-image/:id`, authMiddleware, async (req, res) => {
217
+ /*
218
+ #swagger.ignore = true
219
+ */
220
+ return await UserController.put(req, res, options);
221
+ });
222
+ router.put(`/:id`, authMiddleware, async (req, res) => {
223
+ /*
224
+ #swagger.auto = false
225
+ #swagger.tags = ['user']
226
+ #swagger.summary = 'Update user data by ID'
227
+ #swagger.description = 'This endpoint will update user data by ID'
228
+ #swagger.path = '/user/{id}'
229
+ #swagger.method = 'put'
230
+ #swagger.produces = ['application/json']
231
+ #swagger.consumes = ['application/json']
232
+ #swagger.security = [{
233
+ 'bearerAuth': []
234
+ }]
235
+
236
+ #swagger.parameters['id'] = {
237
+ in: 'path',
238
+ description: 'User ID',
239
+ required: true,
240
+ type: 'string'
241
+ }
242
+
243
+ #swagger.requestBody = {
244
+ in: 'body',
245
+ description: 'User data',
246
+ required: true,
247
+ content: {
248
+ 'application/json': {
249
+ schema: {
250
+ $ref: '#/components/schemas/userRequest'
251
+ }
252
+ }
253
+ }
254
+ }
255
+
256
+ #swagger.responses[200] = {
257
+ description: 'User updated successfully',
258
+ content: {
259
+ 'application/json': {
260
+ schema: {
261
+ $ref: '#/components/schemas/userUpdateResponse'
262
+ }
263
+ }
264
+ }
265
+ }
266
+
267
+ #swagger.responses[400] = {
268
+ description: 'Bad request. Please check the input data',
269
+ content: {
270
+ 'application/json': {
271
+ schema: {
272
+ $ref: '#/components/schemas/userBadRequestResponse'
273
+ }
274
+ }
275
+ }
276
+ }
277
+ */
278
+ return await UserController.put(req, res, options);
279
+ });
280
+ router.put(`/`, authMiddleware, async (req, res) => {
281
+ /*
282
+ #swagger.ignore = true
283
+ */
284
+ return await UserController.put(req, res, options);
285
+ });
286
+
287
+ router.delete(`/:id`, authMiddleware, async (req, res) => {
288
+ /*
289
+ #swagger.auto = false
290
+ #swagger.tags = ['user']
291
+ #swagger.summary = 'Delete user data by ID'
292
+ #swagger.description = 'This endpoint deletes user data by ID, the path ID must match with the ID of the authenticated user'
293
+ #swagger.path = '/user/{id}'
294
+ #swagger.method = 'delete'
295
+ #swagger.produces = ['application/json']
296
+ #swagger.consumes = ['application/json']
297
+ #swagger.security = [{
298
+ 'bearerAuth': []
299
+ }]
300
+
301
+ #swagger.parameters['id'] = {
302
+ in: 'path',
303
+ description: 'User ID',
304
+ required: true,
305
+ type: 'string'
306
+ }
307
+
308
+ #swagger.responses[200] = {
309
+ description: 'get user successfully',
310
+ content: {
311
+ 'application/json': {
312
+ schema: {
313
+ $ref: '#/components/schemas/userGetResponse'
314
+ }
315
+ }
316
+ }
317
+ }
318
+
319
+ #swagger.responses[400] = {
320
+ description: 'Bad request. Please check the input data',
321
+ content: {
322
+ 'application/json': {
323
+ schema: {
324
+ $ref: '#/components/schemas/userBadRequestResponse'
325
+ }
326
+ }
327
+ }
328
+ }
329
+ */
330
+ return await UserController.delete(req, res, options);
331
+ });
332
+
333
+ router.delete(`/`, authMiddleware, async (req, res) => {
334
+ /*
335
+ #swagger.ignore = true
336
+ */
337
+ return await UserController.delete(req, res, options);
338
+ });
339
+
340
+ return router;
341
+ };
342
+
343
+ const ApiRouter = UserRouter;
344
+
345
+ export { ApiRouter, UserRouter };