mock-config-server 3.0.1 → 3.1.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/LICENSE +21 -21
- package/README.md +614 -502
- package/dist/bin/bin.js +8 -3
- package/dist/bin/build.js +51 -45
- package/dist/bin/cli.js +37 -44
- package/dist/bin/helpers/index.js +36 -17
- package/dist/bin/helpers/resolveConfigFile.js +20 -17
- package/dist/bin/helpers/resolveConfigFilePath.js +12 -35
- package/dist/bin/helpers/resolveExportsFromSourceCode.js +11 -8
- package/dist/bin/resolveConfigFilePath/resolveConfigFilePath.js +12 -35
- package/dist/bin/run.js +17 -12
- package/dist/bin/validateMockServerConfig/helpers/index.js +25 -16
- package/dist/bin/validateMockServerConfig/helpers/isCheckModeValid/index.js +14 -15
- package/dist/bin/validateMockServerConfig/helpers/isCheckModeValid/isCheckModeValid.js +8 -6
- package/dist/bin/validateMockServerConfig/helpers/isDescriptorValueValid/index.js +14 -15
- package/dist/bin/validateMockServerConfig/helpers/isDescriptorValueValid/isDescriptorValueValid.js +15 -18
- package/dist/bin/validateMockServerConfig/validateBaseUrl/validateBaseUrl.js +12 -9
- package/dist/bin/validateMockServerConfig/validateCors/validateCors.js +75 -73
- package/dist/bin/validateMockServerConfig/validateDatabaseConfig/validateDatabaseConfig.d.ts +1 -0
- package/dist/bin/validateMockServerConfig/validateDatabaseConfig/validateDatabaseConfig.js +45 -0
- package/dist/bin/validateMockServerConfig/validateGraphqlConfig/validateGraphqlConfig.js +47 -43
- package/dist/bin/validateMockServerConfig/validateGraphqlConfig/validateRoutes/validateRoutes.js +90 -83
- package/dist/bin/validateMockServerConfig/validateInterceptors/validateInterceptors.js +22 -16
- package/dist/bin/validateMockServerConfig/validateMockServerConfig.js +29 -27
- package/dist/bin/validateMockServerConfig/validatePort/validatePort.js +9 -6
- package/dist/bin/validateMockServerConfig/validateRestConfig/validateRestConfig.js +52 -47
- package/dist/bin/validateMockServerConfig/validateRestConfig/validateRoutes/validateRoutes.js +94 -87
- package/dist/bin/validateMockServerConfig/validateStaticPath/validateStaticPath.js +43 -34
- package/dist/src/core/database/createDatabaseRoutes/createDatabaseRoutes.d.ts +3 -0
- package/dist/src/core/database/createDatabaseRoutes/createDatabaseRoutes.js +33 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/array/createNewId/createNewId.d.ts +4 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/array/createNewId/createNewId.js +16 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/array/findIndexById/findIndexById.d.ts +4 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/array/findIndexById/findIndexById.js +8 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/array/index.d.ts +3 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/array/index.js +38 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/array/isIndex/isIndex.d.ts +1 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/array/isIndex/isIndex.js +8 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/createNestedDatabaseRoutes/createNestedDatabaseRoutes.d.ts +4 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/createNestedDatabaseRoutes/createNestedDatabaseRoutes.js +88 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/createRewrittenDatabaseRoutes/createRewrittenDatabaseRoutes.d.ts +2 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/createRewrittenDatabaseRoutes/createRewrittenDatabaseRoutes.js +12 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/createShallowDatabaseRoutes/createShallowDatabaseRoutes.d.ts +4 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/createShallowDatabaseRoutes/createShallowDatabaseRoutes.js +38 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/index.d.ts +5 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/index.js +60 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/splitDatabaseByNesting/splitDatabaseByNesting.d.ts +5 -0
- package/dist/src/core/database/createDatabaseRoutes/helpers/splitDatabaseByNesting/splitDatabaseByNesting.js +30 -0
- package/dist/src/core/database/createDatabaseRoutes/storages/File/FileStorage.d.ts +11 -0
- package/dist/src/core/database/createDatabaseRoutes/storages/File/FileStorage.js +64 -0
- package/dist/src/core/database/createDatabaseRoutes/storages/File/FileWriter.d.ts +11 -0
- package/dist/src/core/database/createDatabaseRoutes/storages/File/FileWriter.js +58 -0
- package/dist/src/core/database/createDatabaseRoutes/storages/Memory/MemoryStorage.d.ts +10 -0
- package/dist/src/core/database/createDatabaseRoutes/storages/Memory/MemoryStorage.js +54 -0
- package/dist/src/core/database/createDatabaseRoutes/storages/index.d.ts +2 -0
- package/dist/src/core/database/createDatabaseRoutes/storages/index.js +27 -0
- package/dist/src/core/database/index.d.ts +1 -0
- package/dist/src/core/database/index.js +16 -0
- package/dist/src/core/graphql/createGraphQLRoutes/createGraphQLRoutes.js +96 -83
- package/dist/src/core/graphql/createGraphQLRoutes/helpers/index.js +14 -15
- package/dist/src/core/graphql/createGraphQLRoutes/helpers/prepareGraphQLRequestConfigs/prepareGraphQLRequestConfigs.js +36 -30
- package/dist/src/core/graphql/index.js +14 -15
- package/dist/src/core/middlewares/cookieParseMiddleware/cookieParseMiddleware.js +15 -13
- package/dist/src/core/middlewares/cookieParseMiddleware/helpers/index.js +14 -15
- package/dist/src/core/middlewares/cookieParseMiddleware/helpers/parseCookie/parseCookie.js +16 -14
- package/dist/src/core/middlewares/corsMiddleware/corsMiddleware.js +48 -41
- package/dist/src/core/middlewares/corsMiddleware/helpers/getAllowedOrigins/getAllowedOrigins.js +13 -10
- package/dist/src/core/middlewares/corsMiddleware/helpers/index.js +14 -15
- package/dist/src/core/middlewares/destroyerMiddleware/destroyerMiddleware.js +21 -18
- package/dist/src/core/middlewares/errorMiddleware/errorMiddleware.js +18 -15
- package/dist/src/core/middlewares/index.js +92 -23
- package/dist/src/core/middlewares/noCorsMiddleware/noCorsMiddleware.js +21 -21
- package/dist/src/core/middlewares/notFoundMiddleware/helpers/getGraphqlUrlSuggestions/getGraphqlUrlSuggestions.js +24 -16
- package/dist/src/core/middlewares/notFoundMiddleware/helpers/getLevenshteinDistance/getLevenshteinDistance.js +78 -74
- package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/getRestUrlSuggestions.js +36 -31
- package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/getActualRestUrlMeaningfulString/getActualRestUrlMeaningfulString.js +6 -5
- package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/getPatternRestUrlMeaningfulString/getPatternRestUrlMeaningfulString.js +6 -3
- package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/index.js +25 -16
- package/dist/src/core/middlewares/notFoundMiddleware/helpers/index.js +36 -17
- package/dist/src/core/middlewares/notFoundMiddleware/notFoundMiddleware.js +63 -48
- package/dist/src/core/middlewares/requestInterceptorMiddleware/requestInterceptorMiddleware.js +13 -7
- package/dist/src/core/middlewares/staticMiddleware/staticMiddleware.js +26 -25
- package/dist/src/core/rest/createRestRoutes/createRestRoutes.js +71 -56
- package/dist/src/core/rest/createRestRoutes/helpers/index.js +14 -15
- package/dist/src/core/rest/createRestRoutes/helpers/prepareRestRequestConfigs/prepareRestRequestConfigs.js +38 -32
- package/dist/src/core/rest/index.js +14 -15
- package/dist/src/index.js +36 -17
- package/dist/src/server/createMockServer/createMockServer.js +74 -53
- package/dist/src/server/index.js +25 -16
- package/dist/src/server/startMockServer/startMockServer.js +20 -17
- package/dist/src/static/views/assets/icons/scheme-dark.svg +3 -3
- package/dist/src/static/views/assets/icons/scheme-light.svg +3 -3
- package/dist/src/static/views/assets/styles/global.css +88 -88
- package/dist/src/static/views/components/header/index.css +55 -55
- package/dist/src/static/views/components/header/index.ejs +39 -39
- package/dist/src/static/views/components/header/index.js +1 -1
- package/dist/src/static/views/features/scheme/dark.css +12 -12
- package/dist/src/static/views/features/scheme/index.ejs +3 -3
- package/dist/src/static/views/features/scheme/index.js +31 -31
- package/dist/src/static/views/features/scheme/light.css +12 -12
- package/dist/src/static/views/features/tab/index.css +30 -30
- package/dist/src/static/views/features/tab/index.ejs +1 -1
- package/dist/src/static/views/features/tab/index.js +12 -12
- package/dist/src/static/views/pages/404/index.css +10 -10
- package/dist/src/static/views/pages/404/index.ejs +84 -84
- package/dist/src/utils/constants/appPath.js +6 -2
- package/dist/src/utils/constants/checkModes.js +21 -30
- package/dist/src/utils/constants/default.js +15 -11
- package/dist/src/utils/constants/index.js +36 -17
- package/dist/src/utils/helpers/asyncHandler.js +6 -3
- package/dist/src/utils/helpers/config/index.js +14 -15
- package/dist/src/utils/helpers/config/resolveEntityValues/resolveEntityValues.js +109 -122
- package/dist/src/utils/helpers/entities/convertToEntityDescriptor/convertToEntityDescriptor.js +10 -6
- package/dist/src/utils/helpers/entities/index.js +25 -16
- package/dist/src/utils/helpers/entities/isEntityDescriptor/isEntityDescriptor.js +7 -4
- package/dist/src/utils/helpers/graphql/getGraphQLInput/getGraphQLInput.js +28 -18
- package/dist/src/utils/helpers/graphql/index.js +36 -17
- package/dist/src/utils/helpers/graphql/parseGraphQLRequest/parseGraphQLRequest.js +11 -9
- package/dist/src/utils/helpers/graphql/parseQuery/parseQuery.js +20 -17
- package/dist/src/utils/helpers/index.js +114 -25
- package/dist/src/utils/helpers/interceptors/callRequestInterceptor/callRequestInterceptor.js +22 -16
- package/dist/src/utils/helpers/interceptors/callResponseInterceptors/callResponseInterceptors.js +56 -48
- package/dist/src/utils/helpers/interceptors/helpers/setDelay.js +8 -5
- package/dist/src/utils/helpers/interceptors/index.js +25 -16
- package/dist/src/utils/helpers/isPlainObject/isPlainObject.js +6 -6
- package/dist/src/utils/helpers/isPrimitive/isPrimitive.js +6 -3
- package/dist/src/utils/helpers/isRegExp/isRegExp.js +6 -3
- package/dist/src/utils/helpers/sleep.js +7 -4
- package/dist/src/utils/helpers/url/convertWin32PathToUnix/convertWin32PathToUnix.js +6 -6
- package/dist/src/utils/helpers/url/getUrlParts/getUrlParts.js +7 -4
- package/dist/src/utils/helpers/url/index.js +47 -18
- package/dist/src/utils/helpers/url/removeLeadingAndTrailingSlashes/removeLeadingAndTrailingSlashes.js +6 -3
- package/dist/src/utils/helpers/url/urlJoin/urlJoin.js +11 -10
- package/dist/src/utils/types/checkModes.js +1 -2
- package/dist/src/utils/types/database.d.ts +6 -0
- package/dist/src/utils/types/database.js +1 -0
- package/dist/src/utils/types/graphql.js +1 -2
- package/dist/src/utils/types/index.d.ts +1 -0
- package/dist/src/utils/types/index.js +80 -20
- package/dist/src/utils/types/interceptors.js +1 -2
- package/dist/src/utils/types/rest.js +1 -2
- package/dist/src/utils/types/server.d.ts +5 -0
- package/dist/src/utils/types/server.js +1 -2
- package/dist/src/utils/types/values.js +1 -2
- package/package.json +130 -113
- package/dist/index.js +0 -17
|
@@ -1,19 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.getGraphqlUrlSuggestions = void 0;
|
|
4
|
-
|
|
5
|
-
const getGraphqlUrlSuggestions = ({
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
}
|
|
17
|
-
|
|
7
|
+
var _getLevenshteinDistance = require("../getLevenshteinDistance/getLevenshteinDistance");
|
|
8
|
+
const getGraphqlUrlSuggestions = ({
|
|
9
|
+
url,
|
|
10
|
+
requestConfigs
|
|
11
|
+
}) => {
|
|
12
|
+
var _url$searchParams$get;
|
|
13
|
+
// ✅ important: operationName is always second word in 'query' query param
|
|
14
|
+
const actualOperationName = (_url$searchParams$get = url.searchParams.get('query')) === null || _url$searchParams$get === void 0 ? void 0 : _url$searchParams$get.split(' ')[1];
|
|
15
|
+
const actualUrlMeaningful = `${url.pathname}/${actualOperationName}`;
|
|
16
|
+
const graphqlUrlSuggestions = requestConfigs.reduce((acc, requestConfig) => {
|
|
17
|
+
const {
|
|
18
|
+
operationName
|
|
19
|
+
} = requestConfig;
|
|
20
|
+
const distance = (0, _getLevenshteinDistance.getLevenshteinDistance)(actualUrlMeaningful, operationName);
|
|
21
|
+
const tolerance = Math.floor(operationName.length / 2);
|
|
22
|
+
if (distance <= tolerance) acc.push(requestConfig);
|
|
23
|
+
return acc;
|
|
24
|
+
}, []);
|
|
25
|
+
return graphqlUrlSuggestions;
|
|
18
26
|
};
|
|
19
|
-
exports.getGraphqlUrlSuggestions = getGraphqlUrlSuggestions;
|
|
27
|
+
exports.getGraphqlUrlSuggestions = getGraphqlUrlSuggestions;
|
|
@@ -1,80 +1,84 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
4
6
|
exports.getLevenshteinDistance = void 0;
|
|
5
|
-
|
|
7
|
+
/* eslint-disable */
|
|
8
|
+
|
|
9
|
+
const min = (d0, d1, d2, bx, ay) => d0 < d1 || d2 < d1 ? d0 > d2 ? d2 + 1 : d0 + 1 : bx === ay ? d1 : d1 + 1;
|
|
6
10
|
const getLevenshteinDistance = (a, b) => {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
}
|
|
11
|
+
if (a === b) {
|
|
12
|
+
return 0;
|
|
13
|
+
}
|
|
14
|
+
if (a.length > b.length) {
|
|
15
|
+
const tmp = a;
|
|
16
|
+
a = b;
|
|
17
|
+
b = tmp;
|
|
18
|
+
}
|
|
19
|
+
let la = a.length;
|
|
20
|
+
let lb = b.length;
|
|
21
|
+
while (la > 0 && a.charCodeAt(la - 1) === b.charCodeAt(lb - 1)) {
|
|
22
|
+
la--;
|
|
23
|
+
lb--;
|
|
24
|
+
}
|
|
25
|
+
let offset = 0;
|
|
26
|
+
while (offset < la && a.charCodeAt(offset) === b.charCodeAt(offset)) {
|
|
27
|
+
offset++;
|
|
28
|
+
}
|
|
29
|
+
la -= offset;
|
|
30
|
+
lb -= offset;
|
|
31
|
+
if (la === 0 || lb < 3) {
|
|
32
|
+
return lb;
|
|
33
|
+
}
|
|
34
|
+
let x = 0;
|
|
35
|
+
let y;
|
|
36
|
+
let d0;
|
|
37
|
+
let d1;
|
|
38
|
+
let d2;
|
|
39
|
+
let d3;
|
|
40
|
+
let dd = 0;
|
|
41
|
+
let dy;
|
|
42
|
+
let ay;
|
|
43
|
+
let bx0;
|
|
44
|
+
let bx1;
|
|
45
|
+
let bx2;
|
|
46
|
+
let bx3;
|
|
47
|
+
const vector = [];
|
|
48
|
+
for (y = 0; y < la; y++) {
|
|
49
|
+
vector.push(y + 1);
|
|
50
|
+
vector.push(a.charCodeAt(offset + y));
|
|
51
|
+
}
|
|
52
|
+
const len = vector.length - 1;
|
|
53
|
+
for (; x < lb - 3;) {
|
|
54
|
+
bx0 = b.charCodeAt(offset + (d0 = x));
|
|
55
|
+
bx1 = b.charCodeAt(offset + (d1 = x + 1));
|
|
56
|
+
bx2 = b.charCodeAt(offset + (d2 = x + 2));
|
|
57
|
+
bx3 = b.charCodeAt(offset + (d3 = x + 3));
|
|
58
|
+
dd = x += 4;
|
|
59
|
+
for (y = 0; y < len; y += 2) {
|
|
60
|
+
dy = vector[y];
|
|
61
|
+
ay = vector[y + 1];
|
|
62
|
+
d0 = min(dy, d0, d1, bx0, ay);
|
|
63
|
+
d1 = min(d0, d1, d2, bx1, ay);
|
|
64
|
+
d2 = min(d1, d2, d3, bx2, ay);
|
|
65
|
+
dd = min(d2, d3, dd, bx3, ay);
|
|
66
|
+
vector[y] = dd;
|
|
67
|
+
d3 = d2;
|
|
68
|
+
d2 = d1;
|
|
69
|
+
d1 = d0;
|
|
70
|
+
d0 = dy;
|
|
68
71
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
72
|
+
}
|
|
73
|
+
for (; x < lb;) {
|
|
74
|
+
bx0 = b.charCodeAt(offset + (d0 = x));
|
|
75
|
+
dd = ++x;
|
|
76
|
+
for (y = 0; y < len; y += 2) {
|
|
77
|
+
dy = vector[y];
|
|
78
|
+
vector[y] = dd = min(dy, d0, dd, bx0, vector[y + 1]);
|
|
79
|
+
d0 = dy;
|
|
77
80
|
}
|
|
78
|
-
|
|
81
|
+
}
|
|
82
|
+
return dd;
|
|
79
83
|
};
|
|
80
|
-
exports.getLevenshteinDistance = getLevenshteinDistance;
|
|
84
|
+
exports.getLevenshteinDistance = getLevenshteinDistance;
|
|
@@ -1,34 +1,39 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.getRestUrlSuggestions = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const getRestUrlSuggestions = ({
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
}
|
|
32
|
-
return
|
|
7
|
+
var _helpers = require("../../../../../utils/helpers");
|
|
8
|
+
var _getLevenshteinDistance = require("../getLevenshteinDistance/getLevenshteinDistance");
|
|
9
|
+
var _helpers2 = require("./helpers");
|
|
10
|
+
const getRestUrlSuggestions = ({
|
|
11
|
+
url,
|
|
12
|
+
requestConfigs
|
|
13
|
+
}) => {
|
|
14
|
+
const actualUrlParts = (0, _helpers.getUrlParts)(url.pathname);
|
|
15
|
+
const restUrlSuggestions = requestConfigs.reduce((acc, requestConfig) => {
|
|
16
|
+
const patternUrlParts = (0, _helpers.getUrlParts)(requestConfig.path);
|
|
17
|
+
// ✅ important: ignore patterns with different amount of parts
|
|
18
|
+
if (patternUrlParts.length !== actualUrlParts.length) return acc;
|
|
19
|
+
const actualUrlMeaningfulString = (0, _helpers2.getActualRestUrlMeaningfulString)(actualUrlParts, patternUrlParts);
|
|
20
|
+
const patternUrlMeaningfulString = (0, _helpers2.getPatternRestUrlMeaningfulString)(patternUrlParts);
|
|
21
|
+
const tolerance = Math.floor(patternUrlMeaningfulString.length / 2);
|
|
22
|
+
const distance = (0, _getLevenshteinDistance.getLevenshteinDistance)(actualUrlMeaningfulString, patternUrlMeaningfulString);
|
|
23
|
+
if (distance <= tolerance) {
|
|
24
|
+
// replace param names in pattern with param values from actual url
|
|
25
|
+
const urlSuggestion = patternUrlParts.map((_patternUrlPart, index) => {
|
|
26
|
+
if (patternUrlParts[index].startsWith(':')) return actualUrlParts[index];
|
|
27
|
+
return patternUrlParts[index];
|
|
28
|
+
}).join('/');
|
|
29
|
+
const suggestionWithQueryParams = `/${urlSuggestion}${url.search}`;
|
|
30
|
+
acc.push({
|
|
31
|
+
...requestConfig,
|
|
32
|
+
path: suggestionWithQueryParams
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
return acc;
|
|
36
|
+
}, []);
|
|
37
|
+
return restUrlSuggestions;
|
|
33
38
|
};
|
|
34
|
-
exports.getRestUrlSuggestions = getRestUrlSuggestions;
|
|
39
|
+
exports.getRestUrlSuggestions = getRestUrlSuggestions;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.getActualRestUrlMeaningfulString = void 0;
|
|
4
|
-
const getActualRestUrlMeaningfulString = (actualUrlParts, patternUrlParts) => actualUrlParts
|
|
5
|
-
|
|
6
|
-
.join('');
|
|
7
|
-
exports.getActualRestUrlMeaningfulString = getActualRestUrlMeaningfulString;
|
|
7
|
+
const getActualRestUrlMeaningfulString = (actualUrlParts, patternUrlParts) => actualUrlParts.filter((_actualUrlPart, index) => !patternUrlParts[index].startsWith(':')).join('');
|
|
8
|
+
exports.getActualRestUrlMeaningfulString = getActualRestUrlMeaningfulString;
|
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.getPatternRestUrlMeaningfulString = void 0;
|
|
4
|
-
const getPatternRestUrlMeaningfulString =
|
|
5
|
-
exports.getPatternRestUrlMeaningfulString = getPatternRestUrlMeaningfulString;
|
|
7
|
+
const getPatternRestUrlMeaningfulString = patternUrlParts => patternUrlParts.filter(urlPatternPart => !urlPatternPart.startsWith(':')).join('');
|
|
8
|
+
exports.getPatternRestUrlMeaningfulString = getPatternRestUrlMeaningfulString;
|
package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/index.js
CHANGED
|
@@ -1,18 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var _getActualRestUrlMeaningfulString = require("./getActualRestUrlMeaningfulString/getActualRestUrlMeaningfulString");
|
|
7
|
+
Object.keys(_getActualRestUrlMeaningfulString).forEach(function (key) {
|
|
8
|
+
if (key === "default" || key === "__esModule") return;
|
|
9
|
+
if (key in exports && exports[key] === _getActualRestUrlMeaningfulString[key]) return;
|
|
10
|
+
Object.defineProperty(exports, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function () {
|
|
13
|
+
return _getActualRestUrlMeaningfulString[key];
|
|
7
14
|
}
|
|
8
|
-
|
|
9
|
-
})
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
var _getPatternRestUrlMeaningfulString = require("./getPatternRestUrlMeaningfulString/getPatternRestUrlMeaningfulString");
|
|
18
|
+
Object.keys(_getPatternRestUrlMeaningfulString).forEach(function (key) {
|
|
19
|
+
if (key === "default" || key === "__esModule") return;
|
|
20
|
+
if (key in exports && exports[key] === _getPatternRestUrlMeaningfulString[key]) return;
|
|
21
|
+
Object.defineProperty(exports, key, {
|
|
22
|
+
enumerable: true,
|
|
23
|
+
get: function () {
|
|
24
|
+
return _getPatternRestUrlMeaningfulString[key];
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
});
|
|
@@ -1,19 +1,38 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var _getGraphqlUrlSuggestions = require("./getGraphqlUrlSuggestions/getGraphqlUrlSuggestions");
|
|
7
|
+
Object.keys(_getGraphqlUrlSuggestions).forEach(function (key) {
|
|
8
|
+
if (key === "default" || key === "__esModule") return;
|
|
9
|
+
if (key in exports && exports[key] === _getGraphqlUrlSuggestions[key]) return;
|
|
10
|
+
Object.defineProperty(exports, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function () {
|
|
13
|
+
return _getGraphqlUrlSuggestions[key];
|
|
7
14
|
}
|
|
8
|
-
|
|
9
|
-
})
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
var _getLevenshteinDistance = require("./getLevenshteinDistance/getLevenshteinDistance");
|
|
18
|
+
Object.keys(_getLevenshteinDistance).forEach(function (key) {
|
|
19
|
+
if (key === "default" || key === "__esModule") return;
|
|
20
|
+
if (key in exports && exports[key] === _getLevenshteinDistance[key]) return;
|
|
21
|
+
Object.defineProperty(exports, key, {
|
|
22
|
+
enumerable: true,
|
|
23
|
+
get: function () {
|
|
24
|
+
return _getLevenshteinDistance[key];
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
var _getRestUrlSuggestions = require("./getRestUrlSuggestions/getRestUrlSuggestions");
|
|
29
|
+
Object.keys(_getRestUrlSuggestions).forEach(function (key) {
|
|
30
|
+
if (key === "default" || key === "__esModule") return;
|
|
31
|
+
if (key in exports && exports[key] === _getRestUrlSuggestions[key]) return;
|
|
32
|
+
Object.defineProperty(exports, key, {
|
|
33
|
+
enumerable: true,
|
|
34
|
+
get: function () {
|
|
35
|
+
return _getRestUrlSuggestions[key];
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
});
|
|
@@ -1,53 +1,68 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.notFoundMiddleware = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
7
|
+
var _helpers = require("../../../utils/helpers");
|
|
8
|
+
var _helpers2 = require("./helpers");
|
|
6
9
|
const notFoundMiddleware = (server, mockServerConfig) => {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
10
|
+
var _rest$configs$filter$, _graphql$configs$filt;
|
|
11
|
+
const {
|
|
12
|
+
baseUrl: serverBaseUrl,
|
|
13
|
+
rest,
|
|
14
|
+
graphql
|
|
15
|
+
} = mockServerConfig;
|
|
16
|
+
const restRequestConfigs = (_rest$configs$filter$ = rest === null || rest === void 0 ? void 0 : rest.configs.filter(({
|
|
17
|
+
path
|
|
18
|
+
}) => !(path instanceof RegExp)).map(request => {
|
|
19
|
+
var _rest$baseUrl;
|
|
20
|
+
return {
|
|
21
|
+
method: request.method,
|
|
22
|
+
path: `${serverBaseUrl !== null && serverBaseUrl !== void 0 ? serverBaseUrl : ''}${(_rest$baseUrl = rest === null || rest === void 0 ? void 0 : rest.baseUrl) !== null && _rest$baseUrl !== void 0 ? _rest$baseUrl : ''}${request.path}`
|
|
23
|
+
};
|
|
24
|
+
})) !== null && _rest$configs$filter$ !== void 0 ? _rest$configs$filter$ : [];
|
|
25
|
+
const graphqlRequestConfigs = (_graphql$configs$filt = graphql === null || graphql === void 0 ? void 0 : graphql.configs.filter(({
|
|
26
|
+
operationName
|
|
27
|
+
}) => !(operationName instanceof RegExp)).map(request => {
|
|
28
|
+
var _graphql$baseUrl;
|
|
29
|
+
return {
|
|
30
|
+
operationType: request.operationType,
|
|
31
|
+
operationName: `${serverBaseUrl !== null && serverBaseUrl !== void 0 ? serverBaseUrl : ''}${(_graphql$baseUrl = graphql === null || graphql === void 0 ? void 0 : graphql.baseUrl) !== null && _graphql$baseUrl !== void 0 ? _graphql$baseUrl : ''} ${request.operationName}`
|
|
32
|
+
};
|
|
33
|
+
})) !== null && _graphql$configs$filt !== void 0 ? _graphql$configs$filt : [];
|
|
34
|
+
server.use((request, response) => {
|
|
35
|
+
var _request$headers$acce, _request$headers$acce2;
|
|
36
|
+
const url = new URL(`${request.protocol}://${request.get('host')}${request.originalUrl}`);
|
|
37
|
+
let restRequestSuggestions = [];
|
|
38
|
+
if (rest) {
|
|
39
|
+
restRequestSuggestions = (0, _helpers2.getRestUrlSuggestions)({
|
|
40
|
+
url,
|
|
41
|
+
requestConfigs: restRequestConfigs
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
let graphqlRequestSuggestions = [];
|
|
45
|
+
if (graphql && (0, _helpers.parseGraphQLRequest)(request)) {
|
|
46
|
+
graphqlRequestSuggestions = (0, _helpers2.getGraphqlUrlSuggestions)({
|
|
47
|
+
url,
|
|
48
|
+
requestConfigs: graphqlRequestConfigs
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
const isRequestSupportHtml = ((_request$headers$acce = request.headers.accept) === null || _request$headers$acce === void 0 ? void 0 : _request$headers$acce.includes('text/html')) || ((_request$headers$acce2 = request.headers.accept) === null || _request$headers$acce2 === void 0 ? void 0 : _request$headers$acce2.includes('*/*'));
|
|
52
|
+
if (isRequestSupportHtml) {
|
|
53
|
+
response.status(404).render('pages/404', {
|
|
54
|
+
restRequestSuggestions,
|
|
55
|
+
graphqlRequestSuggestions
|
|
56
|
+
});
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
response.status(404).json({
|
|
60
|
+
message: 'Request or page not found. Similar requests in data',
|
|
61
|
+
data: {
|
|
62
|
+
restRequestSuggestions,
|
|
63
|
+
graphqlRequestSuggestions
|
|
64
|
+
}
|
|
51
65
|
});
|
|
66
|
+
});
|
|
52
67
|
};
|
|
53
|
-
exports.notFoundMiddleware = notFoundMiddleware;
|
|
68
|
+
exports.notFoundMiddleware = notFoundMiddleware;
|
package/dist/src/core/middlewares/requestInterceptorMiddleware/requestInterceptorMiddleware.js
CHANGED
|
@@ -1,11 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.requestInterceptorMiddleware = void 0;
|
|
4
|
-
|
|
7
|
+
var _helpers = require("../../../utils/helpers");
|
|
5
8
|
const requestInterceptorMiddleware = (server, interceptor) => {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
9
|
+
server.use((0, _helpers.asyncHandler)(async (request, _response, next) => {
|
|
10
|
+
await (0, _helpers.callRequestInterceptor)({
|
|
11
|
+
request,
|
|
12
|
+
interceptor
|
|
13
|
+
});
|
|
14
|
+
return next();
|
|
15
|
+
}));
|
|
10
16
|
};
|
|
11
|
-
exports.requestInterceptorMiddleware = requestInterceptorMiddleware;
|
|
17
|
+
exports.requestInterceptorMiddleware = requestInterceptorMiddleware;
|
|
@@ -1,30 +1,31 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
6
|
exports.staticMiddleware = void 0;
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
7
|
+
var _express = _interopRequireDefault(require("express"));
|
|
8
|
+
var _constants = require("../../../utils/constants");
|
|
9
|
+
var _helpers = require("../../../utils/helpers");
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
10
11
|
const staticMiddleware = (server, baseUrl, staticPath) => {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
server.use(baseUrl, express_1.default.static((0, helpers_1.urlJoin)(constants_1.APP_PATH, staticPath)));
|
|
20
|
-
});
|
|
21
|
-
return;
|
|
22
|
-
}
|
|
23
|
-
const isStaticPathObject = typeof staticPath === 'object';
|
|
24
|
-
if (isStaticPathObject) {
|
|
25
|
-
server.use((0, helpers_1.urlJoin)(baseUrl, staticPath.prefix), express_1.default.static((0, helpers_1.urlJoin)(constants_1.APP_PATH, staticPath.path)));
|
|
12
|
+
const isStaticPathArray = Array.isArray(staticPath);
|
|
13
|
+
if (isStaticPathArray) {
|
|
14
|
+
staticPath.forEach(staticPath => {
|
|
15
|
+
const isPathObject = typeof staticPath === 'object';
|
|
16
|
+
if (isPathObject) {
|
|
17
|
+
server.use((0, _helpers.urlJoin)(baseUrl, staticPath.prefix), _express.default.static((0, _helpers.urlJoin)(_constants.APP_PATH, staticPath.path)));
|
|
26
18
|
return;
|
|
27
|
-
|
|
28
|
-
|
|
19
|
+
}
|
|
20
|
+
server.use(baseUrl, _express.default.static((0, _helpers.urlJoin)(_constants.APP_PATH, staticPath)));
|
|
21
|
+
});
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
const isStaticPathObject = typeof staticPath === 'object';
|
|
25
|
+
if (isStaticPathObject) {
|
|
26
|
+
server.use((0, _helpers.urlJoin)(baseUrl, staticPath.prefix), _express.default.static((0, _helpers.urlJoin)(_constants.APP_PATH, staticPath.path)));
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
server.use(baseUrl, _express.default.static((0, _helpers.urlJoin)(_constants.APP_PATH, staticPath)));
|
|
29
30
|
};
|
|
30
|
-
exports.staticMiddleware = staticMiddleware;
|
|
31
|
+
exports.staticMiddleware = staticMiddleware;
|