ts-deco 1.0.15 → 1.0.17

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 (217) hide show
  1. package/dist/app/app.d.ts +5 -0
  2. package/dist/app/app.d.ts.map +1 -0
  3. package/dist/app/app.js +181 -0
  4. package/dist/app/app.js.map +1 -0
  5. package/dist/app/config/env.config.d.ts +14 -0
  6. package/dist/app/config/env.config.d.ts.map +1 -0
  7. package/dist/app/config/env.config.js +22 -0
  8. package/dist/app/config/env.config.js.map +1 -0
  9. package/dist/app/middleware/error-handler.middleware.d.ts +17 -0
  10. package/dist/app/middleware/error-handler.middleware.d.ts.map +1 -0
  11. package/dist/app/middleware/error-handler.middleware.js +38 -0
  12. package/dist/app/middleware/error-handler.middleware.js.map +1 -0
  13. package/dist/app/middleware/logger.middleware.d.ts +6 -0
  14. package/dist/app/middleware/logger.middleware.d.ts.map +1 -0
  15. package/dist/app/middleware/logger.middleware.js +34 -0
  16. package/dist/app/middleware/logger.middleware.js.map +1 -0
  17. package/dist/app/middleware/not-found.middleware.d.ts +6 -0
  18. package/dist/app/middleware/not-found.middleware.d.ts.map +1 -0
  19. package/dist/app/middleware/not-found.middleware.js +18 -0
  20. package/dist/app/middleware/not-found.middleware.js.map +1 -0
  21. package/dist/app/routers/async/controllers/async-example.controller.d.ts +32 -0
  22. package/dist/app/routers/async/controllers/async-example.controller.d.ts.map +1 -0
  23. package/dist/app/routers/async/controllers/async-example.controller.js +205 -0
  24. package/dist/app/routers/async/controllers/async-example.controller.js.map +1 -0
  25. package/dist/app/routers/async/controllers/index.d.ts +2 -0
  26. package/dist/app/routers/async/controllers/index.d.ts.map +1 -0
  27. package/dist/app/routers/async/controllers/index.js +6 -0
  28. package/dist/app/routers/async/controllers/index.js.map +1 -0
  29. package/dist/app/routers/health/controllers/health.controller.d.ts +5 -0
  30. package/dist/app/routers/health/controllers/health.controller.d.ts.map +1 -0
  31. package/dist/app/routers/health/controllers/health.controller.js +35 -0
  32. package/dist/app/routers/health/controllers/health.controller.js.map +1 -0
  33. package/dist/app/routers/health/controllers/index.d.ts +2 -0
  34. package/dist/app/routers/health/controllers/index.d.ts.map +1 -0
  35. package/dist/app/routers/health/controllers/index.js +6 -0
  36. package/dist/app/routers/health/controllers/index.js.map +1 -0
  37. package/dist/app/routers/index.d.ts +6 -0
  38. package/dist/app/routers/index.d.ts.map +1 -0
  39. package/dist/app/routers/index.js +23 -0
  40. package/dist/app/routers/index.js.map +1 -0
  41. package/dist/app/routers/products/controllers/index.d.ts +2 -0
  42. package/dist/app/routers/products/controllers/index.d.ts.map +1 -0
  43. package/dist/app/routers/products/controllers/index.js +6 -0
  44. package/dist/app/routers/products/controllers/index.js.map +1 -0
  45. package/dist/app/routers/products/controllers/products.controller.d.ts +21 -0
  46. package/dist/app/routers/products/controllers/products.controller.d.ts.map +1 -0
  47. package/dist/app/routers/products/controllers/products.controller.js +124 -0
  48. package/dist/app/routers/products/controllers/products.controller.js.map +1 -0
  49. package/dist/app/routers/products/dto/index.d.ts +2 -0
  50. package/dist/app/routers/products/dto/index.d.ts.map +1 -0
  51. package/dist/app/routers/products/dto/index.js +18 -0
  52. package/dist/app/routers/products/dto/index.js.map +1 -0
  53. package/dist/app/routers/products/dto/product.dto.d.ts +23 -0
  54. package/dist/app/routers/products/dto/product.dto.d.ts.map +1 -0
  55. package/dist/app/routers/products/dto/product.dto.js +84 -0
  56. package/dist/app/routers/products/dto/product.dto.js.map +1 -0
  57. package/dist/app/routers/products/services/index.d.ts +2 -0
  58. package/dist/app/routers/products/services/index.d.ts.map +1 -0
  59. package/dist/app/routers/products/services/index.js +6 -0
  60. package/dist/app/routers/products/services/index.js.map +1 -0
  61. package/dist/app/routers/products/services/product.service.d.ts +32 -0
  62. package/dist/app/routers/products/services/product.service.d.ts.map +1 -0
  63. package/dist/app/routers/products/services/product.service.js +62 -0
  64. package/dist/app/routers/products/services/product.service.js.map +1 -0
  65. package/dist/app/routers/test/controllers/index.d.ts +2 -0
  66. package/dist/app/routers/test/controllers/index.d.ts.map +1 -0
  67. package/dist/app/routers/test/controllers/index.js +6 -0
  68. package/dist/app/routers/test/controllers/index.js.map +1 -0
  69. package/dist/app/routers/test/controllers/test.controller.d.ts +6 -0
  70. package/dist/app/routers/test/controllers/test.controller.d.ts.map +1 -0
  71. package/dist/app/routers/test/controllers/test.controller.js +68 -0
  72. package/dist/app/routers/test/controllers/test.controller.js.map +1 -0
  73. package/dist/app/routers/test/dto/index.d.ts +2 -0
  74. package/dist/app/routers/test/dto/index.d.ts.map +1 -0
  75. package/dist/app/routers/test/dto/index.js +18 -0
  76. package/dist/app/routers/test/dto/index.js.map +1 -0
  77. package/dist/app/routers/test/dto/test.dto.d.ts +27 -0
  78. package/dist/app/routers/test/dto/test.dto.d.ts.map +1 -0
  79. package/dist/app/routers/test/dto/test.dto.js +81 -0
  80. package/dist/app/routers/test/dto/test.dto.js.map +1 -0
  81. package/dist/app/routers/users/controllers/index.d.ts +2 -0
  82. package/dist/app/routers/users/controllers/index.d.ts.map +1 -0
  83. package/dist/app/routers/users/controllers/index.js +6 -0
  84. package/dist/app/routers/users/controllers/index.js.map +1 -0
  85. package/dist/app/routers/users/controllers/users.controller.d.ts +6 -0
  86. package/dist/app/routers/users/controllers/users.controller.d.ts.map +1 -0
  87. package/dist/app/routers/users/controllers/users.controller.js +68 -0
  88. package/dist/app/routers/users/controllers/users.controller.js.map +1 -0
  89. package/dist/app/routers/users/dto/index.d.ts +2 -0
  90. package/dist/app/routers/users/dto/index.d.ts.map +1 -0
  91. package/dist/app/routers/users/dto/index.js +18 -0
  92. package/dist/app/routers/users/dto/index.js.map +1 -0
  93. package/dist/app/routers/users/dto/user.dto.d.ts +28 -0
  94. package/dist/app/routers/users/dto/user.dto.d.ts.map +1 -0
  95. package/dist/app/routers/users/dto/user.dto.js +96 -0
  96. package/dist/app/routers/users/dto/user.dto.js.map +1 -0
  97. package/dist/app/routers/users/services/index.d.ts +2 -0
  98. package/dist/app/routers/users/services/index.d.ts.map +1 -0
  99. package/dist/app/routers/users/services/index.js +6 -0
  100. package/dist/app/routers/users/services/index.js.map +1 -0
  101. package/dist/app/routers/users/services/user.service.d.ts +16 -0
  102. package/dist/app/routers/users/services/user.service.d.ts.map +1 -0
  103. package/dist/app/routers/users/services/user.service.js +39 -0
  104. package/dist/app/routers/users/services/user.service.js.map +1 -0
  105. package/dist/src/configs/app-initializer.d.ts +49 -0
  106. package/dist/src/configs/app-initializer.d.ts.map +1 -0
  107. package/dist/src/configs/app-initializer.js +55 -0
  108. package/dist/src/configs/app-initializer.js.map +1 -0
  109. package/dist/src/configs/extractors/auto-extract-dtos.extractor.d.ts +7 -0
  110. package/dist/src/configs/extractors/auto-extract-dtos.extractor.d.ts.map +1 -0
  111. package/dist/src/configs/extractors/auto-extract-dtos.extractor.js +54 -0
  112. package/dist/src/configs/extractors/auto-extract-dtos.extractor.js.map +1 -0
  113. package/dist/src/configs/extractors/extract-controllers-from-module.extractor.d.ts +8 -0
  114. package/dist/src/configs/extractors/extract-controllers-from-module.extractor.d.ts.map +1 -0
  115. package/dist/src/configs/extractors/extract-controllers-from-module.extractor.js +36 -0
  116. package/dist/src/configs/extractors/extract-controllers-from-module.extractor.js.map +1 -0
  117. package/dist/src/configs/extractors/extract-dtos-from-module.extractor.d.ts +8 -0
  118. package/dist/src/configs/extractors/extract-dtos-from-module.extractor.d.ts.map +1 -0
  119. package/dist/src/configs/extractors/extract-dtos-from-module.extractor.js +34 -0
  120. package/dist/src/configs/extractors/extract-dtos-from-module.extractor.js.map +1 -0
  121. package/dist/src/configs/extractors/index.d.ts +4 -0
  122. package/dist/src/configs/extractors/index.d.ts.map +1 -0
  123. package/dist/src/configs/extractors/index.js +10 -0
  124. package/dist/src/configs/extractors/index.js.map +1 -0
  125. package/dist/src/configs/index.d.ts +9 -0
  126. package/dist/src/configs/index.d.ts.map +1 -0
  127. package/dist/src/configs/index.js +31 -0
  128. package/dist/src/configs/index.js.map +1 -0
  129. package/dist/src/configs/middleware/index.d.ts +2 -0
  130. package/dist/src/configs/middleware/index.d.ts.map +1 -0
  131. package/dist/src/configs/middleware/index.js +6 -0
  132. package/dist/src/configs/middleware/index.js.map +1 -0
  133. package/dist/src/configs/middleware/validation.middleware.d.ts +18 -0
  134. package/dist/src/configs/middleware/validation.middleware.d.ts.map +1 -0
  135. package/dist/src/configs/middleware/validation.middleware.js +50 -0
  136. package/dist/src/configs/middleware/validation.middleware.js.map +1 -0
  137. package/dist/src/configs/routes/auto-register-routes.route.d.ts +10 -0
  138. package/dist/src/configs/routes/auto-register-routes.route.d.ts.map +1 -0
  139. package/dist/src/configs/routes/auto-register-routes.route.js +80 -0
  140. package/dist/src/configs/routes/auto-register-routes.route.js.map +1 -0
  141. package/dist/src/configs/routes/auto-scan-controller-methods.route.d.ts +8 -0
  142. package/dist/src/configs/routes/auto-scan-controller-methods.route.d.ts.map +1 -0
  143. package/dist/src/configs/routes/auto-scan-controller-methods.route.js +44 -0
  144. package/dist/src/configs/routes/auto-scan-controller-methods.route.js.map +1 -0
  145. package/dist/src/configs/routes/generate-route-info.route.d.ts +11 -0
  146. package/dist/src/configs/routes/generate-route-info.route.d.ts.map +1 -0
  147. package/dist/src/configs/routes/generate-route-info.route.js +84 -0
  148. package/dist/src/configs/routes/generate-route-info.route.js.map +1 -0
  149. package/dist/src/configs/routes/index.d.ts +4 -0
  150. package/dist/src/configs/routes/index.d.ts.map +1 -0
  151. package/dist/src/configs/routes/index.js +10 -0
  152. package/dist/src/configs/routes/index.js.map +1 -0
  153. package/dist/src/configs/swagger.factory.d.ts +87 -0
  154. package/dist/src/configs/swagger.factory.d.ts.map +1 -0
  155. package/dist/src/configs/swagger.factory.js +689 -0
  156. package/dist/src/configs/swagger.factory.js.map +1 -0
  157. package/dist/src/configs/utils/format-validation-errors.util.d.ts +8 -0
  158. package/dist/src/configs/utils/format-validation-errors.util.d.ts.map +1 -0
  159. package/dist/src/configs/utils/format-validation-errors.util.js +25 -0
  160. package/dist/src/configs/utils/format-validation-errors.util.js.map +1 -0
  161. package/dist/src/configs/utils/has-swagger-decorators.util.d.ts +9 -0
  162. package/dist/src/configs/utils/has-swagger-decorators.util.d.ts.map +1 -0
  163. package/dist/src/configs/utils/has-swagger-decorators.util.js +19 -0
  164. package/dist/src/configs/utils/has-swagger-decorators.util.js.map +1 -0
  165. package/dist/src/configs/utils/index.d.ts +4 -0
  166. package/dist/src/configs/utils/index.d.ts.map +1 -0
  167. package/dist/src/configs/utils/index.js +10 -0
  168. package/dist/src/configs/utils/index.js.map +1 -0
  169. package/dist/src/configs/utils/is-enum.util.d.ts +7 -0
  170. package/dist/src/configs/utils/is-enum.util.d.ts.map +1 -0
  171. package/dist/src/configs/utils/is-enum.util.js +26 -0
  172. package/dist/src/configs/utils/is-enum.util.js.map +1 -0
  173. package/dist/src/decorators/controllers/api-body.decorator.d.ts +20 -0
  174. package/dist/src/decorators/controllers/api-body.decorator.d.ts.map +1 -0
  175. package/dist/src/decorators/controllers/api-body.decorator.js +39 -0
  176. package/dist/src/decorators/controllers/api-body.decorator.js.map +1 -0
  177. package/dist/src/decorators/controllers/api-operation.decorator.d.ts +15 -0
  178. package/dist/src/decorators/controllers/api-operation.decorator.d.ts.map +1 -0
  179. package/dist/src/decorators/controllers/api-operation.decorator.js +23 -0
  180. package/dist/src/decorators/controllers/api-operation.decorator.js.map +1 -0
  181. package/dist/src/decorators/controllers/api-param.decorator.d.ts +20 -0
  182. package/dist/src/decorators/controllers/api-param.decorator.d.ts.map +1 -0
  183. package/dist/src/decorators/controllers/api-param.decorator.js +41 -0
  184. package/dist/src/decorators/controllers/api-param.decorator.js.map +1 -0
  185. package/dist/src/decorators/controllers/api-query.decorator.d.ts +20 -0
  186. package/dist/src/decorators/controllers/api-query.decorator.d.ts.map +1 -0
  187. package/dist/src/decorators/controllers/api-query.decorator.js +41 -0
  188. package/dist/src/decorators/controllers/api-query.decorator.js.map +1 -0
  189. package/dist/src/decorators/controllers/api-response.decorator.d.ts +16 -0
  190. package/dist/src/decorators/controllers/api-response.decorator.d.ts.map +1 -0
  191. package/dist/src/decorators/controllers/api-response.decorator.js +25 -0
  192. package/dist/src/decorators/controllers/api-response.decorator.js.map +1 -0
  193. package/dist/src/decorators/controllers/api-tags.decorator.d.ts +17 -0
  194. package/dist/src/decorators/controllers/api-tags.decorator.d.ts.map +1 -0
  195. package/dist/src/decorators/controllers/api-tags.decorator.js +35 -0
  196. package/dist/src/decorators/controllers/api-tags.decorator.js.map +1 -0
  197. package/dist/src/decorators/controllers/controller-metadata.d.ts +75 -0
  198. package/dist/src/decorators/controllers/controller-metadata.d.ts.map +1 -0
  199. package/dist/src/decorators/controllers/controller-metadata.js +17 -0
  200. package/dist/src/decorators/controllers/controller-metadata.js.map +1 -0
  201. package/dist/src/decorators/controllers/controller.decorator.d.ts +31 -0
  202. package/dist/src/decorators/controllers/controller.decorator.d.ts.map +1 -0
  203. package/dist/src/decorators/controllers/controller.decorator.js +52 -0
  204. package/dist/src/decorators/controllers/controller.decorator.js.map +1 -0
  205. package/dist/src/decorators/controllers/index.d.ts +12 -0
  206. package/dist/src/decorators/controllers/index.d.ts.map +1 -0
  207. package/dist/src/decorators/controllers/index.js +24 -0
  208. package/dist/src/decorators/controllers/index.js.map +1 -0
  209. package/dist/src/decorators/controllers/operation.decorator.d.ts +45 -0
  210. package/dist/src/decorators/controllers/operation.decorator.d.ts.map +1 -0
  211. package/dist/src/decorators/controllers/operation.decorator.js +93 -0
  212. package/dist/src/decorators/controllers/operation.decorator.js.map +1 -0
  213. package/dist/src/index.d.ts +2 -0
  214. package/dist/src/index.d.ts.map +1 -1
  215. package/dist/src/index.js +10 -1
  216. package/dist/src/index.js.map +1 -1
  217. package/package.json +13 -5
@@ -0,0 +1,5 @@
1
+ import 'reflect-metadata';
2
+ import express from 'express';
3
+ declare const app: express.Express;
4
+ export default app;
5
+ //# sourceMappingURL=app.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.d.ts","sourceRoot":"","sources":["../../app/app.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,OAAO,OAAoB,MAAM,SAAS,CAAC;AAsH3C,QAAA,MAAM,GAAG,iBAAc,CAAC;AAwCxB,eAAe,GAAG,CAAC"}
@@ -0,0 +1,181 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ require("reflect-metadata");
40
+ const express_1 = __importDefault(require("express"));
41
+ const configs_1 = require("../src/configs");
42
+ const controllerModule = __importStar(require("./routers"));
43
+ const env_config_1 = require("./config/env.config");
44
+ const logger_middleware_1 = require("./middleware/logger.middleware");
45
+ const error_handler_middleware_1 = require("./middleware/error-handler.middleware");
46
+ const not_found_middleware_1 = require("./middleware/not-found.middleware");
47
+ // 선택적 의존성 (설치되어 있으면 사용)
48
+ let helmet;
49
+ let cors;
50
+ let compression;
51
+ try {
52
+ helmet = require('helmet');
53
+ }
54
+ catch (e) {
55
+ console.warn('helmet 패키지가 설치되지 않았습니다. 보안 헤더가 적용되지 않습니다.');
56
+ }
57
+ try {
58
+ cors = require('cors');
59
+ }
60
+ catch (e) {
61
+ console.warn('cors 패키지가 설치되지 않았습니다. CORS가 적용되지 않습니다.');
62
+ }
63
+ try {
64
+ compression = require('compression');
65
+ }
66
+ catch (e) {
67
+ console.warn('compression 패키지가 설치되지 않았습니다. 압축이 적용되지 않습니다.');
68
+ }
69
+ /**
70
+ * Express 앱 생성 및 설정
71
+ */
72
+ function createApp() {
73
+ const app = (0, express_1.default)();
74
+ // Trust proxy (리버스 프록시 사용 시)
75
+ app.set('trust proxy', true);
76
+ // 보안 미들웨어 (선택적)
77
+ if (helmet) {
78
+ app.use(helmet({
79
+ contentSecurityPolicy: env_config_1.env.NODE_ENV === 'production',
80
+ crossOriginEmbedderPolicy: false,
81
+ }));
82
+ }
83
+ // CORS 설정 (선택적)
84
+ if (cors) {
85
+ app.use(cors({
86
+ origin: env_config_1.env.CORS_ORIGIN === '*' ? true : env_config_1.env.CORS_ORIGIN.split(','),
87
+ credentials: true,
88
+ methods: ['GET', 'POST', 'PUT', 'PATCH', 'DELETE', 'OPTIONS'],
89
+ allowedHeaders: ['Content-Type', 'Authorization', 'X-Request-ID'],
90
+ }));
91
+ }
92
+ // 압축 미들웨어 (선택적)
93
+ if (compression) {
94
+ app.use(compression());
95
+ }
96
+ // Body 파싱 미들웨어
97
+ app.use(express_1.default.json({ limit: '10mb' }));
98
+ app.use(express_1.default.urlencoded({ extended: true, limit: '10mb' }));
99
+ // 요청 로깅 미들웨어
100
+ app.use(logger_middleware_1.loggerMiddleware);
101
+ // Swagger 및 API 라우트 설정
102
+ if (env_config_1.env.SWAGGER_ENABLED) {
103
+ (0, configs_1.setupApp)({
104
+ app,
105
+ controllers: controllerModule,
106
+ swagger: {
107
+ title: 'API Documentation',
108
+ version: env_config_1.env.API_VERSION,
109
+ description: 'RESTful API with custom decorators',
110
+ servers: [
111
+ {
112
+ url: `http://localhost:${env_config_1.env.PORT}`,
113
+ description: '로컬 개발 서버',
114
+ },
115
+ {
116
+ url: `https://api.example.com`,
117
+ description: '프로덕션 서버',
118
+ },
119
+ ],
120
+ },
121
+ swaggerPath: env_config_1.env.SWAGGER_PATH,
122
+ });
123
+ }
124
+ else {
125
+ // Swagger 없이 라우트만 등록
126
+ const { autoRegisterRoutes } = require('../src/configs');
127
+ autoRegisterRoutes(app, controllerModule);
128
+ }
129
+ // Health check (Swagger 설정 전에 등록)
130
+ app.get('/health', (req, res) => {
131
+ res.json({
132
+ status: 'ok',
133
+ timestamp: new Date().toISOString(),
134
+ uptime: process.uptime(),
135
+ environment: env_config_1.env.NODE_ENV,
136
+ });
137
+ });
138
+ // 에러 핸들링 미들웨어 (모든 라우트 이후)
139
+ app.use(error_handler_middleware_1.errorHandlerMiddleware);
140
+ // 404 핸들러 (모든 라우트 이후, 에러 핸들러 이전)
141
+ app.use(not_found_middleware_1.notFoundMiddleware);
142
+ return app;
143
+ }
144
+ // 앱 인스턴스 생성
145
+ const app = createApp();
146
+ // 서버 시작
147
+ function startServer() {
148
+ const server = app.listen(env_config_1.env.PORT, () => {
149
+ console.log('='.repeat(50));
150
+ console.log(`🚀 Server is running`);
151
+ console.log(`📍 Environment: ${env_config_1.env.NODE_ENV}`);
152
+ console.log(`🌐 Port: ${env_config_1.env.PORT}`);
153
+ console.log(`📚 API Version: ${env_config_1.env.API_VERSION}`);
154
+ if (env_config_1.env.SWAGGER_ENABLED) {
155
+ console.log(`📖 Swagger UI: http://localhost:${env_config_1.env.PORT}${env_config_1.env.SWAGGER_PATH}`);
156
+ }
157
+ console.log(`❤️ Health Check: http://localhost:${env_config_1.env.PORT}/health`);
158
+ console.log('='.repeat(50));
159
+ });
160
+ // Graceful shutdown
161
+ process.on('SIGTERM', () => {
162
+ console.log('SIGTERM signal received: closing HTTP server');
163
+ server.close(() => {
164
+ console.log('HTTP server closed');
165
+ process.exit(0);
166
+ });
167
+ });
168
+ process.on('SIGINT', () => {
169
+ console.log('SIGINT signal received: closing HTTP server');
170
+ server.close(() => {
171
+ console.log('HTTP server closed');
172
+ process.exit(0);
173
+ });
174
+ });
175
+ }
176
+ // 직접 실행 시에만 서버 시작
177
+ if (require.main === module) {
178
+ startServer();
179
+ }
180
+ exports.default = app;
181
+ //# sourceMappingURL=app.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.js","sourceRoot":"","sources":["../../app/app.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ /**
2
+ * 환경 변수 설정
3
+ */
4
+ export declare const env: {
5
+ readonly NODE_ENV: string;
6
+ readonly PORT: number;
7
+ readonly API_VERSION: string;
8
+ readonly API_PREFIX: string;
9
+ readonly SWAGGER_ENABLED: boolean;
10
+ readonly SWAGGER_PATH: string;
11
+ readonly CORS_ORIGIN: string;
12
+ readonly LOG_LEVEL: string;
13
+ };
14
+ //# sourceMappingURL=env.config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"env.config.d.ts","sourceRoot":"","sources":["../../../app/config/env.config.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,eAAO,MAAM,GAAG;;;;;;;;;CAkBN,CAAC"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.env = void 0;
4
+ /**
5
+ * 환경 변수 설정
6
+ */
7
+ exports.env = {
8
+ // 서버 설정
9
+ NODE_ENV: process.env.NODE_ENV || 'development',
10
+ PORT: parseInt(process.env.PORT || '3000', 10),
11
+ // API 설정
12
+ API_VERSION: process.env.API_VERSION || 'v1',
13
+ API_PREFIX: process.env.API_PREFIX || '/api',
14
+ // Swagger 설정
15
+ SWAGGER_ENABLED: process.env.SWAGGER_ENABLED !== 'false',
16
+ SWAGGER_PATH: process.env.SWAGGER_PATH || '/api-docs',
17
+ // CORS 설정
18
+ CORS_ORIGIN: process.env.CORS_ORIGIN || '*',
19
+ // 로깅
20
+ LOG_LEVEL: process.env.LOG_LEVEL || 'info',
21
+ };
22
+ //# sourceMappingURL=env.config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"env.config.js","sourceRoot":"","sources":["../../../app/config/env.config.ts"],"names":[],"mappings":";;;AAAA;;GAEG;AACU,QAAA,GAAG,GAAG;IACf,QAAQ;IACR,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,IAAI,aAAa;IAC/C,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,MAAM,EAAE,EAAE,CAAC;IAE9C,SAAS;IACT,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,IAAI;IAC5C,UAAU,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,MAAM;IAE5C,aAAa;IACb,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,OAAO;IACxD,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,WAAW;IAErD,UAAU;IACV,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,GAAG;IAE3C,KAAK;IACL,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,MAAM;CACpC,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { Request, Response, NextFunction } from 'express';
2
+ /**
3
+ * 에러 응답 인터페이스
4
+ */
5
+ export interface ErrorResponse {
6
+ statusCode: number;
7
+ message: string;
8
+ error?: string;
9
+ requestId?: string;
10
+ timestamp: string;
11
+ path: string;
12
+ }
13
+ /**
14
+ * 글로벌 에러 핸들링 미들웨어
15
+ */
16
+ export declare function errorHandlerMiddleware(err: Error | any, req: Request, res: Response, next: NextFunction): void;
17
+ //# sourceMappingURL=error-handler.middleware.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error-handler.middleware.d.ts","sourceRoot":"","sources":["../../../app/middleware/error-handler.middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE1D;;GAEG;AACH,MAAM,WAAW,aAAa;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAClC,GAAG,EAAE,KAAK,GAAG,GAAG,EAChB,GAAG,EAAE,OAAO,EACZ,GAAG,EAAE,QAAQ,EACb,IAAI,EAAE,YAAY,GACnB,IAAI,CAoCN"}
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.errorHandlerMiddleware = errorHandlerMiddleware;
4
+ /**
5
+ * 글로벌 에러 핸들링 미들웨어
6
+ */
7
+ function errorHandlerMiddleware(err, req, res, next) {
8
+ const requestId = req.headers['x-request-id'];
9
+ // Validation 에러는 이미 처리됨
10
+ if (res.headersSent) {
11
+ return next(err);
12
+ }
13
+ // 에러 로깅
14
+ console.error('[ERROR HANDLER]', {
15
+ error: err.message,
16
+ stack: process.env.NODE_ENV === 'development' ? err.stack : undefined,
17
+ requestId,
18
+ path: req.path,
19
+ method: req.method,
20
+ });
21
+ // 상태 코드 결정
22
+ const statusCode = err.statusCode || err.status || 500;
23
+ const message = err.message || 'Internal server error';
24
+ // 에러 응답
25
+ const errorResponse = {
26
+ statusCode,
27
+ message: statusCode === 500 ? 'Internal server error' : message,
28
+ requestId,
29
+ timestamp: new Date().toISOString(),
30
+ path: req.path,
31
+ };
32
+ // 개발 환경에서만 상세 에러 정보 포함
33
+ if (process.env.NODE_ENV === 'development' && statusCode === 500) {
34
+ errorResponse.error = err.message;
35
+ }
36
+ res.status(statusCode).json(errorResponse);
37
+ }
38
+ //# sourceMappingURL=error-handler.middleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error-handler.middleware.js","sourceRoot":"","sources":["../../../app/middleware/error-handler.middleware.ts"],"names":[],"mappings":";;AAiBA,wDAyCC;AA5CD;;GAEG;AACH,SAAgB,sBAAsB,CAClC,GAAgB,EAChB,GAAY,EACZ,GAAa,EACb,IAAkB;IAElB,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,cAAc,CAAW,CAAC;IAExD,wBAAwB;IACxB,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;QAClB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;IAED,QAAQ;IACR,OAAO,CAAC,KAAK,CAAC,iBAAiB,EAAE;QAC7B,KAAK,EAAE,GAAG,CAAC,OAAO;QAClB,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;QACrE,SAAS;QACT,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,MAAM,EAAE,GAAG,CAAC,MAAM;KACrB,CAAC,CAAC;IAEH,WAAW;IACX,MAAM,UAAU,GAAG,GAAG,CAAC,UAAU,IAAI,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC;IACvD,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO,IAAI,uBAAuB,CAAC;IAEvD,QAAQ;IACR,MAAM,aAAa,GAAkB;QACjC,UAAU;QACV,OAAO,EAAE,UAAU,KAAK,GAAG,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,OAAO;QAC/D,SAAS;QACT,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACnC,IAAI,EAAE,GAAG,CAAC,IAAI;KACjB,CAAC;IAEF,uBAAuB;IACvB,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,IAAI,UAAU,KAAK,GAAG,EAAE,CAAC;QAC/D,aAAa,CAAC,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;IACtC,CAAC;IAED,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;AAC/C,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { Request, Response, NextFunction } from 'express';
2
+ /**
3
+ * 요청 로깅 미들웨어
4
+ */
5
+ export declare function loggerMiddleware(req: Request, res: Response, next: NextFunction): void;
6
+ //# sourceMappingURL=logger.middleware.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.middleware.d.ts","sourceRoot":"","sources":["../../../app/middleware/logger.middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE1D;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,GAAG,IAAI,CA6BtF"}
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.loggerMiddleware = loggerMiddleware;
4
+ /**
5
+ * 요청 로깅 미들웨어
6
+ */
7
+ function loggerMiddleware(req, res, next) {
8
+ const start = Date.now();
9
+ const requestId = req.headers['x-request-id'] || `req-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
10
+ // 요청 ID를 헤더에 추가
11
+ req.headers['x-request-id'] = requestId;
12
+ res.setHeader('x-request-id', requestId);
13
+ // 응답 완료 시 로깅
14
+ res.on('finish', () => {
15
+ const duration = Date.now() - start;
16
+ const logMessage = {
17
+ method: req.method,
18
+ path: req.path,
19
+ statusCode: res.statusCode,
20
+ duration: `${duration}ms`,
21
+ requestId,
22
+ ip: req.ip || req.socket.remoteAddress,
23
+ userAgent: req.get('user-agent'),
24
+ };
25
+ if (res.statusCode >= 400) {
26
+ console.error('[ERROR]', logMessage);
27
+ }
28
+ else {
29
+ console.log('[REQUEST]', logMessage);
30
+ }
31
+ });
32
+ next();
33
+ }
34
+ //# sourceMappingURL=logger.middleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.middleware.js","sourceRoot":"","sources":["../../../app/middleware/logger.middleware.ts"],"names":[],"mappings":";;AAKA,4CA6BC;AAhCD;;GAEG;AACH,SAAgB,gBAAgB,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB;IAC5E,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACzB,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,OAAO,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;IAEhH,gBAAgB;IAChB,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,SAAmB,CAAC;IAClD,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,SAAmB,CAAC,CAAC;IAEnD,aAAa;IACb,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;QAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC;QACpC,MAAM,UAAU,GAAG;YACf,MAAM,EAAE,GAAG,CAAC,MAAM;YAClB,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,QAAQ,EAAE,GAAG,QAAQ,IAAI;YACzB,SAAS;YACT,EAAE,EAAE,GAAG,CAAC,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa;YACtC,SAAS,EAAE,GAAG,CAAC,GAAG,CAAC,YAAY,CAAC;SACnC,CAAC;QAEF,IAAI,GAAG,CAAC,UAAU,IAAI,GAAG,EAAE,CAAC;YACxB,OAAO,CAAC,KAAK,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACJ,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;QACzC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,EAAE,CAAC;AACX,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { Request, Response } from 'express';
2
+ /**
3
+ * 404 Not Found 핸들러
4
+ */
5
+ export declare function notFoundMiddleware(req: Request, res: Response): void;
6
+ //# sourceMappingURL=not-found.middleware.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"not-found.middleware.d.ts","sourceRoot":"","sources":["../../../app/middleware/not-found.middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAE5C;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,IAAI,CAWpE"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.notFoundMiddleware = notFoundMiddleware;
4
+ /**
5
+ * 404 Not Found 핸들러
6
+ */
7
+ function notFoundMiddleware(req, res) {
8
+ const requestId = req.headers['x-request-id'];
9
+ res.status(404).json({
10
+ statusCode: 404,
11
+ message: 'Not Found',
12
+ path: req.path,
13
+ method: req.method,
14
+ requestId,
15
+ timestamp: new Date().toISOString(),
16
+ });
17
+ }
18
+ //# sourceMappingURL=not-found.middleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"not-found.middleware.js","sourceRoot":"","sources":["../../../app/middleware/not-found.middleware.ts"],"names":[],"mappings":";;AAKA,gDAWC;AAdD;;GAEG;AACH,SAAgB,kBAAkB,CAAC,GAAY,EAAE,GAAa;IAC1D,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,cAAc,CAAW,CAAC;IAExD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;QACjB,UAAU,EAAE,GAAG;QACf,OAAO,EAAE,WAAW;QACpB,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,SAAS;QACT,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACtC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,32 @@
1
+ import { Request, Response } from 'express';
2
+ /**
3
+ * Async 메서드 예시 컨트롤러
4
+ * - static async 메서드
5
+ * - instance async 메서드
6
+ * - Promise 기반 비동기 작업 시뮬레이션
7
+ */
8
+ export declare class AsyncExampleController {
9
+ /**
10
+ * Static async 메서드 예시
11
+ * 데이터베이스 조회를 시뮬레이션
12
+ */
13
+ static getUsers(req: Request, res: Response): Promise<void>;
14
+ /**
15
+ * Static async 메서드 - 에러 처리 예시
16
+ */
17
+ static getUserById(req: Request, res: Response): Promise<void>;
18
+ /**
19
+ * Instance async 메서드 예시
20
+ * 인스턴스 변수를 사용할 수 있음
21
+ */
22
+ createUser(req: Request, res: Response): Promise<void>;
23
+ /**
24
+ * Instance async 메서드 - 복잡한 비동기 작업 예시
25
+ */
26
+ updateUser(req: Request, res: Response): Promise<void>;
27
+ /**
28
+ * Promise를 직접 반환하는 async 메서드 예시
29
+ */
30
+ deleteUser(req: Request, res: Response): Promise<Response>;
31
+ }
32
+ //# sourceMappingURL=async-example.controller.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"async-example.controller.d.ts","sourceRoot":"","sources":["../../../../../app/routers/async/controllers/async-example.controller.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAI5C;;;;;GAKG;AACH,qBACa,sBAAsB;IAC/B;;;OAGG;WASU,QAAQ,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBjE;;OAEG;WAWU,WAAW,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBpE;;;OAGG;IAUG,UAAU,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAkB5D;;OAEG;IAYG,UAAU,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IA4B5D;;OAEG;IAUG,UAAU,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;CAgBnE"}
@@ -0,0 +1,205 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.AsyncExampleController = void 0;
13
+ const controllers_1 = require("../../../../src/decorators/controllers");
14
+ const user_dto_1 = require("../../users/dto/user.dto");
15
+ /**
16
+ * Async 메서드 예시 컨트롤러
17
+ * - static async 메서드
18
+ * - instance async 메서드
19
+ * - Promise 기반 비동기 작업 시뮬레이션
20
+ */
21
+ let AsyncExampleController = class AsyncExampleController {
22
+ /**
23
+ * Static async 메서드 예시
24
+ * 데이터베이스 조회를 시뮬레이션
25
+ */
26
+ static async getUsers(req, res) {
27
+ // 비동기 작업 시뮬레이션 (예: 데이터베이스 조회)
28
+ await new Promise(resolve => setTimeout(resolve, 100));
29
+ const users = [
30
+ {
31
+ id: '1',
32
+ name: '홍길동',
33
+ email: 'hong@example.com',
34
+ age: 25,
35
+ role: 'user',
36
+ },
37
+ {
38
+ id: '2',
39
+ name: '김철수',
40
+ email: 'kim@example.com',
41
+ age: 30,
42
+ role: 'admin',
43
+ },
44
+ ];
45
+ res.json(users);
46
+ }
47
+ /**
48
+ * Static async 메서드 - 에러 처리 예시
49
+ */
50
+ static async getUserById(req, res) {
51
+ const { id } = req.params;
52
+ // 비동기 작업 시뮬레이션
53
+ await new Promise(resolve => setTimeout(resolve, 50));
54
+ if (id === '999') {
55
+ res.status(404).json({
56
+ message: '사용자를 찾을 수 없습니다',
57
+ });
58
+ return;
59
+ }
60
+ const user = {
61
+ id,
62
+ name: '홍길동',
63
+ email: 'hong@example.com',
64
+ age: 25,
65
+ role: 'user',
66
+ };
67
+ res.json(user);
68
+ }
69
+ /**
70
+ * Instance async 메서드 예시
71
+ * 인스턴스 변수를 사용할 수 있음
72
+ */
73
+ async createUser(req, res) {
74
+ const dto = req.body;
75
+ // 비동기 작업 시뮬레이션 (예: 데이터베이스 저장)
76
+ await new Promise(resolve => setTimeout(resolve, 200));
77
+ // 인스턴스 변수 사용 예시 (실제로는 서비스나 리포지토리 주입)
78
+ const newUser = {
79
+ id: Date.now().toString(),
80
+ name: dto.name,
81
+ email: dto.email,
82
+ age: dto.age,
83
+ role: dto.role,
84
+ };
85
+ res.status(201).json(newUser);
86
+ }
87
+ /**
88
+ * Instance async 메서드 - 복잡한 비동기 작업 예시
89
+ */
90
+ async updateUser(req, res) {
91
+ const { id } = req.params;
92
+ const dto = req.body;
93
+ // 여러 비동기 작업 시뮬레이션
94
+ await new Promise(resolve => setTimeout(resolve, 100));
95
+ if (id === '999') {
96
+ res.status(404).json({
97
+ message: '사용자를 찾을 수 없습니다',
98
+ });
99
+ return;
100
+ }
101
+ // 추가 비동기 작업
102
+ await new Promise(resolve => setTimeout(resolve, 50));
103
+ const updatedUser = {
104
+ id,
105
+ name: dto.name,
106
+ email: dto.email,
107
+ age: dto.age,
108
+ role: dto.role,
109
+ };
110
+ res.json(updatedUser);
111
+ }
112
+ /**
113
+ * Promise를 직접 반환하는 async 메서드 예시
114
+ */
115
+ async deleteUser(req, res) {
116
+ const { id } = req.params;
117
+ // 비동기 작업 시뮬레이션
118
+ await new Promise(resolve => setTimeout(resolve, 100));
119
+ if (id === '999') {
120
+ return res.status(404).json({
121
+ message: '사용자를 찾을 수 없습니다',
122
+ });
123
+ }
124
+ return res.json({
125
+ message: `사용자 ${id}가 삭제되었습니다`,
126
+ });
127
+ }
128
+ };
129
+ exports.AsyncExampleController = AsyncExampleController;
130
+ __decorate([
131
+ (0, controllers_1.Operation)({
132
+ summary: '사용자 생성 (Instance Async)',
133
+ description: 'Instance async 메서드를 사용한 사용자 생성 예시',
134
+ responses: [
135
+ { status: 201, description: '생성 성공', type: user_dto_1.UserResponseDto },
136
+ { status: 400, description: 'Validation 실패' },
137
+ ],
138
+ body: { type: user_dto_1.CreateUserDto, required: true },
139
+ }),
140
+ __metadata("design:type", Function),
141
+ __metadata("design:paramtypes", [Object, Object]),
142
+ __metadata("design:returntype", Promise)
143
+ ], AsyncExampleController.prototype, "createUser", null);
144
+ __decorate([
145
+ (0, controllers_1.Operation)({
146
+ summary: '사용자 업데이트 (Instance Async)',
147
+ description: '여러 비동기 작업을 수행하는 instance async 메서드 예시',
148
+ responses: [
149
+ { status: 200, description: '업데이트 성공', type: user_dto_1.UserResponseDto },
150
+ { status: 400, description: 'Validation 실패' },
151
+ { status: 404, description: '사용자를 찾을 수 없음' },
152
+ ],
153
+ params: [{ name: 'id', type: String, required: true, description: '사용자 ID' }],
154
+ body: { type: user_dto_1.CreateUserDto, required: true },
155
+ }),
156
+ __metadata("design:type", Function),
157
+ __metadata("design:paramtypes", [Object, Object]),
158
+ __metadata("design:returntype", Promise)
159
+ ], AsyncExampleController.prototype, "updateUser", null);
160
+ __decorate([
161
+ (0, controllers_1.Operation)({
162
+ summary: '사용자 삭제 (Promise Return)',
163
+ description: 'Promise를 직접 반환하는 async 메서드 예시',
164
+ responses: [
165
+ { status: 200, description: '삭제 성공' },
166
+ { status: 404, description: '사용자를 찾을 수 없음' },
167
+ ],
168
+ params: [{ name: 'id', type: String, required: true, description: '사용자 ID' }],
169
+ }),
170
+ __metadata("design:type", Function),
171
+ __metadata("design:paramtypes", [Object, Object]),
172
+ __metadata("design:returntype", Promise)
173
+ ], AsyncExampleController.prototype, "deleteUser", null);
174
+ __decorate([
175
+ (0, controllers_1.Operation)({
176
+ summary: '사용자 목록 조회 (Static Async)',
177
+ description: 'Static async 메서드를 사용한 사용자 목록 조회 예시',
178
+ responses: [
179
+ { status: 200, description: '조회 성공', type: user_dto_1.UserResponseDto, isArray: true },
180
+ { status: 500, description: '서버 오류' },
181
+ ],
182
+ }),
183
+ __metadata("design:type", Function),
184
+ __metadata("design:paramtypes", [Object, Object]),
185
+ __metadata("design:returntype", Promise)
186
+ ], AsyncExampleController, "getUsers", null);
187
+ __decorate([
188
+ (0, controllers_1.Operation)({
189
+ summary: '사용자 조회 (Static Async with Error)',
190
+ description: '에러가 발생할 수 있는 static async 메서드 예시',
191
+ responses: [
192
+ { status: 200, description: '조회 성공', type: user_dto_1.UserResponseDto },
193
+ { status: 404, description: '사용자를 찾을 수 없음' },
194
+ { status: 500, description: '서버 오류' },
195
+ ],
196
+ params: [{ name: 'id', type: String, required: true, description: '사용자 ID' }],
197
+ }),
198
+ __metadata("design:type", Function),
199
+ __metadata("design:paramtypes", [Object, Object]),
200
+ __metadata("design:returntype", Promise)
201
+ ], AsyncExampleController, "getUserById", null);
202
+ exports.AsyncExampleController = AsyncExampleController = __decorate([
203
+ (0, controllers_1.Controller)({ tag: 'Async Examples', path: '/api/async' })
204
+ ], AsyncExampleController);
205
+ //# sourceMappingURL=async-example.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"async-example.controller.js","sourceRoot":"","sources":["../../../../../app/routers/async/controllers/async-example.controller.ts"],"names":[],"mappings":"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"}