mock-config-server 2.3.0 → 3.0.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.
Files changed (160) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +502 -326
  3. package/package.json +113 -106
  4. package/dist/bin/bin.d.ts +0 -2
  5. package/dist/bin/bin.js +0 -8
  6. package/dist/bin/build.d.ts +0 -2
  7. package/dist/bin/build.js +0 -49
  8. package/dist/bin/cli.d.ts +0 -1
  9. package/dist/bin/cli.js +0 -48
  10. package/dist/bin/helpers/index.d.ts +0 -3
  11. package/dist/bin/helpers/index.js +0 -19
  12. package/dist/bin/helpers/resolveConfigFile.d.ts +0 -2
  13. package/dist/bin/helpers/resolveConfigFile.js +0 -20
  14. package/dist/bin/helpers/resolveConfigFilePath.d.ts +0 -1
  15. package/dist/bin/helpers/resolveConfigFilePath.js +0 -39
  16. package/dist/bin/helpers/resolveExportsFromSourceCode.d.ts +0 -1
  17. package/dist/bin/helpers/resolveExportsFromSourceCode.js +0 -11
  18. package/dist/bin/resolveConfigFilePath/resolveConfigFilePath.d.ts +0 -1
  19. package/dist/bin/resolveConfigFilePath/resolveConfigFilePath.js +0 -39
  20. package/dist/bin/run.d.ts +0 -6
  21. package/dist/bin/run.js +0 -17
  22. package/dist/bin/validateMockServerConfig/validateBaseUrl/validateBaseUrl.d.ts +0 -1
  23. package/dist/bin/validateMockServerConfig/validateBaseUrl/validateBaseUrl.js +0 -12
  24. package/dist/bin/validateMockServerConfig/validateCors/validateCors.d.ts +0 -1
  25. package/dist/bin/validateMockServerConfig/validateCors/validateCors.js +0 -82
  26. package/dist/bin/validateMockServerConfig/validateGraphqlConfig/validateGraphqlConfig.d.ts +0 -1
  27. package/dist/bin/validateMockServerConfig/validateGraphqlConfig/validateGraphqlConfig.js +0 -48
  28. package/dist/bin/validateMockServerConfig/validateGraphqlConfig/validateRoutes/validateRoutes.d.ts +0 -2
  29. package/dist/bin/validateMockServerConfig/validateGraphqlConfig/validateRoutes/validateRoutes.js +0 -71
  30. package/dist/bin/validateMockServerConfig/validateInterceptors/validateInterceptors.d.ts +0 -1
  31. package/dist/bin/validateMockServerConfig/validateInterceptors/validateInterceptors.js +0 -21
  32. package/dist/bin/validateMockServerConfig/validateMockServerConfig.d.ts +0 -2
  33. package/dist/bin/validateMockServerConfig/validateMockServerConfig.js +0 -30
  34. package/dist/bin/validateMockServerConfig/validatePort/validatePort.d.ts +0 -1
  35. package/dist/bin/validateMockServerConfig/validatePort/validatePort.js +0 -9
  36. package/dist/bin/validateMockServerConfig/validateRestConfig/validateRestConfig.d.ts +0 -1
  37. package/dist/bin/validateMockServerConfig/validateRestConfig/validateRestConfig.js +0 -52
  38. package/dist/bin/validateMockServerConfig/validateRestConfig/validateRoutes/validateRoutes.d.ts +0 -2
  39. package/dist/bin/validateMockServerConfig/validateRestConfig/validateRoutes/validateRoutes.js +0 -105
  40. package/dist/bin/validateMockServerConfig/validateStaticPath/validateStaticPath.d.ts +0 -1
  41. package/dist/bin/validateMockServerConfig/validateStaticPath/validateStaticPath.js +0 -44
  42. package/dist/index.d.ts +0 -1
  43. package/dist/index.js +0 -17
  44. package/dist/src/core/graphql/createGraphQLRoutes/createGraphQLRoutes.d.ts +0 -3
  45. package/dist/src/core/graphql/createGraphQLRoutes/createGraphQLRoutes.js +0 -74
  46. package/dist/src/core/graphql/createGraphQLRoutes/helpers/index.d.ts +0 -1
  47. package/dist/src/core/graphql/createGraphQLRoutes/helpers/index.js +0 -17
  48. package/dist/src/core/graphql/createGraphQLRoutes/helpers/prepareGraphQLRequestConfigs/prepareGraphQLRequestConfigs.d.ts +0 -2
  49. package/dist/src/core/graphql/createGraphQLRoutes/helpers/prepareGraphQLRequestConfigs/prepareGraphQLRequestConfigs.js +0 -30
  50. package/dist/src/core/graphql/index.d.ts +0 -1
  51. package/dist/src/core/graphql/index.js +0 -17
  52. package/dist/src/core/middlewares/cookieParseMiddleware/cookieParseMiddleware.d.ts +0 -2
  53. package/dist/src/core/middlewares/cookieParseMiddleware/cookieParseMiddleware.js +0 -16
  54. package/dist/src/core/middlewares/cookieParseMiddleware/helpers/index.d.ts +0 -1
  55. package/dist/src/core/middlewares/cookieParseMiddleware/helpers/index.js +0 -17
  56. package/dist/src/core/middlewares/cookieParseMiddleware/helpers/parseCookie/parseCookie.d.ts +0 -3
  57. package/dist/src/core/middlewares/cookieParseMiddleware/helpers/parseCookie/parseCookie.js +0 -17
  58. package/dist/src/core/middlewares/corsMiddleware/corsMiddleware.d.ts +0 -3
  59. package/dist/src/core/middlewares/corsMiddleware/corsMiddleware.js +0 -44
  60. package/dist/src/core/middlewares/corsMiddleware/helpers/getAllowedOrigins/getAllowedOrigins.d.ts +0 -2
  61. package/dist/src/core/middlewares/corsMiddleware/helpers/getAllowedOrigins/getAllowedOrigins.js +0 -13
  62. package/dist/src/core/middlewares/corsMiddleware/helpers/index.d.ts +0 -1
  63. package/dist/src/core/middlewares/corsMiddleware/helpers/index.js +0 -17
  64. package/dist/src/core/middlewares/destroyerMiddleware/destroyerMiddleware.d.ts +0 -7
  65. package/dist/src/core/middlewares/destroyerMiddleware/destroyerMiddleware.js +0 -23
  66. package/dist/src/core/middlewares/index.d.ts +0 -7
  67. package/dist/src/core/middlewares/index.js +0 -23
  68. package/dist/src/core/middlewares/noCorsMiddleware/noCorsMiddleware.d.ts +0 -2
  69. package/dist/src/core/middlewares/noCorsMiddleware/noCorsMiddleware.js +0 -24
  70. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getGraphqlUrlSuggestions/getGraphqlUrlSuggestions.d.ts +0 -6
  71. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getGraphqlUrlSuggestions/getGraphqlUrlSuggestions.js +0 -18
  72. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getLevenshteinDistance/getLevenshteinDistance.d.ts +0 -1
  73. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getLevenshteinDistance/getLevenshteinDistance.js +0 -80
  74. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/getRestUrlSuggestions.d.ts +0 -6
  75. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/getRestUrlSuggestions.js +0 -34
  76. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/getActualRestUrlMeaningfulString/getActualRestUrlMeaningfulString.d.ts +0 -1
  77. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/getActualRestUrlMeaningfulString/getActualRestUrlMeaningfulString.js +0 -7
  78. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/getPatternRestUrlMeaningfulString/getPatternRestUrlMeaningfulString.d.ts +0 -1
  79. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/getPatternRestUrlMeaningfulString/getPatternRestUrlMeaningfulString.js +0 -5
  80. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/index.d.ts +0 -2
  81. package/dist/src/core/middlewares/notFoundMiddleware/helpers/getRestUrlSuggestions/helpers/index.js +0 -18
  82. package/dist/src/core/middlewares/notFoundMiddleware/helpers/index.d.ts +0 -3
  83. package/dist/src/core/middlewares/notFoundMiddleware/helpers/index.js +0 -19
  84. package/dist/src/core/middlewares/notFoundMiddleware/notFoundMiddleware.d.ts +0 -8
  85. package/dist/src/core/middlewares/notFoundMiddleware/notFoundMiddleware.js +0 -47
  86. package/dist/src/core/middlewares/requestInterceptorMiddleware/requestInterceptorMiddleware.d.ts +0 -3
  87. package/dist/src/core/middlewares/requestInterceptorMiddleware/requestInterceptorMiddleware.js +0 -11
  88. package/dist/src/core/middlewares/staticMiddleware/staticMiddleware.d.ts +0 -3
  89. package/dist/src/core/middlewares/staticMiddleware/staticMiddleware.js +0 -30
  90. package/dist/src/core/rest/createRestRoutes/createRestRoutes.d.ts +0 -3
  91. package/dist/src/core/rest/createRestRoutes/createRestRoutes.js +0 -44
  92. package/dist/src/core/rest/createRestRoutes/helpers/index.d.ts +0 -1
  93. package/dist/src/core/rest/createRestRoutes/helpers/index.js +0 -17
  94. package/dist/src/core/rest/createRestRoutes/helpers/prepareRestRequestConfigs/prepareRestRequestConfigs.d.ts +0 -2
  95. package/dist/src/core/rest/createRestRoutes/helpers/prepareRestRequestConfigs/prepareRestRequestConfigs.js +0 -32
  96. package/dist/src/core/rest/index.d.ts +0 -1
  97. package/dist/src/core/rest/index.js +0 -17
  98. package/dist/src/index.d.ts +0 -3
  99. package/dist/src/index.js +0 -19
  100. package/dist/src/server/createMockServer/createMockServer.d.ts +0 -3
  101. package/dist/src/server/createMockServer/createMockServer.js +0 -59
  102. package/dist/src/server/index.d.ts +0 -2
  103. package/dist/src/server/index.js +0 -18
  104. package/dist/src/server/startMockServer/startMockServer.d.ts +0 -5
  105. package/dist/src/server/startMockServer/startMockServer.js +0 -20
  106. package/dist/src/static/views/notFound.ejs +0 -42
  107. package/dist/src/utils/constants/appPath.d.ts +0 -1
  108. package/dist/src/utils/constants/appPath.js +0 -4
  109. package/dist/src/utils/constants/default.d.ts +0 -11
  110. package/dist/src/utils/constants/default.js +0 -14
  111. package/dist/src/utils/constants/index.d.ts +0 -2
  112. package/dist/src/utils/constants/index.js +0 -18
  113. package/dist/src/utils/helpers/config/index.d.ts +0 -1
  114. package/dist/src/utils/helpers/config/index.js +0 -17
  115. package/dist/src/utils/helpers/config/isEntitiesEqual/isEntityValuesEqual.d.ts +0 -1
  116. package/dist/src/utils/helpers/config/isEntitiesEqual/isEntityValuesEqual.js +0 -29
  117. package/dist/src/utils/helpers/graphql/getGraphQLInput/getGraphQLInput.d.ts +0 -3
  118. package/dist/src/utils/helpers/graphql/getGraphQLInput/getGraphQLInput.js +0 -21
  119. package/dist/src/utils/helpers/graphql/index.d.ts +0 -3
  120. package/dist/src/utils/helpers/graphql/index.js +0 -19
  121. package/dist/src/utils/helpers/graphql/parseGraphQLRequest/parseGraphQLRequest.d.ts +0 -3
  122. package/dist/src/utils/helpers/graphql/parseGraphQLRequest/parseGraphQLRequest.js +0 -12
  123. package/dist/src/utils/helpers/graphql/parseQuery/parseQuery.d.ts +0 -7
  124. package/dist/src/utils/helpers/graphql/parseQuery/parseQuery.js +0 -21
  125. package/dist/src/utils/helpers/index.d.ts +0 -6
  126. package/dist/src/utils/helpers/index.js +0 -22
  127. package/dist/src/utils/helpers/interceptors/callRequestInterceptor/callRequestInterceptor.d.ts +0 -8
  128. package/dist/src/utils/helpers/interceptors/callRequestInterceptor/callRequestInterceptor.js +0 -19
  129. package/dist/src/utils/helpers/interceptors/callResponseInterceptors/callResponseInterceptors.d.ts +0 -15
  130. package/dist/src/utils/helpers/interceptors/callResponseInterceptors/callResponseInterceptors.js +0 -52
  131. package/dist/src/utils/helpers/interceptors/helpers/setDelay.d.ts +0 -1
  132. package/dist/src/utils/helpers/interceptors/helpers/setDelay.js +0 -8
  133. package/dist/src/utils/helpers/interceptors/index.d.ts +0 -2
  134. package/dist/src/utils/helpers/interceptors/index.js +0 -18
  135. package/dist/src/utils/helpers/isPlainObject/isPlainObject.d.ts +0 -1
  136. package/dist/src/utils/helpers/isPlainObject/isPlainObject.js +0 -5
  137. package/dist/src/utils/helpers/sleep.d.ts +0 -1
  138. package/dist/src/utils/helpers/sleep.js +0 -7
  139. package/dist/src/utils/helpers/url/convertWin32PathToUnix/convertWin32PathToUnix.d.ts +0 -1
  140. package/dist/src/utils/helpers/url/convertWin32PathToUnix/convertWin32PathToUnix.js +0 -8
  141. package/dist/src/utils/helpers/url/getUrlParts/getUrlParts.d.ts +0 -1
  142. package/dist/src/utils/helpers/url/getUrlParts/getUrlParts.js +0 -6
  143. package/dist/src/utils/helpers/url/index.d.ts +0 -4
  144. package/dist/src/utils/helpers/url/index.js +0 -20
  145. package/dist/src/utils/helpers/url/removeLeadingAndTrailingSlashes/removeLeadingAndTrailingSlashes.d.ts +0 -1
  146. package/dist/src/utils/helpers/url/removeLeadingAndTrailingSlashes/removeLeadingAndTrailingSlashes.js +0 -5
  147. package/dist/src/utils/helpers/url/urlJoin/urlJoin.d.ts +0 -1
  148. package/dist/src/utils/helpers/url/urlJoin/urlJoin.js +0 -14
  149. package/dist/src/utils/types/graphql.d.ts +0 -34
  150. package/dist/src/utils/types/graphql.js +0 -2
  151. package/dist/src/utils/types/index.d.ts +0 -5
  152. package/dist/src/utils/types/index.js +0 -21
  153. package/dist/src/utils/types/interceptors.d.ts +0 -30
  154. package/dist/src/utils/types/interceptors.js +0 -2
  155. package/dist/src/utils/types/rest.d.ts +0 -38
  156. package/dist/src/utils/types/rest.js +0 -2
  157. package/dist/src/utils/types/server.d.ts +0 -47
  158. package/dist/src/utils/types/server.js +0 -2
  159. package/dist/src/utils/types/values.d.ts +0 -10
  160. package/dist/src/utils/types/values.js +0 -2
@@ -1,17 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseCookie = void 0;
4
- const parseCookie = (cookieHeader) => {
5
- if (!cookieHeader)
6
- return {};
7
- const cookies = {};
8
- const cookiePairs = cookieHeader.split(';');
9
- cookiePairs.forEach((cookie) => {
10
- const [name, value] = cookie.trim().split('=');
11
- if (!name)
12
- return;
13
- cookies[name.trim()] = value?.trim() ?? '';
14
- });
15
- return cookies;
16
- };
17
- exports.parseCookie = parseCookie;
@@ -1,3 +0,0 @@
1
- import type { Express } from 'express';
2
- import type { Cors } from '../../../utils/types';
3
- export declare const corsMiddleware: (server: Express, cors: Cors) => void;
@@ -1,44 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.corsMiddleware = void 0;
4
- const constants_1 = require("../../../utils/constants");
5
- const helpers_1 = require("./helpers");
6
- const corsMiddleware = (server, cors) => {
7
- server.use(async (request, response, next) => {
8
- if (Array.isArray(cors.origin) && !cors.origin.length) {
9
- return next();
10
- }
11
- let allowedOrigins = [];
12
- if (typeof cors.origin === 'function') {
13
- const origins = await cors.origin(request);
14
- allowedOrigins = (0, helpers_1.getAllowedOrigins)(origins);
15
- }
16
- else {
17
- allowedOrigins = (0, helpers_1.getAllowedOrigins)(cors.origin);
18
- }
19
- const { origin } = request.headers;
20
- if (!allowedOrigins?.length || !origin) {
21
- return next();
22
- }
23
- const isRequestOriginAllowed = allowedOrigins.some((allowedOrigin) => {
24
- if (allowedOrigin instanceof RegExp) {
25
- return new RegExp(allowedOrigin).test(origin);
26
- }
27
- return allowedOrigin === origin;
28
- });
29
- if (isRequestOriginAllowed) {
30
- response.setHeader('Access-Control-Allow-Origin', origin);
31
- response.setHeader('Access-Control-Allow-Credentials', `${cors.credentials ?? constants_1.DEFAULT.CORS.CREDENTIALS}`);
32
- response.setHeader('Access-Control-Expose-Headers', cors.exposedHeaders ?? constants_1.DEFAULT.CORS.EXPOSED_HEADERS);
33
- if (request.method === 'OPTIONS') {
34
- response.setHeader('Access-Control-Allow-Methods', cors.methods ?? constants_1.DEFAULT.CORS.METHODS);
35
- response.setHeader('Access-Control-Allow-Headers', cors.allowedHeaders ?? constants_1.DEFAULT.CORS.ALLOWED_HEADERS);
36
- response.setHeader('Access-Control-Max-Age', cors.maxAge ?? constants_1.DEFAULT.CORS.MAX_AGE);
37
- response.sendStatus(204);
38
- return response.end();
39
- }
40
- }
41
- return next();
42
- });
43
- };
44
- exports.corsMiddleware = corsMiddleware;
@@ -1,2 +0,0 @@
1
- import type { CorsOrigin } from '../../../../../utils/types';
2
- export declare const getAllowedOrigins: (origin: CorsOrigin) => (string | RegExp)[];
@@ -1,13 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getAllowedOrigins = void 0;
4
- const getAllowedOrigins = (origin) => {
5
- if (Array.isArray(origin)) {
6
- return origin;
7
- }
8
- if (typeof origin === 'string' || origin instanceof RegExp) {
9
- return [origin];
10
- }
11
- throw new Error('Invalid cors origin format');
12
- };
13
- exports.getAllowedOrigins = getAllowedOrigins;
@@ -1 +0,0 @@
1
- export * from './getAllowedOrigins/getAllowedOrigins';
@@ -1,17 +0,0 @@
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
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./getAllowedOrigins/getAllowedOrigins"), exports);
@@ -1,7 +0,0 @@
1
- /// <reference types="node" />
2
- import type { Server } from 'http';
3
- type ServerWithDestroyer = Server & {
4
- destroy: Server['close'];
5
- };
6
- export declare const destroyerMiddleware: (server: Server) => ServerWithDestroyer;
7
- export {};
@@ -1,23 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.destroyerMiddleware = void 0;
4
- const destroyerMiddleware = (server) => {
5
- const serverWithDestroyer = server;
6
- const connections = {};
7
- serverWithDestroyer.on('connection', (connection) => {
8
- const key = `${connection.remoteAddress}:${connection.remotePort}`;
9
- connections[key] = connection;
10
- connection.on('close', () => {
11
- delete connections[key];
12
- });
13
- });
14
- serverWithDestroyer.destroy = (callback) => {
15
- serverWithDestroyer.close(callback);
16
- Object.values(connections).forEach((connection) => {
17
- connection.destroy();
18
- });
19
- return serverWithDestroyer;
20
- };
21
- return serverWithDestroyer;
22
- };
23
- exports.destroyerMiddleware = destroyerMiddleware;
@@ -1,7 +0,0 @@
1
- export * from './staticMiddleware/staticMiddleware';
2
- export * from './corsMiddleware/corsMiddleware';
3
- export * from './noCorsMiddleware/noCorsMiddleware';
4
- export * from './notFoundMiddleware/notFoundMiddleware';
5
- export * from './requestInterceptorMiddleware/requestInterceptorMiddleware';
6
- export * from './destroyerMiddleware/destroyerMiddleware';
7
- export * from './cookieParseMiddleware/cookieParseMiddleware';
@@ -1,23 +0,0 @@
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
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./staticMiddleware/staticMiddleware"), exports);
18
- __exportStar(require("./corsMiddleware/corsMiddleware"), exports);
19
- __exportStar(require("./noCorsMiddleware/noCorsMiddleware"), exports);
20
- __exportStar(require("./notFoundMiddleware/notFoundMiddleware"), exports);
21
- __exportStar(require("./requestInterceptorMiddleware/requestInterceptorMiddleware"), exports);
22
- __exportStar(require("./destroyerMiddleware/destroyerMiddleware"), exports);
23
- __exportStar(require("./cookieParseMiddleware/cookieParseMiddleware"), exports);
@@ -1,2 +0,0 @@
1
- import type { Express } from 'express';
2
- export declare const noCorsMiddleware: (server: Express) => void;
@@ -1,24 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.noCorsMiddleware = void 0;
4
- const constants_1 = require("../../../utils/constants");
5
- const noCorsMiddleware = (server) => {
6
- server.use((request, response, next) => {
7
- response.setHeader('Access-Control-Allow-Origin', constants_1.DEFAULT.CORS.ORIGIN);
8
- response.setHeader('Access-Control-Allow-Credentials', `${constants_1.DEFAULT.CORS.CREDENTIALS}`);
9
- response.setHeader('Access-Control-Expose-Headers', constants_1.DEFAULT.CORS.EXPOSED_HEADERS);
10
- const isPreflightRequest = request.method === 'OPTIONS' &&
11
- request.headers.origin &&
12
- request.headers['access-control-request-method'] &&
13
- request.headers['access-control-request-headers'];
14
- if (isPreflightRequest) {
15
- response.setHeader('Access-Control-Allow-Methods', constants_1.DEFAULT.CORS.METHODS);
16
- response.setHeader('Access-Control-Allow-Headers', constants_1.DEFAULT.CORS.ALLOWED_HEADERS);
17
- response.setHeader('Access-Control-Max-Age', constants_1.DEFAULT.CORS.MAX_AGE);
18
- response.sendStatus(204);
19
- return response.end();
20
- }
21
- return next();
22
- });
23
- };
24
- exports.noCorsMiddleware = noCorsMiddleware;
@@ -1,6 +0,0 @@
1
- interface GetGraphqlUrlSuggestionsParams {
2
- url: URL;
3
- graphqlPatternUrlMeaningfulStrings: string[];
4
- }
5
- export declare const getGraphqlUrlSuggestions: ({ url, graphqlPatternUrlMeaningfulStrings }: GetGraphqlUrlSuggestionsParams) => string[];
6
- export {};
@@ -1,18 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getGraphqlUrlSuggestions = void 0;
4
- const getLevenshteinDistance_1 = require("../getLevenshteinDistance/getLevenshteinDistance");
5
- const getGraphqlUrlSuggestions = ({ url, graphqlPatternUrlMeaningfulStrings }) => {
6
- // ✅ important: operationName is always second word in 'query' query param
7
- const operationName = url.searchParams.get('query')?.split(' ')[1];
8
- const actualUrlMeaningfulString = `${url.pathname}/${operationName}`;
9
- const graphqlUrlSuggestions = graphqlPatternUrlMeaningfulStrings.reduce((acc, patternUrlMeaningfulString) => {
10
- const distance = (0, getLevenshteinDistance_1.getLevenshteinDistance)(actualUrlMeaningfulString, patternUrlMeaningfulString);
11
- const tolerance = Math.floor(patternUrlMeaningfulString.length / 2);
12
- if (distance <= tolerance)
13
- acc.push(patternUrlMeaningfulString);
14
- return acc;
15
- }, []);
16
- return graphqlUrlSuggestions;
17
- };
18
- exports.getGraphqlUrlSuggestions = getGraphqlUrlSuggestions;
@@ -1 +0,0 @@
1
- export declare const getLevenshteinDistance: (a: string, b: string) => number;
@@ -1,80 +0,0 @@
1
- "use strict";
2
- /* eslint-disable */
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.getLevenshteinDistance = void 0;
5
- const min = (d0, d1, d2, bx, ay) => d0 < d1 || d2 < d1 ? (d0 > d2 ? d2 + 1 : d0 + 1) : bx === ay ? d1 : d1 + 1;
6
- const getLevenshteinDistance = (a, b) => {
7
- if (a === b) {
8
- return 0;
9
- }
10
- if (a.length > b.length) {
11
- const tmp = a;
12
- a = b;
13
- b = tmp;
14
- }
15
- let la = a.length;
16
- let lb = b.length;
17
- while (la > 0 && a.charCodeAt(la - 1) === b.charCodeAt(lb - 1)) {
18
- la--;
19
- lb--;
20
- }
21
- let offset = 0;
22
- while (offset < la && a.charCodeAt(offset) === b.charCodeAt(offset)) {
23
- offset++;
24
- }
25
- la -= offset;
26
- lb -= offset;
27
- if (la === 0 || lb < 3) {
28
- return lb;
29
- }
30
- let x = 0;
31
- let y;
32
- let d0;
33
- let d1;
34
- let d2;
35
- let d3;
36
- let dd = 0;
37
- let dy;
38
- let ay;
39
- let bx0;
40
- let bx1;
41
- let bx2;
42
- let bx3;
43
- const vector = [];
44
- for (y = 0; y < la; y++) {
45
- vector.push(y + 1);
46
- vector.push(a.charCodeAt(offset + y));
47
- }
48
- const len = vector.length - 1;
49
- for (; x < lb - 3;) {
50
- bx0 = b.charCodeAt(offset + (d0 = x));
51
- bx1 = b.charCodeAt(offset + (d1 = x + 1));
52
- bx2 = b.charCodeAt(offset + (d2 = x + 2));
53
- bx3 = b.charCodeAt(offset + (d3 = x + 3));
54
- dd = x += 4;
55
- for (y = 0; y < len; y += 2) {
56
- dy = vector[y];
57
- ay = vector[y + 1];
58
- d0 = min(dy, d0, d1, bx0, ay);
59
- d1 = min(d0, d1, d2, bx1, ay);
60
- d2 = min(d1, d2, d3, bx2, ay);
61
- dd = min(d2, d3, dd, bx3, ay);
62
- vector[y] = dd;
63
- d3 = d2;
64
- d2 = d1;
65
- d1 = d0;
66
- d0 = dy;
67
- }
68
- }
69
- for (; x < lb;) {
70
- bx0 = b.charCodeAt(offset + (d0 = x));
71
- dd = ++x;
72
- for (y = 0; y < len; y += 2) {
73
- dy = vector[y];
74
- vector[y] = dd = min(dy, d0, dd, bx0, vector[y + 1]);
75
- d0 = dy;
76
- }
77
- }
78
- return dd;
79
- };
80
- exports.getLevenshteinDistance = getLevenshteinDistance;
@@ -1,6 +0,0 @@
1
- interface GetRestUrlSuggestionsParams {
2
- url: URL;
3
- patternUrls: string[];
4
- }
5
- export declare const getRestUrlSuggestions: ({ url, patternUrls }: GetRestUrlSuggestionsParams) => string[];
6
- export {};
@@ -1,34 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getRestUrlSuggestions = void 0;
4
- const helpers_1 = require("../../../../../utils/helpers");
5
- const getLevenshteinDistance_1 = require("../getLevenshteinDistance/getLevenshteinDistance");
6
- const helpers_2 = require("./helpers");
7
- const getRestUrlSuggestions = ({ url, patternUrls }) => {
8
- const actualUrlParts = (0, helpers_1.getUrlParts)(url.pathname);
9
- const restUrlSuggestions = patternUrls.reduce((acc, patternUrl) => {
10
- const patternUrlParts = (0, helpers_1.getUrlParts)(patternUrl);
11
- // ✅ important: ignore patterns with different amount of parts
12
- if (patternUrlParts.length !== actualUrlParts.length)
13
- return acc;
14
- const actualUrlMeaningfulString = (0, helpers_2.getActualRestUrlMeaningfulString)(actualUrlParts, patternUrlParts);
15
- const patternUrlMeaningfulString = (0, helpers_2.getPatternRestUrlMeaningfulString)(patternUrlParts);
16
- const tolerance = Math.floor(patternUrlMeaningfulString.length / 2);
17
- const distance = (0, getLevenshteinDistance_1.getLevenshteinDistance)(actualUrlMeaningfulString, patternUrlMeaningfulString);
18
- if (distance <= tolerance) {
19
- // replace param names in pattern with param values from actual url
20
- const urlSuggestion = patternUrlParts
21
- .map((_patternUrlPart, index) => {
22
- if (patternUrlParts[index].startsWith(':'))
23
- return actualUrlParts[index];
24
- return patternUrlParts[index];
25
- })
26
- .join('/');
27
- const suggestionWithQueryParams = `/${urlSuggestion}${url.search}`;
28
- acc.push(suggestionWithQueryParams);
29
- }
30
- return acc;
31
- }, []);
32
- return restUrlSuggestions;
33
- };
34
- exports.getRestUrlSuggestions = getRestUrlSuggestions;
@@ -1 +0,0 @@
1
- export declare const getActualRestUrlMeaningfulString: (actualUrlParts: string[], patternUrlParts: string[]) => string;
@@ -1,7 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getActualRestUrlMeaningfulString = void 0;
4
- const getActualRestUrlMeaningfulString = (actualUrlParts, patternUrlParts) => actualUrlParts
5
- .filter((_actualUrlPart, index) => !patternUrlParts[index].startsWith(':'))
6
- .join('');
7
- exports.getActualRestUrlMeaningfulString = getActualRestUrlMeaningfulString;
@@ -1 +0,0 @@
1
- export declare const getPatternRestUrlMeaningfulString: (patternUrlParts: string[]) => string;
@@ -1,5 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getPatternRestUrlMeaningfulString = void 0;
4
- const getPatternRestUrlMeaningfulString = (patternUrlParts) => patternUrlParts.filter((urlPatternPart) => !urlPatternPart.startsWith(':')).join('');
5
- exports.getPatternRestUrlMeaningfulString = getPatternRestUrlMeaningfulString;
@@ -1,2 +0,0 @@
1
- export * from './getActualRestUrlMeaningfulString/getActualRestUrlMeaningfulString';
2
- export * from './getPatternRestUrlMeaningfulString/getPatternRestUrlMeaningfulString';
@@ -1,18 +0,0 @@
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
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./getActualRestUrlMeaningfulString/getActualRestUrlMeaningfulString"), exports);
18
- __exportStar(require("./getPatternRestUrlMeaningfulString/getPatternRestUrlMeaningfulString"), exports);
@@ -1,3 +0,0 @@
1
- export * from './getGraphqlUrlSuggestions/getGraphqlUrlSuggestions';
2
- export * from './getLevenshteinDistance/getLevenshteinDistance';
3
- export * from './getRestUrlSuggestions/getRestUrlSuggestions';
@@ -1,19 +0,0 @@
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
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./getGraphqlUrlSuggestions/getGraphqlUrlSuggestions"), exports);
18
- __exportStar(require("./getLevenshteinDistance/getLevenshteinDistance"), exports);
19
- __exportStar(require("./getRestUrlSuggestions/getRestUrlSuggestions"), exports);
@@ -1,8 +0,0 @@
1
- import type { Express } from 'express';
2
- import type { MockServerConfig } from '../../../utils/types';
3
- interface NotFoundMiddlewareParams {
4
- server: Express;
5
- mockServerConfig: Pick<MockServerConfig, 'baseUrl' | 'rest' | 'graphql'>;
6
- }
7
- export declare const notFoundMiddleware: ({ server, mockServerConfig }: NotFoundMiddlewareParams) => void;
8
- export {};
@@ -1,47 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.notFoundMiddleware = void 0;
4
- const helpers_1 = require("../../../utils/helpers");
5
- const helpers_2 = require("./helpers");
6
- const notFoundMiddleware = ({ server, mockServerConfig }) => {
7
- const { baseUrl: serverBaseUrl, rest, graphql } = mockServerConfig;
8
- const operationNames = graphql?.configs.map(({ operationName }) => operationName) ?? [];
9
- const graphqlPatternUrlMeaningfulStrings = Array.from(operationNames.reduce((acc, operationName) => {
10
- if (typeof operationName === 'string')
11
- acc.add(`${serverBaseUrl ?? ''}${graphql?.baseUrl ?? ''}/${operationName}`);
12
- return acc;
13
- }, new Set()));
14
- const restPaths = rest?.configs.map(({ path }) => path) ?? [];
15
- const patternUrls = Array.from(restPaths.reduce((acc, patternPath) => {
16
- if (typeof patternPath === 'string')
17
- acc.add(`${serverBaseUrl ?? ''}${rest?.baseUrl ?? ''}${patternPath}`);
18
- return acc;
19
- }, new Set()));
20
- server.use((request, response) => {
21
- const url = new URL(`${request.protocol}://${request.get('host')}${request.originalUrl}`);
22
- let graphqlUrlSuggestions = [];
23
- if (graphql) {
24
- const graphqlQuery = (0, helpers_1.parseGraphQLRequest)(request);
25
- if (graphqlQuery) {
26
- graphqlUrlSuggestions = (0, helpers_2.getGraphqlUrlSuggestions)({
27
- url,
28
- graphqlPatternUrlMeaningfulStrings
29
- });
30
- }
31
- }
32
- let restUrlSuggestions = [];
33
- if (rest) {
34
- restUrlSuggestions = (0, helpers_2.getRestUrlSuggestions)({
35
- url,
36
- patternUrls
37
- });
38
- }
39
- response.status(404).render('notFound', {
40
- requestMethod: request.method,
41
- url: `${url.pathname}${url.search}`,
42
- restUrlSuggestions,
43
- graphqlUrlSuggestions
44
- });
45
- });
46
- };
47
- exports.notFoundMiddleware = notFoundMiddleware;
@@ -1,3 +0,0 @@
1
- import type { Express } from 'express';
2
- import type { RequestInterceptor } from '../../../utils/types';
3
- export declare const requestInterceptorMiddleware: (server: Express, interceptor: RequestInterceptor) => void;
@@ -1,11 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.requestInterceptorMiddleware = void 0;
4
- const helpers_1 = require("../../../utils/helpers");
5
- const requestInterceptorMiddleware = (server, interceptor) => {
6
- server.use(async (request, _response, next) => {
7
- await (0, helpers_1.callRequestInterceptor)({ request, interceptor });
8
- return next();
9
- });
10
- };
11
- exports.requestInterceptorMiddleware = requestInterceptorMiddleware;
@@ -1,3 +0,0 @@
1
- import type { Express } from 'express';
2
- import type { BaseUrl, StaticPath } from '../../../utils/types';
3
- export declare const staticMiddleware: (server: Express, baseUrl: BaseUrl, staticPath: StaticPath) => void;
@@ -1,30 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.staticMiddleware = void 0;
7
- const express_1 = __importDefault(require("express"));
8
- const constants_1 = require("../../../utils/constants");
9
- const helpers_1 = require("../../../utils/helpers");
10
- const staticMiddleware = (server, baseUrl, staticPath) => {
11
- const isStaticPathArray = Array.isArray(staticPath);
12
- if (isStaticPathArray) {
13
- staticPath.forEach((staticPath) => {
14
- const isPathObject = typeof staticPath === 'object';
15
- if (isPathObject) {
16
- server.use((0, helpers_1.urlJoin)(baseUrl, staticPath.prefix), express_1.default.static((0, helpers_1.urlJoin)(constants_1.APP_PATH, staticPath.path)));
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)));
26
- return;
27
- }
28
- server.use(baseUrl, express_1.default.static((0, helpers_1.urlJoin)(constants_1.APP_PATH, staticPath)));
29
- };
30
- exports.staticMiddleware = staticMiddleware;
@@ -1,3 +0,0 @@
1
- import type { IRouter } from 'express';
2
- import type { Interceptors, RestConfig } from '../../../utils/types';
3
- export declare const createRestRoutes: (router: IRouter, restConfig: RestConfig, serverResponseInterceptors?: Interceptors['response']) => IRouter;
@@ -1,44 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createRestRoutes = void 0;
4
- const helpers_1 = require("../../../utils/helpers");
5
- const helpers_2 = require("./helpers");
6
- const createRestRoutes = (router, restConfig, serverResponseInterceptors) => {
7
- (0, helpers_2.prepareRestRequestConfigs)(restConfig.configs).forEach((requestConfig) => {
8
- router.route(requestConfig.path)[requestConfig.method](async (request, response, next) => {
9
- const requestInterceptor = requestConfig.interceptors?.request;
10
- if (requestInterceptor) {
11
- await (0, helpers_1.callRequestInterceptor)({ request, interceptor: requestInterceptor });
12
- }
13
- const matchedRouteConfig = requestConfig.routes.find(({ entities }) => {
14
- if (!entities)
15
- return true;
16
- return Object.entries(entities).every(([entity, entityValue]) => (0, helpers_1.isEntityValuesEqual)(entityValue, request[entity]));
17
- });
18
- if (!matchedRouteConfig) {
19
- return next();
20
- }
21
- const matchedRouteConfigData = typeof matchedRouteConfig.data === 'function'
22
- ? await matchedRouteConfig.data(request, matchedRouteConfig.entities ?? {})
23
- : matchedRouteConfig.data;
24
- const data = await (0, helpers_1.callResponseInterceptors)({
25
- data: matchedRouteConfigData,
26
- request,
27
- response,
28
- interceptors: {
29
- routeInterceptor: matchedRouteConfig.interceptors?.response,
30
- requestInterceptor: requestConfig.interceptors?.response,
31
- apiInterceptor: restConfig.interceptors?.response,
32
- serverInterceptor: serverResponseInterceptors
33
- }
34
- });
35
- // ✅ important:
36
- // set 'Cache-Control' header for explicit browsers response revalidate
37
- // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control
38
- response.set('Cache-control', 'max-age=0, must-revalidate');
39
- return response.status(response.statusCode).json(data);
40
- });
41
- });
42
- return router;
43
- };
44
- exports.createRestRoutes = createRestRoutes;
@@ -1 +0,0 @@
1
- export * from './prepareRestRequestConfigs/prepareRestRequestConfigs';
@@ -1,17 +0,0 @@
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
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./prepareRestRequestConfigs/prepareRestRequestConfigs"), exports);
@@ -1,2 +0,0 @@
1
- import type { RestRequestConfig } from '../../../../../utils/types';
2
- export declare const prepareRestRequestConfigs: (requestConfigs: RestRequestConfig[]) => RestRequestConfig[];