@strapi/strapi 4.14.0-alpha.0 → 4.14.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 +25 -29
- package/bin/strapi.js +1 -1
- package/dist/Strapi.d.ts +102 -0
- package/dist/Strapi.js +544 -0
- package/dist/Strapi.js.map +1 -0
- package/dist/commands/actions/admin/create-user/action.d.ts +11 -0
- package/dist/commands/actions/admin/create-user/action.js +97 -0
- package/dist/commands/actions/admin/create-user/action.js.map +1 -0
- package/dist/commands/actions/admin/create-user/command.d.ts +6 -0
- package/dist/commands/actions/admin/create-user/command.js +19 -0
- package/dist/commands/actions/admin/create-user/command.js.map +1 -0
- package/dist/commands/actions/admin/reset-user-password/action.d.ts +9 -0
- package/dist/commands/actions/admin/reset-user-password/action.js +43 -0
- package/dist/commands/actions/admin/reset-user-password/action.js.map +1 -0
- package/dist/commands/actions/admin/reset-user-password/command.d.ts +6 -0
- package/dist/commands/actions/admin/reset-user-password/command.js +17 -0
- package/dist/commands/actions/admin/reset-user-password/command.js.map +1 -0
- package/dist/commands/actions/build-command/action.d.ts +9 -0
- package/dist/commands/actions/build-command/action.js +20 -0
- package/dist/commands/actions/build-command/action.js.map +1 -0
- package/dist/commands/actions/build-command/command.d.ts +6 -0
- package/dist/commands/actions/build-command/command.js +15 -0
- package/dist/commands/actions/build-command/command.js.map +1 -0
- package/dist/commands/actions/components/list/action.d.ts +2 -0
- package/dist/commands/actions/components/list/action.js +20 -0
- package/dist/commands/actions/components/list/action.js.map +1 -0
- package/dist/commands/actions/components/list/command.d.ts +6 -0
- package/dist/commands/actions/components/list/command.js +14 -0
- package/dist/commands/actions/components/list/command.js.map +1 -0
- package/dist/commands/actions/configuration/dump/action.d.ts +10 -0
- package/dist/commands/actions/configuration/dump/action.js +46 -0
- package/dist/commands/actions/configuration/dump/action.js.map +1 -0
- package/dist/commands/actions/configuration/dump/command.d.ts +6 -0
- package/dist/commands/actions/configuration/dump/command.js +17 -0
- package/dist/commands/actions/configuration/dump/command.js.map +1 -0
- package/dist/commands/actions/configuration/restore/action.d.ts +10 -0
- package/dist/commands/actions/configuration/restore/action.js +153 -0
- package/dist/commands/actions/configuration/restore/action.js.map +1 -0
- package/dist/commands/actions/configuration/restore/command.d.ts +6 -0
- package/dist/commands/actions/configuration/restore/command.js +17 -0
- package/dist/commands/actions/configuration/restore/command.js.map +1 -0
- package/dist/commands/actions/console/action.d.ts +5 -0
- package/dist/commands/actions/console/action.js +26 -0
- package/dist/commands/actions/console/action.js.map +1 -0
- package/dist/commands/actions/console/command.d.ts +6 -0
- package/dist/commands/actions/console/command.js +14 -0
- package/dist/commands/actions/console/command.js.map +1 -0
- package/dist/commands/actions/content-types/list/action.d.ts +2 -0
- package/dist/commands/actions/content-types/list/action.js +20 -0
- package/dist/commands/actions/content-types/list/action.js.map +1 -0
- package/dist/commands/actions/content-types/list/command.d.ts +6 -0
- package/dist/commands/actions/content-types/list/command.js +14 -0
- package/dist/commands/actions/content-types/list/command.js.map +1 -0
- package/dist/commands/actions/controllers/list/action.d.ts +2 -0
- package/dist/commands/actions/controllers/list/action.js +20 -0
- package/dist/commands/actions/controllers/list/action.js.map +1 -0
- package/dist/commands/actions/controllers/list/command.d.ts +6 -0
- package/dist/commands/actions/controllers/list/command.js +14 -0
- package/dist/commands/actions/controllers/list/command.js.map +1 -0
- package/dist/commands/actions/develop/action.d.ts +86 -0
- package/dist/commands/actions/develop/action.js +190 -0
- package/dist/commands/actions/develop/action.js.map +1 -0
- package/dist/commands/actions/develop/command.d.ts +6 -0
- package/dist/commands/actions/develop/command.js +19 -0
- package/dist/commands/actions/develop/command.js.map +1 -0
- package/dist/commands/actions/generate/command.d.ts +6 -0
- package/dist/commands/actions/generate/command.js +19 -0
- package/dist/commands/actions/generate/command.js.map +1 -0
- package/dist/commands/actions/hooks/list/action.d.ts +2 -0
- package/dist/commands/actions/hooks/list/action.js +20 -0
- package/dist/commands/actions/hooks/list/action.js.map +1 -0
- package/dist/commands/actions/hooks/list/command.d.ts +6 -0
- package/dist/commands/actions/hooks/list/command.js +14 -0
- package/dist/commands/actions/hooks/list/command.js.map +1 -0
- package/dist/commands/actions/install/action.d.ts +2 -0
- package/dist/commands/actions/install/action.js +49 -0
- package/dist/commands/actions/install/action.js.map +1 -0
- package/dist/commands/actions/install/command.d.ts +6 -0
- package/dist/commands/actions/install/command.js +14 -0
- package/dist/commands/actions/install/command.js.map +1 -0
- package/dist/commands/actions/middlewares/list/action.d.ts +2 -0
- package/dist/commands/actions/middlewares/list/action.js +20 -0
- package/dist/commands/actions/middlewares/list/action.js.map +1 -0
- package/dist/commands/actions/middlewares/list/command.d.ts +6 -0
- package/dist/commands/actions/middlewares/list/command.js +14 -0
- package/dist/commands/actions/middlewares/list/command.js.map +1 -0
- package/dist/commands/actions/new/action.d.ts +7 -0
- package/dist/commands/actions/new/action.js +12 -0
- package/dist/commands/actions/new/action.js.map +1 -0
- package/dist/commands/actions/new/command.d.ts +6 -0
- package/dist/commands/actions/new/command.js +35 -0
- package/dist/commands/actions/new/command.js.map +1 -0
- package/dist/commands/actions/plugin/build-command/action.d.ts +6 -0
- package/dist/commands/actions/plugin/build-command/action.js +105 -0
- package/dist/commands/actions/plugin/build-command/action.js.map +1 -0
- package/dist/commands/actions/plugin/build-command/command.d.ts +6 -0
- package/dist/commands/actions/plugin/build-command/command.js +17 -0
- package/dist/commands/actions/plugin/build-command/command.js.map +1 -0
- package/dist/commands/actions/policies/list/action.d.ts +2 -0
- package/dist/commands/actions/policies/list/action.js +20 -0
- package/dist/commands/actions/policies/list/action.js.map +1 -0
- package/dist/commands/actions/policies/list/command.d.ts +6 -0
- package/dist/commands/actions/policies/list/command.js +14 -0
- package/dist/commands/actions/policies/list/command.js.map +1 -0
- package/dist/commands/actions/report/action.d.ts +7 -0
- package/dist/commands/actions/report/action.js +32 -0
- package/dist/commands/actions/report/action.js.map +1 -0
- package/dist/commands/actions/report/command.d.ts +6 -0
- package/dist/commands/actions/report/command.js +17 -0
- package/dist/commands/actions/report/command.js.map +1 -0
- package/dist/commands/actions/routes/list/action.d.ts +2 -0
- package/dist/commands/actions/routes/list/action.js +26 -0
- package/dist/commands/actions/routes/list/action.js.map +1 -0
- package/dist/commands/actions/routes/list/command.d.ts +6 -0
- package/dist/commands/actions/routes/list/command.js +14 -0
- package/dist/commands/actions/routes/list/command.js.map +1 -0
- package/dist/commands/actions/services/list/action.d.ts +2 -0
- package/dist/commands/actions/services/list/action.js +20 -0
- package/dist/commands/actions/services/list/action.js.map +1 -0
- package/dist/commands/actions/services/list/command.d.ts +6 -0
- package/dist/commands/actions/services/list/command.js +14 -0
- package/dist/commands/actions/services/list/command.js.map +1 -0
- package/dist/commands/actions/start/action.d.ts +78 -0
- package/dist/commands/actions/start/action.js +22 -0
- package/dist/commands/actions/start/action.js.map +1 -0
- package/dist/commands/actions/start/command.d.ts +6 -0
- package/dist/commands/actions/start/command.js +14 -0
- package/dist/commands/actions/start/command.js.map +1 -0
- package/dist/commands/actions/telemetry/disable/action.d.ts +1 -0
- package/dist/commands/actions/telemetry/disable/action.js +83 -0
- package/dist/commands/actions/telemetry/disable/action.js.map +1 -0
- package/dist/commands/actions/telemetry/disable/command.d.ts +6 -0
- package/dist/commands/actions/telemetry/disable/command.js +14 -0
- package/dist/commands/actions/telemetry/disable/command.js.map +1 -0
- package/dist/commands/actions/telemetry/enable/action.d.ts +2 -0
- package/dist/commands/actions/telemetry/enable/action.js +103 -0
- package/dist/commands/actions/telemetry/enable/action.js.map +1 -0
- package/dist/commands/actions/telemetry/enable/command.d.ts +6 -0
- package/dist/commands/actions/telemetry/enable/command.js +14 -0
- package/dist/commands/actions/telemetry/enable/command.js.map +1 -0
- package/dist/commands/actions/templates/generate/action.d.ts +1 -0
- package/dist/commands/actions/templates/generate/action.js +85 -0
- package/dist/commands/actions/templates/generate/action.js.map +1 -0
- package/dist/commands/actions/templates/generate/command.d.ts +6 -0
- package/dist/commands/actions/templates/generate/command.js +14 -0
- package/dist/commands/actions/templates/generate/command.js.map +1 -0
- package/dist/commands/actions/ts/generate-types/action.d.ts +8 -0
- package/dist/commands/actions/ts/generate-types/action.js +28 -0
- package/dist/commands/actions/ts/generate-types/action.js.map +1 -0
- package/dist/commands/actions/ts/generate-types/command.d.ts +6 -0
- package/dist/commands/actions/ts/generate-types/command.js +18 -0
- package/dist/commands/actions/ts/generate-types/command.js.map +1 -0
- package/dist/commands/actions/uninstall/action.d.ts +5 -0
- package/dist/commands/actions/uninstall/action.js +67 -0
- package/dist/commands/actions/uninstall/action.js.map +1 -0
- package/dist/commands/actions/uninstall/command.d.ts +6 -0
- package/dist/commands/actions/uninstall/command.js +15 -0
- package/dist/commands/actions/uninstall/command.js.map +1 -0
- package/dist/commands/actions/version/command.d.ts +6 -0
- package/dist/commands/actions/version/command.js +19 -0
- package/dist/commands/actions/version/command.js.map +1 -0
- package/dist/commands/actions/watch-admin/action.d.ts +4 -0
- package/dist/commands/actions/watch-admin/action.js +36 -0
- package/dist/commands/actions/watch-admin/action.js.map +1 -0
- package/dist/commands/actions/watch-admin/command.d.ts +6 -0
- package/dist/commands/actions/watch-admin/command.js +15 -0
- package/dist/commands/actions/watch-admin/command.js.map +1 -0
- package/dist/commands/builders/admin.d.ts +8 -0
- package/dist/commands/builders/admin.js +52 -0
- package/dist/commands/builders/admin.js.map +1 -0
- package/dist/commands/builders/index.d.ts +3 -0
- package/dist/commands/builders/index.js +11 -0
- package/dist/commands/builders/index.js.map +1 -0
- package/dist/commands/builders/packages.d.ts +37 -0
- package/dist/commands/builders/packages.js +166 -0
- package/dist/commands/builders/packages.js.map +1 -0
- package/dist/commands/builders/tasks/dts.d.ts +13 -0
- package/dist/commands/builders/tasks/dts.js +143 -0
- package/dist/commands/builders/tasks/dts.js.map +1 -0
- package/dist/commands/builders/tasks/index.d.ts +14 -0
- package/dist/commands/builders/tasks/index.js +14 -0
- package/dist/commands/builders/tasks/index.js.map +1 -0
- package/dist/commands/builders/tasks/vite.d.ts +15 -0
- package/dist/commands/builders/tasks/vite.js +114 -0
- package/dist/commands/builders/tasks/vite.js.map +1 -0
- package/dist/commands/builders/typescript.d.ts +6 -0
- package/dist/commands/builders/typescript.js +29 -0
- package/dist/commands/builders/typescript.js.map +1 -0
- package/dist/commands/index.d.ts +34 -0
- package/dist/commands/index.js +100 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/types.d.ts +5 -0
- package/dist/commands/types.js +3 -0
- package/dist/commands/types.js.map +1 -0
- package/dist/commands/utils/commander.d.ts +35 -0
- package/dist/commands/utils/commander.js +138 -0
- package/dist/commands/utils/commander.js.map +1 -0
- package/dist/commands/utils/helpers.d.ts +50 -0
- package/dist/commands/utils/helpers.js +165 -0
- package/dist/commands/utils/helpers.js.map +1 -0
- package/dist/commands/utils/logger.d.ts +16 -0
- package/dist/commands/utils/logger.js +53 -0
- package/dist/commands/utils/logger.js.map +1 -0
- package/dist/commands/utils/pkg.d.ts +237 -0
- package/dist/commands/utils/pkg.js +316 -0
- package/dist/commands/utils/pkg.js.map +1 -0
- package/dist/compile.d.ts +9 -0
- package/dist/compile.js +20 -0
- package/dist/compile.js.map +1 -0
- package/dist/container.d.ts +2 -0
- package/dist/container.js +39 -0
- package/dist/container.js.map +1 -0
- package/dist/core/app-configuration/config-loader.d.ts +2 -0
- package/dist/core/app-configuration/config-loader.js +22 -0
- package/dist/core/app-configuration/config-loader.js.map +1 -0
- package/dist/core/app-configuration/index.d.ts +35 -0
- package/dist/core/app-configuration/index.js +54 -0
- package/dist/core/app-configuration/index.js.map +1 -0
- package/dist/core/app-configuration/load-config-file.d.ts +1 -0
- package/dist/core/app-configuration/load-config-file.js +49 -0
- package/dist/core/app-configuration/load-config-file.js.map +1 -0
- package/dist/core/bootstrap.d.ts +4 -0
- package/dist/core/bootstrap.js +27 -0
- package/dist/core/bootstrap.js.map +1 -0
- package/dist/core/domain/content-type/index.d.ts +8 -0
- package/dist/core/domain/content-type/index.js +117 -0
- package/dist/core/domain/content-type/index.js.map +1 -0
- package/dist/core/domain/content-type/validator.d.ts +21 -0
- package/dist/core/domain/content-type/validator.js +91 -0
- package/dist/core/domain/content-type/validator.js.map +1 -0
- package/dist/core/domain/module/index.d.ts +38 -0
- package/dist/core/domain/module/index.js +110 -0
- package/dist/core/domain/module/index.js.map +1 -0
- package/dist/core/domain/module/validation.d.ts +13 -0
- package/dist/core/domain/module/validation.js +29 -0
- package/dist/core/domain/module/validation.js.map +1 -0
- package/dist/core/loaders/admin.d.ts +2 -0
- package/dist/core/loaders/admin.js +18 -0
- package/dist/core/loaders/admin.js.map +1 -0
- package/dist/core/loaders/apis.d.ts +2 -0
- package/dist/core/loaders/apis.js +156 -0
- package/dist/core/loaders/apis.js.map +1 -0
- package/dist/core/loaders/components.d.ts +6 -0
- package/dist/core/loaders/components.js +37 -0
- package/dist/core/loaders/components.js.map +1 -0
- package/dist/core/loaders/index.d.ts +18 -0
- package/dist/core/loaders/index.js +26 -0
- package/dist/core/loaders/index.js.map +1 -0
- package/dist/core/loaders/middlewares.d.ts +2 -0
- package/dist/core/loaders/middlewares.js +34 -0
- package/dist/core/loaders/middlewares.js.map +1 -0
- package/dist/core/loaders/plugins/get-enabled-plugins.d.ts +4 -0
- package/dist/core/loaders/plugins/get-enabled-plugins.js +113 -0
- package/dist/core/loaders/plugins/get-enabled-plugins.js.map +1 -0
- package/dist/core/loaders/plugins/get-user-plugins-config.d.ts +6 -0
- package/dist/core/loaders/plugins/get-user-plugins-config.js +31 -0
- package/dist/core/loaders/plugins/get-user-plugins-config.js.map +1 -0
- package/dist/core/loaders/plugins/index.d.ts +2 -0
- package/dist/core/loaders/plugins/index.js +109 -0
- package/dist/core/loaders/plugins/index.js.map +1 -0
- package/dist/core/loaders/policies.d.ts +2 -0
- package/dist/core/loaders/policies.js +28 -0
- package/dist/core/loaders/policies.js.map +1 -0
- package/dist/core/loaders/sanitizers.d.ts +3 -0
- package/dist/core/loaders/sanitizers.js +6 -0
- package/dist/core/loaders/sanitizers.js.map +1 -0
- package/dist/core/loaders/src-index.d.ts +3 -0
- package/dist/core/loaders/src-index.js +37 -0
- package/dist/core/loaders/src-index.js.map +1 -0
- package/dist/core/loaders/validators.d.ts +3 -0
- package/dist/core/loaders/validators.js +6 -0
- package/dist/core/loaders/validators.js.map +1 -0
- package/dist/core/registries/apis.d.ts +7 -0
- package/dist/core/registries/apis.js +24 -0
- package/dist/core/registries/apis.js.map +1 -0
- package/dist/core/registries/config.d.ts +3 -0
- package/dist/core/registries/config.js +23 -0
- package/dist/core/registries/config.js.map +1 -0
- package/dist/core/registries/content-types.d.ts +32 -0
- package/dist/core/registries/content-types.js +70 -0
- package/dist/core/registries/content-types.js.map +1 -0
- package/dist/core/registries/controllers.d.ts +34 -0
- package/dist/core/registries/controllers.js +81 -0
- package/dist/core/registries/controllers.js.map +1 -0
- package/dist/core/registries/custom-fields.d.ts +7 -0
- package/dist/core/registries/custom-fields.js +74 -0
- package/dist/core/registries/custom-fields.js.map +1 -0
- package/dist/core/registries/hooks.d.ts +43 -0
- package/dist/core/registries/hooks.js +59 -0
- package/dist/core/registries/hooks.js.map +1 -0
- package/dist/core/registries/middlewares.d.ts +30 -0
- package/dist/core/registries/middlewares.js +62 -0
- package/dist/core/registries/middlewares.js.map +1 -0
- package/dist/core/registries/modules.d.ts +14 -0
- package/dist/core/registries/modules.js +40 -0
- package/dist/core/registries/modules.js.map +1 -0
- package/dist/core/registries/plugins.d.ts +8 -0
- package/dist/core/registries/plugins.js +24 -0
- package/dist/core/registries/plugins.js.map +1 -0
- package/dist/core/registries/policies.d.ts +33 -0
- package/dist/core/registries/policies.js +64 -0
- package/dist/core/registries/policies.js.map +1 -0
- package/dist/core/registries/sanitizers.d.ts +9 -0
- package/dist/core/registries/sanitizers.js +27 -0
- package/dist/core/registries/sanitizers.js.map +1 -0
- package/dist/core/registries/services.d.ts +34 -0
- package/dist/core/registries/services.js +82 -0
- package/dist/core/registries/services.js.map +1 -0
- package/dist/core/registries/validators.d.ts +9 -0
- package/dist/core/registries/validators.js +27 -0
- package/dist/core/registries/validators.js.map +1 -0
- package/dist/core/utils.d.ts +4 -0
- package/dist/core/utils.js +28 -0
- package/dist/core/utils.js.map +1 -0
- package/dist/core-api/controller/collection-type.d.ts +10 -0
- package/dist/core-api/controller/collection-type.js +95 -0
- package/dist/core-api/controller/collection-type.js.map +1 -0
- package/dist/core-api/controller/index.d.ts +5 -0
- package/dist/core-api/controller/index.js +50 -0
- package/dist/core-api/controller/index.js.map +1 -0
- package/dist/core-api/controller/single-type.d.ts +9 -0
- package/dist/core-api/controller/single-type.js +52 -0
- package/dist/core-api/controller/single-type.js.map +1 -0
- package/dist/core-api/controller/transform.d.ts +21 -0
- package/dist/core-api/controller/transform.js +86 -0
- package/dist/core-api/controller/transform.js.map +1 -0
- package/dist/core-api/routes/index.d.ts +23 -0
- package/dist/core-api/routes/index.js +68 -0
- package/dist/core-api/routes/index.js.map +1 -0
- package/dist/core-api/service/collection-type.d.ts +9 -0
- package/dist/core-api/service/collection-type.js +61 -0
- package/dist/core-api/service/collection-type.js.map +1 -0
- package/dist/core-api/service/get-fetch-params.d.ts +6 -0
- package/dist/core-api/service/get-fetch-params.js +16 -0
- package/dist/core-api/service/get-fetch-params.js.map +1 -0
- package/dist/core-api/service/index.d.ts +8 -0
- package/dist/core-api/service/index.js +18 -0
- package/dist/core-api/service/index.js.map +1 -0
- package/dist/core-api/service/pagination.d.ts +40 -0
- package/dist/core-api/service/pagination.js +97 -0
- package/dist/core-api/service/pagination.js.map +1 -0
- package/dist/core-api/service/single-type.d.ts +8 -0
- package/dist/core-api/service/single-type.js +57 -0
- package/dist/core-api/service/single-type.js.map +1 -0
- package/dist/ee/index.d.ts +19 -0
- package/dist/ee/index.js +185 -0
- package/dist/ee/index.js.map +1 -0
- package/dist/ee/license.d.ts +20 -0
- package/dist/ee/license.js +94 -0
- package/dist/ee/license.js.map +1 -0
- package/dist/factories.d.ts +12 -0
- package/dist/factories.js +70 -0
- package/dist/factories.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +35 -0
- package/dist/index.js.map +1 -0
- package/dist/load/filepath-to-prop-path.d.ts +5 -0
- package/dist/load/filepath-to-prop-path.js +21 -0
- package/dist/load/filepath-to-prop-path.js.map +1 -0
- package/dist/load/glob.d.ts +6 -0
- package/dist/load/glob.js +20 -0
- package/dist/load/glob.js.map +1 -0
- package/dist/load/index.d.ts +2 -0
- package/dist/load/index.js +11 -0
- package/dist/load/index.js.map +1 -0
- package/dist/load/load-files.d.ts +9 -0
- package/dist/load/load-files.js +44 -0
- package/dist/load/load-files.js.map +1 -0
- package/dist/load/package-path.d.ts +5 -0
- package/dist/load/package-path.js +11 -0
- package/dist/load/package-path.js.map +1 -0
- package/dist/middlewares/body.d.ts +5 -0
- package/dist/middlewares/body.js +78 -0
- package/dist/middlewares/body.js.map +1 -0
- package/dist/middlewares/compression.d.ts +4 -0
- package/dist/middlewares/compression.js +10 -0
- package/dist/middlewares/compression.js.map +1 -0
- package/dist/middlewares/cors.d.ts +12 -0
- package/dist/middlewares/cors.js +54 -0
- package/dist/middlewares/cors.js.map +1 -0
- package/dist/middlewares/errors.d.ts +3 -0
- package/dist/middlewares/errors.js +35 -0
- package/dist/middlewares/errors.js.map +1 -0
- package/dist/middlewares/favicon.d.ts +4 -0
- package/dist/middlewares/favicon.js +30 -0
- package/dist/middlewares/favicon.js.map +1 -0
- package/dist/middlewares/index.d.ts +2 -0
- package/dist/middlewares/index.js +34 -0
- package/dist/middlewares/index.js.map +1 -0
- package/dist/middlewares/ip.d.ts +4 -0
- package/dist/middlewares/ip.js +10 -0
- package/dist/middlewares/ip.js.map +1 -0
- package/dist/middlewares/logger.d.ts +2 -0
- package/dist/middlewares/logger.js +13 -0
- package/dist/middlewares/logger.js.map +1 -0
- package/dist/middlewares/powered-by.d.ts +5 -0
- package/dist/middlewares/powered-by.js +15 -0
- package/dist/middlewares/powered-by.js.map +1 -0
- package/dist/middlewares/public/index.d.ts +2 -0
- package/dist/middlewares/public/index.js +112 -0
- package/dist/middlewares/public/index.js.map +1 -0
- package/dist/middlewares/public/serve-static.d.ts +3 -0
- package/dist/middlewares/public/serve-static.js +27 -0
- package/dist/middlewares/public/serve-static.js.map +1 -0
- package/dist/middlewares/query.d.ts +2 -0
- package/dist/middlewares/query.js +45 -0
- package/dist/middlewares/query.js.map +1 -0
- package/dist/middlewares/response-time.d.ts +2 -0
- package/dist/middlewares/response-time.js +13 -0
- package/dist/middlewares/response-time.js.map +1 -0
- package/dist/middlewares/responses.d.ts +5 -0
- package/dist/middlewares/responses.js +16 -0
- package/dist/middlewares/responses.js.map +1 -0
- package/dist/middlewares/security.d.ts +4 -0
- package/dist/middlewares/security.js +52 -0
- package/dist/middlewares/security.js.map +1 -0
- package/dist/middlewares/session.d.ts +3 -0
- package/dist/middlewares/session.js +30 -0
- package/dist/middlewares/session.js.map +1 -0
- package/dist/migrations/draft-publish.d.ts +8 -0
- package/dist/migrations/draft-publish.js +46 -0
- package/dist/migrations/draft-publish.js.map +1 -0
- package/dist/services/auth/index.d.ts +25 -0
- package/dist/services/auth/index.js +84 -0
- package/dist/services/auth/index.js.map +1 -0
- package/dist/services/content-api/index.d.ts +53 -0
- package/dist/services/content-api/index.js +62 -0
- package/dist/services/content-api/index.js.map +1 -0
- package/dist/services/content-api/permissions/engine.d.ts +4 -0
- package/dist/services/content-api/permissions/engine.js +8 -0
- package/dist/services/content-api/permissions/engine.js.map +1 -0
- package/dist/services/content-api/permissions/index.d.ts +51 -0
- package/dist/services/content-api/permissions/index.js +110 -0
- package/dist/services/content-api/permissions/index.js.map +1 -0
- package/dist/services/content-api/permissions/providers/action.d.ts +19 -0
- package/dist/services/content-api/permissions/providers/action.js +16 -0
- package/dist/services/content-api/permissions/providers/action.js.map +1 -0
- package/dist/services/content-api/permissions/providers/condition.d.ts +23 -0
- package/dist/services/content-api/permissions/providers/condition.js +16 -0
- package/dist/services/content-api/permissions/providers/condition.js.map +1 -0
- package/dist/services/content-api/permissions/providers/index.d.ts +2 -0
- package/dist/services/content-api/permissions/providers/index.js +11 -0
- package/dist/services/content-api/permissions/providers/index.js.map +1 -0
- package/dist/services/core-store.d.ts +52 -0
- package/dist/services/core-store.js +123 -0
- package/dist/services/core-store.js.map +1 -0
- package/dist/services/cron.d.ts +26 -0
- package/dist/services/cron.js +69 -0
- package/dist/services/cron.js.map +1 -0
- package/dist/services/custom-fields.d.ts +3 -0
- package/dist/services/custom-fields.js +11 -0
- package/dist/services/custom-fields.js.map +1 -0
- package/dist/services/entity-service/attributes/index.d.ts +5 -0
- package/dist/services/entity-service/attributes/index.js +26 -0
- package/dist/services/entity-service/attributes/index.js.map +1 -0
- package/dist/services/entity-service/attributes/transforms.d.ts +9 -0
- package/dist/services/entity-service/attributes/transforms.js +22 -0
- package/dist/services/entity-service/attributes/transforms.js.map +1 -0
- package/dist/services/entity-service/components.d.ts +22 -0
- package/dist/services/entity-service/components.js +381 -0
- package/dist/services/entity-service/components.js.map +1 -0
- package/dist/services/entity-service/index.d.ts +14 -0
- package/dist/services/entity-service/index.js +311 -0
- package/dist/services/entity-service/index.js.map +1 -0
- package/dist/services/entity-service/params.d.ts +7 -0
- package/dist/services/entity-service/params.js +9 -0
- package/dist/services/entity-service/params.js.map +1 -0
- package/dist/services/entity-validator/blocks-validator.d.ts +2 -0
- package/dist/services/entity-validator/blocks-validator.js +127 -0
- package/dist/services/entity-validator/blocks-validator.js.map +1 -0
- package/dist/services/entity-validator/index.d.ts +7 -0
- package/dist/services/entity-validator/index.js +332 -0
- package/dist/services/entity-validator/index.js.map +1 -0
- package/dist/services/entity-validator/validators.d.ts +36 -0
- package/dist/services/entity-validator/validators.js +149 -0
- package/dist/services/entity-validator/validators.js.map +1 -0
- package/dist/services/errors.d.ts +39 -0
- package/dist/services/errors.js +78 -0
- package/dist/services/errors.js.map +1 -0
- package/dist/services/event-hub.d.ts +18 -0
- package/dist/services/event-hub.js +77 -0
- package/dist/services/event-hub.js.map +1 -0
- package/dist/services/fs.d.ts +12 -0
- package/dist/services/fs.js +54 -0
- package/dist/services/fs.js.map +1 -0
- package/dist/services/metrics/admin-user-hash.d.ts +6 -0
- package/dist/services/metrics/admin-user-hash.js +19 -0
- package/dist/services/metrics/admin-user-hash.js.map +1 -0
- package/dist/services/metrics/index.d.ts +13 -0
- package/dist/services/metrics/index.js +53 -0
- package/dist/services/metrics/index.js.map +1 -0
- package/dist/services/metrics/is-truthy.d.ts +2 -0
- package/dist/services/metrics/is-truthy.js +11 -0
- package/dist/services/metrics/is-truthy.js.map +1 -0
- package/dist/services/metrics/middleware.d.ts +6 -0
- package/dist/services/metrics/middleware.js +28 -0
- package/dist/services/metrics/middleware.js.map +1 -0
- package/dist/services/metrics/rate-limiter.d.ts +6 -0
- package/dist/services/metrics/rate-limiter.js +21 -0
- package/dist/services/metrics/rate-limiter.js.map +1 -0
- package/dist/services/metrics/sender.d.ts +12 -0
- package/dist/services/metrics/sender.js +80 -0
- package/dist/services/metrics/sender.js.map +1 -0
- package/dist/services/request-context.d.ts +6 -0
- package/dist/services/request-context.js +14 -0
- package/dist/services/request-context.js.map +1 -0
- package/dist/services/server/admin-api.d.ts +10 -0
- package/dist/services/server/admin-api.js +13 -0
- package/dist/services/server/admin-api.js.map +1 -0
- package/dist/services/server/api.d.ts +14 -0
- package/dist/services/server/api.js +32 -0
- package/dist/services/server/api.js.map +1 -0
- package/dist/services/server/compose-endpoint.d.ts +6 -0
- package/dist/services/server/compose-endpoint.js +121 -0
- package/dist/services/server/compose-endpoint.js.map +1 -0
- package/dist/services/server/content-api.d.ts +10 -0
- package/dist/services/server/content-api.js +13 -0
- package/dist/services/server/content-api.js.map +1 -0
- package/dist/services/server/http-server.d.ts +9 -0
- package/dist/services/server/http-server.js +54 -0
- package/dist/services/server/http-server.js.map +1 -0
- package/dist/services/server/index.d.ts +3 -0
- package/dist/services/server/index.js +91 -0
- package/dist/services/server/index.js.map +1 -0
- package/dist/services/server/koa.d.ts +15 -0
- package/dist/services/server/koa.js +56 -0
- package/dist/services/server/koa.js.map +1 -0
- package/dist/services/server/middleware.d.ts +14 -0
- package/dist/services/server/middleware.js +103 -0
- package/dist/services/server/middleware.js.map +1 -0
- package/dist/services/server/policy.d.ts +3 -0
- package/dist/services/server/policy.js +21 -0
- package/dist/services/server/policy.js.map +1 -0
- package/dist/services/server/register-middlewares.d.ts +6 -0
- package/dist/services/server/register-middlewares.js +82 -0
- package/dist/services/server/register-middlewares.js.map +1 -0
- package/dist/services/server/register-routes.d.ts +6 -0
- package/dist/services/server/register-routes.js +94 -0
- package/dist/services/server/register-routes.js.map +1 -0
- package/dist/services/server/routing.d.ts +32 -0
- package/dist/services/server/routing.js +105 -0
- package/dist/services/server/routing.js.map +1 -0
- package/dist/services/utils/dynamic-zones.d.ts +2 -0
- package/dist/services/utils/dynamic-zones.js +13 -0
- package/dist/services/utils/dynamic-zones.js.map +1 -0
- package/dist/services/utils/upload-files.d.ts +7 -0
- package/dist/services/utils/upload-files.js +74 -0
- package/dist/services/utils/upload-files.js.map +1 -0
- package/dist/services/webhook-runner.d.ts +48 -0
- package/dist/services/webhook-runner.js +141 -0
- package/dist/services/webhook-runner.js.map +1 -0
- package/dist/services/webhook-store.d.ts +49 -0
- package/dist/services/webhook-store.js +106 -0
- package/dist/services/webhook-store.js.map +1 -0
- package/dist/services/worker-queue.d.ts +19 -0
- package/dist/services/worker-queue.js +64 -0
- package/dist/services/worker-queue.js.map +1 -0
- package/dist/utils/addSlash.d.ts +2 -0
- package/dist/utils/addSlash.js +15 -0
- package/dist/utils/addSlash.js.map +1 -0
- package/dist/utils/convert-custom-field-type.d.ts +3 -0
- package/dist/utils/convert-custom-field-type.js +20 -0
- package/dist/utils/convert-custom-field-type.js.map +1 -0
- package/dist/utils/cron.d.ts +7 -0
- package/dist/utils/cron.js +56 -0
- package/dist/utils/cron.js.map +1 -0
- package/dist/utils/ee.d.ts +2 -0
- package/dist/utils/ee.js +8 -0
- package/dist/utils/ee.js.map +1 -0
- package/dist/utils/fetch.d.ts +8 -0
- package/dist/utils/fetch.js +23 -0
- package/dist/utils/fetch.js.map +1 -0
- package/dist/utils/get-dirs.d.ts +9 -0
- package/dist/utils/get-dirs.js +30 -0
- package/dist/utils/get-dirs.js.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.js +13 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/is-initialized.d.ts +5 -0
- package/dist/utils/is-initialized.js +21 -0
- package/dist/utils/is-initialized.js.map +1 -0
- package/dist/utils/lifecycles.d.ts +5 -0
- package/dist/utils/lifecycles.js +9 -0
- package/dist/utils/lifecycles.js.map +1 -0
- package/dist/utils/machine-id.d.ts +2 -0
- package/dist/utils/machine-id.js +15 -0
- package/dist/utils/machine-id.js.map +1 -0
- package/dist/utils/open-browser.d.ts +4 -0
- package/dist/utils/open-browser.js +13 -0
- package/dist/utils/open-browser.js.map +1 -0
- package/dist/utils/postinstall.d.ts +1 -0
- package/dist/utils/postinstall.js +32 -0
- package/dist/utils/postinstall.js.map +1 -0
- package/dist/utils/signals.d.ts +2 -0
- package/dist/utils/signals.js +20 -0
- package/dist/utils/signals.js.map +1 -0
- package/dist/utils/startup-logger.d.ts +10 -0
- package/dist/utils/startup-logger.js +68 -0
- package/dist/utils/startup-logger.js.map +1 -0
- package/dist/utils/update-notifier/index.d.ts +8 -0
- package/dist/utils/update-notifier/index.js +85 -0
- package/dist/utils/update-notifier/index.js.map +1 -0
- package/index.js +5 -0
- package/package.json +59 -27
- package/scripts/postinstall.js +7 -0
- package/.eslintignore +0 -2
- package/.eslintrc.js +0 -4
- package/ee/LICENSE.txt +0 -1
- package/ee/index.js +0 -213
- package/ee/license.js +0 -109
- package/lib/Strapi.js +0 -591
- package/lib/commands/actions/admin/create-user/action.js +0 -113
- package/lib/commands/actions/admin/create-user/command.js +0 -19
- package/lib/commands/actions/admin/reset-user-password/action.js +0 -52
- package/lib/commands/actions/admin/reset-user-password/command.js +0 -17
- package/lib/commands/actions/build-command/action.js +0 -18
- package/lib/commands/actions/build-command/command.js +0 -15
- package/lib/commands/actions/components/list/action.js +0 -23
- package/lib/commands/actions/components/list/command.js +0 -14
- package/lib/commands/actions/configuration/dump/action.js +0 -51
- package/lib/commands/actions/configuration/dump/command.js +0 -17
- package/lib/commands/actions/configuration/restore/action.js +0 -172
- package/lib/commands/actions/configuration/restore/command.js +0 -17
- package/lib/commands/actions/console/action.js +0 -27
- package/lib/commands/actions/console/command.js +0 -14
- package/lib/commands/actions/content-types/list/action.js +0 -23
- package/lib/commands/actions/content-types/list/command.js +0 -14
- package/lib/commands/actions/controllers/list/action.js +0 -23
- package/lib/commands/actions/controllers/list/command.js +0 -14
- package/lib/commands/actions/develop/action.js +0 -217
- package/lib/commands/actions/develop/command.js +0 -19
- package/lib/commands/actions/export/action.js +0 -184
- package/lib/commands/actions/export/command.js +0 -45
- package/lib/commands/actions/generate/command.js +0 -18
- package/lib/commands/actions/hooks/list/action.js +0 -23
- package/lib/commands/actions/hooks/list/command.js +0 -14
- package/lib/commands/actions/import/action.js +0 -181
- package/lib/commands/actions/import/command.js +0 -97
- package/lib/commands/actions/install/action.js +0 -48
- package/lib/commands/actions/install/command.js +0 -14
- package/lib/commands/actions/middlewares/list/action.js +0 -23
- package/lib/commands/actions/middlewares/list/command.js +0 -14
- package/lib/commands/actions/new/action.js +0 -13
- package/lib/commands/actions/new/command.js +0 -35
- package/lib/commands/actions/plugin/build-command/action.js +0 -137
- package/lib/commands/actions/plugin/build-command/command.js +0 -17
- package/lib/commands/actions/policies/list/action.js +0 -23
- package/lib/commands/actions/policies/list/command.js +0 -14
- package/lib/commands/actions/report/action.js +0 -35
- package/lib/commands/actions/report/command.js +0 -17
- package/lib/commands/actions/routes/list/action.js +0 -29
- package/lib/commands/actions/routes/list/command.js +0 -14
- package/lib/commands/actions/services/list/action.js +0 -23
- package/lib/commands/actions/services/list/command.js +0 -14
- package/lib/commands/actions/start/action.js +0 -25
- package/lib/commands/actions/start/command.js +0 -14
- package/lib/commands/actions/telemetry/disable/action.js +0 -88
- package/lib/commands/actions/telemetry/disable/command.js +0 -14
- package/lib/commands/actions/telemetry/enable/action.js +0 -104
- package/lib/commands/actions/telemetry/enable/command.js +0 -14
- package/lib/commands/actions/templates/generate/action.js +0 -96
- package/lib/commands/actions/templates/generate/command.js +0 -14
- package/lib/commands/actions/transfer/action.js +0 -200
- package/lib/commands/actions/transfer/command.js +0 -115
- package/lib/commands/actions/ts/generate-types/action.js +0 -29
- package/lib/commands/actions/ts/generate-types/command.js +0 -21
- package/lib/commands/actions/uninstall/action.js +0 -68
- package/lib/commands/actions/uninstall/command.js +0 -15
- package/lib/commands/actions/version/command.js +0 -19
- package/lib/commands/actions/watch-admin/action.js +0 -40
- package/lib/commands/actions/watch-admin/command.js +0 -15
- package/lib/commands/builders/admin.js +0 -57
- package/lib/commands/builders/index.js +0 -9
- package/lib/commands/builders/packages.js +0 -252
- package/lib/commands/builders/tasks/dts.js +0 -199
- package/lib/commands/builders/tasks/index.js +0 -29
- package/lib/commands/builders/tasks/vite.js +0 -144
- package/lib/commands/builders/typescript.js +0 -32
- package/lib/commands/index.js +0 -68
- package/lib/commands/utils/commander.js +0 -157
- package/lib/commands/utils/data-transfer.js +0 -427
- package/lib/commands/utils/helpers.js +0 -218
- package/lib/commands/utils/logger.js +0 -97
- package/lib/commands/utils/pkg.js +0 -421
- package/lib/compile.js +0 -20
- package/lib/container.js +0 -45
- package/lib/core/app-configuration/config-loader.js +0 -22
- package/lib/core/app-configuration/index.js +0 -61
- package/lib/core/app-configuration/load-config-file.js +0 -43
- package/lib/core/bootstrap.js +0 -33
- package/lib/core/domain/component/index.js +0 -24
- package/lib/core/domain/component/validator.js +0 -23
- package/lib/core/domain/content-type/index.js +0 -134
- package/lib/core/domain/content-type/validator.js +0 -105
- package/lib/core/domain/module/index.js +0 -108
- package/lib/core/domain/module/validation.js +0 -32
- package/lib/core/loaders/admin.js +0 -16
- package/lib/core/loaders/apis.js +0 -161
- package/lib/core/loaders/components.js +0 -42
- package/lib/core/loaders/index.js +0 -13
- package/lib/core/loaders/middlewares.js +0 -37
- package/lib/core/loaders/plugins/get-enabled-plugins.js +0 -151
- package/lib/core/loaders/plugins/get-user-plugins-config.js +0 -37
- package/lib/core/loaders/plugins/index.js +0 -121
- package/lib/core/loaders/policies.js +0 -29
- package/lib/core/loaders/sanitizers.js +0 -5
- package/lib/core/loaders/src-index.js +0 -39
- package/lib/core/loaders/validators.js +0 -5
- package/lib/core/registries/apis.js +0 -29
- package/lib/core/registries/config.js +0 -21
- package/lib/core/registries/content-types.js +0 -97
- package/lib/core/registries/controllers.d.ts +0 -7
- package/lib/core/registries/controllers.js +0 -114
- package/lib/core/registries/custom-fields.js +0 -89
- package/lib/core/registries/hooks.d.ts +0 -17
- package/lib/core/registries/hooks.js +0 -87
- package/lib/core/registries/middlewares.d.ts +0 -5
- package/lib/core/registries/middlewares.js +0 -89
- package/lib/core/registries/modules.js +0 -44
- package/lib/core/registries/plugins.js +0 -28
- package/lib/core/registries/policies.d.ts +0 -13
- package/lib/core/registries/policies.js +0 -89
- package/lib/core/registries/sanitizers.js +0 -26
- package/lib/core/registries/services.js +0 -114
- package/lib/core/registries/validators.js +0 -26
- package/lib/core/utils.js +0 -32
- package/lib/core-api/controller/collection-type.js +0 -115
- package/lib/core-api/controller/index.js +0 -63
- package/lib/core-api/controller/single-type.js +0 -65
- package/lib/core-api/controller/transform.js +0 -97
- package/lib/core-api/routes/index.js +0 -71
- package/lib/core-api/service/collection-type.js +0 -80
- package/lib/core-api/service/index.js +0 -45
- package/lib/core-api/service/pagination.js +0 -125
- package/lib/core-api/service/single-type.js +0 -72
- package/lib/factories.d.ts +0 -18
- package/lib/factories.js +0 -93
- package/lib/global.d.ts +0 -22
- package/lib/index.d.ts +0 -6
- package/lib/index.js +0 -8
- package/lib/load/filepath-to-prop-path.js +0 -22
- package/lib/load/glob.js +0 -15
- package/lib/load/index.js +0 -9
- package/lib/load/load-files.js +0 -58
- package/lib/load/package-path.js +0 -9
- package/lib/middlewares/body.js +0 -82
- package/lib/middlewares/compression.js +0 -8
- package/lib/middlewares/cors.js +0 -59
- package/lib/middlewares/errors.js +0 -40
- package/lib/middlewares/favicon.js +0 -32
- package/lib/middlewares/index.d.ts +0 -5
- package/lib/middlewares/index.js +0 -33
- package/lib/middlewares/ip.js +0 -8
- package/lib/middlewares/logger.js +0 -14
- package/lib/middlewares/powered-by.js +0 -20
- package/lib/middlewares/public/index.js +0 -94
- package/lib/middlewares/public/serve-static.js +0 -23
- package/lib/middlewares/query.js +0 -52
- package/lib/middlewares/response-time.js +0 -15
- package/lib/middlewares/responses.js +0 -19
- package/lib/middlewares/security.js +0 -57
- package/lib/middlewares/session.js +0 -30
- package/lib/migrations/draft-publish.js +0 -53
- package/lib/services/auth/index.js +0 -109
- package/lib/services/content-api/index.js +0 -74
- package/lib/services/content-api/permissions/engine.js +0 -5
- package/lib/services/content-api/permissions/index.js +0 -148
- package/lib/services/content-api/permissions/providers/action.js +0 -19
- package/lib/services/content-api/permissions/providers/condition.js +0 -19
- package/lib/services/content-api/permissions/providers/index.js +0 -9
- package/lib/services/core-store.js +0 -145
- package/lib/services/cron.js +0 -71
- package/lib/services/custom-fields.js +0 -11
- package/lib/services/entity-service/attributes/index.js +0 -31
- package/lib/services/entity-service/attributes/transforms.js +0 -20
- package/lib/services/entity-service/components.js +0 -497
- package/lib/services/entity-service/index.d.ts +0 -1
- package/lib/services/entity-service/index.js +0 -434
- package/lib/services/entity-service/params.js +0 -9
- package/lib/services/entity-service/types/index.d.ts +0 -228
- package/lib/services/entity-service/types/params/attributes.d.ts +0 -146
- package/lib/services/entity-service/types/params/data.d.ts +0 -4
- package/lib/services/entity-service/types/params/fields.d.ts +0 -74
- package/lib/services/entity-service/types/params/filters/index.d.ts +0 -75
- package/lib/services/entity-service/types/params/filters/operators.d.ts +0 -30
- package/lib/services/entity-service/types/params/index.d.ts +0 -79
- package/lib/services/entity-service/types/params/pagination.d.ts +0 -13
- package/lib/services/entity-service/types/params/populate.d.ts +0 -130
- package/lib/services/entity-service/types/params/publication-state.d.ts +0 -38
- package/lib/services/entity-service/types/params/search.d.ts +0 -1
- package/lib/services/entity-service/types/params/sort.d.ts +0 -106
- package/lib/services/entity-service/types/plugin.d.ts +0 -11
- package/lib/services/entity-service/types/result.d.ts +0 -205
- package/lib/services/entity-validator/index.js +0 -382
- package/lib/services/entity-validator/validators.js +0 -216
- package/lib/services/errors.js +0 -87
- package/lib/services/event-hub.js +0 -83
- package/lib/services/fs.js +0 -58
- package/lib/services/metrics/admin-user-hash.js +0 -21
- package/lib/services/metrics/index.js +0 -61
- package/lib/services/metrics/is-truthy.js +0 -9
- package/lib/services/metrics/middleware.js +0 -33
- package/lib/services/metrics/rate-limiter.js +0 -27
- package/lib/services/metrics/sender.js +0 -90
- package/lib/services/metrics/stringify-deep.js +0 -22
- package/lib/services/request-context.js +0 -17
- package/lib/services/server/admin-api.js +0 -14
- package/lib/services/server/api.js +0 -36
- package/lib/services/server/compose-endpoint.js +0 -141
- package/lib/services/server/content-api.js +0 -16
- package/lib/services/server/http-server.js +0 -64
- package/lib/services/server/index.js +0 -129
- package/lib/services/server/koa.js +0 -62
- package/lib/services/server/middleware.js +0 -132
- package/lib/services/server/policy.js +0 -32
- package/lib/services/server/register-middlewares.js +0 -109
- package/lib/services/server/register-routes.js +0 -105
- package/lib/services/server/routing.js +0 -105
- package/lib/services/utils/dynamic-zones.js +0 -13
- package/lib/services/utils/upload-files.js +0 -79
- package/lib/services/webhook-runner.js +0 -156
- package/lib/services/webhook-store.js +0 -120
- package/lib/services/worker-queue.js +0 -59
- package/lib/types/core/attributes/base.d.ts +0 -77
- package/lib/types/core/attributes/biginteger.d.ts +0 -15
- package/lib/types/core/attributes/boolean.d.ts +0 -14
- package/lib/types/core/attributes/common.d.ts +0 -77
- package/lib/types/core/attributes/component.d.ts +0 -36
- package/lib/types/core/attributes/date-time.d.ts +0 -16
- package/lib/types/core/attributes/date.d.ts +0 -13
- package/lib/types/core/attributes/decimal.d.ts +0 -15
- package/lib/types/core/attributes/dynamic-zone.d.ts +0 -29
- package/lib/types/core/attributes/email.d.ts +0 -14
- package/lib/types/core/attributes/enumeration.d.ts +0 -18
- package/lib/types/core/attributes/float.d.ts +0 -13
- package/lib/types/core/attributes/index.d.ts +0 -26
- package/lib/types/core/attributes/integer.d.ts +0 -15
- package/lib/types/core/attributes/json.d.ts +0 -11
- package/lib/types/core/attributes/media.d.ts +0 -42
- package/lib/types/core/attributes/password.d.ts +0 -15
- package/lib/types/core/attributes/relation.d.ts +0 -152
- package/lib/types/core/attributes/richtext.d.ts +0 -15
- package/lib/types/core/attributes/string.d.ts +0 -20
- package/lib/types/core/attributes/text.d.ts +0 -20
- package/lib/types/core/attributes/time.d.ts +0 -13
- package/lib/types/core/attributes/timestamp.d.ts +0 -15
- package/lib/types/core/attributes/uid.d.ts +0 -43
- package/lib/types/core/attributes/utils.d.ts +0 -143
- package/lib/types/core/commands/index.d.ts +0 -6
- package/lib/types/core/common/controller.d.ts +0 -8
- package/lib/types/core/common/index.d.ts +0 -16
- package/lib/types/core/common/schema.d.ts +0 -3
- package/lib/types/core/common/service.d.ts +0 -5
- package/lib/types/core/common/uid.d.ts +0 -58
- package/lib/types/core/index.d.ts +0 -9
- package/lib/types/core/namespace.d.ts +0 -99
- package/lib/types/core/plugins/index.d.ts +0 -16
- package/lib/types/core/registry.d.ts +0 -68
- package/lib/types/core/schemas/index.d.ts +0 -133
- package/lib/types/core/strapi/index.d.ts +0 -453
- package/lib/types/core/uid.d.ts +0 -167
- package/lib/types/core-api/controller.d.ts +0 -54
- package/lib/types/core-api/index.d.ts +0 -3
- package/lib/types/core-api/router.d.ts +0 -68
- package/lib/types/core-api/service.d.ts +0 -50
- package/lib/types/index.d.ts +0 -8
- package/lib/types/shared/entity-service.d.ts +0 -1
- package/lib/types/shared/index.d.ts +0 -3
- package/lib/types/shared/plugins.d.ts +0 -3
- package/lib/types/shared/registries.d.ts +0 -45
- package/lib/types/utils/array.d.ts +0 -25
- package/lib/types/utils/expression.d.ts +0 -91
- package/lib/types/utils/guard.d.ts +0 -27
- package/lib/types/utils/index.d.ts +0 -27
- package/lib/types/utils/object.d.ts +0 -63
- package/lib/types/utils/string.d.ts +0 -59
- package/lib/types/utils/tuple.d.ts +0 -13
- package/lib/utils/addSlash.js +0 -11
- package/lib/utils/convert-custom-field-type.js +0 -22
- package/lib/utils/cron.js +0 -56
- package/lib/utils/ee.js +0 -3
- package/lib/utils/fetch.js +0 -23
- package/lib/utils/get-dirs.js +0 -31
- package/lib/utils/index.js +0 -11
- package/lib/utils/is-initialized.js +0 -23
- package/lib/utils/lifecycles.js +0 -15
- package/lib/utils/machine-id.js +0 -14
- package/lib/utils/open-browser.js +0 -12
- package/lib/utils/run-checks.js +0 -22
- package/lib/utils/signals.js +0 -24
- package/lib/utils/startup-logger.js +0 -88
- package/lib/utils/success.js +0 -35
- package/lib/utils/update-notifier/index.js +0 -97
- package/lib/utils/url-from-segments.js +0 -12
- /package/{lib → dist}/middlewares/public/assets/images/group_people_1.png +0 -0
- /package/{lib → dist}/middlewares/public/assets/images/group_people_2.png +0 -0
- /package/{lib → dist}/middlewares/public/assets/images/group_people_3.png +0 -0
- /package/{lib → dist}/middlewares/public/assets/images/logo_login.png +0 -0
- /package/{lib → dist}/middlewares/public/index.html +0 -0
- /package/{ee/resources → resources}/key.pub +0 -0
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createContentType = void 0;
|
|
7
|
+
const fp_1 = require("lodash/fp");
|
|
8
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
9
|
+
const utils_1 = require("@strapi/utils");
|
|
10
|
+
const validator_1 = require("./validator");
|
|
11
|
+
const { CREATED_AT_ATTRIBUTE, UPDATED_AT_ATTRIBUTE, PUBLISHED_AT_ATTRIBUTE, CREATED_BY_ATTRIBUTE, UPDATED_BY_ATTRIBUTE, } = utils_1.contentTypes.constants;
|
|
12
|
+
const createContentType = (uid, definition) => {
|
|
13
|
+
try {
|
|
14
|
+
(0, validator_1.validateContentTypeDefinition)(definition);
|
|
15
|
+
}
|
|
16
|
+
catch (e) {
|
|
17
|
+
if (e instanceof utils_1.yup.ValidationError) {
|
|
18
|
+
throw new Error(`Content Type Definition is invalid for ${uid}'.\n${e.errors}`);
|
|
19
|
+
}
|
|
20
|
+
throw e;
|
|
21
|
+
}
|
|
22
|
+
const { schema, actions, lifecycles } = (0, fp_1.cloneDeep)(definition);
|
|
23
|
+
// general info
|
|
24
|
+
Object.assign(schema, {
|
|
25
|
+
kind: schema.kind || 'collectionType',
|
|
26
|
+
__schema__: pickSchema(definition.schema),
|
|
27
|
+
modelType: 'contentType',
|
|
28
|
+
modelName: definition.schema.info.singularName,
|
|
29
|
+
connection: 'default',
|
|
30
|
+
});
|
|
31
|
+
if (uid.startsWith('api::')) {
|
|
32
|
+
Object.assign(schema, {
|
|
33
|
+
uid,
|
|
34
|
+
apiName: uid.split('::')[1].split('.')[0],
|
|
35
|
+
collectionName: schema.collectionName || schema.info.singularName,
|
|
36
|
+
globalId: getGlobalId(schema, schema.info.singularName),
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
else if (uid.startsWith('plugin::')) {
|
|
40
|
+
const pluginName = uid.split('::')[1].split('.')[0];
|
|
41
|
+
Object.assign(schema, {
|
|
42
|
+
uid,
|
|
43
|
+
plugin: pluginName,
|
|
44
|
+
collectionName: schema.collectionName || `${pluginName}_${schema.info.singularName}`.toLowerCase(),
|
|
45
|
+
globalId: getGlobalId(schema, schema.info.singularName, pluginName),
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
else if (uid.startsWith('admin::')) {
|
|
49
|
+
Object.assign(schema, {
|
|
50
|
+
uid,
|
|
51
|
+
plugin: 'admin',
|
|
52
|
+
globalId: getGlobalId(schema, schema.info.singularName, 'admin'),
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
throw new Error(`Incorrect Content Type UID "${uid}". The UID should start with api::, plugin:: or admin::.`);
|
|
57
|
+
}
|
|
58
|
+
// attributes
|
|
59
|
+
Object.assign(schema.attributes, {
|
|
60
|
+
[CREATED_AT_ATTRIBUTE]: {
|
|
61
|
+
type: 'datetime',
|
|
62
|
+
},
|
|
63
|
+
// TODO: handle on edit set to new date
|
|
64
|
+
[UPDATED_AT_ATTRIBUTE]: {
|
|
65
|
+
type: 'datetime',
|
|
66
|
+
},
|
|
67
|
+
});
|
|
68
|
+
if (utils_1.contentTypes.hasDraftAndPublish(schema)) {
|
|
69
|
+
schema.attributes[PUBLISHED_AT_ATTRIBUTE] = {
|
|
70
|
+
type: 'datetime',
|
|
71
|
+
configurable: false,
|
|
72
|
+
writable: true,
|
|
73
|
+
visible: false,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
const isPrivate = !lodash_1.default.get(schema, 'options.populateCreatorFields', false);
|
|
77
|
+
schema.attributes[CREATED_BY_ATTRIBUTE] = {
|
|
78
|
+
type: 'relation',
|
|
79
|
+
relation: 'oneToOne',
|
|
80
|
+
target: 'admin::user',
|
|
81
|
+
configurable: false,
|
|
82
|
+
writable: false,
|
|
83
|
+
visible: false,
|
|
84
|
+
useJoinTable: false,
|
|
85
|
+
private: isPrivate,
|
|
86
|
+
};
|
|
87
|
+
schema.attributes[UPDATED_BY_ATTRIBUTE] = {
|
|
88
|
+
type: 'relation',
|
|
89
|
+
relation: 'oneToOne',
|
|
90
|
+
target: 'admin::user',
|
|
91
|
+
configurable: false,
|
|
92
|
+
writable: false,
|
|
93
|
+
visible: false,
|
|
94
|
+
useJoinTable: false,
|
|
95
|
+
private: isPrivate,
|
|
96
|
+
};
|
|
97
|
+
Object.assign(schema, { actions, lifecycles });
|
|
98
|
+
return schema;
|
|
99
|
+
};
|
|
100
|
+
exports.createContentType = createContentType;
|
|
101
|
+
const getGlobalId = (model, modelName, prefix) => {
|
|
102
|
+
const globalId = prefix ? `${prefix}-${modelName}` : modelName;
|
|
103
|
+
return model.globalId || lodash_1.default.upperFirst(lodash_1.default.camelCase(globalId));
|
|
104
|
+
};
|
|
105
|
+
const pickSchema = (model) => {
|
|
106
|
+
const schema = lodash_1.default.cloneDeep(lodash_1.default.pick(model, [
|
|
107
|
+
'connection',
|
|
108
|
+
'collectionName',
|
|
109
|
+
'info',
|
|
110
|
+
'options',
|
|
111
|
+
'pluginOptions',
|
|
112
|
+
'attributes',
|
|
113
|
+
]));
|
|
114
|
+
schema.kind = model.kind || 'collectionType';
|
|
115
|
+
return schema;
|
|
116
|
+
};
|
|
117
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/domain/content-type/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
declare const validateContentTypeDefinition: (data: unknown) => import("yup/lib/object").AssertsShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
|
|
2
|
+
schema: import("yup").ObjectSchema<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
|
|
3
|
+
info: any;
|
|
4
|
+
attributes: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
5
|
+
}>, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
|
|
6
|
+
info: any;
|
|
7
|
+
attributes: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
8
|
+
}>>, import("yup/lib/object").AssertsShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
|
|
9
|
+
info: any;
|
|
10
|
+
attributes: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
11
|
+
}>>>;
|
|
12
|
+
actions: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
13
|
+
lifecycles: import("yup").ObjectSchema<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
|
|
14
|
+
[x: string]: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
|
|
15
|
+
}>, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
|
|
16
|
+
[x: string]: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
|
|
17
|
+
}>>, import("yup/lib/object").AssertsShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
|
|
18
|
+
[x: string]: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
|
|
19
|
+
}>>>;
|
|
20
|
+
}>>;
|
|
21
|
+
export { validateContentTypeDefinition };
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.validateContentTypeDefinition = void 0;
|
|
7
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
8
|
+
const utils_1 = require("@strapi/utils");
|
|
9
|
+
const LIFECYCLES = [
|
|
10
|
+
'beforeCreate',
|
|
11
|
+
'afterCreate',
|
|
12
|
+
'beforeFindOne',
|
|
13
|
+
'afterFindOne',
|
|
14
|
+
'beforeFindMany',
|
|
15
|
+
'afterFindMany',
|
|
16
|
+
'beforeCount',
|
|
17
|
+
'afterCount',
|
|
18
|
+
'beforeCreateMany',
|
|
19
|
+
'afterCreateMany',
|
|
20
|
+
'beforeUpdate',
|
|
21
|
+
'afterUpdate',
|
|
22
|
+
'beforeUpdateMany',
|
|
23
|
+
'afterUpdateMany',
|
|
24
|
+
'beforeDelete',
|
|
25
|
+
'afterDelete',
|
|
26
|
+
'beforeDeleteMany',
|
|
27
|
+
'afterDeleteMany',
|
|
28
|
+
];
|
|
29
|
+
/**
|
|
30
|
+
* For enumerations the least common denomiator is GraphQL, where
|
|
31
|
+
* values needs to match the secure name regex:
|
|
32
|
+
* GraphQL Spec https://spec.graphql.org/June2018/#sec-Names
|
|
33
|
+
*
|
|
34
|
+
* Therefore we need to make sure our users only use values, which
|
|
35
|
+
* can be returned by GraphQL, by checking the regressed values
|
|
36
|
+
* agains the GraphQL regex.
|
|
37
|
+
*
|
|
38
|
+
* TODO V5: check if we can avoid this coupling by moving this logic
|
|
39
|
+
* into the GraphQL plugin.
|
|
40
|
+
*/
|
|
41
|
+
const GRAPHQL_ENUM_REGEX = /^[_A-Za-z][_0-9A-Za-z]*$/;
|
|
42
|
+
const lifecyclesShape = lodash_1.default.mapValues(lodash_1.default.keyBy(LIFECYCLES), () => utils_1.yup.mixed().nullable().isFunction());
|
|
43
|
+
const contentTypeSchemaValidator = utils_1.yup.object().shape({
|
|
44
|
+
schema: utils_1.yup.object().shape({
|
|
45
|
+
info: utils_1.yup
|
|
46
|
+
.object()
|
|
47
|
+
.shape({
|
|
48
|
+
displayName: utils_1.yup.string().required(),
|
|
49
|
+
singularName: utils_1.yup.string().isKebabCase().required(),
|
|
50
|
+
pluralName: utils_1.yup.string().isKebabCase().required(),
|
|
51
|
+
})
|
|
52
|
+
.required(),
|
|
53
|
+
attributes: utils_1.yup.object().test({
|
|
54
|
+
name: 'valuesCollide',
|
|
55
|
+
message: 'Some values collide when normalized',
|
|
56
|
+
test(attributes) {
|
|
57
|
+
for (const attrName of Object.keys(attributes)) {
|
|
58
|
+
const attr = attributes[attrName];
|
|
59
|
+
if (attr.type === 'enumeration') {
|
|
60
|
+
const regressedValues = attr.enum.map(utils_1.toRegressedEnumValue);
|
|
61
|
+
// should match the GraphQL regex
|
|
62
|
+
if (!regressedValues.every((value) => GRAPHQL_ENUM_REGEX.test(value))) {
|
|
63
|
+
const message = `Invalid enumeration value. Values should have at least one alphabetical character preceding the first occurence of a number. Update your enumeration '${attrName}'.`;
|
|
64
|
+
return this.createError({ message });
|
|
65
|
+
}
|
|
66
|
+
// should not contain empty values
|
|
67
|
+
if (regressedValues.some((value) => value === '')) {
|
|
68
|
+
return this.createError({
|
|
69
|
+
message: `At least one value of the enumeration '${attrName}' appears to be empty. Only alphanumerical characters are taken into account.`,
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
// should not collide
|
|
73
|
+
const duplicates = lodash_1.default.uniq(regressedValues.filter((value, index, values) => values.indexOf(value) !== index));
|
|
74
|
+
if (duplicates.length) {
|
|
75
|
+
const message = `Some enumeration values of the field '${attrName}' collide when normalized: ${duplicates.join(', ')}. Please modify your enumeration.`;
|
|
76
|
+
return this.createError({ message });
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return true;
|
|
81
|
+
},
|
|
82
|
+
}),
|
|
83
|
+
}),
|
|
84
|
+
actions: utils_1.yup.object().onlyContainsFunctions(),
|
|
85
|
+
lifecycles: utils_1.yup.object().shape(lifecyclesShape).noUnknown(),
|
|
86
|
+
});
|
|
87
|
+
const validateContentTypeDefinition = (data) => {
|
|
88
|
+
return contentTypeSchemaValidator.validateSync(data, { strict: true, abortEarly: false });
|
|
89
|
+
};
|
|
90
|
+
exports.validateContentTypeDefinition = validateContentTypeDefinition;
|
|
91
|
+
//# sourceMappingURL=validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validator.js","sourceRoot":"","sources":["../../../../src/core/domain/content-type/validator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { Strapi, Common, Schema } from '@strapi/types';
|
|
2
|
+
export interface RawModule {
|
|
3
|
+
config?: Record<string, unknown>;
|
|
4
|
+
routes?: Common.Module['routes'];
|
|
5
|
+
controllers?: Common.Module['controllers'];
|
|
6
|
+
services?: Common.Module['services'];
|
|
7
|
+
contentTypes?: Common.Module['contentTypes'];
|
|
8
|
+
policies?: Common.Module['policies'];
|
|
9
|
+
middlewares?: Common.Module['middlewares'];
|
|
10
|
+
bootstrap?: (params: {
|
|
11
|
+
strapi: Strapi;
|
|
12
|
+
}) => Promise<void>;
|
|
13
|
+
register?: (params: {
|
|
14
|
+
strapi: Strapi;
|
|
15
|
+
}) => Promise<void>;
|
|
16
|
+
destroy?: (params: {
|
|
17
|
+
strapi: Strapi;
|
|
18
|
+
}) => Promise<void>;
|
|
19
|
+
}
|
|
20
|
+
export interface Module {
|
|
21
|
+
bootstrap: () => Promise<void>;
|
|
22
|
+
register: () => Promise<void>;
|
|
23
|
+
destroy: () => Promise<void>;
|
|
24
|
+
load: () => void;
|
|
25
|
+
routes: Common.Module['routes'];
|
|
26
|
+
config: (path: string, defaultValue?: unknown) => unknown;
|
|
27
|
+
contentType: (ctName: Common.UID.ContentType) => Schema.ContentType;
|
|
28
|
+
contentTypes: Record<string, Schema.ContentType>;
|
|
29
|
+
service: (serviceName: Common.UID.Service) => Common.Service;
|
|
30
|
+
services: Record<string, Common.Service>;
|
|
31
|
+
policy: (policyName: Common.UID.Policy) => Common.Policy;
|
|
32
|
+
policies: Record<string, Common.Policy>;
|
|
33
|
+
middleware: (middlewareName: Common.UID.Middleware) => Common.Middleware;
|
|
34
|
+
middlewares: Record<string, Common.Middleware>;
|
|
35
|
+
controller: (controllerName: Common.UID.Controller) => Common.Controller;
|
|
36
|
+
controllers: Record<string, Common.Controller>;
|
|
37
|
+
}
|
|
38
|
+
export declare const createModule: (namespace: string, rawModule: RawModule, strapi: Strapi) => Module;
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createModule = void 0;
|
|
7
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
8
|
+
const utils_1 = require("@strapi/utils");
|
|
9
|
+
const utils_2 = require("../../utils");
|
|
10
|
+
const validation_1 = require("./validation");
|
|
11
|
+
const uidToPath = (uid) => uid.replace('::', '.');
|
|
12
|
+
// Removes the namespace from a map with keys prefixed with a namespace
|
|
13
|
+
const removeNamespacedKeys = (map, namespace) => {
|
|
14
|
+
return lodash_1.default.mapKeys(map, (value, key) => (0, utils_2.removeNamespace)(key, namespace));
|
|
15
|
+
};
|
|
16
|
+
const defaultModule = {
|
|
17
|
+
config: {},
|
|
18
|
+
routes: [],
|
|
19
|
+
controllers: {},
|
|
20
|
+
services: {},
|
|
21
|
+
contentTypes: {},
|
|
22
|
+
policies: {},
|
|
23
|
+
middlewares: {},
|
|
24
|
+
};
|
|
25
|
+
const createModule = (namespace, rawModule, strapi) => {
|
|
26
|
+
lodash_1.default.defaults(rawModule, defaultModule);
|
|
27
|
+
try {
|
|
28
|
+
(0, validation_1.validateModule)(rawModule);
|
|
29
|
+
}
|
|
30
|
+
catch (e) {
|
|
31
|
+
if (e instanceof utils_1.yup.ValidationError) {
|
|
32
|
+
throw new Error(`strapi-server.js is invalid for '${namespace}'.\n${e.errors.join('\n')}`);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
const called = {};
|
|
36
|
+
return {
|
|
37
|
+
async bootstrap() {
|
|
38
|
+
if (called.bootstrap) {
|
|
39
|
+
throw new Error(`Bootstrap for ${namespace} has already been called`);
|
|
40
|
+
}
|
|
41
|
+
called.bootstrap = true;
|
|
42
|
+
await (rawModule.bootstrap && rawModule.bootstrap({ strapi }));
|
|
43
|
+
},
|
|
44
|
+
async register() {
|
|
45
|
+
if (called.register) {
|
|
46
|
+
throw new Error(`Register for ${namespace} has already been called`);
|
|
47
|
+
}
|
|
48
|
+
called.register = true;
|
|
49
|
+
await (rawModule.register && rawModule.register({ strapi }));
|
|
50
|
+
},
|
|
51
|
+
async destroy() {
|
|
52
|
+
if (called.destroy) {
|
|
53
|
+
throw new Error(`Destroy for ${namespace} has already been called`);
|
|
54
|
+
}
|
|
55
|
+
called.destroy = true;
|
|
56
|
+
await (rawModule.destroy && rawModule.destroy({ strapi }));
|
|
57
|
+
},
|
|
58
|
+
load() {
|
|
59
|
+
strapi.container.get('content-types').add(namespace, rawModule.contentTypes);
|
|
60
|
+
strapi.container.get('services').add(namespace, rawModule.services);
|
|
61
|
+
strapi.container.get('policies').add(namespace, rawModule.policies);
|
|
62
|
+
strapi.container.get('middlewares').add(namespace, rawModule.middlewares);
|
|
63
|
+
strapi.container.get('controllers').add(namespace, rawModule.controllers);
|
|
64
|
+
strapi.container.get('config').set(uidToPath(namespace), rawModule.config);
|
|
65
|
+
},
|
|
66
|
+
get routes() {
|
|
67
|
+
return rawModule.routes ?? {};
|
|
68
|
+
},
|
|
69
|
+
config(path, defaultValue) {
|
|
70
|
+
return strapi.container.get('config').get(`${uidToPath(namespace)}.${path}`, defaultValue);
|
|
71
|
+
},
|
|
72
|
+
contentType(ctName) {
|
|
73
|
+
return strapi.container.get('content-types').get(`${namespace}.${ctName}`);
|
|
74
|
+
},
|
|
75
|
+
get contentTypes() {
|
|
76
|
+
const contentTypes = strapi.container.get('content-types').getAll(namespace);
|
|
77
|
+
return removeNamespacedKeys(contentTypes, namespace);
|
|
78
|
+
},
|
|
79
|
+
service(serviceName) {
|
|
80
|
+
return strapi.container.get('services').get(`${namespace}.${serviceName}`);
|
|
81
|
+
},
|
|
82
|
+
get services() {
|
|
83
|
+
const services = strapi.container.get('services').getAll(namespace);
|
|
84
|
+
return removeNamespacedKeys(services, namespace);
|
|
85
|
+
},
|
|
86
|
+
policy(policyName) {
|
|
87
|
+
return strapi.container.get('policies').get(`${namespace}.${policyName}`);
|
|
88
|
+
},
|
|
89
|
+
get policies() {
|
|
90
|
+
const policies = strapi.container.get('policies').getAll(namespace);
|
|
91
|
+
return removeNamespacedKeys(policies, namespace);
|
|
92
|
+
},
|
|
93
|
+
middleware(middlewareName) {
|
|
94
|
+
return strapi.container.get('middlewares').get(`${namespace}.${middlewareName}`);
|
|
95
|
+
},
|
|
96
|
+
get middlewares() {
|
|
97
|
+
const middlewares = strapi.container.get('middlewares').getAll(namespace);
|
|
98
|
+
return removeNamespacedKeys(middlewares, namespace);
|
|
99
|
+
},
|
|
100
|
+
controller(controllerName) {
|
|
101
|
+
return strapi.container.get('controllers').get(`${namespace}.${controllerName}`);
|
|
102
|
+
},
|
|
103
|
+
get controllers() {
|
|
104
|
+
const controllers = strapi.container.get('controllers').getAll(namespace);
|
|
105
|
+
return removeNamespacedKeys(controllers, namespace);
|
|
106
|
+
},
|
|
107
|
+
};
|
|
108
|
+
};
|
|
109
|
+
exports.createModule = createModule;
|
|
110
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/domain/module/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
declare const validateModule: (data: unknown) => import("yup/lib/object").AssertsShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
|
|
2
|
+
bootstrap: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
|
|
3
|
+
destroy: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
|
|
4
|
+
register: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
|
|
5
|
+
config: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
6
|
+
routes: import("yup/lib/Lazy").default<import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>> | import("yup/lib/array").OptionalArraySchema<import("yup").AnySchema, import("yup/lib/types").AnyObject, any[] | undefined>, any>;
|
|
7
|
+
controllers: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
8
|
+
services: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
9
|
+
policies: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
10
|
+
middlewares: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
11
|
+
contentTypes: import("yup/lib/object").OptionalObjectSchema<import("yup/lib/object").ObjectShape, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").ObjectShape>>;
|
|
12
|
+
}>>;
|
|
13
|
+
export { validateModule };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateModule = void 0;
|
|
4
|
+
const utils_1 = require("@strapi/utils");
|
|
5
|
+
const strapiServerSchema = utils_1.yup
|
|
6
|
+
.object()
|
|
7
|
+
.shape({
|
|
8
|
+
bootstrap: utils_1.yup.mixed().isFunction(),
|
|
9
|
+
destroy: utils_1.yup.mixed().isFunction(),
|
|
10
|
+
register: utils_1.yup.mixed().isFunction(),
|
|
11
|
+
config: utils_1.yup.object(),
|
|
12
|
+
routes: utils_1.yup.lazy((value) => {
|
|
13
|
+
if (Array.isArray(value)) {
|
|
14
|
+
return utils_1.yup.array();
|
|
15
|
+
}
|
|
16
|
+
return utils_1.yup.object();
|
|
17
|
+
}),
|
|
18
|
+
controllers: utils_1.yup.object(),
|
|
19
|
+
services: utils_1.yup.object(),
|
|
20
|
+
policies: utils_1.yup.object(),
|
|
21
|
+
middlewares: utils_1.yup.object(),
|
|
22
|
+
contentTypes: utils_1.yup.object(),
|
|
23
|
+
})
|
|
24
|
+
.noUnknown();
|
|
25
|
+
const validateModule = (data) => {
|
|
26
|
+
return strapiServerSchema.validateSync(data, { strict: true, abortEarly: false });
|
|
27
|
+
};
|
|
28
|
+
exports.validateModule = validateModule;
|
|
29
|
+
//# sourceMappingURL=validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../../../src/core/domain/module/validation.ts"],"names":[],"mappings":";;;AAAA,yCAAoC;AAEpC,MAAM,kBAAkB,GAAG,WAAG;KAC3B,MAAM,EAAE;KACR,KAAK,CAAC;IACL,SAAS,EAAE,WAAG,CAAC,KAAK,EAAE,CAAC,UAAU,EAAE;IACnC,OAAO,EAAE,WAAG,CAAC,KAAK,EAAE,CAAC,UAAU,EAAE;IACjC,QAAQ,EAAE,WAAG,CAAC,KAAK,EAAE,CAAC,UAAU,EAAE;IAClC,MAAM,EAAE,WAAG,CAAC,MAAM,EAAE;IACpB,MAAM,EAAE,WAAG,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;QACzB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACxB,OAAO,WAAG,CAAC,KAAK,EAAE,CAAC;SACpB;QACD,OAAO,WAAG,CAAC,MAAM,EAAE,CAAC;IACtB,CAAC,CAAC;IACF,WAAW,EAAE,WAAG,CAAC,MAAM,EAAE;IACzB,QAAQ,EAAE,WAAG,CAAC,MAAM,EAAE;IACtB,QAAQ,EAAE,WAAG,CAAC,MAAM,EAAE;IACtB,WAAW,EAAE,WAAG,CAAC,MAAM,EAAE;IACzB,YAAY,EAAE,WAAG,CAAC,MAAM,EAAE;CAC3B,CAAC;KACD,SAAS,EAAE,CAAC;AAEf,MAAM,cAAc,GAAG,CAAC,IAAa,EAAE,EAAE;IACvC,OAAO,kBAAkB,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;AACpF,CAAC,CAAC;AAEO,wCAAc"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
7
|
+
async function loadAdmin(strapi) {
|
|
8
|
+
strapi.admin = require('@strapi/admin/strapi-server');
|
|
9
|
+
strapi.container.get('services').add(`admin::`, strapi.admin?.services);
|
|
10
|
+
strapi.container.get('controllers').add(`admin::`, strapi.admin?.controllers);
|
|
11
|
+
strapi.container.get('content-types').add(`admin::`, strapi.admin?.contentTypes);
|
|
12
|
+
strapi.container.get('policies').add(`admin::`, strapi.admin?.policies);
|
|
13
|
+
strapi.container.get('middlewares').add(`admin::`, strapi.admin?.middlewares);
|
|
14
|
+
const userAdminConfig = strapi.config.get('admin');
|
|
15
|
+
strapi.container.get('config').set('admin', lodash_1.default.merge(strapi.admin?.config, userAdminConfig));
|
|
16
|
+
}
|
|
17
|
+
exports.default = loadAdmin;
|
|
18
|
+
//# sourceMappingURL=admin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin.js","sourceRoot":"","sources":["../../../src/core/loaders/admin.ts"],"names":[],"mappings":";;;;;AAAA,oDAAuB;AAGR,KAAK,UAAU,SAAS,CAAC,MAAc;IACpD,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC,6BAA6B,CAAC,CAAC;IAEtD,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IACxE,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IAC9E,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;IACjF,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IACxE,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IAE9E,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IACnD,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,gBAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,eAAe,CAAC,CAAC,CAAC;AAC9F,CAAC;AAXD,4BAWC"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const path_1 = require("path");
|
|
30
|
+
const fs_extra_1 = __importStar(require("fs-extra"));
|
|
31
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
32
|
+
const utils_1 = require("@strapi/utils");
|
|
33
|
+
const fp_1 = require("lodash/fp");
|
|
34
|
+
const DEFAULT_CONTENT_TYPE = {
|
|
35
|
+
schema: {},
|
|
36
|
+
actions: {},
|
|
37
|
+
lifecycles: {},
|
|
38
|
+
};
|
|
39
|
+
// to handle names with numbers in it we first check if it is already in kebabCase
|
|
40
|
+
const normalizeName = (name) => ((0, utils_1.isKebabCase)(name) ? name : lodash_1.default.kebabCase(name));
|
|
41
|
+
const isDirectory = (fd) => fd.isDirectory();
|
|
42
|
+
const isDotFile = (fd) => fd.name.startsWith('.');
|
|
43
|
+
async function loadAPIs(strapi) {
|
|
44
|
+
if (!(0, fs_extra_1.existsSync)(strapi.dirs.dist.api)) {
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
const apisFDs = await (await fs_extra_1.default.readdir(strapi.dirs.dist.api, { withFileTypes: true }))
|
|
48
|
+
.filter(isDirectory)
|
|
49
|
+
.filter(lodash_1.default.negate(isDotFile));
|
|
50
|
+
const apis = {};
|
|
51
|
+
// only load folders
|
|
52
|
+
for (const apiFD of apisFDs) {
|
|
53
|
+
const apiName = normalizeName(apiFD.name);
|
|
54
|
+
const api = await loadAPI((0, path_1.join)(strapi.dirs.dist.api, apiFD.name));
|
|
55
|
+
apis[apiName] = api;
|
|
56
|
+
}
|
|
57
|
+
validateContentTypesUnicity(apis);
|
|
58
|
+
for (const apiName of Object.keys(apis)) {
|
|
59
|
+
strapi.container.get('apis').add(apiName, apis[apiName]);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
exports.default = loadAPIs;
|
|
63
|
+
const validateContentTypesUnicity = (apis) => {
|
|
64
|
+
const allApisSchemas = Object.values(apis).flatMap((api) => Object.values(api.contentTypes));
|
|
65
|
+
const names = [];
|
|
66
|
+
allApisSchemas.forEach(({ schema }) => {
|
|
67
|
+
if (schema.info.singularName) {
|
|
68
|
+
const singularName = lodash_1.default.kebabCase(schema.info.singularName);
|
|
69
|
+
if (names.includes(singularName)) {
|
|
70
|
+
throw new Error(`The singular name "${schema.info.singularName}" should be unique`);
|
|
71
|
+
}
|
|
72
|
+
names.push(singularName);
|
|
73
|
+
}
|
|
74
|
+
if (schema.info.pluralName) {
|
|
75
|
+
const pluralName = lodash_1.default.kebabCase(schema.info.pluralName);
|
|
76
|
+
if (names.includes(pluralName)) {
|
|
77
|
+
throw new Error(`The plural name "${schema.info.pluralName}" should be unique`);
|
|
78
|
+
}
|
|
79
|
+
names.push(pluralName);
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
};
|
|
83
|
+
const loadAPI = async (dir) => {
|
|
84
|
+
const [index, config, routes, controllers, services, policies, middlewares, contentTypes] = await Promise.all([
|
|
85
|
+
loadIndex(dir),
|
|
86
|
+
loadDir((0, path_1.join)(dir, 'config')),
|
|
87
|
+
loadDir((0, path_1.join)(dir, 'routes')),
|
|
88
|
+
loadDir((0, path_1.join)(dir, 'controllers')),
|
|
89
|
+
loadDir((0, path_1.join)(dir, 'services')),
|
|
90
|
+
loadDir((0, path_1.join)(dir, 'policies')),
|
|
91
|
+
loadDir((0, path_1.join)(dir, 'middlewares')),
|
|
92
|
+
loadContentTypes((0, path_1.join)(dir, 'content-types')),
|
|
93
|
+
]);
|
|
94
|
+
return {
|
|
95
|
+
...(index || {}),
|
|
96
|
+
config: config || {},
|
|
97
|
+
routes: routes || [],
|
|
98
|
+
controllers: controllers || {},
|
|
99
|
+
services: services || {},
|
|
100
|
+
policies: policies || {},
|
|
101
|
+
middlewares: middlewares || {},
|
|
102
|
+
contentTypes: contentTypes || {},
|
|
103
|
+
};
|
|
104
|
+
};
|
|
105
|
+
const loadIndex = async (dir) => {
|
|
106
|
+
if (await fs_extra_1.default.pathExists((0, path_1.join)(dir, 'index.js'))) {
|
|
107
|
+
return loadFile((0, path_1.join)(dir, 'index.js'));
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
const loadContentTypes = async (dir) => {
|
|
111
|
+
if (!(await fs_extra_1.default.pathExists(dir))) {
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
const fds = await fs_extra_1.default.readdir(dir, { withFileTypes: true });
|
|
115
|
+
const contentTypes = {};
|
|
116
|
+
// only load folders
|
|
117
|
+
for (const fd of fds) {
|
|
118
|
+
if (fd.isFile()) {
|
|
119
|
+
continue;
|
|
120
|
+
}
|
|
121
|
+
const contentTypeName = normalizeName(fd.name);
|
|
122
|
+
const contentType = await loadDir((0, path_1.join)(dir, fd.name));
|
|
123
|
+
if ((0, fp_1.isEmpty)(contentType) || (0, fp_1.isEmpty)(contentType.schema)) {
|
|
124
|
+
throw new Error(`Could not load content type found at ${dir}`);
|
|
125
|
+
}
|
|
126
|
+
contentTypes[normalizeName(contentTypeName)] = lodash_1.default.defaults(contentType, DEFAULT_CONTENT_TYPE);
|
|
127
|
+
}
|
|
128
|
+
return contentTypes;
|
|
129
|
+
};
|
|
130
|
+
const loadDir = async (dir) => {
|
|
131
|
+
if (!(await fs_extra_1.default.pathExists(dir))) {
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
const fds = await fs_extra_1.default.readdir(dir, { withFileTypes: true });
|
|
135
|
+
const root = {};
|
|
136
|
+
for (const fd of fds) {
|
|
137
|
+
if (!fd.isFile() || (0, path_1.extname)(fd.name) === '.map') {
|
|
138
|
+
continue;
|
|
139
|
+
}
|
|
140
|
+
const key = (0, path_1.basename)(fd.name, (0, path_1.extname)(fd.name));
|
|
141
|
+
root[normalizeName(key)] = await loadFile((0, path_1.join)(dir, fd.name));
|
|
142
|
+
}
|
|
143
|
+
return root;
|
|
144
|
+
};
|
|
145
|
+
const loadFile = (file) => {
|
|
146
|
+
const ext = (0, path_1.extname)(file);
|
|
147
|
+
switch (ext) {
|
|
148
|
+
case '.js':
|
|
149
|
+
return (0, utils_1.importDefault)(file);
|
|
150
|
+
case '.json':
|
|
151
|
+
return fs_extra_1.default.readJSON(file);
|
|
152
|
+
default:
|
|
153
|
+
return {};
|
|
154
|
+
}
|
|
155
|
+
};
|
|
156
|
+
//# sourceMappingURL=apis.js.map
|