@skyapp-labs/blueprint-backend-core 1.0.10 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +3 -3
- package/README.md +10 -1
- package/dist/common/filters/http-exception.filter.d.ts +12 -0
- package/dist/common/filters/http-exception.filter.d.ts.map +1 -1
- package/dist/common/filters/http-exception.filter.js +63 -3
- package/dist/common/filters/http-exception.filter.js.map +1 -1
- package/dist/common/index.d.ts +1 -1
- package/dist/common/index.d.ts.map +1 -1
- package/dist/common/index.js +1 -1
- package/dist/common/index.js.map +1 -1
- package/dist/common/interceptors/index.d.ts +1 -0
- package/dist/common/interceptors/index.d.ts.map +1 -1
- package/dist/common/interceptors/index.js +1 -0
- package/dist/common/interceptors/index.js.map +1 -1
- package/dist/common/interceptors/timeout.interceptor.d.ts +8 -0
- package/dist/common/interceptors/timeout.interceptor.d.ts.map +1 -0
- package/dist/common/interceptors/timeout.interceptor.js +37 -0
- package/dist/common/interceptors/timeout.interceptor.js.map +1 -0
- package/dist/common/middlewares/index.d.ts +1 -1
- package/dist/common/middlewares/index.d.ts.map +1 -1
- package/dist/common/middlewares/index.js +13 -4
- package/dist/common/middlewares/index.js.map +1 -1
- package/dist/common/pipes/config-aware-validation.pipe.d.ts.map +1 -1
- package/dist/common/pipes/config-aware-validation.pipe.js +8 -1
- package/dist/common/pipes/config-aware-validation.pipe.js.map +1 -1
- package/dist/common/utils/index.d.ts +1 -0
- package/dist/common/utils/index.d.ts.map +1 -1
- package/dist/common/utils/index.js +15 -0
- package/dist/common/utils/index.js.map +1 -1
- package/dist/common/utils/validation.d.ts +10 -0
- package/dist/common/utils/validation.d.ts.map +1 -0
- package/dist/common/utils/validation.js +28 -0
- package/dist/common/utils/validation.js.map +1 -0
- package/dist/config/app.config.d.ts +7 -0
- package/dist/config/app.config.d.ts.map +1 -1
- package/dist/config/app.config.js +17 -1
- package/dist/config/app.config.js.map +1 -1
- package/dist/config/database.config.d.ts +2 -2
- package/dist/config/database.config.d.ts.map +1 -1
- package/dist/config/database.config.js +2 -1
- package/dist/config/database.config.js.map +1 -1
- package/dist/config/env.validation.d.ts +5 -0
- package/dist/config/env.validation.d.ts.map +1 -1
- package/dist/config/env.validation.js +27 -0
- package/dist/config/env.validation.js.map +1 -1
- package/dist/config/redis.module.d.ts.map +1 -1
- package/dist/config/redis.module.js +3 -3
- package/dist/config/redis.module.js.map +1 -1
- package/dist/config/tls.util.d.ts +19 -0
- package/dist/config/tls.util.d.ts.map +1 -0
- package/dist/config/tls.util.js +47 -0
- package/dist/config/tls.util.js.map +1 -0
- package/dist/core.module.d.ts.map +1 -1
- package/dist/core.module.js +2 -0
- package/dist/core.module.js.map +1 -1
- package/dist/database/data-source.d.ts.map +1 -1
- package/dist/database/data-source.js +2 -1
- package/dist/database/data-source.js.map +1 -1
- package/dist/database/migrations/1746468000000-add-schema-to-app-settings.d.ts +7 -0
- package/dist/database/migrations/1746468000000-add-schema-to-app-settings.d.ts.map +1 -0
- package/dist/database/migrations/1746468000000-add-schema-to-app-settings.js +17 -0
- package/dist/database/migrations/1746468000000-add-schema-to-app-settings.js.map +1 -0
- package/dist/database/seeds/settings.seed.d.ts.map +1 -1
- package/dist/database/seeds/settings.seed.js +24 -2
- package/dist/database/seeds/settings.seed.js.map +1 -1
- package/dist/health/health.module.d.ts.map +1 -1
- package/dist/health/health.module.js +2 -3
- package/dist/health/health.module.js.map +1 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7 -1
- package/dist/index.js.map +1 -1
- package/dist/jobs/jobs.module.d.ts.map +1 -1
- package/dist/jobs/jobs.module.js +2 -3
- package/dist/jobs/jobs.module.js.map +1 -1
- package/dist/modules/auth/auth-core/auth-core.module.d.ts.map +1 -1
- package/dist/modules/auth/auth-core/auth-core.module.js +1 -1
- package/dist/modules/auth/auth-core/auth-core.module.js.map +1 -1
- package/dist/modules/auth/auth-core/strategies/jwt.strategy.js +1 -1
- package/dist/modules/auth/auth-core/strategies/jwt.strategy.js.map +1 -1
- package/dist/modules/settings/entities/app-setting.entity.d.ts +2 -1
- package/dist/modules/settings/entities/app-setting.entity.d.ts.map +1 -1
- package/dist/modules/settings/entities/app-setting.entity.js +9 -0
- package/dist/modules/settings/entities/app-setting.entity.js.map +1 -1
- package/dist/modules/settings/services/settings.service.d.ts.map +1 -1
- package/dist/modules/settings/services/settings.service.js +2 -0
- package/dist/modules/settings/services/settings.service.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
# [1.2.0](https://github.com/Skyapp-Labs/blueprint-backend-core/compare/v1.1.0...v1.2.0) (2026-05-06)
|
|
2
2
|
|
|
3
3
|
|
|
4
|
-
###
|
|
4
|
+
### Features
|
|
5
5
|
|
|
6
|
-
*
|
|
6
|
+
* add schema column to app settings and support arrayOfObject type for complex configurations ([e6e5774](https://github.com/Skyapp-Labs/blueprint-backend-core/commit/e6e57747e4de67dd871bc09cfd517455d3e64991))
|
package/README.md
CHANGED
|
@@ -216,6 +216,7 @@ Copy `.env.example` from this package as a starting point.
|
|
|
216
216
|
| `APP_URL` | — | | Full base URL (used in invite/reset emails) |
|
|
217
217
|
| `APP_DEBUG` | `false` | | Enable verbose logging |
|
|
218
218
|
| `SWAGGER_ENABLED` | auto | | Force-enable Swagger in production (`true`/`false`) |
|
|
219
|
+
| `HTTP_REQUEST_TIMEOUT_MS` | `30000` | | Global HTTP handler timeout (ms); clamped 1000–120000. Host registers `TimeoutInterceptor` with `app.requestTimeoutMs`. |
|
|
219
220
|
|
|
220
221
|
### Database
|
|
221
222
|
|
|
@@ -227,12 +228,16 @@ Copy `.env.example` from this package as a starting point.
|
|
|
227
228
|
| `DATABASE_PASSWORD` | — | **yes** | DB password |
|
|
228
229
|
| `DATABASE_NAME` | — | **yes** | DB name |
|
|
229
230
|
| `DATABASE_SSL` | `false` | | Enable SSL (`true`/`false`) |
|
|
231
|
+
| `DATABASE_SSL_REJECT_UNAUTHORIZED` | `true`* | | When SSL is on, verify server cert (`false` only if unavoidable) |
|
|
232
|
+
| `DATABASE_SSL_CA` | — | | Path to PEM CA bundle (e.g. RDS); optional if the server uses a public CA |
|
|
233
|
+
|
|
234
|
+
\*When `DATABASE_SSL=true`, verification defaults to on unless you set `DATABASE_SSL_REJECT_UNAUTHORIZED=false`.
|
|
230
235
|
|
|
231
236
|
### JWT
|
|
232
237
|
|
|
233
238
|
| Variable | Default | Required | Description |
|
|
234
239
|
|----------|---------|----------|-------------|
|
|
235
|
-
| `JWT_SECRET` | — | **yes** | Use a strong random string in
|
|
240
|
+
| `JWT_SECRET` | — | **yes** | Use a strong random string; there is no safe default in `app.config` — rely on `envValidation` |
|
|
236
241
|
| `JWT_EXPIRATION` | `1d` | | Access token lifetime (e.g. `15m`, `1h`, `1d`) |
|
|
237
242
|
|
|
238
243
|
### Redis
|
|
@@ -244,6 +249,10 @@ Copy `.env.example` from this package as a starting point.
|
|
|
244
249
|
| `REDIS_PORT` | `6379` | | Redis port |
|
|
245
250
|
| `REDIS_PASSWORD` | — | | Redis password (leave empty for local dev) |
|
|
246
251
|
| `REDIS_TLS` | `false` | | Enable TLS (for managed Redis — Upstash, ElastiCache, etc.) |
|
|
252
|
+
| `REDIS_TLS_REJECT_UNAUTHORIZED` | `true`* | | When TLS is on, verify server cert (`false` only if unavoidable) |
|
|
253
|
+
| `REDIS_TLS_CA` | — | | Path to PEM CA bundle; optional if the server uses a public CA |
|
|
254
|
+
|
|
255
|
+
\*When `REDIS_TLS=true`, verification defaults to on unless you set `REDIS_TLS_REJECT_UNAUTHORIZED=false`.
|
|
247
256
|
|
|
248
257
|
> When `REDIS_ENABLED=false`, OTP flows and background jobs are gracefully disabled. JWT-based auth still works, but OTP sending/verification, per-IP rate limiting, and job queues are inactive.
|
|
249
258
|
|
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
import { ExceptionFilter, ArgumentsHost } from '@nestjs/common';
|
|
2
2
|
import { ConfigService } from '@nestjs/config';
|
|
3
|
+
export type ValidationPayload = string[] | Record<string, string[]>;
|
|
4
|
+
export interface HttpErrorResponseBody {
|
|
5
|
+
statusCode: number;
|
|
6
|
+
timestamp: string;
|
|
7
|
+
path: string;
|
|
8
|
+
method: string;
|
|
9
|
+
message: string;
|
|
10
|
+
error?: string;
|
|
11
|
+
errorCode?: string;
|
|
12
|
+
validations?: ValidationPayload;
|
|
13
|
+
stack?: string;
|
|
14
|
+
}
|
|
3
15
|
export declare class HttpExceptionFilter implements ExceptionFilter {
|
|
4
16
|
private readonly configService;
|
|
5
17
|
private readonly logger;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-exception.filter.d.ts","sourceRoot":"","sources":["../../../common/filters/http-exception.filter.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,eAAe,EAEf,aAAa,EAIb,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"http-exception.filter.d.ts","sourceRoot":"","sources":["../../../common/filters/http-exception.filter.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,eAAe,EAEf,aAAa,EAIb,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAQ/C,MAAM,MAAM,iBAAiB,GAAG,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;AAEpE,MAAM,WAAW,qBAAqB;IACrC,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IAEf,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,WAAW,CAAC,EAAE,iBAAiB,CAAC;IAChC,KAAK,CAAC,EAAE,MAAM,CAAC;CACf;AAgED,qBACa,mBAAoB,YAAW,eAAe;IAG9C,OAAO,CAAC,QAAQ,CAAC,aAAa;IAF1C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAwC;gBAElC,aAAa,EAAE,aAAa;IAEzD,KAAK,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,aAAa,GAAG,IAAI;CA+DpD"}
|
|
@@ -13,6 +13,59 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
13
13
|
exports.HttpExceptionFilter = void 0;
|
|
14
14
|
const common_1 = require("@nestjs/common");
|
|
15
15
|
const config_1 = require("@nestjs/config");
|
|
16
|
+
function pickErrorCode(responseObj) {
|
|
17
|
+
const code = responseObj.errorCode;
|
|
18
|
+
return typeof code === 'string' && code.length > 0 ? code : undefined;
|
|
19
|
+
}
|
|
20
|
+
function pickValidations(responseObj) {
|
|
21
|
+
const v = responseObj.validations;
|
|
22
|
+
if (Array.isArray(v) && v.every((x) => typeof x === 'string')) {
|
|
23
|
+
if (v.length === 0)
|
|
24
|
+
return undefined;
|
|
25
|
+
return v;
|
|
26
|
+
}
|
|
27
|
+
if (v !== null && typeof v === 'object' && !Array.isArray(v)) {
|
|
28
|
+
const rec = v;
|
|
29
|
+
const out = {};
|
|
30
|
+
for (const [key, val] of Object.entries(rec)) {
|
|
31
|
+
if (Array.isArray(val) && val.every((x) => typeof x === 'string')) {
|
|
32
|
+
out[key] = val;
|
|
33
|
+
}
|
|
34
|
+
else if (typeof val === 'string') {
|
|
35
|
+
out[key] = [val];
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return Object.keys(out).length > 0 ? out : undefined;
|
|
39
|
+
}
|
|
40
|
+
return undefined;
|
|
41
|
+
}
|
|
42
|
+
function normalizeMessageAndValidations(responseObj) {
|
|
43
|
+
const raw = responseObj.message;
|
|
44
|
+
const explicit = pickValidations(responseObj);
|
|
45
|
+
if (typeof raw === 'string') {
|
|
46
|
+
return {
|
|
47
|
+
message: raw,
|
|
48
|
+
...(explicit !== undefined && { validations: explicit }),
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
if (Array.isArray(raw) && raw.every((x) => typeof x === 'string')) {
|
|
52
|
+
const arr = raw;
|
|
53
|
+
const primary = arr[0] ?? 'Bad Request';
|
|
54
|
+
const derivedList = explicit === undefined && arr.length > 1 ? arr.slice(1) : undefined;
|
|
55
|
+
const validations = explicit ?? derivedList;
|
|
56
|
+
const list = validations;
|
|
57
|
+
const includeList = list !== undefined &&
|
|
58
|
+
(Array.isArray(list) ? list.length > 0 : Object.keys(list).length > 0);
|
|
59
|
+
return {
|
|
60
|
+
message: primary,
|
|
61
|
+
...(includeList && { validations: list }),
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
return {
|
|
65
|
+
message: 'Bad Request',
|
|
66
|
+
...(explicit !== undefined && { validations: explicit }),
|
|
67
|
+
};
|
|
68
|
+
}
|
|
16
69
|
let HttpExceptionFilter = HttpExceptionFilter_1 = class HttpExceptionFilter {
|
|
17
70
|
constructor(configService) {
|
|
18
71
|
this.configService = configService;
|
|
@@ -27,20 +80,25 @@ let HttpExceptionFilter = HttpExceptionFilter_1 = class HttpExceptionFilter {
|
|
|
27
80
|
let status = common_1.HttpStatus.INTERNAL_SERVER_ERROR;
|
|
28
81
|
let message = 'Internal server error';
|
|
29
82
|
let error = 'Internal Server Error';
|
|
83
|
+
let errorCode;
|
|
84
|
+
let validations;
|
|
30
85
|
if (exception instanceof common_1.HttpException) {
|
|
31
86
|
status = exception.getStatus();
|
|
32
87
|
const exceptionResponse = exception.getResponse();
|
|
33
88
|
if (typeof exceptionResponse === 'object' && exceptionResponse !== null) {
|
|
34
89
|
const responseObj = exceptionResponse;
|
|
35
|
-
message = responseObj.message || exception.message;
|
|
36
90
|
error = responseObj.error || exception.name;
|
|
91
|
+
errorCode = pickErrorCode(responseObj);
|
|
92
|
+
const normalized = normalizeMessageAndValidations(responseObj);
|
|
93
|
+
message = normalized.message;
|
|
94
|
+
validations = normalized.validations;
|
|
37
95
|
if (status === common_1.HttpStatus.TOO_MANY_REQUESTS &&
|
|
38
96
|
typeof responseObj.retryAfter === 'number') {
|
|
39
97
|
response.setHeader('Retry-After', String(responseObj.retryAfter));
|
|
40
98
|
}
|
|
41
99
|
}
|
|
42
100
|
else {
|
|
43
|
-
message = exception.message;
|
|
101
|
+
message = String(exception.message ?? 'Error');
|
|
44
102
|
}
|
|
45
103
|
}
|
|
46
104
|
else if (exception instanceof Error) {
|
|
@@ -54,12 +112,14 @@ let HttpExceptionFilter = HttpExceptionFilter_1 = class HttpExceptionFilter {
|
|
|
54
112
|
method: request.method,
|
|
55
113
|
message,
|
|
56
114
|
error,
|
|
115
|
+
...(errorCode && { errorCode }),
|
|
116
|
+
...(validations !== undefined && { validations }),
|
|
57
117
|
};
|
|
58
118
|
const isDebug = this.configService.get('app.debug', false);
|
|
59
119
|
if (isDebug && exception instanceof Error) {
|
|
60
120
|
errorResponse.stack = exception.stack;
|
|
61
121
|
}
|
|
62
|
-
this.logger.error(`${request.method} ${request.url} - ${status} - ${
|
|
122
|
+
this.logger.error(`${request.method} ${request.url} - ${status} - ${message}`, isDebug && exception instanceof Error ? exception.stack : undefined);
|
|
63
123
|
response.status(status).json(errorResponse);
|
|
64
124
|
}
|
|
65
125
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-exception.filter.js","sourceRoot":"","sources":["../../../common/filters/http-exception.filter.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,2CAOwB;AACxB,2CAA+C;
|
|
1
|
+
{"version":3,"file":"http-exception.filter.js","sourceRoot":"","sources":["../../../common/filters/http-exception.filter.ts"],"names":[],"mappings":"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"}
|
package/dist/common/index.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ export * from './decorators';
|
|
|
3
3
|
export * from './dto';
|
|
4
4
|
export * from './filters';
|
|
5
5
|
export * from './guards';
|
|
6
|
-
export * from './interceptors
|
|
6
|
+
export * from './interceptors';
|
|
7
7
|
export * from './interfaces';
|
|
8
8
|
export * from './middlewares';
|
|
9
9
|
export * from './pipes';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../common/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,OAAO,CAAC;AACtB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../common/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,OAAO,CAAC;AACtB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAC7B,cAAc,eAAe,CAAC;AAC9B,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AAGxB,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EACN,cAAc,EACd,KAAK,iBAAiB,EACtB,KAAK,eAAe,GACpB,MAAM,wBAAwB,CAAC"}
|
package/dist/common/index.js
CHANGED
|
@@ -20,7 +20,7 @@ __exportStar(require("./decorators"), exports);
|
|
|
20
20
|
__exportStar(require("./dto"), exports);
|
|
21
21
|
__exportStar(require("./filters"), exports);
|
|
22
22
|
__exportStar(require("./guards"), exports);
|
|
23
|
-
__exportStar(require("./interceptors
|
|
23
|
+
__exportStar(require("./interceptors"), exports);
|
|
24
24
|
__exportStar(require("./interfaces"), exports);
|
|
25
25
|
__exportStar(require("./middlewares"), exports);
|
|
26
26
|
__exportStar(require("./pipes"), exports);
|
package/dist/common/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,+CAA6B;AAC7B,wCAAsB;AACtB,4CAA0B;AAC1B,2CAAyB;AACzB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,+CAA6B;AAC7B,wCAAsB;AACtB,4CAA0B;AAC1B,2CAAyB;AACzB,iDAA+B;AAC/B,+CAA6B;AAC7B,gDAA8B;AAC9B,0CAAwB;AACxB,0CAAwB;AAGxB,kDAAiE;AAAxD,yGAAA,UAAU,OAAA;AAAE,8GAAA,eAAe,OAAA;AACpC,0DAIgC;AAH/B,iHAAA,cAAc,OAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../common/interceptors/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../common/interceptors/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,uBAAuB,CAAC"}
|
|
@@ -15,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./logging.interceptor"), exports);
|
|
18
|
+
__exportStar(require("./timeout.interceptor"), exports);
|
|
18
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../common/interceptors/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wDAAsC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../common/interceptors/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wDAAsC;AACtC,wDAAsC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
export declare class TimeoutInterceptor implements NestInterceptor {
|
|
4
|
+
private readonly ms;
|
|
5
|
+
constructor(ms: number);
|
|
6
|
+
intercept(_context: ExecutionContext, next: CallHandler): Observable<unknown>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=timeout.interceptor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timeout.interceptor.d.ts","sourceRoot":"","sources":["../../../common/interceptors/timeout.interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAEN,eAAe,EACf,gBAAgB,EAChB,WAAW,EAEX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,UAAU,EAA4B,MAAM,MAAM,CAAC;AAQ5D,qBACa,kBAAmB,YAAW,eAAe;IAC7C,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAAF,EAAE,EAAE,MAAM;IAEvC,SAAS,CAAC,QAAQ,EAAE,gBAAgB,EAAE,IAAI,EAAE,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC;CAiB7E"}
|
|
@@ -0,0 +1,37 @@
|
|
|
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.TimeoutInterceptor = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const rxjs_1 = require("rxjs");
|
|
15
|
+
const operators_1 = require("rxjs/operators");
|
|
16
|
+
let TimeoutInterceptor = class TimeoutInterceptor {
|
|
17
|
+
constructor(ms) {
|
|
18
|
+
this.ms = ms;
|
|
19
|
+
}
|
|
20
|
+
intercept(_context, next) {
|
|
21
|
+
return next.handle().pipe((0, operators_1.timeout)(this.ms), (0, operators_1.catchError)((err) => {
|
|
22
|
+
if (err instanceof rxjs_1.TimeoutError) {
|
|
23
|
+
return (0, rxjs_1.throwError)(() => new common_1.RequestTimeoutException({
|
|
24
|
+
message: 'Request timed out',
|
|
25
|
+
errorCode: 'REQUEST_TIMEOUT',
|
|
26
|
+
}));
|
|
27
|
+
}
|
|
28
|
+
return (0, rxjs_1.throwError)(() => err);
|
|
29
|
+
}));
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
exports.TimeoutInterceptor = TimeoutInterceptor;
|
|
33
|
+
exports.TimeoutInterceptor = TimeoutInterceptor = __decorate([
|
|
34
|
+
(0, common_1.Injectable)(),
|
|
35
|
+
__metadata("design:paramtypes", [Number])
|
|
36
|
+
], TimeoutInterceptor);
|
|
37
|
+
//# sourceMappingURL=timeout.interceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timeout.interceptor.js","sourceRoot":"","sources":["../../../common/interceptors/timeout.interceptor.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAMwB;AACxB,+BAA4D;AAC5D,8CAAqD;AAQ9C,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC9B,YAA6B,EAAU;QAAV,OAAE,GAAF,EAAE,CAAQ;IAAG,CAAC;IAE3C,SAAS,CAAC,QAA0B,EAAE,IAAiB;QACtD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CACxB,IAAA,mBAAO,EAAC,IAAI,CAAC,EAAE,CAAC,EAChB,IAAA,sBAAU,EAAC,CAAC,GAAY,EAAE,EAAE;YAC3B,IAAI,GAAG,YAAY,mBAAY,EAAE,CAAC;gBACjC,OAAO,IAAA,iBAAU,EAChB,GAAG,EAAE,CACJ,IAAI,gCAAuB,CAAC;oBAC3B,OAAO,EAAE,mBAAmB;oBAC5B,SAAS,EAAE,iBAAiB;iBAC5B,CAAC,CACH,CAAC;YACH,CAAC;YACD,OAAO,IAAA,iBAAU,EAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QAC9B,CAAC,CAAC,CACF,CAAC;IACH,CAAC;CACD,CAAA;AApBY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;;GACA,kBAAkB,CAoB9B"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { NestMiddleware } from '@nestjs/common';
|
|
2
2
|
import { Request, Response, NextFunction } from 'express';
|
|
3
3
|
export declare class RequestIdMiddleware implements NestMiddleware {
|
|
4
|
-
use(req: Request,
|
|
4
|
+
use(req: Request, res: Response, next: NextFunction): void;
|
|
5
5
|
}
|
|
6
6
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../common/middlewares/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../common/middlewares/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAa1D,qBACa,mBAAoB,YAAW,cAAc;IACzD,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;CAKnD"}
|
|
@@ -8,11 +8,20 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
9
|
exports.RequestIdMiddleware = void 0;
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
|
+
function getOrCreateRequestId(req) {
|
|
12
|
+
const raw = req.headers['x-request-id'];
|
|
13
|
+
const existing = Array.isArray(raw) ? raw[0] : raw;
|
|
14
|
+
if (typeof existing === 'string' && existing.trim().length > 0) {
|
|
15
|
+
return existing.trim();
|
|
16
|
+
}
|
|
17
|
+
const id = crypto.randomUUID();
|
|
18
|
+
req.headers['x-request-id'] = id;
|
|
19
|
+
return id;
|
|
20
|
+
}
|
|
11
21
|
let RequestIdMiddleware = class RequestIdMiddleware {
|
|
12
|
-
use(req,
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
}
|
|
22
|
+
use(req, res, next) {
|
|
23
|
+
const requestId = getOrCreateRequestId(req);
|
|
24
|
+
res.setHeader('x-request-id', requestId);
|
|
16
25
|
next();
|
|
17
26
|
}
|
|
18
27
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../common/middlewares/index.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4D;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../common/middlewares/index.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4D;AAG5D,SAAS,oBAAoB,CAAC,GAAY;IACzC,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;IACxC,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IACnD,IAAI,OAAO,QAAQ,KAAK,QAAQ,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAChE,OAAO,QAAQ,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IACD,MAAM,EAAE,GAAG,MAAM,CAAC,UAAU,EAAE,CAAC;IAC/B,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,EAAE,CAAC;IACjC,OAAO,EAAE,CAAC;AACX,CAAC;AAGM,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAC/B,GAAG,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB;QAClD,MAAM,SAAS,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC;QAC5C,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;QACzC,IAAI,EAAE,CAAC;IACR,CAAC;CACD,CAAA;AANY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,mBAAU,GAAE;GACA,mBAAmB,CAM/B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config-aware-validation.pipe.d.ts","sourceRoot":"","sources":["../../../common/pipes/config-aware-validation.pipe.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,
|
|
1
|
+
{"version":3,"file":"config-aware-validation.pipe.d.ts","sourceRoot":"","sources":["../../../common/pipes/config-aware-validation.pipe.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAmC,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAInG,OAAO,EAAE,eAAe,EAAE,MAAM,kDAAkD,CAAC;AAInF,qBACa,yBAA0B,SAAQ,cAAc;IAGhD,OAAO,CAAC,QAAQ,CAAC,eAAe;IAF5C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAmB;gBAEhB,eAAe,EAAE,eAAe;IAWvD,SAAS,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,gBAAgB;CAY1D"}
|
|
@@ -15,9 +15,16 @@ const core_1 = require("@nestjs/core");
|
|
|
15
15
|
const auth_method_aware_decorator_1 = require("../decorators/auth-method-aware.decorator");
|
|
16
16
|
const settings_service_1 = require("../../modules/settings/services/settings.service");
|
|
17
17
|
const settings_keys_1 = require("../../modules/settings/constants/settings.keys");
|
|
18
|
+
const validation_1 = require("../utils/validation");
|
|
18
19
|
let ConfigAwareValidationPipe = class ConfigAwareValidationPipe extends common_1.ValidationPipe {
|
|
19
20
|
constructor(settingsService) {
|
|
20
|
-
super({
|
|
21
|
+
super({
|
|
22
|
+
transform: true,
|
|
23
|
+
whitelist: true,
|
|
24
|
+
forbidNonWhitelisted: true,
|
|
25
|
+
stopAtFirstError: false,
|
|
26
|
+
exceptionFactory: (errors) => new common_1.BadRequestException((0, validation_1.buildValidationFailedPayload)(errors)),
|
|
27
|
+
});
|
|
21
28
|
this.settingsService = settingsService;
|
|
22
29
|
this.reflector = new core_1.Reflector();
|
|
23
30
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config-aware-validation.pipe.js","sourceRoot":"","sources":["../../../common/pipes/config-aware-validation.pipe.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"config-aware-validation.pipe.js","sourceRoot":"","sources":["../../../common/pipes/config-aware-validation.pipe.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAmG;AACnG,uCAAyC;AAEzC,2FAAkF;AAClF,uFAAmF;AACnF,kFAA8E;AAC9E,oDAAmE;AAG5D,IAAM,yBAAyB,GAA/B,MAAM,yBAA0B,SAAQ,uBAAc;IAG5D,YAA6B,eAAgC;QAC5D,KAAK,CAAC;YACL,SAAS,EAAE,IAAI;YACf,SAAS,EAAE,IAAI;YACf,oBAAoB,EAAE,IAAI;YAC1B,gBAAgB,EAAE,KAAK;YACvB,gBAAgB,EAAE,CAAC,MAAyB,EAAE,EAAE,CAC/C,IAAI,4BAAmB,CAAC,IAAA,yCAA4B,EAAC,MAAM,CAAC,CAAC;SAC9D,CAAC,CAAC;QARyB,oBAAe,GAAf,eAAe,CAAiB;QAF5C,cAAS,GAAG,IAAI,gBAAS,EAAE,CAAC;IAW7C,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,KAAc,EAAE,QAA0B;QACzD,MAAM,OAAO,GACZ,QAAQ,CAAC,QAAQ;YACjB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAU,mDAAqB,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAEvE,IAAI,OAAO,EAAE,CAAC;YACZ,KAAiC,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAC3E,4BAAY,CAAC,WAAW,CACxB,CAAC;QACH,CAAC;QACD,OAAO,KAAK,CAAC,SAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IACzC,CAAC;CACD,CAAA;AA1BY,8DAAyB;oCAAzB,yBAAyB;IADrC,IAAA,mBAAU,GAAE;qCAIkC,kCAAe;GAHjD,yBAAyB,CA0BrC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../common/utils/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../common/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAK7B,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,YAAY,SAAI,GAAG,MAAM,CAMlE;AAKD,wBAAgB,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAE/C;AAKD,wBAAsB,SAAS,CAAC,CAAC,EAChC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,OAAO,GAAE;IAAE,UAAU,CAAC,EAAE,MAAM,CAAC;IAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;CAAO,GAC7E,OAAO,CAAC,CAAC,CAAC,CAiBZ"}
|
|
@@ -1,8 +1,23 @@
|
|
|
1
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
2
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
17
|
exports.maskString = maskString;
|
|
4
18
|
exports.sleep = sleep;
|
|
5
19
|
exports.withRetry = withRetry;
|
|
20
|
+
__exportStar(require("./validation"), exports);
|
|
6
21
|
function maskString(value, visibleChars = 4) {
|
|
7
22
|
if (value.length <= visibleChars) {
|
|
8
23
|
return '*'.repeat(value.length);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../common/utils/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../common/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAKA,gCAMC;AAKD,sBAEC;AAKD,8BAoBC;AA3CD,+CAA6B;AAK7B,SAAgB,UAAU,CAAC,KAAa,EAAE,YAAY,GAAG,CAAC;IACzD,IAAI,KAAK,CAAC,MAAM,IAAI,YAAY,EAAE,CAAC;QAClC,OAAO,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;IACD,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,YAAY,CAAC,CAAC;IACvD,OAAO,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC;AAC5C,CAAC;AAKD,SAAgB,KAAK,CAAC,EAAU;IAC/B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAC1D,CAAC;AAKM,KAAK,UAAU,SAAS,CAC9B,EAAoB,EACpB,UAA6E,EAAE;IAE/E,MAAM,EAAE,UAAU,GAAG,CAAC,EAAE,YAAY,GAAG,IAAI,EAAE,QAAQ,GAAG,KAAK,EAAE,GAAG,OAAO,CAAC;IAC1E,IAAI,SAA4B,CAAC;IAEjC,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,UAAU,EAAE,OAAO,EAAE,EAAE,CAAC;QACxD,IAAI,CAAC;YACJ,OAAO,MAAM,EAAE,EAAE,CAAC;QACnB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,SAAS,GAAG,KAAc,CAAC;YAC3B,IAAI,OAAO,GAAG,UAAU,EAAE,CAAC;gBAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,QAAQ,CAAC,CAAC;gBACtE,MAAM,KAAK,CAAC,KAAK,CAAC,CAAC;YACpB,CAAC;QACF,CAAC;IACF,CAAC;IAED,MAAM,SAAS,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ValidationError } from 'class-validator';
|
|
2
|
+
export declare function flattenValidationErrors(errors: ValidationError[], parentPath?: string): string[];
|
|
3
|
+
export interface ValidationFailedPayload {
|
|
4
|
+
message: string;
|
|
5
|
+
validations?: string[];
|
|
6
|
+
error: string;
|
|
7
|
+
errorCode: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function buildValidationFailedPayload(errors: ValidationError[]): ValidationFailedPayload;
|
|
10
|
+
//# sourceMappingURL=validation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../../common/utils/validation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAMlD,wBAAgB,uBAAuB,CAAC,MAAM,EAAE,eAAe,EAAE,EAAE,UAAU,SAAK,GAAG,MAAM,EAAE,CAY5F;AAGD,MAAM,WAAW,uBAAuB;IACvC,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CAClB;AAMD,wBAAgB,4BAA4B,CAAC,MAAM,EAAE,eAAe,EAAE,GAAG,uBAAuB,CAS/F"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.flattenValidationErrors = flattenValidationErrors;
|
|
4
|
+
exports.buildValidationFailedPayload = buildValidationFailedPayload;
|
|
5
|
+
function flattenValidationErrors(errors, parentPath = '') {
|
|
6
|
+
const messages = [];
|
|
7
|
+
for (const err of errors) {
|
|
8
|
+
const path = parentPath ? `${parentPath}.${err.property}` : err.property;
|
|
9
|
+
if (err.constraints) {
|
|
10
|
+
messages.push(...Object.values(err.constraints).map((c) => `${path}: ${c}`));
|
|
11
|
+
}
|
|
12
|
+
if (err.children?.length) {
|
|
13
|
+
messages.push(...flattenValidationErrors(err.children, path));
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return messages;
|
|
17
|
+
}
|
|
18
|
+
function buildValidationFailedPayload(errors) {
|
|
19
|
+
const all = flattenValidationErrors(errors);
|
|
20
|
+
const primary = all[0] ?? 'Validation failed';
|
|
21
|
+
return {
|
|
22
|
+
message: primary,
|
|
23
|
+
...(all.length > 1 && { validations: all.slice(1) }),
|
|
24
|
+
error: 'Bad Request',
|
|
25
|
+
errorCode: 'VALIDATION_FAILED',
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../../common/utils/validation.ts"],"names":[],"mappings":";;AAMA,0DAYC;AAcD,oEASC;AAnCD,SAAgB,uBAAuB,CAAC,MAAyB,EAAE,UAAU,GAAG,EAAE;IACjF,MAAM,QAAQ,GAAa,EAAE,CAAC;IAC9B,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;QAC1B,MAAM,IAAI,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,IAAI,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC;QACzE,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;YACrB,QAAQ,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9E,CAAC;QACD,IAAI,GAAG,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC;YAC1B,QAAQ,CAAC,IAAI,CAAC,GAAG,uBAAuB,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;QAC/D,CAAC;IACF,CAAC;IACD,OAAO,QAAQ,CAAC;AACjB,CAAC;AAcD,SAAgB,4BAA4B,CAAC,MAAyB;IACrE,MAAM,GAAG,GAAG,uBAAuB,CAAC,MAAM,CAAC,CAAC;IAC5C,MAAM,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,mBAAmB,CAAC;IAC9C,OAAO;QACN,OAAO,EAAE,OAAO;QAChB,GAAG,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,WAAW,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QACpD,KAAK,EAAE,aAAa;QACpB,SAAS,EAAE,mBAAmB;KAC9B,CAAC;AACH,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export declare function parseHttpRequestTimeoutMs(): number;
|
|
1
2
|
export declare const appConfig: (() => {
|
|
2
3
|
nodeEnv: string;
|
|
3
4
|
port: number;
|
|
@@ -6,6 +7,7 @@ export declare const appConfig: (() => {
|
|
|
6
7
|
url: string | undefined;
|
|
7
8
|
debug: boolean;
|
|
8
9
|
swaggerEnabled: string | undefined;
|
|
10
|
+
requestTimeoutMs: number;
|
|
9
11
|
jwt: {
|
|
10
12
|
secret: string;
|
|
11
13
|
expiresIn: string;
|
|
@@ -26,6 +28,8 @@ export declare const appConfig: (() => {
|
|
|
26
28
|
port: number;
|
|
27
29
|
password: string | undefined;
|
|
28
30
|
tls: boolean;
|
|
31
|
+
tlsRejectUnauthorized: boolean;
|
|
32
|
+
tlsCaPath: string | undefined;
|
|
29
33
|
};
|
|
30
34
|
logging: {
|
|
31
35
|
level: string;
|
|
@@ -38,6 +42,7 @@ export declare const appConfig: (() => {
|
|
|
38
42
|
url: string | undefined;
|
|
39
43
|
debug: boolean;
|
|
40
44
|
swaggerEnabled: string | undefined;
|
|
45
|
+
requestTimeoutMs: number;
|
|
41
46
|
jwt: {
|
|
42
47
|
secret: string;
|
|
43
48
|
expiresIn: string;
|
|
@@ -58,6 +63,8 @@ export declare const appConfig: (() => {
|
|
|
58
63
|
port: number;
|
|
59
64
|
password: string | undefined;
|
|
60
65
|
tls: boolean;
|
|
66
|
+
tlsRejectUnauthorized: boolean;
|
|
67
|
+
tlsCaPath: string | undefined;
|
|
61
68
|
};
|
|
62
69
|
logging: {
|
|
63
70
|
level: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.config.d.ts","sourceRoot":"","sources":["../../config/app.config.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"app.config.d.ts","sourceRoot":"","sources":["../../config/app.config.ts"],"names":[],"mappings":"AAOA,wBAAgB,yBAAyB,IAAI,MAAM,CAMlD;AAED,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiDpB,CAAC"}
|
|
@@ -1,7 +1,20 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.appConfig = void 0;
|
|
4
|
+
exports.parseHttpRequestTimeoutMs = parseHttpRequestTimeoutMs;
|
|
4
5
|
const config_1 = require("@nestjs/config");
|
|
6
|
+
const HTTP_REQUEST_TIMEOUT_MS_MIN = 1_000;
|
|
7
|
+
const HTTP_REQUEST_TIMEOUT_MS_MAX = 120_000;
|
|
8
|
+
const HTTP_REQUEST_TIMEOUT_MS_DEFAULT = 30_000;
|
|
9
|
+
function parseHttpRequestTimeoutMs() {
|
|
10
|
+
const raw = process.env.HTTP_REQUEST_TIMEOUT_MS;
|
|
11
|
+
if (raw === undefined || raw === '')
|
|
12
|
+
return HTTP_REQUEST_TIMEOUT_MS_DEFAULT;
|
|
13
|
+
const n = parseInt(raw, 10);
|
|
14
|
+
if (Number.isNaN(n))
|
|
15
|
+
return HTTP_REQUEST_TIMEOUT_MS_DEFAULT;
|
|
16
|
+
return Math.min(HTTP_REQUEST_TIMEOUT_MS_MAX, Math.max(HTTP_REQUEST_TIMEOUT_MS_MIN, n));
|
|
17
|
+
}
|
|
5
18
|
exports.appConfig = (0, config_1.registerAs)('app', () => {
|
|
6
19
|
const redisEnabled = process.env.REDIS_ENABLED === 'true';
|
|
7
20
|
return {
|
|
@@ -12,8 +25,9 @@ exports.appConfig = (0, config_1.registerAs)('app', () => {
|
|
|
12
25
|
url: process.env.APP_URL,
|
|
13
26
|
debug: process.env.APP_DEBUG === 'true',
|
|
14
27
|
swaggerEnabled: process.env.SWAGGER_ENABLED,
|
|
28
|
+
requestTimeoutMs: parseHttpRequestTimeoutMs(),
|
|
15
29
|
jwt: {
|
|
16
|
-
secret: process.env.JWT_SECRET
|
|
30
|
+
secret: process.env.JWT_SECRET ?? '',
|
|
17
31
|
expiresIn: process.env.JWT_EXPIRATION || '1d',
|
|
18
32
|
},
|
|
19
33
|
keycloak: {
|
|
@@ -34,6 +48,8 @@ exports.appConfig = (0, config_1.registerAs)('app', () => {
|
|
|
34
48
|
port: parseInt(process.env.REDIS_PORT || '6379', 10),
|
|
35
49
|
password: process.env.REDIS_PASSWORD || undefined,
|
|
36
50
|
tls: process.env.REDIS_TLS === 'true',
|
|
51
|
+
tlsRejectUnauthorized: process.env.REDIS_TLS_REJECT_UNAUTHORIZED !== 'false',
|
|
52
|
+
tlsCaPath: process.env.REDIS_TLS_CA,
|
|
37
53
|
},
|
|
38
54
|
logging: {
|
|
39
55
|
level: process.env.LOG_LEVEL || 'log',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.config.js","sourceRoot":"","sources":["../../config/app.config.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"app.config.js","sourceRoot":"","sources":["../../config/app.config.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,13 +4,13 @@ export declare const databaseConfig: (() => {
|
|
|
4
4
|
username: string;
|
|
5
5
|
password: string;
|
|
6
6
|
name: string;
|
|
7
|
-
ssl:
|
|
7
|
+
ssl: import("./tls.util").PostgresSslOptions;
|
|
8
8
|
}) & import("@nestjs/config").ConfigFactoryKeyHost<{
|
|
9
9
|
host: string;
|
|
10
10
|
port: number;
|
|
11
11
|
username: string;
|
|
12
12
|
password: string;
|
|
13
13
|
name: string;
|
|
14
|
-
ssl:
|
|
14
|
+
ssl: import("./tls.util").PostgresSslOptions;
|
|
15
15
|
}>;
|
|
16
16
|
//# sourceMappingURL=database.config.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"database.config.d.ts","sourceRoot":"","sources":["../../config/database.config.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"database.config.d.ts","sourceRoot":"","sources":["../../config/database.config.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,cAAc;;;;;;;;;;;;;;EAOxB,CAAC"}
|