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.
- package/dist/app/app.d.ts +5 -0
- package/dist/app/app.d.ts.map +1 -0
- package/dist/app/app.js +181 -0
- package/dist/app/app.js.map +1 -0
- package/dist/app/config/env.config.d.ts +14 -0
- package/dist/app/config/env.config.d.ts.map +1 -0
- package/dist/app/config/env.config.js +22 -0
- package/dist/app/config/env.config.js.map +1 -0
- package/dist/app/middleware/error-handler.middleware.d.ts +17 -0
- package/dist/app/middleware/error-handler.middleware.d.ts.map +1 -0
- package/dist/app/middleware/error-handler.middleware.js +38 -0
- package/dist/app/middleware/error-handler.middleware.js.map +1 -0
- package/dist/app/middleware/logger.middleware.d.ts +6 -0
- package/dist/app/middleware/logger.middleware.d.ts.map +1 -0
- package/dist/app/middleware/logger.middleware.js +34 -0
- package/dist/app/middleware/logger.middleware.js.map +1 -0
- package/dist/app/middleware/not-found.middleware.d.ts +6 -0
- package/dist/app/middleware/not-found.middleware.d.ts.map +1 -0
- package/dist/app/middleware/not-found.middleware.js +18 -0
- package/dist/app/middleware/not-found.middleware.js.map +1 -0
- package/dist/app/routers/async/controllers/async-example.controller.d.ts +32 -0
- package/dist/app/routers/async/controllers/async-example.controller.d.ts.map +1 -0
- package/dist/app/routers/async/controllers/async-example.controller.js +205 -0
- package/dist/app/routers/async/controllers/async-example.controller.js.map +1 -0
- package/dist/app/routers/async/controllers/index.d.ts +2 -0
- package/dist/app/routers/async/controllers/index.d.ts.map +1 -0
- package/dist/app/routers/async/controllers/index.js +6 -0
- package/dist/app/routers/async/controllers/index.js.map +1 -0
- package/dist/app/routers/health/controllers/health.controller.d.ts +5 -0
- package/dist/app/routers/health/controllers/health.controller.d.ts.map +1 -0
- package/dist/app/routers/health/controllers/health.controller.js +35 -0
- package/dist/app/routers/health/controllers/health.controller.js.map +1 -0
- package/dist/app/routers/health/controllers/index.d.ts +2 -0
- package/dist/app/routers/health/controllers/index.d.ts.map +1 -0
- package/dist/app/routers/health/controllers/index.js +6 -0
- package/dist/app/routers/health/controllers/index.js.map +1 -0
- package/dist/app/routers/index.d.ts +6 -0
- package/dist/app/routers/index.d.ts.map +1 -0
- package/dist/app/routers/index.js +23 -0
- package/dist/app/routers/index.js.map +1 -0
- package/dist/app/routers/products/controllers/index.d.ts +2 -0
- package/dist/app/routers/products/controllers/index.d.ts.map +1 -0
- package/dist/app/routers/products/controllers/index.js +6 -0
- package/dist/app/routers/products/controllers/index.js.map +1 -0
- package/dist/app/routers/products/controllers/products.controller.d.ts +21 -0
- package/dist/app/routers/products/controllers/products.controller.d.ts.map +1 -0
- package/dist/app/routers/products/controllers/products.controller.js +124 -0
- package/dist/app/routers/products/controllers/products.controller.js.map +1 -0
- package/dist/app/routers/products/dto/index.d.ts +2 -0
- package/dist/app/routers/products/dto/index.d.ts.map +1 -0
- package/dist/app/routers/products/dto/index.js +18 -0
- package/dist/app/routers/products/dto/index.js.map +1 -0
- package/dist/app/routers/products/dto/product.dto.d.ts +23 -0
- package/dist/app/routers/products/dto/product.dto.d.ts.map +1 -0
- package/dist/app/routers/products/dto/product.dto.js +84 -0
- package/dist/app/routers/products/dto/product.dto.js.map +1 -0
- package/dist/app/routers/products/services/index.d.ts +2 -0
- package/dist/app/routers/products/services/index.d.ts.map +1 -0
- package/dist/app/routers/products/services/index.js +6 -0
- package/dist/app/routers/products/services/index.js.map +1 -0
- package/dist/app/routers/products/services/product.service.d.ts +32 -0
- package/dist/app/routers/products/services/product.service.d.ts.map +1 -0
- package/dist/app/routers/products/services/product.service.js +62 -0
- package/dist/app/routers/products/services/product.service.js.map +1 -0
- package/dist/app/routers/test/controllers/index.d.ts +2 -0
- package/dist/app/routers/test/controllers/index.d.ts.map +1 -0
- package/dist/app/routers/test/controllers/index.js +6 -0
- package/dist/app/routers/test/controllers/index.js.map +1 -0
- package/dist/app/routers/test/controllers/test.controller.d.ts +6 -0
- package/dist/app/routers/test/controllers/test.controller.d.ts.map +1 -0
- package/dist/app/routers/test/controllers/test.controller.js +68 -0
- package/dist/app/routers/test/controllers/test.controller.js.map +1 -0
- package/dist/app/routers/test/dto/index.d.ts +2 -0
- package/dist/app/routers/test/dto/index.d.ts.map +1 -0
- package/dist/app/routers/test/dto/index.js +18 -0
- package/dist/app/routers/test/dto/index.js.map +1 -0
- package/dist/app/routers/test/dto/test.dto.d.ts +27 -0
- package/dist/app/routers/test/dto/test.dto.d.ts.map +1 -0
- package/dist/app/routers/test/dto/test.dto.js +81 -0
- package/dist/app/routers/test/dto/test.dto.js.map +1 -0
- package/dist/app/routers/users/controllers/index.d.ts +2 -0
- package/dist/app/routers/users/controllers/index.d.ts.map +1 -0
- package/dist/app/routers/users/controllers/index.js +6 -0
- package/dist/app/routers/users/controllers/index.js.map +1 -0
- package/dist/app/routers/users/controllers/users.controller.d.ts +6 -0
- package/dist/app/routers/users/controllers/users.controller.d.ts.map +1 -0
- package/dist/app/routers/users/controllers/users.controller.js +68 -0
- package/dist/app/routers/users/controllers/users.controller.js.map +1 -0
- package/dist/app/routers/users/dto/index.d.ts +2 -0
- package/dist/app/routers/users/dto/index.d.ts.map +1 -0
- package/dist/app/routers/users/dto/index.js +18 -0
- package/dist/app/routers/users/dto/index.js.map +1 -0
- package/dist/app/routers/users/dto/user.dto.d.ts +28 -0
- package/dist/app/routers/users/dto/user.dto.d.ts.map +1 -0
- package/dist/app/routers/users/dto/user.dto.js +96 -0
- package/dist/app/routers/users/dto/user.dto.js.map +1 -0
- package/dist/app/routers/users/services/index.d.ts +2 -0
- package/dist/app/routers/users/services/index.d.ts.map +1 -0
- package/dist/app/routers/users/services/index.js +6 -0
- package/dist/app/routers/users/services/index.js.map +1 -0
- package/dist/app/routers/users/services/user.service.d.ts +16 -0
- package/dist/app/routers/users/services/user.service.d.ts.map +1 -0
- package/dist/app/routers/users/services/user.service.js +39 -0
- package/dist/app/routers/users/services/user.service.js.map +1 -0
- package/dist/src/configs/app-initializer.d.ts +49 -0
- package/dist/src/configs/app-initializer.d.ts.map +1 -0
- package/dist/src/configs/app-initializer.js +55 -0
- package/dist/src/configs/app-initializer.js.map +1 -0
- package/dist/src/configs/extractors/auto-extract-dtos.extractor.d.ts +7 -0
- package/dist/src/configs/extractors/auto-extract-dtos.extractor.d.ts.map +1 -0
- package/dist/src/configs/extractors/auto-extract-dtos.extractor.js +54 -0
- package/dist/src/configs/extractors/auto-extract-dtos.extractor.js.map +1 -0
- package/dist/src/configs/extractors/extract-controllers-from-module.extractor.d.ts +8 -0
- package/dist/src/configs/extractors/extract-controllers-from-module.extractor.d.ts.map +1 -0
- package/dist/src/configs/extractors/extract-controllers-from-module.extractor.js +36 -0
- package/dist/src/configs/extractors/extract-controllers-from-module.extractor.js.map +1 -0
- package/dist/src/configs/extractors/extract-dtos-from-module.extractor.d.ts +8 -0
- package/dist/src/configs/extractors/extract-dtos-from-module.extractor.d.ts.map +1 -0
- package/dist/src/configs/extractors/extract-dtos-from-module.extractor.js +34 -0
- package/dist/src/configs/extractors/extract-dtos-from-module.extractor.js.map +1 -0
- package/dist/src/configs/extractors/index.d.ts +4 -0
- package/dist/src/configs/extractors/index.d.ts.map +1 -0
- package/dist/src/configs/extractors/index.js +10 -0
- package/dist/src/configs/extractors/index.js.map +1 -0
- package/dist/src/configs/index.d.ts +9 -0
- package/dist/src/configs/index.d.ts.map +1 -0
- package/dist/src/configs/index.js +31 -0
- package/dist/src/configs/index.js.map +1 -0
- package/dist/src/configs/middleware/index.d.ts +2 -0
- package/dist/src/configs/middleware/index.d.ts.map +1 -0
- package/dist/src/configs/middleware/index.js +6 -0
- package/dist/src/configs/middleware/index.js.map +1 -0
- package/dist/src/configs/middleware/validation.middleware.d.ts +18 -0
- package/dist/src/configs/middleware/validation.middleware.d.ts.map +1 -0
- package/dist/src/configs/middleware/validation.middleware.js +50 -0
- package/dist/src/configs/middleware/validation.middleware.js.map +1 -0
- package/dist/src/configs/routes/auto-register-routes.route.d.ts +10 -0
- package/dist/src/configs/routes/auto-register-routes.route.d.ts.map +1 -0
- package/dist/src/configs/routes/auto-register-routes.route.js +80 -0
- package/dist/src/configs/routes/auto-register-routes.route.js.map +1 -0
- package/dist/src/configs/routes/auto-scan-controller-methods.route.d.ts +8 -0
- package/dist/src/configs/routes/auto-scan-controller-methods.route.d.ts.map +1 -0
- package/dist/src/configs/routes/auto-scan-controller-methods.route.js +44 -0
- package/dist/src/configs/routes/auto-scan-controller-methods.route.js.map +1 -0
- package/dist/src/configs/routes/generate-route-info.route.d.ts +11 -0
- package/dist/src/configs/routes/generate-route-info.route.d.ts.map +1 -0
- package/dist/src/configs/routes/generate-route-info.route.js +84 -0
- package/dist/src/configs/routes/generate-route-info.route.js.map +1 -0
- package/dist/src/configs/routes/index.d.ts +4 -0
- package/dist/src/configs/routes/index.d.ts.map +1 -0
- package/dist/src/configs/routes/index.js +10 -0
- package/dist/src/configs/routes/index.js.map +1 -0
- package/dist/src/configs/swagger.factory.d.ts +87 -0
- package/dist/src/configs/swagger.factory.d.ts.map +1 -0
- package/dist/src/configs/swagger.factory.js +689 -0
- package/dist/src/configs/swagger.factory.js.map +1 -0
- package/dist/src/configs/utils/format-validation-errors.util.d.ts +8 -0
- package/dist/src/configs/utils/format-validation-errors.util.d.ts.map +1 -0
- package/dist/src/configs/utils/format-validation-errors.util.js +25 -0
- package/dist/src/configs/utils/format-validation-errors.util.js.map +1 -0
- package/dist/src/configs/utils/has-swagger-decorators.util.d.ts +9 -0
- package/dist/src/configs/utils/has-swagger-decorators.util.d.ts.map +1 -0
- package/dist/src/configs/utils/has-swagger-decorators.util.js +19 -0
- package/dist/src/configs/utils/has-swagger-decorators.util.js.map +1 -0
- package/dist/src/configs/utils/index.d.ts +4 -0
- package/dist/src/configs/utils/index.d.ts.map +1 -0
- package/dist/src/configs/utils/index.js +10 -0
- package/dist/src/configs/utils/index.js.map +1 -0
- package/dist/src/configs/utils/is-enum.util.d.ts +7 -0
- package/dist/src/configs/utils/is-enum.util.d.ts.map +1 -0
- package/dist/src/configs/utils/is-enum.util.js +26 -0
- package/dist/src/configs/utils/is-enum.util.js.map +1 -0
- package/dist/src/decorators/controllers/api-body.decorator.d.ts +20 -0
- package/dist/src/decorators/controllers/api-body.decorator.d.ts.map +1 -0
- package/dist/src/decorators/controllers/api-body.decorator.js +39 -0
- package/dist/src/decorators/controllers/api-body.decorator.js.map +1 -0
- package/dist/src/decorators/controllers/api-operation.decorator.d.ts +15 -0
- package/dist/src/decorators/controllers/api-operation.decorator.d.ts.map +1 -0
- package/dist/src/decorators/controllers/api-operation.decorator.js +23 -0
- package/dist/src/decorators/controllers/api-operation.decorator.js.map +1 -0
- package/dist/src/decorators/controllers/api-param.decorator.d.ts +20 -0
- package/dist/src/decorators/controllers/api-param.decorator.d.ts.map +1 -0
- package/dist/src/decorators/controllers/api-param.decorator.js +41 -0
- package/dist/src/decorators/controllers/api-param.decorator.js.map +1 -0
- package/dist/src/decorators/controllers/api-query.decorator.d.ts +20 -0
- package/dist/src/decorators/controllers/api-query.decorator.d.ts.map +1 -0
- package/dist/src/decorators/controllers/api-query.decorator.js +41 -0
- package/dist/src/decorators/controllers/api-query.decorator.js.map +1 -0
- package/dist/src/decorators/controllers/api-response.decorator.d.ts +16 -0
- package/dist/src/decorators/controllers/api-response.decorator.d.ts.map +1 -0
- package/dist/src/decorators/controllers/api-response.decorator.js +25 -0
- package/dist/src/decorators/controllers/api-response.decorator.js.map +1 -0
- package/dist/src/decorators/controllers/api-tags.decorator.d.ts +17 -0
- package/dist/src/decorators/controllers/api-tags.decorator.d.ts.map +1 -0
- package/dist/src/decorators/controllers/api-tags.decorator.js +35 -0
- package/dist/src/decorators/controllers/api-tags.decorator.js.map +1 -0
- package/dist/src/decorators/controllers/controller-metadata.d.ts +75 -0
- package/dist/src/decorators/controllers/controller-metadata.d.ts.map +1 -0
- package/dist/src/decorators/controllers/controller-metadata.js +17 -0
- package/dist/src/decorators/controllers/controller-metadata.js.map +1 -0
- package/dist/src/decorators/controllers/controller.decorator.d.ts +31 -0
- package/dist/src/decorators/controllers/controller.decorator.d.ts.map +1 -0
- package/dist/src/decorators/controllers/controller.decorator.js +52 -0
- package/dist/src/decorators/controllers/controller.decorator.js.map +1 -0
- package/dist/src/decorators/controllers/index.d.ts +12 -0
- package/dist/src/decorators/controllers/index.d.ts.map +1 -0
- package/dist/src/decorators/controllers/index.js +24 -0
- package/dist/src/decorators/controllers/index.js.map +1 -0
- package/dist/src/decorators/controllers/operation.decorator.d.ts +45 -0
- package/dist/src/decorators/controllers/operation.decorator.d.ts.map +1 -0
- package/dist/src/decorators/controllers/operation.decorator.js +93 -0
- package/dist/src/decorators/controllers/operation.decorator.js.map +1 -0
- package/dist/src/index.d.ts +2 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +10 -1
- package/dist/src/index.js.map +1 -1
- package/package.json +13 -5
|
@@ -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"}
|
package/dist/app/app.js
ADDED
|
@@ -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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4BAA0B;AAC1B,sDAA2C;AAC3C,4CAA0C;AAC1C,4DAA8C;AAC9C,oDAA0C;AAC1C,sEAAkE;AAClE,oFAA+E;AAC/E,4EAAuE;AAEvE,wBAAwB;AACxB,IAAI,MAAW,CAAC;AAChB,IAAI,IAAS,CAAC;AACd,IAAI,WAAgB,CAAC;AAErB,IAAI,CAAC;IACD,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;AAC/B,CAAC;AAAC,OAAO,CAAC,EAAE,CAAC;IACT,OAAO,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC;AAC9D,CAAC;AAED,IAAI,CAAC;IACD,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;AAC3B,CAAC;AAAC,OAAO,CAAC,EAAE,CAAC;IACT,OAAO,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;AAC3D,CAAC;AAED,IAAI,CAAC;IACD,WAAW,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;AACzC,CAAC;AAAC,OAAO,CAAC,EAAE,CAAC;IACT,OAAO,CAAC,IAAI,CAAC,6CAA6C,CAAC,CAAC;AAChE,CAAC;AAED;;GAEG;AACH,SAAS,SAAS;IACd,MAAM,GAAG,GAAY,IAAA,iBAAO,GAAE,CAAC;IAE/B,6BAA6B;IAC7B,GAAG,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;IAE7B,gBAAgB;IAChB,IAAI,MAAM,EAAE,CAAC;QACT,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC;YACX,qBAAqB,EAAE,gBAAG,CAAC,QAAQ,KAAK,YAAY;YACpD,yBAAyB,EAAE,KAAK;SACnC,CAAC,CAAC,CAAC;IACR,CAAC;IAED,gBAAgB;IAChB,IAAI,IAAI,EAAE,CAAC;QACP,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC;YACT,MAAM,EAAE,gBAAG,CAAC,WAAW,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,gBAAG,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC;YACnE,WAAW,EAAE,IAAI;YACjB,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,CAAC;YAC7D,cAAc,EAAE,CAAC,cAAc,EAAE,eAAe,EAAE,cAAc,CAAC;SACpE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,gBAAgB;IAChB,IAAI,WAAW,EAAE,CAAC;QACd,GAAG,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;IAC3B,CAAC;IAED,eAAe;IACf,GAAG,CAAC,GAAG,CAAC,iBAAO,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;IACzC,GAAG,CAAC,GAAG,CAAC,iBAAO,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;IAE/D,aAAa;IACb,GAAG,CAAC,GAAG,CAAC,oCAAgB,CAAC,CAAC;IAE1B,uBAAuB;IACvB,IAAI,gBAAG,CAAC,eAAe,EAAE,CAAC;QACtB,IAAA,kBAAQ,EAAC;YACL,GAAG;YACH,WAAW,EAAE,gBAAgB;YAC7B,OAAO,EAAE;gBACL,KAAK,EAAE,mBAAmB;gBAC1B,OAAO,EAAE,gBAAG,CAAC,WAAW;gBACxB,WAAW,EAAE,oCAAoC;gBACjD,OAAO,EAAE;oBACL;wBACI,GAAG,EAAE,oBAAoB,gBAAG,CAAC,IAAI,EAAE;wBACnC,WAAW,EAAE,UAAU;qBAC1B;oBACD;wBACI,GAAG,EAAE,yBAAyB;wBAC9B,WAAW,EAAE,SAAS;qBACzB;iBACJ;aACJ;YACD,WAAW,EAAE,gBAAG,CAAC,YAAY;SAChC,CAAC,CAAC;IACP,CAAC;SAAM,CAAC;QACJ,qBAAqB;QACrB,MAAM,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;QACzD,kBAAkB,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;IAC9C,CAAC;IAED,kCAAkC;IAClC,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;QAC5B,GAAG,CAAC,IAAI,CAAC;YACL,MAAM,EAAE,IAAI;YACZ,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE;YACxB,WAAW,EAAE,gBAAG,CAAC,QAAQ;SAC5B,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,0BAA0B;IAC1B,GAAG,CAAC,GAAG,CAAC,iDAAsB,CAAC,CAAC;IAEhC,iCAAiC;IACjC,GAAG,CAAC,GAAG,CAAC,yCAAkB,CAAC,CAAC;IAE5B,OAAO,GAAG,CAAC;AACf,CAAC;AAED,YAAY;AACZ,MAAM,GAAG,GAAG,SAAS,EAAE,CAAC;AAExB,QAAQ;AACR,SAAS,WAAW;IAChB,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,gBAAG,CAAC,IAAI,EAAE,GAAG,EAAE;QACrC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5B,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;QACpC,OAAO,CAAC,GAAG,CAAC,mBAAmB,gBAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC/C,OAAO,CAAC,GAAG,CAAC,YAAY,gBAAG,CAAC,IAAI,EAAE,CAAC,CAAC;QACpC,OAAO,CAAC,GAAG,CAAC,mBAAmB,gBAAG,CAAC,WAAW,EAAE,CAAC,CAAC;QAClD,IAAI,gBAAG,CAAC,eAAe,EAAE,CAAC;YACtB,OAAO,CAAC,GAAG,CAAC,mCAAmC,gBAAG,CAAC,IAAI,GAAG,gBAAG,CAAC,YAAY,EAAE,CAAC,CAAC;QAClF,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,sCAAsC,gBAAG,CAAC,IAAI,SAAS,CAAC,CAAC;QACrE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,oBAAoB;IACpB,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,GAAG,EAAE;QACvB,OAAO,CAAC,GAAG,CAAC,8CAA8C,CAAC,CAAC;QAC5D,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE;YACd,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;YAClC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;QACtB,OAAO,CAAC,GAAG,CAAC,6CAA6C,CAAC,CAAC;QAC3D,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE;YACd,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;YAClC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AACP,CAAC;AAED,kBAAkB;AAClB,IAAI,OAAO,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;IAC1B,WAAW,EAAE,CAAC;AAClB,CAAC;AAED,kBAAe,GAAG,CAAC"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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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"}
|