@strapi/strapi 4.14.5 → 4.15.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/README.md +1 -0
- package/bin/strapi.js +1 -6
- package/dist/Strapi.js +454 -532
- package/dist/Strapi.js.map +1 -1
- package/dist/Strapi.mjs +464 -0
- package/dist/Strapi.mjs.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +4 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/actions/admin/create-user/action.js +75 -94
- package/dist/commands/actions/admin/create-user/action.js.map +1 -1
- package/dist/commands/actions/admin/create-user/command.d.ts.map +1 -1
- package/dist/commands/actions/admin/create-user/command.js +6 -17
- package/dist/commands/actions/admin/create-user/command.js.map +1 -1
- package/dist/commands/actions/admin/reset-user-password/action.js +33 -36
- package/dist/commands/actions/admin/reset-user-password/action.js.map +1 -1
- package/dist/commands/actions/admin/reset-user-password/command.d.ts.map +1 -1
- package/dist/commands/actions/admin/reset-user-password/command.js +6 -15
- package/dist/commands/actions/admin/reset-user-password/command.js.map +1 -1
- package/dist/commands/actions/build-command/action.js +15 -18
- package/dist/commands/actions/build-command/action.js.map +1 -1
- package/dist/commands/actions/build-command/command.d.ts.map +1 -1
- package/dist/commands/actions/build-command/command.js +6 -13
- package/dist/commands/actions/build-command/command.js.map +1 -1
- package/dist/commands/actions/components/list/action.js +18 -18
- package/dist/commands/actions/components/list/action.js.map +1 -1
- package/dist/commands/actions/components/list/command.d.ts.map +1 -1
- package/dist/commands/actions/components/list/command.js +6 -12
- package/dist/commands/actions/components/list/command.js.map +1 -1
- package/dist/commands/actions/configuration/dump/action.js +33 -43
- package/dist/commands/actions/configuration/dump/action.js.map +1 -1
- package/dist/commands/actions/configuration/dump/command.d.ts.map +1 -1
- package/dist/commands/actions/configuration/dump/command.js +6 -15
- package/dist/commands/actions/configuration/dump/command.js.map +1 -1
- package/dist/commands/actions/configuration/restore/action.js +122 -139
- package/dist/commands/actions/configuration/restore/action.js.map +1 -1
- package/dist/commands/actions/configuration/restore/command.d.ts.map +1 -1
- package/dist/commands/actions/configuration/restore/command.js +6 -15
- package/dist/commands/actions/configuration/restore/command.js.map +1 -1
- package/dist/commands/actions/console/action.js +19 -23
- package/dist/commands/actions/console/action.js.map +1 -1
- package/dist/commands/actions/console/command.d.ts.map +1 -1
- package/dist/commands/actions/console/command.js +6 -12
- package/dist/commands/actions/console/command.js.map +1 -1
- package/dist/commands/actions/content-types/list/action.js +18 -18
- package/dist/commands/actions/content-types/list/action.js.map +1 -1
- package/dist/commands/actions/content-types/list/command.d.ts.map +1 -1
- package/dist/commands/actions/content-types/list/command.js +6 -12
- package/dist/commands/actions/content-types/list/command.js.map +1 -1
- package/dist/commands/actions/controllers/list/action.js +18 -18
- package/dist/commands/actions/controllers/list/action.js.map +1 -1
- package/dist/commands/actions/controllers/list/command.d.ts.map +1 -1
- package/dist/commands/actions/controllers/list/command.js +6 -12
- package/dist/commands/actions/controllers/list/command.js.map +1 -1
- package/dist/commands/actions/develop/action.d.ts +1 -75
- package/dist/commands/actions/develop/action.d.ts.map +1 -1
- package/dist/commands/actions/develop/action.js +184 -177
- package/dist/commands/actions/develop/action.js.map +1 -1
- package/dist/commands/actions/develop/command.d.ts.map +1 -1
- package/dist/commands/actions/develop/command.js +6 -17
- package/dist/commands/actions/develop/command.js.map +1 -1
- package/dist/commands/actions/generate/command.js +30 -16
- package/dist/commands/actions/generate/command.js.map +1 -1
- package/dist/commands/actions/hooks/list/action.js +18 -18
- package/dist/commands/actions/hooks/list/action.js.map +1 -1
- package/dist/commands/actions/hooks/list/command.d.ts.map +1 -1
- package/dist/commands/actions/hooks/list/command.js +6 -12
- package/dist/commands/actions/hooks/list/command.js.map +1 -1
- package/dist/commands/actions/install/action.js +41 -45
- package/dist/commands/actions/install/action.js.map +1 -1
- package/dist/commands/actions/install/command.d.ts.map +1 -1
- package/dist/commands/actions/install/command.js +6 -12
- package/dist/commands/actions/install/command.js.map +1 -1
- package/dist/commands/actions/middlewares/list/action.js +18 -18
- package/dist/commands/actions/middlewares/list/action.js.map +1 -1
- package/dist/commands/actions/middlewares/list/command.d.ts.map +1 -1
- package/dist/commands/actions/middlewares/list/command.js +6 -12
- package/dist/commands/actions/middlewares/list/command.js.map +1 -1
- package/dist/commands/actions/new/action.js +5 -10
- package/dist/commands/actions/new/action.js.map +1 -1
- package/dist/commands/actions/new/command.js +14 -33
- package/dist/commands/actions/new/command.js.map +1 -1
- package/dist/commands/actions/plugin/build-command/action.js +80 -79
- package/dist/commands/actions/plugin/build-command/action.js.map +1 -1
- package/dist/commands/actions/plugin/build-command/command.d.ts.map +1 -1
- package/dist/commands/actions/plugin/build-command/command.js +7 -18
- package/dist/commands/actions/plugin/build-command/command.js.map +1 -1
- package/dist/commands/actions/plugin/watch/action.d.ts +7 -0
- package/dist/commands/actions/plugin/watch/action.d.ts.map +1 -0
- package/dist/commands/actions/plugin/watch/action.js +85 -0
- package/dist/commands/actions/plugin/watch/action.js.map +1 -0
- package/dist/commands/actions/plugin/watch/command.d.ts +7 -0
- package/dist/commands/actions/plugin/watch/command.d.ts.map +1 -0
- package/dist/commands/actions/plugin/watch/command.js +8 -0
- package/dist/commands/actions/plugin/watch/command.js.map +1 -0
- package/dist/commands/actions/policies/list/action.js +18 -18
- package/dist/commands/actions/policies/list/action.js.map +1 -1
- package/dist/commands/actions/policies/list/command.d.ts.map +1 -1
- package/dist/commands/actions/policies/list/command.js +6 -12
- package/dist/commands/actions/policies/list/command.js.map +1 -1
- package/dist/commands/actions/report/action.js +22 -25
- package/dist/commands/actions/report/action.js.map +1 -1
- package/dist/commands/actions/report/command.d.ts.map +1 -1
- package/dist/commands/actions/report/command.js +6 -15
- package/dist/commands/actions/report/command.js.map +1 -1
- package/dist/commands/actions/routes/list/action.js +22 -24
- package/dist/commands/actions/routes/list/action.js.map +1 -1
- package/dist/commands/actions/routes/list/command.d.ts.map +1 -1
- package/dist/commands/actions/routes/list/command.js +6 -12
- package/dist/commands/actions/routes/list/command.js.map +1 -1
- package/dist/commands/actions/services/list/action.js +18 -18
- package/dist/commands/actions/services/list/action.js.map +1 -1
- package/dist/commands/actions/services/list/command.d.ts.map +1 -1
- package/dist/commands/actions/services/list/command.js +6 -12
- package/dist/commands/actions/services/list/command.js.map +1 -1
- package/dist/commands/actions/start/action.d.ts +1 -74
- package/dist/commands/actions/start/action.d.ts.map +1 -1
- package/dist/commands/actions/start/action.js +19 -20
- package/dist/commands/actions/start/action.js.map +1 -1
- package/dist/commands/actions/start/command.d.ts.map +1 -1
- package/dist/commands/actions/start/command.js +6 -12
- package/dist/commands/actions/start/command.js.map +1 -1
- package/dist/commands/actions/telemetry/disable/action.js +72 -72
- package/dist/commands/actions/telemetry/disable/action.js.map +1 -1
- package/dist/commands/actions/telemetry/disable/command.d.ts.map +1 -1
- package/dist/commands/actions/telemetry/disable/command.js +6 -12
- package/dist/commands/actions/telemetry/disable/command.js.map +1 -1
- package/dist/commands/actions/telemetry/enable/action.js +87 -88
- package/dist/commands/actions/telemetry/enable/action.js.map +1 -1
- package/dist/commands/actions/telemetry/enable/command.d.ts.map +1 -1
- package/dist/commands/actions/telemetry/enable/command.js +6 -12
- package/dist/commands/actions/telemetry/enable/command.js.map +1 -1
- package/dist/commands/actions/templates/generate/action.js +59 -73
- package/dist/commands/actions/templates/generate/action.js.map +1 -1
- package/dist/commands/actions/templates/generate/command.d.ts.map +1 -1
- package/dist/commands/actions/templates/generate/command.js +6 -12
- package/dist/commands/actions/templates/generate/command.js.map +1 -1
- package/dist/commands/actions/ts/generate-types/action.js +25 -26
- package/dist/commands/actions/ts/generate-types/action.js.map +1 -1
- package/dist/commands/actions/ts/generate-types/command.d.ts.map +1 -1
- package/dist/commands/actions/ts/generate-types/command.js +9 -16
- package/dist/commands/actions/ts/generate-types/command.js.map +1 -1
- package/dist/commands/actions/uninstall/action.js +60 -62
- package/dist/commands/actions/uninstall/action.js.map +1 -1
- package/dist/commands/actions/uninstall/command.d.ts.map +1 -1
- package/dist/commands/actions/uninstall/command.js +6 -13
- package/dist/commands/actions/uninstall/command.js.map +1 -1
- package/dist/commands/actions/version/command.js +10 -17
- package/dist/commands/actions/version/command.js.map +1 -1
- package/dist/commands/actions/watch-admin/action.js +33 -34
- package/dist/commands/actions/watch-admin/action.js.map +1 -1
- package/dist/commands/actions/watch-admin/command.d.ts.map +1 -1
- package/dist/commands/actions/watch-admin/command.js +6 -13
- package/dist/commands/actions/watch-admin/command.js.map +1 -1
- package/dist/commands/builders/admin.js +46 -50
- package/dist/commands/builders/admin.js.map +1 -1
- package/dist/commands/builders/typescript.js +28 -25
- package/dist/commands/builders/typescript.js.map +1 -1
- package/dist/commands/index.d.ts +1 -0
- package/dist/commands/index.d.ts.map +1 -1
- package/dist/commands/index.js +102 -91
- package/dist/commands/index.js.map +1 -1
- package/dist/commands/utils/commander.js +11 -136
- package/dist/commands/utils/commander.js.map +1 -1
- package/dist/commands/utils/helpers.d.ts +4 -6
- package/dist/commands/utils/helpers.d.ts.map +1 -1
- package/dist/commands/utils/helpers.js +57 -155
- package/dist/commands/utils/helpers.js.map +1 -1
- package/dist/commands/utils/logger.js +59 -49
- package/dist/commands/utils/logger.js.map +1 -1
- package/dist/commands/utils/pkg.js +98 -107
- package/dist/commands/utils/pkg.js.map +1 -1
- package/dist/compile.js +15 -17
- package/dist/compile.js.map +1 -1
- package/dist/compile.mjs +17 -0
- package/dist/compile.mjs.map +1 -0
- package/dist/container.js +32 -35
- package/dist/container.js.map +1 -1
- package/dist/container.mjs +36 -0
- package/dist/container.mjs.map +1 -0
- package/dist/core/app-configuration/config-loader.js +17 -20
- package/dist/core/app-configuration/config-loader.js.map +1 -1
- package/dist/core/app-configuration/config-loader.mjs +17 -0
- package/dist/core/app-configuration/config-loader.mjs.map +1 -0
- package/dist/core/app-configuration/index.js +51 -50
- package/dist/core/app-configuration/index.js.map +1 -1
- package/dist/core/app-configuration/index.mjs +51 -0
- package/dist/core/app-configuration/index.mjs.map +1 -0
- package/dist/core/app-configuration/load-config-file.js +34 -38
- package/dist/core/app-configuration/load-config-file.js.map +1 -1
- package/dist/core/app-configuration/load-config-file.mjs +42 -0
- package/dist/core/app-configuration/load-config-file.mjs.map +1 -0
- package/dist/core/bootstrap.js +25 -24
- package/dist/core/bootstrap.js.map +1 -1
- package/dist/core/bootstrap.mjs +27 -0
- package/dist/core/bootstrap.mjs.map +1 -0
- package/dist/core/domain/content-type/index.js +108 -104
- package/dist/core/domain/content-type/index.js.map +1 -1
- package/dist/core/domain/content-type/index.mjs +119 -0
- package/dist/core/domain/content-type/index.mjs.map +1 -0
- package/dist/core/domain/content-type/validator.js +69 -83
- package/dist/core/domain/content-type/validator.js.map +1 -1
- package/dist/core/domain/content-type/validator.mjs +75 -0
- package/dist/core/domain/content-type/validator.mjs.map +1 -0
- package/dist/core/domain/module/index.js +97 -100
- package/dist/core/domain/module/index.js.map +1 -1
- package/dist/core/domain/module/index.mjs +105 -0
- package/dist/core/domain/module/index.mjs.map +1 -0
- package/dist/core/domain/module/validation.js +21 -25
- package/dist/core/domain/module/validation.js.map +1 -1
- package/dist/core/domain/module/validation.mjs +25 -0
- package/dist/core/domain/module/validation.mjs.map +1 -0
- package/dist/core/loaders/admin.js +13 -15
- package/dist/core/loaders/admin.js.map +1 -1
- package/dist/core/loaders/admin.mjs +15 -0
- package/dist/core/loaders/admin.mjs.map +1 -0
- package/dist/core/loaders/apis.js +109 -135
- package/dist/core/loaders/apis.js.map +1 -1
- package/dist/core/loaders/apis.mjs +128 -0
- package/dist/core/loaders/apis.mjs.map +1 -0
- package/dist/core/loaders/components.js +34 -34
- package/dist/core/loaders/components.js.map +1 -1
- package/dist/core/loaders/components.mjs +36 -0
- package/dist/core/loaders/components.mjs.map +1 -0
- package/dist/core/loaders/index.js +21 -24
- package/dist/core/loaders/index.js.map +1 -1
- package/dist/core/loaders/index.mjs +24 -0
- package/dist/core/loaders/index.mjs.map +1 -0
- package/dist/core/loaders/middlewares.js +25 -28
- package/dist/core/loaders/middlewares.js.map +1 -1
- package/dist/core/loaders/middlewares.mjs +30 -0
- package/dist/core/loaders/middlewares.mjs.map +1 -0
- package/dist/core/loaders/plugins/get-enabled-plugins.js +96 -99
- package/dist/core/loaders/plugins/get-enabled-plugins.js.map +1 -1
- package/dist/core/loaders/plugins/get-enabled-plugins.mjs +108 -0
- package/dist/core/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
- package/dist/core/loaders/plugins/get-user-plugins-config.js +23 -27
- package/dist/core/loaders/plugins/get-user-plugins-config.js.map +1 -1
- package/dist/core/loaders/plugins/get-user-plugins-config.mjs +25 -0
- package/dist/core/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
- package/dist/core/loaders/plugins/index.js +92 -96
- package/dist/core/loaders/plugins/index.js.map +1 -1
- package/dist/core/loaders/plugins/index.mjs +104 -0
- package/dist/core/loaders/plugins/index.mjs.map +1 -0
- package/dist/core/loaders/policies.js +21 -24
- package/dist/core/loaders/policies.js.map +1 -1
- package/dist/core/loaders/policies.mjs +24 -0
- package/dist/core/loaders/policies.mjs.map +1 -0
- package/dist/core/loaders/sanitizers.js +4 -4
- package/dist/core/loaders/sanitizers.js.map +1 -1
- package/dist/core/loaders/sanitizers.mjs +7 -0
- package/dist/core/loaders/sanitizers.mjs.map +1 -0
- package/dist/core/loaders/src-index.js +28 -32
- package/dist/core/loaders/src-index.js.map +1 -1
- package/dist/core/loaders/src-index.mjs +34 -0
- package/dist/core/loaders/src-index.mjs.map +1 -0
- package/dist/core/loaders/validators.js +4 -4
- package/dist/core/loaders/validators.js.map +1 -1
- package/dist/core/loaders/validators.mjs +7 -0
- package/dist/core/loaders/validators.mjs.map +1 -0
- package/dist/core/registries/apis.js +20 -21
- package/dist/core/registries/apis.js.map +1 -1
- package/dist/core/registries/apis.mjs +24 -0
- package/dist/core/registries/apis.mjs.map +1 -0
- package/dist/core/registries/config.js +21 -21
- package/dist/core/registries/config.js.map +1 -1
- package/dist/core/registries/config.mjs +22 -0
- package/dist/core/registries/config.mjs.map +1 -0
- package/dist/core/registries/content-types.js +65 -64
- package/dist/core/registries/content-types.js.map +1 -1
- package/dist/core/registries/content-types.mjs +72 -0
- package/dist/core/registries/content-types.mjs.map +1 -0
- package/dist/core/registries/controllers.js +77 -78
- package/dist/core/registries/controllers.js.map +1 -1
- package/dist/core/registries/controllers.mjs +81 -0
- package/dist/core/registries/controllers.mjs.map +1 -0
- package/dist/core/registries/custom-fields.js +66 -69
- package/dist/core/registries/custom-fields.js.map +1 -1
- package/dist/core/registries/custom-fields.mjs +72 -0
- package/dist/core/registries/custom-fields.mjs.map +1 -0
- package/dist/core/registries/hooks.js +55 -56
- package/dist/core/registries/hooks.js.map +1 -1
- package/dist/core/registries/hooks.mjs +59 -0
- package/dist/core/registries/hooks.mjs.map +1 -0
- package/dist/core/registries/middlewares.js +57 -59
- package/dist/core/registries/middlewares.js.map +1 -1
- package/dist/core/registries/middlewares.mjs +61 -0
- package/dist/core/registries/middlewares.mjs.map +1 -0
- package/dist/core/registries/modules.js +36 -37
- package/dist/core/registries/modules.js.map +1 -1
- package/dist/core/registries/modules.mjs +40 -0
- package/dist/core/registries/modules.mjs.map +1 -0
- package/dist/core/registries/plugins.js +20 -21
- package/dist/core/registries/plugins.js.map +1 -1
- package/dist/core/registries/plugins.mjs +24 -0
- package/dist/core/registries/plugins.mjs.map +1 -0
- package/dist/core/registries/policies.js +59 -61
- package/dist/core/registries/policies.js.map +1 -1
- package/dist/core/registries/policies.mjs +63 -0
- package/dist/core/registries/policies.mjs.map +1 -0
- package/dist/core/registries/sanitizers.js +22 -24
- package/dist/core/registries/sanitizers.js.map +1 -1
- package/dist/core/registries/sanitizers.mjs +24 -0
- package/dist/core/registries/sanitizers.mjs.map +1 -0
- package/dist/core/registries/services.js +77 -79
- package/dist/core/registries/services.js.map +1 -1
- package/dist/core/registries/services.mjs +81 -0
- package/dist/core/registries/services.mjs.map +1 -0
- package/dist/core/registries/validators.js +22 -24
- package/dist/core/registries/validators.js.map +1 -1
- package/dist/core/registries/validators.mjs +24 -0
- package/dist/core/registries/validators.mjs.map +1 -0
- package/dist/core/utils.js +19 -20
- package/dist/core/utils.js.map +1 -1
- package/dist/core/utils.mjs +27 -0
- package/dist/core/utils.mjs.map +1 -0
- package/dist/core-api/controller/collection-type.js +90 -93
- package/dist/core-api/controller/collection-type.js.map +1 -1
- package/dist/core-api/controller/collection-type.mjs +93 -0
- package/dist/core-api/controller/collection-type.mjs.map +1 -0
- package/dist/core-api/controller/index.js +43 -46
- package/dist/core-api/controller/index.js.map +1 -1
- package/dist/core-api/controller/index.mjs +47 -0
- package/dist/core-api/controller/index.mjs.map +1 -0
- package/dist/core-api/controller/single-type.js +48 -50
- package/dist/core-api/controller/single-type.js.map +1 -1
- package/dist/core-api/controller/single-type.mjs +51 -0
- package/dist/core-api/controller/single-type.mjs.map +1 -0
- package/dist/core-api/controller/transform.js +70 -72
- package/dist/core-api/controller/transform.js.map +1 -1
- package/dist/core-api/controller/transform.mjs +84 -0
- package/dist/core-api/controller/transform.mjs.map +1 -0
- package/dist/core-api/routes/index.js +60 -61
- package/dist/core-api/routes/index.js.map +1 -1
- package/dist/core-api/routes/index.mjs +67 -0
- package/dist/core-api/routes/index.mjs.map +1 -0
- package/dist/core-api/service/collection-type.js +57 -57
- package/dist/core-api/service/collection-type.js.map +1 -1
- package/dist/core-api/service/collection-type.mjs +62 -0
- package/dist/core-api/service/collection-type.mjs.map +1 -0
- package/dist/core-api/service/get-fetch-params.js +10 -12
- package/dist/core-api/service/get-fetch-params.js.map +1 -1
- package/dist/core-api/service/get-fetch-params.mjs +14 -0
- package/dist/core-api/service/get-fetch-params.mjs.map +1 -0
- package/dist/core-api/service/index.js +13 -15
- package/dist/core-api/service/index.js.map +1 -1
- package/dist/core-api/service/index.mjs +16 -0
- package/dist/core-api/service/index.mjs.map +1 -0
- package/dist/core-api/service/pagination.js +71 -79
- package/dist/core-api/service/pagination.js.map +1 -1
- package/dist/core-api/service/pagination.mjs +89 -0
- package/dist/core-api/service/pagination.mjs.map +1 -0
- package/dist/core-api/service/single-type.js +53 -53
- package/dist/core-api/service/single-type.js.map +1 -1
- package/dist/core-api/service/single-type.mjs +58 -0
- package/dist/core-api/service/single-type.mjs.map +1 -0
- package/dist/ee/index.js +128 -160
- package/dist/ee/index.js.map +1 -1
- package/dist/ee/index.mjs +154 -0
- package/dist/ee/index.mjs.map +1 -0
- package/dist/ee/license.js +72 -77
- package/dist/ee/license.js.map +1 -1
- package/dist/ee/license.mjs +86 -0
- package/dist/ee/license.mjs.map +1 -0
- package/dist/factories.js +62 -61
- package/dist/factories.js.map +1 -1
- package/dist/factories.mjs +71 -0
- package/dist/factories.mjs.map +1 -0
- package/dist/index.d.ts +0 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7 -34
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +8 -0
- package/dist/index.mjs.map +1 -0
- package/dist/load/filepath-to-prop-path.js +9 -19
- package/dist/load/filepath-to-prop-path.js.map +1 -1
- package/dist/load/filepath-to-prop-path.mjs +10 -0
- package/dist/load/filepath-to-prop-path.mjs.map +1 -0
- package/dist/load/glob.js +11 -16
- package/dist/load/glob.js.map +1 -1
- package/dist/load/glob.mjs +14 -0
- package/dist/load/glob.mjs.map +1 -0
- package/dist/load/load-files.js +35 -43
- package/dist/load/load-files.js.map +1 -1
- package/dist/load/load-files.mjs +35 -0
- package/dist/load/load-files.mjs.map +1 -0
- package/dist/load/package-path.js +6 -10
- package/dist/load/package-path.js.map +1 -1
- package/dist/middlewares/body.js +53 -66
- package/dist/middlewares/body.js.map +1 -1
- package/dist/middlewares/body.mjs +61 -0
- package/dist/middlewares/body.mjs.map +1 -0
- package/dist/middlewares/compression.js +6 -8
- package/dist/middlewares/compression.js.map +1 -1
- package/dist/middlewares/compression.mjs +6 -0
- package/dist/middlewares/compression.mjs.map +1 -0
- package/dist/middlewares/cors.js +45 -48
- package/dist/middlewares/cors.js.map +1 -1
- package/dist/middlewares/cors.mjs +49 -0
- package/dist/middlewares/cors.mjs.map +1 -0
- package/dist/middlewares/errors.js +30 -32
- package/dist/middlewares/errors.js.map +1 -1
- package/dist/middlewares/errors.mjs +33 -0
- package/dist/middlewares/errors.mjs.map +1 -0
- package/dist/middlewares/favicon.js +16 -24
- package/dist/middlewares/favicon.js.map +1 -1
- package/dist/middlewares/favicon.mjs +20 -0
- package/dist/middlewares/favicon.mjs.map +1 -0
- package/dist/middlewares/index.js +32 -32
- package/dist/middlewares/index.js.map +1 -1
- package/dist/middlewares/index.mjs +34 -0
- package/dist/middlewares/index.mjs.map +1 -0
- package/dist/middlewares/ip.js +6 -8
- package/dist/middlewares/ip.js.map +1 -1
- package/dist/middlewares/ip.mjs +6 -0
- package/dist/middlewares/ip.mjs.map +1 -0
- package/dist/middlewares/logger.js +8 -9
- package/dist/middlewares/logger.js.map +1 -1
- package/dist/middlewares/logger.mjs +12 -0
- package/dist/middlewares/logger.mjs.map +1 -0
- package/dist/middlewares/powered-by.js +8 -9
- package/dist/middlewares/powered-by.js.map +1 -1
- package/dist/middlewares/powered-by.mjs +14 -0
- package/dist/middlewares/powered-by.mjs.map +1 -0
- package/dist/middlewares/public/index.js +85 -106
- package/dist/middlewares/public/index.js.map +1 -1
- package/dist/middlewares/public/index.mjs +85 -0
- package/dist/middlewares/public/index.mjs.map +1 -0
- package/dist/middlewares/public/serve-static.js +20 -23
- package/dist/middlewares/public/serve-static.js.map +1 -1
- package/dist/middlewares/public/serve-static.mjs +21 -0
- package/dist/middlewares/public/serve-static.mjs.map +1 -0
- package/dist/middlewares/query.js +32 -37
- package/dist/middlewares/query.js.map +1 -1
- package/dist/middlewares/query.mjs +38 -0
- package/dist/middlewares/query.mjs.map +1 -0
- package/dist/middlewares/response-time.js +8 -9
- package/dist/middlewares/response-time.js.map +1 -1
- package/dist/middlewares/response-time.mjs +12 -0
- package/dist/middlewares/response-time.mjs.map +1 -0
- package/dist/middlewares/responses.js +11 -12
- package/dist/middlewares/responses.js.map +1 -1
- package/dist/middlewares/responses.mjs +15 -0
- package/dist/middlewares/responses.mjs.map +1 -0
- package/dist/middlewares/security.js +44 -46
- package/dist/middlewares/security.js.map +1 -1
- package/dist/middlewares/security.mjs +48 -0
- package/dist/middlewares/security.mjs.map +1 -0
- package/dist/middlewares/session.js +24 -24
- package/dist/middlewares/session.js.map +1 -1
- package/dist/middlewares/session.mjs +28 -0
- package/dist/middlewares/session.mjs.map +1 -0
- package/dist/migrations/draft-publish.js +27 -36
- package/dist/migrations/draft-publish.js.map +1 -1
- package/dist/migrations/draft-publish.mjs +37 -0
- package/dist/migrations/draft-publish.mjs.map +1 -0
- package/dist/services/auth/index.js +74 -77
- package/dist/services/auth/index.js.map +1 -1
- package/dist/services/auth/index.mjs +80 -0
- package/dist/services/auth/index.mjs.map +1 -0
- package/dist/services/content-api/index.js +54 -57
- package/dist/services/content-api/index.js.map +1 -1
- package/dist/services/content-api/index.mjs +58 -0
- package/dist/services/content-api/index.mjs.map +1 -0
- package/dist/services/content-api/permissions/engine.js +6 -7
- package/dist/services/content-api/permissions/engine.js.map +1 -1
- package/dist/services/content-api/permissions/engine.mjs +6 -0
- package/dist/services/content-api/permissions/engine.mjs.map +1 -0
- package/dist/services/content-api/permissions/index.js +79 -102
- package/dist/services/content-api/permissions/index.js.map +1 -1
- package/dist/services/content-api/permissions/index.mjs +86 -0
- package/dist/services/content-api/permissions/index.mjs.map +1 -0
- package/dist/services/content-api/permissions/providers/action.js +14 -14
- package/dist/services/content-api/permissions/providers/action.js.map +1 -1
- package/dist/services/content-api/permissions/providers/action.mjs +17 -0
- package/dist/services/content-api/permissions/providers/action.mjs.map +1 -0
- package/dist/services/content-api/permissions/providers/condition.js +14 -14
- package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
- package/dist/services/content-api/permissions/providers/condition.mjs +17 -0
- package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -0
- package/dist/services/core-store.js +91 -111
- package/dist/services/core-store.js.map +1 -1
- package/dist/services/core-store.mjs +103 -0
- package/dist/services/core-store.mjs.map +1 -0
- package/dist/services/cron.js +60 -66
- package/dist/services/cron.js.map +1 -1
- package/dist/services/cron.mjs +64 -0
- package/dist/services/cron.mjs.map +1 -0
- package/dist/services/custom-fields.js +7 -8
- package/dist/services/custom-fields.js.map +1 -1
- package/dist/services/custom-fields.mjs +11 -0
- package/dist/services/custom-fields.mjs.map +1 -0
- package/dist/services/entity-service/attributes/index.js +17 -21
- package/dist/services/entity-service/attributes/index.js.map +1 -1
- package/dist/services/entity-service/attributes/index.mjs +22 -0
- package/dist/services/entity-service/attributes/index.mjs.map +1 -0
- package/dist/services/entity-service/attributes/transforms.js +17 -19
- package/dist/services/entity-service/attributes/transforms.js.map +1 -1
- package/dist/services/entity-service/attributes/transforms.mjs +19 -0
- package/dist/services/entity-service/attributes/transforms.mjs.map +1 -0
- package/dist/services/entity-service/components.js +336 -333
- package/dist/services/entity-service/components.js.map +1 -1
- package/dist/services/entity-service/components.mjs +382 -0
- package/dist/services/entity-service/components.mjs.map +1 -0
- package/dist/services/entity-service/index.js +314 -297
- package/dist/services/entity-service/index.js.map +1 -1
- package/dist/services/entity-service/index.mjs +326 -0
- package/dist/services/entity-service/index.mjs.map +1 -0
- package/dist/services/entity-service/params.js +4 -5
- package/dist/services/entity-service/params.js.map +1 -1
- package/dist/services/entity-service/params.mjs +8 -0
- package/dist/services/entity-service/params.mjs.map +1 -0
- package/dist/services/entity-validator/blocks-validator.js +95 -116
- package/dist/services/entity-validator/blocks-validator.js.map +1 -1
- package/dist/services/entity-validator/blocks-validator.mjs +108 -0
- package/dist/services/entity-validator/blocks-validator.mjs.map +1 -0
- package/dist/services/entity-validator/index.js +284 -297
- package/dist/services/entity-validator/index.js.map +1 -1
- package/dist/services/entity-validator/index.mjs +318 -0
- package/dist/services/entity-validator/index.mjs.map +1 -0
- package/dist/services/entity-validator/validators.js +92 -124
- package/dist/services/entity-validator/validators.js.map +1 -1
- package/dist/services/entity-validator/validators.mjs +115 -0
- package/dist/services/entity-validator/validators.mjs.map +1 -0
- package/dist/services/errors.js +64 -66
- package/dist/services/errors.js.map +1 -1
- package/dist/services/errors.mjs +74 -0
- package/dist/services/errors.mjs.map +1 -0
- package/dist/services/event-hub.js +64 -74
- package/dist/services/event-hub.js.map +1 -1
- package/dist/services/event-hub.mjs +68 -0
- package/dist/services/event-hub.mjs.map +1 -0
- package/dist/services/fs.js +48 -51
- package/dist/services/fs.js.map +1 -1
- package/dist/services/fs.mjs +49 -0
- package/dist/services/fs.mjs.map +1 -0
- package/dist/services/metrics/admin-user-hash.js +10 -15
- package/dist/services/metrics/admin-user-hash.js.map +1 -1
- package/dist/services/metrics/admin-user-hash.mjs +12 -0
- package/dist/services/metrics/admin-user-hash.mjs.map +1 -0
- package/dist/services/metrics/index.js +40 -48
- package/dist/services/metrics/index.js.map +1 -1
- package/dist/services/metrics/index.mjs +46 -0
- package/dist/services/metrics/index.mjs.map +1 -0
- package/dist/services/metrics/is-truthy.js +6 -8
- package/dist/services/metrics/is-truthy.js.map +1 -1
- package/dist/services/metrics/is-truthy.mjs +8 -0
- package/dist/services/metrics/is-truthy.mjs.map +1 -0
- package/dist/services/metrics/middleware.js +22 -25
- package/dist/services/metrics/middleware.js.map +1 -1
- package/dist/services/metrics/middleware.mjs +26 -0
- package/dist/services/metrics/middleware.mjs.map +1 -0
- package/dist/services/metrics/rate-limiter.js +19 -19
- package/dist/services/metrics/rate-limiter.js.map +1 -1
- package/dist/services/metrics/rate-limiter.mjs +22 -0
- package/dist/services/metrics/rate-limiter.mjs.map +1 -0
- package/dist/services/metrics/sender.js +69 -72
- package/dist/services/metrics/sender.js.map +1 -1
- package/dist/services/metrics/sender.mjs +71 -0
- package/dist/services/metrics/sender.mjs.map +1 -0
- package/dist/services/request-context.js +10 -11
- package/dist/services/request-context.js.map +1 -1
- package/dist/services/request-context.mjs +14 -0
- package/dist/services/request-context.mjs.map +1 -0
- package/dist/services/server/admin-api.js +9 -9
- package/dist/services/server/admin-api.js.map +1 -1
- package/dist/services/server/admin-api.mjs +13 -0
- package/dist/services/server/admin-api.mjs.map +1 -0
- package/dist/services/server/api.js +26 -28
- package/dist/services/server/api.js.map +1 -1
- package/dist/services/server/api.mjs +28 -0
- package/dist/services/server/api.mjs.map +1 -0
- package/dist/services/server/compose-endpoint.js +94 -100
- package/dist/services/server/compose-endpoint.js.map +1 -1
- package/dist/services/server/compose-endpoint.mjs +114 -0
- package/dist/services/server/compose-endpoint.mjs.map +1 -0
- package/dist/services/server/content-api.js +8 -9
- package/dist/services/server/content-api.js.map +1 -1
- package/dist/services/server/content-api.mjs +12 -0
- package/dist/services/server/content-api.mjs.map +1 -0
- package/dist/services/server/http-server.js +42 -47
- package/dist/services/server/http-server.js.map +1 -1
- package/dist/services/server/http-server.mjs +47 -0
- package/dist/services/server/http-server.mjs.map +1 -0
- package/dist/services/server/index.js +82 -85
- package/dist/services/server/index.js.map +1 -1
- package/dist/services/server/index.mjs +86 -0
- package/dist/services/server/index.mjs.map +1 -0
- package/dist/services/server/koa.js +46 -50
- package/dist/services/server/koa.js.map +1 -1
- package/dist/services/server/koa.mjs +48 -0
- package/dist/services/server/koa.mjs.map +1 -0
- package/dist/services/server/middleware.js +80 -91
- package/dist/services/server/middleware.js.map +1 -1
- package/dist/services/server/middleware.mjs +90 -0
- package/dist/services/server/middleware.mjs.map +1 -0
- package/dist/services/server/policy.js +16 -17
- package/dist/services/server/policy.js.map +1 -1
- package/dist/services/server/policy.mjs +20 -0
- package/dist/services/server/policy.mjs.map +1 -0
- package/dist/services/server/register-middlewares.js +58 -68
- package/dist/services/server/register-middlewares.js.map +1 -1
- package/dist/services/server/register-middlewares.mjs +73 -0
- package/dist/services/server/register-middlewares.mjs.map +1 -0
- package/dist/services/server/register-routes.js +64 -82
- package/dist/services/server/register-routes.js.map +1 -1
- package/dist/services/server/register-routes.mjs +75 -0
- package/dist/services/server/register-routes.mjs.map +1 -0
- package/dist/services/server/routing.js +80 -94
- package/dist/services/server/routing.js.map +1 -1
- package/dist/services/server/routing.mjs +89 -0
- package/dist/services/server/routing.mjs.map +1 -0
- package/dist/services/utils/dynamic-zones.js +13 -10
- package/dist/services/utils/dynamic-zones.js.map +1 -1
- package/dist/services/utils/dynamic-zones.mjs +17 -0
- package/dist/services/utils/dynamic-zones.mjs.map +1 -0
- package/dist/services/utils/upload-files.js +59 -68
- package/dist/services/utils/upload-files.js.map +1 -1
- package/dist/services/utils/upload-files.mjs +63 -0
- package/dist/services/utils/upload-files.mjs.map +1 -0
- package/dist/services/webhook-runner.js +122 -130
- package/dist/services/webhook-runner.js.map +1 -1
- package/dist/services/webhook-runner.mjs +131 -0
- package/dist/services/webhook-runner.mjs.map +1 -0
- package/dist/services/webhook-store.js +87 -93
- package/dist/services/webhook-store.js.map +1 -1
- package/dist/services/webhook-store.mjs +100 -0
- package/dist/services/webhook-store.mjs.map +1 -0
- package/dist/services/worker-queue.js +49 -57
- package/dist/services/worker-queue.js.map +1 -1
- package/dist/services/worker-queue.mjs +55 -0
- package/dist/services/worker-queue.mjs.map +1 -0
- package/dist/utils/addSlash.js +13 -13
- package/dist/utils/addSlash.js.map +1 -1
- package/dist/utils/convert-custom-field-type.js +19 -16
- package/dist/utils/convert-custom-field-type.js.map +1 -1
- package/dist/utils/convert-custom-field-type.mjs +24 -0
- package/dist/utils/convert-custom-field-type.mjs.map +1 -0
- package/dist/utils/cron.js +29 -47
- package/dist/utils/cron.js.map +1 -1
- package/dist/utils/cron.mjs +38 -0
- package/dist/utils/cron.mjs.map +1 -0
- package/dist/utils/ee.js +3 -7
- package/dist/utils/ee.js.map +1 -1
- package/dist/utils/ee.mjs +5 -0
- package/dist/utils/ee.mjs.map +1 -0
- package/dist/utils/fetch.js +17 -19
- package/dist/utils/fetch.js.map +1 -1
- package/dist/utils/fetch.mjs +19 -0
- package/dist/utils/fetch.mjs.map +1 -0
- package/dist/utils/get-dirs.js +26 -27
- package/dist/utils/get-dirs.js.map +1 -1
- package/dist/utils/get-dirs.mjs +30 -0
- package/dist/utils/get-dirs.mjs.map +1 -0
- package/dist/utils/is-initialized.js +11 -17
- package/dist/utils/is-initialized.js.map +1 -1
- package/dist/utils/is-initialized.mjs +16 -0
- package/dist/utils/is-initialized.mjs.map +1 -0
- package/dist/utils/lifecycles.js +7 -7
- package/dist/utils/lifecycles.js.map +1 -1
- package/dist/utils/lifecycles.mjs +9 -0
- package/dist/utils/lifecycles.mjs.map +1 -0
- package/dist/utils/machine-id.js +12 -13
- package/dist/utils/machine-id.js.map +1 -1
- package/dist/utils/machine-id.mjs +15 -0
- package/dist/utils/machine-id.mjs.map +1 -0
- package/dist/utils/open-browser.js +8 -10
- package/dist/utils/open-browser.js.map +1 -1
- package/dist/utils/open-browser.mjs +10 -0
- package/dist/utils/open-browser.mjs.map +1 -0
- package/dist/utils/signals.js +13 -16
- package/dist/utils/signals.js.map +1 -1
- package/dist/utils/signals.mjs +17 -0
- package/dist/utils/signals.mjs.map +1 -0
- package/dist/utils/startup-logger.js +73 -66
- package/dist/utils/startup-logger.js.map +1 -1
- package/dist/utils/startup-logger.mjs +72 -0
- package/dist/utils/startup-logger.mjs.map +1 -0
- package/dist/utils/update-notifier/index.js +69 -72
- package/dist/utils/update-notifier/index.js.map +1 -1
- package/dist/utils/update-notifier/index.mjs +76 -0
- package/dist/utils/update-notifier/index.mjs.map +1 -0
- package/package.json +26 -25
- package/dist/commands/builders/index.js +0 -11
- package/dist/commands/builders/index.js.map +0 -1
- package/dist/commands/types.js +0 -3
- package/dist/commands/types.js.map +0 -1
- package/dist/load/index.js +0 -11
- package/dist/load/index.js.map +0 -1
- package/dist/services/content-api/permissions/providers/index.js +0 -11
- package/dist/services/content-api/permissions/providers/index.js.map +0 -1
- package/dist/utils/index.js +0 -13
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/postinstall.js +0 -32
- package/dist/utils/postinstall.js.map +0 -1
- package/index.js +0 -5
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { join, extname, basename } from "path";
|
|
2
|
+
import fse, { existsSync } from "fs-extra";
|
|
3
|
+
import _ from "lodash";
|
|
4
|
+
import { isKebabCase, importDefault } from "@strapi/utils";
|
|
5
|
+
import { isEmpty } from "lodash/fp";
|
|
6
|
+
const DEFAULT_CONTENT_TYPE = {
|
|
7
|
+
schema: {},
|
|
8
|
+
actions: {},
|
|
9
|
+
lifecycles: {}
|
|
10
|
+
};
|
|
11
|
+
const normalizeName = (name) => isKebabCase(name) ? name : _.kebabCase(name);
|
|
12
|
+
const isDirectory = (fd) => fd.isDirectory();
|
|
13
|
+
const isDotFile = (fd) => fd.name.startsWith(".");
|
|
14
|
+
async function loadAPIs(strapi) {
|
|
15
|
+
if (!existsSync(strapi.dirs.dist.api)) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
const apisFDs = await (await fse.readdir(strapi.dirs.dist.api, { withFileTypes: true })).filter(isDirectory).filter(_.negate(isDotFile));
|
|
19
|
+
const apis = {};
|
|
20
|
+
for (const apiFD of apisFDs) {
|
|
21
|
+
const apiName = normalizeName(apiFD.name);
|
|
22
|
+
const api = await loadAPI(join(strapi.dirs.dist.api, apiFD.name));
|
|
23
|
+
apis[apiName] = api;
|
|
24
|
+
}
|
|
25
|
+
validateContentTypesUnicity(apis);
|
|
26
|
+
for (const apiName of Object.keys(apis)) {
|
|
27
|
+
strapi.container.get("apis").add(apiName, apis[apiName]);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
const validateContentTypesUnicity = (apis) => {
|
|
31
|
+
const allApisSchemas = Object.values(apis).flatMap((api) => Object.values(api.contentTypes));
|
|
32
|
+
const names = [];
|
|
33
|
+
allApisSchemas.forEach(({ schema }) => {
|
|
34
|
+
if (schema.info.singularName) {
|
|
35
|
+
const singularName = _.kebabCase(schema.info.singularName);
|
|
36
|
+
if (names.includes(singularName)) {
|
|
37
|
+
throw new Error(`The singular name "${schema.info.singularName}" should be unique`);
|
|
38
|
+
}
|
|
39
|
+
names.push(singularName);
|
|
40
|
+
}
|
|
41
|
+
if (schema.info.pluralName) {
|
|
42
|
+
const pluralName = _.kebabCase(schema.info.pluralName);
|
|
43
|
+
if (names.includes(pluralName)) {
|
|
44
|
+
throw new Error(`The plural name "${schema.info.pluralName}" should be unique`);
|
|
45
|
+
}
|
|
46
|
+
names.push(pluralName);
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
const loadAPI = async (dir) => {
|
|
51
|
+
const [index, config, routes, controllers, services, policies, middlewares, contentTypes] = await Promise.all([
|
|
52
|
+
loadIndex(dir),
|
|
53
|
+
loadDir(join(dir, "config")),
|
|
54
|
+
loadDir(join(dir, "routes")),
|
|
55
|
+
loadDir(join(dir, "controllers")),
|
|
56
|
+
loadDir(join(dir, "services")),
|
|
57
|
+
loadDir(join(dir, "policies")),
|
|
58
|
+
loadDir(join(dir, "middlewares")),
|
|
59
|
+
loadContentTypes(join(dir, "content-types"))
|
|
60
|
+
]);
|
|
61
|
+
return {
|
|
62
|
+
...index || {},
|
|
63
|
+
config: config || {},
|
|
64
|
+
routes: routes || [],
|
|
65
|
+
controllers: controllers || {},
|
|
66
|
+
services: services || {},
|
|
67
|
+
policies: policies || {},
|
|
68
|
+
middlewares: middlewares || {},
|
|
69
|
+
contentTypes: contentTypes || {}
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
const loadIndex = async (dir) => {
|
|
73
|
+
if (await fse.pathExists(join(dir, "index.js"))) {
|
|
74
|
+
return loadFile(join(dir, "index.js"));
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
const loadContentTypes = async (dir) => {
|
|
78
|
+
if (!await fse.pathExists(dir)) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
const fds = await fse.readdir(dir, { withFileTypes: true });
|
|
82
|
+
const contentTypes = {};
|
|
83
|
+
for (const fd of fds) {
|
|
84
|
+
if (fd.isFile()) {
|
|
85
|
+
continue;
|
|
86
|
+
}
|
|
87
|
+
const contentTypeName = normalizeName(fd.name);
|
|
88
|
+
const contentType = await loadDir(join(dir, fd.name));
|
|
89
|
+
if (isEmpty(contentType) || isEmpty(contentType.schema)) {
|
|
90
|
+
throw new Error(`Could not load content type found at ${dir}`);
|
|
91
|
+
}
|
|
92
|
+
contentTypes[normalizeName(contentTypeName)] = _.defaults(
|
|
93
|
+
contentType,
|
|
94
|
+
DEFAULT_CONTENT_TYPE
|
|
95
|
+
);
|
|
96
|
+
}
|
|
97
|
+
return contentTypes;
|
|
98
|
+
};
|
|
99
|
+
const loadDir = async (dir) => {
|
|
100
|
+
if (!await fse.pathExists(dir)) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
const fds = await fse.readdir(dir, { withFileTypes: true });
|
|
104
|
+
const root = {};
|
|
105
|
+
for (const fd of fds) {
|
|
106
|
+
if (!fd.isFile() || extname(fd.name) === ".map") {
|
|
107
|
+
continue;
|
|
108
|
+
}
|
|
109
|
+
const key = basename(fd.name, extname(fd.name));
|
|
110
|
+
root[normalizeName(key)] = await loadFile(join(dir, fd.name));
|
|
111
|
+
}
|
|
112
|
+
return root;
|
|
113
|
+
};
|
|
114
|
+
const loadFile = (file) => {
|
|
115
|
+
const ext = extname(file);
|
|
116
|
+
switch (ext) {
|
|
117
|
+
case ".js":
|
|
118
|
+
return importDefault(file);
|
|
119
|
+
case ".json":
|
|
120
|
+
return fse.readJSON(file);
|
|
121
|
+
default:
|
|
122
|
+
return {};
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
export {
|
|
126
|
+
loadAPIs as default
|
|
127
|
+
};
|
|
128
|
+
//# sourceMappingURL=apis.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apis.mjs","sources":["../../../src/core/loaders/apis.ts"],"sourcesContent":["import { join, extname, basename } from 'path';\nimport fse, { existsSync } from 'fs-extra';\nimport _ from 'lodash';\nimport { isKebabCase, importDefault } from '@strapi/utils';\nimport { isEmpty } from 'lodash/fp';\nimport type { Strapi, Common, Schema } from '@strapi/types';\n\ninterface API {\n bootstrap: () => void | Promise<void>;\n destroy: () => void | Promise<void>;\n register: () => void | Promise<void>;\n config: Record<string, unknown>;\n routes: Record<string, Common.Router>;\n controllers: Record<string, Common.Controller>;\n services: Record<string, Common.Service>;\n policies: Record<string, Common.Policy>;\n middlewares: Record<string, Common.Middleware>;\n contentTypes: Record<string, { schema: Schema.ContentType }>;\n}\n\ninterface APIs {\n [key: string]: API;\n}\n\nconst DEFAULT_CONTENT_TYPE = {\n schema: {},\n actions: {},\n lifecycles: {},\n};\n\n// to handle names with numbers in it we first check if it is already in kebabCase\nconst normalizeName = (name: string) => (isKebabCase(name) ? name : _.kebabCase(name));\n\nconst isDirectory = (fd: fse.Dirent) => fd.isDirectory();\nconst isDotFile = (fd: fse.Dirent) => fd.name.startsWith('.');\n\nexport default async function loadAPIs(strapi: Strapi) {\n if (!existsSync(strapi.dirs.dist.api)) {\n return;\n }\n\n const apisFDs = await (await fse.readdir(strapi.dirs.dist.api, { withFileTypes: true }))\n .filter(isDirectory)\n .filter(_.negate(isDotFile));\n\n const apis: APIs = {};\n\n // only load folders\n for (const apiFD of apisFDs) {\n const apiName = normalizeName(apiFD.name);\n const api = await loadAPI(join(strapi.dirs.dist.api, apiFD.name));\n\n apis[apiName] = api;\n }\n\n validateContentTypesUnicity(apis);\n\n for (const apiName of Object.keys(apis)) {\n strapi.container.get('apis').add(apiName, apis[apiName]);\n }\n}\n\nconst validateContentTypesUnicity = (apis: APIs) => {\n const allApisSchemas = Object.values(apis).flatMap((api) => Object.values(api.contentTypes));\n\n const names: string[] = [];\n allApisSchemas.forEach(({ schema }) => {\n if (schema.info.singularName) {\n const singularName = _.kebabCase(schema.info.singularName);\n if (names.includes(singularName)) {\n throw new Error(`The singular name \"${schema.info.singularName}\" should be unique`);\n }\n names.push(singularName);\n }\n\n if (schema.info.pluralName) {\n const pluralName = _.kebabCase(schema.info.pluralName);\n if (names.includes(pluralName)) {\n throw new Error(`The plural name \"${schema.info.pluralName}\" should be unique`);\n }\n names.push(pluralName);\n }\n });\n};\n\nconst loadAPI = async (dir: string) => {\n const [index, config, routes, controllers, services, policies, middlewares, contentTypes] =\n await Promise.all([\n loadIndex(dir),\n loadDir(join(dir, 'config')),\n loadDir(join(dir, 'routes')),\n loadDir(join(dir, 'controllers')),\n loadDir(join(dir, 'services')),\n loadDir(join(dir, 'policies')),\n loadDir(join(dir, 'middlewares')),\n loadContentTypes(join(dir, 'content-types')),\n ]);\n\n return {\n ...(index || {}),\n config: config || {},\n routes: routes || [],\n controllers: controllers || {},\n services: services || {},\n policies: policies || {},\n middlewares: middlewares || {},\n contentTypes: contentTypes || {},\n };\n};\n\nconst loadIndex = async (dir: string) => {\n if (await fse.pathExists(join(dir, 'index.js'))) {\n return loadFile(join(dir, 'index.js'));\n }\n};\n\nconst loadContentTypes = async (dir: string) => {\n if (!(await fse.pathExists(dir))) {\n return;\n }\n\n const fds = await fse.readdir(dir, { withFileTypes: true });\n const contentTypes: API['contentTypes'] = {};\n\n // only load folders\n for (const fd of fds) {\n if (fd.isFile()) {\n continue;\n }\n\n const contentTypeName = normalizeName(fd.name);\n const contentType = await loadDir(join(dir, fd.name));\n\n if (isEmpty(contentType) || isEmpty(contentType.schema)) {\n throw new Error(`Could not load content type found at ${dir}`);\n }\n\n contentTypes[normalizeName(contentTypeName)] = _.defaults(\n contentType as { schema: Schema.ContentType },\n DEFAULT_CONTENT_TYPE\n );\n }\n\n return contentTypes;\n};\n\nconst loadDir = async (dir: string) => {\n if (!(await fse.pathExists(dir))) {\n return;\n }\n\n const fds = await fse.readdir(dir, { withFileTypes: true });\n\n const root: Record<string, unknown> = {};\n for (const fd of fds) {\n if (!fd.isFile() || extname(fd.name) === '.map') {\n continue;\n }\n\n const key = basename(fd.name, extname(fd.name));\n\n root[normalizeName(key)] = await loadFile(join(dir, fd.name));\n }\n\n return root;\n};\n\nconst loadFile = (file: string) => {\n const ext = extname(file);\n\n switch (ext) {\n case '.js':\n return importDefault(file);\n case '.json':\n return fse.readJSON(file);\n default:\n return {};\n }\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -1,37 +1,37 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const fs_extra_1 = require("fs-extra");
|
|
9
|
-
const load_files_1 = __importDefault(require("../../load/load-files"));
|
|
2
|
+
const path = require("path");
|
|
3
|
+
const _ = require("lodash");
|
|
4
|
+
const fse = require("fs-extra");
|
|
5
|
+
const loadFiles = require("../../load/load-files.js");
|
|
6
|
+
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
7
|
+
const ___default = /* @__PURE__ */ _interopDefault(_);
|
|
10
8
|
async function loadComponents(strapi) {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
})
|
|
33
|
-
|
|
34
|
-
}
|
|
9
|
+
if (!await fse.pathExists(strapi.dirs.dist.components)) {
|
|
10
|
+
return {};
|
|
11
|
+
}
|
|
12
|
+
const map = await loadFiles(strapi.dirs.dist.components, "*/*.*(js|json)");
|
|
13
|
+
return Object.keys(map).reduce((acc, category) => {
|
|
14
|
+
Object.keys(map[category]).forEach((key) => {
|
|
15
|
+
const schema = map[category][key];
|
|
16
|
+
if (!schema.collectionName) {
|
|
17
|
+
const filePath = path.join(strapi.dirs.app.components, category, schema.__filename__);
|
|
18
|
+
return strapi.stopWithError(
|
|
19
|
+
`Component ${key} is missing a "collectionName" property.
|
|
20
|
+
Verify file ${filePath}.`
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
const uid = `${category}.${key}`;
|
|
24
|
+
acc[uid] = Object.assign(schema, {
|
|
25
|
+
__schema__: ___default.default.cloneDeep(schema),
|
|
26
|
+
uid,
|
|
27
|
+
category,
|
|
28
|
+
modelType: "component",
|
|
29
|
+
modelName: key,
|
|
30
|
+
globalId: schema.globalId || ___default.default.upperFirst(___default.default.camelCase(`component_${uid}`))
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
return acc;
|
|
34
|
+
}, {});
|
|
35
35
|
}
|
|
36
|
-
exports
|
|
37
|
-
//# sourceMappingURL=components.js.map
|
|
36
|
+
module.exports = loadComponents;
|
|
37
|
+
//# sourceMappingURL=components.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"components.js","
|
|
1
|
+
{"version":3,"file":"components.js","sources":["../../../src/core/loaders/components.ts"],"sourcesContent":["import { join } from 'path';\nimport _ from 'lodash';\nimport { pathExists } from 'fs-extra';\nimport type { Strapi, Common, Schema } from '@strapi/types';\nimport loadFiles from '../../load/load-files';\n\ntype LoadedComponent = {\n collectionName: string;\n __filename__: string;\n __schema__: LoadedComponent;\n uid: string;\n category: string;\n modelName: string;\n globalId: string;\n info: any;\n attributes: any;\n};\n\ntype LoadedComponents = {\n [category: string]: {\n [key: string]: LoadedComponent;\n };\n};\n\ntype ComponentMap = {\n [uid in Common.UID.Component]: Schema.Component;\n};\n\nexport default async function loadComponents(strapi: Strapi) {\n if (!(await pathExists(strapi.dirs.dist.components))) {\n return {};\n }\n\n const map = await loadFiles<LoadedComponents>(strapi.dirs.dist.components, '*/*.*(js|json)');\n\n return Object.keys(map).reduce((acc, category) => {\n Object.keys(map[category]).forEach((key) => {\n const schema = map[category][key];\n\n if (!schema.collectionName) {\n // NOTE: We're using the filepath from the app directory instead of the dist for information purpose\n const filePath = join(strapi.dirs.app.components, category, schema.__filename__);\n\n return strapi.stopWithError(\n `Component ${key} is missing a \"collectionName\" property.\\nVerify file ${filePath}.`\n );\n }\n\n const uid: Common.UID.Component = `${category}.${key}`;\n\n acc[uid] = Object.assign(schema, {\n __schema__: _.cloneDeep(schema),\n uid,\n category,\n modelType: 'component' as const,\n modelName: key,\n globalId: schema.globalId || _.upperFirst(_.camelCase(`component_${uid}`)),\n });\n });\n\n return acc;\n }, {} as ComponentMap);\n}\n"],"names":["pathExists","join","_"],"mappings":";;;;;;;AA4BA,eAA8B,eAAe,QAAgB;AAC3D,MAAI,CAAE,MAAMA,IAAAA,WAAW,OAAO,KAAK,KAAK,UAAU,GAAI;AACpD,WAAO;EACT;AAEA,QAAM,MAAM,MAAM,UAA4B,OAAO,KAAK,KAAK,YAAY,gBAAgB;AAE3F,SAAO,OAAO,KAAK,GAAG,EAAE,OAAO,CAAC,KAAK,aAAa;AAChD,WAAO,KAAK,IAAI,QAAQ,CAAC,EAAE,QAAQ,CAAC,QAAQ;AAC1C,YAAM,SAAS,IAAI,QAAQ,EAAE,GAAG;AAE5B,UAAA,CAAC,OAAO,gBAAgB;AAEpB,cAAA,WAAWC,UAAK,OAAO,KAAK,IAAI,YAAY,UAAU,OAAO,YAAY;AAE/E,eAAO,OAAO;AAAA,UACZ,aAAa,GAAG;AAAA,cAAyD,QAAQ;AAAA,QAAA;AAAA,MAErF;AAEA,YAAM,MAA4B,GAAG,QAAQ,IAAI,GAAG;AAEpD,UAAI,GAAG,IAAI,OAAO,OAAO,QAAQ;AAAA,QAC/B,YAAYC,WAAAA,QAAE,UAAU,MAAM;AAAA,QAC9B;AAAA,QACA;AAAA,QACA,WAAW;AAAA,QACX,WAAW;AAAA,QACX,UAAU,OAAO,YAAYA,WAAAA,QAAE,WAAWA,mBAAE,UAAU,aAAa,GAAG,EAAE,CAAC;AAAA,MAAA,CAC1E;AAAA,IAAA,CACF;AAEM,WAAA;AAAA,EACT,GAAG,CAAkB,CAAA;AACvB;;"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { join } from "path";
|
|
2
|
+
import _ from "lodash";
|
|
3
|
+
import { pathExists } from "fs-extra";
|
|
4
|
+
import loadFiles from "../../load/load-files.mjs";
|
|
5
|
+
async function loadComponents(strapi) {
|
|
6
|
+
if (!await pathExists(strapi.dirs.dist.components)) {
|
|
7
|
+
return {};
|
|
8
|
+
}
|
|
9
|
+
const map = await loadFiles(strapi.dirs.dist.components, "*/*.*(js|json)");
|
|
10
|
+
return Object.keys(map).reduce((acc, category) => {
|
|
11
|
+
Object.keys(map[category]).forEach((key) => {
|
|
12
|
+
const schema = map[category][key];
|
|
13
|
+
if (!schema.collectionName) {
|
|
14
|
+
const filePath = join(strapi.dirs.app.components, category, schema.__filename__);
|
|
15
|
+
return strapi.stopWithError(
|
|
16
|
+
`Component ${key} is missing a "collectionName" property.
|
|
17
|
+
Verify file ${filePath}.`
|
|
18
|
+
);
|
|
19
|
+
}
|
|
20
|
+
const uid = `${category}.${key}`;
|
|
21
|
+
acc[uid] = Object.assign(schema, {
|
|
22
|
+
__schema__: _.cloneDeep(schema),
|
|
23
|
+
uid,
|
|
24
|
+
category,
|
|
25
|
+
modelType: "component",
|
|
26
|
+
modelName: key,
|
|
27
|
+
globalId: schema.globalId || _.upperFirst(_.camelCase(`component_${uid}`))
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
return acc;
|
|
31
|
+
}, {});
|
|
32
|
+
}
|
|
33
|
+
export {
|
|
34
|
+
loadComponents as default
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=components.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"components.mjs","sources":["../../../src/core/loaders/components.ts"],"sourcesContent":["import { join } from 'path';\nimport _ from 'lodash';\nimport { pathExists } from 'fs-extra';\nimport type { Strapi, Common, Schema } from '@strapi/types';\nimport loadFiles from '../../load/load-files';\n\ntype LoadedComponent = {\n collectionName: string;\n __filename__: string;\n __schema__: LoadedComponent;\n uid: string;\n category: string;\n modelName: string;\n globalId: string;\n info: any;\n attributes: any;\n};\n\ntype LoadedComponents = {\n [category: string]: {\n [key: string]: LoadedComponent;\n };\n};\n\ntype ComponentMap = {\n [uid in Common.UID.Component]: Schema.Component;\n};\n\nexport default async function loadComponents(strapi: Strapi) {\n if (!(await pathExists(strapi.dirs.dist.components))) {\n return {};\n }\n\n const map = await loadFiles<LoadedComponents>(strapi.dirs.dist.components, '*/*.*(js|json)');\n\n return Object.keys(map).reduce((acc, category) => {\n Object.keys(map[category]).forEach((key) => {\n const schema = map[category][key];\n\n if (!schema.collectionName) {\n // NOTE: We're using the filepath from the app directory instead of the dist for information purpose\n const filePath = join(strapi.dirs.app.components, category, schema.__filename__);\n\n return strapi.stopWithError(\n `Component ${key} is missing a \"collectionName\" property.\\nVerify file ${filePath}.`\n );\n }\n\n const uid: Common.UID.Component = `${category}.${key}`;\n\n acc[uid] = Object.assign(schema, {\n __schema__: _.cloneDeep(schema),\n uid,\n category,\n modelType: 'component' as const,\n modelName: key,\n globalId: schema.globalId || _.upperFirst(_.camelCase(`component_${uid}`)),\n });\n });\n\n return acc;\n }, {} as ComponentMap);\n}\n"],"names":[],"mappings":";;;;AA4BA,eAA8B,eAAe,QAAgB;AAC3D,MAAI,CAAE,MAAM,WAAW,OAAO,KAAK,KAAK,UAAU,GAAI;AACpD,WAAO;EACT;AAEA,QAAM,MAAM,MAAM,UAA4B,OAAO,KAAK,KAAK,YAAY,gBAAgB;AAE3F,SAAO,OAAO,KAAK,GAAG,EAAE,OAAO,CAAC,KAAK,aAAa;AAChD,WAAO,KAAK,IAAI,QAAQ,CAAC,EAAE,QAAQ,CAAC,QAAQ;AAC1C,YAAM,SAAS,IAAI,QAAQ,EAAE,GAAG;AAE5B,UAAA,CAAC,OAAO,gBAAgB;AAEpB,cAAA,WAAW,KAAK,OAAO,KAAK,IAAI,YAAY,UAAU,OAAO,YAAY;AAE/E,eAAO,OAAO;AAAA,UACZ,aAAa,GAAG;AAAA,cAAyD,QAAQ;AAAA,QAAA;AAAA,MAErF;AAEA,YAAM,MAA4B,GAAG,QAAQ,IAAI,GAAG;AAEpD,UAAI,GAAG,IAAI,OAAO,OAAO,QAAQ;AAAA,QAC/B,YAAY,EAAE,UAAU,MAAM;AAAA,QAC9B;AAAA,QACA;AAAA,QACA,WAAW;AAAA,QACX,WAAW;AAAA,QACX,UAAU,OAAO,YAAY,EAAE,WAAW,EAAE,UAAU,aAAa,GAAG,EAAE,CAAC;AAAA,MAAA,CAC1E;AAAA,IAAA,CACF;AAEM,WAAA;AAAA,EACT,GAAG,CAAkB,CAAA;AACvB;"}
|
|
@@ -1,26 +1,23 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
2
|
+
const srcIndex = require("./src-index.js");
|
|
3
|
+
const apis = require("./apis.js");
|
|
4
|
+
const middlewares = require("./middlewares.js");
|
|
5
|
+
const components = require("./components.js");
|
|
6
|
+
const policies = require("./policies.js");
|
|
7
|
+
const index = require("./plugins/index.js");
|
|
8
|
+
const admin = require("./admin.js");
|
|
9
|
+
const sanitizers = require("./sanitizers.js");
|
|
10
|
+
const validators = require("./validators.js");
|
|
11
|
+
const loaders = {
|
|
12
|
+
loadSrcIndex: srcIndex,
|
|
13
|
+
loadAPIs: apis,
|
|
14
|
+
loadMiddlewares: middlewares,
|
|
15
|
+
loadComponents: components,
|
|
16
|
+
loadPolicies: policies,
|
|
17
|
+
loadPlugins: index,
|
|
18
|
+
loadAdmin: admin,
|
|
19
|
+
loadSanitizers: sanitizers,
|
|
20
|
+
loadValidators: validators
|
|
4
21
|
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const apis_1 = __importDefault(require("./apis"));
|
|
8
|
-
const middlewares_1 = __importDefault(require("./middlewares"));
|
|
9
|
-
const components_1 = __importDefault(require("./components"));
|
|
10
|
-
const policies_1 = __importDefault(require("./policies"));
|
|
11
|
-
const plugins_1 = __importDefault(require("./plugins"));
|
|
12
|
-
const admin_1 = __importDefault(require("./admin"));
|
|
13
|
-
const sanitizers_1 = __importDefault(require("./sanitizers"));
|
|
14
|
-
const validators_1 = __importDefault(require("./validators"));
|
|
15
|
-
exports.default = {
|
|
16
|
-
loadSrcIndex: src_index_1.default,
|
|
17
|
-
loadAPIs: apis_1.default,
|
|
18
|
-
loadMiddlewares: middlewares_1.default,
|
|
19
|
-
loadComponents: components_1.default,
|
|
20
|
-
loadPolicies: policies_1.default,
|
|
21
|
-
loadPlugins: plugins_1.default,
|
|
22
|
-
loadAdmin: admin_1.default,
|
|
23
|
-
loadSanitizers: sanitizers_1.default,
|
|
24
|
-
loadValidators: validators_1.default,
|
|
25
|
-
};
|
|
26
|
-
//# sourceMappingURL=index.js.map
|
|
22
|
+
module.exports = loaders;
|
|
23
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/core/loaders/index.ts"],"sourcesContent":["import loadSrcIndex from './src-index';\nimport loadAPIs from './apis';\nimport loadMiddlewares from './middlewares';\nimport loadComponents from './components';\nimport loadPolicies from './policies';\nimport loadPlugins from './plugins';\nimport loadAdmin from './admin';\nimport loadSanitizers from './sanitizers';\nimport loadValidators from './validators';\n\nexport default {\n loadSrcIndex,\n loadAPIs,\n loadMiddlewares,\n loadComponents,\n loadPolicies,\n loadPlugins,\n loadAdmin,\n loadSanitizers,\n loadValidators,\n};\n"],"names":["loadSrcIndex","loadAPIs","loadMiddlewares","loadComponents","loadPolicies","loadPlugins","loadAdmin","loadSanitizers","loadValidators"],"mappings":";;;;;;;;;;AAUA,MAAe,UAAA;AAAA,EAAA,cACbA;AAAAA,EAAA,UACAC;AAAAA,EAAA,iBACAC;AAAAA,EAAA,gBACAC;AAAAA,EAAA,cACAC;AAAAA,EAAA,aACAC;AAAAA,EAAA,WACAC;AAAAA,EAAA,gBACAC;AAAAA,EAAA,gBACAC;AACF;;"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import loadSrcIndex from "./src-index.mjs";
|
|
2
|
+
import loadAPIs from "./apis.mjs";
|
|
3
|
+
import loadMiddlewares from "./middlewares.mjs";
|
|
4
|
+
import loadComponents from "./components.mjs";
|
|
5
|
+
import loadPolicies from "./policies.mjs";
|
|
6
|
+
import loadPlugins from "./plugins/index.mjs";
|
|
7
|
+
import loadAdmin from "./admin.mjs";
|
|
8
|
+
import loadSanitizers from "./sanitizers.mjs";
|
|
9
|
+
import loadValidators from "./validators.mjs";
|
|
10
|
+
const loaders = {
|
|
11
|
+
loadSrcIndex,
|
|
12
|
+
loadAPIs,
|
|
13
|
+
loadMiddlewares,
|
|
14
|
+
loadComponents,
|
|
15
|
+
loadPolicies,
|
|
16
|
+
loadPlugins,
|
|
17
|
+
loadAdmin,
|
|
18
|
+
loadSanitizers,
|
|
19
|
+
loadValidators
|
|
20
|
+
};
|
|
21
|
+
export {
|
|
22
|
+
loaders as default
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../src/core/loaders/index.ts"],"sourcesContent":["import loadSrcIndex from './src-index';\nimport loadAPIs from './apis';\nimport loadMiddlewares from './middlewares';\nimport loadComponents from './components';\nimport loadPolicies from './policies';\nimport loadPlugins from './plugins';\nimport loadAdmin from './admin';\nimport loadSanitizers from './sanitizers';\nimport loadValidators from './validators';\n\nexport default {\n loadSrcIndex,\n loadAPIs,\n loadMiddlewares,\n loadComponents,\n loadPolicies,\n loadPlugins,\n loadAdmin,\n loadSanitizers,\n loadValidators,\n};\n"],"names":[],"mappings":";;;;;;;;;AAUA,MAAe,UAAA;AAAA,EACb;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;"}
|
|
@@ -1,34 +1,31 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const utils_1 = require("@strapi/utils");
|
|
9
|
-
const middlewares_1 = require("../../middlewares");
|
|
10
|
-
// TODO:: allow folders with index.js inside for bigger policies
|
|
2
|
+
const path = require("path");
|
|
3
|
+
const fse = require("fs-extra");
|
|
4
|
+
const strapiUtils = require("@strapi/utils");
|
|
5
|
+
const index = require("../../middlewares/index.js");
|
|
6
|
+
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
7
|
+
const fse__default = /* @__PURE__ */ _interopDefault(fse);
|
|
11
8
|
async function loadMiddlewares(strapi) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
9
|
+
const localMiddlewares = await loadLocalMiddlewares(strapi);
|
|
10
|
+
strapi.container.get("middlewares").add(`global::`, localMiddlewares);
|
|
11
|
+
strapi.container.get("middlewares").add(`strapi::`, index.middlewares);
|
|
15
12
|
}
|
|
16
|
-
exports.default = loadMiddlewares;
|
|
17
13
|
const loadLocalMiddlewares = async (strapi) => {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
}
|
|
14
|
+
const dir = strapi.dirs.dist.middlewares;
|
|
15
|
+
if (!await fse__default.default.pathExists(dir)) {
|
|
16
|
+
return {};
|
|
17
|
+
}
|
|
18
|
+
const middlewares = {};
|
|
19
|
+
const paths = await fse__default.default.readdir(dir, { withFileTypes: true });
|
|
20
|
+
for (const fd of paths) {
|
|
21
|
+
const { name } = fd;
|
|
22
|
+
const fullPath = path.join(dir, name);
|
|
23
|
+
if (fd.isFile() && path.extname(name) === ".js") {
|
|
24
|
+
const key = path.basename(name, ".js");
|
|
25
|
+
middlewares[key] = strapiUtils.importDefault(fullPath);
|
|
31
26
|
}
|
|
32
|
-
|
|
27
|
+
}
|
|
28
|
+
return middlewares;
|
|
33
29
|
};
|
|
34
|
-
|
|
30
|
+
module.exports = loadMiddlewares;
|
|
31
|
+
//# sourceMappingURL=middlewares.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"middlewares.js","
|
|
1
|
+
{"version":3,"file":"middlewares.js","sources":["../../../src/core/loaders/middlewares.ts"],"sourcesContent":["import { join, extname, basename } from 'path';\nimport fse from 'fs-extra';\nimport { importDefault } from '@strapi/utils';\nimport type { Strapi, Common } from '@strapi/types';\nimport { middlewares as internalMiddlewares } from '../../middlewares';\n\n// TODO:: allow folders with index.js inside for bigger policies\nexport default async function loadMiddlewares(strapi: Strapi) {\n const localMiddlewares = await loadLocalMiddlewares(strapi);\n\n strapi.container.get('middlewares').add(`global::`, localMiddlewares);\n strapi.container.get('middlewares').add(`strapi::`, internalMiddlewares);\n}\n\nconst loadLocalMiddlewares = async (strapi: Strapi) => {\n const dir = strapi.dirs.dist.middlewares;\n\n if (!(await fse.pathExists(dir))) {\n return {};\n }\n\n const middlewares: Record<string, Common.MiddlewareFactory> = {};\n const paths = await fse.readdir(dir, { withFileTypes: true });\n\n for (const fd of paths) {\n const { name } = fd;\n const fullPath = join(dir, name);\n\n if (fd.isFile() && extname(name) === '.js') {\n const key = basename(name, '.js');\n middlewares[key] = importDefault(fullPath);\n }\n }\n\n return middlewares;\n};\n"],"names":["internalMiddlewares","fse","join","extname","basename","importDefault"],"mappings":";;;;;;;AAOA,eAA8B,gBAAgB,QAAgB;AACtD,QAAA,mBAAmB,MAAM,qBAAqB,MAAM;AAE1D,SAAO,UAAU,IAAI,aAAa,EAAE,IAAI,YAAY,gBAAgB;AACpE,SAAO,UAAU,IAAI,aAAa,EAAE,IAAI,YAAYA,MAAAA,WAAmB;AACzE;AAEA,MAAM,uBAAuB,OAAO,WAAmB;AAC/C,QAAA,MAAM,OAAO,KAAK,KAAK;AAE7B,MAAI,CAAE,MAAMC,aAAAA,QAAI,WAAW,GAAG,GAAI;AAChC,WAAO;EACT;AAEA,QAAM,cAAwD,CAAA;AACxD,QAAA,QAAQ,MAAMA,aAAAA,QAAI,QAAQ,KAAK,EAAE,eAAe,MAAM;AAE5D,aAAW,MAAM,OAAO;AAChB,UAAA,EAAE,KAAS,IAAA;AACX,UAAA,WAAWC,KAAAA,KAAK,KAAK,IAAI;AAE/B,QAAI,GAAG,OAAO,KAAKC,KAAQ,QAAA,IAAI,MAAM,OAAO;AACpC,YAAA,MAAMC,KAAAA,SAAS,MAAM,KAAK;AACpB,kBAAA,GAAG,IAAIC,YAAA,cAAc,QAAQ;AAAA,IAC3C;AAAA,EACF;AAEO,SAAA;AACT;;"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { join, extname, basename } from "path";
|
|
2
|
+
import fse from "fs-extra";
|
|
3
|
+
import { importDefault } from "@strapi/utils";
|
|
4
|
+
import { middlewares } from "../../middlewares/index.mjs";
|
|
5
|
+
async function loadMiddlewares(strapi) {
|
|
6
|
+
const localMiddlewares = await loadLocalMiddlewares(strapi);
|
|
7
|
+
strapi.container.get("middlewares").add(`global::`, localMiddlewares);
|
|
8
|
+
strapi.container.get("middlewares").add(`strapi::`, middlewares);
|
|
9
|
+
}
|
|
10
|
+
const loadLocalMiddlewares = async (strapi) => {
|
|
11
|
+
const dir = strapi.dirs.dist.middlewares;
|
|
12
|
+
if (!await fse.pathExists(dir)) {
|
|
13
|
+
return {};
|
|
14
|
+
}
|
|
15
|
+
const middlewares2 = {};
|
|
16
|
+
const paths = await fse.readdir(dir, { withFileTypes: true });
|
|
17
|
+
for (const fd of paths) {
|
|
18
|
+
const { name } = fd;
|
|
19
|
+
const fullPath = join(dir, name);
|
|
20
|
+
if (fd.isFile() && extname(name) === ".js") {
|
|
21
|
+
const key = basename(name, ".js");
|
|
22
|
+
middlewares2[key] = importDefault(fullPath);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return middlewares2;
|
|
26
|
+
};
|
|
27
|
+
export {
|
|
28
|
+
loadMiddlewares as default
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=middlewares.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middlewares.mjs","sources":["../../../src/core/loaders/middlewares.ts"],"sourcesContent":["import { join, extname, basename } from 'path';\nimport fse from 'fs-extra';\nimport { importDefault } from '@strapi/utils';\nimport type { Strapi, Common } from '@strapi/types';\nimport { middlewares as internalMiddlewares } from '../../middlewares';\n\n// TODO:: allow folders with index.js inside for bigger policies\nexport default async function loadMiddlewares(strapi: Strapi) {\n const localMiddlewares = await loadLocalMiddlewares(strapi);\n\n strapi.container.get('middlewares').add(`global::`, localMiddlewares);\n strapi.container.get('middlewares').add(`strapi::`, internalMiddlewares);\n}\n\nconst loadLocalMiddlewares = async (strapi: Strapi) => {\n const dir = strapi.dirs.dist.middlewares;\n\n if (!(await fse.pathExists(dir))) {\n return {};\n }\n\n const middlewares: Record<string, Common.MiddlewareFactory> = {};\n const paths = await fse.readdir(dir, { withFileTypes: true });\n\n for (const fd of paths) {\n const { name } = fd;\n const fullPath = join(dir, name);\n\n if (fd.isFile() && extname(name) === '.js') {\n const key = basename(name, '.js');\n middlewares[key] = importDefault(fullPath);\n }\n }\n\n return middlewares;\n};\n"],"names":["internalMiddlewares","middlewares"],"mappings":";;;;AAOA,eAA8B,gBAAgB,QAAgB;AACtD,QAAA,mBAAmB,MAAM,qBAAqB,MAAM;AAE1D,SAAO,UAAU,IAAI,aAAa,EAAE,IAAI,YAAY,gBAAgB;AACpE,SAAO,UAAU,IAAI,aAAa,EAAE,IAAI,YAAYA,WAAmB;AACzE;AAEA,MAAM,uBAAuB,OAAO,WAAmB;AAC/C,QAAA,MAAM,OAAO,KAAK,KAAK;AAE7B,MAAI,CAAE,MAAM,IAAI,WAAW,GAAG,GAAI;AAChC,WAAO;EACT;AAEA,QAAMC,eAAwD,CAAA;AACxD,QAAA,QAAQ,MAAM,IAAI,QAAQ,KAAK,EAAE,eAAe,MAAM;AAE5D,aAAW,MAAM,OAAO;AAChB,UAAA,EAAE,KAAS,IAAA;AACX,UAAA,WAAW,KAAK,KAAK,IAAI;AAE/B,QAAI,GAAG,OAAO,KAAK,QAAQ,IAAI,MAAM,OAAO;AACpC,YAAA,MAAM,SAAS,MAAM,KAAK;AACpB,MAAAA,aAAA,GAAG,IAAI,cAAc,QAAQ;AAAA,IAC3C;AAAA,EACF;AAEO,SAAAA;AACT;"}
|