From d10f3089dbeaf968827a603c671993f153bf13ad Mon Sep 17 00:00:00 2001 From: Amir Hoseinian Date: Thu, 22 Feb 2024 14:59:44 +0100 Subject: [PATCH 1/3] Fix route param parsing when the param begins with just one letter For example if the param was i_key the current regex would not find it as a variable. it was only working for the params with more than one letter before either `.` `-` or `_`. the fix should allow to find params with only one letter at begninng. --- src/schema-routes/schema-routes.js | 2 +- tests/spec/extractRequestParams/expected.ts | 25 +++++++++ tests/spec/extractRequestParams/schema.json | 56 +++++++++++++++++++++ tests/spec/extractRequestParams/schema.ts | 25 +++++++++ 4 files changed, 107 insertions(+), 1 deletion(-) diff --git a/src/schema-routes/schema-routes.js b/src/schema-routes/schema-routes.js index 81a73a8f..cff9a13b 100644 --- a/src/schema-routes/schema-routes.js +++ b/src/schema-routes/schema-routes.js @@ -110,7 +110,7 @@ class SchemaRoutes { originalRouteName; const pathParamMatches = (routeName || "").match( - /({(([A-z]){1}([a-zA-Z0-9]-?_?\.?)+)([0-9]+)?})|(:(([A-z]){1}([a-zA-Z0-9]-?_?\.?)+)([0-9]+)?:?)/g, + /({(([A-z]){1}([a-zA-Z0-9-_.]-?_?\.?)+)([0-9]+)?})|(:(([A-z]){1}([a-zA-Z0-9-_.]-?_?\.?)+)([0-9]+)?:?)/g, ); // used in case when path parameters is not declared in requestInfo.parameters ("in": "path") diff --git a/tests/spec/extractRequestParams/expected.ts b/tests/spec/extractRequestParams/expected.ts index 08b222e0..6f172cc3 100644 --- a/tests/spec/extractRequestParams/expected.ts +++ b/tests/spec/extractRequestParams/expected.ts @@ -472,6 +472,31 @@ export class Api extends HttpClient + this.request< + { + /** @format date-time */ + since?: string; + status?: string; + /** base64safe encoded public signing key */ + sub?: string; + }, + Error + >({ + path: `/i_key/${iPk}`, + method: "GET", + format: "json", + ...params, + }), + }; login = { /** * @description push sign-in request See: https://github.com/skion/authentiq/wiki/JWT-Examples diff --git a/tests/spec/extractRequestParams/schema.json b/tests/spec/extractRequestParams/schema.json index c9fc4a0a..a3982337 100644 --- a/tests/spec/extractRequestParams/schema.json +++ b/tests/spec/extractRequestParams/schema.json @@ -56,6 +56,13 @@ "required": true, "type": "string" }, + "i_PK": { + "description": "Public Signing Key - Authentiq ID (43 chars)", + "in": "path", + "name": "i_PK", + "required": true, + "type": "string" + }, "BarBaz": { "description": "bar baz", "in": "path", @@ -424,6 +431,55 @@ "tags": ["key", "put"] } }, + "/i_key/{i_PK}": { + "get": { + "description": "Get public details of an Authentiq ID.\n", + "parameters": [ + { + "$ref": "#/parameters/i_PK" + } + ], + "produces": ["application/json"], + "responses": { + "200": { + "description": "Successfully retrieved", + "schema": { + "properties": { + "since": { + "format": "date-time", + "type": "string" + }, + "status": { + "type": "string" + }, + "sub": { + "description": "base64safe encoded public signing key", + "type": "string" + } + }, + "title": "JWT", + "type": "object" + } + }, + "404": { + "description": "Unknown key `unknown-key`", + "schema": { + "$ref": "#/definitions/Error" + } + }, + "410": { + "description": "Key is revoked (gone). `revoked-key`", + "schema": { + "$ref": "#/definitions/Error" + } + }, + "default": { + "$ref": "#/responses/ErrorResponse" + } + }, + "tags": ["key", "get"] + } + }, "/login": { "post": { "consumes": ["application/jwt"], diff --git a/tests/spec/extractRequestParams/schema.ts b/tests/spec/extractRequestParams/schema.ts index 08b222e0..6f172cc3 100644 --- a/tests/spec/extractRequestParams/schema.ts +++ b/tests/spec/extractRequestParams/schema.ts @@ -472,6 +472,31 @@ export class Api extends HttpClient + this.request< + { + /** @format date-time */ + since?: string; + status?: string; + /** base64safe encoded public signing key */ + sub?: string; + }, + Error + >({ + path: `/i_key/${iPk}`, + method: "GET", + format: "json", + ...params, + }), + }; login = { /** * @description push sign-in request See: https://github.com/skion/authentiq/wiki/JWT-Examples From 55aee4551722135c31950ca789ed071082ec4bd9 Mon Sep 17 00:00:00 2001 From: Amir Hoseinian Date: Sun, 28 Apr 2024 16:39:36 +0200 Subject: [PATCH 2/3] Update the regex to be more concise and inclue 1 letter params https://github.com/acacode/swagger-typescript-api/pull/686#issuecomment-2067162950 --- src/schema-routes/schema-routes.js | 2 +- tests/spec/extractRequestParams/expected.ts | 21 ++++++++++++ tests/spec/extractRequestParams/schema.json | 37 +++++++++++++++++++++ tests/spec/extractRequestParams/schema.ts | 21 ++++++++++++ 4 files changed, 80 insertions(+), 1 deletion(-) diff --git a/src/schema-routes/schema-routes.js b/src/schema-routes/schema-routes.js index cff9a13b..513f9ecb 100644 --- a/src/schema-routes/schema-routes.js +++ b/src/schema-routes/schema-routes.js @@ -110,7 +110,7 @@ class SchemaRoutes { originalRouteName; const pathParamMatches = (routeName || "").match( - /({(([A-z]){1}([a-zA-Z0-9-_.]-?_?\.?)+)([0-9]+)?})|(:(([A-z]){1}([a-zA-Z0-9-_.]-?_?\.?)+)([0-9]+)?:?)/g, + /({[a-zA-Z]([a-zA-Z0-9-_.])*})|(:[a-zA-Z]([-_.]?[a-zA-Z0-9-_.])*:?)/g, ); // used in case when path parameters is not declared in requestInfo.parameters ("in": "path") diff --git a/tests/spec/extractRequestParams/expected.ts b/tests/spec/extractRequestParams/expected.ts index 6f172cc3..3c5b71c6 100644 --- a/tests/spec/extractRequestParams/expected.ts +++ b/tests/spec/extractRequestParams/expected.ts @@ -496,6 +496,27 @@ export class Api extends HttpClient + this.request< + { + /** base64safe encoded public signing key */ + sub?: string; + }, + Error + >({ + path: `/i_key/underlines/${iUk}`, + method: "GET", + format: "json", + ...params, + }), }; login = { /** diff --git a/tests/spec/extractRequestParams/schema.json b/tests/spec/extractRequestParams/schema.json index a3982337..8d4d5098 100644 --- a/tests/spec/extractRequestParams/schema.json +++ b/tests/spec/extractRequestParams/schema.json @@ -56,6 +56,13 @@ "required": true, "type": "string" }, + "i__UK": { + "description": "Variable with double __ in it.", + "in": "path", + "name": "i__UK", + "required": true, + "type": "string" + }, "i_PK": { "description": "Public Signing Key - Authentiq ID (43 chars)", "in": "path", @@ -480,6 +487,36 @@ "tags": ["key", "get"] } }, + "/i_key/underlines/{i__UK}": { + "get": { + "description": "Get public details of an Authentiq ID.\n", + "parameters": [ + { + "$ref": "#/parameters/i__UK" + } + ], + "produces": ["application/json"], + "responses": { + "200": { + "description": "Successfully retrieved", + "schema": { + "properties": { + "sub": { + "description": "base64safe encoded public signing key", + "type": "string" + } + }, + "title": "JWT", + "type": "object" + } + }, + "default": { + "$ref": "#/responses/ErrorResponse" + } + }, + "tags": ["key", "get"] + } + }, "/login": { "post": { "consumes": ["application/jwt"], diff --git a/tests/spec/extractRequestParams/schema.ts b/tests/spec/extractRequestParams/schema.ts index 6f172cc3..3c5b71c6 100644 --- a/tests/spec/extractRequestParams/schema.ts +++ b/tests/spec/extractRequestParams/schema.ts @@ -496,6 +496,27 @@ export class Api extends HttpClient + this.request< + { + /** base64safe encoded public signing key */ + sub?: string; + }, + Error + >({ + path: `/i_key/underlines/${iUk}`, + method: "GET", + format: "json", + ...params, + }), }; login = { /** From 7a8f23491d4ced39f9aaec5bf2335ef2d5941224 Mon Sep 17 00:00:00 2001 From: Amir Hoseinian Date: Fri, 10 May 2024 17:01:28 +0200 Subject: [PATCH 3/3] refactor: improve regex for route param parsing accourding to this suggestion https://github.com/acacode/swagger-typescript-api/pull/686#issuecomment-2084927918 --- src/schema-routes/schema-routes.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/schema-routes/schema-routes.js b/src/schema-routes/schema-routes.js index 513f9ecb..5670ddcc 100644 --- a/src/schema-routes/schema-routes.js +++ b/src/schema-routes/schema-routes.js @@ -110,7 +110,7 @@ class SchemaRoutes { originalRouteName; const pathParamMatches = (routeName || "").match( - /({[a-zA-Z]([a-zA-Z0-9-_.])*})|(:[a-zA-Z]([-_.]?[a-zA-Z0-9-_.])*:?)/g, + /({[a-zA-Z]([-_.]*[a-zA-Z0-9])*})|(:[a-zA-Z]([-_.]*[a-zA-Z0-9])*:?)/g, ); // used in case when path parameters is not declared in requestInfo.parameters ("in": "path")