@n1k1t/mock-server 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +61 -0
- package/lib/package.json +77 -0
- package/lib/src/cli.d.ts +2 -0
- package/lib/src/cli.d.ts.map +1 -0
- package/lib/src/cli.js +33 -0
- package/lib/src/cli.js.map +1 -0
- package/lib/src/client/errors/connection.error.d.ts +6 -0
- package/lib/src/client/errors/connection.error.d.ts.map +1 -0
- package/lib/src/client/errors/connection.error.js +11 -0
- package/lib/src/client/errors/connection.error.js.map +1 -0
- package/lib/src/client/errors/index.d.ts +4 -0
- package/lib/src/client/errors/index.d.ts.map +1 -0
- package/lib/src/client/errors/index.js +20 -0
- package/lib/src/client/errors/index.js.map +1 -0
- package/lib/src/client/errors/internal-server.error.d.ts +6 -0
- package/lib/src/client/errors/internal-server.error.d.ts.map +1 -0
- package/lib/src/client/errors/internal-server.error.js +11 -0
- package/lib/src/client/errors/internal-server.error.js.map +1 -0
- package/lib/src/client/errors/types.d.ts +4 -0
- package/lib/src/client/errors/types.d.ts.map +1 -0
- package/lib/src/client/errors/types.js +3 -0
- package/lib/src/client/errors/types.js.map +1 -0
- package/lib/src/client/errors/validation.error.d.ts +7 -0
- package/lib/src/client/errors/validation.error.d.ts.map +1 -0
- package/lib/src/client/errors/validation.error.js +12 -0
- package/lib/src/client/errors/validation.error.js.map +1 -0
- package/lib/src/client/index.d.ts +9 -0
- package/lib/src/client/index.d.ts.map +1 -0
- package/lib/src/client/index.js +59 -0
- package/lib/src/client/index.js.map +1 -0
- package/lib/src/client/methods/expectations/create.method.d.ts +6 -0
- package/lib/src/client/methods/expectations/create.method.d.ts.map +1 -0
- package/lib/src/client/methods/expectations/create.method.js +13 -0
- package/lib/src/client/methods/expectations/create.method.js.map +1 -0
- package/lib/src/client/methods/expectations/delete-all.method.d.ts +3 -0
- package/lib/src/client/methods/expectations/delete-all.method.d.ts.map +1 -0
- package/lib/src/client/methods/expectations/delete-all.method.js +11 -0
- package/lib/src/client/methods/expectations/delete-all.method.js.map +1 -0
- package/lib/src/client/methods/expectations/delete.method.d.ts +4 -0
- package/lib/src/client/methods/expectations/delete.method.d.ts.map +1 -0
- package/lib/src/client/methods/expectations/delete.method.js +12 -0
- package/lib/src/client/methods/expectations/delete.method.js.map +1 -0
- package/lib/src/client/methods/expectations/index.d.ts +5 -0
- package/lib/src/client/methods/expectations/index.d.ts.map +1 -0
- package/lib/src/client/methods/expectations/index.js +15 -0
- package/lib/src/client/methods/expectations/index.js.map +1 -0
- package/lib/src/client/methods/expectations/types.d.ts +18 -0
- package/lib/src/client/methods/expectations/types.d.ts.map +1 -0
- package/lib/src/client/methods/expectations/types.js +3 -0
- package/lib/src/client/methods/expectations/types.js.map +1 -0
- package/lib/src/client/methods/expectations/update.method.d.ts +8 -0
- package/lib/src/client/methods/expectations/update.method.d.ts.map +1 -0
- package/lib/src/client/methods/expectations/update.method.js +16 -0
- package/lib/src/client/methods/expectations/update.method.js.map +1 -0
- package/lib/src/client/methods/expectations/utils.d.ts +3 -0
- package/lib/src/client/methods/expectations/utils.d.ts.map +1 -0
- package/lib/src/client/methods/expectations/utils.js +26 -0
- package/lib/src/client/methods/expectations/utils.js.map +1 -0
- package/lib/src/client/methods/index.d.ts +2 -0
- package/lib/src/client/methods/index.d.ts.map +1 -0
- package/lib/src/client/methods/index.js +18 -0
- package/lib/src/client/methods/index.js.map +1 -0
- package/lib/src/client/types.d.ts +6 -0
- package/lib/src/client/types.d.ts.map +1 -0
- package/lib/src/client/types.js +3 -0
- package/lib/src/client/types.js.map +1 -0
- package/lib/src/client/utils.d.ts +5 -0
- package/lib/src/client/utils.d.ts.map +1 -0
- package/lib/src/client/utils.js +27 -0
- package/lib/src/client/utils.js.map +1 -0
- package/lib/src/config/index.d.ts +8 -0
- package/lib/src/config/index.d.ts.map +1 -0
- package/lib/src/config/index.js +17 -0
- package/lib/src/config/index.js.map +1 -0
- package/lib/src/index.d.ts +5 -0
- package/lib/src/index.d.ts.map +1 -0
- package/lib/src/index.js +21 -0
- package/lib/src/index.js.map +1 -0
- package/lib/src/process.d.ts +2 -0
- package/lib/src/process.d.ts.map +1 -0
- package/lib/src/process.js +7 -0
- package/lib/src/process.js.map +1 -0
- package/lib/src/server/endpoints/config.get.endpoint.d.ts +18 -0
- package/lib/src/server/endpoints/config.get.endpoint.d.ts.map +1 -0
- package/lib/src/server/endpoints/config.get.endpoint.js +12 -0
- package/lib/src/server/endpoints/config.get.endpoint.js.map +1 -0
- package/lib/src/server/endpoints/expectations.create.endpoint.d.ts +21 -0
- package/lib/src/server/endpoints/expectations.create.endpoint.d.ts.map +1 -0
- package/lib/src/server/endpoints/expectations.create.endpoint.js +15 -0
- package/lib/src/server/endpoints/expectations.create.endpoint.js.map +1 -0
- package/lib/src/server/endpoints/expectations.delete-all.endpoint.d.ts +11 -0
- package/lib/src/server/endpoints/expectations.delete-all.endpoint.d.ts.map +1 -0
- package/lib/src/server/endpoints/expectations.delete-all.endpoint.js +11 -0
- package/lib/src/server/endpoints/expectations.delete-all.endpoint.js.map +1 -0
- package/lib/src/server/endpoints/expectations.delete.endpoint.d.ts +19 -0
- package/lib/src/server/endpoints/expectations.delete.endpoint.d.ts.map +1 -0
- package/lib/src/server/endpoints/expectations.delete.endpoint.js +14 -0
- package/lib/src/server/endpoints/expectations.delete.endpoint.js.map +1 -0
- package/lib/src/server/endpoints/expectations.get-list.endpoint.d.ts +16 -0
- package/lib/src/server/endpoints/expectations.get-list.endpoint.d.ts.map +1 -0
- package/lib/src/server/endpoints/expectations.get-list.endpoint.js +9 -0
- package/lib/src/server/endpoints/expectations.get-list.endpoint.js.map +1 -0
- package/lib/src/server/endpoints/expectations.update.endpoint.d.ts +27 -0
- package/lib/src/server/endpoints/expectations.update.endpoint.d.ts.map +1 -0
- package/lib/src/server/endpoints/expectations.update.endpoint.js +27 -0
- package/lib/src/server/endpoints/expectations.update.endpoint.js.map +1 -0
- package/lib/src/server/endpoints/history-records.get-list.endpoint.d.ts +16 -0
- package/lib/src/server/endpoints/history-records.get-list.endpoint.d.ts.map +1 -0
- package/lib/src/server/endpoints/history-records.get-list.endpoint.js +11 -0
- package/lib/src/server/endpoints/history-records.get-list.endpoint.js.map +1 -0
- package/lib/src/server/endpoints/index.d.ts +9 -0
- package/lib/src/server/endpoints/index.d.ts.map +1 -0
- package/lib/src/server/endpoints/index.js +23 -0
- package/lib/src/server/endpoints/index.js.map +1 -0
- package/lib/src/server/endpoints/model.d.ts +26 -0
- package/lib/src/server/endpoints/model.d.ts.map +1 -0
- package/lib/src/server/endpoints/model.js +19 -0
- package/lib/src/server/endpoints/model.js.map +1 -0
- package/lib/src/server/endpoints/ping.endpoint.d.ts +15 -0
- package/lib/src/server/endpoints/ping.endpoint.d.ts.map +1 -0
- package/lib/src/server/endpoints/ping.endpoint.js +9 -0
- package/lib/src/server/endpoints/ping.endpoint.js.map +1 -0
- package/lib/src/server/expectations/__utils__/index.d.ts +3 -0
- package/lib/src/server/expectations/__utils__/index.d.ts.map +1 -0
- package/lib/src/server/expectations/__utils__/index.js +36 -0
- package/lib/src/server/expectations/__utils__/index.js.map +1 -0
- package/lib/src/server/expectations/errors/index.d.ts +6 -0
- package/lib/src/server/expectations/errors/index.d.ts.map +1 -0
- package/lib/src/server/expectations/errors/index.js +11 -0
- package/lib/src/server/expectations/errors/index.js.map +1 -0
- package/lib/src/server/expectations/index.d.ts +5 -0
- package/lib/src/server/expectations/index.d.ts.map +1 -0
- package/lib/src/server/expectations/index.js +21 -0
- package/lib/src/server/expectations/index.js.map +1 -0
- package/lib/src/server/expectations/model.d.ts +37 -0
- package/lib/src/server/expectations/model.d.ts.map +1 -0
- package/lib/src/server/expectations/model.js +90 -0
- package/lib/src/server/expectations/model.js.map +1 -0
- package/lib/src/server/expectations/operators/and.operator.d.ts +3 -0
- package/lib/src/server/expectations/operators/and.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/and.operator.js +5 -0
- package/lib/src/server/expectations/operators/and.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/and.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/and.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/and.operator.spec.js +55 -0
- package/lib/src/server/expectations/operators/and.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/exec.operator.d.ts +9 -0
- package/lib/src/server/expectations/operators/exec.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/exec.operator.js +15 -0
- package/lib/src/server/expectations/operators/exec.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/exec.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/exec.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/exec.operator.spec.js +27 -0
- package/lib/src/server/expectations/operators/exec.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/has.operator.d.ts +3 -0
- package/lib/src/server/expectations/operators/has.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/has.operator.js +83 -0
- package/lib/src/server/expectations/operators/has.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/has.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/has.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/has.operator.spec.js +173 -0
- package/lib/src/server/expectations/operators/has.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/if.operator.d.ts +3 -0
- package/lib/src/server/expectations/operators/if.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/if.operator.js +15 -0
- package/lib/src/server/expectations/operators/if.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/if.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/if.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/if.operator.spec.js +98 -0
- package/lib/src/server/expectations/operators/if.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/index.d.ts +10 -0
- package/lib/src/server/expectations/operators/index.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/index.js +25 -0
- package/lib/src/server/expectations/operators/index.js.map +1 -0
- package/lib/src/server/expectations/operators/merge.operator.d.ts +3 -0
- package/lib/src/server/expectations/operators/merge.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/merge.operator.js +30 -0
- package/lib/src/server/expectations/operators/merge.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/merge.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/merge.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/merge.operator.spec.js +55 -0
- package/lib/src/server/expectations/operators/merge.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/not.operator.d.ts +3 -0
- package/lib/src/server/expectations/operators/not.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/not.operator.js +5 -0
- package/lib/src/server/expectations/operators/not.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/not.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/not.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/not.operator.spec.js +17 -0
- package/lib/src/server/expectations/operators/not.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/or.operator.d.ts +3 -0
- package/lib/src/server/expectations/operators/or.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/or.operator.js +9 -0
- package/lib/src/server/expectations/operators/or.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/or.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/or.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/or.operator.spec.js +55 -0
- package/lib/src/server/expectations/operators/or.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/remove.operator.d.ts +3 -0
- package/lib/src/server/expectations/operators/remove.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/remove.operator.js +28 -0
- package/lib/src/server/expectations/operators/remove.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/remove.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/remove.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/remove.operator.spec.js +45 -0
- package/lib/src/server/expectations/operators/remove.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/set.operator.d.ts +3 -0
- package/lib/src/server/expectations/operators/set.operator.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/set.operator.js +39 -0
- package/lib/src/server/expectations/operators/set.operator.js.map +1 -0
- package/lib/src/server/expectations/operators/set.operator.spec.d.ts +2 -0
- package/lib/src/server/expectations/operators/set.operator.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/set.operator.spec.js +57 -0
- package/lib/src/server/expectations/operators/set.operator.spec.js.map +1 -0
- package/lib/src/server/expectations/operators/utils.d.ts +20 -0
- package/lib/src/server/expectations/operators/utils.d.ts.map +1 -0
- package/lib/src/server/expectations/operators/utils.js +67 -0
- package/lib/src/server/expectations/operators/utils.js.map +1 -0
- package/lib/src/server/expectations/storage.d.ts +19 -0
- package/lib/src/server/expectations/storage.d.ts.map +1 -0
- package/lib/src/server/expectations/storage.js +35 -0
- package/lib/src/server/expectations/storage.js.map +1 -0
- package/lib/src/server/expectations/types.d.ts +83 -0
- package/lib/src/server/expectations/types.d.ts.map +1 -0
- package/lib/src/server/expectations/types.js +16 -0
- package/lib/src/server/expectations/types.js.map +1 -0
- package/lib/src/server/expectations/utils.d.ts +12 -0
- package/lib/src/server/expectations/utils.d.ts.map +1 -0
- package/lib/src/server/expectations/utils.js +92 -0
- package/lib/src/server/expectations/utils.js.map +1 -0
- package/lib/src/server/expectations/utils.spec.d.ts +2 -0
- package/lib/src/server/expectations/utils.spec.d.ts.map +1 -0
- package/lib/src/server/expectations/utils.spec.js +59 -0
- package/lib/src/server/expectations/utils.spec.js.map +1 -0
- package/lib/src/server/expectations/validation-schemas.d.ts +24 -0
- package/lib/src/server/expectations/validation-schemas.d.ts.map +1 -0
- package/lib/src/server/expectations/validation-schemas.js +36 -0
- package/lib/src/server/expectations/validation-schemas.js.map +1 -0
- package/lib/src/server/history/index.d.ts +4 -0
- package/lib/src/server/history/index.d.ts.map +1 -0
- package/lib/src/server/history/index.js +20 -0
- package/lib/src/server/history/index.js.map +1 -0
- package/lib/src/server/history/model.d.ts +26 -0
- package/lib/src/server/history/model.d.ts.map +1 -0
- package/lib/src/server/history/model.js +33 -0
- package/lib/src/server/history/model.js.map +1 -0
- package/lib/src/server/history/storage.d.ts +7 -0
- package/lib/src/server/history/storage.d.ts.map +1 -0
- package/lib/src/server/history/storage.js +21 -0
- package/lib/src/server/history/storage.js.map +1 -0
- package/lib/src/server/history/types.d.ts +6 -0
- package/lib/src/server/history/types.d.ts.map +1 -0
- package/lib/src/server/history/types.js +3 -0
- package/lib/src/server/history/types.js.map +1 -0
- package/lib/src/server/index.d.ts +5 -0
- package/lib/src/server/index.d.ts.map +1 -0
- package/lib/src/server/index.js +80 -0
- package/lib/src/server/index.js.map +1 -0
- package/lib/src/server/middlewares/add-history.middleware.d.ts +8 -0
- package/lib/src/server/middlewares/add-history.middleware.d.ts.map +1 -0
- package/lib/src/server/middlewares/add-history.middleware.js +14 -0
- package/lib/src/server/middlewares/add-history.middleware.js.map +1 -0
- package/lib/src/server/middlewares/destroy-request.midleware.d.ts +8 -0
- package/lib/src/server/middlewares/destroy-request.midleware.d.ts.map +1 -0
- package/lib/src/server/middlewares/destroy-request.midleware.js +17 -0
- package/lib/src/server/middlewares/destroy-request.midleware.js.map +1 -0
- package/lib/src/server/middlewares/handle-expectation-delay.middleware.d.ts +8 -0
- package/lib/src/server/middlewares/handle-expectation-delay.middleware.d.ts.map +1 -0
- package/lib/src/server/middlewares/handle-expectation-delay.middleware.js +18 -0
- package/lib/src/server/middlewares/handle-expectation-delay.middleware.js.map +1 -0
- package/lib/src/server/middlewares/handle-expectation-forward.middleware.d.ts +8 -0
- package/lib/src/server/middlewares/handle-expectation-forward.middleware.d.ts.map +1 -0
- package/lib/src/server/middlewares/handle-expectation-forward.middleware.js +86 -0
- package/lib/src/server/middlewares/handle-expectation-forward.middleware.js.map +1 -0
- package/lib/src/server/middlewares/index.d.ts +9 -0
- package/lib/src/server/middlewares/index.d.ts.map +1 -0
- package/lib/src/server/middlewares/index.js +23 -0
- package/lib/src/server/middlewares/index.js.map +1 -0
- package/lib/src/server/middlewares/internal-route.middleware.d.ts +6 -0
- package/lib/src/server/middlewares/internal-route.middleware.d.ts.map +1 -0
- package/lib/src/server/middlewares/internal-route.middleware.js +11 -0
- package/lib/src/server/middlewares/internal-route.middleware.js.map +1 -0
- package/lib/src/server/middlewares/model.d.ts +25 -0
- package/lib/src/server/middlewares/model.d.ts.map +1 -0
- package/lib/src/server/middlewares/model.js +36 -0
- package/lib/src/server/middlewares/model.js.map +1 -0
- package/lib/src/server/middlewares/reply.middleware.d.ts +8 -0
- package/lib/src/server/middlewares/reply.middleware.d.ts.map +1 -0
- package/lib/src/server/middlewares/reply.middleware.js +35 -0
- package/lib/src/server/middlewares/reply.middleware.js.map +1 -0
- package/lib/src/server/middlewares/resolve-public.middleware.d.ts +6 -0
- package/lib/src/server/middlewares/resolve-public.middleware.d.ts.map +1 -0
- package/lib/src/server/middlewares/resolve-public.middleware.js +38 -0
- package/lib/src/server/middlewares/resolve-public.middleware.js.map +1 -0
- package/lib/src/server/middlewares/validate-expectation-request.middleware.d.ts +6 -0
- package/lib/src/server/middlewares/validate-expectation-request.middleware.d.ts.map +1 -0
- package/lib/src/server/middlewares/validate-expectation-request.middleware.js +20 -0
- package/lib/src/server/middlewares/validate-expectation-request.middleware.js.map +1 -0
- package/lib/src/server/models/index.d.ts +4 -0
- package/lib/src/server/models/index.d.ts.map +1 -0
- package/lib/src/server/models/index.js +20 -0
- package/lib/src/server/models/index.js.map +1 -0
- package/lib/src/server/models/reply-service/index.d.ts +12 -0
- package/lib/src/server/models/reply-service/index.d.ts.map +1 -0
- package/lib/src/server/models/reply-service/index.js +76 -0
- package/lib/src/server/models/reply-service/index.js.map +1 -0
- package/lib/src/server/models/reply-service/types.d.ts +5 -0
- package/lib/src/server/models/reply-service/types.d.ts.map +1 -0
- package/lib/src/server/models/reply-service/types.js +3 -0
- package/lib/src/server/models/reply-service/types.js.map +1 -0
- package/lib/src/server/models/request-context/index.d.ts +60 -0
- package/lib/src/server/models/request-context/index.d.ts.map +1 -0
- package/lib/src/server/models/request-context/index.js +75 -0
- package/lib/src/server/models/request-context/index.js.map +1 -0
- package/lib/src/server/models/request-context/types.d.ts +23 -0
- package/lib/src/server/models/request-context/types.d.ts.map +1 -0
- package/lib/src/server/models/request-context/types.js +3 -0
- package/lib/src/server/models/request-context/types.js.map +1 -0
- package/lib/src/server/models/request-context/utils.d.ts +6 -0
- package/lib/src/server/models/request-context/utils.d.ts.map +1 -0
- package/lib/src/server/models/request-context/utils.js +56 -0
- package/lib/src/server/models/request-context/utils.js.map +1 -0
- package/lib/src/server/models/server-context/index.d.ts +14 -0
- package/lib/src/server/models/server-context/index.d.ts.map +1 -0
- package/lib/src/server/models/server-context/index.js +20 -0
- package/lib/src/server/models/server-context/index.js.map +1 -0
- package/lib/src/server/proxy.d.ts +10 -0
- package/lib/src/server/proxy.d.ts.map +1 -0
- package/lib/src/server/proxy.js +16 -0
- package/lib/src/server/proxy.js.map +1 -0
- package/lib/src/server/router.d.ts +12 -0
- package/lib/src/server/router.d.ts.map +1 -0
- package/lib/src/server/router.js +49 -0
- package/lib/src/server/router.js.map +1 -0
- package/lib/src/server/types.d.ts +6 -0
- package/lib/src/server/types.d.ts.map +1 -0
- package/lib/src/server/types.js +3 -0
- package/lib/src/server/types.js.map +1 -0
- package/lib/src/server/utils/index.d.ts +11 -0
- package/lib/src/server/utils/index.d.ts.map +1 -0
- package/lib/src/server/utils/index.js +26 -0
- package/lib/src/server/utils/index.js.map +1 -0
- package/lib/src/server/web-socket-exchange/index.d.ts +5 -0
- package/lib/src/server/web-socket-exchange/index.d.ts.map +1 -0
- package/lib/src/server/web-socket-exchange/index.js +23 -0
- package/lib/src/server/web-socket-exchange/index.js.map +1 -0
- package/lib/src/server/web-socket-exchange/types.d.ts +12 -0
- package/lib/src/server/web-socket-exchange/types.d.ts.map +1 -0
- package/lib/src/server/web-socket-exchange/types.js +3 -0
- package/lib/src/server/web-socket-exchange/types.js.map +1 -0
- package/lib/src/types.d.ts +6 -0
- package/lib/src/types.d.ts.map +1 -0
- package/lib/src/types.js +3 -0
- package/lib/src/types.js.map +1 -0
- package/lib/src/utils/index.d.ts +29 -0
- package/lib/src/utils/index.d.ts.map +1 -0
- package/lib/src/utils/index.js +50 -0
- package/lib/src/utils/index.js.map +1 -0
- package/lib/task-processor.d.ts +2 -0
- package/lib/task-processor.d.ts.map +1 -0
- package/lib/task-processor.js +75 -0
- package/lib/task-processor.js.map +1 -0
- package/lib/test/index.d.ts +2 -0
- package/lib/test/index.d.ts.map +1 -0
- package/lib/test/index.js +121 -0
- package/lib/test/index.js.map +1 -0
- package/lib/tsconfig.tsbuildinfo +1 -0
- package/lib/types/common.global.d.ts +69 -0
- package/lib/types/common.global.d.ts.map +1 -0
- package/lib/types/common.global.js +3 -0
- package/lib/types/common.global.js.map +1 -0
- package/lib/types/lib.d.ts +3 -0
- package/lib/types/lib.d.ts.map +1 -0
- package/lib/types/lib.js +19 -0
- package/lib/types/lib.js.map +1 -0
- package/package.json +77 -0
- package/public/fonts/fa-regular-400.eot +0 -0
- package/public/fonts/fa-regular-400.svg +801 -0
- package/public/fonts/fa-regular-400.ttf +0 -0
- package/public/fonts/fa-regular-400.woff +0 -0
- package/public/fonts/fa-regular-400.woff2 +0 -0
- package/public/fonts/fa-solid-900.eot +0 -0
- package/public/fonts/fa-solid-900.svg +5028 -0
- package/public/fonts/fa-solid-900.ttf +0 -0
- package/public/fonts/fa-solid-900.woff +0 -0
- package/public/fonts/fa-solid-900.woff2 +0 -0
- package/public/images/favicon.png +0 -0
- package/public/index.html +25 -0
- package/public/scripts/main.js +19950 -0
- package/public/styles/fa-all.css +5 -0
- package/public/styles/json-highlighter.css +259 -0
- package/public/styles/main.css +245 -0
- package/tsconfig.tsbuildinfo +1 -0
- package/types/common.global.ts +112 -0
- package/types/lib.ts +2 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handle-expectation-forward.middleware.d.ts","sourceRoot":"","sources":["../../../../src/server/middlewares/handle-expectation-forward.middleware.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;;;;;;AAErC,wBA+FK"}
|
|
@@ -0,0 +1,86 @@
|
|
|
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
|
+
const axios_1 = __importDefault(require("axios"));
|
|
7
|
+
const https_proxy_agent_1 = __importDefault(require("https-proxy-agent"));
|
|
8
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
9
|
+
const utils_1 = require("../../utils");
|
|
10
|
+
const model_1 = require("./model");
|
|
11
|
+
exports.default = model_1.Middleware
|
|
12
|
+
.build(__filename)
|
|
13
|
+
.requires(['expectation', 'historyRecord'])
|
|
14
|
+
.assignHandler(async (context, next) => {
|
|
15
|
+
if (!context.shared.expectation.forward) {
|
|
16
|
+
return next();
|
|
17
|
+
}
|
|
18
|
+
const { protocol, host, port, timeout, proxy } = context.shared.expectation.forward;
|
|
19
|
+
const manipulatedContext = context.shared.expectation
|
|
20
|
+
.manipulateContext('request', context.toPlain(), { clone: true });
|
|
21
|
+
const body = manipulatedContext.body === undefined ? manipulatedContext.bodyRaw : manipulatedContext.body;
|
|
22
|
+
const bodyRaw = Buffer.from(typeof body === 'object' ? JSON.stringify(body) : String(body));
|
|
23
|
+
Object.assign(manipulatedContext, {
|
|
24
|
+
bodyRaw,
|
|
25
|
+
headers: {
|
|
26
|
+
'connection': 'close',
|
|
27
|
+
...manipulatedContext.headers,
|
|
28
|
+
...((!manipulatedContext.headers?.['transfer-encoding'] && bodyRaw?.length) && {
|
|
29
|
+
'content-length': String(bodyRaw.length),
|
|
30
|
+
}),
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
const historyRecord = context.shared.historyRecord.assign({ forwaded: { request: manipulatedContext } });
|
|
34
|
+
context.webSocketExchange.publish('history:updated', historyRecord);
|
|
35
|
+
const response = await (0, axios_1.default)({
|
|
36
|
+
timeout: timeout ?? 1000 * 30,
|
|
37
|
+
method: manipulatedContext.method,
|
|
38
|
+
headers: manipulatedContext.headers,
|
|
39
|
+
url: manipulatedContext.path,
|
|
40
|
+
baseURL: `${protocol.toLocaleLowerCase()}://${host}:${port}`,
|
|
41
|
+
data: bodyRaw,
|
|
42
|
+
params: context.query,
|
|
43
|
+
responseType: 'arraybuffer',
|
|
44
|
+
...(proxy && {
|
|
45
|
+
proxy,
|
|
46
|
+
httpsAgent: (0, https_proxy_agent_1.default)(proxy.host)
|
|
47
|
+
}),
|
|
48
|
+
}).catch((error) => {
|
|
49
|
+
if (!error.response) {
|
|
50
|
+
historyRecord
|
|
51
|
+
.assign({ error: lodash_1.default.pick(error, ['message', 'code']) })
|
|
52
|
+
.changeState('finished');
|
|
53
|
+
context.webSocketExchange.publish('history:updated', historyRecord);
|
|
54
|
+
context.reply.internalError(error.message);
|
|
55
|
+
throw error;
|
|
56
|
+
}
|
|
57
|
+
return error.response;
|
|
58
|
+
});
|
|
59
|
+
const contentTypeKey = Object
|
|
60
|
+
.keys(response.headers)
|
|
61
|
+
.find((key) => key.toLowerCase() === 'content-type');
|
|
62
|
+
const isJsonData = lodash_1.default.flatten([lodash_1.default.get(response.headers, contentTypeKey ?? '', '')])
|
|
63
|
+
.join(',')
|
|
64
|
+
.toLowerCase()
|
|
65
|
+
.includes('application/json');
|
|
66
|
+
const parsingResponseDataResult = isJsonData ? (0, utils_1.parseJsonSafe)(response.data) : null;
|
|
67
|
+
const responseContext = {
|
|
68
|
+
payloadType: isJsonData ? 'json' : 'plain',
|
|
69
|
+
statusCode: response.status,
|
|
70
|
+
headers: response.headers,
|
|
71
|
+
dataRaw: response.data?.toString() ?? '',
|
|
72
|
+
...(parsingResponseDataResult?.status === 'OK' && { data: parsingResponseDataResult.result }),
|
|
73
|
+
};
|
|
74
|
+
historyRecord.extendForwarded({
|
|
75
|
+
response: responseContext,
|
|
76
|
+
curl: lodash_1.default.get(response.config, 'curlCommand'),
|
|
77
|
+
});
|
|
78
|
+
context.webSocketExchange.publish('history:updated', historyRecord);
|
|
79
|
+
return next({
|
|
80
|
+
forwarded: {
|
|
81
|
+
request: manipulatedContext,
|
|
82
|
+
response: responseContext,
|
|
83
|
+
},
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
//# sourceMappingURL=handle-expectation-forward.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handle-expectation-forward.middleware.js","sourceRoot":"","sources":["../../../../src/server/middlewares/handle-expectation-forward.middleware.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { default as handleInternalMiddleware } from './internal-route.middleware';
|
|
2
|
+
export { default as resolvePublicMiddleware } from './resolve-public.middleware';
|
|
3
|
+
export { default as validateExpectationRequestMiddleware } from './validate-expectation-request.middleware';
|
|
4
|
+
export { default as handleExpectationForwardMiddleware } from './handle-expectation-forward.middleware';
|
|
5
|
+
export { default as handleExpectationDelayMiddleware } from './handle-expectation-delay.middleware';
|
|
6
|
+
export { default as addHistoryMiddleware } from './add-history.middleware';
|
|
7
|
+
export { default as replyMiddleware } from './reply.middleware';
|
|
8
|
+
export { default as buildDestroyRequestMiddleware } from './destroy-request.midleware';
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/server/middlewares/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,6BAA6B,CAAC;AAClF,OAAO,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACjF,OAAO,EAAE,OAAO,IAAI,oCAAoC,EAAE,MAAM,2CAA2C,CAAC;AAC5G,OAAO,EAAE,OAAO,IAAI,kCAAkC,EAAE,MAAM,yCAAyC,CAAC;AACxG,OAAO,EAAE,OAAO,IAAI,gCAAgC,EAAE,MAAM,uCAAuC,CAAC;AACpG,OAAO,EAAE,OAAO,IAAI,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAC3E,OAAO,EAAE,OAAO,IAAI,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,OAAO,IAAI,6BAA6B,EAAE,MAAM,6BAA6B,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
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.buildDestroyRequestMiddleware = exports.replyMiddleware = exports.addHistoryMiddleware = exports.handleExpectationDelayMiddleware = exports.handleExpectationForwardMiddleware = exports.validateExpectationRequestMiddleware = exports.resolvePublicMiddleware = exports.handleInternalMiddleware = void 0;
|
|
7
|
+
var internal_route_middleware_1 = require("./internal-route.middleware");
|
|
8
|
+
Object.defineProperty(exports, "handleInternalMiddleware", { enumerable: true, get: function () { return __importDefault(internal_route_middleware_1).default; } });
|
|
9
|
+
var resolve_public_middleware_1 = require("./resolve-public.middleware");
|
|
10
|
+
Object.defineProperty(exports, "resolvePublicMiddleware", { enumerable: true, get: function () { return __importDefault(resolve_public_middleware_1).default; } });
|
|
11
|
+
var validate_expectation_request_middleware_1 = require("./validate-expectation-request.middleware");
|
|
12
|
+
Object.defineProperty(exports, "validateExpectationRequestMiddleware", { enumerable: true, get: function () { return __importDefault(validate_expectation_request_middleware_1).default; } });
|
|
13
|
+
var handle_expectation_forward_middleware_1 = require("./handle-expectation-forward.middleware");
|
|
14
|
+
Object.defineProperty(exports, "handleExpectationForwardMiddleware", { enumerable: true, get: function () { return __importDefault(handle_expectation_forward_middleware_1).default; } });
|
|
15
|
+
var handle_expectation_delay_middleware_1 = require("./handle-expectation-delay.middleware");
|
|
16
|
+
Object.defineProperty(exports, "handleExpectationDelayMiddleware", { enumerable: true, get: function () { return __importDefault(handle_expectation_delay_middleware_1).default; } });
|
|
17
|
+
var add_history_middleware_1 = require("./add-history.middleware");
|
|
18
|
+
Object.defineProperty(exports, "addHistoryMiddleware", { enumerable: true, get: function () { return __importDefault(add_history_middleware_1).default; } });
|
|
19
|
+
var reply_middleware_1 = require("./reply.middleware");
|
|
20
|
+
Object.defineProperty(exports, "replyMiddleware", { enumerable: true, get: function () { return __importDefault(reply_middleware_1).default; } });
|
|
21
|
+
var destroy_request_midleware_1 = require("./destroy-request.midleware");
|
|
22
|
+
Object.defineProperty(exports, "buildDestroyRequestMiddleware", { enumerable: true, get: function () { return __importDefault(destroy_request_midleware_1).default; } });
|
|
23
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/server/middlewares/index.ts"],"names":[],"mappings":";;;;;;AAAA,yEAAkF;AAAzE,sJAAA,OAAO,OAA4B;AAC5C,yEAAiF;AAAxE,qJAAA,OAAO,OAA2B;AAC3C,qGAA4G;AAAnG,gLAAA,OAAO,OAAwC;AACxD,iGAAwG;AAA/F,4KAAA,OAAO,OAAsC;AACtD,6FAAoG;AAA3F,wKAAA,OAAO,OAAoC;AACpD,mEAA2E;AAAlE,+IAAA,OAAO,OAAwB;AACxC,uDAAgE;AAAvD,oIAAA,OAAO,OAAmB;AACnC,yEAAuF;AAA9E,2JAAA,OAAO,OAAiC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internal-route.middleware.d.ts","sourceRoot":"","sources":["../../../../src/server/middlewares/internal-route.middleware.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;;;;AAErC,wBAKK"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const router_1 = require("../router");
|
|
4
|
+
const model_1 = require("./model");
|
|
5
|
+
exports.default = model_1.Middleware
|
|
6
|
+
.build(__filename)
|
|
7
|
+
.assignHandler((content, next) => {
|
|
8
|
+
const endpoint = (0, router_1.resolveInternalEndpoint)(content);
|
|
9
|
+
return endpoint ? endpoint.handle() : next();
|
|
10
|
+
});
|
|
11
|
+
//# sourceMappingURL=internal-route.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internal-route.middleware.js","sourceRoot":"","sources":["../../../../src/server/middlewares/internal-route.middleware.ts"],"names":[],"mappings":";;AAEA,sCAAoD;AACpD,mCAAqC;AAErC,kBAAe,kBAAU;KACtB,KAAK,CAAC,UAAU,CAAC;KACjB,aAAa,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE;IAC/B,MAAM,QAAQ,GAAG,IAAA,gCAAuB,EAAC,OAAO,CAAC,CAAC;IAClD,OAAO,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;AAC/C,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { RequestContext } from '../models';
|
|
2
|
+
export type TMiddlewareHandler<K extends ExtractPartialKeys<RequestContext['shared']>> = TFunction<unknown, [
|
|
3
|
+
SetRequiredKeys<RequestContext, 'http' | 'webSocketExchange'> & {
|
|
4
|
+
shared: SetRequiredKeys<RequestContext['shared'], K>;
|
|
5
|
+
},
|
|
6
|
+
(result?: Partial<RequestContext['shared']>) => unknown
|
|
7
|
+
]>;
|
|
8
|
+
export declare class Middleware {
|
|
9
|
+
name: string;
|
|
10
|
+
required?: ExtractPartialKeys<RequestContext['shared']>[];
|
|
11
|
+
handler?: TFunction<unknown, [RequestContext, TFunction]>;
|
|
12
|
+
constructor(name: string);
|
|
13
|
+
requires<K extends ExtractPartialKeys<RequestContext['shared']>>(required: K[]): this & {
|
|
14
|
+
required: K[];
|
|
15
|
+
};
|
|
16
|
+
assignHandler<This extends Middleware, K extends This['required'] extends string[] ? ConvertTupleToUnion<This['required']> : never>(this: This, handler: TMiddlewareHandler<K>): This & {
|
|
17
|
+
handler: TMiddlewareHandler<K>;
|
|
18
|
+
};
|
|
19
|
+
compile<This extends SetRequiredKeys<Middleware, 'handler'>>(this: This, context: RequestContext): {
|
|
20
|
+
exec: This["handler"];
|
|
21
|
+
};
|
|
22
|
+
private check;
|
|
23
|
+
static build(name: string): Middleware;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=model.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../../../../src/server/middlewares/model.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAEhD,MAAM,MAAM,kBAAkB,CAAC,CAAC,SAAS,kBAAkB,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,IAAI,SAAS,CAAC,OAAO,EAAE;IAC1G,eAAe,CAAC,cAAc,EAAE,MAAM,GAAG,mBAAmB,CAAC,GAAG;QAC9D,MAAM,EAAE,eAAe,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAA;KACrD;IACD,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,KAAK,OAAO;CACxD,CAAC,CAAC;AAEH,qBAAa,UAAU;IAIF,IAAI,EAAE,MAAM;IAHxB,QAAQ,CAAC,EAAE,kBAAkB,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;IAC1D,OAAO,CAAC,EAAE,SAAS,CAAC,OAAO,EAAE,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC;gBAE9C,IAAI,EAAE,MAAM;IAExB,QAAQ,CAAC,CAAC,SAAS,kBAAkB,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE;;;IAI9E,aAAa,CAClB,IAAI,SAAS,UAAU,EACvB,CAAC,SAAS,IAAI,CAAC,UAAU,CAAC,SAAS,MAAM,EAAE,GAAG,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,KAAK,EAC3F,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,kBAAkB,CAAC,CAAC,CAAC;;;IAIrC,OAAO,CAAC,IAAI,SAAS,eAAe,CAAC,UAAU,EAAE,SAAS,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,cAAc;;;IAMvG,OAAO,CAAC,KAAK;IASb,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM;CAG1B"}
|
|
@@ -0,0 +1,36 @@
|
|
|
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.Middleware = void 0;
|
|
7
|
+
const path_1 = __importDefault(require("path"));
|
|
8
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
9
|
+
class Middleware {
|
|
10
|
+
constructor(name) {
|
|
11
|
+
this.name = name;
|
|
12
|
+
}
|
|
13
|
+
requires(required) {
|
|
14
|
+
return Object.assign(this, { required });
|
|
15
|
+
}
|
|
16
|
+
assignHandler(handler) {
|
|
17
|
+
return Object.assign(this, { handler });
|
|
18
|
+
}
|
|
19
|
+
compile(context) {
|
|
20
|
+
return {
|
|
21
|
+
exec: this.check(context).handler,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
check(context) {
|
|
25
|
+
const notExistentRequiredKeys = this.required?.filter((key) => !lodash_1.default.has(context.shared, key)) ?? [];
|
|
26
|
+
if (notExistentRequiredKeys.length) {
|
|
27
|
+
throw new Error(`Middleware "${this.name}" requires: ${notExistentRequiredKeys.join(', ')}`);
|
|
28
|
+
}
|
|
29
|
+
return this;
|
|
30
|
+
}
|
|
31
|
+
static build(name) {
|
|
32
|
+
return new Middleware(path_1.default.parse(name).name);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
exports.Middleware = Middleware;
|
|
36
|
+
//# sourceMappingURL=model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"model.js","sourceRoot":"","sources":["../../../../src/server/middlewares/model.ts"],"names":[],"mappings":";;;;;;AAAA,gDAAwB;AACxB,oDAAuB;AAWvB,MAAa,UAAU;IAIrB,YAAmB,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;IAAG,CAAC;IAE5B,QAAQ,CAAyD,QAAa;QACnF,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC3C,CAAC;IAEM,aAAa,CAGN,OAA8B;QAC1C,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;IAC1C,CAAC;IAEM,OAAO,CAAkE,OAAuB;QACrG,OAAO;YACL,IAAI,EAAmB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO;SACnD,CAAA;IACH,CAAC;IAEO,KAAK,CAAC,OAAuB;QACnC,MAAM,uBAAuB,GAAG,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;QAClG,IAAI,uBAAuB,CAAC,MAAM,EAAE;YAClC,MAAM,IAAI,KAAK,CAAC,eAAe,IAAI,CAAC,IAAI,eAAe,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAC9F;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,IAAY;QACvB,OAAO,IAAI,UAAU,CAAC,cAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;CACF;AAnCD,gCAmCC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Middleware } from './model';
|
|
2
|
+
declare const _default: Middleware & {
|
|
3
|
+
required: ("expectation" | "historyRecord")[];
|
|
4
|
+
} & {
|
|
5
|
+
handler: import("./model").TMiddlewareHandler<"expectation" | "historyRecord">;
|
|
6
|
+
};
|
|
7
|
+
export default _default;
|
|
8
|
+
//# sourceMappingURL=reply.middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reply.middleware.d.ts","sourceRoot":"","sources":["../../../../src/server/middlewares/reply.middleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;;;;;;AAErC,wBA2CK"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const model_1 = require("./model");
|
|
4
|
+
exports.default = model_1.Middleware
|
|
5
|
+
.build(__dirname)
|
|
6
|
+
.requires(['historyRecord', 'expectation'])
|
|
7
|
+
.assignHandler((context) => {
|
|
8
|
+
const responseContext = context.shared.expectation.manipulateContext('response', Object.assign(context.toPlain(), context.shared.forwarded?.response ?? {
|
|
9
|
+
statusCode: 200,
|
|
10
|
+
headers: {},
|
|
11
|
+
data: {},
|
|
12
|
+
dataRaw: '',
|
|
13
|
+
}), { clone: true });
|
|
14
|
+
const dataRaw = Buffer.from(Object.keys(responseContext?.data ?? {}).length
|
|
15
|
+
? JSON.stringify(responseContext.data)
|
|
16
|
+
: (responseContext.dataRaw ?? ''));
|
|
17
|
+
Object.assign(responseContext, {
|
|
18
|
+
dataRaw: dataRaw.toString(),
|
|
19
|
+
headers: {
|
|
20
|
+
...(responseContext.payloadType === 'json' && { 'content-type': 'application/json' }),
|
|
21
|
+
...responseContext.headers,
|
|
22
|
+
...((!responseContext.headers?.['transfer-encoding'] && !context.http.request.headers['transfer-encoding']) && {
|
|
23
|
+
'content-length': String(dataRaw.length),
|
|
24
|
+
}),
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
context.http.response.writeHead(responseContext.statusCode ?? 200, responseContext.headers);
|
|
28
|
+
context.http.response.write(responseContext.dataRaw);
|
|
29
|
+
context.http.response.end();
|
|
30
|
+
context.shared.historyRecord
|
|
31
|
+
.assign({ response: responseContext })
|
|
32
|
+
.changeState('finished');
|
|
33
|
+
context.webSocketExchange.publish('history:updated', context.shared.historyRecord);
|
|
34
|
+
});
|
|
35
|
+
//# sourceMappingURL=reply.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reply.middleware.js","sourceRoot":"","sources":["../../../../src/server/middlewares/reply.middleware.ts"],"names":[],"mappings":";;AACA,mCAAqC;AAErC,kBAAe,kBAAU;KACtB,KAAK,CAAC,SAAS,CAAC;KAChB,QAAQ,CAAC,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC;KAC1C,aAAa,CAAC,CAAC,OAAO,EAAE,EAAE;IACzB,MAAM,eAAe,GAAG,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,iBAAiB,CAClE,UAAU,EACV,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE,QAAQ,IAAI;QACrE,UAAU,EAAE,GAAG;QACf,OAAO,EAAE,EAAE;QAEX,IAAI,EAAE,EAAE;QACR,OAAO,EAAE,EAAE;KACZ,CAAC,EACF,EAAE,KAAK,EAAE,IAAI,EAAE,CAChB,CAAC;IAEF,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CACzB,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC,MAAM;QAC7C,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,IAAI,CAAC;QACtC,CAAC,CAAC,CAAC,eAAe,CAAC,OAAO,IAAI,EAAE,CAAC,CACpC,CAAC;IAEF,MAAM,CAAC,MAAM,CAAC,eAAe,EAAE;QAC7B,OAAO,EAAE,OAAO,CAAC,QAAQ,EAAE;QAC3B,OAAO,EAAE;YACP,GAAG,CAAC,eAAe,CAAC,WAAW,KAAK,MAAM,IAAI,EAAE,cAAc,EAAE,kBAAkB,EAAE,CAAC;YACrF,GAAG,eAAe,CAAC,OAAO;YAE1B,GAAG,CAAC,CAAC,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,IAAI;gBAC7G,gBAAgB,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;aACzC,CAAC;SACH;KACF,CAAC,CAAA;IAEF,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,IAAI,GAAG,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC;IAC5F,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;IACrD,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;IAE5B,OAAO,CAAC,MAAM,CAAC,aAAa;SACzB,MAAM,CAAC,EAAE,QAAQ,EAAE,eAAe,EAAE,CAAC;SACrC,WAAW,CAAC,UAAU,CAAC,CAAC;IAE3B,OAAO,CAAC,iBAAiB,CAAC,OAAO,CAAC,iBAAiB,EAAE,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;AACrF,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-public.middleware.d.ts","sourceRoot":"","sources":["../../../../src/server/middlewares/resolve-public.middleware.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;;;;AAErC,wBAgCK"}
|
|
@@ -0,0 +1,38 @@
|
|
|
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
|
+
const promises_1 = __importDefault(require("fs/promises"));
|
|
7
|
+
const fs_1 = require("fs");
|
|
8
|
+
const path_1 = __importDefault(require("path"));
|
|
9
|
+
const config_1 = require("../../config");
|
|
10
|
+
const model_1 = require("./model");
|
|
11
|
+
exports.default = model_1.Middleware
|
|
12
|
+
.build(__filename)
|
|
13
|
+
.assignHandler(async (context, next) => {
|
|
14
|
+
if (!context.path.includes(config_1.clientConfig.publicRoute)) {
|
|
15
|
+
return next();
|
|
16
|
+
}
|
|
17
|
+
const requestPath = context.path.replace(config_1.clientConfig.publicRoute, '');
|
|
18
|
+
const requestPathDetails = path_1.default.parse(requestPath);
|
|
19
|
+
if (!requestPath) {
|
|
20
|
+
return context.http.response
|
|
21
|
+
.writeHead(301, 'Moved', { Location: path_1.default.join(config_1.clientConfig.publicRoute, '/') })
|
|
22
|
+
.end();
|
|
23
|
+
}
|
|
24
|
+
if (requestPathDetails.dir === '/' && !requestPathDetails.ext) {
|
|
25
|
+
context.http.response.writeHead(200, 'Ok', { 'Content-type': 'text/html;charset=utf-8' });
|
|
26
|
+
return (0, fs_1.createReadStream)(path_1.default.join(config_1.clientConfig.publicDirPath, '/index.html'))
|
|
27
|
+
.pipe(context.http.response);
|
|
28
|
+
}
|
|
29
|
+
const fileStat = await promises_1.default.stat(path_1.default.join(config_1.clientConfig.publicDirPath, requestPath)).catch(() => null);
|
|
30
|
+
if (fileStat === null) {
|
|
31
|
+
return context.http.response
|
|
32
|
+
.writeHead(404, 'Not found')
|
|
33
|
+
.end();
|
|
34
|
+
}
|
|
35
|
+
return (0, fs_1.createReadStream)(path_1.default.join(config_1.clientConfig.publicDirPath, requestPath))
|
|
36
|
+
.pipe(context.http.response);
|
|
37
|
+
});
|
|
38
|
+
//# sourceMappingURL=resolve-public.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-public.middleware.js","sourceRoot":"","sources":["../../../../src/server/middlewares/resolve-public.middleware.ts"],"names":[],"mappings":";;;;;AAAA,2DAA6B;AAC7B,2BAAsC;AAEtC,gDAAwB;AAExB,yCAA4C;AAC5C,mCAAqC;AAErC,kBAAe,kBAAU;KACtB,KAAK,CAAC,UAAU,CAAC;KACjB,aAAa,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE;IACrC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,qBAAY,CAAC,WAAW,CAAC,EAAE;QACpD,OAAO,IAAI,EAAE,CAAC;KACf;IAED,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,qBAAY,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;IACvE,MAAM,kBAAkB,GAAG,cAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IAEnD,IAAI,CAAC,WAAW,EAAE;QAChB,OAAO,OAAO,CAAC,IAAI,CAAC,QAAQ;aACzB,SAAS,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,cAAI,CAAC,IAAI,CAAC,qBAAY,CAAC,WAAW,EAAE,GAAG,CAAC,EAAE,CAAC;aAC/E,GAAG,EAAE,CAAC;KACV;IAED,IAAI,kBAAkB,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE;QAC7D,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,cAAc,EAAE,yBAAyB,EAAE,CAAC,CAAC;QAE1F,OAAO,IAAA,qBAAgB,EAAC,cAAI,CAAC,IAAI,CAAC,qBAAY,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;aAC1E,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KAChC;IAED,MAAM,QAAQ,GAAG,MAAM,kBAAE,CAAC,IAAI,CAAC,cAAI,CAAC,IAAI,CAAC,qBAAY,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;IACrG,IAAI,QAAQ,KAAK,IAAI,EAAE;QACrB,OAAO,OAAO,CAAC,IAAI,CAAC,QAAQ;aACzB,SAAS,CAAC,GAAG,EAAE,WAAW,CAAC;aAC3B,GAAG,EAAE,CAAC;KACV;IAED,OAAO,IAAA,qBAAgB,EAAC,cAAI,CAAC,IAAI,CAAC,qBAAY,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;SACxE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;AACjC,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-expectation-request.middleware.d.ts","sourceRoot":"","sources":["../../../../src/server/middlewares/validate-expectation-request.middleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;;;;AAErC,wBAmBK"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const model_1 = require("./model");
|
|
4
|
+
exports.default = model_1.Middleware
|
|
5
|
+
.build(__filename)
|
|
6
|
+
.assignHandler((context, next) => {
|
|
7
|
+
const plainContext = context.toPlain();
|
|
8
|
+
const expectation = context.expectationsStorage.findByContext('request', plainContext);
|
|
9
|
+
if (!expectation) {
|
|
10
|
+
const historyRecord = context.historyStorage
|
|
11
|
+
.register(plainContext)
|
|
12
|
+
.changeState('finished');
|
|
13
|
+
context.webSocketExchange.publish('history:added', historyRecord);
|
|
14
|
+
return context.reply.notFound();
|
|
15
|
+
}
|
|
16
|
+
expectation.increaseExecutionsCounter();
|
|
17
|
+
context.webSocketExchange.publish('expectation:updated', expectation);
|
|
18
|
+
return next({ expectation });
|
|
19
|
+
});
|
|
20
|
+
//# sourceMappingURL=validate-expectation-request.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-expectation-request.middleware.js","sourceRoot":"","sources":["../../../../src/server/middlewares/validate-expectation-request.middleware.ts"],"names":[],"mappings":";;AACA,mCAAqC;AAErC,kBAAe,kBAAU;KACtB,KAAK,CAAC,UAAU,CAAC;KACjB,aAAa,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE;IAC/B,MAAM,YAAY,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IACvC,MAAM,WAAW,GAAG,OAAO,CAAC,mBAAmB,CAAC,aAAa,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;IAEvF,IAAI,CAAC,WAAW,EAAE;QAChB,MAAM,aAAa,GAAG,OAAO,CAAC,cAAc;aACzC,QAAQ,CAAC,YAAY,CAAC;aACtB,WAAW,CAAC,UAAU,CAAC,CAAC;QAE3B,OAAO,CAAC,iBAAiB,CAAC,OAAO,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC;QAClE,OAAO,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;KACjC;IAED,WAAW,CAAC,yBAAyB,EAAE,CAAC;IACxC,OAAO,CAAC,iBAAiB,CAAC,OAAO,CAAC,qBAAqB,EAAE,WAAW,CAAC,CAAC;IAEtE,OAAO,IAAI,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;AAC/B,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/server/models/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
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("./request-context"), exports);
|
|
18
|
+
__exportStar(require("./server-context"), exports);
|
|
19
|
+
__exportStar(require("./reply-service"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/server/models/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,mDAAiC;AACjC,kDAAgC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { RequestContext } from '../../models/request-context';
|
|
2
|
+
export * from './types';
|
|
3
|
+
export declare class ReplyService<T> {
|
|
4
|
+
context: RequestContext<any, T>;
|
|
5
|
+
constructor(context: RequestContext<any, T>);
|
|
6
|
+
ok(payload: T): void;
|
|
7
|
+
internalError(message?: string): void;
|
|
8
|
+
validationError(reasons: unknown[]): void;
|
|
9
|
+
notFound(): void;
|
|
10
|
+
static build<T>(context: RequestContext<any, T>): ReplyService<T>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/server/models/reply-service/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAMnE,cAAc,SAAS,CAAC;AAExB,qBAAa,YAAY,CAAC,CAAC;IACN,OAAO,EAAE,cAAc,CAAC,GAAG,EAAE,CAAC,CAAC;gBAA/B,OAAO,EAAE,cAAc,CAAC,GAAG,EAAE,CAAC,CAAC;IAE3C,EAAE,CAAC,OAAO,EAAE,CAAC;IAab,aAAa,CAAC,OAAO,GAAE,MAA+B;IAatD,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE;IAalC,QAAQ;IAaf,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,OAAO,EAAE,cAAc,CAAC,GAAG,EAAE,CAAC,CAAC;CAGhD"}
|
|
@@ -0,0 +1,76 @@
|
|
|
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
|
+
exports.ReplyService = void 0;
|
|
18
|
+
const utils_1 = require("../../../utils");
|
|
19
|
+
const defaultHeaders = {
|
|
20
|
+
'Content-type': 'Application/json',
|
|
21
|
+
};
|
|
22
|
+
__exportStar(require("./types"), exports);
|
|
23
|
+
class ReplyService {
|
|
24
|
+
constructor(context) {
|
|
25
|
+
this.context = context;
|
|
26
|
+
}
|
|
27
|
+
ok(payload) {
|
|
28
|
+
const data = (0, utils_1.cast)({ status: 'OK', data: payload });
|
|
29
|
+
if (this.context.isFlow('http')) {
|
|
30
|
+
this.context.http.response.writeHead(200, defaultHeaders);
|
|
31
|
+
this.context.http.response.write(JSON.stringify(data));
|
|
32
|
+
this.context.http.response.end();
|
|
33
|
+
}
|
|
34
|
+
if (this.context.isFlow('ws')) {
|
|
35
|
+
this.context.ws.callback(data);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
internalError(message = 'Something went wrong') {
|
|
39
|
+
const data = (0, utils_1.cast)({ status: 'INTERNAL_ERROR', data: { message } });
|
|
40
|
+
if (this.context.isFlow('http')) {
|
|
41
|
+
this.context.http.response.writeHead(500, defaultHeaders);
|
|
42
|
+
this.context.http.response.write(JSON.stringify(data));
|
|
43
|
+
this.context.http.response.end();
|
|
44
|
+
}
|
|
45
|
+
if (this.context.isFlow('ws')) {
|
|
46
|
+
this.context.ws.callback(data);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
validationError(reasons) {
|
|
50
|
+
const data = (0, utils_1.cast)({ status: 'VALIDATION_ERROR', data: { reasons } });
|
|
51
|
+
if (this.context.isFlow('http')) {
|
|
52
|
+
this.context.http.response.writeHead(400, defaultHeaders);
|
|
53
|
+
this.context.http.response.write(JSON.stringify(data));
|
|
54
|
+
this.context.http.response.end();
|
|
55
|
+
}
|
|
56
|
+
if (this.context.isFlow('ws')) {
|
|
57
|
+
this.context.ws.callback(data);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
notFound() {
|
|
61
|
+
const data = (0, utils_1.cast)({ status: 'NOT_FOUND', data: null });
|
|
62
|
+
if (this.context.isFlow('http')) {
|
|
63
|
+
this.context.http.response.writeHead(404, defaultHeaders);
|
|
64
|
+
this.context.http.response.write(JSON.stringify(data));
|
|
65
|
+
this.context.http.response.end();
|
|
66
|
+
}
|
|
67
|
+
if (this.context.isFlow('ws')) {
|
|
68
|
+
this.context.ws.callback(data);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
static build(context) {
|
|
72
|
+
return new ReplyService(context);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
exports.ReplyService = ReplyService;
|
|
76
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/server/models/reply-service/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/server/models/reply-service/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,kBAAkB,CAAC,CAAC;IACnC,MAAM,EAAE,IAAI,GAAG,gBAAgB,GAAG,kBAAkB,GAAG,WAAW,CAAC;IACnE,IAAI,EAAE,CAAC,CAAC;CACT"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/server/models/reply-service/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { IncomingMessage, ServerResponse } from 'http';
|
|
3
|
+
import { IHttpRequestIncommingContext, IRequestPlainContext, IResponsePlainContext, TRequestFlow } from './types';
|
|
4
|
+
import { TRequestMethod, TRequestPayloadType } from '../../../types';
|
|
5
|
+
import type { Expectation } from '../../expectations';
|
|
6
|
+
import type { HistoryRecord } from '../../history';
|
|
7
|
+
import { ServerContext } from '../server-context';
|
|
8
|
+
import { ReplyService } from '../reply-service';
|
|
9
|
+
export * from './types';
|
|
10
|
+
export declare class RequestContext<T extends IHttpRequestIncommingContext = IHttpRequestIncommingContext, U = unknown> extends ServerContext implements IRequestPlainContext<T> {
|
|
11
|
+
method: TRequestMethod;
|
|
12
|
+
path: string;
|
|
13
|
+
payloadType: TRequestPayloadType;
|
|
14
|
+
body: T['body'];
|
|
15
|
+
bodyRaw: string;
|
|
16
|
+
query: T["query"];
|
|
17
|
+
headers: T["headers"];
|
|
18
|
+
http?: {
|
|
19
|
+
request: IncomingMessage;
|
|
20
|
+
response: ServerResponse;
|
|
21
|
+
};
|
|
22
|
+
ws?: {
|
|
23
|
+
callback: TFunction<void>;
|
|
24
|
+
};
|
|
25
|
+
flow: TRequestFlow;
|
|
26
|
+
reply: ReplyService<U>;
|
|
27
|
+
shared: {
|
|
28
|
+
expectation?: Expectation;
|
|
29
|
+
historyRecord?: HistoryRecord;
|
|
30
|
+
forwarded?: {
|
|
31
|
+
request: IRequestPlainContext;
|
|
32
|
+
response: IResponsePlainContext;
|
|
33
|
+
};
|
|
34
|
+
};
|
|
35
|
+
isFlow<K extends TRequestFlow>(flow: K): this is SetRequiredKeys<this, K>;
|
|
36
|
+
extendWithServerContext<Q extends ServerContext>(context: Q): this & Q;
|
|
37
|
+
extendShared<Q extends Partial<RequestContext<T, U>['shared']>>(sourceShared: Q): this & {
|
|
38
|
+
shared: {
|
|
39
|
+
expectation?: Expectation | undefined;
|
|
40
|
+
historyRecord?: HistoryRecord | undefined;
|
|
41
|
+
forwarded?: {
|
|
42
|
+
request: IRequestPlainContext<IHttpRequestIncommingContext>;
|
|
43
|
+
response: IResponsePlainContext;
|
|
44
|
+
} | undefined;
|
|
45
|
+
} & Q;
|
|
46
|
+
};
|
|
47
|
+
assignFlow<K extends TRequestFlow>(flow: K, flowContext: NonNullable<RequestContext<T, U>[K]>): this & {
|
|
48
|
+
[KN in K]: NonNullable<RequestContext<T, U>[K]>;
|
|
49
|
+
} & {
|
|
50
|
+
flow: K;
|
|
51
|
+
};
|
|
52
|
+
assignPayloadType<K extends TRequestPayloadType>(payloadType: K): this & {
|
|
53
|
+
payloadType: K;
|
|
54
|
+
};
|
|
55
|
+
prepareHttpIncommingContext<Q extends SetRequiredKeys<RequestContext, 'http'>>(this: Q): Promise<Q & IRequestPlainContext<IHttpRequestIncommingContext>>;
|
|
56
|
+
assign<T extends Partial<IRequestPlainContext>>(context: T): this & T;
|
|
57
|
+
toPlain(): IRequestPlainContext;
|
|
58
|
+
static build<T extends IHttpRequestIncommingContext = IHttpRequestIncommingContext>(): RequestContext<T, unknown>;
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/server/models/request-context/index.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AAEvD,OAAO,EAAE,4BAA4B,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAClH,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAErE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEhD,cAAc,SAAS,CAAC;AAExB,qBAAa,cAAc,CACzB,CAAC,SAAS,4BAA4B,GAAG,4BAA4B,EACrE,CAAC,GAAG,OAAO,CACX,SAAQ,aAAc,YAAW,oBAAoB,CAAC,CAAC,CAAC;IACjD,MAAM,iBAAsB;IAC5B,IAAI,SAAM;IAEV,WAAW,EAAE,mBAAmB,CAAW;IAE3C,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAa;IAC5B,OAAO,SAAM;IAEb,KAAK,aAAkB;IACvB,OAAO,eAAoB;IAE3B,IAAI,CAAC,EAAE;QACZ,OAAO,EAAE,eAAe,CAAC;QACzB,QAAQ,EAAE,cAAc,CAAC;KAC1B,CAAC;IAEK,EAAE,CAAC,EAAE;QACV,QAAQ,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;KAC3B,CAAC;IAEK,IAAI,EAAE,YAAY,CAAU;IAC5B,KAAK,kBAA+B;IAEpC,MAAM,EAAE;QACb,WAAW,CAAC,EAAE,WAAW,CAAC;QAC1B,aAAa,CAAC,EAAE,aAAa,CAAC;QAC9B,SAAS,CAAC,EAAE;YACV,OAAO,EAAE,oBAAoB,CAAC;YAC9B,QAAQ,EAAE,qBAAqB,CAAC;SACjC,CAAA;KACF,CAAM;IAEA,MAAM,CAAC,CAAC,SAAS,YAAY,EAAE,IAAI,EAAE,CAAC,GAAG,IAAI,IAAI,eAAe,CAAC,IAAI,EAAE,CAAC,CAAC;IAIzE,uBAAuB,CAAC,CAAC,SAAS,aAAa,EAAE,OAAO,EAAE,CAAC;IAI3D,YAAY,CAAC,CAAC,SAAS,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,YAAY,EAAE,CAAC;;;;;;;;;;IAK/E,UAAU,CAAC,CAAC,SAAS,YAAY,EACtC,IAAI,EAAE,CAAC,EACP,WAAW,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAChD,IAAI,GAAG;SAAG,EAAE,IAAI,CAAC,GAAG,WAAW,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KAAE,GAAG;QAAE,IAAI,EAAE,CAAC,CAAA;KAAE;IAIpE,iBAAiB,CAAC,CAAC,SAAS,mBAAmB,EAAE,WAAW,EAAE,CAAC;;;IAIzD,2BAA2B,CAAC,CAAC,SAAS,eAAe,CAAC,cAAc,EAAE,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC;IAK5F,MAAM,CAAC,CAAC,SAAS,OAAO,CAAC,oBAAoB,CAAC,EAAE,OAAO,EAAE,CAAC;IAI1D,OAAO,IAAI,oBAAoB;IActC,MAAM,CAAC,KAAK,CAAC,CAAC,SAAS,4BAA4B,GAAG,4BAA4B;CAGnF"}
|