@strapi/core 0.0.0-experimental.e3e48deb89bd0a1b6cc69b698696566fa7854a95 → 0.0.0-experimental.e576af447d9f97e89e24c6daa32d8f714376cd5f
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.
Potentially problematic release.
This version of @strapi/core might be problematic. Click here for more details.
- package/LICENSE +18 -3
- package/dist/Strapi.d.ts +49 -58
- package/dist/Strapi.d.ts.map +1 -1
- package/dist/configuration/config-loader.d.ts.map +1 -1
- package/dist/configuration/get-dirs.d.ts +10 -0
- package/dist/configuration/get-dirs.d.ts.map +1 -0
- package/dist/configuration/index.d.ts +4 -7
- package/dist/configuration/index.d.ts.map +1 -1
- package/dist/container.d.ts +2 -2
- package/dist/container.d.ts.map +1 -1
- package/dist/core-api/controller/collection-type.d.ts +3 -3
- package/dist/core-api/controller/collection-type.d.ts.map +1 -1
- package/dist/core-api/controller/index.d.ts +3 -3
- package/dist/core-api/controller/index.d.ts.map +1 -1
- package/dist/core-api/controller/single-type.d.ts +3 -3
- package/dist/core-api/controller/single-type.d.ts.map +1 -1
- package/dist/core-api/controller/transform.d.ts +2 -2
- package/dist/core-api/controller/transform.d.ts.map +1 -1
- package/dist/core-api/routes/index.d.ts.map +1 -1
- package/dist/core-api/service/collection-type.d.ts +11 -17
- package/dist/core-api/service/collection-type.d.ts.map +1 -1
- package/dist/core-api/service/index.d.ts +3 -3
- package/dist/core-api/service/index.d.ts.map +1 -1
- package/dist/core-api/service/pagination.d.ts +4 -11
- package/dist/core-api/service/pagination.d.ts.map +1 -1
- package/dist/core-api/service/single-type.d.ts +4 -4
- package/dist/core-api/service/single-type.d.ts.map +1 -1
- package/dist/domain/content-type/index.d.ts +1 -1
- package/dist/domain/content-type/index.d.ts.map +1 -1
- package/dist/domain/module/index.d.ts +24 -23
- package/dist/domain/module/index.d.ts.map +1 -1
- package/dist/ee/index.d.ts +4 -2
- package/dist/ee/index.d.ts.map +1 -1
- package/dist/ee/license.d.ts +2 -2
- package/dist/ee/license.d.ts.map +1 -1
- package/dist/factories.d.ts +10 -10
- package/dist/factories.d.ts.map +1 -1
- package/dist/index.d.ts +18 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +10103 -5
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +10079 -5
- package/dist/index.mjs.map +1 -1
- package/dist/loaders/admin.d.ts +2 -2
- package/dist/loaders/admin.d.ts.map +1 -1
- package/dist/loaders/apis.d.ts +2 -2
- package/dist/loaders/apis.d.ts.map +1 -1
- package/dist/loaders/components.d.ts +2 -2
- package/dist/loaders/components.d.ts.map +1 -1
- package/dist/loaders/index.d.ts +2 -2
- package/dist/loaders/index.d.ts.map +1 -1
- package/dist/loaders/middlewares.d.ts +2 -2
- package/dist/loaders/middlewares.d.ts.map +1 -1
- package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
- package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
- package/dist/loaders/plugins/index.d.ts +2 -2
- package/dist/loaders/plugins/index.d.ts.map +1 -1
- package/dist/loaders/policies.d.ts +2 -2
- package/dist/loaders/policies.d.ts.map +1 -1
- package/dist/loaders/sanitizers.d.ts +2 -2
- package/dist/loaders/sanitizers.d.ts.map +1 -1
- package/dist/loaders/src-index.d.ts +2 -2
- package/dist/loaders/src-index.d.ts.map +1 -1
- package/dist/loaders/validators.d.ts +2 -2
- package/dist/loaders/validators.d.ts.map +1 -1
- package/dist/middlewares/body.d.ts +4 -4
- package/dist/middlewares/body.d.ts.map +1 -1
- package/dist/middlewares/compression.d.ts +2 -2
- package/dist/middlewares/compression.d.ts.map +1 -1
- package/dist/middlewares/cors.d.ts +2 -2
- package/dist/middlewares/cors.d.ts.map +1 -1
- package/dist/middlewares/errors.d.ts +2 -2
- package/dist/middlewares/errors.d.ts.map +1 -1
- package/dist/middlewares/favicon.d.ts +2 -2
- package/dist/middlewares/favicon.d.ts.map +1 -1
- package/dist/middlewares/index.d.ts +2 -2
- package/dist/middlewares/index.d.ts.map +1 -1
- package/dist/middlewares/ip.d.ts +2 -2
- package/dist/middlewares/ip.d.ts.map +1 -1
- package/dist/middlewares/logger.d.ts +2 -2
- package/dist/middlewares/logger.d.ts.map +1 -1
- package/dist/middlewares/powered-by.d.ts +2 -2
- package/dist/middlewares/powered-by.d.ts.map +1 -1
- package/dist/middlewares/public.d.ts +2 -2
- package/dist/middlewares/public.d.ts.map +1 -1
- package/dist/middlewares/query.d.ts +2 -2
- package/dist/middlewares/query.d.ts.map +1 -1
- package/dist/middlewares/response-time.d.ts +2 -2
- package/dist/middlewares/response-time.d.ts.map +1 -1
- package/dist/middlewares/responses.d.ts +3 -3
- package/dist/middlewares/responses.d.ts.map +1 -1
- package/dist/middlewares/security.d.ts +2 -2
- package/dist/middlewares/security.d.ts.map +1 -1
- package/dist/middlewares/session.d.ts +2 -2
- package/dist/middlewares/session.d.ts.map +1 -1
- package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
- package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
- package/dist/migrations/draft-publish.d.ts +2 -2
- package/dist/migrations/draft-publish.d.ts.map +1 -1
- package/dist/migrations/i18n.d.ts +5 -0
- package/dist/migrations/i18n.d.ts.map +1 -0
- package/dist/migrations/index.d.ts +5 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/providers/admin.d.ts +3 -0
- package/dist/providers/admin.d.ts.map +1 -0
- package/dist/providers/coreStore.d.ts +3 -0
- package/dist/providers/coreStore.d.ts.map +1 -0
- package/dist/providers/cron.d.ts +3 -0
- package/dist/providers/cron.d.ts.map +1 -0
- package/dist/providers/index.d.ts +3 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/provider.d.ts +9 -0
- package/dist/providers/provider.d.ts.map +1 -0
- package/dist/providers/registries.d.ts +3 -0
- package/dist/providers/registries.d.ts.map +1 -0
- package/dist/providers/telemetry.d.ts +3 -0
- package/dist/providers/telemetry.d.ts.map +1 -0
- package/dist/providers/webhooks.d.ts +3 -0
- package/dist/providers/webhooks.d.ts.map +1 -0
- package/dist/registries/apis.d.ts +2 -2
- package/dist/registries/apis.d.ts.map +1 -1
- package/dist/registries/components.d.ts +6 -6
- package/dist/registries/components.d.ts.map +1 -1
- package/dist/registries/content-types.d.ts +5 -5
- package/dist/registries/content-types.d.ts.map +1 -1
- package/dist/registries/controllers.d.ts +10 -10
- package/dist/registries/controllers.d.ts.map +1 -1
- package/dist/registries/custom-fields.d.ts +3 -3
- package/dist/registries/custom-fields.d.ts.map +1 -1
- package/dist/registries/index.d.ts +0 -1
- package/dist/registries/index.d.ts.map +1 -1
- package/dist/registries/middlewares.d.ts +6 -6
- package/dist/registries/middlewares.d.ts.map +1 -1
- package/dist/registries/modules.d.ts +2 -2
- package/dist/registries/modules.d.ts.map +1 -1
- package/dist/registries/plugins.d.ts +5 -5
- package/dist/registries/plugins.d.ts.map +1 -1
- package/dist/registries/policies.d.ts +22 -10
- package/dist/registries/policies.d.ts.map +1 -1
- package/dist/registries/services.d.ts +8 -8
- package/dist/registries/services.d.ts.map +1 -1
- package/dist/services/auth/index.d.ts +4 -4
- package/dist/services/auth/index.d.ts.map +1 -1
- package/dist/services/config.d.ts +3 -0
- package/dist/services/config.d.ts.map +1 -0
- package/dist/services/content-api/index.d.ts +31 -15
- package/dist/services/content-api/index.d.ts.map +1 -1
- package/dist/services/content-api/permissions/index.d.ts +13 -15
- package/dist/services/content-api/permissions/index.d.ts.map +1 -1
- package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
- package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
- package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
- package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
- package/dist/services/core-store.d.ts.map +1 -1
- package/dist/services/cron.d.ts +5 -5
- package/dist/services/cron.d.ts.map +1 -1
- package/dist/services/custom-fields.d.ts +2 -2
- package/dist/services/custom-fields.d.ts.map +1 -1
- package/dist/services/document-service/attributes/index.d.ts +6 -0
- package/dist/services/document-service/attributes/index.d.ts.map +1 -0
- package/dist/services/document-service/attributes/transforms.d.ts +10 -0
- package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
- package/dist/services/document-service/common.d.ts +2 -2
- package/dist/services/document-service/common.d.ts.map +1 -1
- package/dist/services/document-service/components.d.ts +25 -1
- package/dist/services/document-service/components.d.ts.map +1 -1
- package/dist/services/document-service/draft-and-publish.d.ts +7 -7
- package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
- package/dist/services/document-service/entries.d.ts +10 -0
- package/dist/services/document-service/entries.d.ts.map +1 -0
- package/dist/services/document-service/events.d.ts +25 -0
- package/dist/services/document-service/events.d.ts.map +1 -0
- package/dist/services/document-service/index.d.ts +3 -4
- package/dist/services/document-service/index.d.ts.map +1 -1
- package/dist/services/document-service/internationalization.d.ts +5 -5
- package/dist/services/document-service/internationalization.d.ts.map +1 -1
- package/dist/services/document-service/middlewares/errors.d.ts +6 -0
- package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
- package/dist/services/document-service/middlewares/index.d.ts +3 -0
- package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
- package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
- package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
- package/dist/services/document-service/params.d.ts +3 -1
- package/dist/services/document-service/params.d.ts.map +1 -1
- package/dist/services/document-service/repository.d.ts.map +1 -1
- package/dist/services/document-service/transform/data.d.ts.map +1 -1
- package/dist/services/document-service/transform/fields.d.ts +2 -2
- package/dist/services/document-service/transform/fields.d.ts.map +1 -1
- package/dist/services/document-service/transform/id-map.d.ts +3 -3
- package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
- package/dist/services/document-service/transform/id-transform.d.ts +2 -2
- package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
- package/dist/services/document-service/transform/populate.d.ts +2 -2
- package/dist/services/document-service/transform/populate.d.ts.map +1 -1
- package/dist/services/document-service/transform/query.d.ts +5 -0
- package/dist/services/document-service/transform/query.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
- package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
- package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
- package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
- package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
- package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
- package/dist/services/document-service/transform/types.d.ts +3 -3
- package/dist/services/document-service/transform/types.d.ts.map +1 -1
- package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
- package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
- package/dist/services/document-service/utils/populate.d.ts +2 -2
- package/dist/services/document-service/utils/populate.d.ts.map +1 -1
- package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
- package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
- package/dist/services/entity-service/index.d.ts +4 -4
- package/dist/services/entity-service/index.d.ts.map +1 -1
- package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
- package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
- package/dist/services/entity-validator/index.d.ts +16 -2
- package/dist/services/entity-validator/index.d.ts.map +1 -1
- package/dist/services/entity-validator/validators.d.ts +36 -25
- package/dist/services/entity-validator/validators.d.ts.map +1 -1
- package/dist/services/event-hub.d.ts +1 -0
- package/dist/services/event-hub.d.ts.map +1 -1
- package/dist/services/features.d.ts +3 -3
- package/dist/services/features.d.ts.map +1 -1
- package/dist/services/fs.d.ts +2 -2
- package/dist/services/fs.d.ts.map +1 -1
- package/dist/services/metrics/admin-user-hash.d.ts +2 -2
- package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
- package/dist/services/metrics/index.d.ts +2 -2
- package/dist/services/metrics/index.d.ts.map +1 -1
- package/dist/services/metrics/middleware.d.ts +2 -2
- package/dist/services/metrics/middleware.d.ts.map +1 -1
- package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
- package/dist/services/metrics/sender.d.ts +3 -3
- package/dist/services/metrics/sender.d.ts.map +1 -1
- package/dist/services/query-params.d.ts +7 -0
- package/dist/services/query-params.d.ts.map +1 -0
- package/dist/services/reloader.d.ts +7 -0
- package/dist/services/reloader.d.ts.map +1 -0
- package/dist/services/server/admin-api.d.ts +3 -3
- package/dist/services/server/admin-api.d.ts.map +1 -1
- package/dist/services/server/api.d.ts +3 -3
- package/dist/services/server/api.d.ts.map +1 -1
- package/dist/services/server/compose-endpoint.d.ts +2 -2
- package/dist/services/server/compose-endpoint.d.ts.map +1 -1
- package/dist/services/server/content-api.d.ts +3 -3
- package/dist/services/server/content-api.d.ts.map +1 -1
- package/dist/services/server/http-server.d.ts +2 -2
- package/dist/services/server/http-server.d.ts.map +1 -1
- package/dist/services/server/index.d.ts +2 -2
- package/dist/services/server/index.d.ts.map +1 -1
- package/dist/services/server/koa.d.ts.map +1 -1
- package/dist/services/server/middleware.d.ts +4 -4
- package/dist/services/server/middleware.d.ts.map +1 -1
- package/dist/services/server/policy.d.ts +3 -3
- package/dist/services/server/policy.d.ts.map +1 -1
- package/dist/services/server/register-middlewares.d.ts +2 -2
- package/dist/services/server/register-middlewares.d.ts.map +1 -1
- package/dist/services/server/register-routes.d.ts +2 -2
- package/dist/services/server/register-routes.d.ts.map +1 -1
- package/dist/services/server/routing.d.ts +5 -5
- package/dist/services/server/routing.d.ts.map +1 -1
- package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
- package/dist/services/webhook-runner.d.ts +2 -1
- package/dist/services/webhook-runner.d.ts.map +1 -1
- package/dist/services/webhook-store.d.ts +2 -8
- package/dist/services/webhook-store.d.ts.map +1 -1
- package/dist/utils/convert-custom-field-type.d.ts +2 -2
- package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
- package/dist/utils/fetch.d.ts +3 -3
- package/dist/utils/fetch.d.ts.map +1 -1
- package/dist/utils/filepath-to-prop-path.d.ts +1 -1
- package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
- package/dist/utils/index.d.ts +2 -1
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/is-initialized.d.ts +2 -2
- package/dist/utils/is-initialized.d.ts.map +1 -1
- package/dist/utils/load-files.d.ts.map +1 -1
- package/dist/utils/open-browser.d.ts +2 -2
- package/dist/utils/open-browser.d.ts.map +1 -1
- package/dist/utils/resolve-working-dirs.d.ts +19 -0
- package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
- package/dist/utils/signals.d.ts +2 -2
- package/dist/utils/signals.d.ts.map +1 -1
- package/dist/utils/startup-logger.d.ts +2 -2
- package/dist/utils/startup-logger.d.ts.map +1 -1
- package/dist/utils/transform-content-types-to-models.d.ts +377 -90
- package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
- package/dist/utils/update-notifier/index.d.ts +2 -7
- package/dist/utils/update-notifier/index.d.ts.map +1 -1
- package/package.json +43 -40
- package/dist/Strapi.js +0 -459
- package/dist/Strapi.js.map +0 -1
- package/dist/Strapi.mjs +0 -458
- package/dist/Strapi.mjs.map +0 -1
- package/dist/compile.js +0 -18
- package/dist/compile.js.map +0 -1
- package/dist/compile.mjs +0 -17
- package/dist/compile.mjs.map +0 -1
- package/dist/configuration/config-loader.js +0 -102
- package/dist/configuration/config-loader.js.map +0 -1
- package/dist/configuration/config-loader.mjs +0 -100
- package/dist/configuration/config-loader.mjs.map +0 -1
- package/dist/configuration/index.js +0 -78
- package/dist/configuration/index.js.map +0 -1
- package/dist/configuration/index.mjs +0 -74
- package/dist/configuration/index.mjs.map +0 -1
- package/dist/configuration/urls.js +0 -68
- package/dist/configuration/urls.js.map +0 -1
- package/dist/configuration/urls.mjs +0 -66
- package/dist/configuration/urls.mjs.map +0 -1
- package/dist/container.js +0 -30
- package/dist/container.js.map +0 -1
- package/dist/container.mjs +0 -30
- package/dist/container.mjs.map +0 -1
- package/dist/core-api/controller/collection-type.js +0 -81
- package/dist/core-api/controller/collection-type.js.map +0 -1
- package/dist/core-api/controller/collection-type.mjs +0 -81
- package/dist/core-api/controller/collection-type.mjs.map +0 -1
- package/dist/core-api/controller/index.js +0 -52
- package/dist/core-api/controller/index.js.map +0 -1
- package/dist/core-api/controller/index.mjs +0 -52
- package/dist/core-api/controller/index.mjs.map +0 -1
- package/dist/core-api/controller/single-type.js +0 -45
- package/dist/core-api/controller/single-type.js.map +0 -1
- package/dist/core-api/controller/single-type.mjs +0 -45
- package/dist/core-api/controller/single-type.mjs.map +0 -1
- package/dist/core-api/controller/transform.js +0 -79
- package/dist/core-api/controller/transform.js.map +0 -1
- package/dist/core-api/controller/transform.mjs +0 -79
- package/dist/core-api/controller/transform.mjs.map +0 -1
- package/dist/core-api/routes/index.js +0 -67
- package/dist/core-api/routes/index.js.map +0 -1
- package/dist/core-api/routes/index.mjs +0 -67
- package/dist/core-api/routes/index.mjs.map +0 -1
- package/dist/core-api/service/collection-type.js +0 -56
- package/dist/core-api/service/collection-type.js.map +0 -1
- package/dist/core-api/service/collection-type.mjs +0 -56
- package/dist/core-api/service/collection-type.mjs.map +0 -1
- package/dist/core-api/service/core-service.js +0 -12
- package/dist/core-api/service/core-service.js.map +0 -1
- package/dist/core-api/service/core-service.mjs +0 -12
- package/dist/core-api/service/core-service.mjs.map +0 -1
- package/dist/core-api/service/index.js +0 -16
- package/dist/core-api/service/index.js.map +0 -1
- package/dist/core-api/service/index.mjs +0 -16
- package/dist/core-api/service/index.mjs.map +0 -1
- package/dist/core-api/service/pagination.js +0 -78
- package/dist/core-api/service/pagination.js.map +0 -1
- package/dist/core-api/service/pagination.mjs +0 -78
- package/dist/core-api/service/pagination.mjs.map +0 -1
- package/dist/core-api/service/single-type.js +0 -39
- package/dist/core-api/service/single-type.js.map +0 -1
- package/dist/core-api/service/single-type.mjs +0 -39
- package/dist/core-api/service/single-type.mjs.map +0 -1
- package/dist/domain/content-type/index.js +0 -111
- package/dist/domain/content-type/index.js.map +0 -1
- package/dist/domain/content-type/index.mjs +0 -109
- package/dist/domain/content-type/index.mjs.map +0 -1
- package/dist/domain/content-type/validator.js +0 -77
- package/dist/domain/content-type/validator.js.map +0 -1
- package/dist/domain/content-type/validator.mjs +0 -75
- package/dist/domain/content-type/validator.mjs.map +0 -1
- package/dist/domain/module/index.js +0 -106
- package/dist/domain/module/index.js.map +0 -1
- package/dist/domain/module/index.mjs +0 -104
- package/dist/domain/module/index.mjs.map +0 -1
- package/dist/domain/module/validation.js +0 -25
- package/dist/domain/module/validation.js.map +0 -1
- package/dist/domain/module/validation.mjs +0 -25
- package/dist/domain/module/validation.mjs.map +0 -1
- package/dist/ee/index.js +0 -153
- package/dist/ee/index.js.map +0 -1
- package/dist/ee/index.mjs +0 -154
- package/dist/ee/index.mjs.map +0 -1
- package/dist/ee/license.js +0 -90
- package/dist/ee/license.js.map +0 -1
- package/dist/ee/license.mjs +0 -87
- package/dist/ee/license.mjs.map +0 -1
- package/dist/factories.js +0 -76
- package/dist/factories.js.map +0 -1
- package/dist/factories.mjs +0 -76
- package/dist/factories.mjs.map +0 -1
- package/dist/loaders/admin.js +0 -27
- package/dist/loaders/admin.js.map +0 -1
- package/dist/loaders/admin.mjs +0 -26
- package/dist/loaders/admin.mjs.map +0 -1
- package/dist/loaders/apis.js +0 -137
- package/dist/loaders/apis.js.map +0 -1
- package/dist/loaders/apis.mjs +0 -135
- package/dist/loaders/apis.mjs.map +0 -1
- package/dist/loaders/components.js +0 -38
- package/dist/loaders/components.js.map +0 -1
- package/dist/loaders/components.mjs +0 -37
- package/dist/loaders/components.mjs.map +0 -1
- package/dist/loaders/index.js +0 -26
- package/dist/loaders/index.js.map +0 -1
- package/dist/loaders/index.mjs +0 -26
- package/dist/loaders/index.mjs.map +0 -1
- package/dist/loaders/middlewares.js +0 -31
- package/dist/loaders/middlewares.js.map +0 -1
- package/dist/loaders/middlewares.mjs +0 -30
- package/dist/loaders/middlewares.mjs.map +0 -1
- package/dist/loaders/plugins/get-enabled-plugins.js +0 -111
- package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
- package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -109
- package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
- package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
- package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
- package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
- package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
- package/dist/loaders/plugins/index.js +0 -118
- package/dist/loaders/plugins/index.js.map +0 -1
- package/dist/loaders/plugins/index.mjs +0 -117
- package/dist/loaders/plugins/index.mjs.map +0 -1
- package/dist/loaders/policies.js +0 -25
- package/dist/loaders/policies.js.map +0 -1
- package/dist/loaders/policies.mjs +0 -24
- package/dist/loaders/policies.mjs.map +0 -1
- package/dist/loaders/sanitizers.js +0 -6
- package/dist/loaders/sanitizers.js.map +0 -1
- package/dist/loaders/sanitizers.mjs +0 -7
- package/dist/loaders/sanitizers.mjs.map +0 -1
- package/dist/loaders/src-index.js +0 -33
- package/dist/loaders/src-index.js.map +0 -1
- package/dist/loaders/src-index.mjs +0 -34
- package/dist/loaders/src-index.mjs.map +0 -1
- package/dist/loaders/validators.js +0 -6
- package/dist/loaders/validators.js.map +0 -1
- package/dist/loaders/validators.mjs +0 -7
- package/dist/loaders/validators.mjs.map +0 -1
- package/dist/middlewares/body.js +0 -65
- package/dist/middlewares/body.js.map +0 -1
- package/dist/middlewares/body.mjs +0 -61
- package/dist/middlewares/body.mjs.map +0 -1
- package/dist/middlewares/compression.js +0 -8
- package/dist/middlewares/compression.js.map +0 -1
- package/dist/middlewares/compression.mjs +0 -6
- package/dist/middlewares/compression.mjs.map +0 -1
- package/dist/middlewares/cors.js +0 -51
- package/dist/middlewares/cors.js.map +0 -1
- package/dist/middlewares/cors.mjs +0 -49
- package/dist/middlewares/cors.mjs.map +0 -1
- package/dist/middlewares/errors.js +0 -33
- package/dist/middlewares/errors.js.map +0 -1
- package/dist/middlewares/errors.mjs +0 -33
- package/dist/middlewares/errors.mjs.map +0 -1
- package/dist/middlewares/favicon.js +0 -22
- package/dist/middlewares/favicon.js.map +0 -1
- package/dist/middlewares/favicon.mjs +0 -20
- package/dist/middlewares/favicon.mjs.map +0 -1
- package/dist/middlewares/index.js +0 -34
- package/dist/middlewares/index.js.map +0 -1
- package/dist/middlewares/index.mjs +0 -34
- package/dist/middlewares/index.mjs.map +0 -1
- package/dist/middlewares/ip.js +0 -8
- package/dist/middlewares/ip.js.map +0 -1
- package/dist/middlewares/ip.mjs +0 -6
- package/dist/middlewares/ip.mjs.map +0 -1
- package/dist/middlewares/logger.js +0 -12
- package/dist/middlewares/logger.js.map +0 -1
- package/dist/middlewares/logger.mjs +0 -12
- package/dist/middlewares/logger.mjs.map +0 -1
- package/dist/middlewares/powered-by.js +0 -14
- package/dist/middlewares/powered-by.js.map +0 -1
- package/dist/middlewares/powered-by.mjs +0 -14
- package/dist/middlewares/powered-by.mjs.map +0 -1
- package/dist/middlewares/public.js +0 -34
- package/dist/middlewares/public.js.map +0 -1
- package/dist/middlewares/public.mjs +0 -32
- package/dist/middlewares/public.mjs.map +0 -1
- package/dist/middlewares/query.js +0 -40
- package/dist/middlewares/query.js.map +0 -1
- package/dist/middlewares/query.mjs +0 -38
- package/dist/middlewares/query.mjs.map +0 -1
- package/dist/middlewares/response-time.js +0 -12
- package/dist/middlewares/response-time.js.map +0 -1
- package/dist/middlewares/response-time.mjs +0 -12
- package/dist/middlewares/response-time.mjs.map +0 -1
- package/dist/middlewares/responses.js +0 -15
- package/dist/middlewares/responses.js.map +0 -1
- package/dist/middlewares/responses.mjs +0 -15
- package/dist/middlewares/responses.mjs.map +0 -1
- package/dist/middlewares/security.js +0 -71
- package/dist/middlewares/security.js.map +0 -1
- package/dist/middlewares/security.mjs +0 -69
- package/dist/middlewares/security.mjs.map +0 -1
- package/dist/middlewares/session.js +0 -30
- package/dist/middlewares/session.js.map +0 -1
- package/dist/middlewares/session.mjs +0 -28
- package/dist/middlewares/session.mjs.map +0 -1
- package/dist/migrations/draft-publish.js +0 -59
- package/dist/migrations/draft-publish.js.map +0 -1
- package/dist/migrations/draft-publish.mjs +0 -59
- package/dist/migrations/draft-publish.mjs.map +0 -1
- package/dist/registries/apis.js +0 -23
- package/dist/registries/apis.js.map +0 -1
- package/dist/registries/apis.mjs +0 -24
- package/dist/registries/apis.mjs.map +0 -1
- package/dist/registries/components.js +0 -45
- package/dist/registries/components.js.map +0 -1
- package/dist/registries/components.mjs +0 -46
- package/dist/registries/components.mjs.map +0 -1
- package/dist/registries/config.d.ts +0 -4
- package/dist/registries/config.d.ts.map +0 -1
- package/dist/registries/config.js +0 -31
- package/dist/registries/config.js.map +0 -1
- package/dist/registries/config.mjs +0 -32
- package/dist/registries/config.mjs.map +0 -1
- package/dist/registries/content-types.js +0 -70
- package/dist/registries/content-types.js.map +0 -1
- package/dist/registries/content-types.mjs +0 -71
- package/dist/registries/content-types.mjs.map +0 -1
- package/dist/registries/controllers.js +0 -80
- package/dist/registries/controllers.js.map +0 -1
- package/dist/registries/controllers.mjs +0 -81
- package/dist/registries/controllers.mjs.map +0 -1
- package/dist/registries/custom-fields.js +0 -71
- package/dist/registries/custom-fields.js.map +0 -1
- package/dist/registries/custom-fields.mjs +0 -72
- package/dist/registries/custom-fields.mjs.map +0 -1
- package/dist/registries/hooks.js +0 -58
- package/dist/registries/hooks.js.map +0 -1
- package/dist/registries/hooks.mjs +0 -59
- package/dist/registries/hooks.mjs.map +0 -1
- package/dist/registries/middlewares.js +0 -60
- package/dist/registries/middlewares.js.map +0 -1
- package/dist/registries/middlewares.mjs +0 -61
- package/dist/registries/middlewares.mjs.map +0 -1
- package/dist/registries/models.js +0 -16
- package/dist/registries/models.js.map +0 -1
- package/dist/registries/models.mjs +0 -16
- package/dist/registries/models.mjs.map +0 -1
- package/dist/registries/modules.js +0 -39
- package/dist/registries/modules.js.map +0 -1
- package/dist/registries/modules.mjs +0 -40
- package/dist/registries/modules.mjs.map +0 -1
- package/dist/registries/namespace.js +0 -27
- package/dist/registries/namespace.js.map +0 -1
- package/dist/registries/namespace.mjs +0 -27
- package/dist/registries/namespace.mjs.map +0 -1
- package/dist/registries/plugins.js +0 -23
- package/dist/registries/plugins.js.map +0 -1
- package/dist/registries/plugins.mjs +0 -24
- package/dist/registries/plugins.mjs.map +0 -1
- package/dist/registries/policies.js +0 -62
- package/dist/registries/policies.js.map +0 -1
- package/dist/registries/policies.mjs +0 -63
- package/dist/registries/policies.mjs.map +0 -1
- package/dist/registries/sanitizers.js +0 -25
- package/dist/registries/sanitizers.js.map +0 -1
- package/dist/registries/sanitizers.mjs +0 -24
- package/dist/registries/sanitizers.mjs.map +0 -1
- package/dist/registries/services.js +0 -80
- package/dist/registries/services.js.map +0 -1
- package/dist/registries/services.mjs +0 -81
- package/dist/registries/services.mjs.map +0 -1
- package/dist/registries/validators.js +0 -25
- package/dist/registries/validators.js.map +0 -1
- package/dist/registries/validators.mjs +0 -24
- package/dist/registries/validators.mjs.map +0 -1
- package/dist/services/auth/index.js +0 -81
- package/dist/services/auth/index.js.map +0 -1
- package/dist/services/auth/index.mjs +0 -80
- package/dist/services/auth/index.mjs.map +0 -1
- package/dist/services/content-api/index.js +0 -59
- package/dist/services/content-api/index.js.map +0 -1
- package/dist/services/content-api/index.mjs +0 -58
- package/dist/services/content-api/index.mjs.map +0 -1
- package/dist/services/content-api/permissions/engine.js +0 -7
- package/dist/services/content-api/permissions/engine.js.map +0 -1
- package/dist/services/content-api/permissions/engine.mjs +0 -6
- package/dist/services/content-api/permissions/engine.mjs.map +0 -1
- package/dist/services/content-api/permissions/index.js +0 -87
- package/dist/services/content-api/permissions/index.js.map +0 -1
- package/dist/services/content-api/permissions/index.mjs +0 -86
- package/dist/services/content-api/permissions/index.mjs.map +0 -1
- package/dist/services/content-api/permissions/providers/action.js +0 -16
- package/dist/services/content-api/permissions/providers/action.js.map +0 -1
- package/dist/services/content-api/permissions/providers/action.mjs +0 -17
- package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
- package/dist/services/content-api/permissions/providers/condition.js +0 -16
- package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
- package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
- package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
- package/dist/services/core-store.js +0 -107
- package/dist/services/core-store.js.map +0 -1
- package/dist/services/core-store.mjs +0 -107
- package/dist/services/core-store.mjs.map +0 -1
- package/dist/services/cron.js +0 -63
- package/dist/services/cron.js.map +0 -1
- package/dist/services/cron.mjs +0 -64
- package/dist/services/cron.mjs.map +0 -1
- package/dist/services/custom-fields.js +0 -10
- package/dist/services/custom-fields.js.map +0 -1
- package/dist/services/custom-fields.mjs +0 -11
- package/dist/services/custom-fields.mjs.map +0 -1
- package/dist/services/document-service/common.js +0 -7
- package/dist/services/document-service/common.js.map +0 -1
- package/dist/services/document-service/common.mjs +0 -7
- package/dist/services/document-service/common.mjs.map +0 -1
- package/dist/services/document-service/draft-and-publish.js +0 -69
- package/dist/services/document-service/draft-and-publish.js.map +0 -1
- package/dist/services/document-service/draft-and-publish.mjs +0 -69
- package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
- package/dist/services/document-service/index.js +0 -22
- package/dist/services/document-service/index.js.map +0 -1
- package/dist/services/document-service/index.mjs +0 -22
- package/dist/services/document-service/index.mjs.map +0 -1
- package/dist/services/document-service/internationalization.js +0 -54
- package/dist/services/document-service/internationalization.js.map +0 -1
- package/dist/services/document-service/internationalization.mjs +0 -54
- package/dist/services/document-service/internationalization.mjs.map +0 -1
- package/dist/services/document-service/middlewares.d.ts +0 -8
- package/dist/services/document-service/middlewares.d.ts.map +0 -1
- package/dist/services/document-service/middlewares.js +0 -46
- package/dist/services/document-service/middlewares.js.map +0 -1
- package/dist/services/document-service/middlewares.mjs +0 -46
- package/dist/services/document-service/middlewares.mjs.map +0 -1
- package/dist/services/document-service/repository.js +0 -295
- package/dist/services/document-service/repository.js.map +0 -1
- package/dist/services/document-service/repository.mjs +0 -295
- package/dist/services/document-service/repository.mjs.map +0 -1
- package/dist/services/document-service/transform/data.js +0 -13
- package/dist/services/document-service/transform/data.js.map +0 -1
- package/dist/services/document-service/transform/data.mjs +0 -13
- package/dist/services/document-service/transform/data.mjs.map +0 -1
- package/dist/services/document-service/transform/fields.js +0 -24
- package/dist/services/document-service/transform/fields.js.map +0 -1
- package/dist/services/document-service/transform/fields.mjs +0 -24
- package/dist/services/document-service/transform/fields.mjs.map +0 -1
- package/dist/services/document-service/transform/filters.d.ts +0 -3
- package/dist/services/document-service/transform/filters.d.ts.map +0 -1
- package/dist/services/document-service/transform/id-map.js +0 -78
- package/dist/services/document-service/transform/id-map.js.map +0 -1
- package/dist/services/document-service/transform/id-map.mjs +0 -78
- package/dist/services/document-service/transform/id-map.mjs.map +0 -1
- package/dist/services/document-service/transform/id-transform.js +0 -33
- package/dist/services/document-service/transform/id-transform.js.map +0 -1
- package/dist/services/document-service/transform/id-transform.mjs +0 -33
- package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
- package/dist/services/document-service/transform/populate.js +0 -21
- package/dist/services/document-service/transform/populate.js.map +0 -1
- package/dist/services/document-service/transform/populate.mjs +0 -21
- package/dist/services/document-service/transform/populate.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -90
- package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -90
- package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -141
- package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -141
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
- package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
- package/dist/services/document-service/transform/relations/utils/data.js +0 -12
- package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
- package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
- package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/utils/dp.js +0 -25
- package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
- package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -25
- package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/utils/i18n.js +0 -31
- package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
- package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -31
- package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
- package/dist/services/document-service/transform/sort.d.ts +0 -5
- package/dist/services/document-service/transform/sort.d.ts.map +0 -1
- package/dist/services/document-service/transform/utils.d.ts +0 -9
- package/dist/services/document-service/transform/utils.d.ts.map +0 -1
- package/dist/services/document-service/utils/populate.js +0 -41
- package/dist/services/document-service/utils/populate.js.map +0 -1
- package/dist/services/document-service/utils/populate.mjs +0 -41
- package/dist/services/document-service/utils/populate.mjs.map +0 -1
- package/dist/services/entity-service/attributes/index.d.ts +0 -6
- package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
- package/dist/services/entity-service/attributes/index.js +0 -22
- package/dist/services/entity-service/attributes/index.js.map +0 -1
- package/dist/services/entity-service/attributes/index.mjs +0 -22
- package/dist/services/entity-service/attributes/index.mjs.map +0 -1
- package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
- package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
- package/dist/services/entity-service/attributes/transforms.js +0 -20
- package/dist/services/entity-service/attributes/transforms.js.map +0 -1
- package/dist/services/entity-service/attributes/transforms.mjs +0 -19
- package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
- package/dist/services/entity-service/components.d.ts +0 -20
- package/dist/services/entity-service/components.d.ts.map +0 -1
- package/dist/services/entity-service/components.js +0 -298
- package/dist/services/entity-service/components.js.map +0 -1
- package/dist/services/entity-service/components.mjs +0 -296
- package/dist/services/entity-service/components.mjs.map +0 -1
- package/dist/services/entity-service/index.js +0 -163
- package/dist/services/entity-service/index.js.map +0 -1
- package/dist/services/entity-service/index.mjs +0 -161
- package/dist/services/entity-service/index.mjs.map +0 -1
- package/dist/services/entity-service/params.d.ts +0 -8
- package/dist/services/entity-service/params.d.ts.map +0 -1
- package/dist/services/entity-service/params.js +0 -8
- package/dist/services/entity-service/params.js.map +0 -1
- package/dist/services/entity-service/params.mjs +0 -8
- package/dist/services/entity-service/params.mjs.map +0 -1
- package/dist/services/entity-validator/blocks-validator.js +0 -127
- package/dist/services/entity-validator/blocks-validator.js.map +0 -1
- package/dist/services/entity-validator/blocks-validator.mjs +0 -128
- package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
- package/dist/services/entity-validator/index.js +0 -322
- package/dist/services/entity-validator/index.js.map +0 -1
- package/dist/services/entity-validator/index.mjs +0 -321
- package/dist/services/entity-validator/index.mjs.map +0 -1
- package/dist/services/entity-validator/validators.js +0 -121
- package/dist/services/entity-validator/validators.js.map +0 -1
- package/dist/services/entity-validator/validators.mjs +0 -119
- package/dist/services/entity-validator/validators.mjs.map +0 -1
- package/dist/services/errors.js +0 -76
- package/dist/services/errors.js.map +0 -1
- package/dist/services/errors.mjs +0 -74
- package/dist/services/errors.mjs.map +0 -1
- package/dist/services/event-hub.js +0 -67
- package/dist/services/event-hub.js.map +0 -1
- package/dist/services/event-hub.mjs +0 -68
- package/dist/services/event-hub.mjs.map +0 -1
- package/dist/services/features.js +0 -17
- package/dist/services/features.js.map +0 -1
- package/dist/services/features.mjs +0 -17
- package/dist/services/features.mjs.map +0 -1
- package/dist/services/fs.js +0 -51
- package/dist/services/fs.js.map +0 -1
- package/dist/services/fs.mjs +0 -49
- package/dist/services/fs.mjs.map +0 -1
- package/dist/services/metrics/admin-user-hash.js +0 -14
- package/dist/services/metrics/admin-user-hash.js.map +0 -1
- package/dist/services/metrics/admin-user-hash.mjs +0 -12
- package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
- package/dist/services/metrics/index.js +0 -45
- package/dist/services/metrics/index.js.map +0 -1
- package/dist/services/metrics/index.mjs +0 -46
- package/dist/services/metrics/index.mjs.map +0 -1
- package/dist/services/metrics/is-truthy.js +0 -9
- package/dist/services/metrics/is-truthy.js.map +0 -1
- package/dist/services/metrics/is-truthy.mjs +0 -8
- package/dist/services/metrics/is-truthy.mjs.map +0 -1
- package/dist/services/metrics/middleware.js +0 -25
- package/dist/services/metrics/middleware.js.map +0 -1
- package/dist/services/metrics/middleware.mjs +0 -26
- package/dist/services/metrics/middleware.mjs.map +0 -1
- package/dist/services/metrics/rate-limiter.js +0 -21
- package/dist/services/metrics/rate-limiter.js.map +0 -1
- package/dist/services/metrics/rate-limiter.mjs +0 -22
- package/dist/services/metrics/rate-limiter.mjs.map +0 -1
- package/dist/services/metrics/sender.js +0 -76
- package/dist/services/metrics/sender.js.map +0 -1
- package/dist/services/metrics/sender.mjs +0 -70
- package/dist/services/metrics/sender.mjs.map +0 -1
- package/dist/services/request-context.js +0 -13
- package/dist/services/request-context.js.map +0 -1
- package/dist/services/request-context.mjs +0 -14
- package/dist/services/request-context.mjs.map +0 -1
- package/dist/services/server/admin-api.js +0 -13
- package/dist/services/server/admin-api.js.map +0 -1
- package/dist/services/server/admin-api.mjs +0 -13
- package/dist/services/server/admin-api.mjs.map +0 -1
- package/dist/services/server/api.js +0 -30
- package/dist/services/server/api.js.map +0 -1
- package/dist/services/server/api.mjs +0 -28
- package/dist/services/server/api.mjs.map +0 -1
- package/dist/services/server/compose-endpoint.js +0 -118
- package/dist/services/server/compose-endpoint.js.map +0 -1
- package/dist/services/server/compose-endpoint.mjs +0 -117
- package/dist/services/server/compose-endpoint.mjs.map +0 -1
- package/dist/services/server/content-api.js +0 -12
- package/dist/services/server/content-api.js.map +0 -1
- package/dist/services/server/content-api.mjs +0 -12
- package/dist/services/server/content-api.mjs.map +0 -1
- package/dist/services/server/http-server.js +0 -50
- package/dist/services/server/http-server.js.map +0 -1
- package/dist/services/server/http-server.mjs +0 -48
- package/dist/services/server/http-server.mjs.map +0 -1
- package/dist/services/server/index.js +0 -88
- package/dist/services/server/index.js.map +0 -1
- package/dist/services/server/index.mjs +0 -86
- package/dist/services/server/index.mjs.map +0 -1
- package/dist/services/server/koa.js +0 -52
- package/dist/services/server/koa.js.map +0 -1
- package/dist/services/server/koa.mjs +0 -48
- package/dist/services/server/koa.mjs.map +0 -1
- package/dist/services/server/middleware.js +0 -92
- package/dist/services/server/middleware.js.map +0 -1
- package/dist/services/server/middleware.mjs +0 -90
- package/dist/services/server/middleware.mjs.map +0 -1
- package/dist/services/server/policy.js +0 -20
- package/dist/services/server/policy.js.map +0 -1
- package/dist/services/server/policy.mjs +0 -20
- package/dist/services/server/policy.mjs.map +0 -1
- package/dist/services/server/register-middlewares.js +0 -72
- package/dist/services/server/register-middlewares.js.map +0 -1
- package/dist/services/server/register-middlewares.mjs +0 -73
- package/dist/services/server/register-middlewares.mjs.map +0 -1
- package/dist/services/server/register-routes.js +0 -76
- package/dist/services/server/register-routes.js.map +0 -1
- package/dist/services/server/register-routes.mjs +0 -75
- package/dist/services/server/register-routes.mjs.map +0 -1
- package/dist/services/server/routing.js +0 -91
- package/dist/services/server/routing.js.map +0 -1
- package/dist/services/server/routing.mjs +0 -89
- package/dist/services/server/routing.mjs.map +0 -1
- package/dist/services/utils/dynamic-zones.js +0 -16
- package/dist/services/utils/dynamic-zones.js.map +0 -1
- package/dist/services/utils/dynamic-zones.mjs +0 -17
- package/dist/services/utils/dynamic-zones.mjs.map +0 -1
- package/dist/services/webhook-runner.js +0 -133
- package/dist/services/webhook-runner.js.map +0 -1
- package/dist/services/webhook-runner.mjs +0 -131
- package/dist/services/webhook-runner.mjs.map +0 -1
- package/dist/services/webhook-store.js +0 -104
- package/dist/services/webhook-store.js.map +0 -1
- package/dist/services/webhook-store.mjs +0 -104
- package/dist/services/webhook-store.mjs.map +0 -1
- package/dist/services/worker-queue.js +0 -56
- package/dist/services/worker-queue.js.map +0 -1
- package/dist/services/worker-queue.mjs +0 -55
- package/dist/services/worker-queue.mjs.map +0 -1
- package/dist/utils/convert-custom-field-type.js +0 -24
- package/dist/utils/convert-custom-field-type.js.map +0 -1
- package/dist/utils/convert-custom-field-type.mjs +0 -24
- package/dist/utils/convert-custom-field-type.mjs.map +0 -1
- package/dist/utils/cron.js +0 -38
- package/dist/utils/cron.js.map +0 -1
- package/dist/utils/cron.mjs +0 -38
- package/dist/utils/cron.mjs.map +0 -1
- package/dist/utils/fetch.js +0 -20
- package/dist/utils/fetch.js.map +0 -1
- package/dist/utils/fetch.mjs +0 -20
- package/dist/utils/fetch.mjs.map +0 -1
- package/dist/utils/filepath-to-prop-path.js +0 -12
- package/dist/utils/filepath-to-prop-path.js.map +0 -1
- package/dist/utils/filepath-to-prop-path.mjs +0 -10
- package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
- package/dist/utils/get-dirs.d.ts +0 -9
- package/dist/utils/get-dirs.d.ts.map +0 -1
- package/dist/utils/get-dirs.js +0 -30
- package/dist/utils/get-dirs.js.map +0 -1
- package/dist/utils/get-dirs.mjs +0 -30
- package/dist/utils/get-dirs.mjs.map +0 -1
- package/dist/utils/is-initialized.js +0 -16
- package/dist/utils/is-initialized.js.map +0 -1
- package/dist/utils/is-initialized.mjs +0 -16
- package/dist/utils/is-initialized.mjs.map +0 -1
- package/dist/utils/lifecycles.js +0 -9
- package/dist/utils/lifecycles.js.map +0 -1
- package/dist/utils/lifecycles.mjs +0 -9
- package/dist/utils/lifecycles.mjs.map +0 -1
- package/dist/utils/load-config-file.js +0 -45
- package/dist/utils/load-config-file.js.map +0 -1
- package/dist/utils/load-config-file.mjs +0 -42
- package/dist/utils/load-config-file.mjs.map +0 -1
- package/dist/utils/load-files.js +0 -39
- package/dist/utils/load-files.js.map +0 -1
- package/dist/utils/load-files.mjs +0 -35
- package/dist/utils/load-files.mjs.map +0 -1
- package/dist/utils/open-browser.js +0 -11
- package/dist/utils/open-browser.js.map +0 -1
- package/dist/utils/open-browser.mjs +0 -9
- package/dist/utils/open-browser.mjs.map +0 -1
- package/dist/utils/signals.js +0 -17
- package/dist/utils/signals.js.map +0 -1
- package/dist/utils/signals.mjs +0 -17
- package/dist/utils/signals.mjs.map +0 -1
- package/dist/utils/startup-logger.js +0 -81
- package/dist/utils/startup-logger.js.map +0 -1
- package/dist/utils/startup-logger.mjs +0 -77
- package/dist/utils/startup-logger.mjs.map +0 -1
- package/dist/utils/transform-content-types-to-models.js +0 -237
- package/dist/utils/transform-content-types-to-models.js.map +0 -1
- package/dist/utils/transform-content-types-to-models.mjs +0 -234
- package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
- package/dist/utils/update-notifier/index.js +0 -88
- package/dist/utils/update-notifier/index.js.map +0 -1
- package/dist/utils/update-notifier/index.mjs +0 -81
- package/dist/utils/update-notifier/index.mjs.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../src/services/entity-validator/index.ts"],"sourcesContent":["/**\n * Entity validator\n * Module that will validate input data for entity creation or edition\n */\n\nimport { uniqBy, castArray, isNil, isArray, mergeWith } from 'lodash';\nimport { has, prop, isObject, isEmpty } from 'lodash/fp';\nimport strapiUtils from '@strapi/utils';\nimport { EntityValidator, Common, Schema, Attribute, Shared, EntityService } from '@strapi/types';\nimport validators from './validators';\n\ntype CreateOrUpdate = 'creation' | 'update';\n\nconst { yup, validateYupSchema } = strapiUtils;\nconst { isMediaAttribute, isScalarAttribute, getWritableAttributes } = strapiUtils.contentTypes;\nconst { ValidationError } = strapiUtils.errors;\n\ntype Entity = {\n id: ID;\n [key: string]: unknown;\n} | null;\n\ntype ID = { id: string | number };\n\ntype RelationSource = string | number | ID;\n\ninterface ValidatorMeta<TAttribute = Attribute.Any> {\n attr: TAttribute;\n updatedAttribute: { name: string; value: any };\n}\n\ninterface ValidatorContext {\n isDraft?: boolean;\n locale?: string | null;\n}\n\ninterface AttributeValidatorMetas {\n attr: Attribute.Any;\n updatedAttribute: { name: string; value: unknown };\n model: Schema.ContentType | Schema.Component;\n entity?: Entity;\n}\n\ninterface ModelValidatorMetas {\n model: Schema.ContentType | Schema.Component;\n data: Record<string, unknown>;\n entity?: Entity;\n}\n\nconst isInteger = (value: unknown): value is number => Number.isInteger(value);\n\nconst addMinMax = <\n T extends {\n min(value: number): T;\n max(value: number): T;\n }\n>(\n validator: T,\n { attr, updatedAttribute }: ValidatorMeta<Attribute.Any & Attribute.MinMaxOption<string | number>>\n): T => {\n let nextValidator: T = validator;\n\n if (\n isInteger(attr.min) &&\n (('required' in attr && attr.required) ||\n (Array.isArray(updatedAttribute.value) && updatedAttribute.value.length > 0))\n ) {\n nextValidator = nextValidator.min(attr.min);\n }\n if (isInteger(attr.max)) {\n nextValidator = nextValidator.max(attr.max);\n }\n return nextValidator;\n};\n\nconst addRequiredValidation = (createOrUpdate: CreateOrUpdate) => {\n return <T extends strapiUtils.yup.AnySchema>(\n validator: T,\n { attr: { required } }: ValidatorMeta<Partial<Attribute.Any & Attribute.RequiredOption>>\n ): T => {\n let nextValidator = validator;\n\n if (required) {\n if (createOrUpdate === 'creation') {\n nextValidator = nextValidator.notNil();\n } else if (createOrUpdate === 'update') {\n nextValidator = nextValidator.notNull();\n }\n } else {\n nextValidator = nextValidator.nullable();\n }\n return nextValidator;\n };\n};\n\nconst addDefault = (createOrUpdate: CreateOrUpdate) => {\n return (\n validator: strapiUtils.yup.BaseSchema,\n { attr }: ValidatorMeta<Attribute.Any & Attribute.DefaultOption<unknown>>\n ) => {\n let nextValidator = validator;\n\n if (createOrUpdate === 'creation') {\n if (\n ((attr.type === 'component' && attr.repeatable) || attr.type === 'dynamiczone') &&\n !attr.required\n ) {\n nextValidator = nextValidator.default([]);\n } else {\n nextValidator = nextValidator.default(attr.default);\n }\n } else {\n nextValidator = nextValidator.default(undefined);\n }\n\n return nextValidator;\n };\n};\n\nconst preventCast = (validator: strapiUtils.yup.AnySchema) =>\n validator.transform((val, originalVal) => originalVal);\n\nconst createComponentValidator =\n (createOrUpdate: CreateOrUpdate) =>\n (\n { attr, updatedAttribute }: ValidatorMeta<Attribute.Component<Common.UID.Component, boolean>>,\n { isDraft }: ValidatorContext\n ) => {\n const model = strapi.getModel(attr.component);\n if (!model) {\n throw new Error('Validation failed: Model not found');\n }\n\n if (attr?.repeatable) {\n // FIXME: yup v1\n\n let validator = yup\n .array()\n .of(\n yup.lazy((item) =>\n createModelValidator(createOrUpdate)({ model, data: item }, { isDraft }).notNull()\n ) as any\n );\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: true },\n updatedAttribute,\n });\n\n validator = addMinMax(validator, { attr, updatedAttribute });\n\n return validator;\n }\n\n // FIXME: v4 was broken\n let validator = createModelValidator(createOrUpdate)(\n { model, data: updatedAttribute.value },\n { isDraft }\n );\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: !isDraft && attr.required },\n updatedAttribute,\n });\n\n return validator;\n };\n\nconst createDzValidator =\n (createOrUpdate: CreateOrUpdate) =>\n ({ attr, updatedAttribute }: ValidatorMeta, { isDraft }: ValidatorContext) => {\n let validator;\n\n validator = yup.array().of(\n yup.lazy((item) => {\n const model = strapi.getModel(prop('__component', item));\n const schema = yup\n .object()\n .shape({\n __component: yup.string().required().oneOf(Object.keys(strapi.components)),\n })\n .notNull();\n\n return model\n ? schema.concat(createModelValidator(createOrUpdate)({ model, data: item }, { isDraft }))\n : schema;\n }) as any // FIXME: yup v1\n );\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: true },\n updatedAttribute,\n });\n\n validator = addMinMax(validator, { attr, updatedAttribute });\n\n return validator;\n };\n\nconst createRelationValidator =\n (createOrUpdate: CreateOrUpdate) =>\n (\n { attr, updatedAttribute }: ValidatorMeta<Attribute.Relation>,\n { isDraft }: ValidatorContext\n ) => {\n let validator;\n\n if (Array.isArray(updatedAttribute.value)) {\n validator = yup.array().of(yup.mixed());\n } else {\n validator = yup.mixed();\n }\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: !isDraft && attr.required },\n updatedAttribute,\n });\n\n return validator;\n };\n\nconst createScalarAttributeValidator =\n (createOrUpdate: CreateOrUpdate) => (metas: ValidatorMeta, options: ValidatorContext) => {\n let validator;\n\n if (has(metas.attr.type, validators)) {\n validator = (validators as any)[metas.attr.type](metas, options);\n } else {\n // No validators specified - fall back to mixed\n validator = yup.mixed();\n }\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: !options.isDraft && metas.attr.required },\n updatedAttribute: metas.updatedAttribute,\n });\n\n return validator;\n };\n\nconst createAttributeValidator =\n (createOrUpdate: CreateOrUpdate) =>\n (metas: AttributeValidatorMetas, options: ValidatorContext) => {\n let validator = yup.mixed();\n\n if (isMediaAttribute(metas.attr)) {\n validator = yup.mixed();\n } else if (isScalarAttribute(metas.attr)) {\n validator = createScalarAttributeValidator(createOrUpdate)(metas, options);\n } else {\n if (metas.attr.type === 'component') {\n validator = createComponentValidator(createOrUpdate)(\n { attr: metas.attr, updatedAttribute: metas.updatedAttribute },\n options\n );\n } else if (metas.attr.type === 'dynamiczone') {\n validator = createDzValidator(createOrUpdate)(metas, options);\n } else if (metas.attr.type === 'relation') {\n validator = createRelationValidator(createOrUpdate)(\n {\n attr: metas.attr,\n updatedAttribute: metas.updatedAttribute,\n },\n options\n );\n }\n\n validator = preventCast(validator);\n }\n\n validator = addDefault(createOrUpdate)(validator, metas);\n\n return validator;\n };\n\nconst createModelValidator =\n (createOrUpdate: CreateOrUpdate) =>\n ({ model, data, entity }: ModelValidatorMetas, options: ValidatorContext) => {\n const writableAttributes = model ? getWritableAttributes(model as any) : [];\n\n const schema = writableAttributes.reduce((validators, attributeName) => {\n const metas = {\n attr: model.attributes[attributeName],\n updatedAttribute: { name: attributeName, value: prop(attributeName, data) },\n model,\n entity,\n };\n\n const validator = createAttributeValidator(createOrUpdate)(metas, options);\n\n validators[attributeName] = validator;\n\n return validators;\n }, {} as Record<string, strapiUtils.yup.BaseSchema>);\n\n return yup.object().shape(schema);\n };\n\nconst createValidateEntity = (createOrUpdate: CreateOrUpdate) => {\n return async <\n TUID extends Common.UID.ContentType,\n TData extends EntityService.Params.Data.Input<TUID>\n >(\n model: Shared.ContentTypes[TUID],\n data: TData | Partial<TData> | undefined,\n options?: ValidatorContext,\n entity?: Entity\n ): Promise<TData> => {\n if (!isObject(data)) {\n const { displayName } = model.info;\n\n throw new ValidationError(\n `Invalid payload submitted for the ${createOrUpdate} of an entity of type ${displayName}. Expected an object, but got ${typeof data}`\n );\n }\n\n const validator = createModelValidator(createOrUpdate)(\n { model, data, entity },\n {\n isDraft: options?.isDraft ?? false,\n locale: options?.locale ?? null,\n }\n )\n .test('relations-test', 'check that all relations exist', async function (data) {\n try {\n await checkRelationsExist(buildRelationsStore({ uid: model.uid, data }));\n } catch (e) {\n return this.createError({\n path: this.path,\n message: (e instanceof ValidationError && e.message) || 'Invalid relations',\n });\n }\n return true;\n })\n .required();\n\n return validateYupSchema(validator, {\n strict: false,\n abortEarly: false,\n })(data);\n };\n};\n\n/**\n * Builds an object containing all the media and relations being associated with an entity\n */\nconst buildRelationsStore = <TUID extends Common.UID.ContentType | Common.UID.Component>({\n uid,\n data,\n}: {\n uid: TUID;\n data: Record<string, unknown> | null;\n}): Record<string, ID[]> => {\n if (!uid) {\n throw new ValidationError(`Cannot build relations store: \"uid\" is undefined`);\n }\n\n if (isEmpty(data)) {\n return {};\n }\n\n const currentModel = strapi.getModel(uid);\n\n return Object.keys(currentModel.attributes).reduce((result, attributeName: string) => {\n const attribute = currentModel.attributes[attributeName];\n const value = data[attributeName];\n\n if (isNil(value)) {\n return result;\n }\n\n switch (attribute.type) {\n case 'relation':\n case 'media': {\n if (\n attribute.type === 'relation' &&\n (attribute.relation === 'morphToMany' || attribute.relation === 'morphToOne')\n ) {\n // TODO: handle polymorphic relations\n break;\n }\n\n const target =\n // eslint-disable-next-line no-nested-ternary\n attribute.type === 'media' ? 'plugin::upload.file' : attribute.target;\n // As there are multiple formats supported for associating relations\n // with an entity, the value here can be an: array, object or number.\n let source: RelationSource[];\n if (Array.isArray(value)) {\n source = value;\n } else if (isObject(value)) {\n if ('connect' in value && !isNil(value.connect)) {\n source = value.connect as RelationSource[];\n } else if ('set' in value && !isNil(value.set)) {\n source = value.set as RelationSource[];\n } else {\n source = [];\n }\n } else {\n source = castArray(value as RelationSource);\n }\n const idArray = source.map((v) => ({\n id: typeof v === 'object' ? v.id : v,\n }));\n\n // Update the relationStore to keep track of all associations being made\n // with relations and media.\n result[target] = result[target] || [];\n result[target].push(...idArray);\n break;\n }\n case 'component': {\n return castArray(value).reduce((relationsStore, componentValue) => {\n if (!attribute.component) {\n throw new ValidationError(\n `Cannot build relations store from component, component identifier is undefined`\n );\n }\n\n return mergeWith(\n relationsStore,\n buildRelationsStore({\n uid: attribute.component,\n data: componentValue as Record<string, unknown>,\n }),\n (objValue, srcValue) => {\n if (isArray(objValue)) {\n return objValue.concat(srcValue);\n }\n }\n );\n }, result) as Record<string, ID[]>;\n }\n case 'dynamiczone': {\n return castArray(value).reduce((relationsStore, dzValue) => {\n const value = dzValue as Record<string, unknown>;\n if (!value.__component) {\n throw new ValidationError(\n `Cannot build relations store from dynamiczone, component identifier is undefined`\n );\n }\n\n return mergeWith(\n relationsStore,\n buildRelationsStore({\n uid: value.__component as Common.UID.Component,\n data: value,\n }),\n (objValue, srcValue) => {\n if (isArray(objValue)) {\n return objValue.concat(srcValue);\n }\n }\n );\n }, result) as Record<string, ID[]>;\n }\n default:\n break;\n }\n\n return result;\n }, {} as Record<string, ID[]>);\n};\n\n/**\n * Iterate through the relations store and validates that every relation or media\n * mentioned exists\n */\nconst checkRelationsExist = async (relationsStore: Record<string, ID[]> = {}) => {\n const promises = [];\n\n for (const [key, value] of Object.entries(relationsStore)) {\n const evaluate = async () => {\n const uniqueValues = uniqBy(value, `id`);\n const count = await strapi.db.query(key as Common.UID.Schema).count({\n where: {\n id: {\n $in: uniqueValues.map((v) => v.id),\n },\n },\n });\n\n if (count !== uniqueValues.length) {\n throw new ValidationError(\n `${\n uniqueValues.length - count\n } relation(s) of type ${key} associated with this entity do not exist`\n );\n }\n };\n promises.push(evaluate());\n }\n\n return Promise.all(promises);\n};\n\nconst entityValidator: EntityValidator = {\n validateEntityCreation: createValidateEntity('creation'),\n validateEntityUpdate: createValidateEntity('update'),\n};\n\nexport default entityValidator;\n"],"names":["validator","validators","data","value"],"mappings":"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"}
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const _ = require("lodash");
|
|
3
|
-
const strapiUtils = require("@strapi/utils");
|
|
4
|
-
const blocksValidator = require("./blocks-validator.js");
|
|
5
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
6
|
-
const ___default = /* @__PURE__ */ _interopDefault(_);
|
|
7
|
-
const strapiUtils__default = /* @__PURE__ */ _interopDefault(strapiUtils);
|
|
8
|
-
const { yup } = strapiUtils__default.default;
|
|
9
|
-
const addMinLengthValidator = (validator, {
|
|
10
|
-
attr
|
|
11
|
-
}, { isDraft }) => {
|
|
12
|
-
return attr.minLength && ___default.default.isInteger(attr.minLength) && !isDraft ? validator.min(attr.minLength) : validator;
|
|
13
|
-
};
|
|
14
|
-
const addMaxLengthValidator = (validator, {
|
|
15
|
-
attr
|
|
16
|
-
}) => {
|
|
17
|
-
return attr.maxLength && ___default.default.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;
|
|
18
|
-
};
|
|
19
|
-
const addMinIntegerValidator = (validator, {
|
|
20
|
-
attr
|
|
21
|
-
}) => ___default.default.isNumber(attr.min) ? validator.min(___default.default.toInteger(attr.min)) : validator;
|
|
22
|
-
const addMaxIntegerValidator = (validator, {
|
|
23
|
-
attr
|
|
24
|
-
}) => ___default.default.isNumber(attr.max) ? validator.max(___default.default.toInteger(attr.max)) : validator;
|
|
25
|
-
const addMinFloatValidator = (validator, {
|
|
26
|
-
attr
|
|
27
|
-
}) => ___default.default.isNumber(attr.min) ? validator.min(attr.min) : validator;
|
|
28
|
-
const addMaxFloatValidator = (validator, {
|
|
29
|
-
attr
|
|
30
|
-
}) => ___default.default.isNumber(attr.max) ? validator.max(attr.max) : validator;
|
|
31
|
-
const addStringRegexValidator = (validator, {
|
|
32
|
-
attr
|
|
33
|
-
}) => {
|
|
34
|
-
return "regex" in attr && !___default.default.isUndefined(attr.regex) ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required }) : validator;
|
|
35
|
-
};
|
|
36
|
-
const addUniqueValidator = (validator, { attr, model, updatedAttribute, entity }, options) => {
|
|
37
|
-
if (attr.type !== "uid" && !attr.unique) {
|
|
38
|
-
return validator;
|
|
39
|
-
}
|
|
40
|
-
return validator.test("unique", "This attribute must be unique", async (value) => {
|
|
41
|
-
const isPublish = options.isDraft === false;
|
|
42
|
-
if (___default.default.isNil(value)) {
|
|
43
|
-
return true;
|
|
44
|
-
}
|
|
45
|
-
if (!isPublish && value === entity?.[updatedAttribute.name]) {
|
|
46
|
-
return true;
|
|
47
|
-
}
|
|
48
|
-
const record = await strapi.db.query(model.uid).findOne({
|
|
49
|
-
where: {
|
|
50
|
-
locale: options.locale,
|
|
51
|
-
publishedAt: options.isDraft ? null : { $notNull: true },
|
|
52
|
-
[updatedAttribute.name]: value,
|
|
53
|
-
...entity?.id ? { id: { $ne: entity.id } } : {}
|
|
54
|
-
}
|
|
55
|
-
});
|
|
56
|
-
return !record;
|
|
57
|
-
});
|
|
58
|
-
};
|
|
59
|
-
const stringValidator = (metas, options) => {
|
|
60
|
-
let schema = yup.string().transform((val, originalVal) => originalVal);
|
|
61
|
-
schema = addMinLengthValidator(schema, metas, options);
|
|
62
|
-
schema = addMaxLengthValidator(schema, metas);
|
|
63
|
-
schema = addStringRegexValidator(schema, metas);
|
|
64
|
-
schema = addUniqueValidator(schema, metas, options);
|
|
65
|
-
return schema;
|
|
66
|
-
};
|
|
67
|
-
const emailValidator = (metas, options) => {
|
|
68
|
-
const schema = stringValidator(metas, options);
|
|
69
|
-
return schema.email().min(1, "${path} cannot be empty");
|
|
70
|
-
};
|
|
71
|
-
const uidValidator = (metas, options) => {
|
|
72
|
-
const schema = stringValidator(metas, options);
|
|
73
|
-
return schema.matches(/^[A-Za-z0-9-_.~]*$/);
|
|
74
|
-
};
|
|
75
|
-
const enumerationValidator = ({ attr }) => {
|
|
76
|
-
return yup.string().oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null));
|
|
77
|
-
};
|
|
78
|
-
const integerValidator = (metas, options) => {
|
|
79
|
-
let schema = yup.number().integer();
|
|
80
|
-
schema = addMinIntegerValidator(schema, metas);
|
|
81
|
-
schema = addMaxIntegerValidator(schema, metas);
|
|
82
|
-
schema = addUniqueValidator(schema, metas, options);
|
|
83
|
-
return schema;
|
|
84
|
-
};
|
|
85
|
-
const floatValidator = (metas, options) => {
|
|
86
|
-
let schema = yup.number();
|
|
87
|
-
schema = addMinFloatValidator(schema, metas);
|
|
88
|
-
schema = addMaxFloatValidator(schema, metas);
|
|
89
|
-
schema = addUniqueValidator(schema, metas, options);
|
|
90
|
-
return schema;
|
|
91
|
-
};
|
|
92
|
-
const bigintegerValidator = (metas, options) => {
|
|
93
|
-
const schema = yup.mixed();
|
|
94
|
-
return addUniqueValidator(schema, metas, options);
|
|
95
|
-
};
|
|
96
|
-
const datesValidator = (metas, options) => {
|
|
97
|
-
const schema = yup.mixed();
|
|
98
|
-
return addUniqueValidator(schema, metas, options);
|
|
99
|
-
};
|
|
100
|
-
const validators = {
|
|
101
|
-
string: stringValidator,
|
|
102
|
-
text: stringValidator,
|
|
103
|
-
richtext: stringValidator,
|
|
104
|
-
password: stringValidator,
|
|
105
|
-
email: emailValidator,
|
|
106
|
-
enumeration: enumerationValidator,
|
|
107
|
-
boolean: () => yup.boolean(),
|
|
108
|
-
uid: uidValidator,
|
|
109
|
-
json: () => yup.mixed(),
|
|
110
|
-
integer: integerValidator,
|
|
111
|
-
biginteger: bigintegerValidator,
|
|
112
|
-
float: floatValidator,
|
|
113
|
-
decimal: floatValidator,
|
|
114
|
-
date: datesValidator,
|
|
115
|
-
time: datesValidator,
|
|
116
|
-
datetime: datesValidator,
|
|
117
|
-
timestamp: datesValidator,
|
|
118
|
-
blocks: blocksValidator
|
|
119
|
-
};
|
|
120
|
-
module.exports = validators;
|
|
121
|
-
//# sourceMappingURL=validators.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validators.js","sources":["../../../src/services/entity-validator/validators.ts"],"sourcesContent":["import _ from 'lodash';\nimport strapiUtils from '@strapi/utils';\nimport type { Attribute, Schema } from '@strapi/types';\nimport blocksValidator from './blocks-validator';\n\nconst { yup } = strapiUtils;\n\ninterface ValidatorMetas<TAttribute extends Attribute.Any> {\n attr: TAttribute;\n model: Schema.ContentType;\n updatedAttribute: { name: string; value: unknown };\n entity: Record<string, unknown> | null;\n}\n\ninterface ValidatorOptions {\n isDraft: boolean;\n locale?: string;\n}\n\n/* Validator utils */\n\n/**\n * Adds minLength validator\n */\nconst addMinLengthValidator = (\n validator: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return attr.minLength && _.isInteger(attr.minLength) && !isDraft\n ? validator.min(attr.minLength)\n : validator;\n};\n\n/**\n * Adds maxLength validator\n * @returns {StringSchema}\n */\nconst addMaxLengthValidator = (\n validator: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID;\n }\n) => {\n return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;\n};\n\n/**\n * Adds min integer validator\n * @returns {NumberSchema}\n */\nconst addMinIntegerValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Integer | Attribute.BigInteger;\n }\n) => (_.isNumber(attr.min) ? validator.min(_.toInteger(attr.min)) : validator);\n\n/**\n * Adds max integer validator\n */\nconst addMaxIntegerValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Integer | Attribute.BigInteger;\n }\n) => (_.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator);\n\n/**\n * Adds min float/decimal validator\n */\nconst addMinFloatValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Decimal | Attribute.Float;\n }\n) => (_.isNumber(attr.min) ? validator.min(attr.min) : validator);\n\n/**\n * Adds max float/decimal validator\n */\nconst addMaxFloatValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Decimal | Attribute.Float;\n }\n) => (_.isNumber(attr.max) ? validator.max(attr.max) : validator);\n\n/**\n * Adds regex validator\n */\nconst addStringRegexValidator = (\n validator: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID;\n }\n) => {\n return 'regex' in attr && !_.isUndefined(attr.regex)\n ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required })\n : validator;\n};\n\n/**\n * Adds unique validator\n */\nconst addUniqueValidator = <T extends strapiUtils.yup.AnySchema>(\n validator: T,\n { attr, model, updatedAttribute, entity }: ValidatorMetas<Attribute.Any & Attribute.UniqueOption>,\n options: ValidatorOptions\n): T => {\n if (attr.type !== 'uid' && !attr.unique) {\n return validator;\n }\n\n return validator.test('unique', 'This attribute must be unique', async (value) => {\n const isPublish = options.isDraft === false;\n\n /**\n * If the attribute value is `null` we want to skip the unique validation.\n * Otherwise it'll only accept a single `null` entry in the database.\n */\n if (_.isNil(value)) {\n return true;\n }\n\n /**\n * If we are updating a draft and the value is unchanged we skip the unique verification. This will\n * prevent the validator to be triggered in case the user activated the\n * unique constraint after already creating multiple entries with\n * the same attribute value for that field.\n */\n if (!isPublish && value === entity?.[updatedAttribute.name]) {\n return true;\n }\n\n /**\n * At this point we know that we are creating a new entry, publishing an entry or that the unique field value has changed\n * We check if there is an entry of this content type in the same locale, publication state and with the same unique field value\n */\n const record = await strapi.db.query(model.uid).findOne({\n where: {\n locale: options.locale,\n publishedAt: options.isDraft ? null : { $notNull: true },\n [updatedAttribute.name]: value,\n ...(entity?.id ? { id: { $ne: entity.id } } : {}),\n },\n });\n\n return !record;\n });\n};\n\n/* Type validators */\n\nconst stringValidator = (\n metas: ValidatorMetas<\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID\n >,\n options: ValidatorOptions\n) => {\n let schema = yup.string().transform((val, originalVal) => originalVal);\n\n schema = addMinLengthValidator(schema, metas, options);\n schema = addMaxLengthValidator(schema, metas);\n schema = addStringRegexValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst emailValidator = (metas: ValidatorMetas<Attribute.Email>, options: ValidatorOptions) => {\n const schema = stringValidator(metas, options);\n return schema.email().min(1, '${path} cannot be empty');\n};\n\nconst uidValidator = (metas: ValidatorMetas<Attribute.UID>, options: ValidatorOptions) => {\n const schema = stringValidator(metas, options);\n\n return schema.matches(/^[A-Za-z0-9-_.~]*$/);\n};\n\nconst enumerationValidator = ({ attr }: { attr: Attribute.Enumeration }) => {\n return yup\n .string()\n .oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null as any));\n};\n\nconst integerValidator = (\n metas: ValidatorMetas<Attribute.Integer | Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n let schema = yup.number().integer();\n\n schema = addMinIntegerValidator(schema, metas);\n schema = addMaxIntegerValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst floatValidator = (\n metas: ValidatorMetas<Attribute.Decimal | Attribute.Float>,\n options: ValidatorOptions\n) => {\n let schema = yup.number();\n schema = addMinFloatValidator(schema, metas);\n schema = addMaxFloatValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst bigintegerValidator = (\n metas: ValidatorMetas<Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nconst datesValidator = (\n metas: ValidatorMetas<Attribute.Date | Attribute.DateTime | Attribute.Time | Attribute.Timestamp>,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport default {\n string: stringValidator,\n text: stringValidator,\n richtext: stringValidator,\n password: stringValidator,\n email: emailValidator,\n enumeration: enumerationValidator,\n boolean: () => yup.boolean(),\n uid: uidValidator,\n json: () => yup.mixed(),\n integer: integerValidator,\n biginteger: bigintegerValidator,\n float: floatValidator,\n decimal: floatValidator,\n date: datesValidator,\n time: datesValidator,\n datetime: datesValidator,\n timestamp: datesValidator,\n blocks: blocksValidator,\n};\n"],"names":["strapiUtils","_"],"mappings":"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"}
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
import _ from "lodash";
|
|
2
|
-
import strapiUtils from "@strapi/utils";
|
|
3
|
-
import blocksValidator from "./blocks-validator.mjs";
|
|
4
|
-
const { yup } = strapiUtils;
|
|
5
|
-
const addMinLengthValidator = (validator, {
|
|
6
|
-
attr
|
|
7
|
-
}, { isDraft }) => {
|
|
8
|
-
return attr.minLength && _.isInteger(attr.minLength) && !isDraft ? validator.min(attr.minLength) : validator;
|
|
9
|
-
};
|
|
10
|
-
const addMaxLengthValidator = (validator, {
|
|
11
|
-
attr
|
|
12
|
-
}) => {
|
|
13
|
-
return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;
|
|
14
|
-
};
|
|
15
|
-
const addMinIntegerValidator = (validator, {
|
|
16
|
-
attr
|
|
17
|
-
}) => _.isNumber(attr.min) ? validator.min(_.toInteger(attr.min)) : validator;
|
|
18
|
-
const addMaxIntegerValidator = (validator, {
|
|
19
|
-
attr
|
|
20
|
-
}) => _.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator;
|
|
21
|
-
const addMinFloatValidator = (validator, {
|
|
22
|
-
attr
|
|
23
|
-
}) => _.isNumber(attr.min) ? validator.min(attr.min) : validator;
|
|
24
|
-
const addMaxFloatValidator = (validator, {
|
|
25
|
-
attr
|
|
26
|
-
}) => _.isNumber(attr.max) ? validator.max(attr.max) : validator;
|
|
27
|
-
const addStringRegexValidator = (validator, {
|
|
28
|
-
attr
|
|
29
|
-
}) => {
|
|
30
|
-
return "regex" in attr && !_.isUndefined(attr.regex) ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required }) : validator;
|
|
31
|
-
};
|
|
32
|
-
const addUniqueValidator = (validator, { attr, model, updatedAttribute, entity }, options) => {
|
|
33
|
-
if (attr.type !== "uid" && !attr.unique) {
|
|
34
|
-
return validator;
|
|
35
|
-
}
|
|
36
|
-
return validator.test("unique", "This attribute must be unique", async (value) => {
|
|
37
|
-
const isPublish = options.isDraft === false;
|
|
38
|
-
if (_.isNil(value)) {
|
|
39
|
-
return true;
|
|
40
|
-
}
|
|
41
|
-
if (!isPublish && value === entity?.[updatedAttribute.name]) {
|
|
42
|
-
return true;
|
|
43
|
-
}
|
|
44
|
-
const record = await strapi.db.query(model.uid).findOne({
|
|
45
|
-
where: {
|
|
46
|
-
locale: options.locale,
|
|
47
|
-
publishedAt: options.isDraft ? null : { $notNull: true },
|
|
48
|
-
[updatedAttribute.name]: value,
|
|
49
|
-
...entity?.id ? { id: { $ne: entity.id } } : {}
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
return !record;
|
|
53
|
-
});
|
|
54
|
-
};
|
|
55
|
-
const stringValidator = (metas, options) => {
|
|
56
|
-
let schema = yup.string().transform((val, originalVal) => originalVal);
|
|
57
|
-
schema = addMinLengthValidator(schema, metas, options);
|
|
58
|
-
schema = addMaxLengthValidator(schema, metas);
|
|
59
|
-
schema = addStringRegexValidator(schema, metas);
|
|
60
|
-
schema = addUniqueValidator(schema, metas, options);
|
|
61
|
-
return schema;
|
|
62
|
-
};
|
|
63
|
-
const emailValidator = (metas, options) => {
|
|
64
|
-
const schema = stringValidator(metas, options);
|
|
65
|
-
return schema.email().min(1, "${path} cannot be empty");
|
|
66
|
-
};
|
|
67
|
-
const uidValidator = (metas, options) => {
|
|
68
|
-
const schema = stringValidator(metas, options);
|
|
69
|
-
return schema.matches(/^[A-Za-z0-9-_.~]*$/);
|
|
70
|
-
};
|
|
71
|
-
const enumerationValidator = ({ attr }) => {
|
|
72
|
-
return yup.string().oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null));
|
|
73
|
-
};
|
|
74
|
-
const integerValidator = (metas, options) => {
|
|
75
|
-
let schema = yup.number().integer();
|
|
76
|
-
schema = addMinIntegerValidator(schema, metas);
|
|
77
|
-
schema = addMaxIntegerValidator(schema, metas);
|
|
78
|
-
schema = addUniqueValidator(schema, metas, options);
|
|
79
|
-
return schema;
|
|
80
|
-
};
|
|
81
|
-
const floatValidator = (metas, options) => {
|
|
82
|
-
let schema = yup.number();
|
|
83
|
-
schema = addMinFloatValidator(schema, metas);
|
|
84
|
-
schema = addMaxFloatValidator(schema, metas);
|
|
85
|
-
schema = addUniqueValidator(schema, metas, options);
|
|
86
|
-
return schema;
|
|
87
|
-
};
|
|
88
|
-
const bigintegerValidator = (metas, options) => {
|
|
89
|
-
const schema = yup.mixed();
|
|
90
|
-
return addUniqueValidator(schema, metas, options);
|
|
91
|
-
};
|
|
92
|
-
const datesValidator = (metas, options) => {
|
|
93
|
-
const schema = yup.mixed();
|
|
94
|
-
return addUniqueValidator(schema, metas, options);
|
|
95
|
-
};
|
|
96
|
-
const validators = {
|
|
97
|
-
string: stringValidator,
|
|
98
|
-
text: stringValidator,
|
|
99
|
-
richtext: stringValidator,
|
|
100
|
-
password: stringValidator,
|
|
101
|
-
email: emailValidator,
|
|
102
|
-
enumeration: enumerationValidator,
|
|
103
|
-
boolean: () => yup.boolean(),
|
|
104
|
-
uid: uidValidator,
|
|
105
|
-
json: () => yup.mixed(),
|
|
106
|
-
integer: integerValidator,
|
|
107
|
-
biginteger: bigintegerValidator,
|
|
108
|
-
float: floatValidator,
|
|
109
|
-
decimal: floatValidator,
|
|
110
|
-
date: datesValidator,
|
|
111
|
-
time: datesValidator,
|
|
112
|
-
datetime: datesValidator,
|
|
113
|
-
timestamp: datesValidator,
|
|
114
|
-
blocks: blocksValidator
|
|
115
|
-
};
|
|
116
|
-
export {
|
|
117
|
-
validators as default
|
|
118
|
-
};
|
|
119
|
-
//# sourceMappingURL=validators.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validators.mjs","sources":["../../../src/services/entity-validator/validators.ts"],"sourcesContent":["import _ from 'lodash';\nimport strapiUtils from '@strapi/utils';\nimport type { Attribute, Schema } from '@strapi/types';\nimport blocksValidator from './blocks-validator';\n\nconst { yup } = strapiUtils;\n\ninterface ValidatorMetas<TAttribute extends Attribute.Any> {\n attr: TAttribute;\n model: Schema.ContentType;\n updatedAttribute: { name: string; value: unknown };\n entity: Record<string, unknown> | null;\n}\n\ninterface ValidatorOptions {\n isDraft: boolean;\n locale?: string;\n}\n\n/* Validator utils */\n\n/**\n * Adds minLength validator\n */\nconst addMinLengthValidator = (\n validator: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return attr.minLength && _.isInteger(attr.minLength) && !isDraft\n ? validator.min(attr.minLength)\n : validator;\n};\n\n/**\n * Adds maxLength validator\n * @returns {StringSchema}\n */\nconst addMaxLengthValidator = (\n validator: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID;\n }\n) => {\n return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;\n};\n\n/**\n * Adds min integer validator\n * @returns {NumberSchema}\n */\nconst addMinIntegerValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Integer | Attribute.BigInteger;\n }\n) => (_.isNumber(attr.min) ? validator.min(_.toInteger(attr.min)) : validator);\n\n/**\n * Adds max integer validator\n */\nconst addMaxIntegerValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Integer | Attribute.BigInteger;\n }\n) => (_.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator);\n\n/**\n * Adds min float/decimal validator\n */\nconst addMinFloatValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Decimal | Attribute.Float;\n }\n) => (_.isNumber(attr.min) ? validator.min(attr.min) : validator);\n\n/**\n * Adds max float/decimal validator\n */\nconst addMaxFloatValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Decimal | Attribute.Float;\n }\n) => (_.isNumber(attr.max) ? validator.max(attr.max) : validator);\n\n/**\n * Adds regex validator\n */\nconst addStringRegexValidator = (\n validator: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID;\n }\n) => {\n return 'regex' in attr && !_.isUndefined(attr.regex)\n ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required })\n : validator;\n};\n\n/**\n * Adds unique validator\n */\nconst addUniqueValidator = <T extends strapiUtils.yup.AnySchema>(\n validator: T,\n { attr, model, updatedAttribute, entity }: ValidatorMetas<Attribute.Any & Attribute.UniqueOption>,\n options: ValidatorOptions\n): T => {\n if (attr.type !== 'uid' && !attr.unique) {\n return validator;\n }\n\n return validator.test('unique', 'This attribute must be unique', async (value) => {\n const isPublish = options.isDraft === false;\n\n /**\n * If the attribute value is `null` we want to skip the unique validation.\n * Otherwise it'll only accept a single `null` entry in the database.\n */\n if (_.isNil(value)) {\n return true;\n }\n\n /**\n * If we are updating a draft and the value is unchanged we skip the unique verification. This will\n * prevent the validator to be triggered in case the user activated the\n * unique constraint after already creating multiple entries with\n * the same attribute value for that field.\n */\n if (!isPublish && value === entity?.[updatedAttribute.name]) {\n return true;\n }\n\n /**\n * At this point we know that we are creating a new entry, publishing an entry or that the unique field value has changed\n * We check if there is an entry of this content type in the same locale, publication state and with the same unique field value\n */\n const record = await strapi.db.query(model.uid).findOne({\n where: {\n locale: options.locale,\n publishedAt: options.isDraft ? null : { $notNull: true },\n [updatedAttribute.name]: value,\n ...(entity?.id ? { id: { $ne: entity.id } } : {}),\n },\n });\n\n return !record;\n });\n};\n\n/* Type validators */\n\nconst stringValidator = (\n metas: ValidatorMetas<\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID\n >,\n options: ValidatorOptions\n) => {\n let schema = yup.string().transform((val, originalVal) => originalVal);\n\n schema = addMinLengthValidator(schema, metas, options);\n schema = addMaxLengthValidator(schema, metas);\n schema = addStringRegexValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst emailValidator = (metas: ValidatorMetas<Attribute.Email>, options: ValidatorOptions) => {\n const schema = stringValidator(metas, options);\n return schema.email().min(1, '${path} cannot be empty');\n};\n\nconst uidValidator = (metas: ValidatorMetas<Attribute.UID>, options: ValidatorOptions) => {\n const schema = stringValidator(metas, options);\n\n return schema.matches(/^[A-Za-z0-9-_.~]*$/);\n};\n\nconst enumerationValidator = ({ attr }: { attr: Attribute.Enumeration }) => {\n return yup\n .string()\n .oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null as any));\n};\n\nconst integerValidator = (\n metas: ValidatorMetas<Attribute.Integer | Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n let schema = yup.number().integer();\n\n schema = addMinIntegerValidator(schema, metas);\n schema = addMaxIntegerValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst floatValidator = (\n metas: ValidatorMetas<Attribute.Decimal | Attribute.Float>,\n options: ValidatorOptions\n) => {\n let schema = yup.number();\n schema = addMinFloatValidator(schema, metas);\n schema = addMaxFloatValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst bigintegerValidator = (\n metas: ValidatorMetas<Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nconst datesValidator = (\n metas: ValidatorMetas<Attribute.Date | Attribute.DateTime | Attribute.Time | Attribute.Timestamp>,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport default {\n string: stringValidator,\n text: stringValidator,\n richtext: stringValidator,\n password: stringValidator,\n email: emailValidator,\n enumeration: enumerationValidator,\n boolean: () => yup.boolean(),\n uid: uidValidator,\n json: () => yup.mixed(),\n integer: integerValidator,\n biginteger: bigintegerValidator,\n float: floatValidator,\n decimal: floatValidator,\n date: datesValidator,\n time: datesValidator,\n datetime: datesValidator,\n timestamp: datesValidator,\n blocks: blocksValidator,\n};\n"],"names":[],"mappings":"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"}
|
package/dist/services/errors.js
DELETED
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const createError = require("http-errors");
|
|
4
|
-
const strapiUtils = require("@strapi/utils");
|
|
5
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
6
|
-
const createError__default = /* @__PURE__ */ _interopDefault(createError);
|
|
7
|
-
const mapErrorsAndStatus = [
|
|
8
|
-
{
|
|
9
|
-
classError: strapiUtils.errors.UnauthorizedError,
|
|
10
|
-
status: 401
|
|
11
|
-
},
|
|
12
|
-
{
|
|
13
|
-
classError: strapiUtils.errors.ForbiddenError,
|
|
14
|
-
status: 403
|
|
15
|
-
},
|
|
16
|
-
{
|
|
17
|
-
classError: strapiUtils.errors.NotFoundError,
|
|
18
|
-
status: 404
|
|
19
|
-
},
|
|
20
|
-
{
|
|
21
|
-
classError: strapiUtils.errors.PayloadTooLargeError,
|
|
22
|
-
status: 413
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
classError: strapiUtils.errors.RateLimitError,
|
|
26
|
-
status: 429
|
|
27
|
-
},
|
|
28
|
-
{
|
|
29
|
-
classError: strapiUtils.errors.NotImplementedError,
|
|
30
|
-
status: 501
|
|
31
|
-
}
|
|
32
|
-
];
|
|
33
|
-
const formatApplicationError = (error) => {
|
|
34
|
-
const errorAndStatus = mapErrorsAndStatus.find((pair) => error instanceof pair.classError);
|
|
35
|
-
const status = errorAndStatus ? errorAndStatus.status : 400;
|
|
36
|
-
return {
|
|
37
|
-
status,
|
|
38
|
-
body: {
|
|
39
|
-
data: null,
|
|
40
|
-
error: {
|
|
41
|
-
status,
|
|
42
|
-
name: error.name,
|
|
43
|
-
message: error.message,
|
|
44
|
-
details: error.details
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
};
|
|
49
|
-
const formatHttpError = (error) => {
|
|
50
|
-
return {
|
|
51
|
-
status: error.status,
|
|
52
|
-
body: {
|
|
53
|
-
data: null,
|
|
54
|
-
error: {
|
|
55
|
-
status: error.status,
|
|
56
|
-
name: error.name,
|
|
57
|
-
message: error.message,
|
|
58
|
-
details: error.details
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
};
|
|
62
|
-
};
|
|
63
|
-
const formatInternalError = (error) => {
|
|
64
|
-
if (!(error instanceof Error)) {
|
|
65
|
-
return formatHttpError(createError__default.default(500));
|
|
66
|
-
}
|
|
67
|
-
const httpError = createError__default.default(error);
|
|
68
|
-
if (httpError.expose) {
|
|
69
|
-
return formatHttpError(httpError);
|
|
70
|
-
}
|
|
71
|
-
return formatHttpError(createError__default.default(httpError.status || 500));
|
|
72
|
-
};
|
|
73
|
-
exports.formatApplicationError = formatApplicationError;
|
|
74
|
-
exports.formatHttpError = formatHttpError;
|
|
75
|
-
exports.formatInternalError = formatInternalError;
|
|
76
|
-
//# sourceMappingURL=errors.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"errors.js","sources":["../../src/services/errors.ts"],"sourcesContent":["import createError from 'http-errors';\nimport { errors } from '@strapi/utils';\n\nconst mapErrorsAndStatus = [\n {\n classError: errors.UnauthorizedError,\n status: 401,\n },\n {\n classError: errors.ForbiddenError,\n status: 403,\n },\n {\n classError: errors.NotFoundError,\n status: 404,\n },\n {\n classError: errors.PayloadTooLargeError,\n status: 413,\n },\n {\n classError: errors.RateLimitError,\n status: 429,\n },\n {\n classError: errors.NotImplementedError,\n status: 501,\n },\n];\n\nconst formatApplicationError = (error: InstanceType<typeof errors.ApplicationError>) => {\n const errorAndStatus = mapErrorsAndStatus.find((pair) => error instanceof pair.classError);\n const status = errorAndStatus ? errorAndStatus.status : 400;\n\n return {\n status,\n body: {\n data: null,\n error: {\n status,\n name: error.name,\n message: error.message,\n details: error.details,\n },\n },\n };\n};\n\nconst formatHttpError = (error: createError.HttpError) => {\n return {\n status: error.status,\n body: {\n data: null,\n error: {\n status: error.status,\n name: error.name,\n message: error.message,\n details: error.details,\n },\n },\n };\n};\n\nconst formatInternalError = (error: unknown) => {\n if (!(error instanceof Error)) {\n return formatHttpError(createError(500));\n }\n\n const httpError = createError(error);\n\n if (httpError.expose) {\n return formatHttpError(httpError);\n }\n\n return formatHttpError(createError(httpError.status || 500));\n};\n\nexport { formatApplicationError, formatHttpError, formatInternalError };\n"],"names":["errors","createError"],"mappings":";;;;;;AAGA,MAAM,qBAAqB;AAAA,EACzB;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AACF;AAEM,MAAA,yBAAyB,CAAC,UAAwD;AACtF,QAAM,iBAAiB,mBAAmB,KAAK,CAAC,SAAS,iBAAiB,KAAK,UAAU;AACnF,QAAA,SAAS,iBAAiB,eAAe,SAAS;AAEjD,SAAA;AAAA,IACL;AAAA,IACA,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,QACL;AAAA,QACA,MAAM,MAAM;AAAA,QACZ,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,MACjB;AAAA,IACF;AAAA,EAAA;AAEJ;AAEM,MAAA,kBAAkB,CAAC,UAAiC;AACjD,SAAA;AAAA,IACL,QAAQ,MAAM;AAAA,IACd,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,QACL,QAAQ,MAAM;AAAA,QACd,MAAM,MAAM;AAAA,QACZ,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,MACjB;AAAA,IACF;AAAA,EAAA;AAEJ;AAEM,MAAA,sBAAsB,CAAC,UAAmB;AAC1C,MAAA,EAAE,iBAAiB,QAAQ;AACtB,WAAA,gBAAgBC,qBAAAA,QAAY,GAAG,CAAC;AAAA,EACzC;AAEM,QAAA,YAAYA,6BAAY,KAAK;AAEnC,MAAI,UAAU,QAAQ;AACpB,WAAO,gBAAgB,SAAS;AAAA,EAClC;AAEA,SAAO,gBAAgBA,qBAAAA,QAAY,UAAU,UAAU,GAAG,CAAC;AAC7D;;;;"}
|
package/dist/services/errors.mjs
DELETED
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import createError from "http-errors";
|
|
2
|
-
import { errors } from "@strapi/utils";
|
|
3
|
-
const mapErrorsAndStatus = [
|
|
4
|
-
{
|
|
5
|
-
classError: errors.UnauthorizedError,
|
|
6
|
-
status: 401
|
|
7
|
-
},
|
|
8
|
-
{
|
|
9
|
-
classError: errors.ForbiddenError,
|
|
10
|
-
status: 403
|
|
11
|
-
},
|
|
12
|
-
{
|
|
13
|
-
classError: errors.NotFoundError,
|
|
14
|
-
status: 404
|
|
15
|
-
},
|
|
16
|
-
{
|
|
17
|
-
classError: errors.PayloadTooLargeError,
|
|
18
|
-
status: 413
|
|
19
|
-
},
|
|
20
|
-
{
|
|
21
|
-
classError: errors.RateLimitError,
|
|
22
|
-
status: 429
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
classError: errors.NotImplementedError,
|
|
26
|
-
status: 501
|
|
27
|
-
}
|
|
28
|
-
];
|
|
29
|
-
const formatApplicationError = (error) => {
|
|
30
|
-
const errorAndStatus = mapErrorsAndStatus.find((pair) => error instanceof pair.classError);
|
|
31
|
-
const status = errorAndStatus ? errorAndStatus.status : 400;
|
|
32
|
-
return {
|
|
33
|
-
status,
|
|
34
|
-
body: {
|
|
35
|
-
data: null,
|
|
36
|
-
error: {
|
|
37
|
-
status,
|
|
38
|
-
name: error.name,
|
|
39
|
-
message: error.message,
|
|
40
|
-
details: error.details
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
};
|
|
44
|
-
};
|
|
45
|
-
const formatHttpError = (error) => {
|
|
46
|
-
return {
|
|
47
|
-
status: error.status,
|
|
48
|
-
body: {
|
|
49
|
-
data: null,
|
|
50
|
-
error: {
|
|
51
|
-
status: error.status,
|
|
52
|
-
name: error.name,
|
|
53
|
-
message: error.message,
|
|
54
|
-
details: error.details
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
};
|
|
58
|
-
};
|
|
59
|
-
const formatInternalError = (error) => {
|
|
60
|
-
if (!(error instanceof Error)) {
|
|
61
|
-
return formatHttpError(createError(500));
|
|
62
|
-
}
|
|
63
|
-
const httpError = createError(error);
|
|
64
|
-
if (httpError.expose) {
|
|
65
|
-
return formatHttpError(httpError);
|
|
66
|
-
}
|
|
67
|
-
return formatHttpError(createError(httpError.status || 500));
|
|
68
|
-
};
|
|
69
|
-
export {
|
|
70
|
-
formatApplicationError,
|
|
71
|
-
formatHttpError,
|
|
72
|
-
formatInternalError
|
|
73
|
-
};
|
|
74
|
-
//# sourceMappingURL=errors.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"errors.mjs","sources":["../../src/services/errors.ts"],"sourcesContent":["import createError from 'http-errors';\nimport { errors } from '@strapi/utils';\n\nconst mapErrorsAndStatus = [\n {\n classError: errors.UnauthorizedError,\n status: 401,\n },\n {\n classError: errors.ForbiddenError,\n status: 403,\n },\n {\n classError: errors.NotFoundError,\n status: 404,\n },\n {\n classError: errors.PayloadTooLargeError,\n status: 413,\n },\n {\n classError: errors.RateLimitError,\n status: 429,\n },\n {\n classError: errors.NotImplementedError,\n status: 501,\n },\n];\n\nconst formatApplicationError = (error: InstanceType<typeof errors.ApplicationError>) => {\n const errorAndStatus = mapErrorsAndStatus.find((pair) => error instanceof pair.classError);\n const status = errorAndStatus ? errorAndStatus.status : 400;\n\n return {\n status,\n body: {\n data: null,\n error: {\n status,\n name: error.name,\n message: error.message,\n details: error.details,\n },\n },\n };\n};\n\nconst formatHttpError = (error: createError.HttpError) => {\n return {\n status: error.status,\n body: {\n data: null,\n error: {\n status: error.status,\n name: error.name,\n message: error.message,\n details: error.details,\n },\n },\n };\n};\n\nconst formatInternalError = (error: unknown) => {\n if (!(error instanceof Error)) {\n return formatHttpError(createError(500));\n }\n\n const httpError = createError(error);\n\n if (httpError.expose) {\n return formatHttpError(httpError);\n }\n\n return formatHttpError(createError(httpError.status || 500));\n};\n\nexport { formatApplicationError, formatHttpError, formatInternalError };\n"],"names":[],"mappings":";;AAGA,MAAM,qBAAqB;AAAA,EACzB;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AACF;AAEM,MAAA,yBAAyB,CAAC,UAAwD;AACtF,QAAM,iBAAiB,mBAAmB,KAAK,CAAC,SAAS,iBAAiB,KAAK,UAAU;AACnF,QAAA,SAAS,iBAAiB,eAAe,SAAS;AAEjD,SAAA;AAAA,IACL;AAAA,IACA,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,QACL;AAAA,QACA,MAAM,MAAM;AAAA,QACZ,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,MACjB;AAAA,IACF;AAAA,EAAA;AAEJ;AAEM,MAAA,kBAAkB,CAAC,UAAiC;AACjD,SAAA;AAAA,IACL,QAAQ,MAAM;AAAA,IACd,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,QACL,QAAQ,MAAM;AAAA,QACd,MAAM,MAAM;AAAA,QACZ,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,MACjB;AAAA,IACF;AAAA,EAAA;AAEJ;AAEM,MAAA,sBAAsB,CAAC,UAAmB;AAC1C,MAAA,EAAE,iBAAiB,QAAQ;AACtB,WAAA,gBAAgB,YAAY,GAAG,CAAC;AAAA,EACzC;AAEM,QAAA,YAAY,YAAY,KAAK;AAEnC,MAAI,UAAU,QAAQ;AACpB,WAAO,gBAAgB,SAAS;AAAA,EAClC;AAEA,SAAO,gBAAgB,YAAY,UAAU,UAAU,GAAG,CAAC;AAC7D;"}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
function createEventHub() {
|
|
3
|
-
const listeners = /* @__PURE__ */ new Map();
|
|
4
|
-
const defaultSubscriber = async (eventName, ...args) => {
|
|
5
|
-
if (listeners.has(eventName)) {
|
|
6
|
-
for (const listener of listeners.get(eventName)) {
|
|
7
|
-
await listener(...args);
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
};
|
|
11
|
-
const subscribers = [defaultSubscriber];
|
|
12
|
-
const eventHub = {
|
|
13
|
-
async emit(eventName, ...args) {
|
|
14
|
-
for (const subscriber of subscribers) {
|
|
15
|
-
await subscriber(eventName, ...args);
|
|
16
|
-
}
|
|
17
|
-
},
|
|
18
|
-
subscribe(subscriber) {
|
|
19
|
-
subscribers.push(subscriber);
|
|
20
|
-
return () => {
|
|
21
|
-
eventHub.unsubscribe(subscriber);
|
|
22
|
-
};
|
|
23
|
-
},
|
|
24
|
-
unsubscribe(subscriber) {
|
|
25
|
-
const subscriberIndex = subscribers.indexOf(subscriber);
|
|
26
|
-
if (subscriberIndex >= 0) {
|
|
27
|
-
subscribers.splice(subscriberIndex, 1);
|
|
28
|
-
}
|
|
29
|
-
},
|
|
30
|
-
on(eventName, listener) {
|
|
31
|
-
if (!listeners.has(eventName)) {
|
|
32
|
-
listeners.set(eventName, [listener]);
|
|
33
|
-
} else {
|
|
34
|
-
listeners.get(eventName).push(listener);
|
|
35
|
-
}
|
|
36
|
-
return () => {
|
|
37
|
-
eventHub.off(eventName, listener);
|
|
38
|
-
};
|
|
39
|
-
},
|
|
40
|
-
off(eventName, listener) {
|
|
41
|
-
listeners.get(eventName).splice(listeners.get(eventName).indexOf(listener), 1);
|
|
42
|
-
},
|
|
43
|
-
once(eventName, listener) {
|
|
44
|
-
return eventHub.on(eventName, async (...args) => {
|
|
45
|
-
eventHub.off(eventName, listener);
|
|
46
|
-
return listener(...args);
|
|
47
|
-
});
|
|
48
|
-
},
|
|
49
|
-
destroy() {
|
|
50
|
-
listeners.clear();
|
|
51
|
-
subscribers.length = 0;
|
|
52
|
-
return this;
|
|
53
|
-
},
|
|
54
|
-
removeListener(eventName, listener) {
|
|
55
|
-
return eventHub.off(eventName, listener);
|
|
56
|
-
},
|
|
57
|
-
removeAllListeners() {
|
|
58
|
-
return eventHub.destroy();
|
|
59
|
-
},
|
|
60
|
-
addListener(eventName, listener) {
|
|
61
|
-
return eventHub.on(eventName, listener);
|
|
62
|
-
}
|
|
63
|
-
};
|
|
64
|
-
return eventHub;
|
|
65
|
-
}
|
|
66
|
-
module.exports = createEventHub;
|
|
67
|
-
//# sourceMappingURL=event-hub.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"event-hub.js","sources":["../../src/services/event-hub.ts"],"sourcesContent":["export type Subscriber = (eventName: string, ...args: any[]) => Promise<void>;\nexport type Listener = (...args: any[]) => Promise<void>;\n\nexport interface EventHub {\n emit(eventName: string, ...args: unknown[]): Promise<void>;\n subscribe(subscriber: Subscriber): () => void;\n unsubscribe(subscriber: Subscriber): void;\n on(eventName: string, listener: Listener): () => void;\n off(eventName: string, listener: Listener): void;\n once(eventName: string, listener: Listener): () => void;\n destroy(): EventHub;\n removeListener(eventName: string, listener: Listener): void;\n removeAllListeners(): EventHub;\n addListener(eventName: string, listener: Listener): () => void;\n}\n\n/**\n * The event hub is Strapi's event control center.\n */\nexport default function createEventHub(): EventHub {\n const listeners = new Map();\n\n // Default subscriber to easily add listeners with the on() method\n const defaultSubscriber = async (eventName: string, ...args: unknown[]) => {\n if (listeners.has(eventName)) {\n for (const listener of listeners.get(eventName)) {\n await listener(...args);\n }\n }\n };\n\n // Store of subscribers that will be called when an event is emitted\n const subscribers = [defaultSubscriber];\n\n const eventHub: EventHub = {\n async emit(eventName, ...args) {\n for (const subscriber of subscribers) {\n await subscriber(eventName, ...args);\n }\n },\n\n subscribe(subscriber) {\n subscribers.push(subscriber);\n\n // Return a function to remove the subscriber\n return () => {\n eventHub.unsubscribe(subscriber);\n };\n },\n\n unsubscribe(subscriber) {\n const subscriberIndex = subscribers.indexOf(subscriber);\n\n // Only remove the subscriber if it exists\n if (subscriberIndex >= 0) {\n subscribers.splice(subscriberIndex, 1);\n }\n },\n\n on(eventName, listener) {\n if (!listeners.has(eventName)) {\n listeners.set(eventName, [listener]);\n } else {\n listeners.get(eventName).push(listener);\n }\n\n // Return a function to remove the listener\n return () => {\n eventHub.off(eventName, listener);\n };\n },\n\n off(eventName, listener) {\n listeners.get(eventName).splice(listeners.get(eventName).indexOf(listener), 1);\n },\n\n once(eventName, listener) {\n return eventHub.on(eventName, async (...args) => {\n eventHub.off(eventName, listener);\n return listener(...args);\n });\n },\n\n destroy() {\n listeners.clear();\n subscribers.length = 0;\n return this;\n },\n\n removeListener(eventName, listener) {\n return eventHub.off(eventName, listener);\n },\n\n removeAllListeners() {\n return eventHub.destroy();\n },\n\n addListener(eventName, listener) {\n return eventHub.on(eventName, listener);\n },\n };\n\n return eventHub;\n}\n"],"names":[],"mappings":";AAmBA,SAAwB,iBAA2B;AAC3C,QAAA,gCAAgB;AAGhB,QAAA,oBAAoB,OAAO,cAAsB,SAAoB;AACrE,QAAA,UAAU,IAAI,SAAS,GAAG;AAC5B,iBAAW,YAAY,UAAU,IAAI,SAAS,GAAG;AACzC,cAAA,SAAS,GAAG,IAAI;AAAA,MACxB;AAAA,IACF;AAAA,EAAA;AAII,QAAA,cAAc,CAAC,iBAAiB;AAEtC,QAAM,WAAqB;AAAA,IACzB,MAAM,KAAK,cAAc,MAAM;AAC7B,iBAAW,cAAc,aAAa;AAC9B,cAAA,WAAW,WAAW,GAAG,IAAI;AAAA,MACrC;AAAA,IACF;AAAA,IAEA,UAAU,YAAY;AACpB,kBAAY,KAAK,UAAU;AAG3B,aAAO,MAAM;AACX,iBAAS,YAAY,UAAU;AAAA,MAAA;AAAA,IAEnC;AAAA,IAEA,YAAY,YAAY;AAChB,YAAA,kBAAkB,YAAY,QAAQ,UAAU;AAGtD,UAAI,mBAAmB,GAAG;AACZ,oBAAA,OAAO,iBAAiB,CAAC;AAAA,MACvC;AAAA,IACF;AAAA,IAEA,GAAG,WAAW,UAAU;AACtB,UAAI,CAAC,UAAU,IAAI,SAAS,GAAG;AAC7B,kBAAU,IAAI,WAAW,CAAC,QAAQ,CAAC;AAAA,MAAA,OAC9B;AACL,kBAAU,IAAI,SAAS,EAAE,KAAK,QAAQ;AAAA,MACxC;AAGA,aAAO,MAAM;AACF,iBAAA,IAAI,WAAW,QAAQ;AAAA,MAAA;AAAA,IAEpC;AAAA,IAEA,IAAI,WAAW,UAAU;AACb,gBAAA,IAAI,SAAS,EAAE,OAAO,UAAU,IAAI,SAAS,EAAE,QAAQ,QAAQ,GAAG,CAAC;AAAA,IAC/E;AAAA,IAEA,KAAK,WAAW,UAAU;AACxB,aAAO,SAAS,GAAG,WAAW,UAAU,SAAS;AACtC,iBAAA,IAAI,WAAW,QAAQ;AACzB,eAAA,SAAS,GAAG,IAAI;AAAA,MAAA,CACxB;AAAA,IACH;AAAA,IAEA,UAAU;AACR,gBAAU,MAAM;AAChB,kBAAY,SAAS;AACd,aAAA;AAAA,IACT;AAAA,IAEA,eAAe,WAAW,UAAU;AAC3B,aAAA,SAAS,IAAI,WAAW,QAAQ;AAAA,IACzC;AAAA,IAEA,qBAAqB;AACnB,aAAO,SAAS;IAClB;AAAA,IAEA,YAAY,WAAW,UAAU;AACxB,aAAA,SAAS,GAAG,WAAW,QAAQ;AAAA,IACxC;AAAA,EAAA;AAGK,SAAA;AACT;;"}
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
function createEventHub() {
|
|
2
|
-
const listeners = /* @__PURE__ */ new Map();
|
|
3
|
-
const defaultSubscriber = async (eventName, ...args) => {
|
|
4
|
-
if (listeners.has(eventName)) {
|
|
5
|
-
for (const listener of listeners.get(eventName)) {
|
|
6
|
-
await listener(...args);
|
|
7
|
-
}
|
|
8
|
-
}
|
|
9
|
-
};
|
|
10
|
-
const subscribers = [defaultSubscriber];
|
|
11
|
-
const eventHub = {
|
|
12
|
-
async emit(eventName, ...args) {
|
|
13
|
-
for (const subscriber of subscribers) {
|
|
14
|
-
await subscriber(eventName, ...args);
|
|
15
|
-
}
|
|
16
|
-
},
|
|
17
|
-
subscribe(subscriber) {
|
|
18
|
-
subscribers.push(subscriber);
|
|
19
|
-
return () => {
|
|
20
|
-
eventHub.unsubscribe(subscriber);
|
|
21
|
-
};
|
|
22
|
-
},
|
|
23
|
-
unsubscribe(subscriber) {
|
|
24
|
-
const subscriberIndex = subscribers.indexOf(subscriber);
|
|
25
|
-
if (subscriberIndex >= 0) {
|
|
26
|
-
subscribers.splice(subscriberIndex, 1);
|
|
27
|
-
}
|
|
28
|
-
},
|
|
29
|
-
on(eventName, listener) {
|
|
30
|
-
if (!listeners.has(eventName)) {
|
|
31
|
-
listeners.set(eventName, [listener]);
|
|
32
|
-
} else {
|
|
33
|
-
listeners.get(eventName).push(listener);
|
|
34
|
-
}
|
|
35
|
-
return () => {
|
|
36
|
-
eventHub.off(eventName, listener);
|
|
37
|
-
};
|
|
38
|
-
},
|
|
39
|
-
off(eventName, listener) {
|
|
40
|
-
listeners.get(eventName).splice(listeners.get(eventName).indexOf(listener), 1);
|
|
41
|
-
},
|
|
42
|
-
once(eventName, listener) {
|
|
43
|
-
return eventHub.on(eventName, async (...args) => {
|
|
44
|
-
eventHub.off(eventName, listener);
|
|
45
|
-
return listener(...args);
|
|
46
|
-
});
|
|
47
|
-
},
|
|
48
|
-
destroy() {
|
|
49
|
-
listeners.clear();
|
|
50
|
-
subscribers.length = 0;
|
|
51
|
-
return this;
|
|
52
|
-
},
|
|
53
|
-
removeListener(eventName, listener) {
|
|
54
|
-
return eventHub.off(eventName, listener);
|
|
55
|
-
},
|
|
56
|
-
removeAllListeners() {
|
|
57
|
-
return eventHub.destroy();
|
|
58
|
-
},
|
|
59
|
-
addListener(eventName, listener) {
|
|
60
|
-
return eventHub.on(eventName, listener);
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
return eventHub;
|
|
64
|
-
}
|
|
65
|
-
export {
|
|
66
|
-
createEventHub as default
|
|
67
|
-
};
|
|
68
|
-
//# sourceMappingURL=event-hub.mjs.map
|