@n1k1t/mock-server 0.3.0 → 1.0.1
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/README.md +590 -1006
- package/README.old.md +1255 -0
- package/lib/package.json +15 -6
- package/lib/src/client/helpers/expectations.d.ts +15 -45
- package/lib/src/client/helpers/expectations.d.ts.map +1 -1
- package/lib/src/client/helpers/expectations.js.map +1 -1
- package/lib/src/client/methods/expectations-group.update.method.js +1 -1
- package/lib/src/client/methods/expectations-group.update.method.js.map +1 -1
- package/lib/src/client/methods/expectations.create.method.js +1 -1
- package/lib/src/client/methods/expectations.create.method.js.map +1 -1
- package/lib/src/client/methods/expectations.delete.method.js +1 -1
- package/lib/src/client/methods/expectations.delete.method.js.map +1 -1
- package/lib/src/client/methods/expectations.update.method.js +1 -1
- package/lib/src/client/methods/expectations.update.method.js.map +1 -1
- package/lib/src/client/methods/ping.method.js +1 -1
- package/lib/src/client/methods/ping.method.js.map +1 -1
- package/lib/src/client/methods/providers.create.method.js +1 -1
- package/lib/src/client/methods/providers.create.method.js.map +1 -1
- package/lib/src/client/methods/providers.delete.method.js +1 -1
- package/lib/src/client/methods/providers.delete.method.js.map +1 -1
- package/lib/src/client/models/client.d.ts +4 -4
- package/lib/src/client/models/client.d.ts.map +1 -1
- package/lib/src/client/models/client.js +6 -3
- package/lib/src/client/models/client.js.map +1 -1
- package/lib/src/client/models/types.d.ts +3 -0
- package/lib/src/client/models/types.d.ts.map +1 -1
- package/lib/src/client/models/types.js.map +1 -1
- package/lib/src/client/types.d.ts +1 -1
- package/lib/src/client/types.d.ts.map +1 -1
- package/lib/src/client/utils.d.ts +1 -1
- package/lib/src/client/utils.d.ts.map +1 -1
- package/lib/src/client/utils.js.map +1 -1
- package/lib/src/config/index.d.ts +1 -1
- package/lib/src/config/index.js +1 -1
- package/lib/src/config/index.js.map +1 -1
- package/lib/src/expectations/__utils__/index.d.ts.map +1 -1
- package/lib/src/expectations/__utils__/index.js +0 -1
- package/lib/src/expectations/__utils__/index.js.map +1 -1
- package/lib/src/expectations/models/expectation.d.ts +1 -1
- package/lib/src/expectations/models/expectation.d.ts.map +1 -1
- package/lib/src/expectations/models/expectation.js.map +1 -1
- package/lib/src/expectations/models/storage.d.ts +5 -5
- package/lib/src/expectations/models/storage.d.ts.map +1 -1
- package/lib/src/expectations/models/storage.js.map +1 -1
- package/lib/src/expectations/types.d.ts +18 -15
- package/lib/src/expectations/types.d.ts.map +1 -1
- package/lib/src/expectations/types.js +0 -1
- package/lib/src/expectations/types.js.map +1 -1
- package/lib/src/expectations/utils/location.d.ts.map +1 -1
- package/lib/src/expectations/utils/location.js +0 -6
- package/lib/src/expectations/utils/location.js.map +1 -1
- package/lib/src/server/endpoints/cache.backup.endpoint.js +1 -1
- package/lib/src/server/endpoints/cache.backup.endpoint.js.map +1 -1
- package/lib/src/server/endpoints/cache.delete.endpoint.js +1 -1
- package/lib/src/server/endpoints/cache.delete.endpoint.js.map +1 -1
- package/lib/src/server/endpoints/cache.restore.endpoint.d.ts.map +1 -1
- package/lib/src/server/endpoints/cache.restore.endpoint.js +8 -3
- package/lib/src/server/endpoints/cache.restore.endpoint.js.map +1 -1
- package/lib/src/server/endpoints/cache.restore.stream.endpoint.js +1 -1
- package/lib/src/server/endpoints/cache.restore.stream.endpoint.js.map +1 -1
- package/lib/src/server/endpoints/cache.usage.get.endpoint.js +1 -1
- package/lib/src/server/endpoints/cache.usage.get.endpoint.js.map +1 -1
- package/lib/src/server/endpoints/config.get.endpoint.d.ts +1 -1
- package/lib/src/server/endpoints/expectations.get-by-id.endpoint.js +1 -1
- package/lib/src/server/endpoints/expectations.get-by-id.endpoint.js.map +1 -1
- package/lib/src/server/endpoints/expectations.update.endpoint.d.ts +1 -1
- package/lib/src/server/endpoints/expectations.update.endpoint.d.ts.map +1 -1
- package/lib/src/server/endpoints/gui.endpoint.js +2 -2
- package/lib/src/server/endpoints/gui.endpoint.js.map +1 -1
- package/lib/src/server/endpoints/history.compact.get-list.endpoint.d.ts +2 -2
- package/lib/src/server/endpoints/history.get-by-id.endpoint.d.ts +1 -1
- package/lib/src/server/endpoints/history.get-by-id.endpoint.js +1 -1
- package/lib/src/server/endpoints/history.get-by-id.endpoint.js.map +1 -1
- package/lib/src/server/index.d.ts +2 -5
- package/lib/src/server/index.d.ts.map +1 -1
- package/lib/src/server/index.js +10 -9
- package/lib/src/server/index.js.map +1 -1
- package/lib/src/server/models/context/index.d.ts +6 -6
- package/lib/src/server/models/context/index.d.ts.map +1 -1
- package/lib/src/server/models/context/index.js +0 -4
- package/lib/src/server/models/context/index.js.map +1 -1
- package/lib/src/server/models/context/snapshot.d.ts +2 -3
- package/lib/src/server/models/context/snapshot.d.ts.map +1 -1
- package/lib/src/server/models/context/snapshot.js +6 -6
- package/lib/src/server/models/context/snapshot.js.map +1 -1
- package/lib/src/server/models/context/types.d.ts +10 -9
- package/lib/src/server/models/context/types.d.ts.map +1 -1
- package/lib/src/server/models/context/utils.d.ts.map +1 -1
- package/lib/src/server/models/context/utils.js +2 -6
- package/lib/src/server/models/context/utils.js.map +1 -1
- package/lib/src/server/models/endpoint.d.ts +2 -2
- package/lib/src/server/models/endpoint.d.ts.map +1 -1
- package/lib/src/server/models/executor/index.d.ts +2 -2
- package/lib/src/server/models/executor/index.d.ts.map +1 -1
- package/lib/src/server/models/executor/index.js +38 -6
- package/lib/src/server/models/executor/index.js.map +1 -1
- package/lib/src/server/models/history/model.d.ts +4 -6
- package/lib/src/server/models/history/model.d.ts.map +1 -1
- package/lib/src/server/models/history/model.js +2 -7
- package/lib/src/server/models/history/model.js.map +1 -1
- package/lib/src/server/models/index.d.ts +2 -0
- package/lib/src/server/models/index.d.ts.map +1 -1
- package/lib/src/server/models/index.js +2 -0
- package/lib/src/server/models/index.js.map +1 -1
- package/lib/src/server/models/message.d.ts +16 -0
- package/lib/src/server/models/message.d.ts.map +1 -0
- package/lib/src/server/models/message.js +53 -0
- package/lib/src/server/models/message.js.map +1 -0
- package/lib/src/server/models/providers/model.d.ts +2 -2
- package/lib/src/server/models/providers/model.d.ts.map +1 -1
- package/lib/src/server/models/providers/storage.js +1 -1
- package/lib/src/server/models/providers/storage.js.map +1 -1
- package/lib/src/server/models/providers/system.d.ts.map +1 -1
- package/lib/src/server/models/providers/system.js +0 -1
- package/lib/src/server/models/providers/system.js.map +1 -1
- package/lib/src/server/models/router.js +1 -1
- package/lib/src/server/models/router.js.map +1 -1
- package/lib/src/server/models/transports/storage.js +1 -1
- package/lib/src/server/models/transports/storage.js.map +1 -1
- package/lib/src/server/models/websocket/errors/index.d.ts +2 -0
- package/lib/src/server/models/websocket/errors/index.d.ts.map +1 -0
- package/lib/src/server/models/websocket/errors/index.js +18 -0
- package/lib/src/server/models/websocket/errors/index.js.map +1 -0
- package/lib/src/server/models/websocket/errors/websocket-connection.error.d.ts +9 -0
- package/lib/src/server/models/websocket/errors/websocket-connection.error.d.ts.map +1 -0
- package/lib/src/server/models/websocket/errors/websocket-connection.error.js +32 -0
- package/lib/src/server/models/websocket/errors/websocket-connection.error.js.map +1 -0
- package/lib/src/server/models/websocket/factory.d.ts +9 -0
- package/lib/src/server/models/websocket/factory.d.ts.map +1 -0
- package/lib/src/server/models/websocket/factory.js +23 -0
- package/lib/src/server/models/websocket/factory.js.map +1 -0
- package/lib/src/server/models/websocket/index.d.ts +5 -0
- package/lib/src/server/models/websocket/index.d.ts.map +1 -0
- package/lib/src/server/models/websocket/index.js +21 -0
- package/lib/src/server/models/websocket/index.js.map +1 -0
- package/lib/src/server/models/websocket/model.d.ts +29 -0
- package/lib/src/server/models/websocket/model.d.ts.map +1 -0
- package/lib/src/server/models/websocket/model.js +164 -0
- package/lib/src/server/models/websocket/model.js.map +1 -0
- package/lib/src/server/models/websocket/types.d.ts +11 -0
- package/lib/src/server/models/websocket/types.d.ts.map +1 -0
- package/lib/src/server/models/websocket/types.js +3 -0
- package/lib/src/server/models/websocket/types.js.map +1 -0
- package/lib/src/server/transports/http.transport/context.d.ts +1 -1
- package/lib/src/server/transports/http.transport/context.d.ts.map +1 -1
- package/lib/src/server/transports/http.transport/context.js +10 -3
- package/lib/src/server/transports/http.transport/context.js.map +1 -1
- package/lib/src/server/transports/http.transport/executor.d.ts +3 -13
- package/lib/src/server/transports/http.transport/executor.d.ts.map +1 -1
- package/lib/src/server/transports/http.transport/executor.js +7 -6
- package/lib/src/server/transports/http.transport/executor.js.map +1 -1
- package/lib/src/server/transports/http.transport/index.d.ts +1 -1
- package/lib/src/server/transports/http.transport/index.d.ts.map +1 -1
- package/lib/src/server/transports/http.transport/index.js +2 -3
- package/lib/src/server/transports/http.transport/index.js.map +1 -1
- package/lib/src/server/transports/index.d.ts +1 -1
- package/lib/src/server/transports/index.d.ts.map +1 -1
- package/lib/src/server/transports/index.js +1 -1
- package/lib/src/server/transports/index.js.map +1 -1
- package/lib/src/server/transports/{internal → system}/http.transport/context.d.ts +6 -6
- package/lib/src/server/transports/system/http.transport/context.d.ts.map +1 -0
- package/lib/src/server/transports/{internal → system}/http.transport/context.js +7 -7
- package/lib/src/server/transports/system/http.transport/context.js.map +1 -0
- package/lib/src/server/transports/system/http.transport/executor.d.ts +21 -0
- package/lib/src/server/transports/system/http.transport/executor.d.ts.map +1 -0
- package/lib/src/server/transports/{internal → system}/http.transport/executor.js +5 -5
- package/lib/src/server/transports/system/http.transport/executor.js.map +1 -0
- package/lib/src/server/transports/{internal → system}/http.transport/index.d.ts +5 -5
- package/lib/src/server/transports/system/http.transport/index.d.ts.map +1 -0
- package/lib/src/server/transports/{internal → system}/http.transport/index.js +5 -5
- package/lib/src/server/transports/system/http.transport/index.js.map +1 -0
- package/lib/src/server/transports/system/http.transport/reply.d.ts +10 -0
- package/lib/src/server/transports/system/http.transport/reply.d.ts.map +1 -0
- package/lib/src/server/transports/{internal → system}/http.transport/reply.js +4 -4
- package/lib/src/server/transports/system/http.transport/reply.js.map +1 -0
- package/lib/src/server/transports/system/index.d.ts.map +1 -0
- package/lib/src/server/transports/system/index.js.map +1 -0
- package/lib/src/server/transports/{internal → system}/io.transport/context.d.ts +6 -6
- package/lib/src/server/transports/system/io.transport/context.d.ts.map +1 -0
- package/lib/src/server/transports/{internal → system}/io.transport/context.js +6 -6
- package/lib/src/server/transports/system/io.transport/context.js.map +1 -0
- package/lib/src/server/transports/{internal → system}/io.transport/executor.d.ts +3 -3
- package/lib/src/server/transports/system/io.transport/executor.d.ts.map +1 -0
- package/lib/src/server/transports/{internal → system}/io.transport/executor.js +3 -3
- package/lib/src/server/transports/system/io.transport/executor.js.map +1 -0
- package/lib/src/server/transports/system/io.transport/index.d.ts +14 -0
- package/lib/src/server/transports/system/io.transport/index.d.ts.map +1 -0
- package/lib/src/server/transports/{internal → system}/io.transport/index.js +5 -5
- package/lib/src/server/transports/system/io.transport/index.js.map +1 -0
- package/lib/src/server/transports/system/io.transport/reply.d.ts +10 -0
- package/lib/src/server/transports/system/io.transport/reply.d.ts.map +1 -0
- package/lib/src/server/transports/{internal → system}/io.transport/reply.js +4 -4
- package/lib/src/server/transports/system/io.transport/reply.js.map +1 -0
- package/lib/src/server/transports/system/utils.d.ts.map +1 -0
- package/lib/src/server/transports/system/utils.js.map +1 -0
- package/lib/src/server/transports/ws.transport/context.d.ts +13 -12
- package/lib/src/server/transports/ws.transport/context.d.ts.map +1 -1
- package/lib/src/server/transports/ws.transport/context.js +20 -28
- package/lib/src/server/transports/ws.transport/context.js.map +1 -1
- package/lib/src/server/transports/ws.transport/executor.d.ts +7 -5
- package/lib/src/server/transports/ws.transport/executor.d.ts.map +1 -1
- package/lib/src/server/transports/ws.transport/executor.js +77 -25
- package/lib/src/server/transports/ws.transport/executor.js.map +1 -1
- package/lib/src/server/transports/ws.transport/index.d.ts +3 -3
- package/lib/src/server/transports/ws.transport/index.d.ts.map +1 -1
- package/lib/src/server/transports/ws.transport/index.js +29 -54
- package/lib/src/server/transports/ws.transport/index.js.map +1 -1
- package/lib/src/server/types/index.d.ts +2 -4
- package/lib/src/server/types/index.d.ts.map +1 -1
- package/lib/src/utils/common.d.ts +6 -3
- package/lib/src/utils/common.d.ts.map +1 -1
- package/lib/src/utils/common.js +22 -11
- package/lib/src/utils/common.js.map +1 -1
- package/package.json +15 -6
- package/public/assets/{index-DoUtVarD.js → index-DoLXR0S_.js} +6 -1
- package/public/index.html +1 -1
- package/lib/bin/index.d.ts +0 -3
- package/lib/bin/index.d.ts.map +0 -1
- package/lib/bin/index.js +0 -32
- package/lib/bin/index.js.map +0 -1
- package/lib/src/server/transports/internal/http.transport/context.d.ts.map +0 -1
- package/lib/src/server/transports/internal/http.transport/context.js.map +0 -1
- package/lib/src/server/transports/internal/http.transport/executor.d.ts +0 -21
- package/lib/src/server/transports/internal/http.transport/executor.d.ts.map +0 -1
- package/lib/src/server/transports/internal/http.transport/executor.js.map +0 -1
- package/lib/src/server/transports/internal/http.transport/index.d.ts.map +0 -1
- package/lib/src/server/transports/internal/http.transport/index.js.map +0 -1
- package/lib/src/server/transports/internal/http.transport/reply.d.ts +0 -10
- package/lib/src/server/transports/internal/http.transport/reply.d.ts.map +0 -1
- package/lib/src/server/transports/internal/http.transport/reply.js.map +0 -1
- package/lib/src/server/transports/internal/index.d.ts.map +0 -1
- package/lib/src/server/transports/internal/index.js.map +0 -1
- package/lib/src/server/transports/internal/io.transport/context.d.ts.map +0 -1
- package/lib/src/server/transports/internal/io.transport/context.js.map +0 -1
- package/lib/src/server/transports/internal/io.transport/executor.d.ts.map +0 -1
- package/lib/src/server/transports/internal/io.transport/executor.js.map +0 -1
- package/lib/src/server/transports/internal/io.transport/index.d.ts +0 -14
- package/lib/src/server/transports/internal/io.transport/index.d.ts.map +0 -1
- package/lib/src/server/transports/internal/io.transport/index.js.map +0 -1
- package/lib/src/server/transports/internal/io.transport/reply.d.ts +0 -10
- package/lib/src/server/transports/internal/io.transport/reply.d.ts.map +0 -1
- package/lib/src/server/transports/internal/io.transport/reply.js.map +0 -1
- package/lib/src/server/transports/internal/utils.d.ts.map +0 -1
- package/lib/src/server/transports/internal/utils.js.map +0 -1
- /package/lib/src/server/transports/{internal → system}/index.d.ts +0 -0
- /package/lib/src/server/transports/{internal → system}/index.js +0 -0
- /package/lib/src/server/transports/{internal → system}/utils.d.ts +0 -0
- /package/lib/src/server/transports/{internal → system}/utils.js +0 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ParsedUrlQueryInput } from 'querystring';
|
|
2
|
+
import type { ClientOptions } from 'ws';
|
|
3
|
+
export interface IWebSocketConfiguration extends ClientOptions {
|
|
4
|
+
baseURL?: string;
|
|
5
|
+
url?: string;
|
|
6
|
+
signal?: AbortSignal;
|
|
7
|
+
query?: ParsedUrlQueryInput;
|
|
8
|
+
/** Milliseconds */
|
|
9
|
+
timeout?: number;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/server/models/websocket/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AACvD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAExC,MAAM,WAAW,uBAAwB,SAAQ,aAAa;IAC5D,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,KAAK,CAAC,EAAE,mBAAmB,CAAC;IAE5B,mBAAmB;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/server/models/websocket/types.ts"],"names":[],"mappings":""}
|
|
@@ -2,7 +2,7 @@ import { IncomingMessage, ServerResponse } from 'http';
|
|
|
2
2
|
import { IRequestContextIncoming, Provider, RequestContext, RequestContextSnapshot } from '../../models';
|
|
3
3
|
export declare class HttpRequestContext extends RequestContext<{
|
|
4
4
|
transport: 'http';
|
|
5
|
-
event:
|
|
5
|
+
event: string & {};
|
|
6
6
|
flag: string & {};
|
|
7
7
|
}> {
|
|
8
8
|
provider: Provider;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AAMvD,OAAO,EAEL,uBAAuB,EACvB,QAAQ,EACR,cAAc,EACd,sBAAsB,EACvB,MAAM,cAAc,CAAC;AAItB,qBAAa,kBAAmB,SAAQ,cAAc,CAAC;IACrD,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC;IACnB,IAAI,EAAE,MAAM,GAAG,EAAE,CAAC;CACnB,CAAC;IASS,QAAQ,EAAE,QAAQ;IAClB,QAAQ,EAAE,uBAAuB;IACjC,OAAO,EAAE,eAAe;IACxB,QAAQ,EAAE,cAAc;IAX1B,QAAQ,8BAA0B;IAClC,OAAO,iCAAyB;IAEhC,IAAI,sCAER;gBAGM,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,uBAAuB,EACjC,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,cAAc;IAK1B,MAAM,IAAI,IAAI;IAKd,QAAQ,IAAI,IAAI;IAShB,eAAe,IAAI,sBAAsB;WAwBnC,KAAK,CAChB,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,cAAc,GACvB,OAAO,CAAC,kBAAkB,CAAC;CAI/B"}
|
|
@@ -5,13 +5,14 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.HttpRequestContext = void 0;
|
|
7
7
|
const lodash_1 = __importDefault(require("lodash"));
|
|
8
|
+
const utils_1 = require("../../../utils");
|
|
8
9
|
const meta_1 = require("../../../meta");
|
|
9
10
|
const logger_1 = require("../../../logger");
|
|
10
11
|
const models_1 = require("../../models");
|
|
11
|
-
const logger = logger_1.Logger.build('
|
|
12
|
+
const logger = logger_1.Logger.build('Transports.Http.Context');
|
|
12
13
|
class HttpRequestContext extends models_1.RequestContext {
|
|
13
14
|
constructor(provider, incoming, request, response) {
|
|
14
|
-
super(provider, { transport: 'http'
|
|
15
|
+
super(provider, { transport: 'http' });
|
|
15
16
|
this.provider = provider;
|
|
16
17
|
this.incoming = incoming;
|
|
17
18
|
this.request = request;
|
|
@@ -32,6 +33,12 @@ class HttpRequestContext extends models_1.RequestContext {
|
|
|
32
33
|
}
|
|
33
34
|
compileSnapshot() {
|
|
34
35
|
const snapshot = super.compileSnapshot();
|
|
36
|
+
const state = this.incoming.headers['x-use-mock-state']
|
|
37
|
+
? (0, utils_1.parseJsonSafe)(Buffer.from(String(this.incoming.headers['x-use-mock-state']), 'base64').toString())
|
|
38
|
+
: null;
|
|
39
|
+
if (state?.status === 'ERROR') {
|
|
40
|
+
logger.error('Got error while parsing [x-use-mock-state] header', state.error?.stack ?? state.error);
|
|
41
|
+
}
|
|
35
42
|
snapshot.outgoing.status = 200;
|
|
36
43
|
snapshot.incoming.headers = lodash_1.default.omit(snapshot.incoming.headers, ['transfer-encoding']);
|
|
37
44
|
return snapshot.assign({
|
|
@@ -39,7 +46,7 @@ class HttpRequestContext extends models_1.RequestContext {
|
|
|
39
46
|
seed: Number(this.incoming.headers['x-use-mock-seed']),
|
|
40
47
|
}),
|
|
41
48
|
...(this.incoming.headers['x-use-mock-state'] && {
|
|
42
|
-
state:
|
|
49
|
+
state: state?.result ?? {},
|
|
43
50
|
}),
|
|
44
51
|
});
|
|
45
52
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/context.ts"],"names":[],"mappings":";;;;;;AACA,oDAAuB;AAEvB,wCAA4C;AAC5C,4CAAyC;AACzC,yCAMsB;AAEtB,MAAM,MAAM,GAAG,eAAM,CAAC,KAAK,CAAC,
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/context.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,21 +1,11 @@
|
|
|
1
1
|
import { AxiosRequestConfig } from 'axios';
|
|
2
2
|
import type { Expectation, IExpectationSchemaForward } from '../../../expectations';
|
|
3
3
|
import type { HttpRequestContext } from './context';
|
|
4
|
-
import { Executor, IRequestContextOutgoing, IRequestContextIncoming, IExecutorExecOptions } from '../../models';
|
|
4
|
+
import { Executor, IRequestContextOutgoing, IRequestContextIncoming, IExecutorExecOptions, IRequestContextForwarded } from '../../models';
|
|
5
5
|
export declare class HttpExecutor extends Executor<HttpRequestContext> {
|
|
6
6
|
exec(context: HttpRequestContext, options?: IExecutorExecOptions): Promise<HttpRequestContext>;
|
|
7
|
-
match(context: HttpRequestContext): Promise<Expectation
|
|
8
|
-
forward(context: HttpRequestContext, incoming: IRequestContextIncoming, schema: IExpectationSchemaForward): Promise<
|
|
9
|
-
schema: IExpectationSchemaForward;
|
|
10
|
-
incoming: IRequestContextIncoming;
|
|
11
|
-
outgoing: {
|
|
12
|
-
type: import("../..").TRequestPayloadType;
|
|
13
|
-
status: number;
|
|
14
|
-
headers: import("axios").AxiosResponseHeaders;
|
|
15
|
-
data: object | undefined;
|
|
16
|
-
dataRaw: Buffer<ArrayBufferLike>;
|
|
17
|
-
};
|
|
18
|
-
}>;
|
|
7
|
+
match(context: HttpRequestContext): Promise<Expectation | null>;
|
|
8
|
+
forward(context: HttpRequestContext, incoming: IRequestContextIncoming, schema: IExpectationSchemaForward): Promise<IRequestContextForwarded>;
|
|
19
9
|
reply(context: HttpRequestContext, outgoing: IRequestContextOutgoing): Promise<IRequestContextOutgoing>;
|
|
20
10
|
/** Compiles Axios request configuration to forward */
|
|
21
11
|
protected compileForwardingConfiguration(context: HttpRequestContext, incoming: IRequestContextIncoming, schema: IExpectationSchemaForward): Promise<AxiosRequestConfig>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/executor.ts"],"names":[],"mappings":"AAAA,OAAc,EAAc,kBAAkB,EAAiB,MAAM,OAAO,CAAC;AAM7E,OAAO,KAAK,EAAE,WAAW,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AACpF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/executor.ts"],"names":[],"mappings":"AAAA,OAAc,EAAc,kBAAkB,EAAiB,MAAM,OAAO,CAAC;AAM7E,OAAO,KAAK,EAAE,WAAW,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AACpF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAIpD,OAAO,EAGL,QAAQ,EAER,uBAAuB,EACvB,uBAAuB,EACvB,oBAAoB,EACpB,wBAAwB,EACzB,MAAM,cAAc,CAAC;AAItB,qBAAa,YAAa,SAAQ,QAAQ,CAAC,kBAAkB,CAAC;IAC/C,IAAI,CAAC,OAAO,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,oBAAoB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAY9F,KAAK,CAAC,OAAO,EAAE,kBAAkB,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IAoB/D,OAAO,CAClB,OAAO,EAAE,kBAAkB,EAC3B,QAAQ,EAAE,uBAAuB,EACjC,MAAM,EAAE,yBAAyB,GAChC,OAAO,CAAC,wBAAwB,CAAC;IAqDvB,KAAK,CAChB,OAAO,EAAE,kBAAkB,EAC3B,QAAQ,EAAE,uBAAuB,GAChC,OAAO,CAAC,uBAAuB,CAAC;IAuBnC,sDAAsD;cACtC,8BAA8B,CAC5C,OAAO,EAAE,kBAAkB,EAC3B,QAAQ,EAAE,uBAAuB,EACjC,MAAM,EAAE,yBAAyB,GAChC,OAAO,CAAC,kBAAkB,CAAC;CA8B/B"}
|
|
@@ -8,9 +8,10 @@ const axios_1 = __importDefault(require("axios"));
|
|
|
8
8
|
const lodash_1 = __importDefault(require("lodash"));
|
|
9
9
|
const https_proxy_agent_1 = require("https-proxy-agent");
|
|
10
10
|
const http_encoding_1 = require("http-encoding");
|
|
11
|
+
const utils_1 = require("../../../utils");
|
|
11
12
|
const logger_1 = require("../../../logger");
|
|
12
13
|
const models_1 = require("../../models");
|
|
13
|
-
const logger = logger_1.Logger.build('
|
|
14
|
+
const logger = logger_1.Logger.build('Transports.Http.Executor');
|
|
14
15
|
class HttpExecutor extends models_1.Executor {
|
|
15
16
|
async exec(context, options) {
|
|
16
17
|
await super.exec(context, options).catch((error) => {
|
|
@@ -37,7 +38,7 @@ class HttpExecutor extends models_1.Executor {
|
|
|
37
38
|
return expectation;
|
|
38
39
|
}
|
|
39
40
|
async forward(context, incoming, schema) {
|
|
40
|
-
const
|
|
41
|
+
const configuration = await this
|
|
41
42
|
.compileForwardingConfiguration(context, incoming, schema)
|
|
42
43
|
.catch((error) => {
|
|
43
44
|
context.snapshot.assign({
|
|
@@ -48,7 +49,7 @@ class HttpExecutor extends models_1.Executor {
|
|
|
48
49
|
throw error;
|
|
49
50
|
});
|
|
50
51
|
const response = await axios_1.default
|
|
51
|
-
.request(
|
|
52
|
+
.request(configuration)
|
|
52
53
|
.catch(async (error) => {
|
|
53
54
|
if (!error.response) {
|
|
54
55
|
context.snapshot.assign({
|
|
@@ -70,7 +71,7 @@ class HttpExecutor extends models_1.Executor {
|
|
|
70
71
|
schema,
|
|
71
72
|
incoming,
|
|
72
73
|
outgoing: {
|
|
73
|
-
type
|
|
74
|
+
type,
|
|
74
75
|
status: response.status,
|
|
75
76
|
headers: response.headers,
|
|
76
77
|
data,
|
|
@@ -99,11 +100,11 @@ class HttpExecutor extends models_1.Executor {
|
|
|
99
100
|
return {
|
|
100
101
|
timeout: schema.timeout ?? 30000,
|
|
101
102
|
method: incoming.method,
|
|
102
|
-
headers: Object.assign(incoming.headers, {
|
|
103
|
+
headers: (0, utils_1.formatHeaders)(Object.assign(incoming.headers, {
|
|
103
104
|
connection: 'close',
|
|
104
105
|
...(schema.options?.overrideHost !== false && { host: url.host }),
|
|
105
106
|
...(incoming.dataRaw && { 'content-length': String(incoming.dataRaw.length) }),
|
|
106
|
-
}),
|
|
107
|
+
})),
|
|
107
108
|
...(schema.url && { url: schema.url }),
|
|
108
109
|
...(schema.baseUrl && { baseURL: schema.baseUrl, url: incoming.path }),
|
|
109
110
|
data: incoming.dataRaw,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"executor.js","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/executor.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA6E;AAC7E,oDAAuB;AAEvB,yDAAoD;AACpD,iDAA6C;AAK7C,4CAAyC;AACzC,
|
|
1
|
+
{"version":3,"file":"executor.js","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/executor.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA6E;AAC7E,oDAAuB;AAEvB,yDAAoD;AACpD,iDAA6C;AAK7C,0CAA+C;AAC/C,4CAAyC;AACzC,yCASsB;AAEtB,MAAM,MAAM,GAAG,eAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;AAExD,MAAa,YAAa,SAAQ,iBAA4B;IACrD,KAAK,CAAC,IAAI,CAAC,OAA2B,EAAE,OAA8B;QAC3E,MAAM,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;YACjD,IAAI,KAAK,YAAY,4BAAmB,IAAI,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC;gBACrE,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YAC1C,CAAC;YAED,MAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,CAAC,CAAC;QAC9E,CAAC,CAAC,CAAC;QAEH,OAAO,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,OAA2B;QAC5C,MAAM,WAAW,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAEzF,IAAI,CAAC,WAAW,IAAI,OAAO,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC;YAC7C,OAAO,CAAC,MAAM,CAAC;gBACb,QAAQ,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;oBAClC,IAAI,EAAE,OAAO;oBACb,MAAM,EAAE,GAAG;oBAEX,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC;oBACjD,OAAO,EAAE,EAAE;iBACZ,CAAC;aACH,CAAC,CAAC;YAEH,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,WAAW,CAAC;IACrB,CAAC;IAEM,KAAK,CAAC,OAAO,CAClB,OAA2B,EAC3B,QAAiC,EACjC,MAAiC;QAEjC,MAAM,aAAa,GAAG,MAAM,IAAI;aAC7B,8BAA8B,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC;aACzD,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;YACf,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;gBACtB,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,IAAI,SAAS,EAAE;gBAChE,QAAQ,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE,EAAE;aACtD,CAAC,CAAC;YAEH,MAAM,CAAC,KAAK,CAAC,mEAAmE,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,CAAC,CAAC;YACzG,MAAM,KAAK,CAAC;QACd,CAAC,CAAC,CAAC;QAEL,MAAM,QAAQ,GAAG,MAAM,eAAK;aACzB,OAAO,CAAS,aAAa,CAAC;aAC9B,KAAK,CAAC,KAAK,EAAE,KAAyB,EAAkC,EAAE;YACzE,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;gBACpB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;oBACtB,KAAK,EAAE,gBAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;oBACzC,QAAQ,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE,EAAE;iBACtD,CAAC,CAAC;gBAEH,MAAM,CAAC,KAAK,CAAC,2BAA2B,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,CAAC,CAAC;gBACjE,MAAM,KAAK,CAAC;YACd,CAAC;YAED,OAAO,KAAK,CAAC,QAAQ,CAAC;QACxB,CAAC,CAAC,CAAC;QAEL,IAAI,QAAQ,CAAC,OAAO,CAAC,kBAAkB,CAAC,EAAE,CAAC;YACzC,QAAQ,CAAC,IAAI,GAAG,MAAM,IAAA,4BAAY,EAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC;YACxF,QAAQ,CAAC,OAAO,CAAC,kBAAkB,CAAC,GAAG,OAAO,CAAC;QACjD,CAAC;QAED,MAAM,IAAI,GAAG,IAAA,2BAAkB,EAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC;QAC7D,MAAM,IAAI,GAAG,IAAA,qBAAY,EAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QAE/C,OAAO;YACL,MAAM;YACN,QAAQ;YAER,QAAQ,EAAE;gBACR,IAAI;gBAEJ,MAAM,EAAE,QAAQ,CAAC,MAAM;gBACvB,OAAO,EAAE,QAAQ,CAAC,OAAO;gBAEzB,IAAI;gBACJ,OAAO,EAAE,QAAQ,CAAC,IAAI;aACvB;SACF,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,KAAK,CAChB,OAA2B,EAC3B,QAAiC;QAEjC,QAAQ,CAAC,OAAO,GAAG,gBAAC,CAAC,MAAM,CACzB,MAAM,CAAC,MAAM,CAAC,gBAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,mBAAmB,CAAC,CAAC,EAAE;YAC7D,cAAc,EAAE,QAAQ,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAClD,QAAQ,CAAC,IAAI,KAAK,MAAM;gBACtB,CAAC,CAAC,kBAAkB;gBACpB,CAAC,CAAC,QAAQ,CAAC,IAAI,KAAK,KAAK;oBACvB,CAAC,CAAC,iBAAiB;oBACnB,CAAC,CAAC,SAAS,CAChB;YAED,GAAG,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,gBAAgB,EAAE,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;SAC/E,CAAC,EACF,gBAAC,CAAC,KAAK,CACR,CAAC;QAEF,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;QAC9D,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;QAC/C,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAEvB,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,sDAAsD;IAC5C,KAAK,CAAC,8BAA8B,CAC5C,OAA2B,EAC3B,QAAiC,EACjC,MAAiC;QAEjC,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;QACjE,MAAM,SAAS,GAAG,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAEjD,OAAO;YACL,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,KAAK;YAChC,MAAM,EAAE,QAAQ,CAAC,MAAM;YAEvB,OAAO,EAAE,IAAA,qBAAa,EACpB,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE;gBAC9B,UAAU,EAAE,OAAO;gBAEnB,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,YAAY,KAAK,KAAK,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC;gBACjE,GAAG,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,gBAAgB,EAAE,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;aAC/E,CAAC,CACH;YAED,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,CAAC;YACtC,GAAG,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,GAAG,EAAE,QAAQ,CAAC,IAAI,EAAE,CAAC;YAEtE,IAAI,EAAE,QAAQ,CAAC,OAAO;YACtB,MAAM,EAAE,OAAO,CAAC,QAAQ,CAAC,KAAK;YAC9B,YAAY,EAAE,aAAa;YAE3B,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC;YAC5D,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,IAAI,SAAS,CAAC,IAAI;gBACjC,UAAU,EAAE,IAAI,mCAAe,CAAC,UAAU,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;aACpF,CAAC;SACH,CAAC;IACJ,CAAC;CACF;AAvJD,oCAuJC"}
|
|
@@ -5,7 +5,7 @@ import { IServerContext } from '../../types';
|
|
|
5
5
|
import { HttpExecutor } from './executor';
|
|
6
6
|
export * from './executor';
|
|
7
7
|
export * from './context';
|
|
8
|
-
export declare const buildHttpListener: <T extends IServerContext>(router: Router<T>) => (request: IncomingMessage, response: ServerResponse) => Promise<ServerResponse<IncomingMessage> | null
|
|
8
|
+
export declare const buildHttpListener: <T extends IServerContext>(router: Router<T>) => (request: IncomingMessage, response: ServerResponse) => Promise<void | HttpRequestContext | ServerResponse<IncomingMessage> | null>;
|
|
9
9
|
export declare class HttpTransport extends Transport<HttpExecutor> {
|
|
10
10
|
executor: HttpExecutor;
|
|
11
11
|
compileContext(provider: Provider, request: IncomingMessage, response: ServerResponse): Promise<HttpRequestContext>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AAEvD,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC3D,OAAO,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAI1C,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAI1B,eAAO,MAAM,iBAAiB,GAAI,CAAC,SAAS,cAAc,UAAU,MAAM,CAAC,CAAC,CAAC,eAC3D,eAAe,YAAY,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AAEvD,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC3D,OAAO,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAI1C,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAI1B,eAAO,MAAM,iBAAiB,GAAI,CAAC,SAAS,cAAc,UAAU,MAAM,CAAC,CAAC,CAAC,eAC3D,eAAe,YAAY,cAAc,gFAqCxD,CAAA;AAEH,qBAAa,aAAc,SAAQ,SAAS,CAAC,YAAY,CAAC;IACjD,QAAQ,eAAsB;IAE9B,cAAc,CACnB,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,cAAc;CAI3B"}
|
|
@@ -22,7 +22,7 @@ const meta_1 = require("../../../meta");
|
|
|
22
22
|
const logger_1 = require("../../../logger");
|
|
23
23
|
__exportStar(require("./executor"), exports);
|
|
24
24
|
__exportStar(require("./context"), exports);
|
|
25
|
-
const logger = logger_1.Logger.build('
|
|
25
|
+
const logger = logger_1.Logger.build('Transports.Http');
|
|
26
26
|
const buildHttpListener = (router) => async (request, response) => {
|
|
27
27
|
for (const { provider, transport } of router.match('http', request.url ?? '')) {
|
|
28
28
|
const context = await transport
|
|
@@ -44,10 +44,9 @@ const buildHttpListener = (router) => async (request, response) => {
|
|
|
44
44
|
context.cancel();
|
|
45
45
|
continue;
|
|
46
46
|
}
|
|
47
|
-
|
|
47
|
+
return meta_1.metaStorage
|
|
48
48
|
.wrap(context.meta, () => transport.executor.exec(context.handle(), { expectation }))
|
|
49
49
|
.catch((error) => logger.error('Got error while execution', error?.stack ?? error));
|
|
50
|
-
return null;
|
|
51
50
|
}
|
|
52
51
|
const { transport, provider } = router.default('http');
|
|
53
52
|
const context = await transport.compileContext(provider, request, response);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAEA,yCAA2D;AAC3D,uCAA+C;AAE/C,yCAA0C;AAC1C,wCAA4C;AAC5C,4CAAyC;AAEzC,6CAA2B;AAC3B,4CAA0B;AAE1B,MAAM,MAAM,GAAG,eAAM,CAAC,KAAK,CAAC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/server/transports/http.transport/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAEA,yCAA2D;AAC3D,uCAA+C;AAE/C,yCAA0C;AAC1C,wCAA4C;AAC5C,4CAAyC;AAEzC,6CAA2B;AAC3B,4CAA0B;AAE1B,MAAM,MAAM,GAAG,eAAM,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;AAExC,MAAM,iBAAiB,GAAG,CAA2B,MAAiB,EAAE,EAAE,CAC/E,KAAK,EAAE,OAAwB,EAAE,QAAwB,EAAE,EAAE;IAC3D,KAAK,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,MAAM,CAAC,KAAK,CAAgB,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,CAAC;QAC7F,MAAM,OAAO,GAAG,MAAM,SAAS;aAC5B,cAAc,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC;aAC3C,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,qCAAqC,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC;QAEhG,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,EAAE,CAAC;YAC5C,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,kBAAW;aAClC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;aAC3D,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC;QAEjG,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,EAAE,CAAC;YAC5C,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO,CAAC,MAAM,EAAE,CAAC;YACjB,SAAS;QACX,CAAC;QAED,OAAO,kBAAW;aACf,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;aACpF,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,2BAA2B,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC;IACxF,CAAC;IAED,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC,OAAO,CAAgB,MAAM,CAAC,CAAC;IACtE,MAAM,OAAO,GAAG,MAAM,SAAS,CAAC,cAAc,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IAE5E,MAAM,kBAAW;SACd,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;SACnE,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,2BAA2B,EAAE,KAAK,EAAE,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC;AACxF,CAAC,CAAA;AAtCU,QAAA,iBAAiB,qBAsC3B;AAEH,MAAa,aAAc,SAAQ,kBAAuB;IAA1D;;QACS,aAAQ,GAAG,IAAI,uBAAY,EAAE,CAAC;IASvC,CAAC;IAPQ,cAAc,CACnB,QAAkB,EAClB,OAAwB,EACxB,QAAwB;QAExB,OAAO,4BAAkB,CAAC,KAAK,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IAC/D,CAAC;CACF;AAVD,sCAUC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/server/transports/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/server/transports/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,UAAU,CAAC"}
|
|
@@ -16,5 +16,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./http.transport"), exports);
|
|
18
18
|
__exportStar(require("./ws.transport"), exports);
|
|
19
|
-
__exportStar(require("./
|
|
19
|
+
__exportStar(require("./system"), exports);
|
|
20
20
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/server/transports/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,iDAA+B;AAC/B,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/server/transports/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,iDAA+B;AAC/B,2CAAyB"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { IncomingMessage, ServerResponse } from 'http';
|
|
2
2
|
import type { MockServer } from '../../../index';
|
|
3
3
|
import { History, IRequestContextIncoming, RequestContext } from '../../../models';
|
|
4
|
-
import {
|
|
5
|
-
export declare class
|
|
4
|
+
import { SystemHttpReply } from './reply';
|
|
5
|
+
export declare class SystemHttpRequestContext<TOutgoing = unknown> extends RequestContext<{
|
|
6
6
|
transport: 'http';
|
|
7
|
-
event:
|
|
7
|
+
event: string & {};
|
|
8
8
|
flag: string & {};
|
|
9
9
|
}> {
|
|
10
10
|
server: MockServer;
|
|
@@ -13,13 +13,13 @@ export declare class InternalHttpRequestContext<TOutgoing = unknown> extends Req
|
|
|
13
13
|
response: ServerResponse;
|
|
14
14
|
snapshot: import("../../../index").RequestContextSnapshot<{
|
|
15
15
|
transport: "http";
|
|
16
|
-
event:
|
|
16
|
+
event: string & {};
|
|
17
17
|
flag: string & {};
|
|
18
18
|
}>;
|
|
19
|
-
reply:
|
|
19
|
+
reply: SystemHttpReply<TOutgoing>;
|
|
20
20
|
constructor(server: MockServer, incoming: IRequestContextIncoming, request: IncomingMessage, response: ServerResponse);
|
|
21
21
|
complete(): this;
|
|
22
22
|
compileHistory(): History;
|
|
23
|
-
static build(server: MockServer, request: IncomingMessage, response: ServerResponse): Promise<
|
|
23
|
+
static build(server: MockServer, request: IncomingMessage, response: ServerResponse): Promise<SystemHttpRequestContext<unknown>>;
|
|
24
24
|
}
|
|
25
25
|
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../../../../src/server/transports/system/http.transport/context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AAGvD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,OAAO,EAA+B,OAAO,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAChH,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAK1C,qBAAa,wBAAwB,CAAC,SAAS,GAAG,OAAO,CAAE,SAAQ,cAAc,CAAC;IAChF,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC;IACnB,IAAI,EAAE,MAAM,GAAG,EAAE,CAAC;CACnB,CAAC;IAKS,MAAM,EAAE,UAAU;IAClB,QAAQ,EAAE,uBAAuB;IACjC,OAAO,EAAE,eAAe;IACxB,QAAQ,EAAE,cAAc;IAP1B,QAAQ;mBAJJ,MAAM;eACV,MAAM,GAAG,EAAE;cACZ,MAAM,GAAG,EAAE;OAEwB;IAClC,KAAK,6BAA0C;gBAG7C,MAAM,EAAE,UAAU,EAClB,QAAQ,EAAE,uBAAuB,EACjC,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,cAAc;IAM1B,QAAQ;IASR,cAAc,IAAI,OAAO;WAOnB,KAAK,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,cAAc;CAI1F"}
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.SystemHttpRequestContext = void 0;
|
|
4
4
|
const models_1 = require("../../../models");
|
|
5
5
|
const reply_1 = require("./reply");
|
|
6
6
|
const logger_1 = require("../../../../logger");
|
|
7
|
-
const logger = logger_1.Logger.build('
|
|
8
|
-
class
|
|
7
|
+
const logger = logger_1.Logger.build('Transports.System.Http.Context');
|
|
8
|
+
class SystemHttpRequestContext extends models_1.RequestContext {
|
|
9
9
|
constructor(server, incoming, request, response) {
|
|
10
|
-
super(server.providers.default, { transport: 'http'
|
|
10
|
+
super(server.providers.default, { transport: 'http' });
|
|
11
11
|
this.server = server;
|
|
12
12
|
this.incoming = incoming;
|
|
13
13
|
this.request = request;
|
|
14
14
|
this.response = response;
|
|
15
15
|
this.snapshot = this.compileSnapshot();
|
|
16
|
-
this.reply = reply_1.
|
|
16
|
+
this.reply = reply_1.SystemHttpReply.build(this);
|
|
17
17
|
logger.info('Incoming request', `[${incoming.method} ${incoming.path}]`);
|
|
18
18
|
}
|
|
19
19
|
complete() {
|
|
@@ -28,8 +28,8 @@ class InternalHttpRequestContext extends models_1.RequestContext {
|
|
|
28
28
|
}
|
|
29
29
|
static async build(server, request, response) {
|
|
30
30
|
const incoming = await (0, models_1.extractHttpIncommingContext)(request);
|
|
31
|
-
return new
|
|
31
|
+
return new SystemHttpRequestContext(server, incoming, request, response);
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
|
-
exports.
|
|
34
|
+
exports.SystemHttpRequestContext = SystemHttpRequestContext;
|
|
35
35
|
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../../../../src/server/transports/system/http.transport/context.ts"],"names":[],"mappings":";;;AAKA,4CAAgH;AAChH,mCAA0C;AAC1C,+CAA4C;AAE5C,MAAM,MAAM,GAAG,eAAM,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;AAE9D,MAAa,wBAA8C,SAAQ,uBAIjE;IAIA,YACS,MAAkB,EAClB,QAAiC,EACjC,OAAwB,EACxB,QAAwB;QAE/B,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;QALhD,WAAM,GAAN,MAAM,CAAY;QAClB,aAAQ,GAAR,QAAQ,CAAyB;QACjC,YAAO,GAAP,OAAO,CAAiB;QACxB,aAAQ,GAAR,QAAQ,CAAgB;QAP1B,aAAQ,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAClC,UAAK,GAAG,uBAAe,CAAC,KAAK,CAAY,IAAI,CAAC,CAAC;QASpD,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,IAAI,GAAG,CAAC,CAAC;IAC3E,CAAC;IAEM,QAAQ;QACb,MAAM,CAAC,IAAI,CACT,qBAAqB,IAAI,CAAC,QAAQ,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,gBAAgB,EAC/E,gBAAgB,IAAI,CAAC,QAAQ,EAAE,MAAM,IAAI,GAAG,SAAS,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS,KAAK,CACtF,CAAC;QAEF,OAAO,KAAK,CAAC,QAAQ,EAAE,CAAC;IAC1B,CAAC;IAEM,cAAc;QACnB,OAAO,gBAAO,CAAC,KAAK,CAAC;YACnB,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK;YAC1B,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE;SACjC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,MAAkB,EAAE,OAAwB,EAAE,QAAwB;QACvF,MAAM,QAAQ,GAAG,MAAM,IAAA,oCAA2B,EAAC,OAAO,CAAC,CAAC;QAC5D,OAAO,IAAI,wBAAwB,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IAC3E,CAAC;CACF;AAtCD,4DAsCC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Endpoint, Executor, IRequestContextOutgoing } from '../../../models';
|
|
2
|
+
import { SystemHttpRequestContext } from './context';
|
|
3
|
+
type TEndpoint = Endpoint<{
|
|
4
|
+
locations: {
|
|
5
|
+
http: {
|
|
6
|
+
method: string;
|
|
7
|
+
path: string;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
incoming: any;
|
|
11
|
+
outgoing: any;
|
|
12
|
+
}>;
|
|
13
|
+
export declare class SystemHttpExecutor extends Executor<SystemHttpRequestContext> {
|
|
14
|
+
router: Record<string, TEndpoint>;
|
|
15
|
+
exec(context: SystemHttpRequestContext): Promise<SystemHttpRequestContext<unknown>>;
|
|
16
|
+
match(context: SystemHttpRequestContext<unknown>): Promise<null>;
|
|
17
|
+
forward(): Promise<null>;
|
|
18
|
+
reply(context: SystemHttpRequestContext, outgoing?: IRequestContextOutgoing): Promise<IRequestContextOutgoing>;
|
|
19
|
+
}
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=executor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../../../../../src/server/transports/system/http.transport/executor.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AAC9E,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AAKrD,KAAK,SAAS,GAAG,QAAQ,CAAC;IACxB,SAAS,EAAE;QACT,IAAI,EAAE;YACJ,MAAM,EAAE,MAAM,CAAC;YACf,IAAI,EAAE,MAAM,CAAC;SACd,CAAC;KACH,CAAC;IAEF,QAAQ,EAAE,GAAG,CAAC;IACd,QAAQ,EAAE,GAAG,CAAC;CACf,CAAC,CAAC;AAEH,qBAAa,kBAAmB,SAAQ,QAAQ,CAAC,wBAAwB,CAAC;IACjE,MAAM,4BAMX;IAEW,IAAI,CAAC,OAAO,EAAE,wBAAwB;IAgBtC,KAAK,CAAC,OAAO,EAAE,wBAAwB,CAAC,OAAO,CAAC;IAKhD,OAAO;IAIP,KAAK,CAAC,OAAO,EAAE,wBAAwB,EAAE,QAAQ,CAAC,EAAE,uBAAuB;CAezF"}
|
|
@@ -36,12 +36,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
36
36
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
37
|
};
|
|
38
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
exports.
|
|
39
|
+
exports.SystemHttpExecutor = void 0;
|
|
40
40
|
const lodash_1 = __importDefault(require("lodash"));
|
|
41
41
|
const models_1 = require("../../../models");
|
|
42
42
|
const endpoints = __importStar(require("../../../endpoints"));
|
|
43
43
|
const config_1 = __importDefault(require("../../../../config"));
|
|
44
|
-
class
|
|
44
|
+
class SystemHttpExecutor extends models_1.Executor {
|
|
45
45
|
constructor() {
|
|
46
46
|
super(...arguments);
|
|
47
47
|
this.router = Object.values(endpoints).reduce((acc, endpoint) => endpoint.locations.http
|
|
@@ -50,8 +50,8 @@ class InternalHttpExecutor extends models_1.Executor {
|
|
|
50
50
|
}
|
|
51
51
|
async exec(context) {
|
|
52
52
|
const routes = config_1.default.get('routes');
|
|
53
|
-
const path = `${context.incoming.method}:${context.incoming.path.replace(routes.
|
|
54
|
-
const endpoint = this.router[path] ?? (path.includes(routes.
|
|
53
|
+
const path = `${context.incoming.method}:${context.incoming.path.replace(routes.system.root, '')}`;
|
|
54
|
+
const endpoint = this.router[path] ?? (path.includes(routes.system.gui) ? endpoints.gui : null);
|
|
55
55
|
await endpoint?.handler?.(context);
|
|
56
56
|
if (context.is(['completed'])) {
|
|
57
57
|
return context;
|
|
@@ -79,5 +79,5 @@ class InternalHttpExecutor extends models_1.Executor {
|
|
|
79
79
|
return result;
|
|
80
80
|
}
|
|
81
81
|
}
|
|
82
|
-
exports.
|
|
82
|
+
exports.SystemHttpExecutor = SystemHttpExecutor;
|
|
83
83
|
//# sourceMappingURL=executor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"executor.js","sourceRoot":"","sources":["../../../../../../src/server/transports/system/http.transport/executor.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,oDAAuB;AAEvB,4CAA8E;AAG9E,8DAAgD;AAChD,gEAAwC;AAcxC,MAAa,kBAAmB,SAAQ,iBAAkC;IAA1E;;QACS,WAAM,GAAG,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,CAC7C,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE,CAChB,QAAQ,CAAC,SAAS,CAAC,IAAI;YACrB,CAAC,CAAC,gBAAC,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,QAAQ,CAAC;YAC3F,CAAC,CAAC,GAAG,EACT,EAAE,CACH,CAAC;IA0CJ,CAAC;IAxCQ,KAAK,CAAC,IAAI,CAAC,OAAiC;QACjD,MAAM,MAAM,GAAG,gBAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAEpC,MAAM,IAAI,GAAG,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,CAAC;QACnG,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAEhG,MAAM,QAAQ,EAAE,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;QAEnC,IAAI,OAAO,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC;YAC9B,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;QAC7D,OAAO,OAAO,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;IACjD,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,OAA0C;QAC3D,MAAM,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK,CAAC,OAAO;QAClB,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,OAAiC,EAAE,QAAkC;QACrF,MAAM,MAAM,GAAG,QAAQ,IAAI;YAC1B,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,GAAG;YAEX,OAAO,EAAE,EAAE;YACX,IAAI,EAAE,8BAA8B;SACrC,CAAC;QAEF,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;QAC1D,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;QAC7C,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAEvB,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAjDD,gDAiDC"}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { IncomingMessage, ServerResponse } from 'http';
|
|
2
2
|
import type { MockServer } from '../../../index';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { SystemHttpRequestContext } from './context';
|
|
4
|
+
import { SystemHttpExecutor } from './executor';
|
|
5
5
|
import { Provider, Transport } from '../../../models';
|
|
6
6
|
export * from './executor';
|
|
7
7
|
export * from './context';
|
|
8
8
|
export * from './reply';
|
|
9
|
-
export declare class
|
|
9
|
+
export declare class SystemHttpTransport extends Transport<SystemHttpExecutor> {
|
|
10
10
|
protected server: MockServer;
|
|
11
|
-
executor:
|
|
11
|
+
executor: SystemHttpExecutor;
|
|
12
12
|
constructor(server: MockServer);
|
|
13
|
-
compileContext(provider: Provider, request: IncomingMessage, response: ServerResponse): Promise<
|
|
13
|
+
compileContext(provider: Provider, request: IncomingMessage, response: ServerResponse): Promise<SystemHttpRequestContext<unknown>>;
|
|
14
14
|
}
|
|
15
15
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/server/transports/system/http.transport/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AAEvD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEtD,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AAExB,qBAAa,mBAAoB,SAAQ,SAAS,CAAC,kBAAkB,CAAC;IAGxD,SAAS,CAAC,MAAM,EAAE,UAAU;IAFjC,QAAQ,qBAA4B;gBAErB,MAAM,EAAE,UAAU;IAIjC,cAAc,CACnB,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,cAAc;CAI3B"}
|
|
@@ -14,22 +14,22 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.
|
|
17
|
+
exports.SystemHttpTransport = void 0;
|
|
18
18
|
const context_1 = require("./context");
|
|
19
19
|
const executor_1 = require("./executor");
|
|
20
20
|
const models_1 = require("../../../models");
|
|
21
21
|
__exportStar(require("./executor"), exports);
|
|
22
22
|
__exportStar(require("./context"), exports);
|
|
23
23
|
__exportStar(require("./reply"), exports);
|
|
24
|
-
class
|
|
24
|
+
class SystemHttpTransport extends models_1.Transport {
|
|
25
25
|
constructor(server) {
|
|
26
26
|
super();
|
|
27
27
|
this.server = server;
|
|
28
|
-
this.executor = new executor_1.
|
|
28
|
+
this.executor = new executor_1.SystemHttpExecutor();
|
|
29
29
|
}
|
|
30
30
|
compileContext(provider, request, response) {
|
|
31
|
-
return context_1.
|
|
31
|
+
return context_1.SystemHttpRequestContext.build(this.server, request, response);
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
|
-
exports.
|
|
34
|
+
exports.SystemHttpTransport = SystemHttpTransport;
|
|
35
35
|
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/server/transports/system/http.transport/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAIA,uCAAqD;AACrD,yCAAgD;AAChD,4CAAsD;AAEtD,6CAA2B;AAC3B,4CAA0B;AAC1B,0CAAwB;AAExB,MAAa,mBAAoB,SAAQ,kBAA6B;IAGpE,YAAsB,MAAkB;QACtC,KAAK,EAAE,CAAC;QADY,WAAM,GAAN,MAAM,CAAY;QAFjC,aAAQ,GAAG,IAAI,6BAAkB,EAAE,CAAC;IAI3C,CAAC;IAEM,cAAc,CACnB,QAAkB,EAClB,OAAwB,EACxB,QAAwB;QAExB,OAAO,kCAAwB,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IACxE,CAAC;CACF;AAdD,kDAcC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { SystemHttpRequestContext } from './context';
|
|
2
|
+
import { Reply } from '../../../models';
|
|
3
|
+
export declare class SystemHttpReply<TOutgoing = unknown> extends Reply<SystemHttpRequestContext, TOutgoing> {
|
|
4
|
+
ok(payload: TOutgoing): void;
|
|
5
|
+
internalError(message?: string): void;
|
|
6
|
+
validationError(reasons?: unknown[]): void;
|
|
7
|
+
notFound(): void;
|
|
8
|
+
static build<TResponse>(context: SystemHttpRequestContext): SystemHttpReply<TResponse>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=reply.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reply.d.ts","sourceRoot":"","sources":["../../../../../../src/server/transports/system/http.transport/reply.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AAE1D,OAAO,EAA2B,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAOjE,qBAAa,eAAe,CAAC,SAAS,GAAG,OAAO,CAAE,SAAQ,KAAK,CAAC,wBAAwB,EAAE,SAAS,CAAC;IAC3F,EAAE,CAAC,OAAO,EAAE,SAAS;IAiBrB,aAAa,CAAC,OAAO,GAAE,MAA+B;IAiBtD,eAAe,CAAC,OAAO,GAAE,OAAO,EAA6B;IAiB7D,QAAQ;IAiBf,MAAM,CAAC,KAAK,CAAC,SAAS,EAAE,OAAO,EAAE,wBAAwB;CAG1D"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.SystemHttpReply = void 0;
|
|
4
4
|
const models_1 = require("../../../models");
|
|
5
5
|
const utils_1 = require("../utils");
|
|
6
6
|
const headers = {
|
|
7
7
|
'Content-type': 'application/json',
|
|
8
8
|
};
|
|
9
|
-
class
|
|
9
|
+
class SystemHttpReply extends models_1.Reply {
|
|
10
10
|
ok(payload) {
|
|
11
11
|
const outgoing = {
|
|
12
12
|
headers,
|
|
@@ -56,8 +56,8 @@ class InternalHttpReply extends models_1.Reply {
|
|
|
56
56
|
this.context.assign({ outgoing }).complete();
|
|
57
57
|
}
|
|
58
58
|
static build(context) {
|
|
59
|
-
return new
|
|
59
|
+
return new SystemHttpReply(context);
|
|
60
60
|
}
|
|
61
61
|
}
|
|
62
|
-
exports.
|
|
62
|
+
exports.SystemHttpReply = SystemHttpReply;
|
|
63
63
|
//# sourceMappingURL=reply.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reply.js","sourceRoot":"","sources":["../../../../../../src/server/transports/system/http.transport/reply.ts"],"names":[],"mappings":";;;AAEA,4CAAiE;AACjE,oCAAiD;AAEjD,MAAM,OAAO,GAAG;IACd,cAAc,EAAE,kBAAkB;CACnC,CAAC;AAEF,MAAa,eAAqC,SAAQ,cAA0C;IAC3F,EAAE,CAAC,OAAkB;QAC1B,MAAM,QAAQ,GAA4B;YACxC,OAAO;YAEP,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,GAAG;YAEX,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAA,6BAAqB,EAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;SAC3E,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;QACnE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAE5B,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC/C,CAAC;IAEM,aAAa,CAAC,UAAkB,sBAAsB;QAC3D,MAAM,QAAQ,GAA4B;YACxC,OAAO;YAEP,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,GAAG;YAEX,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAA,6BAAqB,EAAC,gBAAgB,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;SAC3F,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAA;QAClE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAE5B,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC/C,CAAC;IAEM,eAAe,CAAC,UAAqB,CAAC,sBAAsB,CAAC;QAClE,MAAM,QAAQ,GAA4B;YACxC,OAAO;YAEP,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,GAAG;YAEX,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAA,6BAAqB,EAAC,kBAAkB,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;SAC7F,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAA;QAClE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAE5B,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC/C,CAAC;IAEM,QAAQ;QACb,MAAM,QAAQ,GAA4B;YACxC,OAAO;YAEP,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,GAAG;YAEX,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAA,6BAAqB,EAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC;SAC/E,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAA;QAClE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAE5B,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC/C,CAAC;IAED,MAAM,CAAC,KAAK,CAAY,OAAiC;QACvD,OAAO,IAAI,eAAe,CAAY,OAAO,CAAC,CAAC;IACjD,CAAC;CACF;AAxED,0CAwEC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/server/transports/system/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/server/transports/system/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,iDAA+B"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import type { MockServer } from '../../../index';
|
|
2
2
|
import type { TFunction } from '../../../../../types';
|
|
3
3
|
import { IRequestContextIncoming, RequestContext } from '../../../models';
|
|
4
|
-
import {
|
|
5
|
-
export declare class
|
|
4
|
+
import { SystemSocketIoReply } from './reply';
|
|
5
|
+
export declare class SystemSocketIoRequestContext<TOutgoing = unknown> extends RequestContext<{
|
|
6
6
|
transport: 'io';
|
|
7
|
-
event:
|
|
7
|
+
event: string & {};
|
|
8
8
|
flag: string & {};
|
|
9
9
|
}> {
|
|
10
10
|
server: MockServer;
|
|
@@ -14,10 +14,10 @@ export declare class InternalSocketIoRequestContext<TOutgoing = unknown> extends
|
|
|
14
14
|
callback?: TFunction<void>;
|
|
15
15
|
};
|
|
16
16
|
incoming: IRequestContextIncoming;
|
|
17
|
-
reply:
|
|
17
|
+
reply: SystemSocketIoReply<TOutgoing>;
|
|
18
18
|
snapshot: import("../../../index").RequestContextSnapshot<{
|
|
19
19
|
transport: "io";
|
|
20
|
-
event:
|
|
20
|
+
event: string & {};
|
|
21
21
|
flag: string & {};
|
|
22
22
|
}>;
|
|
23
23
|
constructor(server: MockServer, request: {
|
|
@@ -25,6 +25,6 @@ export declare class InternalSocketIoRequestContext<TOutgoing = unknown> extends
|
|
|
25
25
|
data: unknown;
|
|
26
26
|
callback?: TFunction<void>;
|
|
27
27
|
});
|
|
28
|
-
static build(server: MockServer, request:
|
|
28
|
+
static build(server: MockServer, request: SystemSocketIoRequestContext['request']): SystemSocketIoRequestContext<unknown>;
|
|
29
29
|
}
|
|
30
30
|
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../../../../src/server/transports/system/io.transport/context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEtD,OAAO,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAC1E,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAE9C,qBAAa,4BAA4B,CAAC,SAAS,GAAG,OAAO,CAAE,SAAQ,cAAc,CAAC;IACpF,SAAS,EAAE,IAAI,CAAC;IAChB,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC;IACnB,IAAI,EAAE,MAAM,GAAG,EAAE,CAAC;CACnB,CAAC;IAgBS,MAAM,EAAE,UAAU;IAClB,OAAO,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,OAAO,CAAC;QACd,QAAQ,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;KAC5B;IApBI,QAAQ,EAAE,uBAAuB,CAStC;IAEK,KAAK,iCAA8C;IACnD,QAAQ;mBAhBJ,IAAI;eACR,MAAM,GAAG,EAAE;cACZ,MAAM,GAAG,EAAE;OAcwB;gBAGhC,MAAM,EAAE,UAAU,EAClB,OAAO,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,OAAO,CAAC;QACd,QAAQ,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;KAC5B;IAKH,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,4BAA4B,CAAC,SAAS,CAAC;CAGlF"}
|