@acmekit/framework 2.13.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 +0 -0
- package/dist/acmekit-app-loader.d.ts +70 -0
- package/dist/acmekit-app-loader.d.ts.map +1 -0
- package/dist/acmekit-app-loader.js +256 -0
- package/dist/acmekit-app-loader.js.map +1 -0
- package/dist/build-tools/compiler.d.ts +64 -0
- package/dist/build-tools/compiler.d.ts.map +1 -0
- package/dist/build-tools/compiler.js +423 -0
- package/dist/build-tools/compiler.js.map +1 -0
- package/dist/build-tools/index.d.ts +2 -0
- package/dist/build-tools/index.d.ts.map +1 -0
- package/dist/build-tools/index.js +18 -0
- package/dist/build-tools/index.js.map +1 -0
- package/dist/config/config.d.ts +39 -0
- package/dist/config/config.d.ts.map +1 -0
- package/dist/config/config.js +155 -0
- package/dist/config/config.js.map +1 -0
- package/dist/config/index.d.ts +5 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +21 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/loader.d.ts +15 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +39 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/types.d.ts +2 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +3 -0
- package/dist/config/types.js.map +1 -0
- package/dist/container.d.ts +3 -0
- package/dist/container.d.ts.map +1 -0
- package/dist/container.js +21 -0
- package/dist/container.js.map +1 -0
- package/dist/database/index.d.ts +3 -0
- package/dist/database/index.d.ts.map +1 -0
- package/dist/database/index.js +19 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/pg-connection-loader.d.ts +6 -0
- package/dist/database/pg-connection-loader.d.ts.map +1 -0
- package/dist/database/pg-connection-loader.js +68 -0
- package/dist/database/pg-connection-loader.js.map +1 -0
- package/dist/deps/awilix.d.ts +2 -0
- package/dist/deps/awilix.d.ts.map +1 -0
- package/dist/deps/awilix.js +18 -0
- package/dist/deps/awilix.js.map +1 -0
- package/dist/deps/mikro-orm-cli.d.ts +2 -0
- package/dist/deps/mikro-orm-cli.d.ts.map +1 -0
- package/dist/deps/mikro-orm-cli.js +18 -0
- package/dist/deps/mikro-orm-cli.js.map +1 -0
- package/dist/deps/mikro-orm-core.d.ts +2 -0
- package/dist/deps/mikro-orm-core.d.ts.map +1 -0
- package/dist/deps/mikro-orm-core.js +18 -0
- package/dist/deps/mikro-orm-core.js.map +1 -0
- package/dist/deps/mikro-orm-knex.d.ts +2 -0
- package/dist/deps/mikro-orm-knex.d.ts.map +1 -0
- package/dist/deps/mikro-orm-knex.js +18 -0
- package/dist/deps/mikro-orm-knex.js.map +1 -0
- package/dist/deps/mikro-orm-migrations.d.ts +2 -0
- package/dist/deps/mikro-orm-migrations.d.ts.map +1 -0
- package/dist/deps/mikro-orm-migrations.js +18 -0
- package/dist/deps/mikro-orm-migrations.js.map +1 -0
- package/dist/deps/mikro-orm-postgresql.d.ts +2 -0
- package/dist/deps/mikro-orm-postgresql.d.ts.map +1 -0
- package/dist/deps/mikro-orm-postgresql.js +18 -0
- package/dist/deps/mikro-orm-postgresql.js.map +1 -0
- package/dist/deps/opentelemetry-api.d.ts +2 -0
- package/dist/deps/opentelemetry-api.d.ts.map +1 -0
- package/dist/deps/opentelemetry-api.js +18 -0
- package/dist/deps/opentelemetry-api.js.map +1 -0
- package/dist/deps/opentelemetry-instrumentation-pg.d.ts +2 -0
- package/dist/deps/opentelemetry-instrumentation-pg.d.ts.map +1 -0
- package/dist/deps/opentelemetry-instrumentation-pg.js +18 -0
- package/dist/deps/opentelemetry-instrumentation-pg.js.map +1 -0
- package/dist/deps/opentelemetry-resources.d.ts +2 -0
- package/dist/deps/opentelemetry-resources.d.ts.map +1 -0
- package/dist/deps/opentelemetry-resources.js +18 -0
- package/dist/deps/opentelemetry-resources.js.map +1 -0
- package/dist/deps/opentelemetry-sdk-node.d.ts +2 -0
- package/dist/deps/opentelemetry-sdk-node.d.ts.map +1 -0
- package/dist/deps/opentelemetry-sdk-node.js +18 -0
- package/dist/deps/opentelemetry-sdk-node.js.map +1 -0
- package/dist/deps/opentelemetry-sdk-trace-node.d.ts +2 -0
- package/dist/deps/opentelemetry-sdk-trace-node.d.ts.map +1 -0
- package/dist/deps/opentelemetry-sdk-trace-node.js +18 -0
- package/dist/deps/opentelemetry-sdk-trace-node.js.map +1 -0
- package/dist/deps/pg.d.ts +2 -0
- package/dist/deps/pg.d.ts.map +1 -0
- package/dist/deps/pg.js +18 -0
- package/dist/deps/pg.js.map +1 -0
- package/dist/deps/zod.d.ts +2 -0
- package/dist/deps/zod.d.ts.map +1 -0
- package/dist/deps/zod.js +18 -0
- package/dist/deps/zod.js.map +1 -0
- package/dist/feature-flags/feature-flag-loader.d.ts +7 -0
- package/dist/feature-flags/feature-flag-loader.d.ts.map +1 -0
- package/dist/feature-flags/feature-flag-loader.js +34 -0
- package/dist/feature-flags/feature-flag-loader.js.map +1 -0
- package/dist/feature-flags/flag-router.d.ts +32 -0
- package/dist/feature-flags/flag-router.d.ts.map +1 -0
- package/dist/feature-flags/flag-router.js +67 -0
- package/dist/feature-flags/flag-router.js.map +1 -0
- package/dist/feature-flags/index.d.ts +5 -0
- package/dist/feature-flags/index.d.ts.map +1 -0
- package/dist/feature-flags/index.js +21 -0
- package/dist/feature-flags/index.js.map +1 -0
- package/dist/feature-flags/types.d.ts +31 -0
- package/dist/feature-flags/types.d.ts.map +1 -0
- package/dist/feature-flags/types.js +3 -0
- package/dist/feature-flags/types.js.map +1 -0
- package/dist/http/express-loader.d.ts +10 -0
- package/dist/http/express-loader.d.ts.map +1 -0
- package/dist/http/express-loader.js +130 -0
- package/dist/http/express-loader.js.map +1 -0
- package/dist/http/index.d.ts +15 -0
- package/dist/http/index.d.ts.map +1 -0
- package/dist/http/index.js +31 -0
- package/dist/http/index.js.map +1 -0
- package/dist/http/middleware-file-loader.d.ts +33 -0
- package/dist/http/middleware-file-loader.d.ts.map +1 -0
- package/dist/http/middleware-file-loader.js +186 -0
- package/dist/http/middleware-file-loader.js.map +1 -0
- package/dist/http/middlewares/apply-default-filters.d.ts +3 -0
- package/dist/http/middlewares/apply-default-filters.d.ts.map +1 -0
- package/dist/http/middlewares/apply-default-filters.js +32 -0
- package/dist/http/middlewares/apply-default-filters.js.map +1 -0
- package/dist/http/middlewares/apply-locale.d.ts +12 -0
- package/dist/http/middlewares/apply-locale.d.ts.map +1 -0
- package/dist/http/middlewares/apply-locale.js +31 -0
- package/dist/http/middlewares/apply-locale.js.map +1 -0
- package/dist/http/middlewares/apply-params-as-filters.d.ts +5 -0
- package/dist/http/middlewares/apply-params-as-filters.d.ts.map +1 -0
- package/dist/http/middlewares/apply-params-as-filters.js +14 -0
- package/dist/http/middlewares/apply-params-as-filters.js.map +1 -0
- package/dist/http/middlewares/authenticate-middleware.d.ts +14 -0
- package/dist/http/middlewares/authenticate-middleware.d.ts.map +1 -0
- package/dist/http/middlewares/authenticate-middleware.js +142 -0
- package/dist/http/middlewares/authenticate-middleware.js.map +1 -0
- package/dist/http/middlewares/bodyparser.d.ts +13 -0
- package/dist/http/middlewares/bodyparser.d.ts.map +1 -0
- package/dist/http/middlewares/bodyparser.js +62 -0
- package/dist/http/middlewares/bodyparser.js.map +1 -0
- package/dist/http/middlewares/check-permissions.d.ts +15 -0
- package/dist/http/middlewares/check-permissions.d.ts.map +1 -0
- package/dist/http/middlewares/check-permissions.js +54 -0
- package/dist/http/middlewares/check-permissions.js.map +1 -0
- package/dist/http/middlewares/clear-filters-by-key.d.ts +3 -0
- package/dist/http/middlewares/clear-filters-by-key.d.ts.map +1 -0
- package/dist/http/middlewares/clear-filters-by-key.js +12 -0
- package/dist/http/middlewares/clear-filters-by-key.js.map +1 -0
- package/dist/http/middlewares/ensure-publishable-api-key.d.ts +3 -0
- package/dist/http/middlewares/ensure-publishable-api-key.d.ts.map +1 -0
- package/dist/http/middlewares/ensure-publishable-api-key.js +58 -0
- package/dist/http/middlewares/ensure-publishable-api-key.js.map +1 -0
- package/dist/http/middlewares/error-handler.d.ts +21 -0
- package/dist/http/middlewares/error-handler.d.ts.map +1 -0
- package/dist/http/middlewares/error-handler.js +107 -0
- package/dist/http/middlewares/error-handler.js.map +1 -0
- package/dist/http/middlewares/exception-formatter.d.ts +9 -0
- package/dist/http/middlewares/exception-formatter.d.ts.map +1 -0
- package/dist/http/middlewares/exception-formatter.js +36 -0
- package/dist/http/middlewares/exception-formatter.js.map +1 -0
- package/dist/http/middlewares/index.d.ts +10 -0
- package/dist/http/middlewares/index.d.ts.map +1 -0
- package/dist/http/middlewares/index.js +26 -0
- package/dist/http/middlewares/index.js.map +1 -0
- package/dist/http/middlewares/set-context.d.ts +3 -0
- package/dist/http/middlewares/set-context.d.ts.map +1 -0
- package/dist/http/middlewares/set-context.js +18 -0
- package/dist/http/middlewares/set-context.js.map +1 -0
- package/dist/http/router.d.ts +36 -0
- package/dist/http/router.d.ts.map +1 -0
- package/dist/http/router.js +317 -0
- package/dist/http/router.js.map +1 -0
- package/dist/http/routes-finder.d.ts +22 -0
- package/dist/http/routes-finder.d.ts.map +1 -0
- package/dist/http/routes-finder.js +68 -0
- package/dist/http/routes-finder.js.map +1 -0
- package/dist/http/routes-loader.d.ts +39 -0
- package/dist/http/routes-loader.d.ts.map +1 -0
- package/dist/http/routes-loader.js +232 -0
- package/dist/http/routes-loader.js.map +1 -0
- package/dist/http/routes-sorter.d.ts +105 -0
- package/dist/http/routes-sorter.d.ts.map +1 -0
- package/dist/http/routes-sorter.js +146 -0
- package/dist/http/routes-sorter.js.map +1 -0
- package/dist/http/types.d.ts +191 -0
- package/dist/http/types.d.ts.map +1 -0
- package/dist/http/types.js +16 -0
- package/dist/http/types.js.map +1 -0
- package/dist/http/utils/define-middlewares.d.ts +22 -0
- package/dist/http/utils/define-middlewares.d.ts.map +1 -0
- package/dist/http/utils/define-middlewares.js +27 -0
- package/dist/http/utils/define-middlewares.js.map +1 -0
- package/dist/http/utils/field-filtering/field-parser.d.ts +32 -0
- package/dist/http/utils/field-filtering/field-parser.d.ts.map +1 -0
- package/dist/http/utils/field-filtering/field-parser.js +87 -0
- package/dist/http/utils/field-filtering/field-parser.js.map +1 -0
- package/dist/http/utils/field-filtering/field-validator.d.ts +24 -0
- package/dist/http/utils/field-filtering/field-validator.d.ts.map +1 -0
- package/dist/http/utils/field-filtering/field-validator.js +67 -0
- package/dist/http/utils/field-filtering/field-validator.js.map +1 -0
- package/dist/http/utils/field-filtering/index.d.ts +33 -0
- package/dist/http/utils/field-filtering/index.d.ts.map +1 -0
- package/dist/http/utils/field-filtering/index.js +9 -0
- package/dist/http/utils/field-filtering/index.js.map +1 -0
- package/dist/http/utils/get-query-config.d.ts +50 -0
- package/dist/http/utils/get-query-config.d.ts.map +1 -0
- package/dist/http/utils/get-query-config.js +109 -0
- package/dist/http/utils/get-query-config.js.map +1 -0
- package/dist/http/utils/http-compression.d.ts +5 -0
- package/dist/http/utils/http-compression.d.ts.map +1 -0
- package/dist/http/utils/http-compression.js +33 -0
- package/dist/http/utils/http-compression.js.map +1 -0
- package/dist/http/utils/maybe-apply-link-filter.d.ts +8 -0
- package/dist/http/utils/maybe-apply-link-filter.d.ts.map +1 -0
- package/dist/http/utils/maybe-apply-link-filter.js +68 -0
- package/dist/http/utils/maybe-apply-link-filter.js.map +1 -0
- package/dist/http/utils/policies/rbac-field-filter.d.ts +19 -0
- package/dist/http/utils/policies/rbac-field-filter.d.ts.map +1 -0
- package/dist/http/utils/policies/rbac-field-filter.js +348 -0
- package/dist/http/utils/policies/rbac-field-filter.js.map +1 -0
- package/dist/http/utils/refetch-entities.d.ts +21 -0
- package/dist/http/utils/refetch-entities.d.ts.map +1 -0
- package/dist/http/utils/refetch-entities.js +42 -0
- package/dist/http/utils/refetch-entities.js.map +1 -0
- package/dist/http/utils/restricted-fields.d.ts +6 -0
- package/dist/http/utils/restricted-fields.d.ts.map +1 -0
- package/dist/http/utils/restricted-fields.js +30 -0
- package/dist/http/utils/restricted-fields.js.map +1 -0
- package/dist/http/utils/unless-path.d.ts +9 -0
- package/dist/http/utils/unless-path.d.ts.map +1 -0
- package/dist/http/utils/unless-path.js +19 -0
- package/dist/http/utils/unless-path.js.map +1 -0
- package/dist/http/utils/validate-body.d.ts +5 -0
- package/dist/http/utils/validate-body.d.ts.map +1 -0
- package/dist/http/utils/validate-body.js +23 -0
- package/dist/http/utils/validate-body.js.map +1 -0
- package/dist/http/utils/validate-query.d.ts +6 -0
- package/dist/http/utils/validate-query.d.ts.map +1 -0
- package/dist/http/utils/validate-query.js +84 -0
- package/dist/http/utils/validate-query.js.map +1 -0
- package/dist/http/utils/wrap-handler.d.ts +3 -0
- package/dist/http/utils/wrap-handler.d.ts.map +1 -0
- package/dist/http/utils/wrap-handler.js +26 -0
- package/dist/http/utils/wrap-handler.js.map +1 -0
- package/dist/index.d.ts +18 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +36 -0
- package/dist/index.js.map +1 -0
- package/dist/jobs/index.d.ts +2 -0
- package/dist/jobs/index.d.ts.map +1 -0
- package/dist/jobs/index.js +18 -0
- package/dist/jobs/index.js.map +1 -0
- package/dist/jobs/job-loader.d.ts +44 -0
- package/dist/jobs/job-loader.d.ts.map +1 -0
- package/dist/jobs/job-loader.js +91 -0
- package/dist/jobs/job-loader.js.map +1 -0
- package/dist/links/index.d.ts +2 -0
- package/dist/links/index.d.ts.map +1 -0
- package/dist/links/index.js +18 -0
- package/dist/links/index.js.map +1 -0
- package/dist/links/link-loader.d.ts +11 -0
- package/dist/links/link-loader.d.ts.map +1 -0
- package/dist/links/link-loader.js +76 -0
- package/dist/links/link-loader.js.map +1 -0
- package/dist/logger/index.d.ts +3 -0
- package/dist/logger/index.d.ts.map +1 -0
- package/dist/logger/index.js +9 -0
- package/dist/logger/index.js.map +1 -0
- package/dist/migrations/index.d.ts +3 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/migrations/index.js +19 -0
- package/dist/migrations/index.js.map +1 -0
- package/dist/migrations/migrator.d.ts +38 -0
- package/dist/migrations/migrator.d.ts.map +1 -0
- package/dist/migrations/migrator.js +146 -0
- package/dist/migrations/migrator.js.map +1 -0
- package/dist/migrations/run-migration-scripts.d.ts +17 -0
- package/dist/migrations/run-migration-scripts.d.ts.map +1 -0
- package/dist/migrations/run-migration-scripts.js +97 -0
- package/dist/migrations/run-migration-scripts.js.map +1 -0
- package/dist/mikro-orm-cli/bin.d.ts +14 -0
- package/dist/mikro-orm-cli/bin.d.ts.map +1 -0
- package/dist/mikro-orm-cli/bin.js +54 -0
- package/dist/mikro-orm-cli/bin.js.map +1 -0
- package/dist/modules-sdk/index.d.ts +2 -0
- package/dist/modules-sdk/index.d.ts.map +1 -0
- package/dist/modules-sdk/index.js +18 -0
- package/dist/modules-sdk/index.js.map +1 -0
- package/dist/orchestration/index.d.ts +2 -0
- package/dist/orchestration/index.d.ts.map +1 -0
- package/dist/orchestration/index.js +18 -0
- package/dist/orchestration/index.js.map +1 -0
- package/dist/policies/has-permission.d.ts +33 -0
- package/dist/policies/has-permission.d.ts.map +1 -0
- package/dist/policies/has-permission.js +110 -0
- package/dist/policies/has-permission.js.map +1 -0
- package/dist/policies/index.d.ts +3 -0
- package/dist/policies/index.d.ts.map +1 -0
- package/dist/policies/index.js +19 -0
- package/dist/policies/index.js.map +1 -0
- package/dist/policies/policy-loader.d.ts +6 -0
- package/dist/policies/policy-loader.d.ts.map +1 -0
- package/dist/policies/policy-loader.js +17 -0
- package/dist/policies/policy-loader.js.map +1 -0
- package/dist/subscribers/index.d.ts +3 -0
- package/dist/subscribers/index.d.ts.map +1 -0
- package/dist/subscribers/index.js +19 -0
- package/dist/subscribers/index.js.map +1 -0
- package/dist/subscribers/subscriber-loader.d.ts +20 -0
- package/dist/subscribers/subscriber-loader.d.ts.map +1 -0
- package/dist/subscribers/subscriber-loader.js +156 -0
- package/dist/subscribers/subscriber-loader.js.map +1 -0
- package/dist/subscribers/types.d.ts +15 -0
- package/dist/subscribers/types.d.ts.map +1 -0
- package/dist/subscribers/types.js +3 -0
- package/dist/subscribers/types.js.map +1 -0
- package/dist/telemetry/index.d.ts +50 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +81 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/types/container.d.ts +68 -0
- package/dist/types/container.d.ts.map +1 -0
- package/dist/types/container.js +3 -0
- package/dist/types/container.js.map +1 -0
- package/dist/types/index.d.ts +6 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +19 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/index.d.ts +5 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +21 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/resource-loader.d.ts +28 -0
- package/dist/utils/resource-loader.d.ts.map +1 -0
- package/dist/utils/resource-loader.js +78 -0
- package/dist/utils/resource-loader.js.map +1 -0
- package/dist/workflows/index.d.ts +3 -0
- package/dist/workflows/index.d.ts.map +1 -0
- package/dist/workflows/index.js +19 -0
- package/dist/workflows/index.js.map +1 -0
- package/dist/workflows/workflow-loader.d.ts +13 -0
- package/dist/workflows/workflow-loader.d.ts.map +1 -0
- package/dist/workflows/workflow-loader.js +36 -0
- package/dist/workflows/workflow-loader.js.map +1 -0
- package/dist/workflows-sdk/composer.d.ts +2 -0
- package/dist/workflows-sdk/composer.d.ts.map +1 -0
- package/dist/workflows-sdk/composer.js +18 -0
- package/dist/workflows-sdk/composer.js.map +1 -0
- package/dist/workflows-sdk/index.d.ts +3 -0
- package/dist/workflows-sdk/index.d.ts.map +1 -0
- package/dist/workflows-sdk/index.js +19 -0
- package/dist/workflows-sdk/index.js.map +1 -0
- package/dist/zod/index.d.ts +2 -0
- package/dist/zod/index.d.ts.map +1 -0
- package/dist/zod/index.js +18 -0
- package/dist/zod/index.js.map +1 -0
- package/dist/zod/zod-helpers.d.ts +3 -0
- package/dist/zod/zod-helpers.d.ts.map +1 -0
- package/dist/zod/zod-helpers.js +95 -0
- package/dist/zod/zod-helpers.js.map +1 -0
- package/package.json +121 -0
|
@@ -0,0 +1,62 @@
|
|
|
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.createBodyParserMiddlewaresStack = createBodyParserMiddlewaresStack;
|
|
7
|
+
const lodash_memoize_1 = __importDefault(require("lodash.memoize"));
|
|
8
|
+
const reporter_1 = __importDefault(require("@acmekit/cli/dist/reporter"));
|
|
9
|
+
const express_1 = require("express");
|
|
10
|
+
/**
|
|
11
|
+
* Parsers to use for parsing the HTTP request body
|
|
12
|
+
*/
|
|
13
|
+
const parsers = {
|
|
14
|
+
json: (0, lodash_memoize_1.default)(function jsonParserMiddleware(options) {
|
|
15
|
+
return (0, express_1.json)({
|
|
16
|
+
limit: options?.sizeLimit,
|
|
17
|
+
verify: options?.preserveRawBody
|
|
18
|
+
? (req, res, buf) => {
|
|
19
|
+
req.rawBody = buf;
|
|
20
|
+
}
|
|
21
|
+
: undefined,
|
|
22
|
+
});
|
|
23
|
+
}),
|
|
24
|
+
text: (0, lodash_memoize_1.default)(function textParser(options) {
|
|
25
|
+
return (0, express_1.text)({
|
|
26
|
+
limit: options?.sizeLimit,
|
|
27
|
+
});
|
|
28
|
+
}),
|
|
29
|
+
urlencoded: (0, lodash_memoize_1.default)(function urlencodedParserMiddleware(options) {
|
|
30
|
+
return (0, express_1.urlencoded)({
|
|
31
|
+
limit: options?.sizeLimit,
|
|
32
|
+
extended: true,
|
|
33
|
+
});
|
|
34
|
+
}),
|
|
35
|
+
};
|
|
36
|
+
/**
|
|
37
|
+
* Creates the bodyparser middlewares stack that creates custom bodyparsers
|
|
38
|
+
* during an HTTP request based upon the defined config. The bodyparser
|
|
39
|
+
* instances are cached for re-use.
|
|
40
|
+
*/
|
|
41
|
+
function createBodyParserMiddlewaresStack(route, routesFinder, tracer) {
|
|
42
|
+
return ["json", "text", "urlencoded"].map((parser) => {
|
|
43
|
+
function bodyParser(req, res, next) {
|
|
44
|
+
const matchingRoute = routesFinder.find(req.path, req.method);
|
|
45
|
+
const parserMiddleware = parsers[parser];
|
|
46
|
+
if (!matchingRoute) {
|
|
47
|
+
return parserMiddleware()(req, res, next);
|
|
48
|
+
}
|
|
49
|
+
if (matchingRoute.config === false) {
|
|
50
|
+
reporter_1.default.debug(`skipping ${parser} bodyparser middleware ${req.method} ${req.path}`);
|
|
51
|
+
return next();
|
|
52
|
+
}
|
|
53
|
+
reporter_1.default.debug(`using custom ${parser} bodyparser config ${req.method} ${req.path}`);
|
|
54
|
+
return parserMiddleware(matchingRoute.config)(req, res, next);
|
|
55
|
+
}
|
|
56
|
+
Object.defineProperty(bodyParser, "name", {
|
|
57
|
+
value: `${parser}BodyParser`,
|
|
58
|
+
});
|
|
59
|
+
return (tracer ? tracer(bodyParser, { route }) : bodyParser);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=bodyparser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bodyparser.js","sourceRoot":"","sources":["../../../src/http/middlewares/bodyparser.ts"],"names":[],"mappings":";;;;;AAgDA,4EA+CC;AA/FD,oEAAoC;AACpC,0EAA+C;AAC/C,qCAA8E;AAY9E;;GAEG;AACH,MAAM,OAAO,GAAG;IACd,IAAI,EAAE,IAAA,wBAAO,EAAC,SAAS,oBAAoB,CAAC,OAA0B;QACpE,OAAO,IAAA,cAAI,EAAC;YACV,KAAK,EAAE,OAAO,EAAE,SAAS;YACzB,MAAM,EAAE,OAAO,EAAE,eAAe;gBAC9B,CAAC,CAAC,CAAC,GAAmB,EAAE,GAAoB,EAAE,GAAW,EAAE,EAAE;oBACzD,GAAG,CAAC,OAAO,GAAG,GAAG,CAAA;gBACnB,CAAC;gBACH,CAAC,CAAC,SAAS;SACd,CAAC,CAAA;IACJ,CAAC,CAAC;IACF,IAAI,EAAE,IAAA,wBAAO,EAAC,SAAS,UAAU,CAAC,OAA0B;QAC1D,OAAO,IAAA,cAAI,EAAC;YACV,KAAK,EAAE,OAAO,EAAE,SAAS;SAC1B,CAAC,CAAA;IACJ,CAAC,CAAC;IACF,UAAU,EAAE,IAAA,wBAAO,EAAC,SAAS,0BAA0B,CACrD,OAA0B;QAE1B,OAAO,IAAA,oBAAU,EAAC;YAChB,KAAK,EAAE,OAAO,EAAE,SAAS;YACzB,QAAQ,EAAE,IAAI;SACf,CAAC,CAAA;IACJ,CAAC,CAAC;CACH,CAAA;AAED;;;;GAIG;AACH,SAAgB,gCAAgC,CAC9C,KAAa,EACb,YAAiD,EACjD,MAGwC;IAExC,OAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,YAAY,CAA8B,CAAC,GAAG,CACrE,CAAC,MAAM,EAAE,EAAE;QACT,SAAS,UAAU,CACjB,GAAmB,EACnB,GAAoB,EACpB,IAAkB;YAElB,MAAM,aAAa,GAAG,YAAY,CAAC,IAAI,CACrC,GAAG,CAAC,IAAI,EACR,GAAG,CAAC,MAAwB,CAC7B,CAAA;YACD,MAAM,gBAAgB,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;YAExC,IAAI,CAAC,aAAa,EAAE,CAAC;gBACnB,OAAO,gBAAgB,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAA;YAC3C,CAAC;YAED,IAAI,aAAa,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;gBACnC,kBAAM,CAAC,KAAK,CACV,YAAY,MAAM,0BAA0B,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,IAAI,EAAE,CACrE,CAAA;gBACD,OAAO,IAAI,EAAE,CAAA;YACf,CAAC;YAED,kBAAM,CAAC,KAAK,CACV,gBAAgB,MAAM,sBAAsB,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,IAAI,EAAE,CACrE,CAAA;YACD,OAAO,gBAAgB,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAA;QAC/D,CAAC;QAED,MAAM,CAAC,cAAc,CAAC,UAAU,EAAE,MAAM,EAAE;YACxC,KAAK,EAAE,GAAG,MAAM,YAAY;SAC7B,CAAC,CAAA;QAEF,OAAO,CACL,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAClC,CAAA;IACrB,CAAC,CACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { MiddlewareFunction } from "../types";
|
|
2
|
+
export type PolicyAction = {
|
|
3
|
+
resource: string;
|
|
4
|
+
operation: string | string[];
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* Wraps a middleware or route handler with RBAC permission checking.
|
|
8
|
+
* Checks if the authenticated user has the required policies before executing the handler.
|
|
9
|
+
*
|
|
10
|
+
* @param handler - The original middleware or route handler to wrap
|
|
11
|
+
* @param policies - Single policy or array of policies to check
|
|
12
|
+
* @returns Wrapped middleware or route function that checks permissions first
|
|
13
|
+
*/
|
|
14
|
+
export declare function wrapWithPoliciesCheck(handler: MiddlewareFunction, policies: PolicyAction | PolicyAction[]): MiddlewareFunction;
|
|
15
|
+
//# sourceMappingURL=check-permissions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-permissions.d.ts","sourceRoot":"","sources":["../../../src/http/middlewares/check-permissions.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAIV,kBAAkB,EACnB,MAAM,UAAU,CAAA;AAEjB,MAAM,MAAM,YAAY,GAAG;IACzB,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;CAC7B,CAAA;AA0CD;;;;;;;GAOG;AACH,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,kBAAkB,EAC3B,QAAQ,EAAE,YAAY,GAAG,YAAY,EAAE,GACtC,kBAAkB,CAgBpB"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.wrapWithPoliciesCheck = wrapWithPoliciesCheck;
|
|
4
|
+
const utils_1 = require("@acmekit/utils");
|
|
5
|
+
const has_permission_1 = require("../../policies/has-permission");
|
|
6
|
+
/**
|
|
7
|
+
* Core permission checking logic for middleware and routes
|
|
8
|
+
*/
|
|
9
|
+
async function checkPermissions(policies, req) {
|
|
10
|
+
// Normalize policies to array
|
|
11
|
+
const policyList = Array.isArray(policies) ? policies : [policies];
|
|
12
|
+
if (!policyList.length) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const authContext = req.auth_context;
|
|
16
|
+
// Get roles from JWT token's app_metadata
|
|
17
|
+
const roleIds = authContext?.app_metadata?.roles || [];
|
|
18
|
+
if (!roleIds.length) {
|
|
19
|
+
throw new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.FORBIDDEN, "Forbidden");
|
|
20
|
+
}
|
|
21
|
+
const hasAccess = await (0, has_permission_1.hasPermission)({
|
|
22
|
+
roles: roleIds,
|
|
23
|
+
actions: policyList,
|
|
24
|
+
container: req.scope,
|
|
25
|
+
});
|
|
26
|
+
if (!hasAccess) {
|
|
27
|
+
const policyKeys = policyList
|
|
28
|
+
.map((p) => `${p.resource}:${p.operation}`)
|
|
29
|
+
.join(", ");
|
|
30
|
+
throw new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.FORBIDDEN, `Insufficient permissions. Required policies: ${policyKeys}`);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Wraps a middleware or route handler with RBAC permission checking.
|
|
35
|
+
* Checks if the authenticated user has the required policies before executing the handler.
|
|
36
|
+
*
|
|
37
|
+
* @param handler - The original middleware or route handler to wrap
|
|
38
|
+
* @param policies - Single policy or array of policies to check
|
|
39
|
+
* @returns Wrapped middleware or route function that checks permissions first
|
|
40
|
+
*/
|
|
41
|
+
function wrapWithPoliciesCheck(handler, policies) {
|
|
42
|
+
return async (req, res, next) => {
|
|
43
|
+
try {
|
|
44
|
+
req.policies ??= [];
|
|
45
|
+
req.policies.push(...(Array.isArray(policies) ? policies : [policies]));
|
|
46
|
+
await checkPermissions(policies, req);
|
|
47
|
+
return handler(req, res, next);
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
return next(error);
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=check-permissions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-permissions.js","sourceRoot":"","sources":["../../../src/http/middlewares/check-permissions.ts"],"names":[],"mappings":";;AA8DA,sDAmBC;AAjFD,0CAA6C;AAC7C,kEAA6D;AAa7D;;GAEG;AACH,KAAK,UAAU,gBAAgB,CAC7B,QAAuC,EACvC,GAAgC;IAEhC,8BAA8B;IAC9B,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;IAElE,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QACvB,OAAM;IACR,CAAC;IAED,MAAM,WAAW,GAAG,GAAG,CAAC,YAAY,CAAA;IACpC,0CAA0C;IAC1C,MAAM,OAAO,GAAI,WAAW,EAAE,YAAY,EAAE,KAAkB,IAAI,EAAE,CAAA;IAEpE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;QACpB,MAAM,IAAI,oBAAY,CAAC,oBAAY,CAAC,KAAK,CAAC,SAAS,EAAE,WAAW,CAAC,CAAA;IACnE,CAAC;IAED,MAAM,SAAS,GAAG,MAAM,IAAA,8BAAa,EAAC;QACpC,KAAK,EAAE,OAAO;QACd,OAAO,EAAE,UAAU;QACnB,SAAS,EAAE,GAAG,CAAC,KAAK;KACrB,CAAC,CAAA;IAEF,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,UAAU,GAAG,UAAU;aAC1B,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,SAAS,EAAE,CAAC;aAC1C,IAAI,CAAC,IAAI,CAAC,CAAA;QAEb,MAAM,IAAI,oBAAY,CACpB,oBAAY,CAAC,KAAK,CAAC,SAAS,EAC5B,gDAAgD,UAAU,EAAE,CAC7D,CAAA;IACH,CAAC;AACH,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,qBAAqB,CACnC,OAA2B,EAC3B,QAAuC;IAEvC,OAAO,KAAK,EACV,GAAgC,EAChC,GAAoB,EACpB,IAAyB,EACzB,EAAE;QACF,IAAI,CAAC;YACH,GAAG,CAAC,QAAQ,KAAK,EAAE,CAAA;YACnB,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAA;YAEvE,MAAM,gBAAgB,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAA;YACrC,OAAO,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAA;QAChC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,IAAI,CAAC,KAAK,CAAC,CAAA;QACpB,CAAC;IACH,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { AcmeKitNextFunction, AcmeKitRequest, AcmeKitResponse } from "../types";
|
|
2
|
+
export declare function clearFiltersByKey(keys: string[]): (req: AcmeKitRequest, _: AcmeKitResponse, next: AcmeKitNextFunction) => Promise<void>;
|
|
3
|
+
//# sourceMappingURL=clear-filters-by-key.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clear-filters-by-key.d.ts","sourceRoot":"","sources":["../../../src/http/middlewares/clear-filters-by-key.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,mBAAmB,EACnB,cAAc,EACd,eAAe,EAChB,MAAM,UAAU,CAAA;AAEjB,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,IAE5C,KAAK,cAAc,EACnB,GAAG,eAAe,EAClB,MAAM,mBAAmB,mBAQ5B"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.clearFiltersByKey = clearFiltersByKey;
|
|
4
|
+
function clearFiltersByKey(keys) {
|
|
5
|
+
return async function clearFiltersByKeyMiddleware(req, _, next) {
|
|
6
|
+
keys.forEach((key) => {
|
|
7
|
+
delete req.filterableFields[key];
|
|
8
|
+
});
|
|
9
|
+
return next();
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=clear-filters-by-key.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clear-filters-by-key.js","sourceRoot":"","sources":["../../../src/http/middlewares/clear-filters-by-key.ts"],"names":[],"mappings":";;AAMA,8CAYC;AAZD,SAAgB,iBAAiB,CAAC,IAAc;IAC9C,OAAO,KAAK,UAAU,2BAA2B,CAC/C,GAAmB,EACnB,CAAkB,EAClB,IAAyB;QAEzB,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YACnB,OAAO,GAAG,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAA;QAClC,CAAC,CAAC,CAAA;QAEF,OAAO,IAAI,EAAE,CAAA;IACf,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { AcmeKitNextFunction, AcmeKitResponse, AcmeKitStoreRequest } from "../../http";
|
|
2
|
+
export declare function ensurePublishableApiKeyMiddleware(req: AcmeKitStoreRequest, _: AcmeKitResponse, next: AcmeKitNextFunction): Promise<void>;
|
|
3
|
+
//# sourceMappingURL=ensure-publishable-api-key.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ensure-publishable-api-key.d.ts","sourceRoot":"","sources":["../../../src/http/middlewares/ensure-publishable-api-key.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EACV,mBAAmB,EACnB,eAAe,EACf,mBAAmB,EACpB,MAAM,YAAY,CAAA;AAEnB,wBAAsB,iCAAiC,CACrD,GAAG,EAAE,mBAAmB,EACxB,CAAC,EAAE,eAAe,EAClB,IAAI,EAAE,mBAAmB,iBAuE1B"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ensurePublishableApiKeyMiddleware = ensurePublishableApiKeyMiddleware;
|
|
4
|
+
const utils_1 = require("@acmekit/utils");
|
|
5
|
+
async function ensurePublishableApiKeyMiddleware(req, _, next) {
|
|
6
|
+
const publishableApiKey = req.get(utils_1.PUBLISHABLE_KEY_HEADER);
|
|
7
|
+
if (!(0, utils_1.isPresent)(publishableApiKey)) {
|
|
8
|
+
const error = new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.NOT_ALLOWED, `Publishable API key required in the request header: ${utils_1.PUBLISHABLE_KEY_HEADER}. You can manage your keys in settings in the dashboard.`);
|
|
9
|
+
return next(error);
|
|
10
|
+
}
|
|
11
|
+
let apiKey;
|
|
12
|
+
const query = req.scope.resolve(utils_1.ContainerRegistrationKeys.QUERY);
|
|
13
|
+
try {
|
|
14
|
+
// Cache API key data and check revocation in memory
|
|
15
|
+
const { data } = await query.graph({
|
|
16
|
+
entity: "api_key",
|
|
17
|
+
fields: [
|
|
18
|
+
"id",
|
|
19
|
+
"token",
|
|
20
|
+
"revoked_at",
|
|
21
|
+
"sales_channels_link.sales_channel_id",
|
|
22
|
+
],
|
|
23
|
+
filters: {
|
|
24
|
+
token: publishableApiKey,
|
|
25
|
+
type: utils_1.ApiKeyType.PUBLISHABLE,
|
|
26
|
+
},
|
|
27
|
+
}, {
|
|
28
|
+
cache: {
|
|
29
|
+
enable: true,
|
|
30
|
+
},
|
|
31
|
+
});
|
|
32
|
+
if (data.length) {
|
|
33
|
+
const now = new Date();
|
|
34
|
+
const cachedApiKey = data[0];
|
|
35
|
+
const isRevoked = !!cachedApiKey.revoked_at && new Date(cachedApiKey.revoked_at) <= now;
|
|
36
|
+
if (!isRevoked) {
|
|
37
|
+
apiKey = cachedApiKey;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
catch (e) {
|
|
42
|
+
return next(e);
|
|
43
|
+
}
|
|
44
|
+
if (!apiKey) {
|
|
45
|
+
try {
|
|
46
|
+
throw new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.NOT_ALLOWED, `A valid publishable key is required to proceed with the request`);
|
|
47
|
+
}
|
|
48
|
+
catch (e) {
|
|
49
|
+
return next(e);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
req.publishable_key_context = {
|
|
53
|
+
key: apiKey.token,
|
|
54
|
+
sales_channel_ids: apiKey.sales_channels_link.map((link) => link.sales_channel_id),
|
|
55
|
+
};
|
|
56
|
+
return next();
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=ensure-publishable-api-key.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ensure-publishable-api-key.js","sourceRoot":"","sources":["../../../src/http/middlewares/ensure-publishable-api-key.ts"],"names":[],"mappings":";;AAaA,8EA0EC;AAvFD,0CAMuB;AAOhB,KAAK,UAAU,iCAAiC,CACrD,GAAwB,EACxB,CAAkB,EAClB,IAAyB;IAEzB,MAAM,iBAAiB,GAAG,GAAG,CAAC,GAAG,CAAC,8BAAsB,CAAC,CAAA;IAEzD,IAAI,CAAC,IAAA,iBAAS,EAAC,iBAAiB,CAAC,EAAE,CAAC;QAClC,MAAM,KAAK,GAAG,IAAI,oBAAY,CAC5B,oBAAY,CAAC,KAAK,CAAC,WAAW,EAC9B,uDAAuD,8BAAsB,0DAA0D,CACxI,CAAA;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,CAAA;IACpB,CAAC;IAED,IAAI,MAAM,CAAA;IACV,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,iCAAyB,CAAC,KAAK,CAAC,CAAA;IAEhE,IAAI,CAAC;QACH,oDAAoD;QACpD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,KAAK,CAChC;YACE,MAAM,EAAE,SAAS;YACjB,MAAM,EAAE;gBACN,IAAI;gBACJ,OAAO;gBACP,YAAY;gBACZ,sCAAsC;aACvC;YACD,OAAO,EAAE;gBACP,KAAK,EAAE,iBAAiB;gBACxB,IAAI,EAAE,kBAAU,CAAC,WAAW;aAC7B;SACF,EACD;YACE,KAAK,EAAE;gBACL,MAAM,EAAE,IAAI;aACb;SACF,CACF,CAAA;QAED,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAA;YACtB,MAAM,YAAY,GAAG,IAAI,CAAC,CAAC,CAAC,CAAA;YAC5B,MAAM,SAAS,GACb,CAAC,CAAC,YAAY,CAAC,UAAU,IAAI,IAAI,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,GAAG,CAAA;YAEvE,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,MAAM,GAAG,YAAY,CAAA;YACvB,CAAC;QACH,CAAC;IACH,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,IAAI,CAAC,CAAC,CAAC,CAAA;IAChB,CAAC;IAED,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,IAAI,CAAC;YACH,MAAM,IAAI,oBAAY,CACpB,oBAAY,CAAC,KAAK,CAAC,WAAW,EAC9B,iEAAiE,CAClE,CAAA;QACH,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,IAAI,CAAC,CAAC,CAAC,CAAA;QAChB,CAAC;IACH,CAAC;IAED,GAAG,CAAC,uBAAuB,GAAG;QAC5B,GAAG,EAAE,MAAM,CAAC,KAAK;QACjB,iBAAiB,EAAE,MAAM,CAAC,mBAAmB,CAAC,GAAG,CAC/C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAChC;KACF,CAAA;IAED,OAAO,IAAI,EAAE,CAAA;AACf,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { ErrorRequestHandler } from "express";
|
|
2
|
+
export declare function errorHandler(): ErrorRequestHandler;
|
|
3
|
+
/**
|
|
4
|
+
* @schema Error
|
|
5
|
+
* title: "Response Error"
|
|
6
|
+
* type: object
|
|
7
|
+
* properties:
|
|
8
|
+
* code:
|
|
9
|
+
* type: string
|
|
10
|
+
* description: A slug code to indicate the type of the error.
|
|
11
|
+
* enum: [invalid_state_error, invalid_request_error, api_error, unknown_error]
|
|
12
|
+
* message:
|
|
13
|
+
* type: string
|
|
14
|
+
* description: Description of the error that occurred.
|
|
15
|
+
* example: "first_name must be a string"
|
|
16
|
+
* type:
|
|
17
|
+
* type: string
|
|
18
|
+
* description: A slug indicating the type of the error.
|
|
19
|
+
* enum: [QueryRunnerAlreadyReleasedError, TransactionAlreadyStartedError, TransactionNotStartedError, conflict, unauthorized, payment_authorization_error, duplicate_error, not_allowed, invalid_data, not_found, database_error, unexpected_state, invalid_argument, unknown_error]
|
|
20
|
+
*/
|
|
21
|
+
//# sourceMappingURL=error-handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-handler.d.ts","sourceRoot":"","sources":["../../../src/http/middlewares/error-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAA0B,MAAM,SAAS,CAAA;AAerE,wBAAgB,YAAY,IAuFV,mBAAmB,CACpC;AAED;;;;;;;;;;;;;;;;;GAiBG"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.errorHandler = errorHandler;
|
|
4
|
+
const zod_validation_error_1 = require("zod-validation-error");
|
|
5
|
+
const utils_1 = require("@acmekit/utils");
|
|
6
|
+
const exception_formatter_1 = require("./exception-formatter");
|
|
7
|
+
const QUERY_RUNNER_RELEASED = "QueryRunnerAlreadyReleasedError";
|
|
8
|
+
const TRANSACTION_STARTED = "TransactionAlreadyStartedError";
|
|
9
|
+
const TRANSACTION_NOT_STARTED = "TransactionNotStartedError";
|
|
10
|
+
const API_ERROR = "api_error";
|
|
11
|
+
const INVALID_REQUEST_ERROR = "invalid_request_error";
|
|
12
|
+
const INVALID_STATE_ERROR = "invalid_state_error";
|
|
13
|
+
function errorHandler() {
|
|
14
|
+
return function coreErrorHandler(err, req, res, _) {
|
|
15
|
+
const logger = req.scope
|
|
16
|
+
? req.scope.resolve(utils_1.ContainerRegistrationKeys.LOGGER)
|
|
17
|
+
: console;
|
|
18
|
+
if (!req.scope) {
|
|
19
|
+
logger.error("req.scope is missing unexpectedly. It should be defined in all the cases");
|
|
20
|
+
}
|
|
21
|
+
err = (0, exception_formatter_1.formatException)(err);
|
|
22
|
+
const errorType = err.type || err.name;
|
|
23
|
+
const errObj = {
|
|
24
|
+
code: err.code,
|
|
25
|
+
type: err.type,
|
|
26
|
+
message: err.message,
|
|
27
|
+
};
|
|
28
|
+
let statusCode = 500;
|
|
29
|
+
switch (errorType) {
|
|
30
|
+
case QUERY_RUNNER_RELEASED:
|
|
31
|
+
case TRANSACTION_STARTED:
|
|
32
|
+
case TRANSACTION_NOT_STARTED:
|
|
33
|
+
case utils_1.AcmeKitError.Types.CONFLICT:
|
|
34
|
+
statusCode = 409;
|
|
35
|
+
errObj.code = INVALID_STATE_ERROR;
|
|
36
|
+
errObj.message =
|
|
37
|
+
"The request conflicted with another request. You may retry the request with the provided Idempotency-Key.";
|
|
38
|
+
break;
|
|
39
|
+
case utils_1.AcmeKitError.Types.UNAUTHORIZED:
|
|
40
|
+
statusCode = 401;
|
|
41
|
+
break;
|
|
42
|
+
case utils_1.AcmeKitError.Types.FORBIDDEN:
|
|
43
|
+
statusCode = 403;
|
|
44
|
+
break;
|
|
45
|
+
case utils_1.AcmeKitError.Types.PAYMENT_AUTHORIZATION_ERROR:
|
|
46
|
+
statusCode = 422;
|
|
47
|
+
break;
|
|
48
|
+
case utils_1.AcmeKitError.Types.DUPLICATE_ERROR:
|
|
49
|
+
statusCode = 422;
|
|
50
|
+
errObj.code = INVALID_REQUEST_ERROR;
|
|
51
|
+
break;
|
|
52
|
+
case utils_1.AcmeKitError.Types.NOT_ALLOWED:
|
|
53
|
+
case utils_1.AcmeKitError.Types.INVALID_DATA:
|
|
54
|
+
statusCode = 400;
|
|
55
|
+
break;
|
|
56
|
+
case utils_1.AcmeKitError.Types.NOT_FOUND:
|
|
57
|
+
statusCode = 404;
|
|
58
|
+
break;
|
|
59
|
+
case utils_1.AcmeKitError.Types.DB_ERROR:
|
|
60
|
+
statusCode = 500;
|
|
61
|
+
errObj.code = API_ERROR;
|
|
62
|
+
break;
|
|
63
|
+
case utils_1.AcmeKitError.Types.UNEXPECTED_STATE:
|
|
64
|
+
case utils_1.AcmeKitError.Types.INVALID_ARGUMENT:
|
|
65
|
+
break;
|
|
66
|
+
default:
|
|
67
|
+
errObj.code = "unknown_error";
|
|
68
|
+
errObj.message = "An unknown error occurred.";
|
|
69
|
+
errObj.type = "unknown_error";
|
|
70
|
+
break;
|
|
71
|
+
}
|
|
72
|
+
if (statusCode >= 500) {
|
|
73
|
+
logger.error(err);
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
logger.info(err.message);
|
|
77
|
+
}
|
|
78
|
+
if ("issues" in err && Array.isArray(err.issues)) {
|
|
79
|
+
const messages = err.issues.map((issue) => (0, zod_validation_error_1.fromZodIssue)(issue).toString());
|
|
80
|
+
res.status(statusCode).json({
|
|
81
|
+
type: utils_1.AcmeKitError.Types.INVALID_DATA,
|
|
82
|
+
message: messages.join("\n"),
|
|
83
|
+
});
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
res.status(statusCode).json(errObj);
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* @schema Error
|
|
91
|
+
* title: "Response Error"
|
|
92
|
+
* type: object
|
|
93
|
+
* properties:
|
|
94
|
+
* code:
|
|
95
|
+
* type: string
|
|
96
|
+
* description: A slug code to indicate the type of the error.
|
|
97
|
+
* enum: [invalid_state_error, invalid_request_error, api_error, unknown_error]
|
|
98
|
+
* message:
|
|
99
|
+
* type: string
|
|
100
|
+
* description: Description of the error that occurred.
|
|
101
|
+
* example: "first_name must be a string"
|
|
102
|
+
* type:
|
|
103
|
+
* type: string
|
|
104
|
+
* description: A slug indicating the type of the error.
|
|
105
|
+
* enum: [QueryRunnerAlreadyReleasedError, TransactionAlreadyStartedError, TransactionNotStartedError, conflict, unauthorized, payment_authorization_error, duplicate_error, not_allowed, invalid_data, not_found, database_error, unexpected_state, invalid_argument, unknown_error]
|
|
106
|
+
*/
|
|
107
|
+
//# sourceMappingURL=error-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-handler.js","sourceRoot":"","sources":["../../../src/http/middlewares/error-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AcmeKitError } from "@acmekit/utils";
|
|
2
|
+
export declare enum PostgresError {
|
|
3
|
+
DUPLICATE_ERROR = "23505",
|
|
4
|
+
FOREIGN_KEY_ERROR = "23503",
|
|
5
|
+
SERIALIZATION_FAILURE = "40001",
|
|
6
|
+
NULL_VIOLATION = "23502"
|
|
7
|
+
}
|
|
8
|
+
export declare const formatException: (err: any) => AcmeKitError;
|
|
9
|
+
//# sourceMappingURL=exception-formatter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exception-formatter.d.ts","sourceRoot":"","sources":["../../../src/http/middlewares/exception-formatter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAE7C,oBAAY,aAAa;IACvB,eAAe,UAAU;IACzB,iBAAiB,UAAU;IAC3B,qBAAqB,UAAU;IAC/B,cAAc,UAAU;CACzB;AAED,eAAO,MAAM,eAAe,GAAI,QAAG,KAAG,YA8CrC,CAAA"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.formatException = exports.PostgresError = void 0;
|
|
4
|
+
const utils_1 = require("@acmekit/utils");
|
|
5
|
+
var PostgresError;
|
|
6
|
+
(function (PostgresError) {
|
|
7
|
+
PostgresError["DUPLICATE_ERROR"] = "23505";
|
|
8
|
+
PostgresError["FOREIGN_KEY_ERROR"] = "23503";
|
|
9
|
+
PostgresError["SERIALIZATION_FAILURE"] = "40001";
|
|
10
|
+
PostgresError["NULL_VIOLATION"] = "23502";
|
|
11
|
+
})(PostgresError || (exports.PostgresError = PostgresError = {}));
|
|
12
|
+
const formatException = (err) => {
|
|
13
|
+
switch (err.code) {
|
|
14
|
+
case PostgresError.DUPLICATE_ERROR:
|
|
15
|
+
return new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.DUPLICATE_ERROR, `${err.table.charAt(0).toUpperCase()}${err.table.slice(1)} with ${err.detail.slice(4).replace(/[()=]/g, (s) => {
|
|
16
|
+
return s === "=" ? " " : "";
|
|
17
|
+
})}`);
|
|
18
|
+
case PostgresError.FOREIGN_KEY_ERROR: {
|
|
19
|
+
const matches = /Key \(([\w-\d]+)\)=\(([\w-\d]+)\) is not present in table "(\w+)"/g.exec(err.detail);
|
|
20
|
+
if (matches?.length !== 4) {
|
|
21
|
+
return new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.NOT_FOUND, JSON.stringify(matches));
|
|
22
|
+
}
|
|
23
|
+
return new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.NOT_FOUND, `${matches[3]?.charAt(0).toUpperCase()}${matches[3]?.slice(1)} with ${matches[1]} ${matches[2]} does not exist.`);
|
|
24
|
+
}
|
|
25
|
+
case PostgresError.SERIALIZATION_FAILURE: {
|
|
26
|
+
return new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.CONFLICT, err?.detail ?? err?.message);
|
|
27
|
+
}
|
|
28
|
+
case PostgresError.NULL_VIOLATION: {
|
|
29
|
+
return new utils_1.AcmeKitError(utils_1.AcmeKitError.Types.INVALID_DATA, `Can't insert null value in field ${err?.column} on insert in table ${err?.table}`);
|
|
30
|
+
}
|
|
31
|
+
default:
|
|
32
|
+
return err;
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
exports.formatException = formatException;
|
|
36
|
+
//# sourceMappingURL=exception-formatter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exception-formatter.js","sourceRoot":"","sources":["../../../src/http/middlewares/exception-formatter.ts"],"names":[],"mappings":";;;AAAA,0CAA6C;AAE7C,IAAY,aAKX;AALD,WAAY,aAAa;IACvB,0CAAyB,CAAA;IACzB,4CAA2B,CAAA;IAC3B,gDAA+B,CAAA;IAC/B,yCAAwB,CAAA;AAC1B,CAAC,EALW,aAAa,6BAAb,aAAa,QAKxB;AAEM,MAAM,eAAe,GAAG,CAAC,GAAG,EAAgB,EAAE;IACnD,QAAQ,GAAG,CAAC,IAAI,EAAE,CAAC;QACjB,KAAK,aAAa,CAAC,eAAe;YAChC,OAAO,IAAI,oBAAY,CACrB,oBAAY,CAAC,KAAK,CAAC,eAAe,EAClC,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CACpD,CAAC,CACF,SAAS,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;gBACpD,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAA;YAC7B,CAAC,CAAC,EAAE,CACL,CAAA;QACH,KAAK,aAAa,CAAC,iBAAiB,CAAC,CAAC,CAAC;YACrC,MAAM,OAAO,GACX,oEAAoE,CAAC,IAAI,CACvE,GAAG,CAAC,MAAM,CACX,CAAA;YAEH,IAAI,OAAO,EAAE,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC1B,OAAO,IAAI,oBAAY,CACrB,oBAAY,CAAC,KAAK,CAAC,SAAS,EAC5B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CACxB,CAAA;YACH,CAAC;YAED,OAAO,IAAI,oBAAY,CACrB,oBAAY,CAAC,KAAK,CAAC,SAAS,EAC5B,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,SAC3D,OAAO,CAAC,CAAC,CACX,IAAI,OAAO,CAAC,CAAC,CAAC,kBAAkB,CACjC,CAAA;QACH,CAAC;QACD,KAAK,aAAa,CAAC,qBAAqB,CAAC,CAAC,CAAC;YACzC,OAAO,IAAI,oBAAY,CACrB,oBAAY,CAAC,KAAK,CAAC,QAAQ,EAC3B,GAAG,EAAE,MAAM,IAAI,GAAG,EAAE,OAAO,CAC5B,CAAA;QACH,CAAC;QACD,KAAK,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC;YAClC,OAAO,IAAI,oBAAY,CACrB,oBAAY,CAAC,KAAK,CAAC,YAAY,EAC/B,oCAAoC,GAAG,EAAE,MAAM,uBAAuB,GAAG,EAAE,KAAK,EAAE,CACnF,CAAA;QACH,CAAC;QACD;YACE,OAAO,GAAG,CAAA;IACd,CAAC;AACH,CAAC,CAAA;AA9CY,QAAA,eAAe,mBA8C3B"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from "./apply-default-filters";
|
|
2
|
+
export * from "./apply-locale";
|
|
3
|
+
export * from "./apply-params-as-filters";
|
|
4
|
+
export * from "./authenticate-middleware";
|
|
5
|
+
export * from "./check-permissions";
|
|
6
|
+
export * from "./clear-filters-by-key";
|
|
7
|
+
export * from "./error-handler";
|
|
8
|
+
export * from "./exception-formatter";
|
|
9
|
+
export * from "./set-context";
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/http/middlewares/index.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAA;AACvC,cAAc,gBAAgB,CAAA;AAC9B,cAAc,2BAA2B,CAAA;AACzC,cAAc,2BAA2B,CAAA;AACzC,cAAc,qBAAqB,CAAA;AACnC,cAAc,wBAAwB,CAAA;AACtC,cAAc,iBAAiB,CAAA;AAC/B,cAAc,uBAAuB,CAAA;AACrC,cAAc,eAAe,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
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("./apply-default-filters"), exports);
|
|
18
|
+
__exportStar(require("./apply-locale"), exports);
|
|
19
|
+
__exportStar(require("./apply-params-as-filters"), exports);
|
|
20
|
+
__exportStar(require("./authenticate-middleware"), exports);
|
|
21
|
+
__exportStar(require("./check-permissions"), exports);
|
|
22
|
+
__exportStar(require("./clear-filters-by-key"), exports);
|
|
23
|
+
__exportStar(require("./error-handler"), exports);
|
|
24
|
+
__exportStar(require("./exception-formatter"), exports);
|
|
25
|
+
__exportStar(require("./set-context"), exports);
|
|
26
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/http/middlewares/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAuC;AACvC,iDAA8B;AAC9B,4DAAyC;AACzC,4DAAyC;AACzC,sDAAmC;AACnC,yDAAsC;AACtC,kDAA+B;AAC/B,wDAAqC;AACrC,gDAA6B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"set-context.d.ts","sourceRoot":"","sources":["../../../src/http/middlewares/set-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,cAAc,EAAE,MAAM,UAAU,CAAA;AAE9D,wBAAgB,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,IACvC,KAAK,cAAc,EAAE,MAAC,EAAE,MAAM,mBAAmB,mBAiBhE"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.setContext = setContext;
|
|
4
|
+
function setContext(context) {
|
|
5
|
+
return async (req, _, next) => {
|
|
6
|
+
const ctx = { ...(req.context || {}) };
|
|
7
|
+
for (const [contextKey, contextValue] of Object.entries(context || {})) {
|
|
8
|
+
let valueToApply = contextValue;
|
|
9
|
+
if (typeof contextValue === "function") {
|
|
10
|
+
valueToApply = await contextValue(req, ctx);
|
|
11
|
+
}
|
|
12
|
+
ctx[contextKey] = valueToApply;
|
|
13
|
+
}
|
|
14
|
+
req.context = ctx;
|
|
15
|
+
return next();
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=set-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"set-context.js","sourceRoot":"","sources":["../../../src/http/middlewares/set-context.ts"],"names":[],"mappings":";;AAEA,gCAkBC;AAlBD,SAAgB,UAAU,CAAC,OAA4B;IACrD,OAAO,KAAK,EAAE,GAAmB,EAAE,CAAC,EAAE,IAAyB,EAAE,EAAE;QACjE,MAAM,GAAG,GAAwB,EAAE,GAAG,CAAC,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,CAAA;QAE3D,KAAK,MAAM,CAAC,UAAU,EAAE,YAAY,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,CAAC;YACvE,IAAI,YAAY,GAAG,YAAY,CAAA;YAE/B,IAAI,OAAO,YAAY,KAAK,UAAU,EAAE,CAAC;gBACvC,YAAY,GAAG,MAAM,YAAY,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YAC7C,CAAC;YAED,GAAG,CAAC,UAAU,CAAC,GAAG,YAAY,CAAA;QAChC,CAAC;QAED,GAAG,CAAC,OAAO,GAAG,GAAG,CAAA;QAEjB,OAAO,IAAI,EAAE,CAAA;IACf,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import type { Express, RequestHandler } from "express";
|
|
2
|
+
import type { MiddlewareFunction, RouteHandler } from "./types";
|
|
3
|
+
import { AcmeKitContainer } from "@acmekit/types";
|
|
4
|
+
export declare class ApiLoader {
|
|
5
|
+
#private;
|
|
6
|
+
/**
|
|
7
|
+
* Wrap the original route handler implementation for
|
|
8
|
+
* instrumentation.
|
|
9
|
+
*/
|
|
10
|
+
static traceRoute?: (handler: RouteHandler, route: {
|
|
11
|
+
route: string;
|
|
12
|
+
method: string;
|
|
13
|
+
}) => RouteHandler;
|
|
14
|
+
/**
|
|
15
|
+
* Wrap the original middleware handler implementation for
|
|
16
|
+
* instrumentation.
|
|
17
|
+
*/
|
|
18
|
+
static traceMiddleware?: (handler: RequestHandler | MiddlewareFunction, route: {
|
|
19
|
+
route: string;
|
|
20
|
+
method?: string;
|
|
21
|
+
}) => RequestHandler | MiddlewareFunction;
|
|
22
|
+
constructor({ app, sourceDir, baseRestrictedFields, container, }: {
|
|
23
|
+
app: Express;
|
|
24
|
+
sourceDir: string | string[];
|
|
25
|
+
baseRestrictedFields?: string[];
|
|
26
|
+
container: AcmeKitContainer;
|
|
27
|
+
});
|
|
28
|
+
load(): Promise<void>;
|
|
29
|
+
/**
|
|
30
|
+
* Clear all API resources registered by this loader
|
|
31
|
+
* This removes all routes and middleware added after the initial stack state
|
|
32
|
+
* Used by HMR to reset the API state before reloading
|
|
33
|
+
*/
|
|
34
|
+
clearAllResources(): void;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=router.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"router.d.ts","sourceRoot":"","sources":["../../src/http/router.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAEV,OAAO,EAEP,cAAc,EACf,MAAM,SAAS,CAAA;AAChB,OAAO,KAAK,EAOV,kBAAkB,EAGlB,YAAY,EACb,MAAM,SAAS,CAAA;AAEhB,OAAO,EAAU,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AAezD,qBAAa,SAAS;;IACpB;;;OAGG;IACH,MAAM,CAAC,UAAU,CAAC,EAAE,CAClB,OAAO,EAAE,YAAY,EACrB,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,KACrC,YAAY,CAAA;IAEjB;;;OAGG;IACH,MAAM,CAAC,eAAe,CAAC,EAAE,CACvB,OAAO,EAAE,cAAc,GAAG,kBAAkB,EAC5C,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,KACtC,cAAc,GAAG,kBAAkB,CAAA;gBAgB5B,EACV,GAAG,EACH,SAAS,EACT,oBAAyB,EACzB,SAAS,GACV,EAAE;QACD,GAAG,EAAE,OAAO,CAAA;QACZ,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;QAC5B,oBAAoB,CAAC,EAAE,MAAM,EAAE,CAAA;QAC/B,SAAS,EAAE,gBAAgB,CAAA;KAC5B;IA+VK,IAAI;IAoHV;;;;OAIG;IACH,iBAAiB;CASlB"}
|