@strapi/core 0.0.0-experimental.3f7b2587c5e3d548262671895cf11d8bf8c9166e → 0.0.0-experimental.402a8c65252458d28f0c291ad2aaabec270b591d
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 +52 -59
- package/dist/Strapi.d.ts.map +1 -1
- package/dist/configuration/config-loader.d.ts.map +1 -1
- package/dist/configuration/get-dirs.d.ts +10 -0
- package/dist/configuration/get-dirs.d.ts.map +1 -0
- package/dist/configuration/index.d.ts +4 -7
- package/dist/configuration/index.d.ts.map +1 -1
- package/dist/configuration/urls.d.ts +8 -0
- package/dist/configuration/urls.d.ts.map +1 -0
- package/dist/container.d.ts +2 -2
- package/dist/container.d.ts.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/index.d.ts +3 -3
- package/dist/core-api/controller/index.d.ts.map +1 -1
- package/dist/core-api/controller/single-type.d.ts +4 -4
- package/dist/core-api/controller/single-type.d.ts.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/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/core-service.d.ts +4 -0
- package/dist/core-api/service/core-service.d.ts.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/pagination.d.ts +4 -15
- package/dist/core-api/service/pagination.d.ts.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/domain/content-type/index.d.ts +1 -1
- package/dist/domain/content-type/index.d.ts.map +1 -1
- package/dist/domain/content-type/validator.d.ts.map +1 -1
- package/dist/domain/module/index.d.ts +24 -23
- package/dist/domain/module/index.d.ts.map +1 -1
- package/dist/ee/index.d.ts +4 -2
- package/dist/ee/index.d.ts.map +1 -1
- package/dist/ee/license.d.ts +2 -2
- package/dist/ee/license.d.ts.map +1 -1
- package/dist/factories.d.ts +10 -10
- package/dist/factories.d.ts.map +1 -1
- package/dist/index.d.ts +18 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9956 -5
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +9932 -5
- package/dist/index.mjs.map +1 -1
- package/dist/loaders/admin.d.ts +2 -2
- package/dist/loaders/admin.d.ts.map +1 -1
- package/dist/loaders/apis.d.ts +2 -2
- package/dist/loaders/apis.d.ts.map +1 -1
- package/dist/loaders/components.d.ts +2 -2
- package/dist/loaders/components.d.ts.map +1 -1
- package/dist/loaders/index.d.ts +2 -2
- package/dist/loaders/index.d.ts.map +1 -1
- package/dist/loaders/middlewares.d.ts +2 -2
- package/dist/loaders/middlewares.d.ts.map +1 -1
- package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
- package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
- package/dist/loaders/plugins/index.d.ts +2 -2
- package/dist/loaders/plugins/index.d.ts.map +1 -1
- package/dist/loaders/policies.d.ts +2 -2
- package/dist/loaders/policies.d.ts.map +1 -1
- package/dist/loaders/sanitizers.d.ts +2 -2
- package/dist/loaders/sanitizers.d.ts.map +1 -1
- package/dist/loaders/src-index.d.ts +2 -2
- package/dist/loaders/src-index.d.ts.map +1 -1
- package/dist/loaders/validators.d.ts +2 -2
- package/dist/loaders/validators.d.ts.map +1 -1
- package/dist/middlewares/body.d.ts +4 -4
- package/dist/middlewares/body.d.ts.map +1 -1
- package/dist/middlewares/compression.d.ts +2 -2
- package/dist/middlewares/compression.d.ts.map +1 -1
- package/dist/middlewares/cors.d.ts +2 -2
- package/dist/middlewares/cors.d.ts.map +1 -1
- package/dist/middlewares/errors.d.ts +2 -2
- package/dist/middlewares/errors.d.ts.map +1 -1
- package/dist/middlewares/favicon.d.ts +2 -2
- package/dist/middlewares/favicon.d.ts.map +1 -1
- package/dist/middlewares/index.d.ts +2 -2
- package/dist/middlewares/index.d.ts.map +1 -1
- package/dist/middlewares/ip.d.ts +2 -2
- package/dist/middlewares/ip.d.ts.map +1 -1
- package/dist/middlewares/logger.d.ts +2 -2
- package/dist/middlewares/logger.d.ts.map +1 -1
- package/dist/middlewares/powered-by.d.ts +2 -2
- package/dist/middlewares/powered-by.d.ts.map +1 -1
- package/dist/middlewares/public.d.ts +2 -2
- package/dist/middlewares/public.d.ts.map +1 -1
- package/dist/middlewares/query.d.ts +2 -2
- package/dist/middlewares/query.d.ts.map +1 -1
- package/dist/middlewares/response-time.d.ts +2 -2
- package/dist/middlewares/response-time.d.ts.map +1 -1
- package/dist/middlewares/responses.d.ts +3 -3
- package/dist/middlewares/responses.d.ts.map +1 -1
- package/dist/middlewares/security.d.ts +2 -2
- package/dist/middlewares/security.d.ts.map +1 -1
- package/dist/middlewares/session.d.ts +2 -2
- package/dist/middlewares/session.d.ts.map +1 -1
- package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
- package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
- package/dist/migrations/draft-publish.d.ts +17 -0
- package/dist/migrations/draft-publish.d.ts.map +1 -0
- package/dist/migrations/i18n.d.ts +5 -0
- package/dist/migrations/i18n.d.ts.map +1 -0
- package/dist/migrations/index.d.ts +5 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/providers/admin.d.ts +3 -0
- package/dist/providers/admin.d.ts.map +1 -0
- package/dist/providers/coreStore.d.ts +3 -0
- package/dist/providers/coreStore.d.ts.map +1 -0
- package/dist/providers/cron.d.ts +3 -0
- package/dist/providers/cron.d.ts.map +1 -0
- package/dist/providers/index.d.ts +3 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/provider.d.ts +9 -0
- package/dist/providers/provider.d.ts.map +1 -0
- package/dist/providers/registries.d.ts +3 -0
- package/dist/providers/registries.d.ts.map +1 -0
- package/dist/providers/telemetry.d.ts +3 -0
- package/dist/providers/telemetry.d.ts.map +1 -0
- package/dist/providers/webhooks.d.ts +3 -0
- package/dist/providers/webhooks.d.ts.map +1 -0
- package/dist/registries/apis.d.ts +2 -2
- package/dist/registries/apis.d.ts.map +1 -1
- package/dist/registries/components.d.ts +6 -6
- package/dist/registries/components.d.ts.map +1 -1
- package/dist/registries/content-types.d.ts +5 -5
- package/dist/registries/content-types.d.ts.map +1 -1
- package/dist/registries/controllers.d.ts +10 -10
- package/dist/registries/controllers.d.ts.map +1 -1
- package/dist/registries/custom-fields.d.ts +3 -3
- package/dist/registries/custom-fields.d.ts.map +1 -1
- package/dist/registries/index.d.ts +0 -1
- package/dist/registries/index.d.ts.map +1 -1
- package/dist/registries/middlewares.d.ts +6 -6
- package/dist/registries/middlewares.d.ts.map +1 -1
- package/dist/registries/modules.d.ts +2 -2
- package/dist/registries/modules.d.ts.map +1 -1
- package/dist/registries/plugins.d.ts +5 -5
- package/dist/registries/plugins.d.ts.map +1 -1
- package/dist/registries/policies.d.ts +22 -10
- package/dist/registries/policies.d.ts.map +1 -1
- package/dist/registries/services.d.ts +8 -8
- package/dist/registries/services.d.ts.map +1 -1
- package/dist/services/auth/index.d.ts +4 -4
- package/dist/services/auth/index.d.ts.map +1 -1
- package/dist/services/config.d.ts +3 -0
- package/dist/services/config.d.ts.map +1 -0
- package/dist/services/content-api/index.d.ts +31 -15
- package/dist/services/content-api/index.d.ts.map +1 -1
- package/dist/services/content-api/permissions/index.d.ts +13 -15
- package/dist/services/content-api/permissions/index.d.ts.map +1 -1
- package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
- package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
- package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
- package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
- package/dist/services/core-store.d.ts.map +1 -1
- package/dist/services/cron.d.ts +5 -5
- package/dist/services/cron.d.ts.map +1 -1
- package/dist/services/custom-fields.d.ts +2 -2
- package/dist/services/custom-fields.d.ts.map +1 -1
- package/dist/services/document-service/attributes/index.d.ts +6 -0
- package/dist/services/document-service/attributes/index.d.ts.map +1 -0
- package/dist/services/document-service/attributes/transforms.d.ts +10 -0
- package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
- package/dist/services/document-service/common.d.ts +4 -0
- package/dist/services/document-service/common.d.ts.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/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/entries.d.ts +10 -0
- package/dist/services/document-service/entries.d.ts.map +1 -0
- package/dist/services/document-service/events.d.ts +25 -0
- package/dist/services/document-service/events.d.ts.map +1 -0
- package/dist/services/document-service/{document-service.d.ts → index.d.ts} +4 -7
- package/dist/services/document-service/index.d.ts.map +1 -0
- 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/middlewares/errors.d.ts +6 -0
- package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
- package/dist/services/document-service/middlewares/index.d.ts +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/params.d.ts +3 -1
- package/dist/services/document-service/params.d.ts.map +1 -1
- 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/transform/data.d.ts +5 -0
- package/dist/services/document-service/transform/data.d.ts.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/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-transform.d.ts +5 -0
- package/dist/services/document-service/transform/id-transform.d.ts.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/query.d.ts +5 -0
- package/dist/services/document-service/transform/query.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +14 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.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/default-locale.d.ts +9 -0
- package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/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/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/map-relation.d.ts +6 -0
- package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/types.d.ts +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/unidirectional-relations.d.ts +36 -0
- package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
- package/dist/services/entity-service/index.d.ts +4 -6
- package/dist/services/entity-service/index.d.ts.map +1 -1
- package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
- package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
- package/dist/services/entity-validator/index.d.ts +16 -2
- package/dist/services/entity-validator/index.d.ts.map +1 -1
- package/dist/services/entity-validator/validators.d.ts +36 -25
- package/dist/services/entity-validator/validators.d.ts.map +1 -1
- package/dist/services/event-hub.d.ts +1 -0
- package/dist/services/event-hub.d.ts.map +1 -1
- package/dist/services/features.d.ts +3 -3
- package/dist/services/features.d.ts.map +1 -1
- package/dist/services/fs.d.ts +2 -2
- package/dist/services/fs.d.ts.map +1 -1
- package/dist/services/metrics/admin-user-hash.d.ts +2 -2
- package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
- package/dist/services/metrics/index.d.ts +2 -2
- package/dist/services/metrics/index.d.ts.map +1 -1
- package/dist/services/metrics/middleware.d.ts +2 -2
- package/dist/services/metrics/middleware.d.ts.map +1 -1
- package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
- package/dist/services/metrics/sender.d.ts +3 -3
- package/dist/services/metrics/sender.d.ts.map +1 -1
- package/dist/services/query-params.d.ts +7 -0
- package/dist/services/query-params.d.ts.map +1 -0
- package/dist/services/reloader.d.ts +7 -0
- package/dist/services/reloader.d.ts.map +1 -0
- package/dist/services/server/admin-api.d.ts +3 -3
- package/dist/services/server/admin-api.d.ts.map +1 -1
- package/dist/services/server/api.d.ts +3 -3
- package/dist/services/server/api.d.ts.map +1 -1
- package/dist/services/server/compose-endpoint.d.ts +2 -2
- package/dist/services/server/compose-endpoint.d.ts.map +1 -1
- package/dist/services/server/content-api.d.ts +3 -3
- package/dist/services/server/content-api.d.ts.map +1 -1
- package/dist/services/server/http-server.d.ts +2 -2
- package/dist/services/server/http-server.d.ts.map +1 -1
- package/dist/services/server/index.d.ts +2 -2
- package/dist/services/server/index.d.ts.map +1 -1
- package/dist/services/server/koa.d.ts.map +1 -1
- package/dist/services/server/middleware.d.ts +4 -4
- package/dist/services/server/middleware.d.ts.map +1 -1
- package/dist/services/server/policy.d.ts +3 -3
- package/dist/services/server/policy.d.ts.map +1 -1
- package/dist/services/server/register-middlewares.d.ts +2 -2
- package/dist/services/server/register-middlewares.d.ts.map +1 -1
- package/dist/services/server/register-routes.d.ts +2 -2
- package/dist/services/server/register-routes.d.ts.map +1 -1
- package/dist/services/server/routing.d.ts +5 -5
- package/dist/services/server/routing.d.ts.map +1 -1
- package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
- package/dist/services/webhook-runner.d.ts +2 -1
- package/dist/services/webhook-runner.d.ts.map +1 -1
- package/dist/services/webhook-store.d.ts +2 -8
- package/dist/services/webhook-store.d.ts.map +1 -1
- package/dist/utils/convert-custom-field-type.d.ts +2 -2
- package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
- package/dist/utils/fetch.d.ts +3 -3
- package/dist/utils/fetch.d.ts.map +1 -1
- package/dist/utils/filepath-to-prop-path.d.ts +1 -1
- package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
- package/dist/utils/index.d.ts +2 -1
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/is-initialized.d.ts +2 -2
- package/dist/utils/is-initialized.d.ts.map +1 -1
- package/dist/utils/load-files.d.ts.map +1 -1
- package/dist/utils/open-browser.d.ts +2 -2
- package/dist/utils/open-browser.d.ts.map +1 -1
- package/dist/utils/resolve-working-dirs.d.ts +19 -0
- package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
- package/dist/utils/signals.d.ts +2 -2
- package/dist/utils/signals.d.ts.map +1 -1
- package/dist/utils/startup-logger.d.ts +2 -2
- package/dist/utils/startup-logger.d.ts.map +1 -1
- package/dist/utils/transform-content-types-to-models.d.ts +461 -3
- package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
- package/dist/utils/update-notifier/index.d.ts +2 -7
- package/dist/utils/update-notifier/index.d.ts.map +1 -1
- package/package.json +43 -40
- package/dist/Strapi.js +0 -443
- package/dist/Strapi.js.map +0 -1
- package/dist/Strapi.mjs +0 -442
- package/dist/Strapi.mjs.map +0 -1
- package/dist/compile.js +0 -18
- package/dist/compile.js.map +0 -1
- package/dist/compile.mjs +0 -17
- package/dist/compile.mjs.map +0 -1
- package/dist/configuration/config-loader.js +0 -102
- package/dist/configuration/config-loader.js.map +0 -1
- package/dist/configuration/config-loader.mjs +0 -100
- package/dist/configuration/config-loader.mjs.map +0 -1
- package/dist/configuration/index.js +0 -78
- package/dist/configuration/index.js.map +0 -1
- package/dist/configuration/index.mjs +0 -74
- package/dist/configuration/index.mjs.map +0 -1
- package/dist/container.js +0 -30
- package/dist/container.js.map +0 -1
- package/dist/container.mjs +0 -30
- package/dist/container.mjs.map +0 -1
- package/dist/core-api/controller/collection-type.js +0 -92
- package/dist/core-api/controller/collection-type.js.map +0 -1
- package/dist/core-api/controller/collection-type.mjs +0 -93
- package/dist/core-api/controller/collection-type.mjs.map +0 -1
- package/dist/core-api/controller/index.js +0 -47
- package/dist/core-api/controller/index.js.map +0 -1
- package/dist/core-api/controller/index.mjs +0 -47
- package/dist/core-api/controller/index.mjs.map +0 -1
- package/dist/core-api/controller/single-type.js +0 -50
- package/dist/core-api/controller/single-type.js.map +0 -1
- package/dist/core-api/controller/single-type.mjs +0 -51
- package/dist/core-api/controller/single-type.mjs.map +0 -1
- package/dist/core-api/controller/transform.js +0 -84
- package/dist/core-api/controller/transform.js.map +0 -1
- package/dist/core-api/controller/transform.mjs +0 -84
- package/dist/core-api/controller/transform.mjs.map +0 -1
- package/dist/core-api/routes/index.js +0 -67
- package/dist/core-api/routes/index.js.map +0 -1
- package/dist/core-api/routes/index.mjs +0 -67
- package/dist/core-api/routes/index.mjs.map +0 -1
- package/dist/core-api/service/collection-type.js +0 -58
- package/dist/core-api/service/collection-type.js.map +0 -1
- package/dist/core-api/service/collection-type.mjs +0 -59
- package/dist/core-api/service/collection-type.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/core-api/service/index.js +0 -16
- package/dist/core-api/service/index.js.map +0 -1
- package/dist/core-api/service/index.mjs +0 -16
- package/dist/core-api/service/index.mjs.map +0 -1
- package/dist/core-api/service/pagination.js +0 -89
- package/dist/core-api/service/pagination.js.map +0 -1
- package/dist/core-api/service/pagination.mjs +0 -89
- package/dist/core-api/service/pagination.mjs.map +0 -1
- package/dist/core-api/service/single-type.js +0 -54
- package/dist/core-api/service/single-type.js.map +0 -1
- package/dist/core-api/service/single-type.mjs +0 -55
- package/dist/core-api/service/single-type.mjs.map +0 -1
- package/dist/domain/content-type/index.js +0 -108
- package/dist/domain/content-type/index.js.map +0 -1
- package/dist/domain/content-type/index.mjs +0 -106
- package/dist/domain/content-type/index.mjs.map +0 -1
- package/dist/domain/content-type/validator.js +0 -77
- package/dist/domain/content-type/validator.js.map +0 -1
- package/dist/domain/content-type/validator.mjs +0 -75
- package/dist/domain/content-type/validator.mjs.map +0 -1
- package/dist/domain/module/index.js +0 -107
- package/dist/domain/module/index.js.map +0 -1
- package/dist/domain/module/index.mjs +0 -105
- package/dist/domain/module/index.mjs.map +0 -1
- package/dist/domain/module/validation.js +0 -25
- package/dist/domain/module/validation.js.map +0 -1
- package/dist/domain/module/validation.mjs +0 -25
- package/dist/domain/module/validation.mjs.map +0 -1
- package/dist/ee/index.js +0 -153
- package/dist/ee/index.js.map +0 -1
- package/dist/ee/index.mjs +0 -154
- package/dist/ee/index.mjs.map +0 -1
- package/dist/ee/license.js +0 -90
- package/dist/ee/license.js.map +0 -1
- package/dist/ee/license.mjs +0 -87
- package/dist/ee/license.mjs.map +0 -1
- package/dist/factories.js +0 -86
- package/dist/factories.js.map +0 -1
- package/dist/factories.mjs +0 -86
- package/dist/factories.mjs.map +0 -1
- package/dist/loaders/admin.js +0 -27
- package/dist/loaders/admin.js.map +0 -1
- package/dist/loaders/admin.mjs +0 -26
- package/dist/loaders/admin.mjs.map +0 -1
- package/dist/loaders/apis.js +0 -137
- package/dist/loaders/apis.js.map +0 -1
- package/dist/loaders/apis.mjs +0 -135
- package/dist/loaders/apis.mjs.map +0 -1
- package/dist/loaders/components.js +0 -38
- package/dist/loaders/components.js.map +0 -1
- package/dist/loaders/components.mjs +0 -37
- package/dist/loaders/components.mjs.map +0 -1
- package/dist/loaders/index.js +0 -26
- package/dist/loaders/index.js.map +0 -1
- package/dist/loaders/index.mjs +0 -26
- package/dist/loaders/index.mjs.map +0 -1
- package/dist/loaders/middlewares.js +0 -31
- package/dist/loaders/middlewares.js.map +0 -1
- package/dist/loaders/middlewares.mjs +0 -30
- package/dist/loaders/middlewares.mjs.map +0 -1
- package/dist/loaders/plugins/get-enabled-plugins.js +0 -111
- package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
- package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -109
- package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
- package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
- package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
- package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
- package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
- package/dist/loaders/plugins/index.js +0 -118
- package/dist/loaders/plugins/index.js.map +0 -1
- package/dist/loaders/plugins/index.mjs +0 -117
- package/dist/loaders/plugins/index.mjs.map +0 -1
- package/dist/loaders/policies.js +0 -25
- package/dist/loaders/policies.js.map +0 -1
- package/dist/loaders/policies.mjs +0 -24
- package/dist/loaders/policies.mjs.map +0 -1
- package/dist/loaders/sanitizers.js +0 -6
- package/dist/loaders/sanitizers.js.map +0 -1
- package/dist/loaders/sanitizers.mjs +0 -7
- package/dist/loaders/sanitizers.mjs.map +0 -1
- package/dist/loaders/src-index.js +0 -33
- package/dist/loaders/src-index.js.map +0 -1
- package/dist/loaders/src-index.mjs +0 -34
- package/dist/loaders/src-index.mjs.map +0 -1
- package/dist/loaders/validators.js +0 -6
- package/dist/loaders/validators.js.map +0 -1
- package/dist/loaders/validators.mjs +0 -7
- package/dist/loaders/validators.mjs.map +0 -1
- package/dist/middlewares/body.js +0 -65
- package/dist/middlewares/body.js.map +0 -1
- package/dist/middlewares/body.mjs +0 -61
- package/dist/middlewares/body.mjs.map +0 -1
- package/dist/middlewares/compression.js +0 -8
- package/dist/middlewares/compression.js.map +0 -1
- package/dist/middlewares/compression.mjs +0 -6
- package/dist/middlewares/compression.mjs.map +0 -1
- package/dist/middlewares/cors.js +0 -51
- package/dist/middlewares/cors.js.map +0 -1
- package/dist/middlewares/cors.mjs +0 -49
- package/dist/middlewares/cors.mjs.map +0 -1
- package/dist/middlewares/errors.js +0 -33
- package/dist/middlewares/errors.js.map +0 -1
- package/dist/middlewares/errors.mjs +0 -33
- package/dist/middlewares/errors.mjs.map +0 -1
- package/dist/middlewares/favicon.js +0 -22
- package/dist/middlewares/favicon.js.map +0 -1
- package/dist/middlewares/favicon.mjs +0 -20
- package/dist/middlewares/favicon.mjs.map +0 -1
- package/dist/middlewares/index.js +0 -34
- package/dist/middlewares/index.js.map +0 -1
- package/dist/middlewares/index.mjs +0 -34
- package/dist/middlewares/index.mjs.map +0 -1
- package/dist/middlewares/ip.js +0 -8
- package/dist/middlewares/ip.js.map +0 -1
- package/dist/middlewares/ip.mjs +0 -6
- package/dist/middlewares/ip.mjs.map +0 -1
- package/dist/middlewares/logger.js +0 -12
- package/dist/middlewares/logger.js.map +0 -1
- package/dist/middlewares/logger.mjs +0 -12
- package/dist/middlewares/logger.mjs.map +0 -1
- package/dist/middlewares/powered-by.js +0 -14
- package/dist/middlewares/powered-by.js.map +0 -1
- package/dist/middlewares/powered-by.mjs +0 -14
- package/dist/middlewares/powered-by.mjs.map +0 -1
- package/dist/middlewares/public.js +0 -34
- package/dist/middlewares/public.js.map +0 -1
- package/dist/middlewares/public.mjs +0 -32
- package/dist/middlewares/public.mjs.map +0 -1
- package/dist/middlewares/query.js +0 -40
- package/dist/middlewares/query.js.map +0 -1
- package/dist/middlewares/query.mjs +0 -38
- package/dist/middlewares/query.mjs.map +0 -1
- package/dist/middlewares/response-time.js +0 -12
- package/dist/middlewares/response-time.js.map +0 -1
- package/dist/middlewares/response-time.mjs +0 -12
- package/dist/middlewares/response-time.mjs.map +0 -1
- package/dist/middlewares/responses.js +0 -15
- package/dist/middlewares/responses.js.map +0 -1
- package/dist/middlewares/responses.mjs +0 -15
- package/dist/middlewares/responses.mjs.map +0 -1
- package/dist/middlewares/security.js +0 -71
- package/dist/middlewares/security.js.map +0 -1
- package/dist/middlewares/security.mjs +0 -69
- package/dist/middlewares/security.mjs.map +0 -1
- package/dist/middlewares/session.js +0 -30
- package/dist/middlewares/session.js.map +0 -1
- package/dist/middlewares/session.mjs +0 -28
- package/dist/middlewares/session.mjs.map +0 -1
- package/dist/registries/apis.js +0 -23
- package/dist/registries/apis.js.map +0 -1
- package/dist/registries/apis.mjs +0 -24
- package/dist/registries/apis.mjs.map +0 -1
- package/dist/registries/components.js +0 -45
- package/dist/registries/components.js.map +0 -1
- package/dist/registries/components.mjs +0 -46
- package/dist/registries/components.mjs.map +0 -1
- package/dist/registries/config.d.ts +0 -4
- package/dist/registries/config.d.ts.map +0 -1
- package/dist/registries/config.js +0 -23
- package/dist/registries/config.js.map +0 -1
- package/dist/registries/config.mjs +0 -22
- package/dist/registries/config.mjs.map +0 -1
- package/dist/registries/content-types.js +0 -71
- package/dist/registries/content-types.js.map +0 -1
- package/dist/registries/content-types.mjs +0 -72
- package/dist/registries/content-types.mjs.map +0 -1
- package/dist/registries/controllers.js +0 -80
- package/dist/registries/controllers.js.map +0 -1
- package/dist/registries/controllers.mjs +0 -81
- package/dist/registries/controllers.mjs.map +0 -1
- package/dist/registries/custom-fields.js +0 -71
- package/dist/registries/custom-fields.js.map +0 -1
- package/dist/registries/custom-fields.mjs +0 -72
- package/dist/registries/custom-fields.mjs.map +0 -1
- package/dist/registries/hooks.js +0 -58
- package/dist/registries/hooks.js.map +0 -1
- package/dist/registries/hooks.mjs +0 -59
- package/dist/registries/hooks.mjs.map +0 -1
- package/dist/registries/middlewares.js +0 -60
- package/dist/registries/middlewares.js.map +0 -1
- package/dist/registries/middlewares.mjs +0 -61
- package/dist/registries/middlewares.mjs.map +0 -1
- package/dist/registries/models.js +0 -16
- package/dist/registries/models.js.map +0 -1
- package/dist/registries/models.mjs +0 -16
- package/dist/registries/models.mjs.map +0 -1
- package/dist/registries/modules.js +0 -39
- package/dist/registries/modules.js.map +0 -1
- package/dist/registries/modules.mjs +0 -40
- package/dist/registries/modules.mjs.map +0 -1
- package/dist/registries/namespace.js +0 -27
- package/dist/registries/namespace.js.map +0 -1
- package/dist/registries/namespace.mjs +0 -27
- package/dist/registries/namespace.mjs.map +0 -1
- package/dist/registries/plugins.js +0 -23
- package/dist/registries/plugins.js.map +0 -1
- package/dist/registries/plugins.mjs +0 -24
- package/dist/registries/plugins.mjs.map +0 -1
- package/dist/registries/policies.js +0 -62
- package/dist/registries/policies.js.map +0 -1
- package/dist/registries/policies.mjs +0 -63
- package/dist/registries/policies.mjs.map +0 -1
- package/dist/registries/sanitizers.js +0 -25
- package/dist/registries/sanitizers.js.map +0 -1
- package/dist/registries/sanitizers.mjs +0 -24
- package/dist/registries/sanitizers.mjs.map +0 -1
- package/dist/registries/services.js +0 -80
- package/dist/registries/services.js.map +0 -1
- package/dist/registries/services.mjs +0 -81
- package/dist/registries/services.mjs.map +0 -1
- package/dist/registries/validators.js +0 -25
- package/dist/registries/validators.js.map +0 -1
- package/dist/registries/validators.mjs +0 -24
- package/dist/registries/validators.mjs.map +0 -1
- package/dist/services/auth/index.js +0 -81
- package/dist/services/auth/index.js.map +0 -1
- package/dist/services/auth/index.mjs +0 -80
- package/dist/services/auth/index.mjs.map +0 -1
- package/dist/services/content-api/index.js +0 -59
- package/dist/services/content-api/index.js.map +0 -1
- package/dist/services/content-api/index.mjs +0 -58
- package/dist/services/content-api/index.mjs.map +0 -1
- package/dist/services/content-api/permissions/engine.js +0 -7
- package/dist/services/content-api/permissions/engine.js.map +0 -1
- package/dist/services/content-api/permissions/engine.mjs +0 -6
- package/dist/services/content-api/permissions/engine.mjs.map +0 -1
- package/dist/services/content-api/permissions/index.js +0 -87
- package/dist/services/content-api/permissions/index.js.map +0 -1
- package/dist/services/content-api/permissions/index.mjs +0 -86
- package/dist/services/content-api/permissions/index.mjs.map +0 -1
- package/dist/services/content-api/permissions/providers/action.js +0 -16
- package/dist/services/content-api/permissions/providers/action.js.map +0 -1
- package/dist/services/content-api/permissions/providers/action.mjs +0 -17
- package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
- package/dist/services/content-api/permissions/providers/condition.js +0 -16
- package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
- package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
- package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
- package/dist/services/core-store.js +0 -107
- package/dist/services/core-store.js.map +0 -1
- package/dist/services/core-store.mjs +0 -107
- package/dist/services/core-store.mjs.map +0 -1
- package/dist/services/cron.js +0 -63
- package/dist/services/cron.js.map +0 -1
- package/dist/services/cron.mjs +0 -64
- package/dist/services/cron.mjs.map +0 -1
- package/dist/services/custom-fields.js +0 -10
- package/dist/services/custom-fields.js.map +0 -1
- package/dist/services/custom-fields.mjs +0 -11
- package/dist/services/custom-fields.mjs.map +0 -1
- package/dist/services/document-service/document-engine.d.ts +0 -8
- package/dist/services/document-service/document-engine.d.ts.map +0 -1
- package/dist/services/document-service/document-engine.js +0 -200
- package/dist/services/document-service/document-engine.js.map +0 -1
- package/dist/services/document-service/document-engine.mjs +0 -201
- package/dist/services/document-service/document-engine.mjs.map +0 -1
- package/dist/services/document-service/document-service.d.ts.map +0 -1
- package/dist/services/document-service/document-service.js +0 -132
- package/dist/services/document-service/document-service.js.map +0 -1
- package/dist/services/document-service/document-service.mjs +0 -132
- package/dist/services/document-service/document-service.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 -50
- package/dist/services/document-service/middlewares/defaults/locales.js.map +0 -1
- package/dist/services/document-service/middlewares/defaults/locales.mjs +0 -50
- 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 +0 -19
- 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/index.js +0 -328
- package/dist/services/entity-service/index.js.map +0 -1
- package/dist/services/entity-service/index.mjs +0 -326
- package/dist/services/entity-service/index.mjs.map +0 -1
- package/dist/services/entity-service/params.d.ts +0 -8
- package/dist/services/entity-service/params.d.ts.map +0 -1
- package/dist/services/entity-service/params.js +0 -8
- package/dist/services/entity-service/params.js.map +0 -1
- package/dist/services/entity-service/params.mjs +0 -8
- package/dist/services/entity-service/params.mjs.map +0 -1
- package/dist/services/entity-validator/blocks-validator.js +0 -107
- package/dist/services/entity-validator/blocks-validator.js.map +0 -1
- package/dist/services/entity-validator/blocks-validator.mjs +0 -108
- package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
- package/dist/services/entity-validator/index.js +0 -322
- package/dist/services/entity-validator/index.js.map +0 -1
- package/dist/services/entity-validator/index.mjs +0 -321
- package/dist/services/entity-validator/index.mjs.map +0 -1
- package/dist/services/entity-validator/validators.js +0 -122
- package/dist/services/entity-validator/validators.js.map +0 -1
- package/dist/services/entity-validator/validators.mjs +0 -120
- package/dist/services/entity-validator/validators.mjs.map +0 -1
- package/dist/services/errors.js +0 -76
- package/dist/services/errors.js.map +0 -1
- package/dist/services/errors.mjs +0 -74
- package/dist/services/errors.mjs.map +0 -1
- package/dist/services/event-hub.js +0 -67
- package/dist/services/event-hub.js.map +0 -1
- package/dist/services/event-hub.mjs +0 -68
- package/dist/services/event-hub.mjs.map +0 -1
- package/dist/services/features.js +0 -17
- package/dist/services/features.js.map +0 -1
- package/dist/services/features.mjs +0 -17
- package/dist/services/features.mjs.map +0 -1
- package/dist/services/fs.js +0 -51
- package/dist/services/fs.js.map +0 -1
- package/dist/services/fs.mjs +0 -49
- package/dist/services/fs.mjs.map +0 -1
- package/dist/services/metrics/admin-user-hash.js +0 -14
- package/dist/services/metrics/admin-user-hash.js.map +0 -1
- package/dist/services/metrics/admin-user-hash.mjs +0 -12
- package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
- package/dist/services/metrics/index.js +0 -45
- package/dist/services/metrics/index.js.map +0 -1
- package/dist/services/metrics/index.mjs +0 -46
- package/dist/services/metrics/index.mjs.map +0 -1
- package/dist/services/metrics/is-truthy.js +0 -9
- package/dist/services/metrics/is-truthy.js.map +0 -1
- package/dist/services/metrics/is-truthy.mjs +0 -8
- package/dist/services/metrics/is-truthy.mjs.map +0 -1
- package/dist/services/metrics/middleware.js +0 -25
- package/dist/services/metrics/middleware.js.map +0 -1
- package/dist/services/metrics/middleware.mjs +0 -26
- package/dist/services/metrics/middleware.mjs.map +0 -1
- package/dist/services/metrics/rate-limiter.js +0 -21
- package/dist/services/metrics/rate-limiter.js.map +0 -1
- package/dist/services/metrics/rate-limiter.mjs +0 -22
- package/dist/services/metrics/rate-limiter.mjs.map +0 -1
- package/dist/services/metrics/sender.js +0 -76
- package/dist/services/metrics/sender.js.map +0 -1
- package/dist/services/metrics/sender.mjs +0 -70
- package/dist/services/metrics/sender.mjs.map +0 -1
- package/dist/services/request-context.js +0 -13
- package/dist/services/request-context.js.map +0 -1
- package/dist/services/request-context.mjs +0 -14
- package/dist/services/request-context.mjs.map +0 -1
- package/dist/services/server/admin-api.js +0 -13
- package/dist/services/server/admin-api.js.map +0 -1
- package/dist/services/server/admin-api.mjs +0 -13
- package/dist/services/server/admin-api.mjs.map +0 -1
- package/dist/services/server/api.js +0 -30
- package/dist/services/server/api.js.map +0 -1
- package/dist/services/server/api.mjs +0 -28
- package/dist/services/server/api.mjs.map +0 -1
- package/dist/services/server/compose-endpoint.js +0 -115
- package/dist/services/server/compose-endpoint.js.map +0 -1
- package/dist/services/server/compose-endpoint.mjs +0 -114
- package/dist/services/server/compose-endpoint.mjs.map +0 -1
- package/dist/services/server/content-api.js +0 -12
- package/dist/services/server/content-api.js.map +0 -1
- package/dist/services/server/content-api.mjs +0 -12
- package/dist/services/server/content-api.mjs.map +0 -1
- package/dist/services/server/http-server.js +0 -50
- package/dist/services/server/http-server.js.map +0 -1
- package/dist/services/server/http-server.mjs +0 -48
- package/dist/services/server/http-server.mjs.map +0 -1
- package/dist/services/server/index.js +0 -88
- package/dist/services/server/index.js.map +0 -1
- package/dist/services/server/index.mjs +0 -86
- package/dist/services/server/index.mjs.map +0 -1
- package/dist/services/server/koa.js +0 -52
- package/dist/services/server/koa.js.map +0 -1
- package/dist/services/server/koa.mjs +0 -48
- package/dist/services/server/koa.mjs.map +0 -1
- package/dist/services/server/middleware.js +0 -92
- package/dist/services/server/middleware.js.map +0 -1
- package/dist/services/server/middleware.mjs +0 -90
- package/dist/services/server/middleware.mjs.map +0 -1
- package/dist/services/server/policy.js +0 -20
- package/dist/services/server/policy.js.map +0 -1
- package/dist/services/server/policy.mjs +0 -20
- package/dist/services/server/policy.mjs.map +0 -1
- package/dist/services/server/register-middlewares.js +0 -72
- package/dist/services/server/register-middlewares.js.map +0 -1
- package/dist/services/server/register-middlewares.mjs +0 -73
- package/dist/services/server/register-middlewares.mjs.map +0 -1
- package/dist/services/server/register-routes.js +0 -76
- package/dist/services/server/register-routes.js.map +0 -1
- package/dist/services/server/register-routes.mjs +0 -75
- package/dist/services/server/register-routes.mjs.map +0 -1
- package/dist/services/server/routing.js +0 -91
- package/dist/services/server/routing.js.map +0 -1
- package/dist/services/server/routing.mjs +0 -89
- package/dist/services/server/routing.mjs.map +0 -1
- package/dist/services/utils/dynamic-zones.js +0 -16
- package/dist/services/utils/dynamic-zones.js.map +0 -1
- package/dist/services/utils/dynamic-zones.mjs +0 -17
- package/dist/services/utils/dynamic-zones.mjs.map +0 -1
- package/dist/services/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/services/webhook-runner.js +0 -133
- package/dist/services/webhook-runner.js.map +0 -1
- package/dist/services/webhook-runner.mjs +0 -131
- package/dist/services/webhook-runner.mjs.map +0 -1
- package/dist/services/webhook-store.js +0 -104
- package/dist/services/webhook-store.js.map +0 -1
- package/dist/services/webhook-store.mjs +0 -104
- package/dist/services/webhook-store.mjs.map +0 -1
- package/dist/services/worker-queue.js +0 -56
- package/dist/services/worker-queue.js.map +0 -1
- package/dist/services/worker-queue.mjs +0 -55
- package/dist/services/worker-queue.mjs.map +0 -1
- package/dist/utils/convert-custom-field-type.js +0 -24
- package/dist/utils/convert-custom-field-type.js.map +0 -1
- package/dist/utils/convert-custom-field-type.mjs +0 -24
- package/dist/utils/convert-custom-field-type.mjs.map +0 -1
- package/dist/utils/cron.js +0 -38
- package/dist/utils/cron.js.map +0 -1
- package/dist/utils/cron.mjs +0 -38
- package/dist/utils/cron.mjs.map +0 -1
- package/dist/utils/fetch.js +0 -20
- package/dist/utils/fetch.js.map +0 -1
- package/dist/utils/fetch.mjs +0 -20
- package/dist/utils/fetch.mjs.map +0 -1
- package/dist/utils/filepath-to-prop-path.js +0 -12
- package/dist/utils/filepath-to-prop-path.js.map +0 -1
- package/dist/utils/filepath-to-prop-path.mjs +0 -10
- package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
- package/dist/utils/get-dirs.d.ts +0 -9
- package/dist/utils/get-dirs.d.ts.map +0 -1
- package/dist/utils/get-dirs.js +0 -30
- package/dist/utils/get-dirs.js.map +0 -1
- package/dist/utils/get-dirs.mjs +0 -30
- package/dist/utils/get-dirs.mjs.map +0 -1
- package/dist/utils/is-initialized.js +0 -16
- package/dist/utils/is-initialized.js.map +0 -1
- package/dist/utils/is-initialized.mjs +0 -16
- package/dist/utils/is-initialized.mjs.map +0 -1
- package/dist/utils/lifecycles.js +0 -9
- package/dist/utils/lifecycles.js.map +0 -1
- package/dist/utils/lifecycles.mjs +0 -9
- package/dist/utils/lifecycles.mjs.map +0 -1
- package/dist/utils/load-config-file.js +0 -45
- package/dist/utils/load-config-file.js.map +0 -1
- package/dist/utils/load-config-file.mjs +0 -42
- package/dist/utils/load-config-file.mjs.map +0 -1
- package/dist/utils/load-files.js +0 -39
- package/dist/utils/load-files.js.map +0 -1
- package/dist/utils/load-files.mjs +0 -35
- package/dist/utils/load-files.mjs.map +0 -1
- package/dist/utils/open-browser.js +0 -11
- package/dist/utils/open-browser.js.map +0 -1
- package/dist/utils/open-browser.mjs +0 -9
- package/dist/utils/open-browser.mjs.map +0 -1
- package/dist/utils/signals.js +0 -17
- package/dist/utils/signals.js.map +0 -1
- package/dist/utils/signals.mjs +0 -17
- package/dist/utils/signals.mjs.map +0 -1
- package/dist/utils/startup-logger.js +0 -81
- package/dist/utils/startup-logger.js.map +0 -1
- package/dist/utils/startup-logger.mjs +0 -77
- package/dist/utils/startup-logger.mjs.map +0 -1
- package/dist/utils/transform-content-types-to-models.js +0 -198
- package/dist/utils/transform-content-types-to-models.js.map +0 -1
- package/dist/utils/transform-content-types-to-models.mjs +0 -196
- package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
- package/dist/utils/update-notifier/index.js +0 -88
- package/dist/utils/update-notifier/index.js.map +0 -1
- package/dist/utils/update-notifier/index.mjs +0 -81
- package/dist/utils/update-notifier/index.mjs.map +0 -1
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import transforms from "./transforms.mjs";
|
|
2
|
-
const applyTransforms = (data, context) => {
|
|
3
|
-
const { contentType } = context;
|
|
4
|
-
const attributeNames = Object.keys(data);
|
|
5
|
-
for (const attributeName of attributeNames) {
|
|
6
|
-
const value = data[attributeName];
|
|
7
|
-
const attribute = contentType.attributes[attributeName];
|
|
8
|
-
if (!attribute) {
|
|
9
|
-
continue;
|
|
10
|
-
}
|
|
11
|
-
const transform = transforms[attribute.type];
|
|
12
|
-
if (transform) {
|
|
13
|
-
const attributeContext = { ...context, attributeName, attribute };
|
|
14
|
-
data[attributeName] = transform(value, attributeContext);
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
return data;
|
|
18
|
-
};
|
|
19
|
-
export {
|
|
20
|
-
applyTransforms
|
|
21
|
-
};
|
|
22
|
-
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../../src/services/entity-service/attributes/index.ts"],"sourcesContent":["import type { Common, Shared, EntityService } from '@strapi/types';\nimport transforms from './transforms';\n\nconst applyTransforms = <TUID extends Common.UID.ContentType>(\n data: EntityService.Params.Data.Input<TUID>,\n context: {\n contentType: Shared.ContentTypes[TUID];\n }\n) => {\n const { contentType } = context;\n\n const attributeNames = Object.keys(data) as Array<keyof typeof data & string>;\n\n for (const attributeName of attributeNames) {\n const value = data[attributeName];\n\n const attribute = contentType.attributes[attributeName];\n\n if (!attribute) {\n continue;\n }\n\n const transform = transforms[attribute.type];\n\n if (transform) {\n const attributeContext = { ...context, attributeName, attribute };\n\n data[attributeName] = transform(value, attributeContext);\n }\n }\n\n return data;\n};\n\nexport { applyTransforms };\n"],"names":[],"mappings":";AAGM,MAAA,kBAAkB,CACtB,MACA,YAGG;AACG,QAAA,EAAE,YAAgB,IAAA;AAElB,QAAA,iBAAiB,OAAO,KAAK,IAAI;AAEvC,aAAW,iBAAiB,gBAAgB;AACpC,UAAA,QAAQ,KAAK,aAAa;AAE1B,UAAA,YAAY,YAAY,WAAW,aAAa;AAEtD,QAAI,CAAC,WAAW;AACd;AAAA,IACF;AAEM,UAAA,YAAY,WAAW,UAAU,IAAI;AAE3C,QAAI,WAAW;AACb,YAAM,mBAAmB,EAAE,GAAG,SAAS,eAAe,UAAU;AAEhE,WAAK,aAAa,IAAI,UAAU,OAAO,gBAAgB;AAAA,IACzD;AAAA,EACF;AAEO,SAAA;AACT;"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import type { Attribute } from '@strapi/types';
|
|
2
|
-
type Transforms = {
|
|
3
|
-
[TKind in Attribute.Kind]?: (value: unknown, context: {
|
|
4
|
-
attribute: Attribute.Any;
|
|
5
|
-
attributeName: string;
|
|
6
|
-
}) => any;
|
|
7
|
-
};
|
|
8
|
-
declare const transforms: Transforms;
|
|
9
|
-
export default transforms;
|
|
10
|
-
//# sourceMappingURL=transforms.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"transforms.d.ts","sourceRoot":"","sources":["../../../../src/services/entity-service/attributes/transforms.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAG/C,KAAK,UAAU,GAAG;KACf,KAAK,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC,EAAE,CAC1B,KAAK,EAAE,OAAO,EACd,OAAO,EAAE;QAAE,SAAS,EAAE,SAAS,CAAC,GAAG,CAAC;QAAC,aAAa,EAAE,MAAM,CAAA;KAAE,KACzD,GAAG;CACT,CAAC;AAEF,QAAA,MAAM,UAAU,EAAE,UAgBjB,CAAC;AAEF,eAAe,UAAU,CAAC"}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const _ = require("lodash/fp");
|
|
3
|
-
const bcrypt = require("bcryptjs");
|
|
4
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
5
|
-
const bcrypt__default = /* @__PURE__ */ _interopDefault(bcrypt);
|
|
6
|
-
const transforms = {
|
|
7
|
-
password(value, context) {
|
|
8
|
-
const { attribute } = context;
|
|
9
|
-
if (attribute.type !== "password") {
|
|
10
|
-
throw new Error("Invalid attribute type");
|
|
11
|
-
}
|
|
12
|
-
if (!_.isString(value) && !(value instanceof Buffer)) {
|
|
13
|
-
return value;
|
|
14
|
-
}
|
|
15
|
-
const rounds = _.toNumber(_.getOr(10, "encryption.rounds", attribute));
|
|
16
|
-
return bcrypt__default.default.hashSync(value.toString(), rounds);
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
module.exports = transforms;
|
|
20
|
-
//# sourceMappingURL=transforms.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"transforms.js","sources":["../../../../src/services/entity-service/attributes/transforms.ts"],"sourcesContent":["import { getOr, toNumber, isString } from 'lodash/fp';\nimport type { Attribute } from '@strapi/types';\nimport bcrypt from 'bcryptjs';\n\ntype Transforms = {\n [TKind in Attribute.Kind]?: (\n value: unknown,\n context: { attribute: Attribute.Any; attributeName: string }\n ) => any;\n};\n\nconst transforms: Transforms = {\n password(value, context) {\n const { attribute } = context;\n\n if (attribute.type !== 'password') {\n throw new Error('Invalid attribute type');\n }\n\n if (!isString(value) && !(value instanceof Buffer)) {\n return value;\n }\n\n const rounds = toNumber(getOr(10, 'encryption.rounds', attribute));\n\n return bcrypt.hashSync(value.toString(), rounds);\n },\n};\n\nexport default transforms;\n"],"names":["isString","toNumber","getOr","bcrypt"],"mappings":";;;;;AAWA,MAAM,aAAyB;AAAA,EAC7B,SAAS,OAAO,SAAS;AACjB,UAAA,EAAE,UAAc,IAAA;AAElB,QAAA,UAAU,SAAS,YAAY;AAC3B,YAAA,IAAI,MAAM,wBAAwB;AAAA,IAC1C;AAEA,QAAI,CAACA,EAAS,SAAA,KAAK,KAAK,EAAE,iBAAiB,SAAS;AAC3C,aAAA;AAAA,IACT;AAEA,UAAM,SAASC,EAAAA,SAASC,EAAA,MAAM,IAAI,qBAAqB,SAAS,CAAC;AAEjE,WAAOC,gBAAAA,QAAO,SAAS,MAAM,YAAY,MAAM;AAAA,EACjD;AACF;;"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { isString, toNumber, getOr } from "lodash/fp";
|
|
2
|
-
import bcrypt from "bcryptjs";
|
|
3
|
-
const transforms = {
|
|
4
|
-
password(value, context) {
|
|
5
|
-
const { attribute } = context;
|
|
6
|
-
if (attribute.type !== "password") {
|
|
7
|
-
throw new Error("Invalid attribute type");
|
|
8
|
-
}
|
|
9
|
-
if (!isString(value) && !(value instanceof Buffer)) {
|
|
10
|
-
return value;
|
|
11
|
-
}
|
|
12
|
-
const rounds = toNumber(getOr(10, "encryption.rounds", attribute));
|
|
13
|
-
return bcrypt.hashSync(value.toString(), rounds);
|
|
14
|
-
}
|
|
15
|
-
};
|
|
16
|
-
export {
|
|
17
|
-
transforms as default
|
|
18
|
-
};
|
|
19
|
-
//# sourceMappingURL=transforms.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"transforms.mjs","sources":["../../../../src/services/entity-service/attributes/transforms.ts"],"sourcesContent":["import { getOr, toNumber, isString } from 'lodash/fp';\nimport type { Attribute } from '@strapi/types';\nimport bcrypt from 'bcryptjs';\n\ntype Transforms = {\n [TKind in Attribute.Kind]?: (\n value: unknown,\n context: { attribute: Attribute.Any; attributeName: string }\n ) => any;\n};\n\nconst transforms: Transforms = {\n password(value, context) {\n const { attribute } = context;\n\n if (attribute.type !== 'password') {\n throw new Error('Invalid attribute type');\n }\n\n if (!isString(value) && !(value instanceof Buffer)) {\n return value;\n }\n\n const rounds = toNumber(getOr(10, 'encryption.rounds', attribute));\n\n return bcrypt.hashSync(value.toString(), rounds);\n },\n};\n\nexport default transforms;\n"],"names":[],"mappings":";;AAWA,MAAM,aAAyB;AAAA,EAC7B,SAAS,OAAO,SAAS;AACjB,UAAA,EAAE,UAAc,IAAA;AAElB,QAAA,UAAU,SAAS,YAAY;AAC3B,YAAA,IAAI,MAAM,wBAAwB;AAAA,IAC1C;AAEA,QAAI,CAAC,SAAS,KAAK,KAAK,EAAE,iBAAiB,SAAS;AAC3C,aAAA;AAAA,IACT;AAEA,UAAM,SAAS,SAAS,MAAM,IAAI,qBAAqB,SAAS,CAAC;AAEjE,WAAO,OAAO,SAAS,MAAM,YAAY,MAAM;AAAA,EACjD;AACF;"}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import type { Attribute, Common, Schema, EntityService } from '@strapi/types';
|
|
2
|
-
type LoadedComponents<TUID extends Common.UID.Schema> = Attribute.GetValues<TUID, Attribute.GetKeysByType<TUID, 'component' | 'dynamiczone'>>;
|
|
3
|
-
type ComponentBody = {
|
|
4
|
-
[key: string]: Attribute.GetValue<Attribute.Component<Common.UID.Component, false> | Attribute.Component<Common.UID.Component, true> | Attribute.DynamicZone>;
|
|
5
|
-
};
|
|
6
|
-
declare function omitComponentData(contentType: Schema.ContentType, data: EntityService.Params.Data.Input<Schema.ContentType['uid']>): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid']>>;
|
|
7
|
-
declare function omitComponentData(contentType: Schema.Component, data: EntityService.Params.Data.Input<Schema.Component['uid']>): Partial<EntityService.Params.Data.Input<Schema.Component['uid']>>;
|
|
8
|
-
declare const createComponents: <TUID extends Common.UID.Schema, TData extends EntityService.Params.Data.Input<TUID>>(uid: TUID, data: TData) => Promise<ComponentBody>;
|
|
9
|
-
declare const getComponents: <TUID extends Common.UID.Schema>(uid: TUID, entity: {
|
|
10
|
-
id: EntityService.Params.Attribute.ID;
|
|
11
|
-
}) => Promise<LoadedComponents<TUID>>;
|
|
12
|
-
declare const updateComponents: <TUID extends Common.UID.Schema, TData extends Partial<EntityService.Params.Data.Input<TUID>>>(uid: TUID, entityToUpdate: {
|
|
13
|
-
id: EntityService.Params.Attribute.ID;
|
|
14
|
-
}, data: TData) => Promise<ComponentBody>;
|
|
15
|
-
declare const deleteComponents: <TUID extends Common.UID.Schema, TEntity extends Attribute.GetValues<TUID, Attribute.GetKeys<TUID>>>(uid: TUID, entityToDelete: TEntity, { loadComponents }?: {
|
|
16
|
-
loadComponents?: boolean | undefined;
|
|
17
|
-
}) => Promise<void>;
|
|
18
|
-
declare const cloneComponents: <TUID extends Common.UID.Schema>(uid: TUID, entityToClone: {
|
|
19
|
-
id: EntityService.Params.Attribute.ID;
|
|
20
|
-
}, data: EntityService.Params.Data.Input<TUID>) => Promise<ComponentBody>;
|
|
21
|
-
declare const deleteComponent: <TUID extends `${string}.${string}`>(uid: TUID, componentToDelete: Attribute.GetValues<TUID, Attribute.GetKeys<TUID>>) => Promise<void>;
|
|
22
|
-
export { omitComponentData, getComponents, createComponents, updateComponents, deleteComponents, deleteComponent, cloneComponents, };
|
|
23
|
-
//# sourceMappingURL=components.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../../src/services/entity-service/components.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAS,aAAa,EAAE,MAAM,eAAe,CAAC;AAGrF,KAAK,gBAAgB,CAAC,IAAI,SAAS,MAAM,CAAC,GAAG,CAAC,MAAM,IAAI,SAAS,CAAC,SAAS,CACzE,IAAI,EACJ,SAAS,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,GAAG,aAAa,CAAC,CAC3D,CAAC;AAMF,KAAK,aAAa,GAAG;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC,QAAQ,CAC7B,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,CAAC,GAChD,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,GAC/C,SAAS,CAAC,WAAW,CACxB,CAAC;CACH,CAAC;AAIF,iBAAS,iBAAiB,CACxB,WAAW,EAAE,MAAM,CAAC,WAAW,EAC/B,IAAI,EAAE,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,GAC/D,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACvE,iBAAS,iBAAiB,CACxB,WAAW,EAAE,MAAM,CAAC,SAAS,EAC7B,IAAI,EAAE,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GAC7D,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAcrE,QAAA,MAAM,gBAAgB,yIAqGrB,CAAC;AAEF,QAAA,MAAM,aAAa,sDAET;IAAE,EAAE,EAAE,cAAc,MAAM,UAAU,CAAC,EAAE,CAAA;CAAE,oCASlD,CAAC;AAMF,QAAA,MAAM,gBAAgB,4HAKJ;IAAE,EAAE,EAAE,cAAc,MAAM,UAAU,CAAC,EAAE,CAAA;CAAE,wCA2F1D,CAAC;AAkGF,QAAA,MAAM,gBAAgB;;mBAkDrB,CAAC;AAEF,QAAA,MAAM,eAAe,6DAEJ;IAAE,EAAE,EAAE,cAAc,MAAM,UAAU,CAAC,EAAE,CAAA;CAAE,wEA4FzD,CAAC;AA6DF,QAAA,MAAM,eAAe,yIAMpB,CAAC;AAyBF,OAAO,EACL,iBAAiB,EACjB,aAAa,EACb,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,EAChB,eAAe,EACf,eAAe,GAChB,CAAC"}
|
|
@@ -1,384 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const _$1 = require("lodash");
|
|
4
|
-
const _ = require("lodash/fp");
|
|
5
|
-
const strapiUtils = require("@strapi/utils");
|
|
6
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
7
|
-
const ___default = /* @__PURE__ */ _interopDefault(_$1);
|
|
8
|
-
const isDialectMySQL = () => strapi.db?.dialect.client === "mysql";
|
|
9
|
-
function omitComponentData(contentType, data) {
|
|
10
|
-
const { attributes } = contentType;
|
|
11
|
-
const componentAttributes = Object.keys(attributes).filter(
|
|
12
|
-
(attributeName) => strapiUtils.contentTypes.isComponentAttribute(attributes[attributeName])
|
|
13
|
-
);
|
|
14
|
-
return _.omit(componentAttributes, data);
|
|
15
|
-
}
|
|
16
|
-
const createComponents = async (uid, data) => {
|
|
17
|
-
const { attributes = {} } = strapi.getModel(uid);
|
|
18
|
-
const componentBody = {};
|
|
19
|
-
const attributeNames = Object.keys(attributes);
|
|
20
|
-
for (const attributeName of attributeNames) {
|
|
21
|
-
const attribute = attributes[attributeName];
|
|
22
|
-
if (!_.has(attributeName, data) || !strapiUtils.contentTypes.isComponentAttribute(attribute)) {
|
|
23
|
-
continue;
|
|
24
|
-
}
|
|
25
|
-
if (attribute.type === "component") {
|
|
26
|
-
const { component: componentUID, repeatable = false } = attribute;
|
|
27
|
-
const componentValue = data[attributeName];
|
|
28
|
-
if (componentValue === null) {
|
|
29
|
-
continue;
|
|
30
|
-
}
|
|
31
|
-
if (repeatable === true) {
|
|
32
|
-
if (!Array.isArray(componentValue)) {
|
|
33
|
-
throw new Error("Expected an array to create repeatable component");
|
|
34
|
-
}
|
|
35
|
-
const components = await strapiUtils.mapAsync(
|
|
36
|
-
componentValue,
|
|
37
|
-
(value) => createComponent(componentUID, value),
|
|
38
|
-
{ concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
|
|
39
|
-
);
|
|
40
|
-
componentBody[attributeName] = components.map(({ id }) => {
|
|
41
|
-
return {
|
|
42
|
-
id,
|
|
43
|
-
__pivot: {
|
|
44
|
-
field: attributeName,
|
|
45
|
-
component_type: componentUID
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
});
|
|
49
|
-
} else {
|
|
50
|
-
const component = await createComponent(
|
|
51
|
-
componentUID,
|
|
52
|
-
componentValue
|
|
53
|
-
);
|
|
54
|
-
componentBody[attributeName] = {
|
|
55
|
-
id: component.id,
|
|
56
|
-
__pivot: {
|
|
57
|
-
field: attributeName,
|
|
58
|
-
component_type: componentUID
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
}
|
|
62
|
-
continue;
|
|
63
|
-
}
|
|
64
|
-
if (attribute.type === "dynamiczone") {
|
|
65
|
-
const dynamiczoneValues = data[attributeName];
|
|
66
|
-
if (!Array.isArray(dynamiczoneValues)) {
|
|
67
|
-
throw new Error("Expected an array to create repeatable component");
|
|
68
|
-
}
|
|
69
|
-
const createDynamicZoneComponents = async (value) => {
|
|
70
|
-
const { id } = await createComponent(value.__component, value);
|
|
71
|
-
return {
|
|
72
|
-
id,
|
|
73
|
-
__component: value.__component,
|
|
74
|
-
__pivot: {
|
|
75
|
-
field: attributeName
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
};
|
|
79
|
-
componentBody[attributeName] = await strapiUtils.mapAsync(
|
|
80
|
-
dynamiczoneValues,
|
|
81
|
-
createDynamicZoneComponents,
|
|
82
|
-
{ concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
|
|
83
|
-
);
|
|
84
|
-
continue;
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
return componentBody;
|
|
88
|
-
};
|
|
89
|
-
const getComponents = async (uid, entity) => {
|
|
90
|
-
const componentAttributes = strapiUtils.contentTypes.getComponentAttributes(strapi.getModel(uid));
|
|
91
|
-
if (___default.default.isEmpty(componentAttributes)) {
|
|
92
|
-
return {};
|
|
93
|
-
}
|
|
94
|
-
return strapi.query(uid).load(entity, componentAttributes);
|
|
95
|
-
};
|
|
96
|
-
const updateComponents = async (uid, entityToUpdate, data) => {
|
|
97
|
-
const { attributes = {} } = strapi.getModel(uid);
|
|
98
|
-
const componentBody = {};
|
|
99
|
-
for (const attributeName of Object.keys(attributes)) {
|
|
100
|
-
const attribute = attributes[attributeName];
|
|
101
|
-
if (!_.has(attributeName, data)) {
|
|
102
|
-
continue;
|
|
103
|
-
}
|
|
104
|
-
if (attribute.type === "component") {
|
|
105
|
-
const { component: componentUID, repeatable = false } = attribute;
|
|
106
|
-
const componentValue = data[attributeName];
|
|
107
|
-
await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);
|
|
108
|
-
if (repeatable === true) {
|
|
109
|
-
if (!Array.isArray(componentValue)) {
|
|
110
|
-
throw new Error("Expected an array to create repeatable component");
|
|
111
|
-
}
|
|
112
|
-
const components = await strapiUtils.mapAsync(
|
|
113
|
-
componentValue,
|
|
114
|
-
(value) => updateOrCreateComponent(componentUID, value),
|
|
115
|
-
{ concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
|
|
116
|
-
);
|
|
117
|
-
componentBody[attributeName] = components.filter(___default.default.negate(___default.default.isNil)).map(({ id }) => {
|
|
118
|
-
return {
|
|
119
|
-
id,
|
|
120
|
-
__pivot: {
|
|
121
|
-
field: attributeName,
|
|
122
|
-
component_type: componentUID
|
|
123
|
-
}
|
|
124
|
-
};
|
|
125
|
-
});
|
|
126
|
-
} else {
|
|
127
|
-
const component = await updateOrCreateComponent(componentUID, componentValue);
|
|
128
|
-
componentBody[attributeName] = component && {
|
|
129
|
-
id: component.id,
|
|
130
|
-
__pivot: {
|
|
131
|
-
field: attributeName,
|
|
132
|
-
component_type: componentUID
|
|
133
|
-
}
|
|
134
|
-
};
|
|
135
|
-
}
|
|
136
|
-
continue;
|
|
137
|
-
}
|
|
138
|
-
if (attribute.type === "dynamiczone") {
|
|
139
|
-
const dynamiczoneValues = data[attributeName];
|
|
140
|
-
await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);
|
|
141
|
-
if (!Array.isArray(dynamiczoneValues)) {
|
|
142
|
-
throw new Error("Expected an array to create repeatable component");
|
|
143
|
-
}
|
|
144
|
-
componentBody[attributeName] = await strapiUtils.mapAsync(
|
|
145
|
-
dynamiczoneValues,
|
|
146
|
-
async (value) => {
|
|
147
|
-
const { id } = await updateOrCreateComponent(value.__component, value);
|
|
148
|
-
return {
|
|
149
|
-
id,
|
|
150
|
-
__component: value.__component,
|
|
151
|
-
__pivot: {
|
|
152
|
-
field: attributeName
|
|
153
|
-
}
|
|
154
|
-
};
|
|
155
|
-
},
|
|
156
|
-
{ concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
|
|
157
|
-
);
|
|
158
|
-
continue;
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
return componentBody;
|
|
162
|
-
};
|
|
163
|
-
const pickStringifiedId = ({
|
|
164
|
-
id
|
|
165
|
-
}) => {
|
|
166
|
-
if (typeof id === "string") {
|
|
167
|
-
return id;
|
|
168
|
-
}
|
|
169
|
-
return `${id}`;
|
|
170
|
-
};
|
|
171
|
-
const deleteOldComponents = async (uid, componentUID, entityToUpdate, attributeName, componentValue) => {
|
|
172
|
-
const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
|
|
173
|
-
const idsToKeep = ___default.default.castArray(componentValue).filter(_.has("id")).map(pickStringifiedId);
|
|
174
|
-
const allIds = ___default.default.castArray(previousValue).filter(_.has("id")).map(pickStringifiedId);
|
|
175
|
-
idsToKeep.forEach((id) => {
|
|
176
|
-
if (!allIds.includes(id)) {
|
|
177
|
-
throw new strapiUtils.errors.ApplicationError(
|
|
178
|
-
`Some of the provided components in ${attributeName} are not related to the entity`
|
|
179
|
-
);
|
|
180
|
-
}
|
|
181
|
-
});
|
|
182
|
-
const idsToDelete = ___default.default.difference(allIds, idsToKeep);
|
|
183
|
-
if (idsToDelete.length > 0) {
|
|
184
|
-
for (const idToDelete of idsToDelete) {
|
|
185
|
-
await deleteComponent(componentUID, { id: idToDelete });
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
};
|
|
189
|
-
const deleteOldDZComponents = async (uid, entityToUpdate, attributeName, dynamiczoneValues) => {
|
|
190
|
-
const previousValue = await strapi.query(uid).load(entityToUpdate, attributeName);
|
|
191
|
-
const idsToKeep = ___default.default.castArray(dynamiczoneValues).filter(_.has("id")).map((v) => ({
|
|
192
|
-
id: pickStringifiedId(v),
|
|
193
|
-
__component: v.__component
|
|
194
|
-
}));
|
|
195
|
-
const allIds = ___default.default.castArray(previousValue).filter(_.has("id")).map((v) => ({
|
|
196
|
-
id: pickStringifiedId(v),
|
|
197
|
-
__component: v.__component
|
|
198
|
-
}));
|
|
199
|
-
idsToKeep.forEach(({ id, __component }) => {
|
|
200
|
-
if (!allIds.find((el) => el.id === id && el.__component === __component)) {
|
|
201
|
-
const err = new Error(
|
|
202
|
-
`Some of the provided components in ${attributeName} are not related to the entity`
|
|
203
|
-
);
|
|
204
|
-
Object.assign(err, { status: 400 });
|
|
205
|
-
throw err;
|
|
206
|
-
}
|
|
207
|
-
});
|
|
208
|
-
const idsToDelete = allIds.reduce((acc, { id, __component }) => {
|
|
209
|
-
if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {
|
|
210
|
-
acc.push({ id, __component });
|
|
211
|
-
}
|
|
212
|
-
return acc;
|
|
213
|
-
}, []);
|
|
214
|
-
if (idsToDelete.length > 0) {
|
|
215
|
-
for (const idToDelete of idsToDelete) {
|
|
216
|
-
const { id, __component } = idToDelete;
|
|
217
|
-
await deleteComponent(__component, { id });
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
};
|
|
221
|
-
const deleteComponents = async (uid, entityToDelete, { loadComponents = true } = {}) => {
|
|
222
|
-
const { attributes = {} } = strapi.getModel(uid);
|
|
223
|
-
const attributeNames = Object.keys(attributes);
|
|
224
|
-
for (const attributeName of attributeNames) {
|
|
225
|
-
const attribute = attributes[attributeName];
|
|
226
|
-
if (attribute.type === "component" || attribute.type === "dynamiczone") {
|
|
227
|
-
let value;
|
|
228
|
-
if (loadComponents) {
|
|
229
|
-
value = await strapi.query(uid).load(entityToDelete, attributeName);
|
|
230
|
-
} else {
|
|
231
|
-
value = entityToDelete[attributeName];
|
|
232
|
-
}
|
|
233
|
-
if (!value) {
|
|
234
|
-
continue;
|
|
235
|
-
}
|
|
236
|
-
if (attribute.type === "component") {
|
|
237
|
-
const { component: componentUID } = attribute;
|
|
238
|
-
await strapiUtils.mapAsync(
|
|
239
|
-
___default.default.castArray(value),
|
|
240
|
-
(subValue) => deleteComponent(componentUID, subValue),
|
|
241
|
-
{
|
|
242
|
-
concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity
|
|
243
|
-
}
|
|
244
|
-
);
|
|
245
|
-
} else {
|
|
246
|
-
await strapiUtils.mapAsync(
|
|
247
|
-
___default.default.castArray(value),
|
|
248
|
-
(subValue) => deleteComponent(subValue.__component, subValue),
|
|
249
|
-
{ concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }
|
|
250
|
-
);
|
|
251
|
-
}
|
|
252
|
-
continue;
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
};
|
|
256
|
-
const cloneComponents = async (uid, entityToClone, data) => {
|
|
257
|
-
const { attributes = {} } = strapi.getModel(uid);
|
|
258
|
-
const componentBody = {};
|
|
259
|
-
const componentData = await getComponents(uid, entityToClone);
|
|
260
|
-
for (const attributeName of Object.keys(attributes)) {
|
|
261
|
-
const attribute = attributes[attributeName];
|
|
262
|
-
if (!_.has(attributeName, data) && !_.has(attributeName, componentData)) {
|
|
263
|
-
continue;
|
|
264
|
-
}
|
|
265
|
-
if (attribute.type === "component") {
|
|
266
|
-
const { component: componentUID, repeatable = false } = attribute;
|
|
267
|
-
const componentValue = attributeName in data ? data[attributeName] : componentData[attributeName];
|
|
268
|
-
if (componentValue === null) {
|
|
269
|
-
continue;
|
|
270
|
-
}
|
|
271
|
-
if (repeatable === true) {
|
|
272
|
-
if (!Array.isArray(componentValue)) {
|
|
273
|
-
throw new Error("Expected an array to create repeatable component");
|
|
274
|
-
}
|
|
275
|
-
const components = await strapiUtils.mapAsync(
|
|
276
|
-
componentValue,
|
|
277
|
-
(value) => cloneComponent(componentUID, value),
|
|
278
|
-
{ concurrency: isDialectMySQL() ? 1 : Infinity }
|
|
279
|
-
);
|
|
280
|
-
componentBody[attributeName] = components.filter(___default.default.negate(___default.default.isNil)).map(({ id }) => {
|
|
281
|
-
return {
|
|
282
|
-
id,
|
|
283
|
-
__pivot: {
|
|
284
|
-
field: attributeName,
|
|
285
|
-
component_type: componentUID
|
|
286
|
-
}
|
|
287
|
-
};
|
|
288
|
-
});
|
|
289
|
-
} else {
|
|
290
|
-
const component = await cloneComponent(componentUID, componentValue);
|
|
291
|
-
componentBody[attributeName] = component && {
|
|
292
|
-
id: component.id,
|
|
293
|
-
__pivot: {
|
|
294
|
-
field: attributeName,
|
|
295
|
-
component_type: componentUID
|
|
296
|
-
}
|
|
297
|
-
};
|
|
298
|
-
}
|
|
299
|
-
continue;
|
|
300
|
-
}
|
|
301
|
-
if (attribute.type === "dynamiczone") {
|
|
302
|
-
const dynamiczoneValues = _.has(attributeName, data) ? data[attributeName] : componentData[attributeName];
|
|
303
|
-
if (!Array.isArray(dynamiczoneValues)) {
|
|
304
|
-
throw new Error("Expected an array to create repeatable component");
|
|
305
|
-
}
|
|
306
|
-
componentBody[attributeName] = await strapiUtils.mapAsync(
|
|
307
|
-
dynamiczoneValues,
|
|
308
|
-
async (value) => {
|
|
309
|
-
const { id } = await cloneComponent(value.__component, value);
|
|
310
|
-
return {
|
|
311
|
-
id,
|
|
312
|
-
__component: value.__component,
|
|
313
|
-
__pivot: {
|
|
314
|
-
field: attributeName
|
|
315
|
-
}
|
|
316
|
-
};
|
|
317
|
-
},
|
|
318
|
-
{ concurrency: isDialectMySQL() ? 1 : Infinity }
|
|
319
|
-
);
|
|
320
|
-
continue;
|
|
321
|
-
}
|
|
322
|
-
}
|
|
323
|
-
return componentBody;
|
|
324
|
-
};
|
|
325
|
-
const createComponent = async (uid, data) => {
|
|
326
|
-
const model = strapi.getModel(uid);
|
|
327
|
-
const componentData = await createComponents(uid, data);
|
|
328
|
-
const transform = _.pipe(
|
|
329
|
-
// Make sure we don't save the component with a pre-defined ID
|
|
330
|
-
_.omit("id"),
|
|
331
|
-
// Remove the component data from the original data object ...
|
|
332
|
-
(payload) => omitComponentData(model, payload),
|
|
333
|
-
// ... and assign the newly created component instead
|
|
334
|
-
_.assign(componentData)
|
|
335
|
-
);
|
|
336
|
-
return strapi.query(uid).create({ data: transform(data) });
|
|
337
|
-
};
|
|
338
|
-
const updateComponent = async (uid, componentToUpdate, data) => {
|
|
339
|
-
const model = strapi.getModel(uid);
|
|
340
|
-
const componentData = await updateComponents(uid, componentToUpdate, data);
|
|
341
|
-
return strapi.query(uid).update({
|
|
342
|
-
where: {
|
|
343
|
-
id: componentToUpdate.id
|
|
344
|
-
},
|
|
345
|
-
data: Object.assign(omitComponentData(model, data), componentData)
|
|
346
|
-
});
|
|
347
|
-
};
|
|
348
|
-
const updateOrCreateComponent = (componentUID, value) => {
|
|
349
|
-
if (value === null) {
|
|
350
|
-
return null;
|
|
351
|
-
}
|
|
352
|
-
if ("id" in value && typeof value.id !== "undefined") {
|
|
353
|
-
return updateComponent(componentUID, { id: value.id }, value);
|
|
354
|
-
}
|
|
355
|
-
return createComponent(componentUID, value);
|
|
356
|
-
};
|
|
357
|
-
const deleteComponent = async (uid, componentToDelete) => {
|
|
358
|
-
await deleteComponents(uid, componentToDelete);
|
|
359
|
-
await strapi.query(uid).delete({ where: { id: componentToDelete.id } });
|
|
360
|
-
};
|
|
361
|
-
const cloneComponent = async (uid, data) => {
|
|
362
|
-
const model = strapi.getModel(uid);
|
|
363
|
-
if (!("id" in data) || typeof data.id === "undefined") {
|
|
364
|
-
return createComponent(uid, data);
|
|
365
|
-
}
|
|
366
|
-
const componentData = await cloneComponents(uid, { id: data.id }, data);
|
|
367
|
-
const transform = _.pipe(
|
|
368
|
-
// Make sure we don't save the component with a pre-defined ID
|
|
369
|
-
_.omit("id"),
|
|
370
|
-
// Remove the component data from the original data object ...
|
|
371
|
-
(payload) => omitComponentData(model, payload),
|
|
372
|
-
// ... and assign the newly created component instead
|
|
373
|
-
_.assign(componentData)
|
|
374
|
-
);
|
|
375
|
-
return strapi.query(uid).clone(data.id, { data: transform(data) });
|
|
376
|
-
};
|
|
377
|
-
exports.cloneComponents = cloneComponents;
|
|
378
|
-
exports.createComponents = createComponents;
|
|
379
|
-
exports.deleteComponent = deleteComponent;
|
|
380
|
-
exports.deleteComponents = deleteComponents;
|
|
381
|
-
exports.getComponents = getComponents;
|
|
382
|
-
exports.omitComponentData = omitComponentData;
|
|
383
|
-
exports.updateComponents = updateComponents;
|
|
384
|
-
//# sourceMappingURL=components.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"components.js","sources":["../../../src/services/entity-service/components.ts"],"sourcesContent":["import _ from 'lodash';\nimport { has, omit, pipe, assign } from 'lodash/fp';\nimport type { Attribute, Common, Schema, Utils, EntityService } from '@strapi/types';\nimport { contentTypes as contentTypesUtils, mapAsync, errors } from '@strapi/utils';\n\ntype LoadedComponents<TUID extends Common.UID.Schema> = Attribute.GetValues<\n TUID,\n Attribute.GetKeysByType<TUID, 'component' | 'dynamiczone'>\n>;\n\ntype ComponentValue = Attribute.GetValue<\n Attribute.Component<Common.UID.Component, false> | Attribute.Component<Common.UID.Component, true>\n>;\n\ntype ComponentBody = {\n [key: string]: Attribute.GetValue<\n | Attribute.Component<Common.UID.Component, false>\n | Attribute.Component<Common.UID.Component, true>\n | Attribute.DynamicZone\n >;\n};\n\nconst isDialectMySQL = () => strapi.db?.dialect.client === 'mysql';\n\nfunction omitComponentData(\n contentType: Schema.ContentType,\n data: EntityService.Params.Data.Input<Schema.ContentType['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid']>>;\nfunction omitComponentData(\n contentType: Schema.Component,\n data: EntityService.Params.Data.Input<Schema.Component['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.Component['uid']>>;\nfunction omitComponentData(\n contentType: Schema.ContentType | Schema.Component,\n data: EntityService.Params.Data.Input<Schema.ContentType['uid'] | Schema.Component['uid']>\n): Partial<EntityService.Params.Data.Input<Schema.ContentType['uid'] | Schema.Component['uid']>> {\n const { attributes } = contentType;\n const componentAttributes = Object.keys(attributes).filter((attributeName) =>\n contentTypesUtils.isComponentAttribute(attributes[attributeName])\n );\n\n return omit(componentAttributes, data);\n}\n\n// NOTE: we could generalize the logic to allow CRUD of relation directly in the DB layer\nconst createComponents = async <\n TUID extends Common.UID.Schema,\n TData extends EntityService.Params.Data.Input<TUID>\n>(\n uid: TUID,\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data) || !contentTypesUtils.isComponentAttribute(attribute)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[attributeName as keyof TData];\n\n if (componentValue === null) {\n continue;\n }\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await mapAsync(\n componentValue,\n (value: any) => createComponent(componentUID, value),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\n\n componentBody[attributeName] = components.map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await createComponent(\n componentUID,\n componentValue as EntityService.Params.Data.Input<Common.UID.Component>\n );\n componentBody[attributeName] = {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as EntityService.Params.Attribute.GetValue<Attribute.DynamicZone>;\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n const createDynamicZoneComponents = async (\n value: Utils.Array.Values<typeof dynamiczoneValues>\n ) => {\n const { id } = await createComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n };\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await mapAsync(\n dynamiczoneValues,\n createDynamicZoneComponents,\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst getComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entity: { id: EntityService.Params.Attribute.ID }\n): Promise<LoadedComponents<TUID>> => {\n const componentAttributes = contentTypesUtils.getComponentAttributes(strapi.getModel(uid));\n\n if (_.isEmpty(componentAttributes)) {\n return {} as LoadedComponents<TUID>;\n }\n\n return strapi.query(uid).load(entity, componentAttributes) as Promise<LoadedComponents<TUID>>;\n};\n\n/*\n delete old components\n create or update\n*/\nconst updateComponents = async <\n TUID extends Common.UID.Schema,\n TData extends Partial<EntityService.Params.Data.Input<TUID>>\n>(\n uid: TUID,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n data: TData\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n if (!has(attributeName, data)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = data[\n attributeName as keyof TData\n ] as Attribute.GetValue<Attribute.Component>;\n\n await deleteOldComponents(uid, componentUID, entityToUpdate, attributeName, componentValue);\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await mapAsync(\n componentValue,\n (value: any) => updateOrCreateComponent(componentUID, value),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await updateOrCreateComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = data[\n attributeName as keyof TData\n ] as Attribute.GetValue<Attribute.DynamicZone>;\n\n await deleteOldDZComponents(uid, entityToUpdate, attributeName, dynamiczoneValues);\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await mapAsync(\n dynamiczoneValues,\n async (value: any) => {\n const { id } = await updateOrCreateComponent(value.__component, value);\n\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n },\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n\n continue;\n }\n }\n\n return componentBody;\n};\n\nconst pickStringifiedId = ({\n id,\n}: {\n id: EntityService.Params.Attribute.ID;\n}): EntityService.Params.Attribute.ID & string => {\n if (typeof id === 'string') {\n return id;\n }\n\n return `${id}`;\n};\n\nconst deleteOldComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n componentUID: Common.UID.Component,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n attributeName: string,\n componentValue: Attribute.GetValue<Attribute.Component>\n) => {\n const previousValue = (await strapi\n .query(uid)\n .load(entityToUpdate, attributeName)) as ComponentValue;\n\n const idsToKeep = _.castArray(componentValue).filter(has('id')).map(pickStringifiedId);\n const allIds = _.castArray(previousValue).filter(has('id')).map(pickStringifiedId);\n\n idsToKeep.forEach((id) => {\n if (!allIds.includes(id)) {\n throw new errors.ApplicationError(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n }\n });\n\n const idsToDelete = _.difference(allIds, idsToKeep);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n await deleteComponent(componentUID, { id: idToDelete });\n }\n }\n};\n\nconst deleteOldDZComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entityToUpdate: { id: EntityService.Params.Attribute.ID },\n attributeName: string,\n dynamiczoneValues: Attribute.GetValue<Attribute.DynamicZone>\n) => {\n const previousValue = (await strapi\n .query(uid)\n .load(entityToUpdate, attributeName)) as Attribute.GetValue<Attribute.DynamicZone>;\n\n const idsToKeep = _.castArray(dynamiczoneValues)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n const allIds = _.castArray(previousValue)\n .filter(has('id'))\n .map((v) => ({\n id: pickStringifiedId(v),\n __component: v.__component,\n }));\n\n idsToKeep.forEach(({ id, __component }) => {\n if (!allIds.find((el) => el.id === id && el.__component === __component)) {\n const err = new Error(\n `Some of the provided components in ${attributeName} are not related to the entity`\n );\n\n Object.assign(err, { status: 400 });\n throw err;\n }\n });\n\n type IdsToDelete = Attribute.GetValue<Attribute.DynamicZone>;\n\n const idsToDelete = allIds.reduce((acc, { id, __component }) => {\n if (!idsToKeep.find((el) => el.id === id && el.__component === __component)) {\n acc.push({ id, __component });\n }\n\n return acc;\n }, [] as IdsToDelete);\n\n if (idsToDelete.length > 0) {\n for (const idToDelete of idsToDelete) {\n const { id, __component } = idToDelete;\n await deleteComponent(__component, { id });\n }\n }\n};\n\nconst deleteComponents = async <\n TUID extends Common.UID.Schema,\n TEntity extends Attribute.GetValues<TUID>\n>(\n uid: TUID,\n entityToDelete: TEntity,\n { loadComponents = true } = {}\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const attributeNames = Object.keys(attributes);\n\n for (const attributeName of attributeNames) {\n const attribute = attributes[attributeName];\n\n if (attribute.type === 'component' || attribute.type === 'dynamiczone') {\n let value;\n if (loadComponents) {\n value = await strapi.query(uid).load(entityToDelete, attributeName);\n } else {\n value = entityToDelete[attributeName as keyof TEntity];\n }\n\n if (!value) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID } = attribute;\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await mapAsync(\n _.castArray(value),\n (subValue: any) => deleteComponent(componentUID, subValue),\n {\n concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity,\n }\n );\n } else {\n // delete dynamic zone components\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n await mapAsync(\n _.castArray(value),\n (subValue: any) => deleteComponent(subValue.__component, subValue),\n { concurrency: isDialectMySQL() && !strapi.db?.inTransaction() ? 1 : Infinity }\n );\n }\n\n continue;\n }\n }\n};\n\nconst cloneComponents = async <TUID extends Common.UID.Schema>(\n uid: TUID,\n entityToClone: { id: EntityService.Params.Attribute.ID },\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const { attributes = {} } = strapi.getModel(uid);\n\n const componentBody: ComponentBody = {};\n const componentData = await getComponents(uid, entityToClone);\n\n for (const attributeName of Object.keys(attributes)) {\n const attribute = attributes[attributeName];\n\n // If the attribute is not set or on the component to clone, skip it\n if (!has(attributeName, data) && !has(attributeName, componentData)) {\n continue;\n }\n\n if (attribute.type === 'component') {\n const { component: componentUID, repeatable = false } = attribute;\n\n const componentValue = (\n attributeName in data\n ? data[attributeName as keyof typeof data]\n : componentData[attributeName as keyof typeof componentData]\n ) as ComponentValue;\n\n if (componentValue === null) {\n continue;\n }\n\n if (repeatable === true) {\n if (!Array.isArray(componentValue)) {\n throw new Error('Expected an array to create repeatable component');\n }\n\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n const components = (await mapAsync(\n componentValue,\n (value: any) => cloneComponent(componentUID, value),\n { concurrency: isDialectMySQL() ? 1 : Infinity }\n )) as Attribute.GetValue<Attribute.Component<Common.UID.Component, true>>;\n\n componentBody[attributeName] = components.filter(_.negate(_.isNil)).map(({ id }) => {\n return {\n id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n });\n } else {\n const component = await cloneComponent(componentUID, componentValue);\n componentBody[attributeName] = component && {\n id: component.id,\n __pivot: {\n field: attributeName,\n component_type: componentUID,\n },\n };\n }\n\n continue;\n }\n\n if (attribute.type === 'dynamiczone') {\n const dynamiczoneValues = has(attributeName, data)\n ? data[attributeName as keyof typeof data]\n : componentData[attributeName as keyof typeof componentData];\n\n if (!Array.isArray(dynamiczoneValues)) {\n throw new Error('Expected an array to create repeatable component');\n }\n // MySQL/MariaDB can cause deadlocks here if concurrency higher than 1\n componentBody[attributeName] = await mapAsync(\n dynamiczoneValues,\n async (value: any) => {\n const { id } = await cloneComponent(value.__component, value);\n return {\n id,\n __component: value.__component,\n __pivot: {\n field: attributeName,\n },\n };\n },\n { concurrency: isDialectMySQL() ? 1 : Infinity }\n );\n continue;\n }\n }\n\n return componentBody;\n};\n/** *************************\n Component queries\n************************** */\n\n// components can have nested compos so this must be recursive\nconst createComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await createComponents(uid, data);\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n // Remove the component data from the original data object ...\n (payload) => omitComponentData(model, payload),\n // ... and assign the newly created component instead\n assign(componentData)\n );\n\n return strapi.query(uid).create({ data: transform(data) });\n};\n\n// components can have nested compos so this must be recursive\nconst updateComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n componentToUpdate: { id: EntityService.Params.Attribute.ID },\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n const componentData = await updateComponents(uid, componentToUpdate, data);\n\n return strapi.query(uid).update({\n where: {\n id: componentToUpdate.id,\n },\n data: Object.assign(omitComponentData(model, data), componentData),\n });\n};\n\nconst updateOrCreateComponent = <TUID extends Common.UID.Component>(\n componentUID: TUID,\n value: EntityService.Params.Data.Input<TUID>\n) => {\n if (value === null) {\n return null;\n }\n\n // update\n if ('id' in value && typeof value.id !== 'undefined') {\n // TODO: verify the compo is associated with the entity\n return updateComponent(componentUID, { id: value.id }, value);\n }\n\n // create\n return createComponent(componentUID, value);\n};\n\nconst deleteComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n componentToDelete: Attribute.GetValues<TUID>\n) => {\n await deleteComponents(uid, componentToDelete);\n await strapi.query(uid).delete({ where: { id: componentToDelete.id } });\n};\n\nconst cloneComponent = async <TUID extends Common.UID.Component>(\n uid: TUID,\n data: EntityService.Params.Data.Input<TUID>\n) => {\n const model = strapi.getModel(uid);\n\n if (!('id' in data) || typeof data.id === 'undefined') {\n return createComponent(uid, data);\n }\n\n const componentData = await cloneComponents(uid, { id: data.id }, data);\n const transform = pipe(\n // Make sure we don't save the component with a pre-defined ID\n omit('id'),\n // Remove the component data from the original data object ...\n (payload) => omitComponentData(model, payload),\n // ... and assign the newly created component instead\n assign(componentData)\n );\n\n return strapi.query(uid).clone(data.id, { data: transform(data) });\n};\n\nexport {\n omitComponentData,\n getComponents,\n createComponents,\n updateComponents,\n deleteComponents,\n deleteComponent,\n cloneComponents,\n};\n"],"names":["contentTypesUtils","omit","has","mapAsync","_","errors","pipe","assign"],"mappings":"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"}
|