@strapi/core 0.0.0-experimental.6dbac0c205b0f8495781db5706c18cac1a62e62b → 0.0.0-experimental.7273fc63f5c2c8aa9e100655b1776f3e0621e61a
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 +53 -57
- package/dist/Strapi.d.ts.map +1 -1
- package/dist/Strapi.js +212 -217
- package/dist/Strapi.js.map +1 -1
- package/dist/Strapi.mjs +185 -209
- package/dist/Strapi.mjs.map +1 -1
- package/dist/configuration/config-loader.d.ts.map +1 -0
- package/dist/configuration/config-loader.js +106 -0
- package/dist/configuration/config-loader.js.map +1 -0
- package/dist/configuration/config-loader.mjs +104 -0
- package/dist/configuration/config-loader.mjs.map +1 -0
- package/dist/configuration/get-dirs.d.ts +10 -0
- package/dist/configuration/get-dirs.d.ts.map +1 -0
- package/dist/configuration/get-dirs.js +31 -0
- package/dist/configuration/get-dirs.js.map +1 -0
- package/dist/configuration/get-dirs.mjs +31 -0
- package/dist/configuration/get-dirs.mjs.map +1 -0
- package/dist/configuration/index.d.ts +48 -0
- package/dist/configuration/index.d.ts.map +1 -0
- package/dist/configuration/index.js +80 -0
- package/dist/configuration/index.js.map +1 -0
- package/dist/configuration/index.mjs +75 -0
- package/dist/configuration/index.mjs.map +1 -0
- package/dist/configuration/urls.d.ts +8 -0
- package/dist/configuration/urls.d.ts.map +1 -0
- package/dist/configuration/urls.js +68 -0
- package/dist/configuration/urls.js.map +1 -0
- package/dist/configuration/urls.mjs +66 -0
- package/dist/configuration/urls.mjs.map +1 -0
- package/dist/container.d.ts +2 -2
- package/dist/container.d.ts.map +1 -1
- package/dist/container.js.map +1 -1
- package/dist/container.mjs.map +1 -1
- package/dist/core-api/controller/collection-type.d.ts +4 -4
- package/dist/core-api/controller/collection-type.d.ts.map +1 -1
- package/dist/core-api/controller/collection-type.js +15 -23
- package/dist/core-api/controller/collection-type.js.map +1 -1
- package/dist/core-api/controller/collection-type.mjs +11 -20
- package/dist/core-api/controller/collection-type.mjs.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/index.js +15 -10
- package/dist/core-api/controller/index.js.map +1 -1
- package/dist/core-api/controller/index.mjs +14 -9
- package/dist/core-api/controller/index.mjs.map +1 -1
- package/dist/core-api/controller/single-type.d.ts +4 -4
- package/dist/core-api/controller/single-type.d.ts.map +1 -1
- package/dist/core-api/controller/single-type.js +9 -13
- package/dist/core-api/controller/single-type.js.map +1 -1
- package/dist/core-api/controller/single-type.mjs +6 -11
- package/dist/core-api/controller/single-type.mjs.map +1 -1
- package/dist/core-api/controller/transform.d.ts +10 -18
- package/dist/core-api/controller/transform.d.ts.map +1 -1
- package/dist/core-api/controller/transform.js +17 -25
- package/dist/core-api/controller/transform.js.map +1 -1
- package/dist/core-api/controller/transform.mjs +10 -18
- package/dist/core-api/controller/transform.mjs.map +1 -1
- package/dist/core-api/routes/index.d.ts.map +1 -1
- package/dist/core-api/service/collection-type.d.ts +22 -5
- package/dist/core-api/service/collection-type.d.ts.map +1 -1
- package/dist/core-api/service/collection-type.js +58 -49
- package/dist/core-api/service/collection-type.js.map +1 -1
- package/dist/core-api/service/collection-type.mjs +58 -50
- package/dist/core-api/service/collection-type.mjs.map +1 -1
- package/dist/core-api/service/core-service.d.ts +4 -0
- package/dist/core-api/service/core-service.d.ts.map +1 -0
- package/dist/core-api/service/core-service.js +12 -0
- package/dist/core-api/service/core-service.js.map +1 -0
- package/dist/core-api/service/core-service.mjs +12 -0
- package/dist/core-api/service/core-service.mjs.map +1 -0
- 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/index.js +2 -2
- package/dist/core-api/service/index.js.map +1 -1
- package/dist/core-api/service/index.mjs +4 -4
- package/dist/core-api/service/index.mjs.map +1 -1
- package/dist/core-api/service/pagination.d.ts +4 -15
- package/dist/core-api/service/pagination.d.ts.map +1 -1
- package/dist/core-api/service/pagination.js +18 -55
- package/dist/core-api/service/pagination.js.map +1 -1
- package/dist/core-api/service/pagination.mjs +16 -53
- package/dist/core-api/service/pagination.mjs.map +1 -1
- package/dist/core-api/service/single-type.d.ts +14 -8
- package/dist/core-api/service/single-type.d.ts.map +1 -1
- package/dist/core-api/service/single-type.js +42 -50
- package/dist/core-api/service/single-type.js.map +1 -1
- package/dist/core-api/service/single-type.mjs +41 -50
- package/dist/core-api/service/single-type.mjs.map +1 -1
- package/dist/domain/content-type/index.d.ts +10 -0
- package/dist/domain/content-type/index.d.ts.map +1 -0
- package/dist/domain/content-type/index.js +111 -0
- package/dist/domain/content-type/index.js.map +1 -0
- package/dist/domain/content-type/index.mjs +109 -0
- package/dist/domain/content-type/index.mjs.map +1 -0
- package/dist/domain/content-type/validator.d.ts.map +1 -0
- package/dist/domain/content-type/validator.js +77 -0
- package/dist/domain/content-type/validator.js.map +1 -0
- package/dist/domain/content-type/validator.mjs +75 -0
- package/dist/domain/content-type/validator.mjs.map +1 -0
- package/dist/domain/module/index.d.ts +40 -0
- package/dist/domain/module/index.d.ts.map +1 -0
- package/dist/domain/module/index.js +107 -0
- package/dist/domain/module/index.js.map +1 -0
- package/dist/domain/module/index.mjs +105 -0
- package/dist/domain/module/index.mjs.map +1 -0
- package/dist/domain/module/validation.d.ts.map +1 -0
- package/dist/domain/module/validation.js.map +1 -0
- package/dist/domain/module/validation.mjs.map +1 -0
- package/dist/ee/index.d.ts +4 -2
- package/dist/ee/index.d.ts.map +1 -1
- package/dist/ee/index.js +11 -6
- package/dist/ee/index.js.map +1 -1
- package/dist/ee/index.mjs +8 -3
- package/dist/ee/index.mjs.map +1 -1
- package/dist/ee/license.d.ts +2 -2
- package/dist/ee/license.d.ts.map +1 -1
- package/dist/ee/license.js +3 -1
- package/dist/ee/license.js.map +1 -1
- package/dist/ee/license.mjs +3 -1
- package/dist/ee/license.mjs.map +1 -1
- package/dist/factories.d.ts +11 -10
- package/dist/factories.d.ts.map +1 -1
- package/dist/factories.js +26 -17
- package/dist/factories.js.map +1 -1
- package/dist/factories.mjs +23 -14
- package/dist/factories.mjs.map +1 -1
- package/dist/index.d.ts +19 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +27 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +28 -2
- package/dist/index.mjs.map +1 -1
- package/dist/loaders/admin.d.ts +3 -0
- package/dist/loaders/admin.d.ts.map +1 -0
- package/dist/loaders/admin.js +26 -0
- package/dist/loaders/admin.js.map +1 -0
- package/dist/loaders/admin.mjs +25 -0
- package/dist/loaders/admin.mjs.map +1 -0
- package/dist/loaders/apis.d.ts +3 -0
- package/dist/loaders/apis.d.ts.map +1 -0
- package/dist/loaders/apis.js +137 -0
- package/dist/loaders/apis.js.map +1 -0
- package/dist/loaders/apis.mjs +135 -0
- package/dist/loaders/apis.mjs.map +1 -0
- package/dist/loaders/components.d.ts +3 -0
- package/dist/loaders/components.d.ts.map +1 -0
- package/dist/loaders/components.js +38 -0
- package/dist/loaders/components.js.map +1 -0
- package/dist/loaders/components.mjs +37 -0
- package/dist/loaders/components.mjs.map +1 -0
- package/dist/loaders/index.d.ts +3 -0
- package/dist/loaders/index.d.ts.map +1 -0
- package/dist/loaders/index.js +24 -0
- package/dist/loaders/index.js.map +1 -0
- package/dist/loaders/index.mjs +24 -0
- package/dist/loaders/index.mjs.map +1 -0
- package/dist/loaders/middlewares.d.ts +3 -0
- package/dist/loaders/middlewares.d.ts.map +1 -0
- package/dist/loaders/middlewares.js +31 -0
- package/dist/loaders/middlewares.js.map +1 -0
- package/dist/loaders/middlewares.mjs +30 -0
- package/dist/loaders/middlewares.mjs.map +1 -0
- package/dist/loaders/plugins/get-enabled-plugins.d.ts +5 -0
- package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -0
- package/dist/loaders/plugins/get-enabled-plugins.js +141 -0
- package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -0
- package/dist/loaders/plugins/get-enabled-plugins.mjs +117 -0
- package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
- package/dist/loaders/plugins/get-user-plugins-config.d.ts.map +1 -0
- package/dist/loaders/plugins/get-user-plugins-config.js +27 -0
- package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -0
- package/dist/loaders/plugins/get-user-plugins-config.mjs +25 -0
- package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
- package/dist/loaders/plugins/index.d.ts +3 -0
- package/dist/loaders/plugins/index.d.ts.map +1 -0
- package/dist/loaders/plugins/index.js +145 -0
- package/dist/loaders/plugins/index.js.map +1 -0
- package/dist/loaders/plugins/index.mjs +125 -0
- package/dist/loaders/plugins/index.mjs.map +1 -0
- package/dist/loaders/policies.d.ts +3 -0
- package/dist/loaders/policies.d.ts.map +1 -0
- package/dist/loaders/policies.js.map +1 -0
- package/dist/loaders/policies.mjs.map +1 -0
- package/dist/loaders/sanitizers.d.ts +4 -0
- package/dist/loaders/sanitizers.d.ts.map +1 -0
- package/dist/loaders/sanitizers.js.map +1 -0
- package/dist/loaders/sanitizers.mjs.map +1 -0
- package/dist/loaders/src-index.d.ts +4 -0
- package/dist/loaders/src-index.d.ts.map +1 -0
- package/dist/loaders/src-index.js.map +1 -0
- package/dist/loaders/src-index.mjs.map +1 -0
- package/dist/loaders/validators.d.ts +4 -0
- package/dist/loaders/validators.d.ts.map +1 -0
- package/dist/loaders/validators.js.map +1 -0
- package/dist/loaders/validators.mjs.map +1 -0
- package/dist/middlewares/body.d.ts +4 -4
- package/dist/middlewares/body.d.ts.map +1 -1
- package/dist/middlewares/body.js +6 -6
- package/dist/middlewares/body.js.map +1 -1
- package/dist/middlewares/body.mjs +4 -4
- package/dist/middlewares/body.mjs.map +1 -1
- package/dist/middlewares/compression.d.ts +2 -2
- package/dist/middlewares/compression.d.ts.map +1 -1
- package/dist/middlewares/compression.js.map +1 -1
- package/dist/middlewares/compression.mjs.map +1 -1
- package/dist/middlewares/cors.d.ts +2 -2
- package/dist/middlewares/cors.d.ts.map +1 -1
- package/dist/middlewares/cors.js +9 -7
- package/dist/middlewares/cors.js.map +1 -1
- package/dist/middlewares/cors.mjs +9 -7
- package/dist/middlewares/cors.mjs.map +1 -1
- package/dist/middlewares/errors.d.ts +2 -2
- package/dist/middlewares/errors.d.ts.map +1 -1
- package/dist/middlewares/errors.js.map +1 -1
- package/dist/middlewares/errors.mjs.map +1 -1
- package/dist/middlewares/favicon.d.ts +3 -2
- package/dist/middlewares/favicon.d.ts.map +1 -1
- package/dist/middlewares/favicon.js.map +1 -1
- package/dist/middlewares/favicon.mjs.map +1 -1
- package/dist/middlewares/index.d.ts +2 -2
- package/dist/middlewares/index.d.ts.map +1 -1
- package/dist/middlewares/index.js +2 -2
- package/dist/middlewares/index.js.map +1 -1
- package/dist/middlewares/index.mjs +1 -1
- package/dist/middlewares/index.mjs.map +1 -1
- package/dist/middlewares/ip.d.ts +2 -2
- package/dist/middlewares/ip.d.ts.map +1 -1
- package/dist/middlewares/ip.js.map +1 -1
- package/dist/middlewares/ip.mjs.map +1 -1
- package/dist/middlewares/logger.d.ts +2 -2
- package/dist/middlewares/logger.d.ts.map +1 -1
- package/dist/middlewares/logger.js.map +1 -1
- package/dist/middlewares/logger.mjs.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/powered-by.js.map +1 -1
- package/dist/middlewares/powered-by.mjs.map +1 -1
- package/dist/middlewares/public.d.ts +3 -0
- package/dist/middlewares/public.d.ts.map +1 -0
- package/dist/middlewares/public.js +34 -0
- package/dist/middlewares/public.js.map +1 -0
- package/dist/middlewares/public.mjs +32 -0
- package/dist/middlewares/public.mjs.map +1 -0
- package/dist/middlewares/query.d.ts +2 -2
- package/dist/middlewares/query.d.ts.map +1 -1
- package/dist/middlewares/query.js.map +1 -1
- package/dist/middlewares/query.mjs.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/response-time.js.map +1 -1
- package/dist/middlewares/response-time.mjs.map +1 -1
- package/dist/middlewares/responses.d.ts +3 -3
- package/dist/middlewares/responses.d.ts.map +1 -1
- package/dist/middlewares/responses.js +2 -2
- package/dist/middlewares/responses.js.map +1 -1
- package/dist/middlewares/responses.mjs.map +1 -1
- package/dist/middlewares/security.d.ts +2 -2
- package/dist/middlewares/security.d.ts.map +1 -1
- package/dist/middlewares/security.js +34 -6
- package/dist/middlewares/security.js.map +1 -1
- package/dist/middlewares/security.mjs +33 -5
- package/dist/middlewares/security.mjs.map +1 -1
- package/dist/middlewares/session.d.ts +2 -2
- package/dist/middlewares/session.d.ts.map +1 -1
- package/dist/middlewares/session.js +2 -2
- package/dist/middlewares/session.js.map +1 -1
- package/dist/middlewares/session.mjs.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/database/5.0.0-discard-drafts.js +106 -0
- package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
- package/dist/migrations/database/5.0.0-discard-drafts.mjs +106 -0
- package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
- package/dist/migrations/draft-publish.d.ts +17 -0
- package/dist/migrations/draft-publish.d.ts.map +1 -0
- package/dist/migrations/draft-publish.js +42 -0
- package/dist/migrations/draft-publish.js.map +1 -0
- package/dist/migrations/draft-publish.mjs +42 -0
- package/dist/migrations/draft-publish.mjs.map +1 -0
- package/dist/migrations/i18n.d.ts +5 -0
- package/dist/migrations/i18n.d.ts.map +1 -0
- package/dist/migrations/i18n.js +54 -0
- package/dist/migrations/i18n.js.map +1 -0
- package/dist/migrations/i18n.mjs +54 -0
- package/dist/migrations/i18n.mjs.map +1 -0
- package/dist/migrations/index.d.ts +5 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/migrations/index.js +15 -0
- package/dist/migrations/index.js.map +1 -0
- package/dist/migrations/index.mjs +15 -0
- package/dist/migrations/index.mjs.map +1 -0
- package/dist/providers/admin.d.ts +3 -0
- package/dist/providers/admin.d.ts.map +1 -0
- package/dist/providers/admin.js +20 -0
- package/dist/providers/admin.js.map +1 -0
- package/dist/providers/admin.mjs +21 -0
- package/dist/providers/admin.mjs.map +1 -0
- package/dist/providers/coreStore.d.ts +3 -0
- package/dist/providers/coreStore.d.ts.map +1 -0
- package/dist/providers/coreStore.js +11 -0
- package/dist/providers/coreStore.js.map +1 -0
- package/dist/providers/coreStore.mjs +12 -0
- package/dist/providers/coreStore.mjs.map +1 -0
- package/dist/providers/cron.d.ts +3 -0
- package/dist/providers/cron.d.ts.map +1 -0
- package/dist/providers/cron.js +20 -0
- package/dist/providers/cron.js.map +1 -0
- package/dist/providers/cron.mjs +21 -0
- package/dist/providers/cron.mjs.map +1 -0
- package/dist/providers/index.d.ts +3 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +11 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/index.mjs +11 -0
- package/dist/providers/index.mjs.map +1 -0
- package/dist/providers/provider.d.ts +9 -0
- package/dist/providers/provider.d.ts.map +1 -0
- package/dist/providers/provider.js +5 -0
- package/dist/providers/provider.js.map +1 -0
- package/dist/providers/provider.mjs +5 -0
- package/dist/providers/provider.mjs.map +1 -0
- package/dist/providers/registries.d.ts +3 -0
- package/dist/providers/registries.d.ts.map +1 -0
- package/dist/providers/registries.js +35 -0
- package/dist/providers/registries.js.map +1 -0
- package/dist/providers/registries.mjs +36 -0
- package/dist/providers/registries.mjs.map +1 -0
- package/dist/providers/telemetry.d.ts +3 -0
- package/dist/providers/telemetry.d.ts.map +1 -0
- package/dist/providers/telemetry.js +19 -0
- package/dist/providers/telemetry.js.map +1 -0
- package/dist/providers/telemetry.mjs +20 -0
- package/dist/providers/telemetry.mjs.map +1 -0
- package/dist/providers/webhooks.d.ts +3 -0
- package/dist/providers/webhooks.d.ts.map +1 -0
- package/dist/providers/webhooks.js +30 -0
- package/dist/providers/webhooks.js.map +1 -0
- package/dist/providers/webhooks.mjs +31 -0
- package/dist/providers/webhooks.mjs.map +1 -0
- package/dist/registries/apis.d.ts +8 -0
- package/dist/registries/apis.d.ts.map +1 -0
- package/dist/registries/apis.js +23 -0
- package/dist/registries/apis.js.map +1 -0
- package/dist/registries/apis.mjs.map +1 -0
- package/dist/registries/components.d.ts +25 -0
- package/dist/registries/components.d.ts.map +1 -0
- package/dist/registries/components.js +45 -0
- package/dist/registries/components.js.map +1 -0
- package/dist/registries/components.mjs.map +1 -0
- package/dist/registries/content-types.d.ts +33 -0
- package/dist/registries/content-types.d.ts.map +1 -0
- package/dist/registries/content-types.js +70 -0
- package/dist/registries/content-types.js.map +1 -0
- package/dist/registries/content-types.mjs +71 -0
- package/dist/registries/content-types.mjs.map +1 -0
- package/dist/registries/controllers.d.ts +35 -0
- package/dist/registries/controllers.d.ts.map +1 -0
- package/dist/registries/controllers.js +80 -0
- package/dist/registries/controllers.js.map +1 -0
- package/dist/registries/controllers.mjs +81 -0
- package/dist/registries/controllers.mjs.map +1 -0
- package/dist/registries/custom-fields.d.ts +8 -0
- package/dist/registries/custom-fields.d.ts.map +1 -0
- package/dist/registries/custom-fields.js +71 -0
- package/dist/registries/custom-fields.js.map +1 -0
- package/dist/registries/custom-fields.mjs.map +1 -0
- package/dist/registries/hooks.d.ts.map +1 -0
- package/dist/registries/hooks.js +58 -0
- package/dist/registries/hooks.js.map +1 -0
- package/dist/registries/hooks.mjs +59 -0
- package/dist/registries/hooks.mjs.map +1 -0
- package/dist/registries/index.d.ts +15 -0
- package/dist/registries/index.d.ts.map +1 -0
- package/dist/registries/middlewares.d.ts +31 -0
- package/dist/registries/middlewares.d.ts.map +1 -0
- package/dist/registries/middlewares.js +60 -0
- package/dist/registries/middlewares.js.map +1 -0
- package/dist/registries/middlewares.mjs +61 -0
- package/dist/registries/middlewares.mjs.map +1 -0
- package/dist/registries/models.d.ts +6 -0
- package/dist/registries/models.d.ts.map +1 -0
- package/dist/registries/models.js +16 -0
- package/dist/registries/models.js.map +1 -0
- package/dist/registries/models.mjs +16 -0
- package/dist/registries/models.mjs.map +1 -0
- package/dist/registries/modules.d.ts +15 -0
- package/dist/registries/modules.d.ts.map +1 -0
- package/dist/registries/modules.js +39 -0
- package/dist/registries/modules.js.map +1 -0
- package/dist/registries/modules.mjs.map +1 -0
- package/dist/registries/namespace.d.ts +5 -0
- package/dist/registries/namespace.d.ts.map +1 -0
- package/dist/registries/namespace.js +27 -0
- package/dist/registries/namespace.js.map +1 -0
- package/dist/registries/namespace.mjs +27 -0
- package/dist/registries/namespace.mjs.map +1 -0
- package/dist/registries/plugins.d.ts +9 -0
- package/dist/registries/plugins.d.ts.map +1 -0
- package/dist/registries/plugins.js +23 -0
- package/dist/registries/plugins.js.map +1 -0
- package/dist/registries/plugins.mjs.map +1 -0
- package/dist/registries/policies.d.ts +46 -0
- package/dist/registries/policies.d.ts.map +1 -0
- package/dist/registries/policies.js +108 -0
- package/dist/registries/policies.js.map +1 -0
- package/dist/registries/policies.mjs +109 -0
- package/dist/registries/policies.mjs.map +1 -0
- package/dist/registries/sanitizers.d.ts.map +1 -0
- package/dist/registries/sanitizers.js.map +1 -0
- package/dist/registries/sanitizers.mjs.map +1 -0
- package/dist/registries/services.d.ts +35 -0
- package/dist/registries/services.d.ts.map +1 -0
- package/dist/registries/services.js +80 -0
- package/dist/registries/services.js.map +1 -0
- package/dist/registries/services.mjs +81 -0
- package/dist/registries/services.mjs.map +1 -0
- package/dist/registries/validators.d.ts.map +1 -0
- package/dist/registries/validators.js.map +1 -0
- package/dist/registries/validators.mjs.map +1 -0
- package/dist/services/auth/index.d.ts +4 -4
- package/dist/services/auth/index.d.ts.map +1 -1
- package/dist/services/auth/index.js +3 -3
- package/dist/services/auth/index.js.map +1 -1
- package/dist/services/auth/index.mjs.map +1 -1
- package/dist/services/config.d.ts +3 -0
- package/dist/services/config.d.ts.map +1 -0
- package/dist/services/config.js +47 -0
- package/dist/services/config.js.map +1 -0
- package/dist/services/config.mjs +47 -0
- package/dist/services/config.mjs.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/index.js +28 -2
- package/dist/services/content-api/index.js.map +1 -1
- package/dist/services/content-api/index.mjs +28 -2
- package/dist/services/content-api/index.mjs.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/index.js +1 -1
- package/dist/services/content-api/permissions/index.js.map +1 -1
- package/dist/services/content-api/permissions/index.mjs +1 -1
- package/dist/services/content-api/permissions/index.mjs.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 +2 -22
- package/dist/services/core-store.d.ts.map +1 -1
- package/dist/services/core-store.js +8 -4
- package/dist/services/core-store.js.map +1 -1
- package/dist/services/core-store.mjs +5 -1
- package/dist/services/core-store.mjs.map +1 -1
- package/dist/services/cron.d.ts +5 -5
- package/dist/services/cron.d.ts.map +1 -1
- package/dist/services/cron.js +12 -7
- package/dist/services/cron.js.map +1 -1
- package/dist/services/cron.mjs +9 -4
- package/dist/services/cron.mjs.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/custom-fields.js.map +1 -1
- package/dist/services/custom-fields.mjs.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/index.js +22 -0
- package/dist/services/document-service/attributes/index.js.map +1 -0
- package/dist/services/document-service/attributes/index.mjs +22 -0
- package/dist/services/document-service/attributes/index.mjs.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/attributes/transforms.js +20 -0
- package/dist/services/document-service/attributes/transforms.js.map +1 -0
- package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
- package/dist/services/document-service/common.d.ts +4 -0
- package/dist/services/document-service/common.d.ts.map +1 -0
- package/dist/services/document-service/common.js +7 -0
- package/dist/services/document-service/common.js.map +1 -0
- package/dist/services/document-service/common.mjs +7 -0
- package/dist/services/document-service/common.mjs.map +1 -0
- 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/components.js +288 -0
- package/dist/services/document-service/components.js.map +1 -0
- package/dist/services/document-service/components.mjs +286 -0
- package/dist/services/document-service/components.mjs.map +1 -0
- package/dist/services/document-service/draft-and-publish.d.ts +10 -0
- package/dist/services/document-service/draft-and-publish.d.ts.map +1 -0
- package/dist/services/document-service/draft-and-publish.js +69 -0
- package/dist/services/document-service/draft-and-publish.js.map +1 -0
- package/dist/services/document-service/draft-and-publish.mjs +69 -0
- package/dist/services/document-service/draft-and-publish.mjs.map +1 -0
- 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/entries.js +95 -0
- package/dist/services/document-service/entries.js.map +1 -0
- package/dist/services/document-service/entries.mjs +95 -0
- package/dist/services/document-service/entries.mjs.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/events.js +47 -0
- package/dist/services/document-service/events.js.map +1 -0
- package/dist/services/document-service/events.mjs +47 -0
- package/dist/services/document-service/events.mjs.map +1 -0
- package/dist/services/document-service/index.d.ts +17 -7
- package/dist/services/document-service/index.d.ts.map +1 -1
- package/dist/services/document-service/index.js +28 -186
- package/dist/services/document-service/index.js.map +1 -1
- package/dist/services/document-service/index.mjs +27 -186
- package/dist/services/document-service/index.mjs.map +1 -1
- package/dist/services/document-service/internationalization.d.ts +8 -0
- package/dist/services/document-service/internationalization.d.ts.map +1 -0
- package/dist/services/document-service/internationalization.js +63 -0
- package/dist/services/document-service/internationalization.js.map +1 -0
- package/dist/services/document-service/internationalization.mjs +63 -0
- package/dist/services/document-service/internationalization.mjs.map +1 -0
- 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/errors.js +25 -0
- package/dist/services/document-service/middlewares/errors.js.map +1 -0
- package/dist/services/document-service/middlewares/errors.mjs +25 -0
- package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
- package/dist/services/document-service/middlewares/index.d.ts +2 -10
- package/dist/services/document-service/middlewares/index.d.ts.map +1 -1
- 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/middlewares/middleware-manager.js +49 -0
- package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
- package/dist/services/document-service/middlewares/middleware-manager.mjs +49 -0
- package/dist/services/document-service/middlewares/middleware-manager.mjs.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/params.js +8 -0
- package/dist/services/document-service/params.js.map +1 -0
- package/dist/services/document-service/params.mjs +8 -0
- package/dist/services/document-service/params.mjs.map +1 -0
- package/dist/services/document-service/repository.d.ts +3 -0
- package/dist/services/document-service/repository.d.ts.map +1 -0
- package/dist/services/document-service/repository.js +329 -0
- package/dist/services/document-service/repository.js.map +1 -0
- package/dist/services/document-service/repository.mjs +329 -0
- package/dist/services/document-service/repository.mjs.map +1 -0
- package/dist/services/document-service/transform/data.d.ts +5 -0
- package/dist/services/document-service/transform/data.d.ts.map +1 -0
- package/dist/services/document-service/transform/data.js +15 -0
- package/dist/services/document-service/transform/data.js.map +1 -0
- package/dist/services/document-service/transform/data.mjs +15 -0
- package/dist/services/document-service/transform/data.mjs.map +1 -0
- package/dist/services/document-service/transform/fields.d.ts +5 -0
- package/dist/services/document-service/transform/fields.d.ts.map +1 -0
- package/dist/services/document-service/transform/fields.js +24 -0
- package/dist/services/document-service/transform/fields.js.map +1 -0
- package/dist/services/document-service/transform/fields.mjs +24 -0
- package/dist/services/document-service/transform/fields.mjs.map +1 -0
- package/dist/services/document-service/transform/id-map.d.ts +23 -0
- package/dist/services/document-service/transform/id-map.d.ts.map +1 -0
- package/dist/services/document-service/transform/id-map.js +87 -0
- package/dist/services/document-service/transform/id-map.js.map +1 -0
- package/dist/services/document-service/transform/id-map.mjs +87 -0
- package/dist/services/document-service/transform/id-map.mjs.map +1 -0
- package/dist/services/document-service/transform/id-transform.d.ts +5 -0
- package/dist/services/document-service/transform/id-transform.d.ts.map +1 -0
- package/dist/services/document-service/transform/id-transform.js +33 -0
- package/dist/services/document-service/transform/id-transform.js.map +1 -0
- package/dist/services/document-service/transform/id-transform.mjs +33 -0
- package/dist/services/document-service/transform/id-transform.mjs.map +1 -0
- package/dist/services/document-service/transform/populate.d.ts +6 -0
- package/dist/services/document-service/transform/populate.d.ts.map +1 -0
- package/dist/services/document-service/transform/populate.js +21 -0
- package/dist/services/document-service/transform/populate.js.map +1 -0
- package/dist/services/document-service/transform/populate.mjs +21 -0
- package/dist/services/document-service/transform/populate.mjs.map +1 -0
- 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/query.js +9 -0
- package/dist/services/document-service/transform/query.js.map +1 -0
- package/dist/services/document-service/transform/query.mjs +9 -0
- package/dist/services/document-service/transform/query.mjs.map +1 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +14 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.js +57 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.mjs +57 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -0
- package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +14 -0
- package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/transform/data-ids.js +76 -0
- package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -0
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs +76 -0
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -0
- 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/transform/default-locale.js +32 -0
- package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
- package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
- package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
- package/dist/services/document-service/transform/relations/utils/data.d.ts +4 -0
- package/dist/services/document-service/transform/relations/utils/data.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
- package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/dp.js +30 -0
- package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
- package/dist/services/document-service/transform/relations/utils/dp.mjs +30 -0
- package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts +10 -0
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/i18n.js +25 -0
- package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -0
- package/dist/services/document-service/transform/relations/utils/i18n.mjs +25 -0
- package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -0
- 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/map-relation.js +91 -0
- package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
- package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
- package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
- package/dist/services/document-service/transform/relations/utils/types.d.ts +21 -0
- package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -0
- package/dist/services/document-service/transform/types.d.ts +13 -0
- package/dist/services/document-service/transform/types.d.ts.map +1 -0
- package/dist/services/document-service/utils/populate.d.ts +10 -0
- package/dist/services/document-service/utils/populate.d.ts.map +1 -0
- package/dist/services/document-service/utils/populate.js +47 -0
- package/dist/services/document-service/utils/populate.js.map +1 -0
- package/dist/services/document-service/utils/populate.mjs +47 -0
- package/dist/services/document-service/utils/populate.mjs.map +1 -0
- 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/document-service/utils/unidirectional-relations.js +69 -0
- package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
- package/dist/services/document-service/utils/unidirectional-relations.mjs +69 -0
- package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
- package/dist/services/entity-service/index.d.ts +4 -6
- package/dist/services/entity-service/index.d.ts.map +1 -1
- package/dist/services/entity-service/index.js +44 -203
- package/dist/services/entity-service/index.js.map +1 -1
- package/dist/services/entity-service/index.mjs +38 -197
- package/dist/services/entity-service/index.mjs.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/blocks-validator.js +26 -5
- package/dist/services/entity-validator/blocks-validator.js.map +1 -1
- package/dist/services/entity-validator/blocks-validator.mjs +25 -5
- package/dist/services/entity-validator/blocks-validator.mjs.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/index.js +201 -131
- package/dist/services/entity-validator/index.js.map +1 -1
- package/dist/services/entity-validator/index.mjs +196 -126
- package/dist/services/entity-validator/index.mjs.map +1 -1
- package/dist/services/entity-validator/validators.d.ts +37 -25
- package/dist/services/entity-validator/validators.d.ts.map +1 -1
- package/dist/services/entity-validator/validators.js +163 -39
- package/dist/services/entity-validator/validators.js.map +1 -1
- package/dist/services/entity-validator/validators.mjs +155 -31
- package/dist/services/entity-validator/validators.mjs.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/event-hub.js +9 -4
- package/dist/services/event-hub.js.map +1 -1
- package/dist/services/event-hub.mjs +9 -4
- package/dist/services/event-hub.mjs.map +1 -1
- package/dist/services/features.d.ts +10 -0
- package/dist/services/features.d.ts.map +1 -0
- package/dist/services/features.js +17 -0
- package/dist/services/features.js.map +1 -0
- package/dist/services/features.mjs +17 -0
- package/dist/services/features.mjs.map +1 -0
- package/dist/services/fs.d.ts +2 -2
- package/dist/services/fs.d.ts.map +1 -1
- package/dist/services/fs.js.map +1 -1
- package/dist/services/fs.mjs.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/admin-user-hash.js.map +1 -1
- package/dist/services/metrics/admin-user-hash.mjs.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/index.js.map +1 -1
- package/dist/services/metrics/index.mjs.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/middleware.js.map +1 -1
- package/dist/services/metrics/middleware.mjs.map +1 -1
- package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
- package/dist/services/metrics/rate-limiter.js.map +1 -1
- package/dist/services/metrics/rate-limiter.mjs.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/metrics/sender.js.map +1 -1
- package/dist/services/metrics/sender.mjs.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/query-params.js +12 -0
- package/dist/services/query-params.js.map +1 -0
- package/dist/services/query-params.mjs +13 -0
- package/dist/services/query-params.mjs.map +1 -0
- package/dist/services/reloader.d.ts +7 -0
- package/dist/services/reloader.d.ts.map +1 -0
- package/dist/services/reloader.js +36 -0
- package/dist/services/reloader.js.map +1 -0
- package/dist/services/reloader.mjs +36 -0
- package/dist/services/reloader.mjs.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/admin-api.js.map +1 -1
- package/dist/services/server/admin-api.mjs.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/api.js.map +1 -1
- package/dist/services/server/api.mjs.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/compose-endpoint.js +11 -9
- package/dist/services/server/compose-endpoint.js.map +1 -1
- package/dist/services/server/compose-endpoint.mjs +5 -3
- package/dist/services/server/compose-endpoint.mjs.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/content-api.js.map +1 -1
- package/dist/services/server/content-api.mjs.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/http-server.js.map +1 -1
- package/dist/services/server/http-server.mjs.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/index.js +2 -3
- package/dist/services/server/index.js.map +1 -1
- package/dist/services/server/index.mjs +2 -3
- package/dist/services/server/index.mjs.map +1 -1
- package/dist/services/server/koa.d.ts.map +1 -1
- package/dist/services/server/koa.js +4 -4
- package/dist/services/server/koa.js.map +1 -1
- package/dist/services/server/koa.mjs +1 -1
- package/dist/services/server/koa.mjs.map +1 -1
- package/dist/services/server/middleware.d.ts +4 -8
- package/dist/services/server/middleware.d.ts.map +1 -1
- package/dist/services/server/middleware.js +3 -3
- package/dist/services/server/middleware.js.map +1 -1
- package/dist/services/server/middleware.mjs.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/policy.js +4 -4
- package/dist/services/server/policy.js.map +1 -1
- package/dist/services/server/policy.mjs +4 -4
- package/dist/services/server/policy.mjs.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-middlewares.js +1 -1
- package/dist/services/server/register-middlewares.js.map +1 -1
- package/dist/services/server/register-middlewares.mjs +1 -1
- package/dist/services/server/register-middlewares.mjs.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/register-routes.js +3 -3
- package/dist/services/server/register-routes.js.map +1 -1
- package/dist/services/server/register-routes.mjs +3 -3
- package/dist/services/server/register-routes.mjs.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/server/routing.js +2 -2
- package/dist/services/server/routing.js.map +1 -1
- package/dist/services/server/routing.mjs.map +1 -1
- package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
- package/dist/services/utils/dynamic-zones.js +7 -6
- package/dist/services/utils/dynamic-zones.js.map +1 -1
- package/dist/services/utils/dynamic-zones.mjs +2 -1
- package/dist/services/utils/dynamic-zones.mjs.map +1 -1
- package/dist/services/webhook-runner.d.ts +12 -2
- package/dist/services/webhook-runner.d.ts.map +1 -1
- package/dist/services/webhook-runner.js.map +1 -1
- package/dist/services/webhook-runner.mjs.map +1 -1
- package/dist/services/webhook-store.d.ts +4 -30
- package/dist/services/webhook-store.d.ts.map +1 -1
- package/dist/services/webhook-store.js +20 -10
- package/dist/services/webhook-store.js.map +1 -1
- package/dist/services/webhook-store.mjs +20 -10
- package/dist/services/webhook-store.mjs.map +1 -1
- package/dist/utils/convert-custom-field-type.d.ts +2 -3
- package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
- package/dist/utils/convert-custom-field-type.js +2 -1
- package/dist/utils/convert-custom-field-type.js.map +1 -1
- package/dist/utils/convert-custom-field-type.mjs +1 -1
- package/dist/utils/convert-custom-field-type.mjs.map +1 -1
- package/dist/utils/cron.js +3 -3
- package/dist/utils/cron.js.map +1 -1
- package/dist/utils/ee.d.ts +1 -2
- package/dist/utils/ee.d.ts.map +1 -1
- package/dist/utils/fetch.d.ts +3 -2
- package/dist/utils/fetch.d.ts.map +1 -1
- package/dist/utils/fetch.js +6 -5
- package/dist/utils/fetch.js.map +1 -1
- package/dist/utils/fetch.mjs +6 -5
- package/dist/utils/fetch.mjs.map +1 -1
- package/dist/utils/filepath-to-prop-path.d.ts +5 -0
- package/dist/utils/filepath-to-prop-path.d.ts.map +1 -0
- package/dist/utils/filepath-to-prop-path.js +33 -0
- package/dist/utils/filepath-to-prop-path.js.map +1 -0
- package/dist/utils/filepath-to-prop-path.mjs +30 -0
- package/dist/utils/filepath-to-prop-path.mjs.map +1 -0
- package/dist/utils/index.d.ts +12 -4
- 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/is-initialized.js +8 -7
- package/dist/utils/is-initialized.js.map +1 -1
- package/dist/utils/is-initialized.mjs +4 -4
- package/dist/utils/is-initialized.mjs.map +1 -1
- package/dist/utils/load-config-file.d.ts +2 -0
- package/dist/utils/load-config-file.d.ts.map +1 -0
- package/dist/utils/load-config-file.js +45 -0
- package/dist/utils/load-config-file.js.map +1 -0
- package/dist/utils/load-config-file.mjs +42 -0
- package/dist/utils/load-config-file.mjs.map +1 -0
- package/dist/utils/load-files.d.ts +11 -0
- package/dist/utils/load-files.d.ts.map +1 -0
- package/dist/utils/load-files.js +39 -0
- package/dist/utils/load-files.js.map +1 -0
- package/dist/utils/load-files.mjs +35 -0
- package/dist/utils/load-files.mjs.map +1 -0
- package/dist/utils/open-browser.d.ts +2 -3
- package/dist/utils/open-browser.d.ts.map +1 -1
- package/dist/utils/open-browser.js +5 -5
- package/dist/utils/open-browser.js.map +1 -1
- package/dist/utils/open-browser.mjs +4 -5
- package/dist/utils/open-browser.mjs.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/resolve-working-dirs.js +13 -0
- package/dist/utils/resolve-working-dirs.js.map +1 -0
- package/dist/utils/resolve-working-dirs.mjs +11 -0
- package/dist/utils/resolve-working-dirs.mjs.map +1 -0
- package/dist/utils/signals.d.ts +2 -2
- package/dist/utils/signals.d.ts.map +1 -1
- package/dist/utils/signals.js.map +1 -1
- package/dist/utils/signals.mjs.map +1 -1
- package/dist/utils/startup-logger.d.ts +2 -3
- package/dist/utils/startup-logger.d.ts.map +1 -1
- package/dist/utils/startup-logger.js +23 -17
- package/dist/utils/startup-logger.js.map +1 -1
- package/dist/utils/startup-logger.mjs +21 -16
- package/dist/utils/startup-logger.mjs.map +1 -1
- package/dist/utils/transform-content-types-to-models.d.ts +433 -3
- package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
- package/dist/utils/transform-content-types-to-models.js +254 -16
- package/dist/utils/transform-content-types-to-models.js.map +1 -1
- package/dist/utils/transform-content-types-to-models.mjs +251 -16
- package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
- package/dist/utils/update-notifier/index.d.ts +2 -8
- package/dist/utils/update-notifier/index.d.ts.map +1 -1
- package/dist/utils/update-notifier/index.js +13 -10
- package/dist/utils/update-notifier/index.js.map +1 -1
- package/dist/utils/update-notifier/index.mjs +12 -10
- package/dist/utils/update-notifier/index.mjs.map +1 -1
- package/package.json +39 -43
- package/bin/strapi.js +0 -2
- package/dist/admin.d.ts +0 -5
- package/dist/admin.d.ts.map +0 -1
- package/dist/cli.d.ts +0 -2
- package/dist/cli.d.ts.map +0 -1
- package/dist/commands/actions/admin/create-user/action.d.ts +0 -12
- package/dist/commands/actions/admin/create-user/action.d.ts.map +0 -1
- package/dist/commands/actions/admin/create-user/command.d.ts +0 -7
- package/dist/commands/actions/admin/create-user/command.d.ts.map +0 -1
- package/dist/commands/actions/admin/reset-user-password/action.d.ts +0 -10
- package/dist/commands/actions/admin/reset-user-password/action.d.ts.map +0 -1
- package/dist/commands/actions/admin/reset-user-password/command.d.ts +0 -7
- package/dist/commands/actions/admin/reset-user-password/command.d.ts.map +0 -1
- package/dist/commands/actions/components/list/action.d.ts +0 -3
- package/dist/commands/actions/components/list/action.d.ts.map +0 -1
- package/dist/commands/actions/components/list/command.d.ts +0 -7
- package/dist/commands/actions/components/list/command.d.ts.map +0 -1
- package/dist/commands/actions/configuration/dump/action.d.ts +0 -11
- package/dist/commands/actions/configuration/dump/action.d.ts.map +0 -1
- package/dist/commands/actions/configuration/dump/command.d.ts +0 -7
- package/dist/commands/actions/configuration/dump/command.d.ts.map +0 -1
- package/dist/commands/actions/configuration/restore/action.d.ts +0 -11
- package/dist/commands/actions/configuration/restore/action.d.ts.map +0 -1
- package/dist/commands/actions/configuration/restore/command.d.ts +0 -7
- package/dist/commands/actions/configuration/restore/command.d.ts.map +0 -1
- package/dist/commands/actions/console/action.d.ts +0 -6
- package/dist/commands/actions/console/action.d.ts.map +0 -1
- package/dist/commands/actions/console/command.d.ts +0 -7
- package/dist/commands/actions/console/command.d.ts.map +0 -1
- package/dist/commands/actions/content-types/list/action.d.ts +0 -3
- package/dist/commands/actions/content-types/list/action.d.ts.map +0 -1
- package/dist/commands/actions/content-types/list/command.d.ts +0 -7
- package/dist/commands/actions/content-types/list/command.d.ts.map +0 -1
- package/dist/commands/actions/controllers/list/action.d.ts +0 -3
- package/dist/commands/actions/controllers/list/action.d.ts.map +0 -1
- package/dist/commands/actions/controllers/list/command.d.ts +0 -7
- package/dist/commands/actions/controllers/list/command.d.ts.map +0 -1
- package/dist/commands/actions/generate/command.d.ts +0 -7
- package/dist/commands/actions/generate/command.d.ts.map +0 -1
- package/dist/commands/actions/hooks/list/action.d.ts +0 -3
- package/dist/commands/actions/hooks/list/action.d.ts.map +0 -1
- package/dist/commands/actions/hooks/list/command.d.ts +0 -7
- package/dist/commands/actions/hooks/list/command.d.ts.map +0 -1
- package/dist/commands/actions/install/action.d.ts +0 -3
- package/dist/commands/actions/install/action.d.ts.map +0 -1
- package/dist/commands/actions/install/command.d.ts +0 -7
- package/dist/commands/actions/install/command.d.ts.map +0 -1
- package/dist/commands/actions/middlewares/list/action.d.ts +0 -3
- package/dist/commands/actions/middlewares/list/action.d.ts.map +0 -1
- package/dist/commands/actions/middlewares/list/command.d.ts +0 -7
- package/dist/commands/actions/middlewares/list/command.d.ts.map +0 -1
- package/dist/commands/actions/new/action.d.ts +0 -8
- package/dist/commands/actions/new/action.d.ts.map +0 -1
- package/dist/commands/actions/new/command.d.ts +0 -7
- package/dist/commands/actions/new/command.d.ts.map +0 -1
- package/dist/commands/actions/plugin/build-command/action.d.ts +0 -7
- package/dist/commands/actions/plugin/build-command/action.d.ts.map +0 -1
- package/dist/commands/actions/plugin/build-command/command.d.ts +0 -7
- package/dist/commands/actions/plugin/build-command/command.d.ts.map +0 -1
- package/dist/commands/actions/plugin/watch/action.d.ts +0 -7
- package/dist/commands/actions/plugin/watch/action.d.ts.map +0 -1
- package/dist/commands/actions/plugin/watch/command.d.ts +0 -7
- package/dist/commands/actions/plugin/watch/command.d.ts.map +0 -1
- package/dist/commands/actions/policies/list/action.d.ts +0 -3
- package/dist/commands/actions/policies/list/action.d.ts.map +0 -1
- package/dist/commands/actions/policies/list/command.d.ts +0 -7
- package/dist/commands/actions/policies/list/command.d.ts.map +0 -1
- package/dist/commands/actions/report/action.d.ts +0 -8
- package/dist/commands/actions/report/action.d.ts.map +0 -1
- package/dist/commands/actions/report/command.d.ts +0 -7
- package/dist/commands/actions/report/command.d.ts.map +0 -1
- package/dist/commands/actions/routes/list/action.d.ts +0 -3
- package/dist/commands/actions/routes/list/action.d.ts.map +0 -1
- package/dist/commands/actions/routes/list/command.d.ts +0 -7
- package/dist/commands/actions/routes/list/command.d.ts.map +0 -1
- package/dist/commands/actions/services/list/action.d.ts +0 -3
- package/dist/commands/actions/services/list/action.d.ts.map +0 -1
- package/dist/commands/actions/services/list/command.d.ts +0 -7
- package/dist/commands/actions/services/list/command.d.ts.map +0 -1
- package/dist/commands/actions/start/action.d.ts +0 -6
- package/dist/commands/actions/start/action.d.ts.map +0 -1
- package/dist/commands/actions/start/command.d.ts +0 -7
- package/dist/commands/actions/start/command.d.ts.map +0 -1
- package/dist/commands/actions/telemetry/disable/action.d.ts +0 -2
- package/dist/commands/actions/telemetry/disable/action.d.ts.map +0 -1
- package/dist/commands/actions/telemetry/disable/command.d.ts +0 -7
- package/dist/commands/actions/telemetry/disable/command.d.ts.map +0 -1
- package/dist/commands/actions/telemetry/enable/action.d.ts +0 -3
- package/dist/commands/actions/telemetry/enable/action.d.ts.map +0 -1
- package/dist/commands/actions/telemetry/enable/command.d.ts +0 -7
- package/dist/commands/actions/telemetry/enable/command.d.ts.map +0 -1
- package/dist/commands/actions/templates/generate/action.d.ts +0 -2
- package/dist/commands/actions/templates/generate/action.d.ts.map +0 -1
- package/dist/commands/actions/templates/generate/command.d.ts +0 -7
- package/dist/commands/actions/templates/generate/command.d.ts.map +0 -1
- package/dist/commands/actions/ts/generate-types/action.d.ts +0 -9
- package/dist/commands/actions/ts/generate-types/action.d.ts.map +0 -1
- package/dist/commands/actions/ts/generate-types/command.d.ts +0 -7
- package/dist/commands/actions/ts/generate-types/command.d.ts.map +0 -1
- package/dist/commands/actions/uninstall/action.d.ts +0 -6
- package/dist/commands/actions/uninstall/action.d.ts.map +0 -1
- package/dist/commands/actions/uninstall/command.d.ts +0 -7
- package/dist/commands/actions/uninstall/command.d.ts.map +0 -1
- package/dist/commands/actions/version/command.d.ts +0 -7
- package/dist/commands/actions/version/command.d.ts.map +0 -1
- package/dist/commands/actions/watch-admin/action.d.ts +0 -7
- package/dist/commands/actions/watch-admin/action.d.ts.map +0 -1
- package/dist/commands/actions/watch-admin/command.d.ts +0 -7
- package/dist/commands/actions/watch-admin/command.d.ts.map +0 -1
- package/dist/commands/index.d.ts +0 -37
- package/dist/commands/index.d.ts.map +0 -1
- package/dist/commands/types.d.ts +0 -14
- package/dist/commands/types.d.ts.map +0 -1
- package/dist/commands/utils/commander.d.ts +0 -36
- package/dist/commands/utils/commander.d.ts.map +0 -1
- package/dist/commands/utils/helpers.d.ts +0 -49
- package/dist/commands/utils/helpers.d.ts.map +0 -1
- package/dist/commands/utils/logger.d.ts +0 -19
- package/dist/commands/utils/logger.d.ts.map +0 -1
- package/dist/commands/utils/pkg.d.ts +0 -119
- package/dist/commands/utils/pkg.d.ts.map +0 -1
- package/dist/commands/utils/tsconfig.d.ts +0 -19
- package/dist/commands/utils/tsconfig.d.ts.map +0 -1
- package/dist/core/app-configuration/config-loader.d.ts.map +0 -1
- package/dist/core/app-configuration/config-loader.js +0 -19
- package/dist/core/app-configuration/config-loader.js.map +0 -1
- package/dist/core/app-configuration/config-loader.mjs +0 -17
- package/dist/core/app-configuration/config-loader.mjs.map +0 -1
- package/dist/core/app-configuration/index.d.ts +0 -36
- package/dist/core/app-configuration/index.d.ts.map +0 -1
- package/dist/core/app-configuration/index.js +0 -55
- package/dist/core/app-configuration/index.js.map +0 -1
- package/dist/core/app-configuration/index.mjs +0 -51
- package/dist/core/app-configuration/index.mjs.map +0 -1
- package/dist/core/app-configuration/load-config-file.d.ts +0 -2
- package/dist/core/app-configuration/load-config-file.d.ts.map +0 -1
- package/dist/core/app-configuration/load-config-file.js +0 -45
- package/dist/core/app-configuration/load-config-file.js.map +0 -1
- package/dist/core/app-configuration/load-config-file.mjs +0 -42
- package/dist/core/app-configuration/load-config-file.mjs.map +0 -1
- package/dist/core/bootstrap.d.ts +0 -5
- package/dist/core/bootstrap.d.ts.map +0 -1
- package/dist/core/bootstrap.js +0 -28
- package/dist/core/bootstrap.js.map +0 -1
- package/dist/core/bootstrap.mjs +0 -27
- package/dist/core/bootstrap.mjs.map +0 -1
- package/dist/core/domain/content-type/index.d.ts +0 -9
- package/dist/core/domain/content-type/index.d.ts.map +0 -1
- package/dist/core/domain/content-type/index.js +0 -122
- package/dist/core/domain/content-type/index.js.map +0 -1
- package/dist/core/domain/content-type/index.mjs +0 -120
- package/dist/core/domain/content-type/index.mjs.map +0 -1
- package/dist/core/domain/content-type/validator.d.ts.map +0 -1
- package/dist/core/domain/content-type/validator.js +0 -77
- package/dist/core/domain/content-type/validator.js.map +0 -1
- package/dist/core/domain/content-type/validator.mjs +0 -75
- package/dist/core/domain/content-type/validator.mjs.map +0 -1
- package/dist/core/domain/module/index.d.ts +0 -39
- package/dist/core/domain/module/index.d.ts.map +0 -1
- package/dist/core/domain/module/index.js +0 -107
- package/dist/core/domain/module/index.js.map +0 -1
- package/dist/core/domain/module/index.mjs +0 -105
- package/dist/core/domain/module/index.mjs.map +0 -1
- package/dist/core/domain/module/validation.d.ts.map +0 -1
- package/dist/core/domain/module/validation.js.map +0 -1
- package/dist/core/domain/module/validation.mjs.map +0 -1
- package/dist/core/loaders/admin.d.ts +0 -3
- package/dist/core/loaders/admin.d.ts.map +0 -1
- package/dist/core/loaders/admin.js +0 -16
- package/dist/core/loaders/admin.js.map +0 -1
- package/dist/core/loaders/admin.mjs +0 -15
- package/dist/core/loaders/admin.mjs.map +0 -1
- package/dist/core/loaders/apis.d.ts +0 -3
- package/dist/core/loaders/apis.d.ts.map +0 -1
- package/dist/core/loaders/apis.js +0 -130
- package/dist/core/loaders/apis.js.map +0 -1
- package/dist/core/loaders/apis.mjs +0 -128
- package/dist/core/loaders/apis.mjs.map +0 -1
- package/dist/core/loaders/components.d.ts +0 -3
- package/dist/core/loaders/components.d.ts.map +0 -1
- package/dist/core/loaders/components.js +0 -38
- package/dist/core/loaders/components.js.map +0 -1
- package/dist/core/loaders/components.mjs +0 -37
- package/dist/core/loaders/components.mjs.map +0 -1
- package/dist/core/loaders/index.d.ts +0 -3
- package/dist/core/loaders/index.d.ts.map +0 -1
- package/dist/core/loaders/index.js +0 -26
- package/dist/core/loaders/index.js.map +0 -1
- package/dist/core/loaders/index.mjs +0 -26
- package/dist/core/loaders/index.mjs.map +0 -1
- package/dist/core/loaders/middlewares.d.ts +0 -3
- package/dist/core/loaders/middlewares.d.ts.map +0 -1
- package/dist/core/loaders/middlewares.js +0 -31
- package/dist/core/loaders/middlewares.js.map +0 -1
- package/dist/core/loaders/middlewares.mjs +0 -30
- package/dist/core/loaders/middlewares.mjs.map +0 -1
- package/dist/core/loaders/plugins/get-enabled-plugins.d.ts +0 -5
- package/dist/core/loaders/plugins/get-enabled-plugins.d.ts.map +0 -1
- package/dist/core/loaders/plugins/get-enabled-plugins.js +0 -110
- package/dist/core/loaders/plugins/get-enabled-plugins.js.map +0 -1
- package/dist/core/loaders/plugins/get-enabled-plugins.mjs +0 -108
- package/dist/core/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
- package/dist/core/loaders/plugins/get-user-plugins-config.d.ts.map +0 -1
- package/dist/core/loaders/plugins/get-user-plugins-config.js +0 -27
- package/dist/core/loaders/plugins/get-user-plugins-config.js.map +0 -1
- package/dist/core/loaders/plugins/get-user-plugins-config.mjs +0 -25
- package/dist/core/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
- package/dist/core/loaders/plugins/index.d.ts +0 -3
- package/dist/core/loaders/plugins/index.d.ts.map +0 -1
- package/dist/core/loaders/plugins/index.js +0 -105
- package/dist/core/loaders/plugins/index.js.map +0 -1
- package/dist/core/loaders/plugins/index.mjs +0 -104
- package/dist/core/loaders/plugins/index.mjs.map +0 -1
- package/dist/core/loaders/policies.d.ts +0 -3
- package/dist/core/loaders/policies.d.ts.map +0 -1
- package/dist/core/loaders/policies.js.map +0 -1
- package/dist/core/loaders/policies.mjs.map +0 -1
- package/dist/core/loaders/sanitizers.d.ts +0 -4
- package/dist/core/loaders/sanitizers.d.ts.map +0 -1
- package/dist/core/loaders/sanitizers.js.map +0 -1
- package/dist/core/loaders/sanitizers.mjs.map +0 -1
- package/dist/core/loaders/src-index.d.ts +0 -4
- package/dist/core/loaders/src-index.d.ts.map +0 -1
- package/dist/core/loaders/src-index.js.map +0 -1
- package/dist/core/loaders/src-index.mjs.map +0 -1
- package/dist/core/loaders/validators.d.ts +0 -4
- package/dist/core/loaders/validators.d.ts.map +0 -1
- package/dist/core/loaders/validators.js.map +0 -1
- package/dist/core/loaders/validators.mjs.map +0 -1
- package/dist/core/registries/apis.d.ts +0 -8
- package/dist/core/registries/apis.d.ts.map +0 -1
- package/dist/core/registries/apis.js +0 -23
- package/dist/core/registries/apis.js.map +0 -1
- package/dist/core/registries/apis.mjs.map +0 -1
- package/dist/core/registries/components.d.ts +0 -25
- package/dist/core/registries/components.d.ts.map +0 -1
- package/dist/core/registries/components.js +0 -45
- package/dist/core/registries/components.js.map +0 -1
- package/dist/core/registries/components.mjs.map +0 -1
- package/dist/core/registries/config.d.ts +0 -4
- package/dist/core/registries/config.d.ts.map +0 -1
- package/dist/core/registries/config.js +0 -23
- package/dist/core/registries/config.js.map +0 -1
- package/dist/core/registries/config.mjs +0 -22
- package/dist/core/registries/config.mjs.map +0 -1
- package/dist/core/registries/content-types.d.ts +0 -33
- package/dist/core/registries/content-types.d.ts.map +0 -1
- package/dist/core/registries/content-types.js +0 -71
- package/dist/core/registries/content-types.js.map +0 -1
- package/dist/core/registries/content-types.mjs +0 -72
- package/dist/core/registries/content-types.mjs.map +0 -1
- package/dist/core/registries/controllers.d.ts +0 -35
- package/dist/core/registries/controllers.d.ts.map +0 -1
- package/dist/core/registries/controllers.js +0 -80
- package/dist/core/registries/controllers.js.map +0 -1
- package/dist/core/registries/controllers.mjs +0 -81
- package/dist/core/registries/controllers.mjs.map +0 -1
- package/dist/core/registries/custom-fields.d.ts +0 -8
- package/dist/core/registries/custom-fields.d.ts.map +0 -1
- package/dist/core/registries/custom-fields.js +0 -71
- package/dist/core/registries/custom-fields.js.map +0 -1
- package/dist/core/registries/custom-fields.mjs.map +0 -1
- package/dist/core/registries/hooks.d.ts.map +0 -1
- package/dist/core/registries/hooks.js +0 -58
- package/dist/core/registries/hooks.js.map +0 -1
- package/dist/core/registries/hooks.mjs +0 -59
- package/dist/core/registries/hooks.mjs.map +0 -1
- package/dist/core/registries/index.d.ts +0 -15
- package/dist/core/registries/index.d.ts.map +0 -1
- package/dist/core/registries/middlewares.d.ts +0 -31
- package/dist/core/registries/middlewares.d.ts.map +0 -1
- package/dist/core/registries/middlewares.js +0 -60
- package/dist/core/registries/middlewares.js.map +0 -1
- package/dist/core/registries/middlewares.mjs +0 -61
- package/dist/core/registries/middlewares.mjs.map +0 -1
- package/dist/core/registries/modules.d.ts +0 -15
- package/dist/core/registries/modules.d.ts.map +0 -1
- package/dist/core/registries/modules.js +0 -39
- package/dist/core/registries/modules.js.map +0 -1
- package/dist/core/registries/modules.mjs.map +0 -1
- package/dist/core/registries/plugins.d.ts +0 -9
- package/dist/core/registries/plugins.d.ts.map +0 -1
- package/dist/core/registries/plugins.js +0 -23
- package/dist/core/registries/plugins.js.map +0 -1
- package/dist/core/registries/plugins.mjs.map +0 -1
- package/dist/core/registries/policies.d.ts +0 -34
- package/dist/core/registries/policies.d.ts.map +0 -1
- package/dist/core/registries/policies.js +0 -62
- package/dist/core/registries/policies.js.map +0 -1
- package/dist/core/registries/policies.mjs +0 -63
- package/dist/core/registries/policies.mjs.map +0 -1
- package/dist/core/registries/sanitizers.d.ts.map +0 -1
- package/dist/core/registries/sanitizers.js.map +0 -1
- package/dist/core/registries/sanitizers.mjs.map +0 -1
- package/dist/core/registries/services.d.ts +0 -35
- package/dist/core/registries/services.d.ts.map +0 -1
- package/dist/core/registries/services.js +0 -80
- package/dist/core/registries/services.js.map +0 -1
- package/dist/core/registries/services.mjs +0 -81
- package/dist/core/registries/services.mjs.map +0 -1
- package/dist/core/registries/validators.d.ts.map +0 -1
- package/dist/core/registries/validators.js.map +0 -1
- package/dist/core/registries/validators.mjs.map +0 -1
- package/dist/core/utils.d.ts +0 -5
- package/dist/core/utils.d.ts.map +0 -1
- package/dist/core/utils.js +0 -27
- package/dist/core/utils.js.map +0 -1
- package/dist/core/utils.mjs +0 -27
- package/dist/core/utils.mjs.map +0 -1
- package/dist/core-api/service/get-fetch-params.d.ts +0 -7
- package/dist/core-api/service/get-fetch-params.d.ts.map +0 -1
- package/dist/core-api/service/get-fetch-params.js +0 -14
- package/dist/core-api/service/get-fetch-params.js.map +0 -1
- package/dist/core-api/service/get-fetch-params.mjs +0 -14
- package/dist/core-api/service/get-fetch-params.mjs.map +0 -1
- package/dist/load/filepath-to-prop-path.d.ts +0 -6
- package/dist/load/filepath-to-prop-path.d.ts.map +0 -1
- package/dist/load/filepath-to-prop-path.js +0 -11
- package/dist/load/filepath-to-prop-path.js.map +0 -1
- package/dist/load/filepath-to-prop-path.mjs +0 -10
- package/dist/load/filepath-to-prop-path.mjs.map +0 -1
- package/dist/load/glob.d.ts +0 -7
- package/dist/load/glob.d.ts.map +0 -1
- package/dist/load/glob.js +0 -15
- package/dist/load/glob.js.map +0 -1
- package/dist/load/glob.mjs +0 -14
- package/dist/load/glob.mjs.map +0 -1
- package/dist/load/index.d.ts +0 -3
- package/dist/load/index.d.ts.map +0 -1
- package/dist/load/load-files.d.ts +0 -11
- package/dist/load/load-files.d.ts.map +0 -1
- package/dist/load/load-files.js +0 -38
- package/dist/load/load-files.js.map +0 -1
- package/dist/load/load-files.mjs +0 -35
- package/dist/load/load-files.mjs.map +0 -1
- package/dist/load/package-path.d.ts +0 -6
- package/dist/load/package-path.d.ts.map +0 -1
- package/dist/middlewares/public/assets/images/group_people_1.png +0 -0
- package/dist/middlewares/public/assets/images/group_people_2.png +0 -0
- package/dist/middlewares/public/assets/images/group_people_3.png +0 -0
- package/dist/middlewares/public/assets/images/logo_login.png +0 -0
- package/dist/middlewares/public/index.d.ts +0 -3
- package/dist/middlewares/public/index.d.ts.map +0 -1
- package/dist/middlewares/public/index.html +0 -66
- package/dist/middlewares/public/index.js +0 -91
- package/dist/middlewares/public/index.js.map +0 -1
- package/dist/middlewares/public/index.mjs +0 -85
- package/dist/middlewares/public/index.mjs.map +0 -1
- package/dist/middlewares/public/serve-static.d.ts +0 -4
- package/dist/middlewares/public/serve-static.d.ts.map +0 -1
- package/dist/middlewares/public/serve-static.js +0 -24
- package/dist/middlewares/public/serve-static.js.map +0 -1
- package/dist/middlewares/public/serve-static.mjs +0 -21
- package/dist/middlewares/public/serve-static.mjs.map +0 -1
- package/dist/services/document-service/document-repository.d.ts +0 -21
- package/dist/services/document-service/document-repository.d.ts.map +0 -1
- package/dist/services/document-service/document-repository.js +0 -132
- package/dist/services/document-service/document-repository.js.map +0 -1
- package/dist/services/document-service/document-repository.mjs +0 -132
- package/dist/services/document-service/document-repository.mjs.map +0 -1
- package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts +0 -26
- package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts.map +0 -1
- package/dist/services/document-service/middlewares/defaults/draft-and-publish.js +0 -58
- package/dist/services/document-service/middlewares/defaults/draft-and-publish.js.map +0 -1
- package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs +0 -58
- package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs.map +0 -1
- package/dist/services/document-service/middlewares/defaults/index.d.ts +0 -3
- package/dist/services/document-service/middlewares/defaults/index.d.ts.map +0 -1
- package/dist/services/document-service/middlewares/defaults/index.js +0 -82
- package/dist/services/document-service/middlewares/defaults/index.js.map +0 -1
- package/dist/services/document-service/middlewares/defaults/index.mjs +0 -82
- package/dist/services/document-service/middlewares/defaults/index.mjs.map +0 -1
- package/dist/services/document-service/middlewares/defaults/locales.d.ts +0 -18
- package/dist/services/document-service/middlewares/defaults/locales.d.ts.map +0 -1
- package/dist/services/document-service/middlewares/defaults/locales.js +0 -40
- package/dist/services/document-service/middlewares/defaults/locales.js.map +0 -1
- package/dist/services/document-service/middlewares/defaults/locales.mjs +0 -40
- package/dist/services/document-service/middlewares/defaults/locales.mjs.map +0 -1
- package/dist/services/document-service/middlewares/index.js +0 -59
- package/dist/services/document-service/middlewares/index.js.map +0 -1
- package/dist/services/document-service/middlewares/index.mjs +0 -59
- package/dist/services/document-service/middlewares/index.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.map +0 -1
- package/dist/services/entity-service/components.d.ts +0 -23
- package/dist/services/entity-service/components.d.ts.map +0 -1
- package/dist/services/entity-service/components.js +0 -384
- package/dist/services/entity-service/components.js.map +0 -1
- package/dist/services/entity-service/components.mjs +0 -382
- package/dist/services/entity-service/components.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/utils/upload-files.d.ts +0 -8
- package/dist/services/utils/upload-files.d.ts.map +0 -1
- package/dist/services/utils/upload-files.js +0 -64
- package/dist/services/utils/upload-files.js.map +0 -1
- package/dist/services/utils/upload-files.mjs +0 -63
- package/dist/services/utils/upload-files.mjs.map +0 -1
- package/dist/utils/addSlash.d.ts +0 -3
- package/dist/utils/addSlash.d.ts.map +0 -1
- package/dist/utils/ee.js +0 -4
- package/dist/utils/ee.js.map +0 -1
- package/dist/utils/ee.mjs +0 -5
- package/dist/utils/ee.mjs.map +0 -1
- package/dist/utils/get-dirs.d.ts +0 -10
- package/dist/utils/get-dirs.d.ts.map +0 -1
- package/dist/utils/get-dirs.js +0 -29
- 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/{core/app-configuration → configuration}/config-loader.d.ts +0 -0
- /package/dist/{core/domain → domain}/content-type/validator.d.ts +0 -0
- /package/dist/{core/domain → domain}/module/validation.d.ts +0 -0
- /package/dist/{core/domain → domain}/module/validation.js +0 -0
- /package/dist/{core/domain → domain}/module/validation.mjs +0 -0
- /package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.d.ts +0 -0
- /package/dist/{core/loaders → loaders}/policies.js +0 -0
- /package/dist/{core/loaders → loaders}/policies.mjs +0 -0
- /package/dist/{core/loaders → loaders}/sanitizers.js +0 -0
- /package/dist/{core/loaders → loaders}/sanitizers.mjs +0 -0
- /package/dist/{core/loaders → loaders}/src-index.js +0 -0
- /package/dist/{core/loaders → loaders}/src-index.mjs +0 -0
- /package/dist/{core/loaders → loaders}/validators.js +0 -0
- /package/dist/{core/loaders → loaders}/validators.mjs +0 -0
- /package/dist/{core/registries → registries}/apis.mjs +0 -0
- /package/dist/{core/registries → registries}/components.mjs +0 -0
- /package/dist/{core/registries → registries}/custom-fields.mjs +0 -0
- /package/dist/{core/registries → registries}/hooks.d.ts +0 -0
- /package/dist/{core/registries → registries}/modules.mjs +0 -0
- /package/dist/{core/registries → registries}/plugins.mjs +0 -0
- /package/dist/{core/registries → registries}/sanitizers.d.ts +0 -0
- /package/dist/{core/registries → registries}/sanitizers.js +0 -0
- /package/dist/{core/registries → registries}/sanitizers.mjs +0 -0
- /package/dist/{core/registries → registries}/validators.d.ts +0 -0
- /package/dist/{core/registries → registries}/validators.js +0 -0
- /package/dist/{core/registries → registries}/validators.mjs +0 -0
- /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
|
@@ -1,194 +1,36 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
const
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const index$1 = require("../entity-service/attributes/index.js");
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const errors = require("./middlewares/errors.js");
|
|
4
|
+
const middlewareManager = require("./middlewares/middleware-manager.js");
|
|
5
|
+
const repository = require("./repository.js");
|
|
6
|
+
const data = require("./transform/data.js");
|
|
8
7
|
const index = require("../entity-validator/index.js");
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
};
|
|
17
|
-
const createDocumentService = ({
|
|
18
|
-
strapi,
|
|
19
|
-
db
|
|
20
|
-
}) => ({
|
|
21
|
-
uploadFiles,
|
|
22
|
-
async findMany(uid, params2) {
|
|
23
|
-
const { kind } = strapi.getModel(uid);
|
|
24
|
-
const query = transformParamsToQuery(uid, params2 || {});
|
|
25
|
-
query.where = { ...params2?.lookup, ...query.where };
|
|
26
|
-
if (kind === "singleType") {
|
|
27
|
-
return db.query(uid).findOne(query);
|
|
28
|
-
}
|
|
29
|
-
return db.query(uid).findMany(query);
|
|
30
|
-
},
|
|
31
|
-
async findFirst(uid, params2) {
|
|
32
|
-
const query = transformParamsToQuery(uid, params2 || {});
|
|
33
|
-
return db.query(uid).findOne({ ...query, where: { ...params2?.lookup, ...query.where } });
|
|
34
|
-
},
|
|
35
|
-
async findOne(uid, documentId, params2) {
|
|
36
|
-
const query = transformParamsToQuery(uid, params2 || {});
|
|
37
|
-
return db.query(uid).findOne({ ...query, where: { ...params2?.lookup, ...query.where, documentId } });
|
|
38
|
-
},
|
|
39
|
-
async delete(uid, documentId, params2 = {}) {
|
|
40
|
-
const query = transformParamsToQuery(uid, params2);
|
|
41
|
-
if (params2.status === "draft") {
|
|
42
|
-
throw new Error("Cannot delete a draft document");
|
|
43
|
-
}
|
|
44
|
-
const entriesToDelete = await db.query(uid).findMany({
|
|
45
|
-
...query,
|
|
46
|
-
where: {
|
|
47
|
-
...params2.lookup,
|
|
48
|
-
...query?.where,
|
|
49
|
-
documentId
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
await strapiUtils.mapAsync(entriesToDelete, async (entryToDelete) => {
|
|
53
|
-
const componentsToDelete = await components.getComponents(uid, entryToDelete);
|
|
54
|
-
await db.query(uid).delete({ where: { id: entryToDelete.id } });
|
|
55
|
-
await components.deleteComponents(uid, componentsToDelete, { loadComponents: false });
|
|
56
|
-
});
|
|
57
|
-
return { versions: entriesToDelete };
|
|
58
|
-
},
|
|
59
|
-
// TODO: should we provide two separate methods?
|
|
60
|
-
async deleteMany(uid, paramsOrIds) {
|
|
61
|
-
let queryParams;
|
|
62
|
-
if (_.isArray(paramsOrIds)) {
|
|
63
|
-
queryParams = { filter: { documentID: { $in: paramsOrIds } } };
|
|
64
|
-
} else {
|
|
65
|
-
queryParams = paramsOrIds;
|
|
8
|
+
const createDocumentService = (strapi, validator = index) => {
|
|
9
|
+
const repositories = /* @__PURE__ */ new Map();
|
|
10
|
+
const middlewares = middlewareManager.createMiddlewareManager();
|
|
11
|
+
middlewares.use(errors.databaseErrorsMiddleware);
|
|
12
|
+
const factory = function factory2(uid) {
|
|
13
|
+
if (repositories.has(uid)) {
|
|
14
|
+
return repositories.get(uid);
|
|
66
15
|
}
|
|
67
|
-
const
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
if (!data) {
|
|
73
|
-
throw new Error("Create requires data attribute");
|
|
74
|
-
}
|
|
75
|
-
const model = strapi.getModel(uid);
|
|
76
|
-
const validData = await index.validateEntityCreation(model, data, { isDraft: true });
|
|
77
|
-
const componentData = await components.createComponents(uid, validData);
|
|
78
|
-
const entryData = createPipeline(
|
|
79
|
-
Object.assign(components.omitComponentData(model, validData), componentData),
|
|
16
|
+
const contentType = strapi.contentType(uid);
|
|
17
|
+
const repository$1 = repository.createContentTypeRepository(uid, validator);
|
|
18
|
+
const instance = middlewares.wrapObject(
|
|
19
|
+
repository$1,
|
|
20
|
+
{ uid, contentType },
|
|
80
21
|
{
|
|
81
|
-
|
|
22
|
+
exclude: ["updateComponents", "omitComponentData"]
|
|
82
23
|
}
|
|
83
24
|
);
|
|
84
|
-
|
|
85
|
-
return
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
if (!entryToUpdate) {
|
|
94
|
-
return null;
|
|
95
|
-
}
|
|
96
|
-
const validData = await index.validateEntityUpdate(
|
|
97
|
-
model,
|
|
98
|
-
data,
|
|
99
|
-
{ isDraft: true },
|
|
100
|
-
// Always update the draft version
|
|
101
|
-
entryToUpdate
|
|
102
|
-
);
|
|
103
|
-
const componentData = await components.updateComponents(uid, entryToUpdate, validData);
|
|
104
|
-
const entryData = updatePipeline(
|
|
105
|
-
Object.assign(components.omitComponentData(model, validData), componentData),
|
|
106
|
-
{ contentType: model }
|
|
107
|
-
);
|
|
108
|
-
return db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });
|
|
109
|
-
},
|
|
110
|
-
async count(uid, params2 = void 0) {
|
|
111
|
-
const query = transformParamsToQuery(uid, params2 || {});
|
|
112
|
-
query.where = { ...params2?.lookup, ...query.where };
|
|
113
|
-
return db.query(uid).count(query);
|
|
114
|
-
},
|
|
115
|
-
async clone(uid, documentId, params$1) {
|
|
116
|
-
const { data = {} } = params$1;
|
|
117
|
-
const model = strapi.getModel(uid);
|
|
118
|
-
const query = transformParamsToQuery(uid, params.pickSelectionParams(params$1));
|
|
119
|
-
const entries = await db.query(uid).findMany({
|
|
120
|
-
...query,
|
|
121
|
-
where: { ...params$1?.lookup, ...query.where, documentId }
|
|
122
|
-
});
|
|
123
|
-
if (!entries.length) {
|
|
124
|
-
return null;
|
|
125
|
-
}
|
|
126
|
-
const newDocumentId = transformContentTypesToModels.createDocumentId();
|
|
127
|
-
const versions = await strapiUtils.mapAsync(entries, async (entryToClone) => {
|
|
128
|
-
const isDraft = strapiUtils.contentTypes.isDraft(data);
|
|
129
|
-
const validData = await index.validateEntityUpdate(
|
|
130
|
-
model,
|
|
131
|
-
// Omit id fields, the cloned entity id will be generated by the database
|
|
132
|
-
_.omit(["id"], data),
|
|
133
|
-
{ isDraft },
|
|
134
|
-
entryToClone
|
|
135
|
-
);
|
|
136
|
-
const componentData = await components.cloneComponents(uid, entryToClone, validData);
|
|
137
|
-
const entityData = createPipeline(
|
|
138
|
-
Object.assign(components.omitComponentData(model, validData), componentData),
|
|
139
|
-
{ contentType: model }
|
|
140
|
-
);
|
|
141
|
-
return db.query(uid).clone(entryToClone.id, {
|
|
142
|
-
...query,
|
|
143
|
-
// Allows entityData to override the documentId (e.g. when publishing)
|
|
144
|
-
data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale }
|
|
145
|
-
});
|
|
146
|
-
});
|
|
147
|
-
return { id: newDocumentId, versions };
|
|
148
|
-
},
|
|
149
|
-
// TODO: Handle relations so they target the published version
|
|
150
|
-
async publish(uid, documentId, params2) {
|
|
151
|
-
await this.delete(uid, documentId, {
|
|
152
|
-
...params2,
|
|
153
|
-
lookup: { ...params2?.lookup, publishedAt: { $ne: null } }
|
|
154
|
-
});
|
|
155
|
-
const clonedDocuments = await this.clone(uid, documentId, {
|
|
156
|
-
...params2 || {},
|
|
157
|
-
// @ts-expect-error - Generic type does not have publishedAt attribute by default
|
|
158
|
-
data: { documentId, publishedAt: /* @__PURE__ */ new Date() }
|
|
159
|
-
});
|
|
160
|
-
return { versions: clonedDocuments?.versions || [] };
|
|
161
|
-
},
|
|
162
|
-
async unpublish(uid, documentId, params2) {
|
|
163
|
-
return this.delete(uid, documentId, {
|
|
164
|
-
...params2,
|
|
165
|
-
lookup: { ...params2?.lookup, publishedAt: { $ne: null } }
|
|
166
|
-
});
|
|
167
|
-
},
|
|
168
|
-
/**
|
|
169
|
-
* Steps:
|
|
170
|
-
* - Delete the matching draft versions (publishedAt = null)
|
|
171
|
-
* - Clone the matching published versions into draft versions
|
|
172
|
-
*/
|
|
173
|
-
async discardDraft(uid, documentId, params2) {
|
|
174
|
-
await this.delete(uid, documentId, {
|
|
175
|
-
...params2,
|
|
176
|
-
// Delete all drafts that match query
|
|
177
|
-
lookup: { ...params2?.lookup, publishedAt: null }
|
|
178
|
-
});
|
|
179
|
-
const clonedDocuments = await this.clone(uid, documentId, {
|
|
180
|
-
...params2 || {},
|
|
181
|
-
// Clone only published versions
|
|
182
|
-
lookup: { ...params2?.lookup, publishedAt: { $ne: null } },
|
|
183
|
-
// @ts-expect-error - Generic type does not have publishedAt attribute by default
|
|
184
|
-
data: { documentId, publishedAt: null }
|
|
185
|
-
});
|
|
186
|
-
return { versions: clonedDocuments?.versions || [] };
|
|
187
|
-
}
|
|
188
|
-
});
|
|
189
|
-
const createDocumentService$1 = (ctx) => {
|
|
190
|
-
const implementation = createDocumentService(ctx);
|
|
191
|
-
return implementation;
|
|
25
|
+
repositories.set(uid, instance);
|
|
26
|
+
return instance;
|
|
27
|
+
};
|
|
28
|
+
return Object.assign(factory, {
|
|
29
|
+
utils: {
|
|
30
|
+
transformData: data.transformData
|
|
31
|
+
},
|
|
32
|
+
use: middlewares.use.bind(middlewares)
|
|
33
|
+
});
|
|
192
34
|
};
|
|
193
|
-
|
|
35
|
+
exports.createDocumentService = createDocumentService;
|
|
194
36
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import type { Database } from '@strapi/database';\nimport type { Common, Documents, Schema, Shared, Strapi } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, convertQueryParams, mapAsync } from '@strapi/utils';\n\nimport { isArray, omit } from 'lodash/fp';\nimport uploadFiles from '../utils/upload-files';\n\nimport {\n cloneComponents,\n createComponents,\n deleteComponents,\n getComponents,\n omitComponentData,\n updateComponents,\n} from '../entity-service/components';\n\nimport { createDocumentId } from '../../utils/transform-content-types-to-models';\nimport { applyTransforms } from '../entity-service/attributes';\nimport entityValidator from '../entity-validator';\nimport { pickSelectionParams } from './params';\n\nconst { transformParamsToQuery } = convertQueryParams;\n\n/**\n * TODO: Sanitization / validation built-in\n * TODO: i18n - Move logic to i18n package\n * TODO: Webhooks\n * TODO: Audit logs\n * TODO: Entity Validation - Uniqueness across same locale and publication status\n * TODO: File upload\n * TODO: replace 'any'\n * TODO: availableLocales\n *\n */\ntype Context = {\n contentType: Schema.ContentType;\n};\n\nconst createPipeline = (data: Record<string, unknown>, context: Context) => {\n return applyTransforms(data, context);\n};\n\nconst updatePipeline = (data: Record<string, unknown>, context: Context) => {\n return applyTransforms(data, context);\n};\n\nconst createDocumentService = ({\n strapi,\n db,\n}: {\n strapi: Strapi;\n db: Database;\n}): Documents.Service => ({\n uploadFiles,\n\n async findMany(uid, params) {\n const { kind } = strapi.getModel(uid);\n\n const query = transformParamsToQuery(uid, params || ({} as any));\n query.where = { ...params?.lookup, ...query.where };\n\n if (kind === 'singleType') {\n return db.query(uid).findOne(query);\n }\n\n return db.query(uid).findMany(query);\n },\n\n async findFirst(uid, params) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n\n return db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query.where } });\n },\n\n async findOne(uid, documentId, params) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n return db\n .query(uid)\n .findOne({ ...query, where: { ...params?.lookup, ...query.where, documentId } });\n },\n\n async delete(uid, documentId, params = {} as any) {\n const query = transformParamsToQuery(uid, params as any);\n\n if (params.status === 'draft') {\n throw new Error('Cannot delete a draft document');\n }\n\n const entriesToDelete = await db.query(uid).findMany({\n ...query,\n where: {\n ...params.lookup,\n ...query?.where,\n documentId,\n },\n });\n\n // Delete all matched entries and its components\n await mapAsync(entriesToDelete, async (entryToDelete: any) => {\n const componentsToDelete = await getComponents(uid, entryToDelete);\n await db.query(uid).delete({ where: { id: entryToDelete.id } });\n await deleteComponents(uid, componentsToDelete as any, { loadComponents: false });\n });\n\n // TODO: Change return value to actual count\n return { versions: entriesToDelete };\n },\n\n // TODO: should we provide two separate methods?\n async deleteMany(uid, paramsOrIds) {\n let queryParams;\n if (isArray(paramsOrIds)) {\n queryParams = { filter: { documentID: { $in: paramsOrIds } } };\n } else {\n queryParams = paramsOrIds;\n }\n\n const query = transformParamsToQuery(uid, queryParams || ({} as any));\n\n return db.query(uid).deleteMany(query);\n },\n\n async create(uid, params) {\n // TODO: Entity validator.\n // TODO: File upload - Probably in the lifecycles?\n const { data } = params;\n\n if (!data) {\n throw new Error('Create requires data attribute');\n }\n\n const model = strapi.getModel(uid) as Shared.ContentTypes[Common.UID.ContentType];\n\n const validData = await entityValidator.validateEntityCreation(model, data, { isDraft: true });\n\n const componentData = await createComponents(uid, validData);\n const entryData = createPipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n {\n contentType: model,\n }\n );\n\n // select / populate\n const query = transformParamsToQuery(uid, pickSelectionParams(params));\n\n return db.query(uid).create({ ...query, data: entryData });\n },\n\n // NOTE: What happens if user doesn't provide specific publications state and locale to update?\n async update(uid, documentId, params) {\n // TODO: Prevent updating a published document\n // TODO: Entity validator.\n // TODO: File upload\n const { data } = params || {};\n const model = strapi.getModel(uid) as Shared.ContentTypes[Common.UID.ContentType];\n\n const query = transformParamsToQuery(uid, pickSelectionParams(params || {}));\n\n // Find all locales of the document\n const entryToUpdate = await db\n .query(uid)\n .findOne({ ...query, where: { ...params?.lookup, ...query?.where, documentId } });\n\n // Document does not exist\n if (!entryToUpdate) {\n return null;\n }\n\n const validData = await entityValidator.validateEntityUpdate(\n model,\n data,\n { isDraft: true }, // Always update the draft version\n entryToUpdate\n );\n\n const componentData = await updateComponents(uid, entryToUpdate, validData);\n const entryData = updatePipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n return db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });\n },\n\n async count(uid, params = undefined) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n query.where = { ...params?.lookup, ...query.where };\n\n return db.query(uid).count(query);\n },\n\n async clone(uid, documentId, params) {\n // TODO: File upload\n // TODO: Entity validator.\n const { data = {} as any } = params!;\n\n const model = strapi.getModel(uid);\n const query = transformParamsToQuery(uid, pickSelectionParams(params));\n\n // Find all locales of the document\n const entries = await db.query(uid).findMany({\n ...query,\n where: { ...params?.lookup, ...query.where, documentId },\n });\n\n // Document does not exist\n if (!entries.length) {\n return null;\n }\n\n const newDocumentId = createDocumentId();\n\n const versions = await mapAsync(entries, async (entryToClone: any) => {\n const isDraft = contentTypesUtils.isDraft(data);\n // Todo: Merge data with entry to clone\n const validData = await entityValidator.validateEntityUpdate(\n model,\n // Omit id fields, the cloned entity id will be generated by the database\n omit(['id'], data),\n { isDraft },\n entryToClone\n );\n\n const componentData = await cloneComponents(uid, entryToClone, validData);\n const entityData = createPipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n // TODO: Transform params to query\n return db.query(uid).clone(entryToClone.id, {\n ...query,\n // Allows entityData to override the documentId (e.g. when publishing)\n data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale },\n });\n });\n\n return { id: newDocumentId, versions };\n },\n\n // TODO: Handle relations so they target the published version\n async publish(uid, documentId, params) {\n // Delete already published versions that match the locales to be published\n await this.delete(uid, documentId, {\n ...params,\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n });\n\n // Clone every draft version to be published\n const clonedDocuments = (await this.clone(uid, documentId, {\n ...(params || {}),\n // @ts-expect-error - Generic type does not have publishedAt attribute by default\n data: { documentId, publishedAt: new Date() },\n })) as any;\n\n // TODO: Return actual count\n return { versions: clonedDocuments?.versions || [] };\n },\n\n async unpublish(uid, documentId, params) {\n // Delete all published versions\n return this.delete(uid, documentId, {\n ...params,\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n }) as any;\n },\n\n /**\n * Steps:\n * - Delete the matching draft versions (publishedAt = null)\n * - Clone the matching published versions into draft versions\n */\n async discardDraft(uid, documentId, params) {\n // Delete draft versions, clone published versions into draft versions\n await this.delete(uid, documentId, {\n ...params,\n // Delete all drafts that match query\n lookup: { ...params?.lookup, publishedAt: null },\n });\n\n // Clone published versions into draft versions\n const clonedDocuments = (await this.clone(uid, documentId, {\n ...(params || {}),\n // Clone only published versions\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n // @ts-expect-error - Generic type does not have publishedAt attribute by default\n data: { documentId, publishedAt: null },\n })) as any;\n\n return { versions: clonedDocuments?.versions || [] };\n },\n});\n\nexport default (ctx: { strapi: Strapi; db: Database }): Documents.Service => {\n const implementation = createDocumentService(ctx);\n\n // TODO: Wrap with database error handling\n return implementation;\n};\n"],"names":["convertQueryParams","applyTransforms","params","mapAsync","getComponents","deleteComponents","isArray","entityValidator","createComponents","omitComponentData","pickSelectionParams","updateComponents","createDocumentId","contentTypesUtils","omit","cloneComponents"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import type { Core, Modules, UID } from '@strapi/types';\n\nimport { createMiddlewareManager, databaseErrorsMiddleware } from './middlewares';\nimport { createContentTypeRepository } from './repository';\nimport { transformData } from './transform/data';\n\nimport entityValidator from '../entity-validator';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @param validator - validator for database entries\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\nexport const createDocumentService = (\n strapi: Core.Strapi,\n validator: Modules.EntityValidator.EntityValidator = entityValidator\n): Modules.Documents.Service => {\n // Cache the repositories (one per content type)\n const repositories = new Map<string, Modules.Documents.ServiceInstance>();\n\n // Manager to handle document service middlewares\n const middlewares = createMiddlewareManager();\n middlewares.use(databaseErrorsMiddleware);\n\n const factory = function factory(uid: UID.ContentType) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid, validator);\n\n const instance = middlewares.wrapObject(\n repository,\n { uid, contentType },\n {\n exclude: ['updateComponents', 'omitComponentData'],\n }\n );\n\n repositories.set(uid, instance);\n\n return instance;\n } as Modules.Documents.Service;\n\n return Object.assign(factory, {\n utils: {\n transformData,\n },\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["entityValidator","createMiddlewareManager","databaseErrorsMiddleware","factory","repository","createContentTypeRepository","transformData"],"mappings":";;;;;;;AAuBO,MAAM,wBAAwB,CACnC,QACA,YAAqDA,UACvB;AAExB,QAAA,mCAAmB;AAGzB,QAAM,cAAcC,kBAAAA;AACpB,cAAY,IAAIC,OAAAA,wBAAwB;AAElC,QAAA,UAAU,SAASC,SAAQ,KAAsB;AACjD,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAAC,eAAaC,WAAAA,4BAA4B,KAAK,SAAS;AAE7D,UAAM,WAAW,YAAY;AAAA,MAC3BD;AAAAA,MACA,EAAE,KAAK,YAAY;AAAA,MACnB;AAAA,QACE,SAAS,CAAC,oBAAoB,mBAAmB;AAAA,MACnD;AAAA,IAAA;AAGW,iBAAA,IAAI,KAAK,QAAQ;AAEvB,WAAA;AAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,OAAO;AAAA,MAAA,eACLE,KAAA;AAAA,IACF;AAAA,IACA,KAAK,YAAY,IAAI,KAAK,WAAW;AAAA,EAAA,CACtC;AACH;;"}
|
|
@@ -1,195 +1,36 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
import { createDocumentId } from "../../utils/transform-content-types-to-models.mjs";
|
|
6
|
-
import { applyTransforms } from "../entity-service/attributes/index.mjs";
|
|
1
|
+
import { databaseErrorsMiddleware } from "./middlewares/errors.mjs";
|
|
2
|
+
import { createMiddlewareManager } from "./middlewares/middleware-manager.mjs";
|
|
3
|
+
import { createContentTypeRepository } from "./repository.mjs";
|
|
4
|
+
import { transformData } from "./transform/data.mjs";
|
|
7
5
|
import entityValidator from "../entity-validator/index.mjs";
|
|
8
|
-
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
};
|
|
16
|
-
const createDocumentService = ({
|
|
17
|
-
strapi,
|
|
18
|
-
db
|
|
19
|
-
}) => ({
|
|
20
|
-
uploadFiles: uploadFile,
|
|
21
|
-
async findMany(uid, params) {
|
|
22
|
-
const { kind } = strapi.getModel(uid);
|
|
23
|
-
const query = transformParamsToQuery(uid, params || {});
|
|
24
|
-
query.where = { ...params?.lookup, ...query.where };
|
|
25
|
-
if (kind === "singleType") {
|
|
26
|
-
return db.query(uid).findOne(query);
|
|
27
|
-
}
|
|
28
|
-
return db.query(uid).findMany(query);
|
|
29
|
-
},
|
|
30
|
-
async findFirst(uid, params) {
|
|
31
|
-
const query = transformParamsToQuery(uid, params || {});
|
|
32
|
-
return db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query.where } });
|
|
33
|
-
},
|
|
34
|
-
async findOne(uid, documentId, params) {
|
|
35
|
-
const query = transformParamsToQuery(uid, params || {});
|
|
36
|
-
return db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query.where, documentId } });
|
|
37
|
-
},
|
|
38
|
-
async delete(uid, documentId, params = {}) {
|
|
39
|
-
const query = transformParamsToQuery(uid, params);
|
|
40
|
-
if (params.status === "draft") {
|
|
41
|
-
throw new Error("Cannot delete a draft document");
|
|
42
|
-
}
|
|
43
|
-
const entriesToDelete = await db.query(uid).findMany({
|
|
44
|
-
...query,
|
|
45
|
-
where: {
|
|
46
|
-
...params.lookup,
|
|
47
|
-
...query?.where,
|
|
48
|
-
documentId
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
await mapAsync(entriesToDelete, async (entryToDelete) => {
|
|
52
|
-
const componentsToDelete = await getComponents(uid, entryToDelete);
|
|
53
|
-
await db.query(uid).delete({ where: { id: entryToDelete.id } });
|
|
54
|
-
await deleteComponents(uid, componentsToDelete, { loadComponents: false });
|
|
55
|
-
});
|
|
56
|
-
return { versions: entriesToDelete };
|
|
57
|
-
},
|
|
58
|
-
// TODO: should we provide two separate methods?
|
|
59
|
-
async deleteMany(uid, paramsOrIds) {
|
|
60
|
-
let queryParams;
|
|
61
|
-
if (isArray(paramsOrIds)) {
|
|
62
|
-
queryParams = { filter: { documentID: { $in: paramsOrIds } } };
|
|
63
|
-
} else {
|
|
64
|
-
queryParams = paramsOrIds;
|
|
6
|
+
const createDocumentService = (strapi, validator = entityValidator) => {
|
|
7
|
+
const repositories = /* @__PURE__ */ new Map();
|
|
8
|
+
const middlewares = createMiddlewareManager();
|
|
9
|
+
middlewares.use(databaseErrorsMiddleware);
|
|
10
|
+
const factory = function factory2(uid) {
|
|
11
|
+
if (repositories.has(uid)) {
|
|
12
|
+
return repositories.get(uid);
|
|
65
13
|
}
|
|
66
|
-
const
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
if (!data) {
|
|
72
|
-
throw new Error("Create requires data attribute");
|
|
73
|
-
}
|
|
74
|
-
const model = strapi.getModel(uid);
|
|
75
|
-
const validData = await entityValidator.validateEntityCreation(model, data, { isDraft: true });
|
|
76
|
-
const componentData = await createComponents(uid, validData);
|
|
77
|
-
const entryData = createPipeline(
|
|
78
|
-
Object.assign(omitComponentData(model, validData), componentData),
|
|
14
|
+
const contentType = strapi.contentType(uid);
|
|
15
|
+
const repository = createContentTypeRepository(uid, validator);
|
|
16
|
+
const instance = middlewares.wrapObject(
|
|
17
|
+
repository,
|
|
18
|
+
{ uid, contentType },
|
|
79
19
|
{
|
|
80
|
-
|
|
20
|
+
exclude: ["updateComponents", "omitComponentData"]
|
|
81
21
|
}
|
|
82
22
|
);
|
|
83
|
-
|
|
84
|
-
return
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
if (!entryToUpdate) {
|
|
93
|
-
return null;
|
|
94
|
-
}
|
|
95
|
-
const validData = await entityValidator.validateEntityUpdate(
|
|
96
|
-
model,
|
|
97
|
-
data,
|
|
98
|
-
{ isDraft: true },
|
|
99
|
-
// Always update the draft version
|
|
100
|
-
entryToUpdate
|
|
101
|
-
);
|
|
102
|
-
const componentData = await updateComponents(uid, entryToUpdate, validData);
|
|
103
|
-
const entryData = updatePipeline(
|
|
104
|
-
Object.assign(omitComponentData(model, validData), componentData),
|
|
105
|
-
{ contentType: model }
|
|
106
|
-
);
|
|
107
|
-
return db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });
|
|
108
|
-
},
|
|
109
|
-
async count(uid, params = void 0) {
|
|
110
|
-
const query = transformParamsToQuery(uid, params || {});
|
|
111
|
-
query.where = { ...params?.lookup, ...query.where };
|
|
112
|
-
return db.query(uid).count(query);
|
|
113
|
-
},
|
|
114
|
-
async clone(uid, documentId, params) {
|
|
115
|
-
const { data = {} } = params;
|
|
116
|
-
const model = strapi.getModel(uid);
|
|
117
|
-
const query = transformParamsToQuery(uid, pickSelectionParams(params));
|
|
118
|
-
const entries = await db.query(uid).findMany({
|
|
119
|
-
...query,
|
|
120
|
-
where: { ...params?.lookup, ...query.where, documentId }
|
|
121
|
-
});
|
|
122
|
-
if (!entries.length) {
|
|
123
|
-
return null;
|
|
124
|
-
}
|
|
125
|
-
const newDocumentId = createDocumentId();
|
|
126
|
-
const versions = await mapAsync(entries, async (entryToClone) => {
|
|
127
|
-
const isDraft = contentTypes.isDraft(data);
|
|
128
|
-
const validData = await entityValidator.validateEntityUpdate(
|
|
129
|
-
model,
|
|
130
|
-
// Omit id fields, the cloned entity id will be generated by the database
|
|
131
|
-
omit(["id"], data),
|
|
132
|
-
{ isDraft },
|
|
133
|
-
entryToClone
|
|
134
|
-
);
|
|
135
|
-
const componentData = await cloneComponents(uid, entryToClone, validData);
|
|
136
|
-
const entityData = createPipeline(
|
|
137
|
-
Object.assign(omitComponentData(model, validData), componentData),
|
|
138
|
-
{ contentType: model }
|
|
139
|
-
);
|
|
140
|
-
return db.query(uid).clone(entryToClone.id, {
|
|
141
|
-
...query,
|
|
142
|
-
// Allows entityData to override the documentId (e.g. when publishing)
|
|
143
|
-
data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale }
|
|
144
|
-
});
|
|
145
|
-
});
|
|
146
|
-
return { id: newDocumentId, versions };
|
|
147
|
-
},
|
|
148
|
-
// TODO: Handle relations so they target the published version
|
|
149
|
-
async publish(uid, documentId, params) {
|
|
150
|
-
await this.delete(uid, documentId, {
|
|
151
|
-
...params,
|
|
152
|
-
lookup: { ...params?.lookup, publishedAt: { $ne: null } }
|
|
153
|
-
});
|
|
154
|
-
const clonedDocuments = await this.clone(uid, documentId, {
|
|
155
|
-
...params || {},
|
|
156
|
-
// @ts-expect-error - Generic type does not have publishedAt attribute by default
|
|
157
|
-
data: { documentId, publishedAt: /* @__PURE__ */ new Date() }
|
|
158
|
-
});
|
|
159
|
-
return { versions: clonedDocuments?.versions || [] };
|
|
160
|
-
},
|
|
161
|
-
async unpublish(uid, documentId, params) {
|
|
162
|
-
return this.delete(uid, documentId, {
|
|
163
|
-
...params,
|
|
164
|
-
lookup: { ...params?.lookup, publishedAt: { $ne: null } }
|
|
165
|
-
});
|
|
166
|
-
},
|
|
167
|
-
/**
|
|
168
|
-
* Steps:
|
|
169
|
-
* - Delete the matching draft versions (publishedAt = null)
|
|
170
|
-
* - Clone the matching published versions into draft versions
|
|
171
|
-
*/
|
|
172
|
-
async discardDraft(uid, documentId, params) {
|
|
173
|
-
await this.delete(uid, documentId, {
|
|
174
|
-
...params,
|
|
175
|
-
// Delete all drafts that match query
|
|
176
|
-
lookup: { ...params?.lookup, publishedAt: null }
|
|
177
|
-
});
|
|
178
|
-
const clonedDocuments = await this.clone(uid, documentId, {
|
|
179
|
-
...params || {},
|
|
180
|
-
// Clone only published versions
|
|
181
|
-
lookup: { ...params?.lookup, publishedAt: { $ne: null } },
|
|
182
|
-
// @ts-expect-error - Generic type does not have publishedAt attribute by default
|
|
183
|
-
data: { documentId, publishedAt: null }
|
|
184
|
-
});
|
|
185
|
-
return { versions: clonedDocuments?.versions || [] };
|
|
186
|
-
}
|
|
187
|
-
});
|
|
188
|
-
const createDocumentService$1 = (ctx) => {
|
|
189
|
-
const implementation = createDocumentService(ctx);
|
|
190
|
-
return implementation;
|
|
23
|
+
repositories.set(uid, instance);
|
|
24
|
+
return instance;
|
|
25
|
+
};
|
|
26
|
+
return Object.assign(factory, {
|
|
27
|
+
utils: {
|
|
28
|
+
transformData
|
|
29
|
+
},
|
|
30
|
+
use: middlewares.use.bind(middlewares)
|
|
31
|
+
});
|
|
191
32
|
};
|
|
192
33
|
export {
|
|
193
|
-
createDocumentService
|
|
34
|
+
createDocumentService
|
|
194
35
|
};
|
|
195
36
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import type { Database } from '@strapi/database';\nimport type { Common, Documents, Schema, Shared, Strapi } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, convertQueryParams, mapAsync } from '@strapi/utils';\n\nimport { isArray, omit } from 'lodash/fp';\nimport uploadFiles from '../utils/upload-files';\n\nimport {\n cloneComponents,\n createComponents,\n deleteComponents,\n getComponents,\n omitComponentData,\n updateComponents,\n} from '../entity-service/components';\n\nimport { createDocumentId } from '../../utils/transform-content-types-to-models';\nimport { applyTransforms } from '../entity-service/attributes';\nimport entityValidator from '../entity-validator';\nimport { pickSelectionParams } from './params';\n\nconst { transformParamsToQuery } = convertQueryParams;\n\n/**\n * TODO: Sanitization / validation built-in\n * TODO: i18n - Move logic to i18n package\n * TODO: Webhooks\n * TODO: Audit logs\n * TODO: Entity Validation - Uniqueness across same locale and publication status\n * TODO: File upload\n * TODO: replace 'any'\n * TODO: availableLocales\n *\n */\ntype Context = {\n contentType: Schema.ContentType;\n};\n\nconst createPipeline = (data: Record<string, unknown>, context: Context) => {\n return applyTransforms(data, context);\n};\n\nconst updatePipeline = (data: Record<string, unknown>, context: Context) => {\n return applyTransforms(data, context);\n};\n\nconst createDocumentService = ({\n strapi,\n db,\n}: {\n strapi: Strapi;\n db: Database;\n}): Documents.Service => ({\n uploadFiles,\n\n async findMany(uid, params) {\n const { kind } = strapi.getModel(uid);\n\n const query = transformParamsToQuery(uid, params || ({} as any));\n query.where = { ...params?.lookup, ...query.where };\n\n if (kind === 'singleType') {\n return db.query(uid).findOne(query);\n }\n\n return db.query(uid).findMany(query);\n },\n\n async findFirst(uid, params) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n\n return db.query(uid).findOne({ ...query, where: { ...params?.lookup, ...query.where } });\n },\n\n async findOne(uid, documentId, params) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n return db\n .query(uid)\n .findOne({ ...query, where: { ...params?.lookup, ...query.where, documentId } });\n },\n\n async delete(uid, documentId, params = {} as any) {\n const query = transformParamsToQuery(uid, params as any);\n\n if (params.status === 'draft') {\n throw new Error('Cannot delete a draft document');\n }\n\n const entriesToDelete = await db.query(uid).findMany({\n ...query,\n where: {\n ...params.lookup,\n ...query?.where,\n documentId,\n },\n });\n\n // Delete all matched entries and its components\n await mapAsync(entriesToDelete, async (entryToDelete: any) => {\n const componentsToDelete = await getComponents(uid, entryToDelete);\n await db.query(uid).delete({ where: { id: entryToDelete.id } });\n await deleteComponents(uid, componentsToDelete as any, { loadComponents: false });\n });\n\n // TODO: Change return value to actual count\n return { versions: entriesToDelete };\n },\n\n // TODO: should we provide two separate methods?\n async deleteMany(uid, paramsOrIds) {\n let queryParams;\n if (isArray(paramsOrIds)) {\n queryParams = { filter: { documentID: { $in: paramsOrIds } } };\n } else {\n queryParams = paramsOrIds;\n }\n\n const query = transformParamsToQuery(uid, queryParams || ({} as any));\n\n return db.query(uid).deleteMany(query);\n },\n\n async create(uid, params) {\n // TODO: Entity validator.\n // TODO: File upload - Probably in the lifecycles?\n const { data } = params;\n\n if (!data) {\n throw new Error('Create requires data attribute');\n }\n\n const model = strapi.getModel(uid) as Shared.ContentTypes[Common.UID.ContentType];\n\n const validData = await entityValidator.validateEntityCreation(model, data, { isDraft: true });\n\n const componentData = await createComponents(uid, validData);\n const entryData = createPipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n {\n contentType: model,\n }\n );\n\n // select / populate\n const query = transformParamsToQuery(uid, pickSelectionParams(params));\n\n return db.query(uid).create({ ...query, data: entryData });\n },\n\n // NOTE: What happens if user doesn't provide specific publications state and locale to update?\n async update(uid, documentId, params) {\n // TODO: Prevent updating a published document\n // TODO: Entity validator.\n // TODO: File upload\n const { data } = params || {};\n const model = strapi.getModel(uid) as Shared.ContentTypes[Common.UID.ContentType];\n\n const query = transformParamsToQuery(uid, pickSelectionParams(params || {}));\n\n // Find all locales of the document\n const entryToUpdate = await db\n .query(uid)\n .findOne({ ...query, where: { ...params?.lookup, ...query?.where, documentId } });\n\n // Document does not exist\n if (!entryToUpdate) {\n return null;\n }\n\n const validData = await entityValidator.validateEntityUpdate(\n model,\n data,\n { isDraft: true }, // Always update the draft version\n entryToUpdate\n );\n\n const componentData = await updateComponents(uid, entryToUpdate, validData);\n const entryData = updatePipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n return db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });\n },\n\n async count(uid, params = undefined) {\n const query = transformParamsToQuery(uid, params || ({} as any));\n query.where = { ...params?.lookup, ...query.where };\n\n return db.query(uid).count(query);\n },\n\n async clone(uid, documentId, params) {\n // TODO: File upload\n // TODO: Entity validator.\n const { data = {} as any } = params!;\n\n const model = strapi.getModel(uid);\n const query = transformParamsToQuery(uid, pickSelectionParams(params));\n\n // Find all locales of the document\n const entries = await db.query(uid).findMany({\n ...query,\n where: { ...params?.lookup, ...query.where, documentId },\n });\n\n // Document does not exist\n if (!entries.length) {\n return null;\n }\n\n const newDocumentId = createDocumentId();\n\n const versions = await mapAsync(entries, async (entryToClone: any) => {\n const isDraft = contentTypesUtils.isDraft(data);\n // Todo: Merge data with entry to clone\n const validData = await entityValidator.validateEntityUpdate(\n model,\n // Omit id fields, the cloned entity id will be generated by the database\n omit(['id'], data),\n { isDraft },\n entryToClone\n );\n\n const componentData = await cloneComponents(uid, entryToClone, validData);\n const entityData = createPipeline(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n // TODO: Transform params to query\n return db.query(uid).clone(entryToClone.id, {\n ...query,\n // Allows entityData to override the documentId (e.g. when publishing)\n data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale },\n });\n });\n\n return { id: newDocumentId, versions };\n },\n\n // TODO: Handle relations so they target the published version\n async publish(uid, documentId, params) {\n // Delete already published versions that match the locales to be published\n await this.delete(uid, documentId, {\n ...params,\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n });\n\n // Clone every draft version to be published\n const clonedDocuments = (await this.clone(uid, documentId, {\n ...(params || {}),\n // @ts-expect-error - Generic type does not have publishedAt attribute by default\n data: { documentId, publishedAt: new Date() },\n })) as any;\n\n // TODO: Return actual count\n return { versions: clonedDocuments?.versions || [] };\n },\n\n async unpublish(uid, documentId, params) {\n // Delete all published versions\n return this.delete(uid, documentId, {\n ...params,\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n }) as any;\n },\n\n /**\n * Steps:\n * - Delete the matching draft versions (publishedAt = null)\n * - Clone the matching published versions into draft versions\n */\n async discardDraft(uid, documentId, params) {\n // Delete draft versions, clone published versions into draft versions\n await this.delete(uid, documentId, {\n ...params,\n // Delete all drafts that match query\n lookup: { ...params?.lookup, publishedAt: null },\n });\n\n // Clone published versions into draft versions\n const clonedDocuments = (await this.clone(uid, documentId, {\n ...(params || {}),\n // Clone only published versions\n lookup: { ...params?.lookup, publishedAt: { $ne: null } },\n // @ts-expect-error - Generic type does not have publishedAt attribute by default\n data: { documentId, publishedAt: null },\n })) as any;\n\n return { versions: clonedDocuments?.versions || [] };\n },\n});\n\nexport default (ctx: { strapi: Strapi; db: Database }): Documents.Service => {\n const implementation = createDocumentService(ctx);\n\n // TODO: Wrap with database error handling\n return implementation;\n};\n"],"names":["uploadFiles","contentTypesUtils"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import type { Core, Modules, UID } from '@strapi/types';\n\nimport { createMiddlewareManager, databaseErrorsMiddleware } from './middlewares';\nimport { createContentTypeRepository } from './repository';\nimport { transformData } from './transform/data';\n\nimport entityValidator from '../entity-validator';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @param validator - validator for database entries\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\nexport const createDocumentService = (\n strapi: Core.Strapi,\n validator: Modules.EntityValidator.EntityValidator = entityValidator\n): Modules.Documents.Service => {\n // Cache the repositories (one per content type)\n const repositories = new Map<string, Modules.Documents.ServiceInstance>();\n\n // Manager to handle document service middlewares\n const middlewares = createMiddlewareManager();\n middlewares.use(databaseErrorsMiddleware);\n\n const factory = function factory(uid: UID.ContentType) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid, validator);\n\n const instance = middlewares.wrapObject(\n repository,\n { uid, contentType },\n {\n exclude: ['updateComponents', 'omitComponentData'],\n }\n );\n\n repositories.set(uid, instance);\n\n return instance;\n } as Modules.Documents.Service;\n\n return Object.assign(factory, {\n utils: {\n transformData,\n },\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["factory"],"mappings":";;;;;AAuBO,MAAM,wBAAwB,CACnC,QACA,YAAqD,oBACvB;AAExB,QAAA,mCAAmB;AAGzB,QAAM,cAAc;AACpB,cAAY,IAAI,wBAAwB;AAElC,QAAA,UAAU,SAASA,SAAQ,KAAsB;AACjD,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAA,aAAa,4BAA4B,KAAK,SAAS;AAE7D,UAAM,WAAW,YAAY;AAAA,MAC3B;AAAA,MACA,EAAE,KAAK,YAAY;AAAA,MACnB;AAAA,QACE,SAAS,CAAC,oBAAoB,mBAAmB;AAAA,MACnD;AAAA,IAAA;AAGW,iBAAA,IAAI,KAAK,QAAQ;AAEvB,WAAA;AAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,OAAO;AAAA,MACL;AAAA,IACF;AAAA,IACA,KAAK,YAAY,IAAI,KAAK,WAAW;AAAA,EAAA,CACtC;AACH;"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="lodash" />
|
|
2
|
+
import type { Struct, Modules } from '@strapi/types';
|
|
3
|
+
declare const defaultLocaleCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Promise<Modules.Documents.Params.All>>;
|
|
4
|
+
declare const localeToLookupCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
|
|
5
|
+
declare const multiLocaleToLookupCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
|
|
6
|
+
declare const localeToDataCurry: import("lodash").CurriedFunction2<Struct.SingleTypeSchema | Struct.CollectionTypeSchema, Modules.Documents.Params.All, Modules.Documents.Params.All>;
|
|
7
|
+
export { defaultLocaleCurry as defaultLocale, localeToLookupCurry as localeToLookup, localeToDataCurry as localeToData, multiLocaleToLookupCurry as multiLocaleToLookup, };
|
|
8
|
+
//# sourceMappingURL=internationalization.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internationalization.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/internationalization.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AA8FrD,QAAA,MAAM,kBAAkB,+JAAuB,CAAC;AAChD,QAAA,MAAM,mBAAmB,sJAAwB,CAAC;AAClD,QAAA,MAAM,wBAAwB,sJAA6B,CAAC;AAC5D,QAAA,MAAM,iBAAiB,sJAAsB,CAAC;AAE9C,OAAO,EACL,kBAAkB,IAAI,aAAa,EACnC,mBAAmB,IAAI,cAAc,EACrC,iBAAiB,IAAI,YAAY,EACjC,wBAAwB,IAAI,mBAAmB,GAChD,CAAC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const strapiUtils = require("@strapi/utils");
|
|
4
|
+
const fp = require("lodash/fp");
|
|
5
|
+
const getDefaultLocale = async () => {
|
|
6
|
+
return strapi.plugin("i18n").service("locales").getDefaultLocale();
|
|
7
|
+
};
|
|
8
|
+
const defaultLocale = async (contentType, params) => {
|
|
9
|
+
if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
|
|
10
|
+
return params;
|
|
11
|
+
}
|
|
12
|
+
if (!params.locale) {
|
|
13
|
+
return fp.assoc("locale", await getDefaultLocale(), params);
|
|
14
|
+
}
|
|
15
|
+
return params;
|
|
16
|
+
};
|
|
17
|
+
const localeToLookup = (contentType, params) => {
|
|
18
|
+
if (!params.locale || !strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
|
|
19
|
+
return params;
|
|
20
|
+
}
|
|
21
|
+
if (typeof params.locale !== "string") {
|
|
22
|
+
throw new strapiUtils.errors.ValidationError(
|
|
23
|
+
`Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`
|
|
24
|
+
);
|
|
25
|
+
}
|
|
26
|
+
return fp.assoc(["lookup", "locale"], params.locale, params);
|
|
27
|
+
};
|
|
28
|
+
const multiLocaleToLookup = (contentType, params) => {
|
|
29
|
+
if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
|
|
30
|
+
return params;
|
|
31
|
+
}
|
|
32
|
+
if (params.locale) {
|
|
33
|
+
if (params.locale === "*") {
|
|
34
|
+
return params;
|
|
35
|
+
}
|
|
36
|
+
return fp.assoc(["lookup", "locale"], params.locale, params);
|
|
37
|
+
}
|
|
38
|
+
return params;
|
|
39
|
+
};
|
|
40
|
+
const localeToData = (contentType, params) => {
|
|
41
|
+
if (!strapi.plugin("i18n").service("content-types").isLocalizedContentType(contentType)) {
|
|
42
|
+
return params;
|
|
43
|
+
}
|
|
44
|
+
if (params.locale) {
|
|
45
|
+
const isValidLocale = typeof params.locale === "string" && params.locale !== "*";
|
|
46
|
+
if (isValidLocale) {
|
|
47
|
+
return fp.assoc(["data", "locale"], params.locale, params);
|
|
48
|
+
}
|
|
49
|
+
throw new strapiUtils.errors.ValidationError(
|
|
50
|
+
`Invalid locale param ${params.locale} provided. Document locales must be strings.`
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
return params;
|
|
54
|
+
};
|
|
55
|
+
const defaultLocaleCurry = fp.curry(defaultLocale);
|
|
56
|
+
const localeToLookupCurry = fp.curry(localeToLookup);
|
|
57
|
+
const multiLocaleToLookupCurry = fp.curry(multiLocaleToLookup);
|
|
58
|
+
const localeToDataCurry = fp.curry(localeToData);
|
|
59
|
+
exports.defaultLocale = defaultLocaleCurry;
|
|
60
|
+
exports.localeToData = localeToDataCurry;
|
|
61
|
+
exports.localeToLookup = localeToLookupCurry;
|
|
62
|
+
exports.multiLocaleToLookup = multiLocaleToLookupCurry;
|
|
63
|
+
//# sourceMappingURL=internationalization.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internationalization.js","sources":["../../../src/services/document-service/internationalization.ts"],"sourcesContent":["import type { Struct, Modules } from '@strapi/types';\nimport { errors } from '@strapi/utils';\nimport { curry, assoc } from 'lodash/fp';\n\ntype Transform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Modules.Documents.Params.All;\n\ntype AsyncTransform = (\n contentType: Struct.SingleTypeSchema | Struct.CollectionTypeSchema,\n params: Modules.Documents.Params.All\n) => Promise<Modules.Documents.Params.All>;\n\nconst getDefaultLocale = async (): Promise<string> => {\n return strapi.plugin('i18n').service('locales').getDefaultLocale();\n};\n\nconst defaultLocale: AsyncTransform = async (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (!params.locale) {\n return assoc('locale', await getDefaultLocale(), params);\n }\n\n return params;\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst localeToLookup: Transform = (contentType, params) => {\n if (\n !params.locale ||\n !strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)\n ) {\n return params;\n }\n\n if (typeof params.locale !== 'string') {\n // localeToLookup accepts locales of '*'. This is because the document\n // service functions that use this transform work with the '*' locale\n // to return all locales.\n throw new errors.ValidationError(\n `Invalid locale param ${String(params.locale)} provided. Document locales must be strings.`\n );\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n};\n\n/**\n * Add locale lookup query to the params\n */\nconst multiLocaleToLookup: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n if (params.locale === '*') {\n return params;\n }\n\n return assoc(['lookup', 'locale'], params.locale, params);\n }\n\n return params;\n};\n\n/**\n * Translate locale status parameter into the data that will be saved\n */\nconst localeToData: Transform = (contentType, params) => {\n if (!strapi.plugin('i18n').service('content-types').isLocalizedContentType(contentType)) {\n return params;\n }\n\n if (params.locale) {\n const isValidLocale = typeof params.locale === 'string' && params.locale !== '*';\n if (isValidLocale) {\n return assoc(['data', 'locale'], params.locale, params);\n }\n\n throw new errors.ValidationError(\n `Invalid locale param ${params.locale} provided. Document locales must be strings.`\n );\n }\n\n return params;\n};\n\nconst defaultLocaleCurry = curry(defaultLocale);\nconst localeToLookupCurry = curry(localeToLookup);\nconst multiLocaleToLookupCurry = curry(multiLocaleToLookup);\nconst localeToDataCurry = curry(localeToData);\n\nexport {\n defaultLocaleCurry as defaultLocale,\n localeToLookupCurry as localeToLookup,\n localeToDataCurry as localeToData,\n multiLocaleToLookupCurry as multiLocaleToLookup,\n};\n"],"names":["assoc","errors","curry"],"mappings":";;;;AAcA,MAAM,mBAAmB,YAA6B;AACpD,SAAO,OAAO,OAAO,MAAM,EAAE,QAAQ,SAAS,EAAE;AAClD;AAEA,MAAM,gBAAgC,OAAO,aAAa,WAAW;AAC/D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEI,MAAA,CAAC,OAAO,QAAQ;AAClB,WAAOA,GAAM,MAAA,UAAU,MAAM,oBAAoB,MAAM;AAAA,EACzD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA4B,CAAC,aAAa,WAAW;AACzD,MACE,CAAC,OAAO,UACR,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAClF;AACO,WAAA;AAAA,EACT;AAEI,MAAA,OAAO,OAAO,WAAW,UAAU;AAIrC,UAAM,IAAIC,YAAO,OAAA;AAAA,MACf,wBAAwB,OAAO,OAAO,MAAM,CAAC;AAAA,IAAA;AAAA,EAEjD;AAEA,SAAOD,GAAAA,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAC1D;AAKA,MAAM,sBAAiC,CAAC,aAAa,WAAW;AAC1D,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACb,QAAA,OAAO,WAAW,KAAK;AAClB,aAAA;AAAA,IACT;AAEA,WAAOA,GAAAA,MAAM,CAAC,UAAU,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,EAC1D;AAEO,SAAA;AACT;AAKA,MAAM,eAA0B,CAAC,aAAa,WAAW;AACnD,MAAA,CAAC,OAAO,OAAO,MAAM,EAAE,QAAQ,eAAe,EAAE,uBAAuB,WAAW,GAAG;AAChF,WAAA;AAAA,EACT;AAEA,MAAI,OAAO,QAAQ;AACjB,UAAM,gBAAgB,OAAO,OAAO,WAAW,YAAY,OAAO,WAAW;AAC7E,QAAI,eAAe;AACjB,aAAOA,GAAAA,MAAM,CAAC,QAAQ,QAAQ,GAAG,OAAO,QAAQ,MAAM;AAAA,IACxD;AAEA,UAAM,IAAIC,YAAO,OAAA;AAAA,MACf,wBAAwB,OAAO,MAAM;AAAA,IAAA;AAAA,EAEzC;AAEO,SAAA;AACT;AAEM,MAAA,qBAAqBC,SAAM,aAAa;AACxC,MAAA,sBAAsBA,SAAM,cAAc;AAC1C,MAAA,2BAA2BA,SAAM,mBAAmB;AACpD,MAAA,oBAAoBA,SAAM,YAAY;;;;;"}
|