@strapi/core 0.0.0-experimental.2363945b79274c79e6505e5a6c3cdec876ed8cec → 0.0.0-experimental.24165c9d5cbc756c03fe23bc491569c77973f5ac
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 +3 -3
- package/dist/core-api/controller/collection-type.d.ts.map +1 -1
- package/dist/core-api/controller/index.d.ts +3 -3
- package/dist/core-api/controller/index.d.ts.map +1 -1
- package/dist/core-api/controller/single-type.d.ts +3 -3
- package/dist/core-api/controller/single-type.d.ts.map +1 -1
- package/dist/core-api/controller/transform.d.ts +2 -2
- package/dist/core-api/controller/transform.d.ts.map +1 -1
- package/dist/core-api/routes/index.d.ts.map +1 -1
- package/dist/core-api/service/collection-type.d.ts +11 -17
- package/dist/core-api/service/collection-type.d.ts.map +1 -1
- package/dist/core-api/service/index.d.ts +3 -3
- package/dist/core-api/service/index.d.ts.map +1 -1
- package/dist/core-api/service/pagination.d.ts +4 -11
- package/dist/core-api/service/pagination.d.ts.map +1 -1
- package/dist/core-api/service/single-type.d.ts +5 -5
- 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 +2 -2
- package/dist/services/document-service/common.d.ts.map +1 -1
- package/dist/services/document-service/components.d.ts +25 -1
- package/dist/services/document-service/components.d.ts.map +1 -1
- package/dist/services/document-service/draft-and-publish.d.ts +9 -23
- package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
- package/dist/services/document-service/entries.d.ts +10 -0
- package/dist/services/document-service/entries.d.ts.map +1 -0
- package/dist/services/document-service/events.d.ts +25 -0
- package/dist/services/document-service/events.d.ts.map +1 -0
- package/dist/services/document-service/index.d.ts +3 -4
- package/dist/services/document-service/index.d.ts.map +1 -1
- package/dist/services/document-service/internationalization.d.ts +5 -5
- package/dist/services/document-service/internationalization.d.ts.map +1 -1
- package/dist/services/document-service/middlewares/errors.d.ts +6 -0
- package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
- package/dist/services/document-service/middlewares/index.d.ts +3 -0
- package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
- package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
- package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
- package/dist/services/document-service/params.d.ts +3 -1
- package/dist/services/document-service/params.d.ts.map +1 -1
- package/dist/services/document-service/repository.d.ts.map +1 -1
- package/dist/services/document-service/transform/data.d.ts.map +1 -1
- package/dist/services/document-service/transform/fields.d.ts +2 -2
- package/dist/services/document-service/transform/fields.d.ts.map +1 -1
- package/dist/services/document-service/transform/id-map.d.ts +4 -4
- package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
- package/dist/services/document-service/transform/id-transform.d.ts +4 -18
- package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
- package/dist/services/document-service/transform/populate.d.ts +5 -2
- package/dist/services/document-service/transform/populate.d.ts.map +1 -1
- package/dist/services/document-service/transform/query.d.ts +5 -0
- package/dist/services/document-service/transform/query.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +9 -5
- package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
- package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/dp.d.ts +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 +6 -6
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
- package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/types.d.ts +10 -1
- package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
- package/dist/services/document-service/transform/types.d.ts +4 -4
- package/dist/services/document-service/transform/types.d.ts.map +1 -1
- package/dist/services/document-service/utils/populate.d.ts +9 -2
- package/dist/services/document-service/utils/populate.d.ts.map +1 -1
- package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
- package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
- package/dist/services/entity-service/index.d.ts +4 -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 +377 -90
- package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
- package/dist/utils/update-notifier/index.d.ts +2 -7
- package/dist/utils/update-notifier/index.d.ts.map +1 -1
- package/package.json +43 -40
- package/dist/Strapi.js +0 -447
- package/dist/Strapi.js.map +0 -1
- package/dist/Strapi.mjs +0 -446
- 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 -81
- package/dist/core-api/controller/collection-type.js.map +0 -1
- package/dist/core-api/controller/collection-type.mjs +0 -81
- package/dist/core-api/controller/collection-type.mjs.map +0 -1
- package/dist/core-api/controller/index.js +0 -52
- package/dist/core-api/controller/index.js.map +0 -1
- package/dist/core-api/controller/index.mjs +0 -52
- package/dist/core-api/controller/index.mjs.map +0 -1
- package/dist/core-api/controller/single-type.js +0 -45
- package/dist/core-api/controller/single-type.js.map +0 -1
- package/dist/core-api/controller/single-type.mjs +0 -45
- package/dist/core-api/controller/single-type.mjs.map +0 -1
- package/dist/core-api/controller/transform.js +0 -79
- package/dist/core-api/controller/transform.js.map +0 -1
- package/dist/core-api/controller/transform.mjs +0 -79
- package/dist/core-api/controller/transform.mjs.map +0 -1
- package/dist/core-api/routes/index.js +0 -67
- package/dist/core-api/routes/index.js.map +0 -1
- package/dist/core-api/routes/index.mjs +0 -67
- package/dist/core-api/routes/index.mjs.map +0 -1
- package/dist/core-api/service/collection-type.js +0 -56
- package/dist/core-api/service/collection-type.js.map +0 -1
- package/dist/core-api/service/collection-type.mjs +0 -56
- package/dist/core-api/service/collection-type.mjs.map +0 -1
- package/dist/core-api/service/core-service.js +0 -12
- package/dist/core-api/service/core-service.js.map +0 -1
- package/dist/core-api/service/core-service.mjs +0 -12
- package/dist/core-api/service/core-service.mjs.map +0 -1
- package/dist/core-api/service/index.js +0 -16
- package/dist/core-api/service/index.js.map +0 -1
- package/dist/core-api/service/index.mjs +0 -16
- package/dist/core-api/service/index.mjs.map +0 -1
- package/dist/core-api/service/pagination.js +0 -78
- package/dist/core-api/service/pagination.js.map +0 -1
- package/dist/core-api/service/pagination.mjs +0 -78
- package/dist/core-api/service/pagination.mjs.map +0 -1
- package/dist/core-api/service/single-type.js +0 -40
- package/dist/core-api/service/single-type.js.map +0 -1
- package/dist/core-api/service/single-type.mjs +0 -40
- 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 -76
- package/dist/factories.js.map +0 -1
- package/dist/factories.mjs +0 -76
- package/dist/factories.mjs.map +0 -1
- package/dist/loaders/admin.js +0 -27
- package/dist/loaders/admin.js.map +0 -1
- package/dist/loaders/admin.mjs +0 -26
- package/dist/loaders/admin.mjs.map +0 -1
- package/dist/loaders/apis.js +0 -137
- package/dist/loaders/apis.js.map +0 -1
- package/dist/loaders/apis.mjs +0 -135
- package/dist/loaders/apis.mjs.map +0 -1
- package/dist/loaders/components.js +0 -38
- package/dist/loaders/components.js.map +0 -1
- package/dist/loaders/components.mjs +0 -37
- package/dist/loaders/components.mjs.map +0 -1
- package/dist/loaders/index.js +0 -26
- package/dist/loaders/index.js.map +0 -1
- package/dist/loaders/index.mjs +0 -26
- package/dist/loaders/index.mjs.map +0 -1
- package/dist/loaders/middlewares.js +0 -31
- package/dist/loaders/middlewares.js.map +0 -1
- package/dist/loaders/middlewares.mjs +0 -30
- package/dist/loaders/middlewares.mjs.map +0 -1
- package/dist/loaders/plugins/get-enabled-plugins.js +0 -111
- package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
- package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -109
- package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
- package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
- package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
- package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
- package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
- package/dist/loaders/plugins/index.js +0 -118
- package/dist/loaders/plugins/index.js.map +0 -1
- package/dist/loaders/plugins/index.mjs +0 -117
- package/dist/loaders/plugins/index.mjs.map +0 -1
- package/dist/loaders/policies.js +0 -25
- package/dist/loaders/policies.js.map +0 -1
- package/dist/loaders/policies.mjs +0 -24
- package/dist/loaders/policies.mjs.map +0 -1
- package/dist/loaders/sanitizers.js +0 -6
- package/dist/loaders/sanitizers.js.map +0 -1
- package/dist/loaders/sanitizers.mjs +0 -7
- package/dist/loaders/sanitizers.mjs.map +0 -1
- package/dist/loaders/src-index.js +0 -33
- package/dist/loaders/src-index.js.map +0 -1
- package/dist/loaders/src-index.mjs +0 -34
- package/dist/loaders/src-index.mjs.map +0 -1
- package/dist/loaders/validators.js +0 -6
- package/dist/loaders/validators.js.map +0 -1
- package/dist/loaders/validators.mjs +0 -7
- package/dist/loaders/validators.mjs.map +0 -1
- package/dist/middlewares/body.js +0 -65
- package/dist/middlewares/body.js.map +0 -1
- package/dist/middlewares/body.mjs +0 -61
- package/dist/middlewares/body.mjs.map +0 -1
- package/dist/middlewares/compression.js +0 -8
- package/dist/middlewares/compression.js.map +0 -1
- package/dist/middlewares/compression.mjs +0 -6
- package/dist/middlewares/compression.mjs.map +0 -1
- package/dist/middlewares/cors.js +0 -51
- package/dist/middlewares/cors.js.map +0 -1
- package/dist/middlewares/cors.mjs +0 -49
- package/dist/middlewares/cors.mjs.map +0 -1
- package/dist/middlewares/errors.js +0 -33
- package/dist/middlewares/errors.js.map +0 -1
- package/dist/middlewares/errors.mjs +0 -33
- package/dist/middlewares/errors.mjs.map +0 -1
- package/dist/middlewares/favicon.js +0 -22
- package/dist/middlewares/favicon.js.map +0 -1
- package/dist/middlewares/favicon.mjs +0 -20
- package/dist/middlewares/favicon.mjs.map +0 -1
- package/dist/middlewares/index.js +0 -34
- package/dist/middlewares/index.js.map +0 -1
- package/dist/middlewares/index.mjs +0 -34
- package/dist/middlewares/index.mjs.map +0 -1
- package/dist/middlewares/ip.js +0 -8
- package/dist/middlewares/ip.js.map +0 -1
- package/dist/middlewares/ip.mjs +0 -6
- package/dist/middlewares/ip.mjs.map +0 -1
- package/dist/middlewares/logger.js +0 -12
- package/dist/middlewares/logger.js.map +0 -1
- package/dist/middlewares/logger.mjs +0 -12
- package/dist/middlewares/logger.mjs.map +0 -1
- package/dist/middlewares/powered-by.js +0 -14
- package/dist/middlewares/powered-by.js.map +0 -1
- package/dist/middlewares/powered-by.mjs +0 -14
- package/dist/middlewares/powered-by.mjs.map +0 -1
- package/dist/middlewares/public.js +0 -34
- package/dist/middlewares/public.js.map +0 -1
- package/dist/middlewares/public.mjs +0 -32
- package/dist/middlewares/public.mjs.map +0 -1
- package/dist/middlewares/query.js +0 -40
- package/dist/middlewares/query.js.map +0 -1
- package/dist/middlewares/query.mjs +0 -38
- package/dist/middlewares/query.mjs.map +0 -1
- package/dist/middlewares/response-time.js +0 -12
- package/dist/middlewares/response-time.js.map +0 -1
- package/dist/middlewares/response-time.mjs +0 -12
- package/dist/middlewares/response-time.mjs.map +0 -1
- package/dist/middlewares/responses.js +0 -15
- package/dist/middlewares/responses.js.map +0 -1
- package/dist/middlewares/responses.mjs +0 -15
- package/dist/middlewares/responses.mjs.map +0 -1
- package/dist/middlewares/security.js +0 -71
- package/dist/middlewares/security.js.map +0 -1
- package/dist/middlewares/security.mjs +0 -69
- package/dist/middlewares/security.mjs.map +0 -1
- package/dist/middlewares/session.js +0 -30
- package/dist/middlewares/session.js.map +0 -1
- package/dist/middlewares/session.mjs +0 -28
- package/dist/middlewares/session.mjs.map +0 -1
- package/dist/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 -70
- package/dist/registries/content-types.js.map +0 -1
- package/dist/registries/content-types.mjs +0 -71
- package/dist/registries/content-types.mjs.map +0 -1
- package/dist/registries/controllers.js +0 -80
- package/dist/registries/controllers.js.map +0 -1
- package/dist/registries/controllers.mjs +0 -81
- package/dist/registries/controllers.mjs.map +0 -1
- package/dist/registries/custom-fields.js +0 -71
- package/dist/registries/custom-fields.js.map +0 -1
- package/dist/registries/custom-fields.mjs +0 -72
- package/dist/registries/custom-fields.mjs.map +0 -1
- package/dist/registries/hooks.js +0 -58
- package/dist/registries/hooks.js.map +0 -1
- package/dist/registries/hooks.mjs +0 -59
- package/dist/registries/hooks.mjs.map +0 -1
- package/dist/registries/middlewares.js +0 -60
- package/dist/registries/middlewares.js.map +0 -1
- package/dist/registries/middlewares.mjs +0 -61
- package/dist/registries/middlewares.mjs.map +0 -1
- package/dist/registries/models.js +0 -16
- package/dist/registries/models.js.map +0 -1
- package/dist/registries/models.mjs +0 -16
- package/dist/registries/models.mjs.map +0 -1
- package/dist/registries/modules.js +0 -39
- package/dist/registries/modules.js.map +0 -1
- package/dist/registries/modules.mjs +0 -40
- package/dist/registries/modules.mjs.map +0 -1
- package/dist/registries/namespace.js +0 -27
- package/dist/registries/namespace.js.map +0 -1
- package/dist/registries/namespace.mjs +0 -27
- package/dist/registries/namespace.mjs.map +0 -1
- package/dist/registries/plugins.js +0 -23
- package/dist/registries/plugins.js.map +0 -1
- package/dist/registries/plugins.mjs +0 -24
- package/dist/registries/plugins.mjs.map +0 -1
- package/dist/registries/policies.js +0 -62
- package/dist/registries/policies.js.map +0 -1
- package/dist/registries/policies.mjs +0 -63
- package/dist/registries/policies.mjs.map +0 -1
- package/dist/registries/sanitizers.js +0 -25
- package/dist/registries/sanitizers.js.map +0 -1
- package/dist/registries/sanitizers.mjs +0 -24
- package/dist/registries/sanitizers.mjs.map +0 -1
- package/dist/registries/services.js +0 -80
- package/dist/registries/services.js.map +0 -1
- package/dist/registries/services.mjs +0 -81
- package/dist/registries/services.mjs.map +0 -1
- package/dist/registries/validators.js +0 -25
- package/dist/registries/validators.js.map +0 -1
- package/dist/registries/validators.mjs +0 -24
- package/dist/registries/validators.mjs.map +0 -1
- package/dist/services/auth/index.js +0 -81
- package/dist/services/auth/index.js.map +0 -1
- package/dist/services/auth/index.mjs +0 -80
- package/dist/services/auth/index.mjs.map +0 -1
- package/dist/services/content-api/index.js +0 -59
- package/dist/services/content-api/index.js.map +0 -1
- package/dist/services/content-api/index.mjs +0 -58
- package/dist/services/content-api/index.mjs.map +0 -1
- package/dist/services/content-api/permissions/engine.js +0 -7
- package/dist/services/content-api/permissions/engine.js.map +0 -1
- package/dist/services/content-api/permissions/engine.mjs +0 -6
- package/dist/services/content-api/permissions/engine.mjs.map +0 -1
- package/dist/services/content-api/permissions/index.js +0 -87
- package/dist/services/content-api/permissions/index.js.map +0 -1
- package/dist/services/content-api/permissions/index.mjs +0 -86
- package/dist/services/content-api/permissions/index.mjs.map +0 -1
- package/dist/services/content-api/permissions/providers/action.js +0 -16
- package/dist/services/content-api/permissions/providers/action.js.map +0 -1
- package/dist/services/content-api/permissions/providers/action.mjs +0 -17
- package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
- package/dist/services/content-api/permissions/providers/condition.js +0 -16
- package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
- package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
- package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
- package/dist/services/core-store.js +0 -107
- package/dist/services/core-store.js.map +0 -1
- package/dist/services/core-store.mjs +0 -107
- package/dist/services/core-store.mjs.map +0 -1
- package/dist/services/cron.js +0 -63
- package/dist/services/cron.js.map +0 -1
- package/dist/services/cron.mjs +0 -64
- package/dist/services/cron.mjs.map +0 -1
- package/dist/services/custom-fields.js +0 -10
- package/dist/services/custom-fields.js.map +0 -1
- package/dist/services/custom-fields.mjs +0 -11
- package/dist/services/custom-fields.mjs.map +0 -1
- package/dist/services/document-service/common.js +0 -7
- package/dist/services/document-service/common.js.map +0 -1
- package/dist/services/document-service/common.mjs +0 -7
- package/dist/services/document-service/common.mjs.map +0 -1
- package/dist/services/document-service/draft-and-publish.js +0 -41
- package/dist/services/document-service/draft-and-publish.js.map +0 -1
- package/dist/services/document-service/draft-and-publish.mjs +0 -41
- package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
- package/dist/services/document-service/index.js +0 -22
- package/dist/services/document-service/index.js.map +0 -1
- package/dist/services/document-service/index.mjs +0 -22
- package/dist/services/document-service/index.mjs.map +0 -1
- package/dist/services/document-service/internationalization.js +0 -54
- package/dist/services/document-service/internationalization.js.map +0 -1
- package/dist/services/document-service/internationalization.mjs +0 -54
- package/dist/services/document-service/internationalization.mjs.map +0 -1
- package/dist/services/document-service/middlewares.d.ts +0 -8
- package/dist/services/document-service/middlewares.d.ts.map +0 -1
- package/dist/services/document-service/middlewares.js +0 -46
- package/dist/services/document-service/middlewares.js.map +0 -1
- package/dist/services/document-service/middlewares.mjs +0 -46
- package/dist/services/document-service/middlewares.mjs.map +0 -1
- package/dist/services/document-service/repository.js +0 -309
- package/dist/services/document-service/repository.js.map +0 -1
- package/dist/services/document-service/repository.mjs +0 -309
- package/dist/services/document-service/repository.mjs.map +0 -1
- package/dist/services/document-service/transform/data.js +0 -13
- package/dist/services/document-service/transform/data.js.map +0 -1
- package/dist/services/document-service/transform/data.mjs +0 -13
- package/dist/services/document-service/transform/data.mjs.map +0 -1
- package/dist/services/document-service/transform/fields.js +0 -24
- package/dist/services/document-service/transform/fields.js.map +0 -1
- package/dist/services/document-service/transform/fields.mjs +0 -24
- package/dist/services/document-service/transform/fields.mjs.map +0 -1
- package/dist/services/document-service/transform/filters.d.ts +0 -3
- package/dist/services/document-service/transform/filters.d.ts.map +0 -1
- package/dist/services/document-service/transform/id-map.js +0 -72
- package/dist/services/document-service/transform/id-map.js.map +0 -1
- package/dist/services/document-service/transform/id-map.mjs +0 -72
- package/dist/services/document-service/transform/id-map.mjs.map +0 -1
- package/dist/services/document-service/transform/id-transform.js +0 -27
- package/dist/services/document-service/transform/id-transform.js.map +0 -1
- package/dist/services/document-service/transform/id-transform.mjs +0 -27
- package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
- package/dist/services/document-service/transform/populate.js +0 -21
- package/dist/services/document-service/transform/populate.js.map +0 -1
- package/dist/services/document-service/transform/populate.mjs +0 -21
- package/dist/services/document-service/transform/populate.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -79
- package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -79
- package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -117
- package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -117
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
- package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
- package/dist/services/document-service/transform/relations/utils/data.js +0 -12
- package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
- package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
- package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/utils/i18n.js +0 -31
- package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
- package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -31
- package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
- package/dist/services/document-service/transform/sort.d.ts +0 -5
- package/dist/services/document-service/transform/sort.d.ts.map +0 -1
- package/dist/services/document-service/transform/utils.d.ts +0 -9
- package/dist/services/document-service/transform/utils.d.ts.map +0 -1
- package/dist/services/document-service/utils/populate.js +0 -41
- package/dist/services/document-service/utils/populate.js.map +0 -1
- package/dist/services/document-service/utils/populate.mjs +0 -41
- package/dist/services/document-service/utils/populate.mjs.map +0 -1
- package/dist/services/entity-service/attributes/index.d.ts +0 -6
- package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
- package/dist/services/entity-service/attributes/index.js +0 -22
- package/dist/services/entity-service/attributes/index.js.map +0 -1
- package/dist/services/entity-service/attributes/index.mjs +0 -22
- package/dist/services/entity-service/attributes/index.mjs.map +0 -1
- package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
- package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
- package/dist/services/entity-service/attributes/transforms.js +0 -20
- package/dist/services/entity-service/attributes/transforms.js.map +0 -1
- package/dist/services/entity-service/attributes/transforms.mjs +0 -19
- package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
- package/dist/services/entity-service/components.d.ts +0 -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 -127
- package/dist/services/entity-validator/blocks-validator.js.map +0 -1
- package/dist/services/entity-validator/blocks-validator.mjs +0 -128
- package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
- package/dist/services/entity-validator/index.js +0 -322
- package/dist/services/entity-validator/index.js.map +0 -1
- package/dist/services/entity-validator/index.mjs +0 -321
- package/dist/services/entity-validator/index.mjs.map +0 -1
- package/dist/services/entity-validator/validators.js +0 -121
- package/dist/services/entity-validator/validators.js.map +0 -1
- package/dist/services/entity-validator/validators.mjs +0 -119
- package/dist/services/entity-validator/validators.mjs.map +0 -1
- package/dist/services/errors.js +0 -76
- package/dist/services/errors.js.map +0 -1
- package/dist/services/errors.mjs +0 -74
- package/dist/services/errors.mjs.map +0 -1
- package/dist/services/event-hub.js +0 -67
- package/dist/services/event-hub.js.map +0 -1
- package/dist/services/event-hub.mjs +0 -68
- package/dist/services/event-hub.mjs.map +0 -1
- package/dist/services/features.js +0 -17
- package/dist/services/features.js.map +0 -1
- package/dist/services/features.mjs +0 -17
- package/dist/services/features.mjs.map +0 -1
- package/dist/services/fs.js +0 -51
- package/dist/services/fs.js.map +0 -1
- package/dist/services/fs.mjs +0 -49
- package/dist/services/fs.mjs.map +0 -1
- package/dist/services/metrics/admin-user-hash.js +0 -14
- package/dist/services/metrics/admin-user-hash.js.map +0 -1
- package/dist/services/metrics/admin-user-hash.mjs +0 -12
- package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
- package/dist/services/metrics/index.js +0 -45
- package/dist/services/metrics/index.js.map +0 -1
- package/dist/services/metrics/index.mjs +0 -46
- package/dist/services/metrics/index.mjs.map +0 -1
- package/dist/services/metrics/is-truthy.js +0 -9
- package/dist/services/metrics/is-truthy.js.map +0 -1
- package/dist/services/metrics/is-truthy.mjs +0 -8
- package/dist/services/metrics/is-truthy.mjs.map +0 -1
- package/dist/services/metrics/middleware.js +0 -25
- package/dist/services/metrics/middleware.js.map +0 -1
- package/dist/services/metrics/middleware.mjs +0 -26
- package/dist/services/metrics/middleware.mjs.map +0 -1
- package/dist/services/metrics/rate-limiter.js +0 -21
- package/dist/services/metrics/rate-limiter.js.map +0 -1
- package/dist/services/metrics/rate-limiter.mjs +0 -22
- package/dist/services/metrics/rate-limiter.mjs.map +0 -1
- package/dist/services/metrics/sender.js +0 -76
- package/dist/services/metrics/sender.js.map +0 -1
- package/dist/services/metrics/sender.mjs +0 -70
- package/dist/services/metrics/sender.mjs.map +0 -1
- package/dist/services/request-context.js +0 -13
- package/dist/services/request-context.js.map +0 -1
- package/dist/services/request-context.mjs +0 -14
- package/dist/services/request-context.mjs.map +0 -1
- package/dist/services/server/admin-api.js +0 -13
- package/dist/services/server/admin-api.js.map +0 -1
- package/dist/services/server/admin-api.mjs +0 -13
- package/dist/services/server/admin-api.mjs.map +0 -1
- package/dist/services/server/api.js +0 -30
- package/dist/services/server/api.js.map +0 -1
- package/dist/services/server/api.mjs +0 -28
- package/dist/services/server/api.mjs.map +0 -1
- package/dist/services/server/compose-endpoint.js +0 -118
- package/dist/services/server/compose-endpoint.js.map +0 -1
- package/dist/services/server/compose-endpoint.mjs +0 -117
- package/dist/services/server/compose-endpoint.mjs.map +0 -1
- package/dist/services/server/content-api.js +0 -12
- package/dist/services/server/content-api.js.map +0 -1
- package/dist/services/server/content-api.mjs +0 -12
- package/dist/services/server/content-api.mjs.map +0 -1
- package/dist/services/server/http-server.js +0 -50
- package/dist/services/server/http-server.js.map +0 -1
- package/dist/services/server/http-server.mjs +0 -48
- package/dist/services/server/http-server.mjs.map +0 -1
- package/dist/services/server/index.js +0 -88
- package/dist/services/server/index.js.map +0 -1
- package/dist/services/server/index.mjs +0 -86
- package/dist/services/server/index.mjs.map +0 -1
- package/dist/services/server/koa.js +0 -52
- package/dist/services/server/koa.js.map +0 -1
- package/dist/services/server/koa.mjs +0 -48
- package/dist/services/server/koa.mjs.map +0 -1
- package/dist/services/server/middleware.js +0 -92
- package/dist/services/server/middleware.js.map +0 -1
- package/dist/services/server/middleware.mjs +0 -90
- package/dist/services/server/middleware.mjs.map +0 -1
- package/dist/services/server/policy.js +0 -20
- package/dist/services/server/policy.js.map +0 -1
- package/dist/services/server/policy.mjs +0 -20
- package/dist/services/server/policy.mjs.map +0 -1
- package/dist/services/server/register-middlewares.js +0 -72
- package/dist/services/server/register-middlewares.js.map +0 -1
- package/dist/services/server/register-middlewares.mjs +0 -73
- package/dist/services/server/register-middlewares.mjs.map +0 -1
- package/dist/services/server/register-routes.js +0 -76
- package/dist/services/server/register-routes.js.map +0 -1
- package/dist/services/server/register-routes.mjs +0 -75
- package/dist/services/server/register-routes.mjs.map +0 -1
- package/dist/services/server/routing.js +0 -91
- package/dist/services/server/routing.js.map +0 -1
- package/dist/services/server/routing.mjs +0 -89
- package/dist/services/server/routing.mjs.map +0 -1
- package/dist/services/utils/dynamic-zones.js +0 -16
- package/dist/services/utils/dynamic-zones.js.map +0 -1
- package/dist/services/utils/dynamic-zones.mjs +0 -17
- package/dist/services/utils/dynamic-zones.mjs.map +0 -1
- package/dist/services/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 -237
- package/dist/utils/transform-content-types-to-models.js.map +0 -1
- package/dist/utils/transform-content-types-to-models.mjs +0 -234
- package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
- package/dist/utils/update-notifier/index.js +0 -88
- package/dist/utils/update-notifier/index.js.map +0 -1
- package/dist/utils/update-notifier/index.mjs +0 -81
- package/dist/utils/update-notifier/index.mjs.map +0 -1
|
@@ -1,309 +0,0 @@
|
|
|
1
|
-
import { curry, assoc, omit } from "lodash/fp";
|
|
2
|
-
import { convertQueryParams, pipeAsync, mapAsync, contentTypes } from "@strapi/utils";
|
|
3
|
-
import { wrapInTransaction } from "./common.mjs";
|
|
4
|
-
import { defaultToDraft, statusToLookup, setStatusToDraft, statusToData, filterDataPublishedAt } from "./draft-and-publish.mjs";
|
|
5
|
-
import { defaultLocale as defaultLocaleCurry, localeToLookup as localeToLookupCurry, multiLocaleToLookup as multiLocaleToLookupCurry, localeToData as localeToDataCurry } from "./internationalization.mjs";
|
|
6
|
-
import { transformParamsDocumentId } from "./transform/id-transform.mjs";
|
|
7
|
-
import { cloneComponents, omitComponentData, updateComponents, getComponents, deleteComponents, createComponents } from "../entity-service/components.mjs";
|
|
8
|
-
import { pickSelectionParams } from "../entity-service/params.mjs";
|
|
9
|
-
import entityValidator from "../entity-validator/index.mjs";
|
|
10
|
-
import { applyTransforms } from "../entity-service/attributes/index.mjs";
|
|
11
|
-
import { createDocumentId } from "../../utils/transform-content-types-to-models.mjs";
|
|
12
|
-
import { getDeepPopulate } from "./utils/populate.mjs";
|
|
13
|
-
import { transformData } from "./transform/data.mjs";
|
|
14
|
-
const transformParamsToQuery = curry((uid, params) => {
|
|
15
|
-
const query = convertQueryParams.transformParamsToQuery(uid, params);
|
|
16
|
-
return assoc("where", { ...params?.lookup, ...query.where }, query);
|
|
17
|
-
});
|
|
18
|
-
const createContentTypeRepository = (uid) => {
|
|
19
|
-
const contentType = strapi.contentType(uid);
|
|
20
|
-
async function findMany(params = {}) {
|
|
21
|
-
const query = await pipeAsync(
|
|
22
|
-
defaultToDraft,
|
|
23
|
-
statusToLookup,
|
|
24
|
-
defaultLocaleCurry(contentType),
|
|
25
|
-
localeToLookupCurry(contentType),
|
|
26
|
-
(queryParams) => transformParamsDocumentId(uid, queryParams, { isDraft: queryParams.status === "draft" }),
|
|
27
|
-
transformParamsToQuery(uid)
|
|
28
|
-
)(params || {});
|
|
29
|
-
return strapi.db.query(uid).findMany(query);
|
|
30
|
-
}
|
|
31
|
-
async function findFirst(params = {}) {
|
|
32
|
-
const query = await pipeAsync(
|
|
33
|
-
defaultToDraft,
|
|
34
|
-
statusToLookup,
|
|
35
|
-
defaultLocaleCurry(contentType),
|
|
36
|
-
localeToLookupCurry(contentType),
|
|
37
|
-
(queryParams) => transformParamsDocumentId(uid, queryParams, { isDraft: queryParams.status === "draft" }),
|
|
38
|
-
transformParamsToQuery(uid)
|
|
39
|
-
)(params);
|
|
40
|
-
return strapi.db.query(uid).findOne(query);
|
|
41
|
-
}
|
|
42
|
-
async function findOne(documentId, params = {}) {
|
|
43
|
-
const query = await pipeAsync(
|
|
44
|
-
defaultToDraft,
|
|
45
|
-
statusToLookup,
|
|
46
|
-
defaultLocaleCurry(contentType),
|
|
47
|
-
localeToLookupCurry(contentType),
|
|
48
|
-
(queryParams) => transformParamsDocumentId(uid, queryParams, { isDraft: queryParams.status === "draft" }),
|
|
49
|
-
transformParamsToQuery(uid),
|
|
50
|
-
(query2) => assoc("where", { ...query2.where, documentId }, query2)
|
|
51
|
-
)(params);
|
|
52
|
-
return strapi.db.query(uid).findOne(query);
|
|
53
|
-
}
|
|
54
|
-
async function deleteEntry(id) {
|
|
55
|
-
const componentsToDelete = await getComponents(uid, { id });
|
|
56
|
-
await strapi.db.query(uid).delete({ where: { id } });
|
|
57
|
-
await deleteComponents(uid, componentsToDelete, { loadComponents: false });
|
|
58
|
-
}
|
|
59
|
-
async function deleteFn(documentId, params = {}) {
|
|
60
|
-
const query = await pipeAsync(
|
|
61
|
-
omit("status"),
|
|
62
|
-
defaultLocaleCurry(contentType),
|
|
63
|
-
multiLocaleToLookupCurry(contentType),
|
|
64
|
-
transformParamsToQuery(uid),
|
|
65
|
-
(query2) => assoc("where", { ...query2.where, documentId }, query2)
|
|
66
|
-
)(params);
|
|
67
|
-
if (params.status === "draft") {
|
|
68
|
-
throw new Error("Cannot delete a draft document");
|
|
69
|
-
}
|
|
70
|
-
const entriesToDelete = await strapi.db.query(uid).findMany(query);
|
|
71
|
-
await mapAsync(entriesToDelete, (entryToDelete) => deleteEntry(entryToDelete.id));
|
|
72
|
-
return { deletedEntries: entriesToDelete.length };
|
|
73
|
-
}
|
|
74
|
-
async function createEntry(params = {}) {
|
|
75
|
-
const { data, ...restParams } = await transformParamsDocumentId(uid, params, {
|
|
76
|
-
locale: params.locale,
|
|
77
|
-
// User can not set publishedAt on create, but other methods in the engine can (publish)
|
|
78
|
-
isDraft: !params.data?.publishedAt
|
|
79
|
-
});
|
|
80
|
-
const query = transformParamsToQuery(uid, pickSelectionParams(restParams));
|
|
81
|
-
if (!params.data) {
|
|
82
|
-
throw new Error("Create requires data attribute");
|
|
83
|
-
}
|
|
84
|
-
const validData = await entityValidator.validateEntityCreation(contentType, data, {
|
|
85
|
-
isDraft: !data.publishedAt,
|
|
86
|
-
locale: params?.locale
|
|
87
|
-
});
|
|
88
|
-
const componentData = await createComponents(uid, validData);
|
|
89
|
-
const entryData = applyTransforms(
|
|
90
|
-
Object.assign(omitComponentData(contentType, validData), componentData),
|
|
91
|
-
{ contentType }
|
|
92
|
-
);
|
|
93
|
-
const doc = await strapi.db.query(uid).create({ ...query, data: entryData });
|
|
94
|
-
return doc;
|
|
95
|
-
}
|
|
96
|
-
async function create(params = {}) {
|
|
97
|
-
const queryParams = await pipeAsync(
|
|
98
|
-
setStatusToDraft,
|
|
99
|
-
statusToData,
|
|
100
|
-
filterDataPublishedAt,
|
|
101
|
-
defaultLocaleCurry(contentType),
|
|
102
|
-
localeToDataCurry(contentType)
|
|
103
|
-
)(params);
|
|
104
|
-
const doc = await createEntry(queryParams);
|
|
105
|
-
if (params.status === "published") {
|
|
106
|
-
return publish(doc.documentId, params).then((doc2) => doc2.versions[0]);
|
|
107
|
-
}
|
|
108
|
-
return doc;
|
|
109
|
-
}
|
|
110
|
-
async function clone(documentId, params = {}) {
|
|
111
|
-
const queryParams = await pipeAsync(
|
|
112
|
-
filterDataPublishedAt,
|
|
113
|
-
localeToLookupCurry(contentType)
|
|
114
|
-
)(params);
|
|
115
|
-
const { data, ...restParams } = await transformParamsDocumentId(uid, queryParams || {}, {
|
|
116
|
-
isDraft: true,
|
|
117
|
-
locale: queryParams?.locale
|
|
118
|
-
});
|
|
119
|
-
const query = transformParamsToQuery(uid, pickSelectionParams(restParams));
|
|
120
|
-
const model = strapi.contentType(uid);
|
|
121
|
-
const entries = await strapi.db.query(uid).findMany({
|
|
122
|
-
...query,
|
|
123
|
-
where: { ...queryParams?.lookup, ...query.where, documentId }
|
|
124
|
-
});
|
|
125
|
-
if (!entries.length) {
|
|
126
|
-
return null;
|
|
127
|
-
}
|
|
128
|
-
const newDocumentId = createDocumentId();
|
|
129
|
-
const versions = await mapAsync(entries, async (entryToClone) => {
|
|
130
|
-
const isDraft = contentTypes.isDraft(data);
|
|
131
|
-
const validData = await entityValidator.validateEntityUpdate(
|
|
132
|
-
model,
|
|
133
|
-
// Omit id fields, the cloned entity id will be generated by the database
|
|
134
|
-
omit(["id"], data),
|
|
135
|
-
{ isDraft, ...queryParams?.lookup },
|
|
136
|
-
entryToClone
|
|
137
|
-
);
|
|
138
|
-
const componentData = await cloneComponents(uid, entryToClone, validData);
|
|
139
|
-
const entityData = applyTransforms(
|
|
140
|
-
Object.assign(omitComponentData(model, validData), componentData),
|
|
141
|
-
{ contentType: model }
|
|
142
|
-
);
|
|
143
|
-
return strapi.db.query(uid).clone(entryToClone.id, {
|
|
144
|
-
...query,
|
|
145
|
-
// Allows entityData to override the documentId (e.g. when publishing)
|
|
146
|
-
data: { documentId: newDocumentId, ...entityData, locale: entryToClone.locale }
|
|
147
|
-
});
|
|
148
|
-
});
|
|
149
|
-
return { documentId: newDocumentId, versions };
|
|
150
|
-
}
|
|
151
|
-
async function update(documentId, params = {}) {
|
|
152
|
-
const queryParams = await pipeAsync(
|
|
153
|
-
setStatusToDraft,
|
|
154
|
-
statusToLookup,
|
|
155
|
-
statusToData,
|
|
156
|
-
filterDataPublishedAt,
|
|
157
|
-
// Default locale will be set if not provided
|
|
158
|
-
defaultLocaleCurry(contentType),
|
|
159
|
-
localeToLookupCurry(contentType),
|
|
160
|
-
localeToDataCurry(contentType)
|
|
161
|
-
)(params);
|
|
162
|
-
const { data, ...restParams } = await transformParamsDocumentId(uid, queryParams || {}, {
|
|
163
|
-
isDraft: true,
|
|
164
|
-
locale: queryParams?.locale
|
|
165
|
-
});
|
|
166
|
-
const query = transformParamsToQuery(uid, pickSelectionParams(restParams || {}));
|
|
167
|
-
const model = strapi.contentType(uid);
|
|
168
|
-
const entryToUpdate = await strapi.db.query(uid).findOne({ ...query, where: { ...queryParams?.lookup, ...query?.where, documentId } });
|
|
169
|
-
let updatedDraft = null;
|
|
170
|
-
if (entryToUpdate) {
|
|
171
|
-
const validData = await entityValidator.validateEntityUpdate(
|
|
172
|
-
model,
|
|
173
|
-
data,
|
|
174
|
-
{
|
|
175
|
-
isDraft: true,
|
|
176
|
-
// Always update the draft version
|
|
177
|
-
locale: queryParams?.locale
|
|
178
|
-
},
|
|
179
|
-
entryToUpdate
|
|
180
|
-
);
|
|
181
|
-
const componentData = await updateComponents(uid, entryToUpdate, validData);
|
|
182
|
-
const entryData = applyTransforms(
|
|
183
|
-
Object.assign(omitComponentData(model, validData), componentData),
|
|
184
|
-
{ contentType: model }
|
|
185
|
-
);
|
|
186
|
-
updatedDraft = await strapi.db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });
|
|
187
|
-
}
|
|
188
|
-
if (!updatedDraft) {
|
|
189
|
-
const documentExists = await strapi.db.query(contentType.uid).findOne({ where: { documentId } });
|
|
190
|
-
if (documentExists) {
|
|
191
|
-
updatedDraft = await createEntry({
|
|
192
|
-
...queryParams,
|
|
193
|
-
data: { ...queryParams.data, documentId }
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
if (updatedDraft && params.status === "published") {
|
|
198
|
-
return publish(documentId, params).then((doc) => doc.versions[0]);
|
|
199
|
-
}
|
|
200
|
-
return updatedDraft;
|
|
201
|
-
}
|
|
202
|
-
async function count(params = {}) {
|
|
203
|
-
const query = await pipeAsync(
|
|
204
|
-
defaultToDraft,
|
|
205
|
-
statusToLookup,
|
|
206
|
-
defaultLocaleCurry(contentType),
|
|
207
|
-
localeToLookupCurry(contentType),
|
|
208
|
-
transformParamsToQuery(uid)
|
|
209
|
-
)(params);
|
|
210
|
-
return strapi.db.query(uid).count(query);
|
|
211
|
-
}
|
|
212
|
-
async function publish(documentId, params = {}) {
|
|
213
|
-
const queryParams = await pipeAsync(
|
|
214
|
-
defaultLocaleCurry(contentType),
|
|
215
|
-
multiLocaleToLookupCurry(contentType)
|
|
216
|
-
)(params);
|
|
217
|
-
await deleteFn(documentId, {
|
|
218
|
-
...queryParams,
|
|
219
|
-
lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } }
|
|
220
|
-
});
|
|
221
|
-
const entriesToPublish = await strapi.db?.query(uid).findMany({
|
|
222
|
-
where: {
|
|
223
|
-
...queryParams?.lookup,
|
|
224
|
-
documentId,
|
|
225
|
-
publishedAt: null
|
|
226
|
-
},
|
|
227
|
-
populate: getDeepPopulate(uid)
|
|
228
|
-
});
|
|
229
|
-
const publishedEntries = await mapAsync(
|
|
230
|
-
entriesToPublish,
|
|
231
|
-
pipeAsync(
|
|
232
|
-
assoc("publishedAt", /* @__PURE__ */ new Date()),
|
|
233
|
-
assoc("documentId", documentId),
|
|
234
|
-
omit("id"),
|
|
235
|
-
// Transform relations to target published versions
|
|
236
|
-
(entry) => {
|
|
237
|
-
const opts = { uid, locale: entry.locale, isDraft: false, allowMissingId: true };
|
|
238
|
-
return transformData(entry, opts);
|
|
239
|
-
},
|
|
240
|
-
// Create the published entry
|
|
241
|
-
(data) => createEntry({ ...queryParams, data, locale: data.locale })
|
|
242
|
-
)
|
|
243
|
-
);
|
|
244
|
-
return { versions: publishedEntries };
|
|
245
|
-
}
|
|
246
|
-
async function unpublish(documentId, params = {}) {
|
|
247
|
-
const queryParams = await pipeAsync(
|
|
248
|
-
defaultLocaleCurry(contentType),
|
|
249
|
-
multiLocaleToLookupCurry(contentType)
|
|
250
|
-
)(params);
|
|
251
|
-
const { deletedEntries } = await deleteFn(documentId, {
|
|
252
|
-
...params,
|
|
253
|
-
lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } }
|
|
254
|
-
});
|
|
255
|
-
return { versions: deletedEntries };
|
|
256
|
-
}
|
|
257
|
-
async function discardDraft(documentId, params = {}) {
|
|
258
|
-
const queryParams = await pipeAsync(
|
|
259
|
-
defaultLocaleCurry(contentType),
|
|
260
|
-
multiLocaleToLookupCurry(contentType)
|
|
261
|
-
)(params);
|
|
262
|
-
await deleteFn(documentId, {
|
|
263
|
-
...queryParams,
|
|
264
|
-
// Delete all drafts that match query
|
|
265
|
-
lookup: { ...queryParams?.lookup, publishedAt: null }
|
|
266
|
-
});
|
|
267
|
-
const entriesToDraft = await strapi.db?.query(uid).findMany({
|
|
268
|
-
where: {
|
|
269
|
-
...queryParams?.lookup,
|
|
270
|
-
documentId,
|
|
271
|
-
publishedAt: { $ne: null }
|
|
272
|
-
},
|
|
273
|
-
populate: getDeepPopulate(uid)
|
|
274
|
-
});
|
|
275
|
-
const draftEntries = await mapAsync(
|
|
276
|
-
entriesToDraft,
|
|
277
|
-
pipeAsync(
|
|
278
|
-
assoc("publishedAt", null),
|
|
279
|
-
assoc("documentId", documentId),
|
|
280
|
-
omit("id"),
|
|
281
|
-
// Transform relations to target draft versions
|
|
282
|
-
(entry) => {
|
|
283
|
-
const opts = { uid, locale: entry.locale, isDraft: true, allowMissingId: true };
|
|
284
|
-
return transformData(entry, opts);
|
|
285
|
-
},
|
|
286
|
-
// Create the draft entry
|
|
287
|
-
(data) => createEntry({ ...queryParams, locale: data.locale, data })
|
|
288
|
-
)
|
|
289
|
-
);
|
|
290
|
-
return { versions: draftEntries };
|
|
291
|
-
}
|
|
292
|
-
return {
|
|
293
|
-
findMany: wrapInTransaction(findMany),
|
|
294
|
-
findFirst: wrapInTransaction(findFirst),
|
|
295
|
-
findOne: wrapInTransaction(findOne),
|
|
296
|
-
delete: wrapInTransaction(deleteFn),
|
|
297
|
-
create: wrapInTransaction(create),
|
|
298
|
-
clone: wrapInTransaction(clone),
|
|
299
|
-
update: wrapInTransaction(update),
|
|
300
|
-
count: wrapInTransaction(count),
|
|
301
|
-
publish: wrapInTransaction(publish),
|
|
302
|
-
unpublish: wrapInTransaction(unpublish),
|
|
303
|
-
discardDraft: wrapInTransaction(discardDraft)
|
|
304
|
-
};
|
|
305
|
-
};
|
|
306
|
-
export {
|
|
307
|
-
createContentTypeRepository
|
|
308
|
-
};
|
|
309
|
-
//# sourceMappingURL=repository.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"repository.mjs","sources":["../../../src/services/document-service/repository.ts"],"sourcesContent":["import { omit, assoc, curry } from 'lodash/fp';\n\nimport {\n pipeAsync,\n mapAsync,\n convertQueryParams,\n contentTypes as contentTypesUtils,\n} from '@strapi/utils';\nimport { Common } from '@strapi/types';\n\nimport { wrapInTransaction, type RepositoryFactoryMethod } from './common';\nimport * as DP from './draft-and-publish';\nimport * as i18n from './internationalization';\nimport { transformParamsDocumentId } from './transform/id-transform';\n\nimport {\n cloneComponents,\n createComponents,\n deleteComponents,\n getComponents,\n omitComponentData,\n updateComponents,\n} from '../entity-service/components';\n\nimport { pickSelectionParams } from './params';\nimport entityValidator from '../entity-validator';\nimport { applyTransforms } from '../entity-service/attributes';\nimport { createDocumentId } from '../../utils/transform-content-types-to-models';\nimport { getDeepPopulate } from './utils/populate';\nimport { transformData } from './transform/data';\n\nconst transformParamsToQuery = curry((uid: Common.UID.Schema, params: any) => {\n const query = convertQueryParams.transformParamsToQuery(uid, params);\n\n return assoc('where', { ...params?.lookup, ...query.where }, query);\n});\n\nexport const createContentTypeRepository: RepositoryFactoryMethod = (uid) => {\n const contentType = strapi.contentType(uid);\n\n async function findMany(params = {} as any) {\n const query = await pipeAsync(\n DP.defaultToDraft,\n DP.statusToLookup,\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n (queryParams) =>\n transformParamsDocumentId(uid, queryParams, { isDraft: queryParams.status === 'draft' }),\n transformParamsToQuery(uid)\n )(params || {});\n\n return strapi.db.query(uid).findMany(query);\n }\n\n async function findFirst(params = {} as any) {\n const query = await pipeAsync(\n DP.defaultToDraft,\n DP.statusToLookup,\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n (queryParams) =>\n transformParamsDocumentId(uid, queryParams, { isDraft: queryParams.status === 'draft' }),\n transformParamsToQuery(uid)\n )(params);\n\n return strapi.db.query(uid).findOne(query);\n }\n\n // TODO: do we really want to add filters on the findOne now that we have findFirst ?\n async function findOne(documentId: string, params = {} as any) {\n const query = await pipeAsync(\n DP.defaultToDraft,\n DP.statusToLookup,\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n (queryParams) =>\n transformParamsDocumentId(uid, queryParams, { isDraft: queryParams.status === 'draft' }),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId }, query)\n )(params);\n\n return strapi.db.query(uid).findOne(query);\n }\n\n async function deleteEntry(id: number) {\n const componentsToDelete = await getComponents(uid, { id });\n\n await strapi.db.query(uid).delete({ where: { id } });\n\n await deleteComponents(uid, componentsToDelete as any, { loadComponents: false });\n }\n\n async function deleteFn(documentId: string, params = {} as any) {\n const query = await pipeAsync(\n omit('status'),\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId }, query)\n )(params);\n\n if (params.status === 'draft') {\n throw new Error('Cannot delete a draft document');\n }\n\n const entriesToDelete = await strapi.db.query(uid).findMany(query);\n\n // Delete all matched entries and its components\n await mapAsync(entriesToDelete, (entryToDelete: any) => deleteEntry(entryToDelete.id));\n\n return { deletedEntries: entriesToDelete.length };\n }\n\n async function createEntry(params = {} as any) {\n const { data, ...restParams } = await transformParamsDocumentId(uid, params, {\n locale: params.locale,\n // User can not set publishedAt on create, but other methods in the engine can (publish)\n isDraft: !params.data?.publishedAt,\n });\n\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams) as any); // select / populate\n\n // Validation\n if (!params.data) {\n throw new Error('Create requires data attribute');\n }\n\n const validData = await entityValidator.validateEntityCreation(contentType, data, {\n isDraft: !data.publishedAt,\n locale: params?.locale,\n });\n\n // Component handling\n const componentData = await createComponents(uid, validData as any);\n const entryData = applyTransforms(\n Object.assign(omitComponentData(contentType, validData), componentData),\n { contentType }\n );\n\n const doc = await strapi.db.query(uid).create({ ...query, data: entryData });\n\n return doc;\n }\n\n async function create(params = {} as any) {\n const queryParams = await pipeAsync(\n DP.setStatusToDraft,\n DP.statusToData,\n DP.filterDataPublishedAt,\n i18n.defaultLocale(contentType),\n i18n.localeToData(contentType)\n )(params);\n\n const doc = await createEntry(queryParams);\n\n if (params.status === 'published') {\n return publish(doc.documentId, params).then((doc) => doc.versions[0]);\n }\n\n return doc;\n }\n\n async function clone(documentId: string, params = {} as any) {\n const queryParams = await pipeAsync(\n DP.filterDataPublishedAt,\n i18n.localeToLookup(contentType)\n )(params);\n\n const { data, ...restParams } = await transformParamsDocumentId(uid, queryParams || {}, {\n isDraft: true,\n locale: queryParams?.locale,\n });\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams) as any);\n // Param parsing\n\n // Validation\n const model = strapi.contentType(uid);\n // Find all locales of the document\n const entries = await strapi.db.query(uid).findMany({\n ...query,\n where: { ...queryParams?.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, ...queryParams?.lookup },\n entryToClone\n );\n\n const componentData = await cloneComponents(uid, entryToClone, validData);\n const entityData = applyTransforms(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n // TODO: Transform params to query\n return strapi.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 { documentId: newDocumentId, versions };\n }\n\n // NOTE: What happens if user doesn't provide specific publications state and locale to update?\n async function update(documentId: string, params = {} as any) {\n const queryParams = await pipeAsync(\n DP.setStatusToDraft,\n DP.statusToLookup,\n DP.statusToData,\n DP.filterDataPublishedAt,\n // Default locale will be set if not provided\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n i18n.localeToData(contentType)\n )(params);\n\n const { data, ...restParams } = await transformParamsDocumentId(uid, queryParams || {}, {\n isDraft: true,\n locale: queryParams?.locale,\n });\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams || {}) as any);\n\n // Validation\n const model = strapi.contentType(uid);\n // Find if document exists\n const entryToUpdate = await strapi.db\n .query(uid)\n .findOne({ ...query, where: { ...queryParams?.lookup, ...query?.where, documentId } });\n\n let updatedDraft = null;\n if (entryToUpdate) {\n const validData = await entityValidator.validateEntityUpdate(\n model,\n data,\n {\n isDraft: true, // Always update the draft version\n locale: queryParams?.locale,\n },\n entryToUpdate\n );\n\n // Component handling\n const componentData = await updateComponents(uid, entryToUpdate, validData as any);\n const entryData = applyTransforms(\n Object.assign(omitComponentData(model, validData), componentData),\n { contentType: model }\n );\n\n updatedDraft = await strapi.db\n .query(uid)\n .update({ ...query, where: { id: entryToUpdate.id }, data: entryData });\n }\n\n if (!updatedDraft) {\n const documentExists = await strapi.db\n .query(contentType.uid)\n .findOne({ where: { documentId } });\n\n if (documentExists) {\n updatedDraft = await createEntry({\n ...queryParams,\n data: { ...queryParams.data, documentId },\n });\n }\n }\n\n if (updatedDraft && params.status === 'published') {\n return publish(documentId, params).then((doc) => doc.versions[0]);\n }\n\n return updatedDraft;\n }\n\n async function count(params = {} as any) {\n const query = await pipeAsync(\n DP.defaultToDraft,\n DP.statusToLookup,\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n transformParamsToQuery(uid)\n )(params);\n\n return strapi.db.query(uid).count(query);\n }\n\n async function publish(documentId: string, params = {} as any) {\n const queryParams = await pipeAsync(\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n await deleteFn(documentId, {\n ...queryParams,\n lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } },\n });\n\n // Get deep populate\n const entriesToPublish = await strapi.db?.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: null,\n },\n populate: getDeepPopulate(uid),\n });\n\n // Transform draft entry data and create published versions\n const publishedEntries = await mapAsync(\n entriesToPublish,\n pipeAsync(\n assoc('publishedAt', new Date()),\n assoc('documentId', documentId),\n omit('id'),\n // Transform relations to target published versions\n (entry) => {\n const opts = { uid, locale: entry.locale, isDraft: false, allowMissingId: true };\n return transformData(entry, opts);\n },\n // Create the published entry\n (data) => createEntry({ ...queryParams, data, locale: data.locale })\n )\n );\n\n return { versions: publishedEntries };\n }\n\n async function unpublish(documentId: string, params = {} as any) {\n const queryParams = await pipeAsync(\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n const { deletedEntries } = await deleteFn(documentId, {\n ...params,\n lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } },\n });\n\n return { versions: deletedEntries };\n }\n\n async function discardDraft(documentId: string, params = {} as any) {\n const queryParams = await pipeAsync(\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n await deleteFn(documentId, {\n ...queryParams,\n // Delete all drafts that match query\n lookup: { ...queryParams?.lookup, publishedAt: null },\n });\n\n // Get deep populate of published versions\n const entriesToDraft = await strapi.db?.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: { $ne: null },\n },\n populate: getDeepPopulate(uid),\n });\n\n // Transform published entry data and create draft versions\n const draftEntries = await mapAsync(\n entriesToDraft,\n pipeAsync(\n assoc('publishedAt', null),\n assoc('documentId', documentId),\n omit('id'),\n // Transform relations to target draft versions\n (entry) => {\n const opts = { uid, locale: entry.locale, isDraft: true, allowMissingId: true };\n return transformData(entry, opts);\n },\n // Create the draft entry\n (data) => createEntry({ ...queryParams, locale: data.locale, data })\n )\n );\n\n return { versions: draftEntries };\n }\n\n return {\n findMany: wrapInTransaction(findMany),\n findFirst: wrapInTransaction(findFirst),\n findOne: wrapInTransaction(findOne),\n delete: wrapInTransaction(deleteFn),\n create: wrapInTransaction(create),\n clone: wrapInTransaction(clone),\n update: wrapInTransaction(update),\n count: wrapInTransaction(count),\n publish: wrapInTransaction(publish),\n unpublish: wrapInTransaction(unpublish),\n discardDraft: wrapInTransaction(discardDraft),\n };\n};\n"],"names":["DP.defaultToDraft","DP.statusToLookup","i18n.defaultLocale","i18n.localeToLookup","query","i18n.multiLocaleToLookup","DP.setStatusToDraft","DP.statusToData","DP.filterDataPublishedAt","i18n.localeToData","doc","contentTypesUtils"],"mappings":"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"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const idMap = require("./id-map.js");
|
|
4
|
-
const dataIds = require("./relations/extract/data-ids.js");
|
|
5
|
-
const dataIds$1 = require("./relations/transform/data-ids.js");
|
|
6
|
-
const transformData = async (data, opts) => {
|
|
7
|
-
const idMap$1 = idMap.createIdMap({ strapi });
|
|
8
|
-
await dataIds.extractDataIds(idMap$1, data, opts);
|
|
9
|
-
await idMap$1.load();
|
|
10
|
-
return dataIds$1.transformDataIdsVisitor(idMap$1, data, opts);
|
|
11
|
-
};
|
|
12
|
-
exports.transformData = transformData;
|
|
13
|
-
//# sourceMappingURL=data.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"data.js","sources":["../../../../src/services/document-service/transform/data.ts"],"sourcesContent":["import { createIdMap } from './id-map';\nimport { extractDataIds as extractDataRelationIds } from './relations/extract/data-ids';\nimport { transformDataIdsVisitor as transformRelationDataIds } from './relations/transform/data-ids';\n\n/**\n * Transforms input data, containing relation document ids, to entity ids.\n */\nexport const transformData = async (data: any, opts: any) => {\n const idMap = createIdMap({ strapi });\n\n // Extract any relation ids from the input\n await extractDataRelationIds(idMap, data, opts);\n\n // Load any relation the extract methods found\n await idMap.load();\n\n // Transform any relation ids to entity ids\n return transformRelationDataIds(idMap, data, opts);\n};\n"],"names":["idMap","createIdMap","extractDataRelationIds","transformRelationDataIds"],"mappings":";;;;;AAOa,MAAA,gBAAgB,OAAO,MAAW,SAAc;AAC3D,QAAMA,UAAQC,MAAAA,YAAY,EAAE,OAAQ,CAAA;AAG9B,QAAAC,uBAAuBF,SAAO,MAAM,IAAI;AAG9C,QAAMA,QAAM;AAGL,SAAAG,kCAAyBH,SAAO,MAAM,IAAI;AACnD;;"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { createIdMap } from "./id-map.mjs";
|
|
2
|
-
import { extractDataIds } from "./relations/extract/data-ids.mjs";
|
|
3
|
-
import { transformDataIdsVisitor } from "./relations/transform/data-ids.mjs";
|
|
4
|
-
const transformData = async (data, opts) => {
|
|
5
|
-
const idMap = createIdMap({ strapi });
|
|
6
|
-
await extractDataIds(idMap, data, opts);
|
|
7
|
-
await idMap.load();
|
|
8
|
-
return transformDataIdsVisitor(idMap, data, opts);
|
|
9
|
-
};
|
|
10
|
-
export {
|
|
11
|
-
transformData
|
|
12
|
-
};
|
|
13
|
-
//# sourceMappingURL=data.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"data.mjs","sources":["../../../../src/services/document-service/transform/data.ts"],"sourcesContent":["import { createIdMap } from './id-map';\nimport { extractDataIds as extractDataRelationIds } from './relations/extract/data-ids';\nimport { transformDataIdsVisitor as transformRelationDataIds } from './relations/transform/data-ids';\n\n/**\n * Transforms input data, containing relation document ids, to entity ids.\n */\nexport const transformData = async (data: any, opts: any) => {\n const idMap = createIdMap({ strapi });\n\n // Extract any relation ids from the input\n await extractDataRelationIds(idMap, data, opts);\n\n // Load any relation the extract methods found\n await idMap.load();\n\n // Transform any relation ids to entity ids\n return transformRelationDataIds(idMap, data, opts);\n};\n"],"names":["extractDataRelationIds","transformRelationDataIds"],"mappings":";;;AAOa,MAAA,gBAAgB,OAAO,MAAW,SAAc;AAC3D,QAAM,QAAQ,YAAY,EAAE,OAAQ,CAAA;AAG9B,QAAAA,eAAuB,OAAO,MAAM,IAAI;AAG9C,QAAM,MAAM;AAGL,SAAAC,wBAAyB,OAAO,MAAM,IAAI;AACnD;"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const transformFields = (fields) => {
|
|
4
|
-
if (typeof fields === "string") {
|
|
5
|
-
if (fields === "*") {
|
|
6
|
-
return fields;
|
|
7
|
-
}
|
|
8
|
-
if (fields === "") {
|
|
9
|
-
return "documentId";
|
|
10
|
-
}
|
|
11
|
-
if (!fields.split(",").includes("documentId")) {
|
|
12
|
-
return `${fields},documentId`;
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
if (!fields || !Array.isArray(fields)) {
|
|
16
|
-
return fields;
|
|
17
|
-
}
|
|
18
|
-
if (!fields.includes("documentId")) {
|
|
19
|
-
fields.push("documentId");
|
|
20
|
-
}
|
|
21
|
-
return fields;
|
|
22
|
-
};
|
|
23
|
-
exports.transformFields = transformFields;
|
|
24
|
-
//# sourceMappingURL=fields.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fields.js","sources":["../../../../src/services/document-service/transform/fields.ts"],"sourcesContent":["import { Documents, Common } from '@strapi/types';\n\ntype Fields = Documents.Params.Pick<Common.UID.Schema, 'fields'>['fields'];\n\nexport const transformFields = (fields: Fields): Fields => {\n // If it's a string, and it doesn't contain documentId, should be an array\n if (typeof fields === 'string') {\n // '*' => '*'\n if (fields === '*') {\n return fields;\n }\n\n // '' => 'documentId'\n if (fields === '') {\n return 'documentId';\n }\n\n // 'name,description' => 'name,description,documentId'\n if (!fields.split(',').includes('documentId')) {\n return `${fields},documentId`;\n }\n }\n\n // It's not an array, ignore it\n if (!fields || !Array.isArray(fields)) {\n // If fields is empty, return it as is\n return fields;\n }\n\n // Ensure we are always selecting the documentId\n // ['name', 'description'] => ['name', 'description', 'documentId']\n if (!fields.includes('documentId')) {\n fields.push('documentId');\n }\n\n return fields;\n};\n"],"names":[],"mappings":";;AAIa,MAAA,kBAAkB,CAAC,WAA2B;AAErD,MAAA,OAAO,WAAW,UAAU;AAE9B,QAAI,WAAW,KAAK;AACX,aAAA;AAAA,IACT;AAGA,QAAI,WAAW,IAAI;AACV,aAAA;AAAA,IACT;AAGA,QAAI,CAAC,OAAO,MAAM,GAAG,EAAE,SAAS,YAAY,GAAG;AAC7C,aAAO,GAAG,MAAM;AAAA,IAClB;AAAA,EACF;AAGA,MAAI,CAAC,UAAU,CAAC,MAAM,QAAQ,MAAM,GAAG;AAE9B,WAAA;AAAA,EACT;AAIA,MAAI,CAAC,OAAO,SAAS,YAAY,GAAG;AAClC,WAAO,KAAK,YAAY;AAAA,EAC1B;AAEO,SAAA;AACT;;"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
const transformFields = (fields) => {
|
|
2
|
-
if (typeof fields === "string") {
|
|
3
|
-
if (fields === "*") {
|
|
4
|
-
return fields;
|
|
5
|
-
}
|
|
6
|
-
if (fields === "") {
|
|
7
|
-
return "documentId";
|
|
8
|
-
}
|
|
9
|
-
if (!fields.split(",").includes("documentId")) {
|
|
10
|
-
return `${fields},documentId`;
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
if (!fields || !Array.isArray(fields)) {
|
|
14
|
-
return fields;
|
|
15
|
-
}
|
|
16
|
-
if (!fields.includes("documentId")) {
|
|
17
|
-
fields.push("documentId");
|
|
18
|
-
}
|
|
19
|
-
return fields;
|
|
20
|
-
};
|
|
21
|
-
export {
|
|
22
|
-
transformFields
|
|
23
|
-
};
|
|
24
|
-
//# sourceMappingURL=fields.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fields.mjs","sources":["../../../../src/services/document-service/transform/fields.ts"],"sourcesContent":["import { Documents, Common } from '@strapi/types';\n\ntype Fields = Documents.Params.Pick<Common.UID.Schema, 'fields'>['fields'];\n\nexport const transformFields = (fields: Fields): Fields => {\n // If it's a string, and it doesn't contain documentId, should be an array\n if (typeof fields === 'string') {\n // '*' => '*'\n if (fields === '*') {\n return fields;\n }\n\n // '' => 'documentId'\n if (fields === '') {\n return 'documentId';\n }\n\n // 'name,description' => 'name,description,documentId'\n if (!fields.split(',').includes('documentId')) {\n return `${fields},documentId`;\n }\n }\n\n // It's not an array, ignore it\n if (!fields || !Array.isArray(fields)) {\n // If fields is empty, return it as is\n return fields;\n }\n\n // Ensure we are always selecting the documentId\n // ['name', 'description'] => ['name', 'description', 'documentId']\n if (!fields.includes('documentId')) {\n fields.push('documentId');\n }\n\n return fields;\n};\n"],"names":[],"mappings":"AAIa,MAAA,kBAAkB,CAAC,WAA2B;AAErD,MAAA,OAAO,WAAW,UAAU;AAE9B,QAAI,WAAW,KAAK;AACX,aAAA;AAAA,IACT;AAGA,QAAI,WAAW,IAAI;AACV,aAAA;AAAA,IACT;AAGA,QAAI,CAAC,OAAO,MAAM,GAAG,EAAE,SAAS,YAAY,GAAG;AAC7C,aAAO,GAAG,MAAM;AAAA,IAClB;AAAA,EACF;AAGA,MAAI,CAAC,UAAU,CAAC,MAAM,QAAQ,MAAM,GAAG;AAE9B,WAAA;AAAA,EACT;AAIA,MAAI,CAAC,OAAO,SAAS,YAAY,GAAG;AAClC,WAAO,KAAK,YAAY;AAAA,EAC1B;AAEO,SAAA;AACT;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"filters.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/transform/filters.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,IAAI,EAAE,KAAK,OAAO,EAAE,MAAM,SAAS,CAAC;AAyBlD,eAAO,MAAM,gBAAgB,SAAgB,IAAI,QAAQ,OAAO,qBAqC/D,CAAC"}
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const strapiUtils = require("@strapi/utils");
|
|
4
|
-
const encodeKey = (obj) => {
|
|
5
|
-
const keys = Object.keys(obj).sort();
|
|
6
|
-
return keys.map((key) => `${key}:::${obj[key]}`).join("&&");
|
|
7
|
-
};
|
|
8
|
-
const createIdMap = ({ strapi }) => {
|
|
9
|
-
const loadedIds = /* @__PURE__ */ new Map();
|
|
10
|
-
const toLoadIds = /* @__PURE__ */ new Map();
|
|
11
|
-
return {
|
|
12
|
-
loadedIds,
|
|
13
|
-
toLoadIds,
|
|
14
|
-
/**
|
|
15
|
-
* Register a new document id and its corresponding entity id.
|
|
16
|
-
*/
|
|
17
|
-
add(keyFields) {
|
|
18
|
-
const key = encodeKey({ isDraft: false, locale: null, ...keyFields });
|
|
19
|
-
if (loadedIds.has(key))
|
|
20
|
-
return;
|
|
21
|
-
if (toLoadIds.has(key))
|
|
22
|
-
return;
|
|
23
|
-
toLoadIds.set(key, keyFields);
|
|
24
|
-
},
|
|
25
|
-
/**
|
|
26
|
-
* Load all ids from the registry.
|
|
27
|
-
*/
|
|
28
|
-
async load() {
|
|
29
|
-
const loadIdValues = Array.from(toLoadIds.values());
|
|
30
|
-
const idsByUidAndLocale = loadIdValues.reduce((acc, { documentId, ...rest }) => {
|
|
31
|
-
const key = encodeKey(rest);
|
|
32
|
-
const ids = acc[key] || { ...rest, documentIds: [] };
|
|
33
|
-
ids.documentIds.push(documentId);
|
|
34
|
-
return { ...acc, [key]: ids };
|
|
35
|
-
}, {});
|
|
36
|
-
await strapiUtils.mapAsync(
|
|
37
|
-
Object.values(idsByUidAndLocale),
|
|
38
|
-
async ({ uid, locale, documentIds, isDraft }) => {
|
|
39
|
-
const result = await strapi?.db?.query(uid).findMany({
|
|
40
|
-
select: ["id", "documentId", "locale", "publishedAt"],
|
|
41
|
-
where: {
|
|
42
|
-
documentId: { $in: documentIds },
|
|
43
|
-
locale,
|
|
44
|
-
publishedAt: isDraft ? null : { $ne: null }
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
result?.forEach(({ documentId, id, locale: locale2, publishedAt }) => {
|
|
48
|
-
const key = encodeKey({ documentId, uid, locale: locale2, isDraft: !publishedAt });
|
|
49
|
-
loadedIds.set(key, id);
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
);
|
|
53
|
-
toLoadIds.clear();
|
|
54
|
-
},
|
|
55
|
-
/**
|
|
56
|
-
* Get the entity id for a given document id.
|
|
57
|
-
*/
|
|
58
|
-
get(keys) {
|
|
59
|
-
const key = encodeKey({ isDraft: false, locale: null, ...keys });
|
|
60
|
-
return loadedIds.get(key);
|
|
61
|
-
},
|
|
62
|
-
/**
|
|
63
|
-
* Clear the registry.
|
|
64
|
-
*/
|
|
65
|
-
clear() {
|
|
66
|
-
loadedIds.clear();
|
|
67
|
-
toLoadIds.clear();
|
|
68
|
-
}
|
|
69
|
-
};
|
|
70
|
-
};
|
|
71
|
-
exports.createIdMap = createIdMap;
|
|
72
|
-
//# sourceMappingURL=id-map.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"id-map.js","sources":["../../../../src/services/document-service/transform/id-map.ts"],"sourcesContent":["import { Strapi, Entity } from '@strapi/types';\nimport { mapAsync } from '@strapi/utils';\n\n/**\n * TODO: Find a better way to encode keys than this\n * This converts an object into a string by joining its keys and values,\n * so it can be used as a key in a Map.\n *\n * @example\n * const obj = { a: 1, b: 2 };\n * const key = encodeKey(obj);\n * ^ \"a:::1&&b:::2\"\n */\nconst encodeKey = (obj: any) => {\n // Sort keys to always keep the same order when encoding\n const keys = Object.keys(obj).sort();\n return keys.map((key) => `${key}:::${obj[key]}`).join('&&');\n};\n\ninterface KeyFields {\n uid: string;\n documentId: Entity.ID;\n locale?: string | null;\n isDraft?: boolean;\n}\n\nexport interface IdMap {\n loadedIds: Map<string, string>;\n toLoadIds: Map<string, KeyFields>;\n // Make the Keys type to be the params of add\n add(keys: KeyFields): void;\n load(): Promise<void>;\n get(keys: KeyFields): string | undefined;\n clear(): void;\n}\n\n/**\n * Holds a registry of document ids and their corresponding entity ids.\n */\nconst createIdMap = ({ strapi }: { strapi: Strapi }): IdMap => {\n const loadedIds = new Map();\n const toLoadIds = new Map();\n\n return {\n loadedIds,\n toLoadIds,\n /**\n * Register a new document id and its corresponding entity id.\n */\n add(keyFields: KeyFields) {\n const key = encodeKey({ isDraft: false, locale: null, ...keyFields });\n\n // If the id is already loaded, do nothing\n if (loadedIds.has(key)) return;\n // If the id is already in the toLoadIds, do nothing\n if (toLoadIds.has(key)) return;\n\n // Add the id to the toLoadIds\n toLoadIds.set(key, keyFields);\n },\n\n /**\n * Load all ids from the registry.\n */\n async load() {\n // Document Id to Entry Id queries are batched by its uid and locale\n // TODO: Add publication state too\n const loadIdValues = Array.from(toLoadIds.values());\n\n // 1. Group ids to query together\n const idsByUidAndLocale = loadIdValues.reduce((acc, { documentId, ...rest }) => {\n const key = encodeKey(rest);\n const ids = acc[key] || { ...rest, documentIds: [] };\n ids.documentIds.push(documentId);\n return { ...acc, [key]: ids };\n }, {});\n\n // 2. Query ids\n await mapAsync(\n Object.values(idsByUidAndLocale),\n async ({ uid, locale, documentIds, isDraft }: any) => {\n const result = await strapi?.db?.query(uid).findMany({\n select: ['id', 'documentId', 'locale', 'publishedAt'],\n where: {\n documentId: { $in: documentIds },\n locale,\n publishedAt: isDraft ? null : { $ne: null },\n },\n });\n\n // 3. Store result in loadedIds\n result?.forEach(({ documentId, id, locale, publishedAt }: any) => {\n const key = encodeKey({ documentId, uid, locale, isDraft: !publishedAt });\n loadedIds.set(key, id);\n });\n }\n );\n\n // 4. Clear toLoadIds\n toLoadIds.clear();\n },\n\n /**\n * Get the entity id for a given document id.\n */\n get(keys: KeyFields) {\n const key = encodeKey({ isDraft: false, locale: null, ...keys });\n return loadedIds.get(key);\n },\n\n /**\n * Clear the registry.\n */\n clear() {\n loadedIds.clear();\n toLoadIds.clear();\n },\n };\n};\n\nexport { createIdMap };\n"],"names":["mapAsync","locale"],"mappings":";;;AAaA,MAAM,YAAY,CAAC,QAAa;AAE9B,QAAM,OAAO,OAAO,KAAK,GAAG,EAAE,KAAK;AACnC,SAAO,KAAK,IAAI,CAAC,QAAQ,GAAG,GAAG,MAAM,IAAI,GAAG,CAAC,EAAE,EAAE,KAAK,IAAI;AAC5D;AAsBA,MAAM,cAAc,CAAC,EAAE,aAAwC;AACvD,QAAA,gCAAgB;AAChB,QAAA,gCAAgB;AAEf,SAAA;AAAA,IACL;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAIA,IAAI,WAAsB;AAClB,YAAA,MAAM,UAAU,EAAE,SAAS,OAAO,QAAQ,MAAM,GAAG,UAAA,CAAW;AAGhE,UAAA,UAAU,IAAI,GAAG;AAAG;AAEpB,UAAA,UAAU,IAAI,GAAG;AAAG;AAGd,gBAAA,IAAI,KAAK,SAAS;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,IAKA,MAAM,OAAO;AAGX,YAAM,eAAe,MAAM,KAAK,UAAU,OAAQ,CAAA;AAG5C,YAAA,oBAAoB,aAAa,OAAO,CAAC,KAAK,EAAE,YAAY,GAAG,WAAW;AACxE,cAAA,MAAM,UAAU,IAAI;AACpB,cAAA,MAAM,IAAI,GAAG,KAAK,EAAE,GAAG,MAAM,aAAa,CAAA;AAC5C,YAAA,YAAY,KAAK,UAAU;AAC/B,eAAO,EAAE,GAAG,KAAK,CAAC,GAAG,GAAG,IAAI;AAAA,MAC9B,GAAG,CAAE,CAAA;AAGC,YAAAA,YAAA;AAAA,QACJ,OAAO,OAAO,iBAAiB;AAAA,QAC/B,OAAO,EAAE,KAAK,QAAQ,aAAa,cAAmB;AACpD,gBAAM,SAAS,MAAM,QAAQ,IAAI,MAAM,GAAG,EAAE,SAAS;AAAA,YACnD,QAAQ,CAAC,MAAM,cAAc,UAAU,aAAa;AAAA,YACpD,OAAO;AAAA,cACL,YAAY,EAAE,KAAK,YAAY;AAAA,cAC/B;AAAA,cACA,aAAa,UAAU,OAAO,EAAE,KAAK,KAAK;AAAA,YAC5C;AAAA,UAAA,CACD;AAGO,kBAAA,QAAQ,CAAC,EAAE,YAAY,IAAI,QAAAC,SAAQ,kBAAuB;AAC1D,kBAAA,MAAM,UAAU,EAAE,YAAY,KAAK,QAAAA,SAAQ,SAAS,CAAC,YAAA,CAAa;AAC9D,sBAAA,IAAI,KAAK,EAAE;AAAA,UAAA,CACtB;AAAA,QACH;AAAA,MAAA;AAIF,gBAAU,MAAM;AAAA,IAClB;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,MAAiB;AACb,YAAA,MAAM,UAAU,EAAE,SAAS,OAAO,QAAQ,MAAM,GAAG,KAAA,CAAM;AACxD,aAAA,UAAU,IAAI,GAAG;AAAA,IAC1B;AAAA;AAAA;AAAA;AAAA,IAKA,QAAQ;AACN,gBAAU,MAAM;AAChB,gBAAU,MAAM;AAAA,IAClB;AAAA,EAAA;AAEJ;;"}
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import { mapAsync } from "@strapi/utils";
|
|
2
|
-
const encodeKey = (obj) => {
|
|
3
|
-
const keys = Object.keys(obj).sort();
|
|
4
|
-
return keys.map((key) => `${key}:::${obj[key]}`).join("&&");
|
|
5
|
-
};
|
|
6
|
-
const createIdMap = ({ strapi }) => {
|
|
7
|
-
const loadedIds = /* @__PURE__ */ new Map();
|
|
8
|
-
const toLoadIds = /* @__PURE__ */ new Map();
|
|
9
|
-
return {
|
|
10
|
-
loadedIds,
|
|
11
|
-
toLoadIds,
|
|
12
|
-
/**
|
|
13
|
-
* Register a new document id and its corresponding entity id.
|
|
14
|
-
*/
|
|
15
|
-
add(keyFields) {
|
|
16
|
-
const key = encodeKey({ isDraft: false, locale: null, ...keyFields });
|
|
17
|
-
if (loadedIds.has(key))
|
|
18
|
-
return;
|
|
19
|
-
if (toLoadIds.has(key))
|
|
20
|
-
return;
|
|
21
|
-
toLoadIds.set(key, keyFields);
|
|
22
|
-
},
|
|
23
|
-
/**
|
|
24
|
-
* Load all ids from the registry.
|
|
25
|
-
*/
|
|
26
|
-
async load() {
|
|
27
|
-
const loadIdValues = Array.from(toLoadIds.values());
|
|
28
|
-
const idsByUidAndLocale = loadIdValues.reduce((acc, { documentId, ...rest }) => {
|
|
29
|
-
const key = encodeKey(rest);
|
|
30
|
-
const ids = acc[key] || { ...rest, documentIds: [] };
|
|
31
|
-
ids.documentIds.push(documentId);
|
|
32
|
-
return { ...acc, [key]: ids };
|
|
33
|
-
}, {});
|
|
34
|
-
await mapAsync(
|
|
35
|
-
Object.values(idsByUidAndLocale),
|
|
36
|
-
async ({ uid, locale, documentIds, isDraft }) => {
|
|
37
|
-
const result = await strapi?.db?.query(uid).findMany({
|
|
38
|
-
select: ["id", "documentId", "locale", "publishedAt"],
|
|
39
|
-
where: {
|
|
40
|
-
documentId: { $in: documentIds },
|
|
41
|
-
locale,
|
|
42
|
-
publishedAt: isDraft ? null : { $ne: null }
|
|
43
|
-
}
|
|
44
|
-
});
|
|
45
|
-
result?.forEach(({ documentId, id, locale: locale2, publishedAt }) => {
|
|
46
|
-
const key = encodeKey({ documentId, uid, locale: locale2, isDraft: !publishedAt });
|
|
47
|
-
loadedIds.set(key, id);
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
);
|
|
51
|
-
toLoadIds.clear();
|
|
52
|
-
},
|
|
53
|
-
/**
|
|
54
|
-
* Get the entity id for a given document id.
|
|
55
|
-
*/
|
|
56
|
-
get(keys) {
|
|
57
|
-
const key = encodeKey({ isDraft: false, locale: null, ...keys });
|
|
58
|
-
return loadedIds.get(key);
|
|
59
|
-
},
|
|
60
|
-
/**
|
|
61
|
-
* Clear the registry.
|
|
62
|
-
*/
|
|
63
|
-
clear() {
|
|
64
|
-
loadedIds.clear();
|
|
65
|
-
toLoadIds.clear();
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
};
|
|
69
|
-
export {
|
|
70
|
-
createIdMap
|
|
71
|
-
};
|
|
72
|
-
//# sourceMappingURL=id-map.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"id-map.mjs","sources":["../../../../src/services/document-service/transform/id-map.ts"],"sourcesContent":["import { Strapi, Entity } from '@strapi/types';\nimport { mapAsync } from '@strapi/utils';\n\n/**\n * TODO: Find a better way to encode keys than this\n * This converts an object into a string by joining its keys and values,\n * so it can be used as a key in a Map.\n *\n * @example\n * const obj = { a: 1, b: 2 };\n * const key = encodeKey(obj);\n * ^ \"a:::1&&b:::2\"\n */\nconst encodeKey = (obj: any) => {\n // Sort keys to always keep the same order when encoding\n const keys = Object.keys(obj).sort();\n return keys.map((key) => `${key}:::${obj[key]}`).join('&&');\n};\n\ninterface KeyFields {\n uid: string;\n documentId: Entity.ID;\n locale?: string | null;\n isDraft?: boolean;\n}\n\nexport interface IdMap {\n loadedIds: Map<string, string>;\n toLoadIds: Map<string, KeyFields>;\n // Make the Keys type to be the params of add\n add(keys: KeyFields): void;\n load(): Promise<void>;\n get(keys: KeyFields): string | undefined;\n clear(): void;\n}\n\n/**\n * Holds a registry of document ids and their corresponding entity ids.\n */\nconst createIdMap = ({ strapi }: { strapi: Strapi }): IdMap => {\n const loadedIds = new Map();\n const toLoadIds = new Map();\n\n return {\n loadedIds,\n toLoadIds,\n /**\n * Register a new document id and its corresponding entity id.\n */\n add(keyFields: KeyFields) {\n const key = encodeKey({ isDraft: false, locale: null, ...keyFields });\n\n // If the id is already loaded, do nothing\n if (loadedIds.has(key)) return;\n // If the id is already in the toLoadIds, do nothing\n if (toLoadIds.has(key)) return;\n\n // Add the id to the toLoadIds\n toLoadIds.set(key, keyFields);\n },\n\n /**\n * Load all ids from the registry.\n */\n async load() {\n // Document Id to Entry Id queries are batched by its uid and locale\n // TODO: Add publication state too\n const loadIdValues = Array.from(toLoadIds.values());\n\n // 1. Group ids to query together\n const idsByUidAndLocale = loadIdValues.reduce((acc, { documentId, ...rest }) => {\n const key = encodeKey(rest);\n const ids = acc[key] || { ...rest, documentIds: [] };\n ids.documentIds.push(documentId);\n return { ...acc, [key]: ids };\n }, {});\n\n // 2. Query ids\n await mapAsync(\n Object.values(idsByUidAndLocale),\n async ({ uid, locale, documentIds, isDraft }: any) => {\n const result = await strapi?.db?.query(uid).findMany({\n select: ['id', 'documentId', 'locale', 'publishedAt'],\n where: {\n documentId: { $in: documentIds },\n locale,\n publishedAt: isDraft ? null : { $ne: null },\n },\n });\n\n // 3. Store result in loadedIds\n result?.forEach(({ documentId, id, locale, publishedAt }: any) => {\n const key = encodeKey({ documentId, uid, locale, isDraft: !publishedAt });\n loadedIds.set(key, id);\n });\n }\n );\n\n // 4. Clear toLoadIds\n toLoadIds.clear();\n },\n\n /**\n * Get the entity id for a given document id.\n */\n get(keys: KeyFields) {\n const key = encodeKey({ isDraft: false, locale: null, ...keys });\n return loadedIds.get(key);\n },\n\n /**\n * Clear the registry.\n */\n clear() {\n loadedIds.clear();\n toLoadIds.clear();\n },\n };\n};\n\nexport { createIdMap };\n"],"names":["locale"],"mappings":";AAaA,MAAM,YAAY,CAAC,QAAa;AAE9B,QAAM,OAAO,OAAO,KAAK,GAAG,EAAE,KAAK;AACnC,SAAO,KAAK,IAAI,CAAC,QAAQ,GAAG,GAAG,MAAM,IAAI,GAAG,CAAC,EAAE,EAAE,KAAK,IAAI;AAC5D;AAsBA,MAAM,cAAc,CAAC,EAAE,aAAwC;AACvD,QAAA,gCAAgB;AAChB,QAAA,gCAAgB;AAEf,SAAA;AAAA,IACL;AAAA,IACA;AAAA;AAAA;AAAA;AAAA,IAIA,IAAI,WAAsB;AAClB,YAAA,MAAM,UAAU,EAAE,SAAS,OAAO,QAAQ,MAAM,GAAG,UAAA,CAAW;AAGhE,UAAA,UAAU,IAAI,GAAG;AAAG;AAEpB,UAAA,UAAU,IAAI,GAAG;AAAG;AAGd,gBAAA,IAAI,KAAK,SAAS;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,IAKA,MAAM,OAAO;AAGX,YAAM,eAAe,MAAM,KAAK,UAAU,OAAQ,CAAA;AAG5C,YAAA,oBAAoB,aAAa,OAAO,CAAC,KAAK,EAAE,YAAY,GAAG,WAAW;AACxE,cAAA,MAAM,UAAU,IAAI;AACpB,cAAA,MAAM,IAAI,GAAG,KAAK,EAAE,GAAG,MAAM,aAAa,CAAA;AAC5C,YAAA,YAAY,KAAK,UAAU;AAC/B,eAAO,EAAE,GAAG,KAAK,CAAC,GAAG,GAAG,IAAI;AAAA,MAC9B,GAAG,CAAE,CAAA;AAGC,YAAA;AAAA,QACJ,OAAO,OAAO,iBAAiB;AAAA,QAC/B,OAAO,EAAE,KAAK,QAAQ,aAAa,cAAmB;AACpD,gBAAM,SAAS,MAAM,QAAQ,IAAI,MAAM,GAAG,EAAE,SAAS;AAAA,YACnD,QAAQ,CAAC,MAAM,cAAc,UAAU,aAAa;AAAA,YACpD,OAAO;AAAA,cACL,YAAY,EAAE,KAAK,YAAY;AAAA,cAC/B;AAAA,cACA,aAAa,UAAU,OAAO,EAAE,KAAK,KAAK;AAAA,YAC5C;AAAA,UAAA,CACD;AAGO,kBAAA,QAAQ,CAAC,EAAE,YAAY,IAAI,QAAAA,SAAQ,kBAAuB;AAC1D,kBAAA,MAAM,UAAU,EAAE,YAAY,KAAK,QAAAA,SAAQ,SAAS,CAAC,YAAA,CAAa;AAC9D,sBAAA,IAAI,KAAK,EAAE;AAAA,UAAA,CACtB;AAAA,QACH;AAAA,MAAA;AAIF,gBAAU,MAAM;AAAA,IAClB;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,MAAiB;AACb,YAAA,MAAM,UAAU,EAAE,SAAS,OAAO,QAAQ,MAAM,GAAG,KAAA,CAAM;AACxD,aAAA,UAAU,IAAI,GAAG;AAAA,IAC1B;AAAA;AAAA;AAAA;AAAA,IAKA,QAAQ;AACN,gBAAU,MAAM;AAChB,gBAAU,MAAM;AAAA,IAClB;AAAA,EAAA;AAEJ;"}
|