From db199c87c573e240157e52fb0efbbf0252796269 Mon Sep 17 00:00:00 2001 From: Jeongho Nam Date: Thu, 5 Oct 2023 18:54:23 +0900 Subject: [PATCH] Fix #631 - when non-class value being exported As current `@nestia/sdk`'s `ReflectAnalyzer` class had not checked whether exported member is class type or not, if user exports any atomic value in a controller class file, it became an error due to characteristics of `WeakSet`. Therefore, fixed this bug just by adding a `typeof value === 'function` statement. Thanks to @Val0429 for such special case reporting. ```typescript @Controller("something") export class SomeController {} export const SOME_ATOMIC_VALUE = 0; ``` https://github.com/samchon/nestia/blob/e995adcf0b78448ca53efe569bd37e9e25ead4a3/packages/sdk/src/analyses/ReflectAnalyzer.ts#L15-L39 --- benchmark/package.json | 2 +- packages/core/package.json | 10 +++++----- packages/e2e/package.json | 2 +- packages/fetcher/package.json | 2 +- packages/migrate/package.json | 2 +- packages/sdk/package.json | 10 +++++----- packages/sdk/src/NestiaSdkApplication.ts | 5 ++++- packages/sdk/src/analyses/ReflectAnalyzer.ts | 9 +++++---- .../swagger.json | 8 ++++---- test/features/date/swagger.json | 17 ++++++++++++++--- .../distribute-assert/packages/api/package.json | 2 +- .../distribute-json/packages/api/package.json | 2 +- .../distribute/packages/api/package.json | 2 +- test/package.json | 10 +++++----- 14 files changed, 49 insertions(+), 34 deletions(-) diff --git a/benchmark/package.json b/benchmark/package.json index e43fa1575..63fe0a794 100644 --- a/benchmark/package.json +++ b/benchmark/package.json @@ -25,7 +25,7 @@ "homepage": "https://nestia.io", "dependencies": { "@nestia/core": "^2.0.5-dev.20230921", - "typia": "^5.1.5" + "typia": "^5.1.6" }, "devDependencies": { "@trivago/prettier-plugin-sort-imports": "^4.1.1", diff --git a/packages/core/package.json b/packages/core/package.json index 741f57242..135da781b 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -1,6 +1,6 @@ { "name": "@nestia/core", - "version": "2.1.7", + "version": "2.1.8", "description": "Super-fast validation decorators of NestJS", "main": "lib/index.js", "typings": "lib/index.d.ts", @@ -34,7 +34,7 @@ }, "homepage": "https://nestia.io", "dependencies": { - "@nestia/fetcher": "^2.1.7", + "@nestia/fetcher": "^2.1.8", "@nestjs/common": ">= 7.0.1", "@nestjs/core": ">= 7.0.1", "@nestjs/platform-express": ">= 7.0.1", @@ -44,10 +44,10 @@ "raw-body": ">= 2.0.0", "reflect-metadata": ">= 0.1.12", "rxjs": ">= 6.0.0", - "typia": "^5.1.5" + "typia": "^5.1.6" }, "peerDependencies": { - "@nestia/fetcher": ">=2.1.7", + "@nestia/fetcher": ">=2.1.8", "@nestjs/common": ">=7.0.1", "@nestjs/core": ">=7.0.1", "@nestjs/platform-express": ">=7.0.1", @@ -56,7 +56,7 @@ "reflect-metadata": ">=0.1.12", "rxjs": ">=6.0.0", "typescript": ">=4.8.0", - "typia": ">=5.1.5 <6.0.0" + "typia": ">=5.1.6 <6.0.0" }, "devDependencies": { "@trivago/prettier-plugin-sort-imports": "^4.0.0", diff --git a/packages/e2e/package.json b/packages/e2e/package.json index d68d0cc8c..73a70cb14 100644 --- a/packages/e2e/package.json +++ b/packages/e2e/package.json @@ -40,7 +40,7 @@ "ts-node": "^10.9.1", "ts-patch": "^3.0.2", "typescript": "^5.2.2", - "typia": "^5.1.5" + "typia": "^5.1.6" }, "dependencies": { "chalk": "^4.1.2", diff --git a/packages/fetcher/package.json b/packages/fetcher/package.json index 60465d2c9..0785fbec2 100644 --- a/packages/fetcher/package.json +++ b/packages/fetcher/package.json @@ -1,6 +1,6 @@ { "name": "@nestia/fetcher", - "version": "2.1.7", + "version": "2.1.8", "description": "Fetcher library of Nestia SDK", "main": "lib/index.js", "typings": "lib/index.d.ts", diff --git a/packages/migrate/package.json b/packages/migrate/package.json index 86562d1e6..420b72811 100644 --- a/packages/migrate/package.json +++ b/packages/migrate/package.json @@ -45,7 +45,7 @@ "typescript-transform-paths": "^3.4.6" }, "dependencies": { - "typia": "^5.1.5" + "typia": "^5.1.6" }, "files": [ "lib", diff --git a/packages/sdk/package.json b/packages/sdk/package.json index 0e84b6527..f76d8a7b7 100644 --- a/packages/sdk/package.json +++ b/packages/sdk/package.json @@ -1,6 +1,6 @@ { "name": "@nestia/sdk", - "version": "2.1.7", + "version": "2.1.8", "description": "Nestia SDK and Swagger generator", "main": "lib/index.js", "typings": "lib/index.d.ts", @@ -35,7 +35,7 @@ }, "homepage": "https://nestia.io", "dependencies": { - "@nestia/fetcher": "^2.1.7", + "@nestia/fetcher": "^2.1.8", "cli": "^1.0.1", "glob": "^7.2.0", "path-to-regexp": "^6.2.1", @@ -44,16 +44,16 @@ "tsconfck": "^2.0.1", "tsconfig-paths": "^4.1.1", "tstl": "^2.5.13", - "typia": "^5.1.5" + "typia": "^5.1.6" }, "peerDependencies": { - "@nestia/fetcher": ">=2.1.7", + "@nestia/fetcher": ">=2.1.8", "@nestjs/common": ">=7.0.1", "@nestjs/core": ">=7.0.1", "reflect-metadata": ">=0.1.12", "ts-node": ">=10.6.0", "typescript": ">=4.8.0", - "typia": ">=5.1.5 <6.0.0" + "typia": ">=5.1.6 <6.0.0" }, "devDependencies": { "@nestjs/common": ">= 7.0.1", diff --git a/packages/sdk/src/NestiaSdkApplication.ts b/packages/sdk/src/NestiaSdkApplication.ts index adb05cf9f..eefff125b 100644 --- a/packages/sdk/src/NestiaSdkApplication.ts +++ b/packages/sdk/src/NestiaSdkApplication.ts @@ -224,7 +224,10 @@ export class NestiaSdkApplication { "\n" + "List of implicit return typed routes:\n" + implicit - .map((it) => ` - ${it.symbol.class}.${it.symbol.function} at "${it.location}"`) + .map( + (it) => + ` - ${it.symbol.class}.${it.symbol.function} at "${it.location}"`, + ) .join("\n"), ); diff --git a/packages/sdk/src/analyses/ReflectAnalyzer.ts b/packages/sdk/src/analyses/ReflectAnalyzer.ts index 0dedb358e..59f783ff6 100644 --- a/packages/sdk/src/analyses/ReflectAnalyzer.ts +++ b/packages/sdk/src/analyses/ReflectAnalyzer.ts @@ -34,13 +34,14 @@ export namespace ReflectAnalyzer { })(); const ret: IController[] = []; - for (const tuple of Object.entries(module)) { - if (unique.has(tuple[1])) continue; - else unique.add(tuple[1]); + for (const [key, value] of Object.entries(module)) { + if (typeof value !== "function" || unique.has(value)) continue; + else unique.add(value); const controller: IController | null = _Analyze_controller( file, - ...tuple, + key, + value, ); if (controller !== null) ret.push(controller); } diff --git a/test/features/clone-and-exact-optional-property/swagger.json b/test/features/clone-and-exact-optional-property/swagger.json index 41cb98fdc..3356dfabf 100644 --- a/test/features/clone-and-exact-optional-property/swagger.json +++ b/test/features/clone-and-exact-optional-property/swagger.json @@ -272,7 +272,7 @@ }, "undefinable_attr": { "x-typia-required": false, - "x-typia-optional": false, + "x-typia-optional": true, "type": "string" }, "c": { @@ -342,7 +342,7 @@ }, "undefinable_attr": { "x-typia-required": false, - "x-typia-optional": false, + "x-typia-optional": true, "type": "string" }, "a": { @@ -417,7 +417,7 @@ }, "undefinable_attr": { "x-typia-required": false, - "x-typia-optional": false, + "x-typia-optional": true, "type": "string" } }, @@ -482,7 +482,7 @@ }, "undefinable_attr": { "x-typia-required": false, - "x-typia-optional": false, + "x-typia-optional": true, "type": "string" }, "b": { diff --git a/test/features/date/swagger.json b/test/features/date/swagger.json index a5fc886b4..93818c365 100644 --- a/test/features/date/swagger.json +++ b/test/features/date/swagger.json @@ -83,7 +83,7 @@ "string": { "x-typia-jsDocTags": [ { - "name": "formt", + "name": "format", "text": [ { "text": "date-time", @@ -94,7 +94,18 @@ ], "x-typia-required": true, "x-typia-optional": false, - "type": "string" + "type": "string", + "format": "date-time", + "x-typia-typeTags": [ + { + "name": "Format<\"date-time\">", + "target": "string", + "kind": "format", + "value": "date-time", + "validate": "!isNaN(new Date($input).getTime())", + "exclusive": true + } + ] }, "date": { "x-typia-required": true, @@ -105,7 +116,7 @@ "date_with_tag": { "x-typia-jsDocTags": [ { - "name": "formt", + "name": "format", "text": [ { "text": "date-time", diff --git a/test/features/distribute-assert/packages/api/package.json b/test/features/distribute-assert/packages/api/package.json index 284aae800..2b056ffa3 100644 --- a/test/features/distribute-assert/packages/api/package.json +++ b/test/features/distribute-assert/packages/api/package.json @@ -34,6 +34,6 @@ }, "dependencies": { "@nestia/fetcher": "file:../../../../../packages/fetcher/nestia-fetcher-0.0.0-dev.20991231.tgz", - "typia": "^5.1.5" + "typia": "^5.1.6" } } \ No newline at end of file diff --git a/test/features/distribute-json/packages/api/package.json b/test/features/distribute-json/packages/api/package.json index 284aae800..2b056ffa3 100644 --- a/test/features/distribute-json/packages/api/package.json +++ b/test/features/distribute-json/packages/api/package.json @@ -34,6 +34,6 @@ }, "dependencies": { "@nestia/fetcher": "file:../../../../../packages/fetcher/nestia-fetcher-0.0.0-dev.20991231.tgz", - "typia": "^5.1.5" + "typia": "^5.1.6" } } \ No newline at end of file diff --git a/test/features/distribute/packages/api/package.json b/test/features/distribute/packages/api/package.json index 284aae800..2b056ffa3 100644 --- a/test/features/distribute/packages/api/package.json +++ b/test/features/distribute/packages/api/package.json @@ -34,6 +34,6 @@ }, "dependencies": { "@nestia/fetcher": "file:../../../../../packages/fetcher/nestia-fetcher-0.0.0-dev.20991231.tgz", - "typia": "^5.1.5" + "typia": "^5.1.6" } } \ No newline at end of file diff --git a/test/package.json b/test/package.json index ee27491c2..7f19a7dff 100644 --- a/test/package.json +++ b/test/package.json @@ -1,7 +1,7 @@ { "private": true, "name": "@nestia/test", - "version": "2.1.7", + "version": "2.1.8", "description": "Test program of Nestia", "main": "index.js", "scripts": { @@ -34,12 +34,12 @@ "ts-patch": "v3.0.2", "typescript": "^5.1.6", "typescript-transform-paths": "^3.4.4", - "typia": "^5.1.5", + "typia": "^5.1.6", "uuid": "^9.0.0", "nestia": "^4.5.0", - "@nestia/core": "^2.1.7", + "@nestia/core": "^2.1.8", "@nestia/e2e": "^0.3.6", - "@nestia/fetcher": "^2.1.7", - "@nestia/sdk": "^2.1.7" + "@nestia/fetcher": "^2.1.8", + "@nestia/sdk": "^2.1.8" } } \ No newline at end of file