@strapi/core 5.9.0 → 5.10.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/configuration/index.d.ts.map +1 -1
- package/dist/index.js +9954 -27
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +9932 -29
- package/dist/index.mjs.map +1 -1
- package/dist/middlewares/body.d.ts.map +1 -1
- package/dist/migrations/draft-publish.d.ts +1 -1
- package/dist/migrations/draft-publish.d.ts.map +1 -1
- package/dist/services/document-service/draft-and-publish.d.ts +1 -1
- package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
- package/dist/services/document-service/events.d.ts +1 -1
- package/dist/services/document-service/events.d.ts.map +1 -1
- package/dist/services/document-service/transform/id-map.d.ts +1 -1
- package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
- package/dist/services/document-service/transform/id-transform.d.ts +1 -1
- package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
- package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
- package/dist/services/document-service/utils/populate.d.ts +1 -1
- package/dist/services/document-service/utils/populate.d.ts.map +1 -1
- package/dist/services/document-service/utils/unidirectional-relations.d.ts +1 -1
- package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
- package/dist/services/entity-validator/index.d.ts +1 -1
- package/dist/services/entity-validator/index.d.ts.map +1 -1
- package/dist/utils/update-notifier/index.d.ts.map +1 -1
- package/package.json +22 -22
- package/dist/Strapi.js +0 -437
- package/dist/Strapi.js.map +0 -1
- package/dist/Strapi.mjs +0 -416
- 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 -105
- package/dist/configuration/config-loader.js.map +0 -1
- package/dist/configuration/config-loader.mjs +0 -103
- package/dist/configuration/config-loader.mjs.map +0 -1
- package/dist/configuration/get-dirs.js +0 -31
- package/dist/configuration/get-dirs.js.map +0 -1
- package/dist/configuration/get-dirs.mjs +0 -31
- package/dist/configuration/get-dirs.mjs.map +0 -1
- package/dist/configuration/index.js +0 -85
- package/dist/configuration/index.js.map +0 -1
- package/dist/configuration/index.mjs +0 -80
- package/dist/configuration/index.mjs.map +0 -1
- package/dist/configuration/urls.js +0 -68
- package/dist/configuration/urls.js.map +0 -1
- package/dist/configuration/urls.mjs +0 -66
- package/dist/configuration/urls.mjs.map +0 -1
- package/dist/container.js +0 -30
- package/dist/container.js.map +0 -1
- package/dist/container.mjs +0 -30
- package/dist/container.mjs.map +0 -1
- package/dist/core-api/controller/collection-type.js +0 -84
- package/dist/core-api/controller/collection-type.js.map +0 -1
- package/dist/core-api/controller/collection-type.mjs +0 -84
- 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 -46
- package/dist/core-api/controller/single-type.js.map +0 -1
- package/dist/core-api/controller/single-type.mjs +0 -46
- package/dist/core-api/controller/single-type.mjs.map +0 -1
- package/dist/core-api/controller/transform.js +0 -76
- package/dist/core-api/controller/transform.js.map +0 -1
- package/dist/core-api/controller/transform.mjs +0 -76
- 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 -67
- package/dist/core-api/service/collection-type.js.map +0 -1
- package/dist/core-api/service/collection-type.mjs +0 -67
- 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 -52
- package/dist/core-api/service/pagination.js.map +0 -1
- package/dist/core-api/service/pagination.mjs +0 -52
- package/dist/core-api/service/pagination.mjs.map +0 -1
- package/dist/core-api/service/single-type.js +0 -45
- package/dist/core-api/service/single-type.js.map +0 -1
- package/dist/core-api/service/single-type.mjs +0 -45
- package/dist/core-api/service/single-type.mjs.map +0 -1
- package/dist/domain/content-type/index.js +0 -111
- package/dist/domain/content-type/index.js.map +0 -1
- package/dist/domain/content-type/index.mjs +0 -109
- package/dist/domain/content-type/index.mjs.map +0 -1
- package/dist/domain/content-type/validator.js +0 -77
- package/dist/domain/content-type/validator.js.map +0 -1
- package/dist/domain/content-type/validator.mjs +0 -75
- package/dist/domain/content-type/validator.mjs.map +0 -1
- package/dist/domain/module/index.js +0 -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 -158
- package/dist/ee/index.js.map +0 -1
- package/dist/ee/index.mjs +0 -159
- package/dist/ee/index.mjs.map +0 -1
- package/dist/ee/license.js +0 -91
- package/dist/ee/license.js.map +0 -1
- package/dist/ee/license.mjs +0 -88
- package/dist/ee/license.mjs.map +0 -1
- package/dist/factories.js +0 -80
- package/dist/factories.js.map +0 -1
- package/dist/factories.mjs +0 -80
- package/dist/factories.mjs.map +0 -1
- package/dist/loaders/admin.js +0 -26
- package/dist/loaders/admin.js.map +0 -1
- package/dist/loaders/admin.mjs +0 -25
- 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 -24
- package/dist/loaders/index.js.map +0 -1
- package/dist/loaders/index.mjs +0 -24
- 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 -141
- package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
- package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -117
- 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 -144
- package/dist/loaders/plugins/index.js.map +0 -1
- package/dist/loaders/plugins/index.mjs +0 -125
- 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 -53
- package/dist/middlewares/cors.js.map +0 -1
- package/dist/middlewares/cors.mjs +0 -51
- 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 -78
- package/dist/middlewares/security.js.map +0 -1
- package/dist/middlewares/security.mjs +0 -76
- package/dist/middlewares/security.mjs.map +0 -1
- package/dist/middlewares/session.js +0 -30
- package/dist/middlewares/session.js.map +0 -1
- package/dist/middlewares/session.mjs +0 -28
- package/dist/middlewares/session.mjs.map +0 -1
- package/dist/migrations/database/5.0.0-discard-drafts.js +0 -109
- package/dist/migrations/database/5.0.0-discard-drafts.js.map +0 -1
- package/dist/migrations/database/5.0.0-discard-drafts.mjs +0 -109
- package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +0 -1
- package/dist/migrations/draft-publish.js +0 -42
- package/dist/migrations/draft-publish.js.map +0 -1
- package/dist/migrations/draft-publish.mjs +0 -42
- package/dist/migrations/draft-publish.mjs.map +0 -1
- package/dist/migrations/i18n.js +0 -54
- package/dist/migrations/i18n.js.map +0 -1
- package/dist/migrations/i18n.mjs +0 -54
- package/dist/migrations/i18n.mjs.map +0 -1
- package/dist/migrations/index.js +0 -15
- package/dist/migrations/index.js.map +0 -1
- package/dist/migrations/index.mjs +0 -15
- package/dist/migrations/index.mjs.map +0 -1
- package/dist/providers/admin.js +0 -20
- package/dist/providers/admin.js.map +0 -1
- package/dist/providers/admin.mjs +0 -21
- package/dist/providers/admin.mjs.map +0 -1
- package/dist/providers/coreStore.js +0 -11
- package/dist/providers/coreStore.js.map +0 -1
- package/dist/providers/coreStore.mjs +0 -12
- package/dist/providers/coreStore.mjs.map +0 -1
- package/dist/providers/cron.js +0 -20
- package/dist/providers/cron.js.map +0 -1
- package/dist/providers/cron.mjs +0 -21
- package/dist/providers/cron.mjs.map +0 -1
- package/dist/providers/index.js +0 -11
- package/dist/providers/index.js.map +0 -1
- package/dist/providers/index.mjs +0 -11
- package/dist/providers/index.mjs.map +0 -1
- package/dist/providers/provider.js +0 -5
- package/dist/providers/provider.js.map +0 -1
- package/dist/providers/provider.mjs +0 -5
- package/dist/providers/provider.mjs.map +0 -1
- package/dist/providers/registries.js +0 -35
- package/dist/providers/registries.js.map +0 -1
- package/dist/providers/registries.mjs +0 -36
- package/dist/providers/registries.mjs.map +0 -1
- package/dist/providers/telemetry.js +0 -19
- package/dist/providers/telemetry.js.map +0 -1
- package/dist/providers/telemetry.mjs +0 -20
- package/dist/providers/telemetry.mjs.map +0 -1
- package/dist/providers/webhooks.js +0 -30
- package/dist/providers/webhooks.js.map +0 -1
- package/dist/providers/webhooks.mjs +0 -31
- package/dist/providers/webhooks.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/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 -108
- package/dist/registries/policies.js.map +0 -1
- package/dist/registries/policies.mjs +0 -109
- 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/config.js +0 -47
- package/dist/services/config.js.map +0 -1
- package/dist/services/config.mjs +0 -47
- package/dist/services/config.mjs.map +0 -1
- package/dist/services/content-api/index.js +0 -85
- package/dist/services/content-api/index.js.map +0 -1
- package/dist/services/content-api/index.mjs +0 -84
- 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 -67
- package/dist/services/cron.js.map +0 -1
- package/dist/services/cron.mjs +0 -68
- 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/attributes/index.js +0 -22
- package/dist/services/document-service/attributes/index.js.map +0 -1
- package/dist/services/document-service/attributes/index.mjs +0 -22
- package/dist/services/document-service/attributes/index.mjs.map +0 -1
- package/dist/services/document-service/attributes/transforms.js +0 -20
- package/dist/services/document-service/attributes/transforms.js.map +0 -1
- package/dist/services/document-service/attributes/transforms.mjs +0 -19
- package/dist/services/document-service/attributes/transforms.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/components.js +0 -288
- package/dist/services/document-service/components.js.map +0 -1
- package/dist/services/document-service/components.mjs +0 -286
- package/dist/services/document-service/components.mjs.map +0 -1
- package/dist/services/document-service/draft-and-publish.js +0 -69
- package/dist/services/document-service/draft-and-publish.js.map +0 -1
- package/dist/services/document-service/draft-and-publish.mjs +0 -69
- package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
- package/dist/services/document-service/entries.js +0 -95
- package/dist/services/document-service/entries.js.map +0 -1
- package/dist/services/document-service/entries.mjs +0 -95
- package/dist/services/document-service/entries.mjs.map +0 -1
- package/dist/services/document-service/events.js +0 -47
- package/dist/services/document-service/events.js.map +0 -1
- package/dist/services/document-service/events.mjs +0 -47
- package/dist/services/document-service/events.mjs.map +0 -1
- package/dist/services/document-service/index.js +0 -36
- package/dist/services/document-service/index.js.map +0 -1
- package/dist/services/document-service/index.mjs +0 -36
- package/dist/services/document-service/index.mjs.map +0 -1
- package/dist/services/document-service/internationalization.js +0 -63
- package/dist/services/document-service/internationalization.js.map +0 -1
- package/dist/services/document-service/internationalization.mjs +0 -63
- package/dist/services/document-service/internationalization.mjs.map +0 -1
- package/dist/services/document-service/middlewares/errors.js +0 -25
- package/dist/services/document-service/middlewares/errors.js.map +0 -1
- package/dist/services/document-service/middlewares/errors.mjs +0 -25
- package/dist/services/document-service/middlewares/errors.mjs.map +0 -1
- package/dist/services/document-service/middlewares/middleware-manager.js +0 -49
- package/dist/services/document-service/middlewares/middleware-manager.js.map +0 -1
- package/dist/services/document-service/middlewares/middleware-manager.mjs +0 -49
- package/dist/services/document-service/middlewares/middleware-manager.mjs.map +0 -1
- package/dist/services/document-service/params.js +0 -8
- package/dist/services/document-service/params.js.map +0 -1
- package/dist/services/document-service/params.mjs +0 -8
- package/dist/services/document-service/params.mjs.map +0 -1
- package/dist/services/document-service/repository.js +0 -332
- package/dist/services/document-service/repository.js.map +0 -1
- package/dist/services/document-service/repository.mjs +0 -332
- package/dist/services/document-service/repository.mjs.map +0 -1
- package/dist/services/document-service/transform/data.js +0 -15
- package/dist/services/document-service/transform/data.js.map +0 -1
- package/dist/services/document-service/transform/data.mjs +0 -15
- 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/id-map.js +0 -85
- package/dist/services/document-service/transform/id-map.js.map +0 -1
- package/dist/services/document-service/transform/id-map.mjs +0 -85
- package/dist/services/document-service/transform/id-map.mjs.map +0 -1
- package/dist/services/document-service/transform/id-transform.js +0 -33
- package/dist/services/document-service/transform/id-transform.js.map +0 -1
- package/dist/services/document-service/transform/id-transform.mjs +0 -33
- package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
- package/dist/services/document-service/transform/populate.js +0 -21
- package/dist/services/document-service/transform/populate.js.map +0 -1
- package/dist/services/document-service/transform/populate.mjs +0 -21
- package/dist/services/document-service/transform/populate.mjs.map +0 -1
- package/dist/services/document-service/transform/query.js +0 -9
- package/dist/services/document-service/transform/query.js.map +0 -1
- package/dist/services/document-service/transform/query.mjs +0 -9
- package/dist/services/document-service/transform/query.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -64
- 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 -64
- 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 -85
- 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 -85
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/transform/default-locale.js +0 -32
- package/dist/services/document-service/transform/relations/transform/default-locale.js.map +0 -1
- package/dist/services/document-service/transform/relations/transform/default-locale.mjs +0 -32
- package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/utils/dp.js +0 -30
- package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
- package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -30
- package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/utils/i18n.js +0 -25
- package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
- package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -25
- package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/utils/map-relation.js +0 -84
- package/dist/services/document-service/transform/relations/utils/map-relation.js.map +0 -1
- package/dist/services/document-service/transform/relations/utils/map-relation.mjs +0 -84
- package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +0 -1
- package/dist/services/document-service/utils/populate.js +0 -47
- package/dist/services/document-service/utils/populate.js.map +0 -1
- package/dist/services/document-service/utils/populate.mjs +0 -47
- package/dist/services/document-service/utils/populate.mjs.map +0 -1
- package/dist/services/document-service/utils/unidirectional-relations.js +0 -68
- package/dist/services/document-service/utils/unidirectional-relations.js.map +0 -1
- package/dist/services/document-service/utils/unidirectional-relations.mjs +0 -68
- package/dist/services/document-service/utils/unidirectional-relations.mjs.map +0 -1
- package/dist/services/entity-service/index.js +0 -169
- package/dist/services/entity-service/index.js.map +0 -1
- package/dist/services/entity-service/index.mjs +0 -167
- package/dist/services/entity-service/index.mjs.map +0 -1
- package/dist/services/entity-validator/blocks-validator.js +0 -128
- 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 -389
- package/dist/services/entity-validator/index.js.map +0 -1
- package/dist/services/entity-validator/index.mjs +0 -388
- package/dist/services/entity-validator/index.mjs.map +0 -1
- package/dist/services/entity-validator/validators.js +0 -241
- package/dist/services/entity-validator/validators.js.map +0 -1
- package/dist/services/entity-validator/validators.mjs +0 -239
- 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 -72
- package/dist/services/event-hub.js.map +0 -1
- package/dist/services/event-hub.mjs +0 -73
- 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 -44
- package/dist/services/metrics/index.js.map +0 -1
- package/dist/services/metrics/index.mjs +0 -45
- 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 -27
- package/dist/services/metrics/middleware.js.map +0 -1
- package/dist/services/metrics/middleware.mjs +0 -28
- package/dist/services/metrics/middleware.mjs.map +0 -1
- package/dist/services/metrics/rate-limiter.js +0 -24
- package/dist/services/metrics/rate-limiter.js.map +0 -1
- package/dist/services/metrics/rate-limiter.mjs +0 -25
- 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/query-params.js +0 -12
- package/dist/services/query-params.js.map +0 -1
- package/dist/services/query-params.mjs +0 -13
- package/dist/services/query-params.mjs.map +0 -1
- package/dist/services/reloader.js +0 -36
- package/dist/services/reloader.js.map +0 -1
- package/dist/services/reloader.mjs +0 -36
- package/dist/services/reloader.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 -117
- package/dist/services/server/compose-endpoint.js.map +0 -1
- package/dist/services/server/compose-endpoint.mjs +0 -116
- 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 -87
- package/dist/services/server/index.js.map +0 -1
- package/dist/services/server/index.mjs +0 -85
- 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 -17
- package/dist/services/utils/dynamic-zones.js.map +0 -1
- package/dist/services/utils/dynamic-zones.mjs +0 -18
- package/dist/services/utils/dynamic-zones.mjs.map +0 -1
- package/dist/services/webhook-runner.js +0 -133
- package/dist/services/webhook-runner.js.map +0 -1
- package/dist/services/webhook-runner.mjs +0 -131
- package/dist/services/webhook-runner.mjs.map +0 -1
- package/dist/services/webhook-store.js +0 -110
- package/dist/services/webhook-store.js.map +0 -1
- package/dist/services/webhook-store.mjs +0 -110
- 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 -21
- package/dist/utils/fetch.js.map +0 -1
- package/dist/utils/fetch.mjs +0 -21
- package/dist/utils/fetch.mjs.map +0 -1
- package/dist/utils/filepath-to-prop-path.js +0 -33
- package/dist/utils/filepath-to-prop-path.js.map +0 -1
- package/dist/utils/filepath-to-prop-path.mjs +0 -30
- package/dist/utils/filepath-to-prop-path.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 -38
- package/dist/utils/load-files.js.map +0 -1
- package/dist/utils/load-files.mjs +0 -34
- 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/resolve-working-dirs.js +0 -13
- package/dist/utils/resolve-working-dirs.js.map +0 -1
- package/dist/utils/resolve-working-dirs.mjs +0 -11
- package/dist/utils/resolve-working-dirs.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 -86
- package/dist/utils/startup-logger.js.map +0 -1
- package/dist/utils/startup-logger.mjs +0 -82
- package/dist/utils/startup-logger.mjs.map +0 -1
- package/dist/utils/transform-content-types-to-models.js +0 -288
- package/dist/utils/transform-content-types-to-models.js.map +0 -1
- package/dist/utils/transform-content-types-to-models.mjs +0 -285
- package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
- package/dist/utils/update-notifier/index.js +0 -85
- package/dist/utils/update-notifier/index.js.map +0 -1
- package/dist/utils/update-notifier/index.mjs +0 -78
- package/dist/utils/update-notifier/index.mjs.map +0 -1
@@ -1,388 +0,0 @@
|
|
1
|
-
import { isNil, castArray, mergeWith, isArray, uniqBy } from "lodash";
|
2
|
-
import { isObject, isEmpty, prop, has } from "lodash/fp";
|
3
|
-
import strapiUtils from "@strapi/utils";
|
4
|
-
import { Validators } from "./validators.mjs";
|
5
|
-
const { yup, validateYupSchema } = strapiUtils;
|
6
|
-
const { isMediaAttribute, isScalarAttribute, getWritableAttributes } = strapiUtils.contentTypes;
|
7
|
-
const { ValidationError } = strapiUtils.errors;
|
8
|
-
const isInteger = (value) => Number.isInteger(value);
|
9
|
-
const addMinMax = (validator, {
|
10
|
-
attr,
|
11
|
-
updatedAttribute
|
12
|
-
}) => {
|
13
|
-
let nextValidator = validator;
|
14
|
-
if (isInteger(attr.min) && ("required" in attr && attr.required || Array.isArray(updatedAttribute.value) && updatedAttribute.value.length > 0)) {
|
15
|
-
nextValidator = nextValidator.min(attr.min);
|
16
|
-
}
|
17
|
-
if (isInteger(attr.max)) {
|
18
|
-
nextValidator = nextValidator.max(attr.max);
|
19
|
-
}
|
20
|
-
return nextValidator;
|
21
|
-
};
|
22
|
-
const addRequiredValidation = (createOrUpdate) => {
|
23
|
-
return (validator, {
|
24
|
-
attr: { required }
|
25
|
-
}) => {
|
26
|
-
let nextValidator = validator;
|
27
|
-
if (required) {
|
28
|
-
if (createOrUpdate === "creation") {
|
29
|
-
nextValidator = nextValidator.notNil();
|
30
|
-
} else if (createOrUpdate === "update") {
|
31
|
-
nextValidator = nextValidator.notNull();
|
32
|
-
}
|
33
|
-
} else {
|
34
|
-
nextValidator = nextValidator.nullable();
|
35
|
-
}
|
36
|
-
return nextValidator;
|
37
|
-
};
|
38
|
-
};
|
39
|
-
const addDefault = (createOrUpdate) => {
|
40
|
-
return (validator, { attr }) => {
|
41
|
-
let nextValidator = validator;
|
42
|
-
if (createOrUpdate === "creation") {
|
43
|
-
if ((attr.type === "component" && attr.repeatable || attr.type === "dynamiczone") && !attr.required) {
|
44
|
-
nextValidator = nextValidator.default([]);
|
45
|
-
} else {
|
46
|
-
nextValidator = nextValidator.default(attr.default);
|
47
|
-
}
|
48
|
-
} else {
|
49
|
-
nextValidator = nextValidator.default(void 0);
|
50
|
-
}
|
51
|
-
return nextValidator;
|
52
|
-
};
|
53
|
-
};
|
54
|
-
const preventCast = (validator) => validator.transform((val, originalVal) => originalVal);
|
55
|
-
const createComponentValidator = (createOrUpdate) => ({
|
56
|
-
attr,
|
57
|
-
updatedAttribute,
|
58
|
-
componentContext
|
59
|
-
}, { isDraft }) => {
|
60
|
-
const model = strapi.getModel(attr.component);
|
61
|
-
if (!model) {
|
62
|
-
throw new Error("Validation failed: Model not found");
|
63
|
-
}
|
64
|
-
if (attr?.repeatable) {
|
65
|
-
let validator2 = yup.array().of(
|
66
|
-
yup.lazy(
|
67
|
-
(item) => createModelValidator(createOrUpdate)(
|
68
|
-
{ componentContext, model, data: item },
|
69
|
-
{ isDraft }
|
70
|
-
).notNull()
|
71
|
-
)
|
72
|
-
);
|
73
|
-
validator2 = addRequiredValidation(createOrUpdate)(validator2, {
|
74
|
-
attr: { required: true },
|
75
|
-
updatedAttribute
|
76
|
-
});
|
77
|
-
if (!isDraft) {
|
78
|
-
validator2 = addMinMax(validator2, { attr, updatedAttribute });
|
79
|
-
}
|
80
|
-
return validator2;
|
81
|
-
}
|
82
|
-
let validator = createModelValidator(createOrUpdate)(
|
83
|
-
{
|
84
|
-
model,
|
85
|
-
data: updatedAttribute.value,
|
86
|
-
componentContext
|
87
|
-
},
|
88
|
-
{ isDraft }
|
89
|
-
);
|
90
|
-
validator = addRequiredValidation(createOrUpdate)(validator, {
|
91
|
-
attr: { required: !isDraft && attr.required },
|
92
|
-
updatedAttribute
|
93
|
-
});
|
94
|
-
return validator;
|
95
|
-
};
|
96
|
-
const createDzValidator = (createOrUpdate) => ({ attr, updatedAttribute, componentContext }, { isDraft }) => {
|
97
|
-
let validator;
|
98
|
-
validator = yup.array().of(
|
99
|
-
yup.lazy((item) => {
|
100
|
-
const model = strapi.getModel(prop("__component", item));
|
101
|
-
const schema = yup.object().shape({
|
102
|
-
__component: yup.string().required().oneOf(Object.keys(strapi.components))
|
103
|
-
}).notNull();
|
104
|
-
return model ? schema.concat(
|
105
|
-
createModelValidator(createOrUpdate)(
|
106
|
-
{ model, data: item, componentContext },
|
107
|
-
{ isDraft }
|
108
|
-
)
|
109
|
-
) : schema;
|
110
|
-
})
|
111
|
-
// FIXME: yup v1
|
112
|
-
);
|
113
|
-
validator = addRequiredValidation(createOrUpdate)(validator, {
|
114
|
-
attr: { required: true },
|
115
|
-
updatedAttribute
|
116
|
-
});
|
117
|
-
if (!isDraft) {
|
118
|
-
validator = addMinMax(validator, { attr, updatedAttribute });
|
119
|
-
}
|
120
|
-
return validator;
|
121
|
-
};
|
122
|
-
const createRelationValidator = ({
|
123
|
-
updatedAttribute
|
124
|
-
}) => {
|
125
|
-
let validator;
|
126
|
-
if (Array.isArray(updatedAttribute.value)) {
|
127
|
-
validator = yup.array().of(yup.mixed());
|
128
|
-
} else {
|
129
|
-
validator = yup.mixed();
|
130
|
-
}
|
131
|
-
return validator;
|
132
|
-
};
|
133
|
-
const createScalarAttributeValidator = (createOrUpdate) => (metas, options) => {
|
134
|
-
let validator;
|
135
|
-
if (has(metas.attr.type, Validators)) {
|
136
|
-
validator = Validators[metas.attr.type](metas, options);
|
137
|
-
} else {
|
138
|
-
validator = yup.mixed();
|
139
|
-
}
|
140
|
-
validator = addRequiredValidation(createOrUpdate)(validator, {
|
141
|
-
attr: { required: !options.isDraft && metas.attr.required },
|
142
|
-
updatedAttribute: metas.updatedAttribute
|
143
|
-
});
|
144
|
-
return validator;
|
145
|
-
};
|
146
|
-
const createAttributeValidator = (createOrUpdate) => (metas, options) => {
|
147
|
-
let validator = yup.mixed();
|
148
|
-
if (isMediaAttribute(metas.attr)) {
|
149
|
-
validator = yup.mixed();
|
150
|
-
} else if (isScalarAttribute(metas.attr)) {
|
151
|
-
validator = createScalarAttributeValidator(createOrUpdate)(metas, options);
|
152
|
-
} else {
|
153
|
-
if (metas.attr.type === "component" && metas.componentContext) {
|
154
|
-
const pathToComponent = [
|
155
|
-
...metas?.componentContext?.pathToComponent ?? [],
|
156
|
-
metas.updatedAttribute.name
|
157
|
-
];
|
158
|
-
const repeatableData = metas.attr.repeatable && pathToComponent.length === 1 ? metas.updatedAttribute.value : metas.componentContext?.repeatableData;
|
159
|
-
const newComponentContext = {
|
160
|
-
...metas.componentContext,
|
161
|
-
pathToComponent,
|
162
|
-
repeatableData
|
163
|
-
};
|
164
|
-
validator = createComponentValidator(createOrUpdate)(
|
165
|
-
{
|
166
|
-
componentContext: newComponentContext,
|
167
|
-
attr: metas.attr,
|
168
|
-
updatedAttribute: metas.updatedAttribute
|
169
|
-
},
|
170
|
-
options
|
171
|
-
);
|
172
|
-
} else if (metas.attr.type === "dynamiczone" && metas.componentContext) {
|
173
|
-
const newComponentContext = {
|
174
|
-
...metas.componentContext,
|
175
|
-
fullDynamicZoneContent: metas.updatedAttribute.value,
|
176
|
-
pathToComponent: [...metas.componentContext.pathToComponent, metas.updatedAttribute.name]
|
177
|
-
};
|
178
|
-
Object.assign(metas, { componentContext: newComponentContext });
|
179
|
-
validator = createDzValidator(createOrUpdate)(metas, options);
|
180
|
-
} else if (metas.attr.type === "relation") {
|
181
|
-
validator = createRelationValidator({
|
182
|
-
attr: metas.attr,
|
183
|
-
updatedAttribute: metas.updatedAttribute
|
184
|
-
});
|
185
|
-
}
|
186
|
-
validator = preventCast(validator);
|
187
|
-
}
|
188
|
-
validator = addDefault(createOrUpdate)(validator, metas);
|
189
|
-
return validator;
|
190
|
-
};
|
191
|
-
const createModelValidator = (createOrUpdate) => ({ componentContext, model, data, entity }, options) => {
|
192
|
-
const writableAttributes = model ? getWritableAttributes(model) : [];
|
193
|
-
const schema = writableAttributes.reduce(
|
194
|
-
(validators, attributeName) => {
|
195
|
-
const metas = {
|
196
|
-
attr: model.attributes[attributeName],
|
197
|
-
updatedAttribute: { name: attributeName, value: prop(attributeName, data) },
|
198
|
-
model,
|
199
|
-
entity,
|
200
|
-
componentContext
|
201
|
-
};
|
202
|
-
const validator = createAttributeValidator(createOrUpdate)(metas, options);
|
203
|
-
validators[attributeName] = validator;
|
204
|
-
return validators;
|
205
|
-
},
|
206
|
-
{}
|
207
|
-
);
|
208
|
-
return yup.object().shape(schema);
|
209
|
-
};
|
210
|
-
const createValidateEntity = (createOrUpdate) => {
|
211
|
-
return async (model, data, options, entity) => {
|
212
|
-
if (!isObject(data)) {
|
213
|
-
const { displayName } = model.info;
|
214
|
-
throw new ValidationError(
|
215
|
-
`Invalid payload submitted for the ${createOrUpdate} of an entity of type ${displayName}. Expected an object, but got ${typeof data}`
|
216
|
-
);
|
217
|
-
}
|
218
|
-
const validator = createModelValidator(createOrUpdate)(
|
219
|
-
{
|
220
|
-
model,
|
221
|
-
data,
|
222
|
-
entity,
|
223
|
-
componentContext: {
|
224
|
-
// Set up the initial component context.
|
225
|
-
// Keeping track of parent content type context in which a component will be used.
|
226
|
-
// This is necessary to validate component field constraints such as uniqueness.
|
227
|
-
parentContent: {
|
228
|
-
id: entity?.id,
|
229
|
-
model,
|
230
|
-
options
|
231
|
-
},
|
232
|
-
pathToComponent: [],
|
233
|
-
repeatableData: []
|
234
|
-
}
|
235
|
-
},
|
236
|
-
{
|
237
|
-
isDraft: options?.isDraft ?? false,
|
238
|
-
locale: options?.locale ?? null
|
239
|
-
}
|
240
|
-
).test(
|
241
|
-
"relations-test",
|
242
|
-
"check that all relations exist",
|
243
|
-
async function relationsValidation(data2) {
|
244
|
-
try {
|
245
|
-
await checkRelationsExist(buildRelationsStore({ uid: model.uid, data: data2 }));
|
246
|
-
} catch (e) {
|
247
|
-
return this.createError({
|
248
|
-
path: this.path,
|
249
|
-
message: e instanceof ValidationError && e.message || "Invalid relations"
|
250
|
-
});
|
251
|
-
}
|
252
|
-
return true;
|
253
|
-
}
|
254
|
-
).required();
|
255
|
-
return validateYupSchema(validator, {
|
256
|
-
strict: false,
|
257
|
-
abortEarly: false
|
258
|
-
})(data);
|
259
|
-
};
|
260
|
-
};
|
261
|
-
const buildRelationsStore = ({
|
262
|
-
uid,
|
263
|
-
data
|
264
|
-
}) => {
|
265
|
-
if (!uid) {
|
266
|
-
throw new ValidationError(`Cannot build relations store: "uid" is undefined`);
|
267
|
-
}
|
268
|
-
if (isEmpty(data)) {
|
269
|
-
return {};
|
270
|
-
}
|
271
|
-
const currentModel = strapi.getModel(uid);
|
272
|
-
return Object.keys(currentModel.attributes).reduce(
|
273
|
-
(result, attributeName) => {
|
274
|
-
const attribute = currentModel.attributes[attributeName];
|
275
|
-
const value = data[attributeName];
|
276
|
-
if (isNil(value)) {
|
277
|
-
return result;
|
278
|
-
}
|
279
|
-
switch (attribute.type) {
|
280
|
-
case "relation":
|
281
|
-
case "media": {
|
282
|
-
if (attribute.type === "relation" && (attribute.relation === "morphToMany" || attribute.relation === "morphToOne")) {
|
283
|
-
break;
|
284
|
-
}
|
285
|
-
const target = (
|
286
|
-
// eslint-disable-next-line no-nested-ternary
|
287
|
-
attribute.type === "media" ? "plugin::upload.file" : attribute.target
|
288
|
-
);
|
289
|
-
let source;
|
290
|
-
if (Array.isArray(value)) {
|
291
|
-
source = value;
|
292
|
-
} else if (isObject(value)) {
|
293
|
-
if ("connect" in value && !isNil(value.connect)) {
|
294
|
-
source = value.connect;
|
295
|
-
} else if ("set" in value && !isNil(value.set)) {
|
296
|
-
source = value.set;
|
297
|
-
} else {
|
298
|
-
source = [];
|
299
|
-
}
|
300
|
-
} else {
|
301
|
-
source = castArray(value);
|
302
|
-
}
|
303
|
-
const idArray = source.map((v) => ({
|
304
|
-
id: typeof v === "object" ? v.id : v
|
305
|
-
}));
|
306
|
-
result[target] = result[target] || [];
|
307
|
-
result[target].push(...idArray);
|
308
|
-
break;
|
309
|
-
}
|
310
|
-
case "component": {
|
311
|
-
return castArray(value).reduce((relationsStore, componentValue) => {
|
312
|
-
if (!attribute.component) {
|
313
|
-
throw new ValidationError(
|
314
|
-
`Cannot build relations store from component, component identifier is undefined`
|
315
|
-
);
|
316
|
-
}
|
317
|
-
return mergeWith(
|
318
|
-
relationsStore,
|
319
|
-
buildRelationsStore({
|
320
|
-
uid: attribute.component,
|
321
|
-
data: componentValue
|
322
|
-
}),
|
323
|
-
(objValue, srcValue) => {
|
324
|
-
if (isArray(objValue)) {
|
325
|
-
return objValue.concat(srcValue);
|
326
|
-
}
|
327
|
-
}
|
328
|
-
);
|
329
|
-
}, result);
|
330
|
-
}
|
331
|
-
case "dynamiczone": {
|
332
|
-
return castArray(value).reduce((relationsStore, dzValue) => {
|
333
|
-
const value2 = dzValue;
|
334
|
-
if (!value2.__component) {
|
335
|
-
throw new ValidationError(
|
336
|
-
`Cannot build relations store from dynamiczone, component identifier is undefined`
|
337
|
-
);
|
338
|
-
}
|
339
|
-
return mergeWith(
|
340
|
-
relationsStore,
|
341
|
-
buildRelationsStore({
|
342
|
-
uid: value2.__component,
|
343
|
-
data: value2
|
344
|
-
}),
|
345
|
-
(objValue, srcValue) => {
|
346
|
-
if (isArray(objValue)) {
|
347
|
-
return objValue.concat(srcValue);
|
348
|
-
}
|
349
|
-
}
|
350
|
-
);
|
351
|
-
}, result);
|
352
|
-
}
|
353
|
-
}
|
354
|
-
return result;
|
355
|
-
},
|
356
|
-
{}
|
357
|
-
);
|
358
|
-
};
|
359
|
-
const checkRelationsExist = async (relationsStore = {}) => {
|
360
|
-
const promises = [];
|
361
|
-
for (const [key, value] of Object.entries(relationsStore)) {
|
362
|
-
const evaluate = async () => {
|
363
|
-
const uniqueValues = uniqBy(value, `id`);
|
364
|
-
const count = await strapi.db.query(key).count({
|
365
|
-
where: {
|
366
|
-
id: {
|
367
|
-
$in: uniqueValues.map((v) => v.id)
|
368
|
-
}
|
369
|
-
}
|
370
|
-
});
|
371
|
-
if (count !== uniqueValues.length) {
|
372
|
-
throw new ValidationError(
|
373
|
-
`${uniqueValues.length - count} relation(s) of type ${key} associated with this entity do not exist`
|
374
|
-
);
|
375
|
-
}
|
376
|
-
};
|
377
|
-
promises.push(evaluate());
|
378
|
-
}
|
379
|
-
return Promise.all(promises);
|
380
|
-
};
|
381
|
-
const entityValidator = {
|
382
|
-
validateEntityCreation: createValidateEntity("creation"),
|
383
|
-
validateEntityUpdate: createValidateEntity("update")
|
384
|
-
};
|
385
|
-
export {
|
386
|
-
entityValidator as default
|
387
|
-
};
|
388
|
-
//# sourceMappingURL=index.mjs.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../src/services/entity-validator/index.ts"],"sourcesContent":["/**\n * Entity validator\n * Module that will validate input data for entity creation or edition\n */\n\nimport { uniqBy, castArray, isNil, isArray, mergeWith } from 'lodash';\nimport { has, prop, isObject, isEmpty } from 'lodash/fp';\nimport strapiUtils from '@strapi/utils';\nimport { Modules, UID, Struct, Schema } from '@strapi/types';\nimport { Validators, ValidatorMetas } from './validators';\n\ntype CreateOrUpdate = 'creation' | 'update';\n\nconst { yup, validateYupSchema } = strapiUtils;\nconst { isMediaAttribute, isScalarAttribute, getWritableAttributes } = strapiUtils.contentTypes;\nconst { ValidationError } = strapiUtils.errors;\n\ntype ID = { id: string | number };\n\ntype RelationSource = string | number | ID;\n\nexport type ComponentContext = {\n parentContent: {\n // The model of the parent content type that contains the current component.\n model: Struct.Schema;\n // The numeric id of the parent entity that contains the component.\n id?: number;\n // The options passed to the entity validator. From which we can extract\n // entity dimensions such as locale and publication state.\n options?: ValidatorContext;\n };\n // The path to the component within the parent content type schema.\n pathToComponent: string[];\n // If working with a repeatable component this contains the\n // full data of the repeatable component in the current entity.\n repeatableData: Modules.EntityValidator.Entity[];\n fullDynamicZoneContent?: Schema.Attribute.Value<Schema.Attribute.DynamicZone>;\n};\n\ninterface WithComponentContext {\n componentContext?: ComponentContext;\n}\n\ninterface ValidatorMeta<TAttribute = Schema.Attribute.AnyAttribute> extends WithComponentContext {\n attr: TAttribute;\n updatedAttribute: { name: string; value: any };\n}\n\ninterface ValidatorContext {\n isDraft?: boolean;\n locale?: string | null;\n}\n\ninterface ModelValidatorMetas extends WithComponentContext {\n model: Struct.Schema;\n data: Record<string, unknown>;\n entity?: Modules.EntityValidator.Entity;\n}\n\nconst isInteger = (value: unknown): value is number => Number.isInteger(value);\n\nconst addMinMax = <\n T extends {\n min(value: number): T;\n max(value: number): T;\n },\n>(\n validator: T,\n {\n attr,\n updatedAttribute,\n }: ValidatorMeta<Schema.Attribute.AnyAttribute & Schema.Attribute.MinMaxOption<string | number>>\n): T => {\n let nextValidator: T = validator;\n\n if (\n isInteger(attr.min) &&\n (('required' in attr && attr.required) ||\n (Array.isArray(updatedAttribute.value) && updatedAttribute.value.length > 0))\n ) {\n nextValidator = nextValidator.min(attr.min);\n }\n if (isInteger(attr.max)) {\n nextValidator = nextValidator.max(attr.max);\n }\n return nextValidator;\n};\n\nconst addRequiredValidation = (createOrUpdate: CreateOrUpdate) => {\n return <T extends strapiUtils.yup.AnySchema>(\n validator: T,\n {\n attr: { required },\n }: ValidatorMeta<Partial<Schema.Attribute.AnyAttribute & Schema.Attribute.RequiredOption>>\n ): T => {\n let nextValidator = validator;\n\n if (required) {\n if (createOrUpdate === 'creation') {\n nextValidator = nextValidator.notNil();\n } else if (createOrUpdate === 'update') {\n nextValidator = nextValidator.notNull();\n }\n } else {\n nextValidator = nextValidator.nullable();\n }\n return nextValidator;\n };\n};\n\nconst addDefault = (createOrUpdate: CreateOrUpdate) => {\n return (\n validator: strapiUtils.yup.BaseSchema,\n { attr }: ValidatorMeta<Schema.Attribute.AnyAttribute & Schema.Attribute.DefaultOption<unknown>>\n ) => {\n let nextValidator = validator;\n\n if (createOrUpdate === 'creation') {\n if (\n ((attr.type === 'component' && attr.repeatable) || attr.type === 'dynamiczone') &&\n !attr.required\n ) {\n nextValidator = nextValidator.default([]);\n } else {\n nextValidator = nextValidator.default(attr.default);\n }\n } else {\n nextValidator = nextValidator.default(undefined);\n }\n\n return nextValidator;\n };\n};\n\nconst preventCast = (validator: strapiUtils.yup.AnySchema) =>\n validator.transform((val, originalVal) => originalVal);\n\nconst createComponentValidator =\n (createOrUpdate: CreateOrUpdate) =>\n (\n {\n attr,\n updatedAttribute,\n componentContext,\n }: ValidatorMeta<Schema.Attribute.Component<UID.Component, boolean>>,\n { isDraft }: ValidatorContext\n ) => {\n const model = strapi.getModel(attr.component);\n if (!model) {\n throw new Error('Validation failed: Model not found');\n }\n\n if (attr?.repeatable) {\n // FIXME: yup v1\n\n let validator = yup\n .array()\n .of(\n yup.lazy((item) =>\n createModelValidator(createOrUpdate)(\n { componentContext, model, data: item },\n { isDraft }\n ).notNull()\n ) as any\n );\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: true },\n updatedAttribute,\n });\n\n if (!isDraft) {\n validator = addMinMax(validator, { attr, updatedAttribute });\n }\n\n return validator;\n }\n\n let validator = createModelValidator(createOrUpdate)(\n {\n model,\n data: updatedAttribute.value,\n componentContext,\n },\n { isDraft }\n );\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: !isDraft && attr.required },\n updatedAttribute,\n });\n\n return validator;\n };\n\nconst createDzValidator =\n (createOrUpdate: CreateOrUpdate) =>\n ({ attr, updatedAttribute, componentContext }: ValidatorMeta, { isDraft }: ValidatorContext) => {\n let validator;\n\n validator = yup.array().of(\n yup.lazy((item) => {\n const model = strapi.getModel(prop('__component', item));\n const schema = yup\n .object()\n .shape({\n __component: yup.string().required().oneOf(Object.keys(strapi.components)),\n })\n .notNull();\n\n return model\n ? schema.concat(\n createModelValidator(createOrUpdate)(\n { model, data: item, componentContext },\n { isDraft }\n )\n )\n : schema;\n }) as any // FIXME: yup v1\n );\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: true },\n updatedAttribute,\n });\n\n if (!isDraft) {\n validator = addMinMax(validator, { attr, updatedAttribute });\n }\n\n return validator;\n };\n\nconst createRelationValidator = ({\n updatedAttribute,\n}: ValidatorMeta<Schema.Attribute.Relation>) => {\n let validator;\n\n if (Array.isArray(updatedAttribute.value)) {\n validator = yup.array().of(yup.mixed());\n } else {\n validator = yup.mixed();\n }\n\n return validator;\n};\n\nconst createScalarAttributeValidator =\n (createOrUpdate: CreateOrUpdate) => (metas: ValidatorMeta, options: ValidatorContext) => {\n let validator;\n\n if (has(metas.attr.type, Validators)) {\n validator = (Validators as any)[metas.attr.type](metas, options);\n } else {\n // No validators specified - fall back to mixed\n validator = yup.mixed();\n }\n\n validator = addRequiredValidation(createOrUpdate)(validator, {\n attr: { required: !options.isDraft && metas.attr.required },\n updatedAttribute: metas.updatedAttribute,\n });\n\n return validator;\n };\n\nconst createAttributeValidator =\n (createOrUpdate: CreateOrUpdate) => (metas: ValidatorMetas, options: ValidatorContext) => {\n let validator = yup.mixed();\n\n if (isMediaAttribute(metas.attr)) {\n validator = yup.mixed();\n } else if (isScalarAttribute(metas.attr)) {\n validator = createScalarAttributeValidator(createOrUpdate)(metas, options);\n } else {\n if (metas.attr.type === 'component' && metas.componentContext) {\n // Build the path to the component within the parent content type schema.\n const pathToComponent = [\n ...(metas?.componentContext?.pathToComponent ?? []),\n metas.updatedAttribute.name,\n ];\n\n // If working with a repeatable component, determine the repeatable data\n // based on the component's path.\n\n // In order to validate the repeatable within this entity we need\n // access to the full repeatable data. In case we are validating a\n // nested component within a repeatable.\n // Hence why we set this up when the path to the component is only one level deep.\n const repeatableData = (\n metas.attr.repeatable && pathToComponent.length === 1\n ? metas.updatedAttribute.value\n : metas.componentContext?.repeatableData\n ) as Modules.EntityValidator.Entity[];\n\n const newComponentContext: ComponentContext = {\n ...metas.componentContext,\n pathToComponent,\n repeatableData,\n };\n\n validator = createComponentValidator(createOrUpdate)(\n {\n componentContext: newComponentContext,\n attr: metas.attr,\n updatedAttribute: metas.updatedAttribute,\n },\n options\n );\n } else if (metas.attr.type === 'dynamiczone' && metas.componentContext) {\n const newComponentContext: ComponentContext = {\n ...metas.componentContext,\n fullDynamicZoneContent: metas.updatedAttribute.value,\n pathToComponent: [...metas.componentContext.pathToComponent, metas.updatedAttribute.name],\n };\n\n Object.assign(metas, { componentContext: newComponentContext });\n\n validator = createDzValidator(createOrUpdate)(metas, options);\n } else if (metas.attr.type === 'relation') {\n validator = createRelationValidator({\n attr: metas.attr,\n updatedAttribute: metas.updatedAttribute,\n });\n }\n\n validator = preventCast(validator);\n }\n\n validator = addDefault(createOrUpdate)(validator, metas);\n\n return validator;\n };\n\nconst createModelValidator =\n (createOrUpdate: CreateOrUpdate) =>\n ({ componentContext, model, data, entity }: ModelValidatorMetas, options: ValidatorContext) => {\n const writableAttributes = model ? getWritableAttributes(model as any) : [];\n\n const schema = writableAttributes.reduce(\n (validators, attributeName) => {\n const metas = {\n attr: model.attributes[attributeName],\n updatedAttribute: { name: attributeName, value: prop(attributeName, data) },\n model,\n entity,\n componentContext,\n };\n\n const validator = createAttributeValidator(createOrUpdate)(metas, options);\n\n validators[attributeName] = validator;\n\n return validators;\n },\n {} as Record<string, strapiUtils.yup.BaseSchema>\n );\n\n return yup.object().shape(schema);\n };\n\nconst createValidateEntity = (createOrUpdate: CreateOrUpdate) => {\n return async <\n TUID extends UID.ContentType,\n TData extends Modules.EntityService.Params.Data.Input<TUID>,\n >(\n model: Schema.ContentType<TUID>,\n data: TData | Partial<TData> | undefined,\n options?: ValidatorContext,\n entity?: Modules.EntityValidator.Entity\n ): Promise<TData> => {\n if (!isObject(data)) {\n const { displayName } = model.info;\n\n throw new ValidationError(\n `Invalid payload submitted for the ${createOrUpdate} of an entity of type ${displayName}. Expected an object, but got ${typeof data}`\n );\n }\n\n const validator = createModelValidator(createOrUpdate)(\n {\n model,\n data,\n entity,\n componentContext: {\n // Set up the initial component context.\n // Keeping track of parent content type context in which a component will be used.\n // This is necessary to validate component field constraints such as uniqueness.\n parentContent: {\n id: entity?.id,\n model,\n options,\n },\n pathToComponent: [],\n repeatableData: [],\n },\n },\n {\n isDraft: options?.isDraft ?? false,\n locale: options?.locale ?? null,\n }\n )\n .test(\n 'relations-test',\n 'check that all relations exist',\n async function relationsValidation(data) {\n try {\n await checkRelationsExist(buildRelationsStore({ uid: model.uid, data }));\n } catch (e) {\n return this.createError({\n path: this.path,\n message: (e instanceof ValidationError && e.message) || 'Invalid relations',\n });\n }\n return true;\n }\n )\n .required();\n\n return validateYupSchema(validator, {\n strict: false,\n abortEarly: false,\n })(data);\n };\n};\n\n/**\n * Builds an object containing all the media and relations being associated with an entity\n */\nconst buildRelationsStore = <TUID extends UID.Schema>({\n uid,\n data,\n}: {\n uid: TUID;\n data: Record<string, unknown> | null;\n}): Record<string, ID[]> => {\n if (!uid) {\n throw new ValidationError(`Cannot build relations store: \"uid\" is undefined`);\n }\n\n if (isEmpty(data)) {\n return {};\n }\n\n const currentModel = strapi.getModel(uid);\n\n return Object.keys(currentModel.attributes).reduce(\n (result, attributeName: string) => {\n const attribute = currentModel.attributes[attributeName];\n const value = data[attributeName];\n\n if (isNil(value)) {\n return result;\n }\n\n switch (attribute.type) {\n case 'relation':\n case 'media': {\n if (\n attribute.type === 'relation' &&\n (attribute.relation === 'morphToMany' || attribute.relation === 'morphToOne')\n ) {\n // TODO: handle polymorphic relations\n break;\n }\n\n const target =\n // eslint-disable-next-line no-nested-ternary\n attribute.type === 'media' ? 'plugin::upload.file' : attribute.target;\n // As there are multiple formats supported for associating relations\n // with an entity, the value here can be an: array, object or number.\n let source: RelationSource[];\n if (Array.isArray(value)) {\n source = value;\n } else if (isObject(value)) {\n if ('connect' in value && !isNil(value.connect)) {\n source = value.connect as RelationSource[];\n } else if ('set' in value && !isNil(value.set)) {\n source = value.set as RelationSource[];\n } else {\n source = [];\n }\n } else {\n source = castArray(value as RelationSource);\n }\n const idArray = source.map((v) => ({\n id: typeof v === 'object' ? v.id : v,\n }));\n\n // Update the relationStore to keep track of all associations being made\n // with relations and media.\n result[target] = result[target] || [];\n result[target].push(...idArray);\n break;\n }\n case 'component': {\n return castArray(value).reduce((relationsStore, componentValue) => {\n if (!attribute.component) {\n throw new ValidationError(\n `Cannot build relations store from component, component identifier is undefined`\n );\n }\n\n return mergeWith(\n relationsStore,\n buildRelationsStore({\n uid: attribute.component,\n data: componentValue as Record<string, unknown>,\n }),\n (objValue, srcValue) => {\n if (isArray(objValue)) {\n return objValue.concat(srcValue);\n }\n }\n );\n }, result) as Record<string, ID[]>;\n }\n case 'dynamiczone': {\n return castArray(value).reduce((relationsStore, dzValue) => {\n const value = dzValue as Record<string, unknown>;\n if (!value.__component) {\n throw new ValidationError(\n `Cannot build relations store from dynamiczone, component identifier is undefined`\n );\n }\n\n return mergeWith(\n relationsStore,\n buildRelationsStore({\n uid: value.__component as UID.Component,\n data: value,\n }),\n (objValue, srcValue) => {\n if (isArray(objValue)) {\n return objValue.concat(srcValue);\n }\n }\n );\n }, result) as Record<string, ID[]>;\n }\n default:\n break;\n }\n\n return result;\n },\n {} as Record<string, ID[]>\n );\n};\n\n/**\n * Iterate through the relations store and validates that every relation or media\n * mentioned exists\n */\nconst checkRelationsExist = async (relationsStore: Record<string, ID[]> = {}) => {\n const promises: Promise<void>[] = [];\n\n for (const [key, value] of Object.entries(relationsStore)) {\n const evaluate = async () => {\n const uniqueValues = uniqBy(value, `id`);\n const count = await strapi.db.query(key as UID.Schema).count({\n where: {\n id: {\n $in: uniqueValues.map((v) => v.id),\n },\n },\n });\n\n if (count !== uniqueValues.length) {\n throw new ValidationError(\n `${\n uniqueValues.length - count\n } relation(s) of type ${key} associated with this entity do not exist`\n );\n }\n };\n promises.push(evaluate());\n }\n\n return Promise.all(promises);\n};\n\nconst entityValidator: Modules.EntityValidator.EntityValidator = {\n validateEntityCreation: createValidateEntity('creation'),\n validateEntityUpdate: createValidateEntity('update'),\n};\n\nexport default entityValidator;\n"],"names":["validator","data","value"],"mappings":"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"}
|
@@ -1,241 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
3
|
-
const _ = require("lodash");
|
4
|
-
const strapiUtils = require("@strapi/utils");
|
5
|
-
const blocksValidator = require("./blocks-validator.js");
|
6
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
7
|
-
const ___default = /* @__PURE__ */ _interopDefault(_);
|
8
|
-
const addMinLengthValidator = (validator, {
|
9
|
-
attr
|
10
|
-
}, { isDraft }) => {
|
11
|
-
return attr.minLength && ___default.default.isInteger(attr.minLength) && !isDraft ? validator.min(attr.minLength) : validator;
|
12
|
-
};
|
13
|
-
const addMaxLengthValidator = (validator, {
|
14
|
-
attr
|
15
|
-
}) => {
|
16
|
-
return attr.maxLength && ___default.default.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;
|
17
|
-
};
|
18
|
-
const addMinIntegerValidator = (validator, {
|
19
|
-
attr
|
20
|
-
}, { isDraft }) => ___default.default.isNumber(attr.min) && !isDraft ? validator.min(___default.default.toInteger(attr.min)) : validator;
|
21
|
-
const addMaxIntegerValidator = (validator, {
|
22
|
-
attr
|
23
|
-
}) => ___default.default.isNumber(attr.max) ? validator.max(___default.default.toInteger(attr.max)) : validator;
|
24
|
-
const addMinFloatValidator = (validator, {
|
25
|
-
attr
|
26
|
-
}, { isDraft }) => ___default.default.isNumber(attr.min) && !isDraft ? validator.min(attr.min) : validator;
|
27
|
-
const addMaxFloatValidator = (validator, {
|
28
|
-
attr
|
29
|
-
}) => ___default.default.isNumber(attr.max) ? validator.max(attr.max) : validator;
|
30
|
-
const addStringRegexValidator = (validator, {
|
31
|
-
attr
|
32
|
-
}, { isDraft }) => {
|
33
|
-
return "regex" in attr && !___default.default.isUndefined(attr.regex) && !isDraft ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required }) : validator;
|
34
|
-
};
|
35
|
-
const addUniqueValidator = (validator, {
|
36
|
-
attr,
|
37
|
-
model,
|
38
|
-
updatedAttribute,
|
39
|
-
entity,
|
40
|
-
componentContext
|
41
|
-
}, options) => {
|
42
|
-
if (attr.type !== "uid" && !attr.unique) {
|
43
|
-
return validator;
|
44
|
-
}
|
45
|
-
const validateUniqueFieldWithinComponent = async (value) => {
|
46
|
-
if (!componentContext) {
|
47
|
-
return false;
|
48
|
-
}
|
49
|
-
const hasRepeatableData = componentContext.repeatableData.length > 0;
|
50
|
-
if (hasRepeatableData) {
|
51
|
-
const { name: updatedName, value: updatedValue } = updatedAttribute;
|
52
|
-
const pathToCheck = [...componentContext.pathToComponent.slice(1), updatedName].join(".");
|
53
|
-
const values = componentContext.repeatableData.map((item) => {
|
54
|
-
return pathToCheck.split(".").reduce((acc, key) => acc[key], item);
|
55
|
-
});
|
56
|
-
const isUpdatedAttributeRepeatedInThisEntity = values.filter((value2) => value2 === updatedValue).length > 1;
|
57
|
-
if (isUpdatedAttributeRepeatedInThisEntity) {
|
58
|
-
return false;
|
59
|
-
}
|
60
|
-
}
|
61
|
-
const {
|
62
|
-
model: parentModel,
|
63
|
-
options: parentOptions,
|
64
|
-
id: excludeId
|
65
|
-
} = componentContext.parentContent;
|
66
|
-
const whereConditions = {};
|
67
|
-
const isParentDraft = parentOptions && parentOptions.isDraft;
|
68
|
-
whereConditions.publishedAt = isParentDraft ? null : { $notNull: true };
|
69
|
-
if (parentOptions?.locale) {
|
70
|
-
whereConditions.locale = parentOptions.locale;
|
71
|
-
}
|
72
|
-
if (excludeId && !Number.isNaN(excludeId)) {
|
73
|
-
whereConditions.id = { $ne: excludeId };
|
74
|
-
}
|
75
|
-
const queryUid = parentModel.uid;
|
76
|
-
const queryWhere = {
|
77
|
-
...componentContext.pathToComponent.reduceRight((acc, key) => ({ [key]: acc }), {
|
78
|
-
[updatedAttribute.name]: value
|
79
|
-
}),
|
80
|
-
...whereConditions
|
81
|
-
};
|
82
|
-
return !await strapi.db.query(queryUid).findOne({ where: queryWhere });
|
83
|
-
};
|
84
|
-
const validateUniqueFieldWithinDynamicZoneComponent = async (startOfPath) => {
|
85
|
-
if (!componentContext) {
|
86
|
-
return false;
|
87
|
-
}
|
88
|
-
const targetComponentUID = model.uid;
|
89
|
-
const countOfValueInThisEntity = (componentContext?.fullDynamicZoneContent ?? []).reduce(
|
90
|
-
(acc, component) => {
|
91
|
-
if (component.__component !== targetComponentUID) {
|
92
|
-
return acc;
|
93
|
-
}
|
94
|
-
const updatedValue = component[updatedAttribute.name];
|
95
|
-
return updatedValue === updatedAttribute.value ? acc + 1 : acc;
|
96
|
-
},
|
97
|
-
0
|
98
|
-
);
|
99
|
-
if (countOfValueInThisEntity > 1) {
|
100
|
-
return false;
|
101
|
-
}
|
102
|
-
const query = {
|
103
|
-
select: ["id"],
|
104
|
-
where: {},
|
105
|
-
populate: {
|
106
|
-
[startOfPath]: {
|
107
|
-
on: {
|
108
|
-
[targetComponentUID]: {
|
109
|
-
select: ["id"],
|
110
|
-
where: { [updatedAttribute.name]: updatedAttribute.value }
|
111
|
-
}
|
112
|
-
}
|
113
|
-
}
|
114
|
-
}
|
115
|
-
};
|
116
|
-
const { options: options2, id } = componentContext.parentContent;
|
117
|
-
if (options2?.isDraft !== void 0) {
|
118
|
-
query.where.published_at = options2.isDraft ? { $eq: null } : { $ne: null };
|
119
|
-
}
|
120
|
-
if (id) {
|
121
|
-
query.where.id = { $ne: id };
|
122
|
-
}
|
123
|
-
if (options2?.locale) {
|
124
|
-
query.where.locale = options2.locale;
|
125
|
-
}
|
126
|
-
const parentModelQueryResult = await strapi.db.query(componentContext.parentContent.model.uid).findMany(query);
|
127
|
-
const filteredResults = parentModelQueryResult.filter((result) => Array.isArray(result[startOfPath]) && result[startOfPath].length).flatMap((result) => result[startOfPath]).filter((dynamicZoneComponent) => dynamicZoneComponent.__component === targetComponentUID);
|
128
|
-
if (filteredResults.length >= 1) {
|
129
|
-
return false;
|
130
|
-
}
|
131
|
-
return true;
|
132
|
-
};
|
133
|
-
return validator.test("unique", "This attribute must be unique", async (value) => {
|
134
|
-
if (___default.default.isNil(value) || value === "") {
|
135
|
-
return true;
|
136
|
-
}
|
137
|
-
if (options.isDraft) {
|
138
|
-
return true;
|
139
|
-
}
|
140
|
-
const hasPathToComponent = componentContext && componentContext.pathToComponent.length > 0;
|
141
|
-
if (hasPathToComponent) {
|
142
|
-
const startOfPath = componentContext.pathToComponent[0];
|
143
|
-
const testingDZ = componentContext.parentContent.model.attributes[startOfPath].type === "dynamiczone";
|
144
|
-
if (testingDZ) {
|
145
|
-
return validateUniqueFieldWithinDynamicZoneComponent(startOfPath);
|
146
|
-
}
|
147
|
-
return validateUniqueFieldWithinComponent(value);
|
148
|
-
}
|
149
|
-
const scalarAttributeWhere = {
|
150
|
-
[updatedAttribute.name]: value,
|
151
|
-
publishedAt: { $notNull: true }
|
152
|
-
};
|
153
|
-
if (options?.locale) {
|
154
|
-
scalarAttributeWhere.locale = options.locale;
|
155
|
-
}
|
156
|
-
if (entity?.id) {
|
157
|
-
scalarAttributeWhere.id = { $ne: entity.id };
|
158
|
-
}
|
159
|
-
return !await strapi.db.query(model.uid).findOne({ where: scalarAttributeWhere, select: ["id"] });
|
160
|
-
});
|
161
|
-
};
|
162
|
-
const stringValidator = (metas, options) => {
|
163
|
-
let schema = strapiUtils.yup.string().transform((val, originalVal) => originalVal);
|
164
|
-
schema = addMinLengthValidator(schema, metas, options);
|
165
|
-
schema = addMaxLengthValidator(schema, metas);
|
166
|
-
schema = addStringRegexValidator(schema, metas, options);
|
167
|
-
schema = addUniqueValidator(schema, metas, options);
|
168
|
-
return schema;
|
169
|
-
};
|
170
|
-
const emailValidator = (metas, options) => {
|
171
|
-
const schema = stringValidator(metas, options);
|
172
|
-
if (options.isDraft) {
|
173
|
-
return schema;
|
174
|
-
}
|
175
|
-
return schema.email().min(
|
176
|
-
1,
|
177
|
-
// eslint-disable-next-line no-template-curly-in-string
|
178
|
-
"${path} cannot be empty"
|
179
|
-
);
|
180
|
-
};
|
181
|
-
const uidValidator = (metas, options) => {
|
182
|
-
const schema = stringValidator(metas, options);
|
183
|
-
if (options.isDraft) {
|
184
|
-
return schema;
|
185
|
-
}
|
186
|
-
return schema.matches(/^[A-Za-z0-9-_.~]*$/);
|
187
|
-
};
|
188
|
-
const enumerationValidator = ({ attr }) => {
|
189
|
-
return strapiUtils.yup.string().oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null));
|
190
|
-
};
|
191
|
-
const integerValidator = (metas, options) => {
|
192
|
-
let schema = strapiUtils.yup.number().integer();
|
193
|
-
schema = addMinIntegerValidator(schema, metas, options);
|
194
|
-
schema = addMaxIntegerValidator(schema, metas);
|
195
|
-
schema = addUniqueValidator(schema, metas, options);
|
196
|
-
return schema;
|
197
|
-
};
|
198
|
-
const floatValidator = (metas, options) => {
|
199
|
-
let schema = strapiUtils.yup.number();
|
200
|
-
schema = addMinFloatValidator(schema, metas, options);
|
201
|
-
schema = addMaxFloatValidator(schema, metas);
|
202
|
-
schema = addUniqueValidator(schema, metas, options);
|
203
|
-
return schema;
|
204
|
-
};
|
205
|
-
const bigintegerValidator = (metas, options) => {
|
206
|
-
const schema = strapiUtils.yup.mixed();
|
207
|
-
return addUniqueValidator(schema, metas, options);
|
208
|
-
};
|
209
|
-
const datesValidator = (metas, options) => {
|
210
|
-
const schema = strapiUtils.yup.mixed();
|
211
|
-
return addUniqueValidator(schema, metas, options);
|
212
|
-
};
|
213
|
-
const Validators = {
|
214
|
-
string: stringValidator,
|
215
|
-
text: stringValidator,
|
216
|
-
richtext: stringValidator,
|
217
|
-
password: stringValidator,
|
218
|
-
email: emailValidator,
|
219
|
-
enumeration: enumerationValidator,
|
220
|
-
boolean: () => strapiUtils.yup.boolean(),
|
221
|
-
uid: uidValidator,
|
222
|
-
json: () => strapiUtils.yup.mixed(),
|
223
|
-
integer: integerValidator,
|
224
|
-
biginteger: bigintegerValidator,
|
225
|
-
float: floatValidator,
|
226
|
-
decimal: floatValidator,
|
227
|
-
date: datesValidator,
|
228
|
-
time: datesValidator,
|
229
|
-
datetime: datesValidator,
|
230
|
-
timestamp: datesValidator,
|
231
|
-
blocks: blocksValidator.blocksValidator
|
232
|
-
};
|
233
|
-
exports.Validators = Validators;
|
234
|
-
exports.bigintegerValidator = bigintegerValidator;
|
235
|
-
exports.datesValidator = datesValidator;
|
236
|
-
exports.emailValidator = emailValidator;
|
237
|
-
exports.enumerationValidator = enumerationValidator;
|
238
|
-
exports.floatValidator = floatValidator;
|
239
|
-
exports.integerValidator = integerValidator;
|
240
|
-
exports.uidValidator = uidValidator;
|
241
|
-
//# sourceMappingURL=validators.js.map
|