@strapi/core 5.8.1 → 5.10.0
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,133 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
const createDebugger = require("debug");
|
3
|
-
const _ = require("lodash");
|
4
|
-
const workerQueue = require("./worker-queue.js");
|
5
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
6
|
-
const createDebugger__default = /* @__PURE__ */ _interopDefault(createDebugger);
|
7
|
-
const ___default = /* @__PURE__ */ _interopDefault(_);
|
8
|
-
const debug = createDebugger__default.default("strapi:webhook");
|
9
|
-
const defaultConfiguration = {
|
10
|
-
defaultHeaders: {}
|
11
|
-
};
|
12
|
-
class WebhookRunner {
|
13
|
-
eventHub;
|
14
|
-
logger;
|
15
|
-
config;
|
16
|
-
webhooksMap = /* @__PURE__ */ new Map();
|
17
|
-
listeners = /* @__PURE__ */ new Map();
|
18
|
-
queue;
|
19
|
-
fetch;
|
20
|
-
constructor({ eventHub, logger, configuration = {}, fetch }) {
|
21
|
-
debug("Initialized webhook runner");
|
22
|
-
this.eventHub = eventHub;
|
23
|
-
this.logger = logger;
|
24
|
-
this.fetch = fetch;
|
25
|
-
if (typeof configuration !== "object") {
|
26
|
-
throw new Error(
|
27
|
-
"Invalid configuration provided to the webhookRunner.\nCheck your server.json -> webhooks configuration"
|
28
|
-
);
|
29
|
-
}
|
30
|
-
this.config = ___default.default.merge(defaultConfiguration, configuration);
|
31
|
-
this.queue = new workerQueue({ logger, concurrency: 5 });
|
32
|
-
this.queue.subscribe(this.executeListener.bind(this));
|
33
|
-
}
|
34
|
-
deleteListener(event) {
|
35
|
-
debug(`Deleting listener for event '${event}'`);
|
36
|
-
const fn = this.listeners.get(event);
|
37
|
-
if (fn !== void 0) {
|
38
|
-
this.eventHub.off(event, fn);
|
39
|
-
this.listeners.delete(event);
|
40
|
-
}
|
41
|
-
}
|
42
|
-
createListener(event) {
|
43
|
-
debug(`Creating listener for event '${event}'`);
|
44
|
-
if (this.listeners.has(event)) {
|
45
|
-
this.logger.error(
|
46
|
-
`The webhook runner is already listening for the event '${event}'. Did you mean to call .register() ?`
|
47
|
-
);
|
48
|
-
}
|
49
|
-
const listen = async (info) => {
|
50
|
-
this.queue.enqueue({ event, info });
|
51
|
-
};
|
52
|
-
this.listeners.set(event, listen);
|
53
|
-
this.eventHub.on(event, listen);
|
54
|
-
}
|
55
|
-
async executeListener({ event, info }) {
|
56
|
-
debug(`Executing webhook for event '${event}'`);
|
57
|
-
const webhooks = this.webhooksMap.get(event) || [];
|
58
|
-
const activeWebhooks = webhooks.filter((webhook) => webhook.isEnabled === true);
|
59
|
-
for (const webhook of activeWebhooks) {
|
60
|
-
await this.run(webhook, event, info).catch((error) => {
|
61
|
-
this.logger.error("Error running webhook");
|
62
|
-
this.logger.error(error);
|
63
|
-
});
|
64
|
-
}
|
65
|
-
}
|
66
|
-
run(webhook, event, info = {}) {
|
67
|
-
const { url, headers } = webhook;
|
68
|
-
return this.fetch(url, {
|
69
|
-
method: "post",
|
70
|
-
body: JSON.stringify({
|
71
|
-
event,
|
72
|
-
createdAt: /* @__PURE__ */ new Date(),
|
73
|
-
...info
|
74
|
-
}),
|
75
|
-
headers: {
|
76
|
-
...this.config.defaultHeaders,
|
77
|
-
...headers,
|
78
|
-
"X-Strapi-Event": event,
|
79
|
-
"Content-Type": "application/json"
|
80
|
-
},
|
81
|
-
signal: AbortSignal.timeout(1e4)
|
82
|
-
}).then(async (res) => {
|
83
|
-
if (res.ok) {
|
84
|
-
return {
|
85
|
-
statusCode: res.status
|
86
|
-
};
|
87
|
-
}
|
88
|
-
return {
|
89
|
-
statusCode: res.status,
|
90
|
-
message: await res.text()
|
91
|
-
};
|
92
|
-
}).catch((err) => {
|
93
|
-
return {
|
94
|
-
statusCode: 500,
|
95
|
-
message: err.message
|
96
|
-
};
|
97
|
-
});
|
98
|
-
}
|
99
|
-
add(webhook) {
|
100
|
-
debug(`Registering webhook '${webhook.id}'`);
|
101
|
-
const { events } = webhook;
|
102
|
-
events.forEach((event) => {
|
103
|
-
if (this.webhooksMap.has(event)) {
|
104
|
-
this.webhooksMap.get(event)?.push(webhook);
|
105
|
-
} else {
|
106
|
-
this.webhooksMap.set(event, [webhook]);
|
107
|
-
this.createListener(event);
|
108
|
-
}
|
109
|
-
});
|
110
|
-
}
|
111
|
-
update(webhook) {
|
112
|
-
debug(`Refreshing webhook '${webhook.id}'`);
|
113
|
-
this.remove(webhook);
|
114
|
-
this.add(webhook);
|
115
|
-
}
|
116
|
-
remove(webhook) {
|
117
|
-
debug(`Unregistering webhook '${webhook.id}'`);
|
118
|
-
this.webhooksMap.forEach((webhooks, event) => {
|
119
|
-
const filteredWebhooks = webhooks.filter((value) => value.id !== webhook.id);
|
120
|
-
if (filteredWebhooks.length === 0) {
|
121
|
-
this.webhooksMap.delete(event);
|
122
|
-
this.deleteListener(event);
|
123
|
-
} else {
|
124
|
-
this.webhooksMap.set(event, filteredWebhooks);
|
125
|
-
}
|
126
|
-
});
|
127
|
-
}
|
128
|
-
}
|
129
|
-
function createWebhookRunner(opts) {
|
130
|
-
return new WebhookRunner(opts);
|
131
|
-
}
|
132
|
-
module.exports = createWebhookRunner;
|
133
|
-
//# sourceMappingURL=webhook-runner.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"webhook-runner.js","sources":["../../src/services/webhook-runner.ts"],"sourcesContent":["/**\n * The event hub is Strapi's event control center.\n */\n\nimport createdDebugger from 'debug';\nimport _ from 'lodash';\nimport type { Logger } from '@strapi/logger';\n\nimport type { Modules } from '@strapi/types';\nimport WorkerQueue from './worker-queue';\nimport type { EventHub } from './event-hub';\nimport type { Fetch } from '../utils/fetch';\n\ntype Webhook = Modules.WebhookStore.Webhook;\n\ninterface Config {\n defaultHeaders: Record<string, string>;\n}\n\ninterface ConstructorParameters {\n eventHub: EventHub;\n logger: Logger;\n configuration?: Record<string, unknown>;\n fetch: Fetch;\n}\n\ninterface Event {\n event: string;\n info: Record<string, unknown>;\n}\n\ntype Listener = (info: Record<string, unknown>) => Promise<void>;\n\nconst debug = createdDebugger('strapi:webhook');\n\nconst defaultConfiguration: Config = {\n defaultHeaders: {},\n};\n\nclass WebhookRunner {\n private eventHub: EventHub;\n\n private logger: Logger;\n\n private config: Config;\n\n private webhooksMap: Map<string, Webhook[]> = new Map();\n\n private listeners: Map<string, Listener> = new Map();\n\n private queue: WorkerQueue<Event, void>;\n\n private fetch: Fetch;\n\n constructor({ eventHub, logger, configuration = {}, fetch }: ConstructorParameters) {\n debug('Initialized webhook runner');\n this.eventHub = eventHub;\n this.logger = logger;\n this.fetch = fetch;\n\n if (typeof configuration !== 'object') {\n throw new Error(\n 'Invalid configuration provided to the webhookRunner.\\nCheck your server.json -> webhooks configuration'\n );\n }\n\n this.config = _.merge(defaultConfiguration, configuration);\n\n this.queue = new WorkerQueue({ logger, concurrency: 5 });\n\n this.queue.subscribe(this.executeListener.bind(this));\n }\n\n deleteListener(event: string) {\n debug(`Deleting listener for event '${event}'`);\n\n const fn = this.listeners.get(event);\n\n if (fn !== undefined) {\n this.eventHub.off(event, fn);\n this.listeners.delete(event);\n }\n }\n\n createListener(event: string) {\n debug(`Creating listener for event '${event}'`);\n if (this.listeners.has(event)) {\n this.logger.error(\n `The webhook runner is already listening for the event '${event}'. Did you mean to call .register() ?`\n );\n }\n\n const listen = async (info: Event['info']) => {\n this.queue.enqueue({ event, info });\n };\n\n this.listeners.set(event, listen);\n this.eventHub.on(event, listen);\n }\n\n async executeListener({ event, info }: Event) {\n debug(`Executing webhook for event '${event}'`);\n const webhooks = this.webhooksMap.get(event) || [];\n const activeWebhooks = webhooks.filter((webhook) => webhook.isEnabled === true);\n\n for (const webhook of activeWebhooks) {\n await this.run(webhook, event, info).catch((error: unknown) => {\n this.logger.error('Error running webhook');\n this.logger.error(error);\n });\n }\n }\n\n run(webhook: Webhook, event: string, info = {}) {\n const { url, headers } = webhook;\n\n return this.fetch(url, {\n method: 'post',\n body: JSON.stringify({\n event,\n createdAt: new Date(),\n ...info,\n }),\n headers: {\n ...this.config.defaultHeaders,\n ...headers,\n 'X-Strapi-Event': event,\n 'Content-Type': 'application/json',\n },\n signal: AbortSignal.timeout(10000),\n })\n .then(async (res) => {\n if (res.ok) {\n return {\n statusCode: res.status,\n };\n }\n\n return {\n statusCode: res.status,\n message: await res.text(),\n };\n })\n .catch((err) => {\n return {\n statusCode: 500,\n message: err.message,\n };\n });\n }\n\n add(webhook: Webhook) {\n debug(`Registering webhook '${webhook.id}'`);\n const { events } = webhook;\n\n events.forEach((event) => {\n if (this.webhooksMap.has(event)) {\n this.webhooksMap.get(event)?.push(webhook);\n } else {\n this.webhooksMap.set(event, [webhook]);\n this.createListener(event);\n }\n });\n }\n\n update(webhook: Webhook) {\n debug(`Refreshing webhook '${webhook.id}'`);\n this.remove(webhook);\n this.add(webhook);\n }\n\n remove(webhook: Webhook) {\n debug(`Unregistering webhook '${webhook.id}'`);\n\n this.webhooksMap.forEach((webhooks, event) => {\n const filteredWebhooks = webhooks.filter((value) => value.id !== webhook.id);\n\n // Cleanup hanging listeners\n if (filteredWebhooks.length === 0) {\n this.webhooksMap.delete(event);\n this.deleteListener(event);\n } else {\n this.webhooksMap.set(event, filteredWebhooks);\n }\n });\n }\n}\n\n/**\n * Expose a factory function instead of the class\n */\nexport default function createWebhookRunner(opts: ConstructorParameters): WebhookRunner {\n return new WebhookRunner(opts);\n}\n\nexport type { WebhookRunner };\n"],"names":["createdDebugger","_","WorkerQueue"],"mappings":";;;;;;;AAiCA,MAAM,QAAQA,gCAAgB,gBAAgB;AAE9C,MAAM,uBAA+B;AAAA,EACnC,gBAAgB,CAAA;AAClB;AAEA,MAAM,cAAc;AAAA,EACV;AAAA,EAEA;AAAA,EAEA;AAAA,EAEA,kCAA0C,IAAI;AAAA,EAE9C,gCAAuC,IAAI;AAAA,EAE3C;AAAA,EAEA;AAAA,EAER,YAAY,EAAE,UAAU,QAAQ,gBAAgB,CAAA,GAAI,SAAgC;AAClF,UAAM,4BAA4B;AAClC,SAAK,WAAW;AAChB,SAAK,SAAS;AACd,SAAK,QAAQ;AAET,QAAA,OAAO,kBAAkB,UAAU;AACrC,YAAM,IAAI;AAAA,QACR;AAAA,MACF;AAAA,IAAA;AAGF,SAAK,SAASC,WAAAA,QAAE,MAAM,sBAAsB,aAAa;AAEzD,SAAK,QAAQ,IAAIC,YAAY,EAAE,QAAQ,aAAa,GAAG;AAEvD,SAAK,MAAM,UAAU,KAAK,gBAAgB,KAAK,IAAI,CAAC;AAAA,EAAA;AAAA,EAGtD,eAAe,OAAe;AACtB,UAAA,gCAAgC,KAAK,GAAG;AAE9C,UAAM,KAAK,KAAK,UAAU,IAAI,KAAK;AAEnC,QAAI,OAAO,QAAW;AACf,WAAA,SAAS,IAAI,OAAO,EAAE;AACtB,WAAA,UAAU,OAAO,KAAK;AAAA,IAAA;AAAA,EAC7B;AAAA,EAGF,eAAe,OAAe;AACtB,UAAA,gCAAgC,KAAK,GAAG;AAC9C,QAAI,KAAK,UAAU,IAAI,KAAK,GAAG;AAC7B,WAAK,OAAO;AAAA,QACV,0DAA0D,KAAK;AAAA,MACjE;AAAA,IAAA;AAGI,UAAA,SAAS,OAAO,SAAwB;AAC5C,WAAK,MAAM,QAAQ,EAAE,OAAO,MAAM;AAAA,IACpC;AAEK,SAAA,UAAU,IAAI,OAAO,MAAM;AAC3B,SAAA,SAAS,GAAG,OAAO,MAAM;AAAA,EAAA;AAAA,EAGhC,MAAM,gBAAgB,EAAE,OAAO,QAAe;AACtC,UAAA,gCAAgC,KAAK,GAAG;AAC9C,UAAM,WAAW,KAAK,YAAY,IAAI,KAAK,KAAK,CAAC;AACjD,UAAM,iBAAiB,SAAS,OAAO,CAAC,YAAY,QAAQ,cAAc,IAAI;AAE9E,eAAW,WAAW,gBAAgB;AAC9B,YAAA,KAAK,IAAI,SAAS,OAAO,IAAI,EAAE,MAAM,CAAC,UAAmB;AACxD,aAAA,OAAO,MAAM,uBAAuB;AACpC,aAAA,OAAO,MAAM,KAAK;AAAA,MAAA,CACxB;AAAA,IAAA;AAAA,EACH;AAAA,EAGF,IAAI,SAAkB,OAAe,OAAO,CAAA,GAAI;AACxC,UAAA,EAAE,KAAK,QAAA,IAAY;AAElB,WAAA,KAAK,MAAM,KAAK;AAAA,MACrB,QAAQ;AAAA,MACR,MAAM,KAAK,UAAU;AAAA,QACnB;AAAA,QACA,+BAAe,KAAK;AAAA,QACpB,GAAG;AAAA,MAAA,CACJ;AAAA,MACD,SAAS;AAAA,QACP,GAAG,KAAK,OAAO;AAAA,QACf,GAAG;AAAA,QACH,kBAAkB;AAAA,QAClB,gBAAgB;AAAA,MAClB;AAAA,MACA,QAAQ,YAAY,QAAQ,GAAK;AAAA,IAAA,CAClC,EACE,KAAK,OAAO,QAAQ;AACnB,UAAI,IAAI,IAAI;AACH,eAAA;AAAA,UACL,YAAY,IAAI;AAAA,QAClB;AAAA,MAAA;AAGK,aAAA;AAAA,QACL,YAAY,IAAI;AAAA,QAChB,SAAS,MAAM,IAAI,KAAK;AAAA,MAC1B;AAAA,IAAA,CACD,EACA,MAAM,CAAC,QAAQ;AACP,aAAA;AAAA,QACL,YAAY;AAAA,QACZ,SAAS,IAAI;AAAA,MACf;AAAA,IAAA,CACD;AAAA,EAAA;AAAA,EAGL,IAAI,SAAkB;AACd,UAAA,wBAAwB,QAAQ,EAAE,GAAG;AACrC,UAAA,EAAE,WAAW;AAEZ,WAAA,QAAQ,CAAC,UAAU;AACxB,UAAI,KAAK,YAAY,IAAI,KAAK,GAAG;AAC/B,aAAK,YAAY,IAAI,KAAK,GAAG,KAAK,OAAO;AAAA,MAAA,OACpC;AACL,aAAK,YAAY,IAAI,OAAO,CAAC,OAAO,CAAC;AACrC,aAAK,eAAe,KAAK;AAAA,MAAA;AAAA,IAC3B,CACD;AAAA,EAAA;AAAA,EAGH,OAAO,SAAkB;AACjB,UAAA,uBAAuB,QAAQ,EAAE,GAAG;AAC1C,SAAK,OAAO,OAAO;AACnB,SAAK,IAAI,OAAO;AAAA,EAAA;AAAA,EAGlB,OAAO,SAAkB;AACjB,UAAA,0BAA0B,QAAQ,EAAE,GAAG;AAE7C,SAAK,YAAY,QAAQ,CAAC,UAAU,UAAU;AACtC,YAAA,mBAAmB,SAAS,OAAO,CAAC,UAAU,MAAM,OAAO,QAAQ,EAAE;AAGvE,UAAA,iBAAiB,WAAW,GAAG;AAC5B,aAAA,YAAY,OAAO,KAAK;AAC7B,aAAK,eAAe,KAAK;AAAA,MAAA,OACpB;AACA,aAAA,YAAY,IAAI,OAAO,gBAAgB;AAAA,MAAA;AAAA,IAC9C,CACD;AAAA,EAAA;AAEL;AAKA,SAAwB,oBAAoB,MAA4C;AAC/E,SAAA,IAAI,cAAc,IAAI;AAC/B;;"}
|
@@ -1,131 +0,0 @@
|
|
1
|
-
import createDebugger from "debug";
|
2
|
-
import _ from "lodash";
|
3
|
-
import WorkerQueue from "./worker-queue.mjs";
|
4
|
-
const debug = createDebugger("strapi:webhook");
|
5
|
-
const defaultConfiguration = {
|
6
|
-
defaultHeaders: {}
|
7
|
-
};
|
8
|
-
class WebhookRunner {
|
9
|
-
eventHub;
|
10
|
-
logger;
|
11
|
-
config;
|
12
|
-
webhooksMap = /* @__PURE__ */ new Map();
|
13
|
-
listeners = /* @__PURE__ */ new Map();
|
14
|
-
queue;
|
15
|
-
fetch;
|
16
|
-
constructor({ eventHub, logger, configuration = {}, fetch }) {
|
17
|
-
debug("Initialized webhook runner");
|
18
|
-
this.eventHub = eventHub;
|
19
|
-
this.logger = logger;
|
20
|
-
this.fetch = fetch;
|
21
|
-
if (typeof configuration !== "object") {
|
22
|
-
throw new Error(
|
23
|
-
"Invalid configuration provided to the webhookRunner.\nCheck your server.json -> webhooks configuration"
|
24
|
-
);
|
25
|
-
}
|
26
|
-
this.config = _.merge(defaultConfiguration, configuration);
|
27
|
-
this.queue = new WorkerQueue({ logger, concurrency: 5 });
|
28
|
-
this.queue.subscribe(this.executeListener.bind(this));
|
29
|
-
}
|
30
|
-
deleteListener(event) {
|
31
|
-
debug(`Deleting listener for event '${event}'`);
|
32
|
-
const fn = this.listeners.get(event);
|
33
|
-
if (fn !== void 0) {
|
34
|
-
this.eventHub.off(event, fn);
|
35
|
-
this.listeners.delete(event);
|
36
|
-
}
|
37
|
-
}
|
38
|
-
createListener(event) {
|
39
|
-
debug(`Creating listener for event '${event}'`);
|
40
|
-
if (this.listeners.has(event)) {
|
41
|
-
this.logger.error(
|
42
|
-
`The webhook runner is already listening for the event '${event}'. Did you mean to call .register() ?`
|
43
|
-
);
|
44
|
-
}
|
45
|
-
const listen = async (info) => {
|
46
|
-
this.queue.enqueue({ event, info });
|
47
|
-
};
|
48
|
-
this.listeners.set(event, listen);
|
49
|
-
this.eventHub.on(event, listen);
|
50
|
-
}
|
51
|
-
async executeListener({ event, info }) {
|
52
|
-
debug(`Executing webhook for event '${event}'`);
|
53
|
-
const webhooks = this.webhooksMap.get(event) || [];
|
54
|
-
const activeWebhooks = webhooks.filter((webhook) => webhook.isEnabled === true);
|
55
|
-
for (const webhook of activeWebhooks) {
|
56
|
-
await this.run(webhook, event, info).catch((error) => {
|
57
|
-
this.logger.error("Error running webhook");
|
58
|
-
this.logger.error(error);
|
59
|
-
});
|
60
|
-
}
|
61
|
-
}
|
62
|
-
run(webhook, event, info = {}) {
|
63
|
-
const { url, headers } = webhook;
|
64
|
-
return this.fetch(url, {
|
65
|
-
method: "post",
|
66
|
-
body: JSON.stringify({
|
67
|
-
event,
|
68
|
-
createdAt: /* @__PURE__ */ new Date(),
|
69
|
-
...info
|
70
|
-
}),
|
71
|
-
headers: {
|
72
|
-
...this.config.defaultHeaders,
|
73
|
-
...headers,
|
74
|
-
"X-Strapi-Event": event,
|
75
|
-
"Content-Type": "application/json"
|
76
|
-
},
|
77
|
-
signal: AbortSignal.timeout(1e4)
|
78
|
-
}).then(async (res) => {
|
79
|
-
if (res.ok) {
|
80
|
-
return {
|
81
|
-
statusCode: res.status
|
82
|
-
};
|
83
|
-
}
|
84
|
-
return {
|
85
|
-
statusCode: res.status,
|
86
|
-
message: await res.text()
|
87
|
-
};
|
88
|
-
}).catch((err) => {
|
89
|
-
return {
|
90
|
-
statusCode: 500,
|
91
|
-
message: err.message
|
92
|
-
};
|
93
|
-
});
|
94
|
-
}
|
95
|
-
add(webhook) {
|
96
|
-
debug(`Registering webhook '${webhook.id}'`);
|
97
|
-
const { events } = webhook;
|
98
|
-
events.forEach((event) => {
|
99
|
-
if (this.webhooksMap.has(event)) {
|
100
|
-
this.webhooksMap.get(event)?.push(webhook);
|
101
|
-
} else {
|
102
|
-
this.webhooksMap.set(event, [webhook]);
|
103
|
-
this.createListener(event);
|
104
|
-
}
|
105
|
-
});
|
106
|
-
}
|
107
|
-
update(webhook) {
|
108
|
-
debug(`Refreshing webhook '${webhook.id}'`);
|
109
|
-
this.remove(webhook);
|
110
|
-
this.add(webhook);
|
111
|
-
}
|
112
|
-
remove(webhook) {
|
113
|
-
debug(`Unregistering webhook '${webhook.id}'`);
|
114
|
-
this.webhooksMap.forEach((webhooks, event) => {
|
115
|
-
const filteredWebhooks = webhooks.filter((value) => value.id !== webhook.id);
|
116
|
-
if (filteredWebhooks.length === 0) {
|
117
|
-
this.webhooksMap.delete(event);
|
118
|
-
this.deleteListener(event);
|
119
|
-
} else {
|
120
|
-
this.webhooksMap.set(event, filteredWebhooks);
|
121
|
-
}
|
122
|
-
});
|
123
|
-
}
|
124
|
-
}
|
125
|
-
function createWebhookRunner(opts) {
|
126
|
-
return new WebhookRunner(opts);
|
127
|
-
}
|
128
|
-
export {
|
129
|
-
createWebhookRunner as default
|
130
|
-
};
|
131
|
-
//# sourceMappingURL=webhook-runner.mjs.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"webhook-runner.mjs","sources":["../../src/services/webhook-runner.ts"],"sourcesContent":["/**\n * The event hub is Strapi's event control center.\n */\n\nimport createdDebugger from 'debug';\nimport _ from 'lodash';\nimport type { Logger } from '@strapi/logger';\n\nimport type { Modules } from '@strapi/types';\nimport WorkerQueue from './worker-queue';\nimport type { EventHub } from './event-hub';\nimport type { Fetch } from '../utils/fetch';\n\ntype Webhook = Modules.WebhookStore.Webhook;\n\ninterface Config {\n defaultHeaders: Record<string, string>;\n}\n\ninterface ConstructorParameters {\n eventHub: EventHub;\n logger: Logger;\n configuration?: Record<string, unknown>;\n fetch: Fetch;\n}\n\ninterface Event {\n event: string;\n info: Record<string, unknown>;\n}\n\ntype Listener = (info: Record<string, unknown>) => Promise<void>;\n\nconst debug = createdDebugger('strapi:webhook');\n\nconst defaultConfiguration: Config = {\n defaultHeaders: {},\n};\n\nclass WebhookRunner {\n private eventHub: EventHub;\n\n private logger: Logger;\n\n private config: Config;\n\n private webhooksMap: Map<string, Webhook[]> = new Map();\n\n private listeners: Map<string, Listener> = new Map();\n\n private queue: WorkerQueue<Event, void>;\n\n private fetch: Fetch;\n\n constructor({ eventHub, logger, configuration = {}, fetch }: ConstructorParameters) {\n debug('Initialized webhook runner');\n this.eventHub = eventHub;\n this.logger = logger;\n this.fetch = fetch;\n\n if (typeof configuration !== 'object') {\n throw new Error(\n 'Invalid configuration provided to the webhookRunner.\\nCheck your server.json -> webhooks configuration'\n );\n }\n\n this.config = _.merge(defaultConfiguration, configuration);\n\n this.queue = new WorkerQueue({ logger, concurrency: 5 });\n\n this.queue.subscribe(this.executeListener.bind(this));\n }\n\n deleteListener(event: string) {\n debug(`Deleting listener for event '${event}'`);\n\n const fn = this.listeners.get(event);\n\n if (fn !== undefined) {\n this.eventHub.off(event, fn);\n this.listeners.delete(event);\n }\n }\n\n createListener(event: string) {\n debug(`Creating listener for event '${event}'`);\n if (this.listeners.has(event)) {\n this.logger.error(\n `The webhook runner is already listening for the event '${event}'. Did you mean to call .register() ?`\n );\n }\n\n const listen = async (info: Event['info']) => {\n this.queue.enqueue({ event, info });\n };\n\n this.listeners.set(event, listen);\n this.eventHub.on(event, listen);\n }\n\n async executeListener({ event, info }: Event) {\n debug(`Executing webhook for event '${event}'`);\n const webhooks = this.webhooksMap.get(event) || [];\n const activeWebhooks = webhooks.filter((webhook) => webhook.isEnabled === true);\n\n for (const webhook of activeWebhooks) {\n await this.run(webhook, event, info).catch((error: unknown) => {\n this.logger.error('Error running webhook');\n this.logger.error(error);\n });\n }\n }\n\n run(webhook: Webhook, event: string, info = {}) {\n const { url, headers } = webhook;\n\n return this.fetch(url, {\n method: 'post',\n body: JSON.stringify({\n event,\n createdAt: new Date(),\n ...info,\n }),\n headers: {\n ...this.config.defaultHeaders,\n ...headers,\n 'X-Strapi-Event': event,\n 'Content-Type': 'application/json',\n },\n signal: AbortSignal.timeout(10000),\n })\n .then(async (res) => {\n if (res.ok) {\n return {\n statusCode: res.status,\n };\n }\n\n return {\n statusCode: res.status,\n message: await res.text(),\n };\n })\n .catch((err) => {\n return {\n statusCode: 500,\n message: err.message,\n };\n });\n }\n\n add(webhook: Webhook) {\n debug(`Registering webhook '${webhook.id}'`);\n const { events } = webhook;\n\n events.forEach((event) => {\n if (this.webhooksMap.has(event)) {\n this.webhooksMap.get(event)?.push(webhook);\n } else {\n this.webhooksMap.set(event, [webhook]);\n this.createListener(event);\n }\n });\n }\n\n update(webhook: Webhook) {\n debug(`Refreshing webhook '${webhook.id}'`);\n this.remove(webhook);\n this.add(webhook);\n }\n\n remove(webhook: Webhook) {\n debug(`Unregistering webhook '${webhook.id}'`);\n\n this.webhooksMap.forEach((webhooks, event) => {\n const filteredWebhooks = webhooks.filter((value) => value.id !== webhook.id);\n\n // Cleanup hanging listeners\n if (filteredWebhooks.length === 0) {\n this.webhooksMap.delete(event);\n this.deleteListener(event);\n } else {\n this.webhooksMap.set(event, filteredWebhooks);\n }\n });\n }\n}\n\n/**\n * Expose a factory function instead of the class\n */\nexport default function createWebhookRunner(opts: ConstructorParameters): WebhookRunner {\n return new WebhookRunner(opts);\n}\n\nexport type { WebhookRunner };\n"],"names":["createdDebugger"],"mappings":"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"}
|
@@ -1,110 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
3
|
-
const strapiUtils = require("@strapi/utils");
|
4
|
-
const { ValidationError } = strapiUtils.errors;
|
5
|
-
const webhookModel = {
|
6
|
-
uid: "strapi::webhook",
|
7
|
-
singularName: "strapi_webhooks",
|
8
|
-
tableName: "strapi_webhooks",
|
9
|
-
attributes: {
|
10
|
-
id: {
|
11
|
-
type: "increments"
|
12
|
-
},
|
13
|
-
name: {
|
14
|
-
type: "string"
|
15
|
-
},
|
16
|
-
url: {
|
17
|
-
type: "text"
|
18
|
-
},
|
19
|
-
headers: {
|
20
|
-
type: "json"
|
21
|
-
},
|
22
|
-
events: {
|
23
|
-
type: "json"
|
24
|
-
},
|
25
|
-
enabled: {
|
26
|
-
type: "boolean"
|
27
|
-
}
|
28
|
-
}
|
29
|
-
};
|
30
|
-
const toDBObject = (data) => {
|
31
|
-
return {
|
32
|
-
name: data.name,
|
33
|
-
url: data.url,
|
34
|
-
headers: data.headers,
|
35
|
-
events: data.events,
|
36
|
-
enabled: data.isEnabled
|
37
|
-
};
|
38
|
-
};
|
39
|
-
const fromDBObject = (row) => {
|
40
|
-
return {
|
41
|
-
id: typeof row.id === "number" ? row.id.toString() : row.id,
|
42
|
-
name: row.name,
|
43
|
-
url: row.url,
|
44
|
-
headers: row.headers,
|
45
|
-
events: row.events,
|
46
|
-
isEnabled: row.enabled
|
47
|
-
};
|
48
|
-
};
|
49
|
-
const webhookEventValidator = async (allowedEvents, events) => {
|
50
|
-
const allowedValues = Array.from(allowedEvents.values());
|
51
|
-
events.forEach((event) => {
|
52
|
-
if (allowedValues.includes(event)) {
|
53
|
-
return;
|
54
|
-
}
|
55
|
-
throw new ValidationError(`Webhook event ${event} is not supported`);
|
56
|
-
});
|
57
|
-
};
|
58
|
-
const createWebhookStore = ({ db }) => {
|
59
|
-
return {
|
60
|
-
allowedEvents: /* @__PURE__ */ new Map([
|
61
|
-
["ENTRY_CREATE", "entry.create"],
|
62
|
-
["ENTRY_UPDATE", "entry.update"],
|
63
|
-
["ENTRY_DELETE", "entry.delete"],
|
64
|
-
["ENTRY_PUBLISH", "entry.publish"],
|
65
|
-
["ENTRY_UNPUBLISH", "entry.unpublish"],
|
66
|
-
["ENTRY_DRAFT_DISCARD", "entry.draft-discard"]
|
67
|
-
]),
|
68
|
-
addAllowedEvent(key, value) {
|
69
|
-
this.allowedEvents.set(key, value);
|
70
|
-
},
|
71
|
-
removeAllowedEvent(key) {
|
72
|
-
this.allowedEvents.delete(key);
|
73
|
-
},
|
74
|
-
listAllowedEvents() {
|
75
|
-
return Array.from(this.allowedEvents.keys());
|
76
|
-
},
|
77
|
-
getAllowedEvent(key) {
|
78
|
-
return this.allowedEvents.get(key);
|
79
|
-
},
|
80
|
-
async findWebhooks() {
|
81
|
-
const results = await db.query("strapi::webhook").findMany();
|
82
|
-
return results.map(fromDBObject);
|
83
|
-
},
|
84
|
-
async findWebhook(id) {
|
85
|
-
const result = await db.query("strapi::webhook").findOne({ where: { id } });
|
86
|
-
return result ? fromDBObject(result) : null;
|
87
|
-
},
|
88
|
-
async createWebhook(data) {
|
89
|
-
await webhookEventValidator(this.allowedEvents, data.events);
|
90
|
-
return db.query("strapi::webhook").create({
|
91
|
-
data: toDBObject({ ...data, isEnabled: true })
|
92
|
-
}).then(fromDBObject);
|
93
|
-
},
|
94
|
-
async updateWebhook(id, data) {
|
95
|
-
await webhookEventValidator(this.allowedEvents, data.events);
|
96
|
-
const webhook = await db.query("strapi::webhook").update({
|
97
|
-
where: { id },
|
98
|
-
data: toDBObject(data)
|
99
|
-
});
|
100
|
-
return webhook ? fromDBObject(webhook) : null;
|
101
|
-
},
|
102
|
-
async deleteWebhook(id) {
|
103
|
-
const webhook = await db.query("strapi::webhook").delete({ where: { id } });
|
104
|
-
return webhook ? fromDBObject(webhook) : null;
|
105
|
-
}
|
106
|
-
};
|
107
|
-
};
|
108
|
-
exports.createWebhookStore = createWebhookStore;
|
109
|
-
exports.webhookModel = webhookModel;
|
110
|
-
//# sourceMappingURL=webhook-store.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"webhook-store.js","sources":["../../src/services/webhook-store.ts"],"sourcesContent":["/**\n * Webhook store is the implementation of webhook storage over the core_store\n */\n\nimport { errors } from '@strapi/utils';\nimport type { Model, Database } from '@strapi/database';\nimport type { Modules } from '@strapi/types';\n\nconst { ValidationError } = errors;\n\nconst webhookModel: Model = {\n uid: 'strapi::webhook',\n singularName: 'strapi_webhooks',\n tableName: 'strapi_webhooks',\n attributes: {\n id: {\n type: 'increments',\n },\n name: {\n type: 'string',\n },\n url: {\n type: 'text',\n },\n headers: {\n type: 'json',\n },\n events: {\n type: 'json',\n },\n enabled: {\n type: 'boolean',\n },\n },\n};\n\ntype Webhook = Modules.WebhookStore.Webhook;\ntype DBOutput = Omit<Webhook, 'id' | 'isEnabled'> & { id: string | number; enabled: boolean };\ntype DBInput = Omit<DBOutput, 'id'>;\n\nconst toDBObject = (data: Webhook): DBInput => {\n return {\n name: data.name,\n url: data.url,\n headers: data.headers,\n events: data.events,\n enabled: data.isEnabled,\n };\n};\n\nconst fromDBObject = (row: DBOutput): Webhook => {\n return {\n id: typeof row.id === 'number' ? row.id.toString() : row.id,\n name: row.name,\n url: row.url,\n headers: row.headers,\n events: row.events,\n isEnabled: row.enabled,\n };\n};\n\nconst webhookEventValidator = async (allowedEvents: Map<string, string>, events: string[]) => {\n const allowedValues = Array.from(allowedEvents.values());\n\n events.forEach((event) => {\n if (allowedValues.includes(event)) {\n return;\n }\n\n throw new ValidationError(`Webhook event ${event} is not supported`);\n });\n};\n\nexport interface WebhookStore {\n allowedEvents: Map<string, string>;\n addAllowedEvent(key: string, value: string): void;\n removeAllowedEvent(key: string): void;\n listAllowedEvents(): string[];\n getAllowedEvent(key: string): string | undefined;\n findWebhooks(): Promise<Webhook[]>;\n findWebhook(id: string): Promise<Webhook | null>;\n createWebhook(data: Webhook): Promise<Webhook>;\n updateWebhook(id: string, data: Webhook): Promise<Webhook | null>;\n deleteWebhook(id: string): Promise<Webhook | null>;\n}\n\nconst createWebhookStore = ({ db }: { db: Database }): WebhookStore => {\n return {\n allowedEvents: new Map([\n ['ENTRY_CREATE', 'entry.create'],\n ['ENTRY_UPDATE', 'entry.update'],\n ['ENTRY_DELETE', 'entry.delete'],\n ['ENTRY_PUBLISH', 'entry.publish'],\n ['ENTRY_UNPUBLISH', 'entry.unpublish'],\n ['ENTRY_DRAFT_DISCARD', 'entry.draft-discard'],\n ]),\n addAllowedEvent(key, value) {\n this.allowedEvents.set(key, value);\n },\n removeAllowedEvent(key) {\n this.allowedEvents.delete(key);\n },\n listAllowedEvents() {\n return Array.from(this.allowedEvents.keys());\n },\n getAllowedEvent(key) {\n return this.allowedEvents.get(key);\n },\n async findWebhooks() {\n const results = await db.query('strapi::webhook').findMany();\n\n return results.map(fromDBObject);\n },\n async findWebhook(id) {\n const result = await db.query('strapi::webhook').findOne({ where: { id } });\n return result ? fromDBObject(result) : null;\n },\n async createWebhook(data) {\n await webhookEventValidator(this.allowedEvents, data.events);\n\n return db\n .query('strapi::webhook')\n .create({\n data: toDBObject({ ...data, isEnabled: true }),\n })\n .then(fromDBObject);\n },\n async updateWebhook(id, data) {\n await webhookEventValidator(this.allowedEvents, data.events);\n\n const webhook = await db.query('strapi::webhook').update({\n where: { id },\n data: toDBObject(data),\n });\n\n return webhook ? fromDBObject(webhook) : null;\n },\n async deleteWebhook(id) {\n const webhook = await db.query('strapi::webhook').delete({ where: { id } });\n return webhook ? fromDBObject(webhook) : null;\n },\n };\n};\n\nexport { webhookModel, createWebhookStore };\n"],"names":["errors"],"mappings":"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"}
|
@@ -1,110 +0,0 @@
|
|
1
|
-
import { errors } from "@strapi/utils";
|
2
|
-
const { ValidationError } = errors;
|
3
|
-
const webhookModel = {
|
4
|
-
uid: "strapi::webhook",
|
5
|
-
singularName: "strapi_webhooks",
|
6
|
-
tableName: "strapi_webhooks",
|
7
|
-
attributes: {
|
8
|
-
id: {
|
9
|
-
type: "increments"
|
10
|
-
},
|
11
|
-
name: {
|
12
|
-
type: "string"
|
13
|
-
},
|
14
|
-
url: {
|
15
|
-
type: "text"
|
16
|
-
},
|
17
|
-
headers: {
|
18
|
-
type: "json"
|
19
|
-
},
|
20
|
-
events: {
|
21
|
-
type: "json"
|
22
|
-
},
|
23
|
-
enabled: {
|
24
|
-
type: "boolean"
|
25
|
-
}
|
26
|
-
}
|
27
|
-
};
|
28
|
-
const toDBObject = (data) => {
|
29
|
-
return {
|
30
|
-
name: data.name,
|
31
|
-
url: data.url,
|
32
|
-
headers: data.headers,
|
33
|
-
events: data.events,
|
34
|
-
enabled: data.isEnabled
|
35
|
-
};
|
36
|
-
};
|
37
|
-
const fromDBObject = (row) => {
|
38
|
-
return {
|
39
|
-
id: typeof row.id === "number" ? row.id.toString() : row.id,
|
40
|
-
name: row.name,
|
41
|
-
url: row.url,
|
42
|
-
headers: row.headers,
|
43
|
-
events: row.events,
|
44
|
-
isEnabled: row.enabled
|
45
|
-
};
|
46
|
-
};
|
47
|
-
const webhookEventValidator = async (allowedEvents, events) => {
|
48
|
-
const allowedValues = Array.from(allowedEvents.values());
|
49
|
-
events.forEach((event) => {
|
50
|
-
if (allowedValues.includes(event)) {
|
51
|
-
return;
|
52
|
-
}
|
53
|
-
throw new ValidationError(`Webhook event ${event} is not supported`);
|
54
|
-
});
|
55
|
-
};
|
56
|
-
const createWebhookStore = ({ db }) => {
|
57
|
-
return {
|
58
|
-
allowedEvents: /* @__PURE__ */ new Map([
|
59
|
-
["ENTRY_CREATE", "entry.create"],
|
60
|
-
["ENTRY_UPDATE", "entry.update"],
|
61
|
-
["ENTRY_DELETE", "entry.delete"],
|
62
|
-
["ENTRY_PUBLISH", "entry.publish"],
|
63
|
-
["ENTRY_UNPUBLISH", "entry.unpublish"],
|
64
|
-
["ENTRY_DRAFT_DISCARD", "entry.draft-discard"]
|
65
|
-
]),
|
66
|
-
addAllowedEvent(key, value) {
|
67
|
-
this.allowedEvents.set(key, value);
|
68
|
-
},
|
69
|
-
removeAllowedEvent(key) {
|
70
|
-
this.allowedEvents.delete(key);
|
71
|
-
},
|
72
|
-
listAllowedEvents() {
|
73
|
-
return Array.from(this.allowedEvents.keys());
|
74
|
-
},
|
75
|
-
getAllowedEvent(key) {
|
76
|
-
return this.allowedEvents.get(key);
|
77
|
-
},
|
78
|
-
async findWebhooks() {
|
79
|
-
const results = await db.query("strapi::webhook").findMany();
|
80
|
-
return results.map(fromDBObject);
|
81
|
-
},
|
82
|
-
async findWebhook(id) {
|
83
|
-
const result = await db.query("strapi::webhook").findOne({ where: { id } });
|
84
|
-
return result ? fromDBObject(result) : null;
|
85
|
-
},
|
86
|
-
async createWebhook(data) {
|
87
|
-
await webhookEventValidator(this.allowedEvents, data.events);
|
88
|
-
return db.query("strapi::webhook").create({
|
89
|
-
data: toDBObject({ ...data, isEnabled: true })
|
90
|
-
}).then(fromDBObject);
|
91
|
-
},
|
92
|
-
async updateWebhook(id, data) {
|
93
|
-
await webhookEventValidator(this.allowedEvents, data.events);
|
94
|
-
const webhook = await db.query("strapi::webhook").update({
|
95
|
-
where: { id },
|
96
|
-
data: toDBObject(data)
|
97
|
-
});
|
98
|
-
return webhook ? fromDBObject(webhook) : null;
|
99
|
-
},
|
100
|
-
async deleteWebhook(id) {
|
101
|
-
const webhook = await db.query("strapi::webhook").delete({ where: { id } });
|
102
|
-
return webhook ? fromDBObject(webhook) : null;
|
103
|
-
}
|
104
|
-
};
|
105
|
-
};
|
106
|
-
export {
|
107
|
-
createWebhookStore,
|
108
|
-
webhookModel
|
109
|
-
};
|
110
|
-
//# sourceMappingURL=webhook-store.mjs.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"webhook-store.mjs","sources":["../../src/services/webhook-store.ts"],"sourcesContent":["/**\n * Webhook store is the implementation of webhook storage over the core_store\n */\n\nimport { errors } from '@strapi/utils';\nimport type { Model, Database } from '@strapi/database';\nimport type { Modules } from '@strapi/types';\n\nconst { ValidationError } = errors;\n\nconst webhookModel: Model = {\n uid: 'strapi::webhook',\n singularName: 'strapi_webhooks',\n tableName: 'strapi_webhooks',\n attributes: {\n id: {\n type: 'increments',\n },\n name: {\n type: 'string',\n },\n url: {\n type: 'text',\n },\n headers: {\n type: 'json',\n },\n events: {\n type: 'json',\n },\n enabled: {\n type: 'boolean',\n },\n },\n};\n\ntype Webhook = Modules.WebhookStore.Webhook;\ntype DBOutput = Omit<Webhook, 'id' | 'isEnabled'> & { id: string | number; enabled: boolean };\ntype DBInput = Omit<DBOutput, 'id'>;\n\nconst toDBObject = (data: Webhook): DBInput => {\n return {\n name: data.name,\n url: data.url,\n headers: data.headers,\n events: data.events,\n enabled: data.isEnabled,\n };\n};\n\nconst fromDBObject = (row: DBOutput): Webhook => {\n return {\n id: typeof row.id === 'number' ? row.id.toString() : row.id,\n name: row.name,\n url: row.url,\n headers: row.headers,\n events: row.events,\n isEnabled: row.enabled,\n };\n};\n\nconst webhookEventValidator = async (allowedEvents: Map<string, string>, events: string[]) => {\n const allowedValues = Array.from(allowedEvents.values());\n\n events.forEach((event) => {\n if (allowedValues.includes(event)) {\n return;\n }\n\n throw new ValidationError(`Webhook event ${event} is not supported`);\n });\n};\n\nexport interface WebhookStore {\n allowedEvents: Map<string, string>;\n addAllowedEvent(key: string, value: string): void;\n removeAllowedEvent(key: string): void;\n listAllowedEvents(): string[];\n getAllowedEvent(key: string): string | undefined;\n findWebhooks(): Promise<Webhook[]>;\n findWebhook(id: string): Promise<Webhook | null>;\n createWebhook(data: Webhook): Promise<Webhook>;\n updateWebhook(id: string, data: Webhook): Promise<Webhook | null>;\n deleteWebhook(id: string): Promise<Webhook | null>;\n}\n\nconst createWebhookStore = ({ db }: { db: Database }): WebhookStore => {\n return {\n allowedEvents: new Map([\n ['ENTRY_CREATE', 'entry.create'],\n ['ENTRY_UPDATE', 'entry.update'],\n ['ENTRY_DELETE', 'entry.delete'],\n ['ENTRY_PUBLISH', 'entry.publish'],\n ['ENTRY_UNPUBLISH', 'entry.unpublish'],\n ['ENTRY_DRAFT_DISCARD', 'entry.draft-discard'],\n ]),\n addAllowedEvent(key, value) {\n this.allowedEvents.set(key, value);\n },\n removeAllowedEvent(key) {\n this.allowedEvents.delete(key);\n },\n listAllowedEvents() {\n return Array.from(this.allowedEvents.keys());\n },\n getAllowedEvent(key) {\n return this.allowedEvents.get(key);\n },\n async findWebhooks() {\n const results = await db.query('strapi::webhook').findMany();\n\n return results.map(fromDBObject);\n },\n async findWebhook(id) {\n const result = await db.query('strapi::webhook').findOne({ where: { id } });\n return result ? fromDBObject(result) : null;\n },\n async createWebhook(data) {\n await webhookEventValidator(this.allowedEvents, data.events);\n\n return db\n .query('strapi::webhook')\n .create({\n data: toDBObject({ ...data, isEnabled: true }),\n })\n .then(fromDBObject);\n },\n async updateWebhook(id, data) {\n await webhookEventValidator(this.allowedEvents, data.events);\n\n const webhook = await db.query('strapi::webhook').update({\n where: { id },\n data: toDBObject(data),\n });\n\n return webhook ? fromDBObject(webhook) : null;\n },\n async deleteWebhook(id) {\n const webhook = await db.query('strapi::webhook').delete({ where: { id } });\n return webhook ? fromDBObject(webhook) : null;\n },\n };\n};\n\nexport { webhookModel, createWebhookStore };\n"],"names":[],"mappings":"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"}
|
@@ -1,56 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
const createDebugger = require("debug");
|
3
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
4
|
-
const createDebugger__default = /* @__PURE__ */ _interopDefault(createDebugger);
|
5
|
-
const debug = createDebugger__default.default("strapi:worker-queue");
|
6
|
-
const noop = () => {
|
7
|
-
};
|
8
|
-
class WorkerQueue {
|
9
|
-
logger;
|
10
|
-
worker;
|
11
|
-
concurrency;
|
12
|
-
running;
|
13
|
-
queue;
|
14
|
-
constructor({ logger, concurrency = 5 }) {
|
15
|
-
debug("Initialize worker queue");
|
16
|
-
this.logger = logger;
|
17
|
-
this.worker = noop;
|
18
|
-
this.concurrency = concurrency;
|
19
|
-
this.running = 0;
|
20
|
-
this.queue = [];
|
21
|
-
}
|
22
|
-
subscribe(worker) {
|
23
|
-
debug("Subscribe to worker queue");
|
24
|
-
this.worker = worker;
|
25
|
-
}
|
26
|
-
enqueue(payload) {
|
27
|
-
debug("Enqueue event in worker queue");
|
28
|
-
if (this.running < this.concurrency) {
|
29
|
-
this.running += 1;
|
30
|
-
this.execute(payload);
|
31
|
-
} else {
|
32
|
-
this.queue.unshift(payload);
|
33
|
-
}
|
34
|
-
}
|
35
|
-
pop() {
|
36
|
-
debug("Pop worker queue and execute");
|
37
|
-
const payload = this.queue.pop();
|
38
|
-
if (payload) {
|
39
|
-
this.execute(payload);
|
40
|
-
} else {
|
41
|
-
this.running -= 1;
|
42
|
-
}
|
43
|
-
}
|
44
|
-
async execute(payload) {
|
45
|
-
debug("Execute worker");
|
46
|
-
try {
|
47
|
-
await this.worker(payload);
|
48
|
-
} catch (error) {
|
49
|
-
this.logger.error(error);
|
50
|
-
} finally {
|
51
|
-
this.pop();
|
52
|
-
}
|
53
|
-
}
|
54
|
-
}
|
55
|
-
module.exports = WorkerQueue;
|
56
|
-
//# sourceMappingURL=worker-queue.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"worker-queue.js","sources":["../../src/services/worker-queue.ts"],"sourcesContent":["/**\n * Simple worker queue in memory\n */\nimport createDebugger from 'debug';\nimport type { Logger } from '@strapi/logger';\nimport type { Utils } from '@strapi/types';\n\nconst debug = createDebugger('strapi:worker-queue');\n\ninterface ConstructorParameters {\n logger: Logger;\n concurrency?: number;\n}\n\ntype Worker<TPayload, TReturn> = (payload: TPayload) => Promise<TReturn> | TReturn;\n\nconst noop: Utils.Function.Any = () => {};\n\nexport default class WorkerQueue<TPayload, TReturn> {\n logger: Logger;\n\n worker: Worker<TPayload, TReturn>;\n\n concurrency: number;\n\n running: number;\n\n queue: TPayload[];\n\n constructor({ logger, concurrency = 5 }: ConstructorParameters) {\n debug('Initialize worker queue');\n\n this.logger = logger;\n this.worker = noop;\n\n this.concurrency = concurrency;\n this.running = 0;\n this.queue = [];\n }\n\n subscribe(worker: Worker<TPayload, TReturn>) {\n debug('Subscribe to worker queue');\n this.worker = worker;\n }\n\n enqueue(payload: TPayload) {\n debug('Enqueue event in worker queue');\n if (this.running < this.concurrency) {\n this.running += 1;\n this.execute(payload);\n } else {\n this.queue.unshift(payload);\n }\n }\n\n pop() {\n debug('Pop worker queue and execute');\n const payload = this.queue.pop();\n\n if (payload) {\n this.execute(payload);\n } else {\n this.running -= 1;\n }\n }\n\n async execute(payload: TPayload) {\n debug('Execute worker');\n try {\n await this.worker(payload);\n } catch (error) {\n this.logger.error(error);\n } finally {\n this.pop();\n }\n }\n}\n"],"names":["createDebugger"],"mappings":";;;;AAOA,MAAM,QAAQA,gCAAe,qBAAqB;AASlD,MAAM,OAA2B,MAAM;AAAC;AAExC,MAAqB,YAA+B;AAAA,EAClD;AAAA,EAEA;AAAA,EAEA;AAAA,EAEA;AAAA,EAEA;AAAA,EAEA,YAAY,EAAE,QAAQ,cAAc,KAA4B;AAC9D,UAAM,yBAAyB;AAE/B,SAAK,SAAS;AACd,SAAK,SAAS;AAEd,SAAK,cAAc;AACnB,SAAK,UAAU;AACf,SAAK,QAAQ,CAAC;AAAA,EAAA;AAAA,EAGhB,UAAU,QAAmC;AAC3C,UAAM,2BAA2B;AACjC,SAAK,SAAS;AAAA,EAAA;AAAA,EAGhB,QAAQ,SAAmB;AACzB,UAAM,+BAA+B;AACjC,QAAA,KAAK,UAAU,KAAK,aAAa;AACnC,WAAK,WAAW;AAChB,WAAK,QAAQ,OAAO;AAAA,IAAA,OACf;AACA,WAAA,MAAM,QAAQ,OAAO;AAAA,IAAA;AAAA,EAC5B;AAAA,EAGF,MAAM;AACJ,UAAM,8BAA8B;AAC9B,UAAA,UAAU,KAAK,MAAM,IAAI;AAE/B,QAAI,SAAS;AACX,WAAK,QAAQ,OAAO;AAAA,IAAA,OACf;AACL,WAAK,WAAW;AAAA,IAAA;AAAA,EAClB;AAAA,EAGF,MAAM,QAAQ,SAAmB;AAC/B,UAAM,gBAAgB;AAClB,QAAA;AACI,YAAA,KAAK,OAAO,OAAO;AAAA,aAClB,OAAO;AACT,WAAA,OAAO,MAAM,KAAK;AAAA,IAAA,UACvB;AACA,WAAK,IAAI;AAAA,IAAA;AAAA,EACX;AAEJ;;"}
|
@@ -1,55 +0,0 @@
|
|
1
|
-
import createDebugger from "debug";
|
2
|
-
const debug = createDebugger("strapi:worker-queue");
|
3
|
-
const noop = () => {
|
4
|
-
};
|
5
|
-
class WorkerQueue {
|
6
|
-
logger;
|
7
|
-
worker;
|
8
|
-
concurrency;
|
9
|
-
running;
|
10
|
-
queue;
|
11
|
-
constructor({ logger, concurrency = 5 }) {
|
12
|
-
debug("Initialize worker queue");
|
13
|
-
this.logger = logger;
|
14
|
-
this.worker = noop;
|
15
|
-
this.concurrency = concurrency;
|
16
|
-
this.running = 0;
|
17
|
-
this.queue = [];
|
18
|
-
}
|
19
|
-
subscribe(worker) {
|
20
|
-
debug("Subscribe to worker queue");
|
21
|
-
this.worker = worker;
|
22
|
-
}
|
23
|
-
enqueue(payload) {
|
24
|
-
debug("Enqueue event in worker queue");
|
25
|
-
if (this.running < this.concurrency) {
|
26
|
-
this.running += 1;
|
27
|
-
this.execute(payload);
|
28
|
-
} else {
|
29
|
-
this.queue.unshift(payload);
|
30
|
-
}
|
31
|
-
}
|
32
|
-
pop() {
|
33
|
-
debug("Pop worker queue and execute");
|
34
|
-
const payload = this.queue.pop();
|
35
|
-
if (payload) {
|
36
|
-
this.execute(payload);
|
37
|
-
} else {
|
38
|
-
this.running -= 1;
|
39
|
-
}
|
40
|
-
}
|
41
|
-
async execute(payload) {
|
42
|
-
debug("Execute worker");
|
43
|
-
try {
|
44
|
-
await this.worker(payload);
|
45
|
-
} catch (error) {
|
46
|
-
this.logger.error(error);
|
47
|
-
} finally {
|
48
|
-
this.pop();
|
49
|
-
}
|
50
|
-
}
|
51
|
-
}
|
52
|
-
export {
|
53
|
-
WorkerQueue as default
|
54
|
-
};
|
55
|
-
//# sourceMappingURL=worker-queue.mjs.map
|