@strapi/admin 4.3.2 → 4.3.5
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/admin/src/StrapiApp.js +23 -23
- package/admin/src/components/AuthenticatedApp/index.js +15 -12
- package/admin/src/components/AuthenticatedApp/utils/api.js +1 -1
- package/admin/src/components/AutoReloadOverlayBlockerProvider/index.js +8 -6
- package/admin/src/components/ConfigurationsProvider/index.js +21 -12
- package/admin/src/components/ConfigurationsProvider/reducer.js +1 -1
- package/admin/src/components/GuidedTour/Homepage/components/Stepper.js +1 -1
- package/admin/src/components/GuidedTour/Homepage/index.js +2 -2
- package/admin/src/components/GuidedTour/Modal/components/Content.js +6 -6
- package/admin/src/components/GuidedTour/Modal/components/Modal.js +1 -1
- package/admin/src/components/GuidedTour/Modal/index.js +2 -4
- package/admin/src/components/GuidedTour/Modal/reducer.js +1 -1
- package/admin/src/components/GuidedTour/index.js +4 -4
- package/admin/src/components/GuidedTour/init.js +2 -2
- package/admin/src/components/GuidedTour/reducer.js +1 -1
- package/admin/src/components/GuidedTour/utils/isGuidedTourCompleted.js +1 -1
- package/admin/src/components/GuidedTour/utils/persistStateToLocaleStorage.js +4 -4
- package/admin/src/components/LanguageProvider/index.js +1 -1
- package/admin/src/components/LanguageProvider/init.js +1 -1
- package/admin/src/components/LeftMenu/index.js +6 -6
- package/admin/src/components/Notifications/Notification/index.js +3 -4
- package/admin/src/components/Notifications/index.js +2 -2
- package/admin/src/components/Notifications/reducer.js +2 -2
- package/admin/src/components/PluginsInitializer/index.js +4 -2
- package/admin/src/components/PluginsInitializer/init.js +1 -1
- package/admin/src/components/PluginsInitializer/reducer.js +1 -1
- package/admin/src/components/PrivateRoute/index.js +1 -1
- package/admin/src/components/RBACProvider/actions.js +1 -1
- package/admin/src/components/RBACProvider/index.js +1 -1
- package/admin/src/components/RBACProvider/reducer.js +2 -2
- package/admin/src/components/ThemeToggleProvider/index.js +1 -1
- package/admin/src/components/UpgradePlanModal/index.js +1 -1
- package/admin/src/content-manager/components/AttributeFilter/Filters.js +1 -1
- package/admin/src/content-manager/components/AttributeFilter/hooks/useAllowedAttributes.js +1 -1
- package/admin/src/content-manager/components/AttributeFilter/index.js +4 -2
- package/admin/src/content-manager/components/Block/index.js +1 -1
- package/admin/src/content-manager/components/CollectionTypeFormWrapper/index.js +7 -12
- package/admin/src/content-manager/components/DragLayer/index.js +1 -1
- package/admin/src/content-manager/components/DynamicTable/CellContent/CellValue.js +3 -5
- package/admin/src/content-manager/components/DynamicTable/CellContent/RelationMultiple/index.js +1 -1
- package/admin/src/content-manager/components/DynamicTable/CellContent/RepeatableComponent/index.js +1 -1
- package/admin/src/content-manager/components/DynamicTable/TableRows/index.js +4 -4
- package/admin/src/content-manager/components/DynamicTable/index.js +25 -4
- package/admin/src/content-manager/components/DynamicZone/components/AddComponentButton/index.js +18 -20
- package/admin/src/content-manager/components/DynamicZone/components/Component/index.js +1 -1
- package/admin/src/content-manager/components/DynamicZone/components/ComponentPicker/Category/ComponentCard/index.js +1 -1
- package/admin/src/content-manager/components/DynamicZone/components/ComponentPicker/index.js +3 -3
- package/admin/src/content-manager/components/DynamicZone/index.js +10 -10
- package/admin/src/content-manager/components/DynamicZone/utils/connect.js +1 -1
- package/admin/src/content-manager/components/DynamicZone/utils/select.js +1 -1
- package/admin/src/content-manager/components/EditViewDataManagerProvider/index.js +6 -6
- package/admin/src/content-manager/components/EditViewDataManagerProvider/reducer.js +1 -1
- package/admin/src/content-manager/components/EditViewDataManagerProvider/utils/cleanData.js +4 -4
- package/admin/src/content-manager/components/EditViewDataManagerProvider/utils/schema.js +18 -18
- package/admin/src/content-manager/components/FieldComponent/utils/connect.js +1 -1
- package/admin/src/content-manager/components/FieldComponent/utils/select.js +6 -6
- package/admin/src/content-manager/components/FormTitle/index.js +1 -1
- package/admin/src/content-manager/components/InjectionZoneList/index.js +1 -1
- package/admin/src/content-manager/components/InputJSON/index.js +5 -6
- package/admin/src/content-manager/components/InputJSON/jsonlint.js +13 -13
- package/admin/src/content-manager/components/InputUID/index.js +1 -1
- package/admin/src/content-manager/components/InputUID/regex.js +1 -1
- package/admin/src/content-manager/components/Inputs/index.js +32 -5
- package/admin/src/content-manager/components/Inputs/utils/connect.js +1 -1
- package/admin/src/content-manager/components/Inputs/utils/generateOptions.js +1 -1
- package/admin/src/content-manager/components/Inputs/utils/getStep.js +1 -5
- package/admin/src/content-manager/components/LayoutDndProvider/index.js +6 -6
- package/admin/src/content-manager/components/NonRepeatableComponent/index.js +4 -4
- package/admin/src/content-manager/components/PreviewWysiwyg/utils/mdRenderer.js +1 -1
- package/admin/src/content-manager/components/PreviewWysiwyg/utils/satinizeHtml.js +1 -1
- package/admin/src/content-manager/components/RepeatableComponent/AccordionGroupCustom/index.js +1 -1
- package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/index.js +9 -15
- package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/utils/connect.js +1 -1
- package/admin/src/content-manager/components/RepeatableComponent/index.js +5 -5
- package/admin/src/content-manager/components/RepeatableComponent/utils/connect.js +1 -1
- package/admin/src/content-manager/components/RepeatableComponent/utils/getComponentErrorKeys.js +2 -2
- package/admin/src/content-manager/components/SectionTitle/index.js +1 -1
- package/admin/src/content-manager/components/SelectMany/ListItem.js +1 -1
- package/admin/src/content-manager/components/SelectMany/index.js +1 -1
- package/admin/src/content-manager/components/SelectOne/SingleValue.js +1 -1
- package/admin/src/content-manager/components/SelectWrapper/Option.js +1 -1
- package/admin/src/content-manager/components/SelectWrapper/index.js +16 -26
- package/admin/src/content-manager/components/SelectWrapper/utils/connect.js +1 -1
- package/admin/src/content-manager/components/SingleTypeFormWrapper/index.js +6 -11
- package/admin/src/content-manager/components/SingleTypeFormWrapper/utils/getRequestUrl.js +1 -1
- package/admin/src/content-manager/components/Wysiwyg/Editor.js +1 -1
- package/admin/src/content-manager/components/Wysiwyg/EditorLayout.js +1 -1
- package/admin/src/content-manager/components/Wysiwyg/WysiwygFooter.js +1 -1
- package/admin/src/content-manager/components/Wysiwyg/WysiwygNav.js +4 -4
- package/admin/src/content-manager/components/Wysiwyg/index.js +5 -5
- package/admin/src/content-manager/components/Wysiwyg/utils/utils.js +4 -4
- package/admin/src/content-manager/hooks/useContentTypeLayout/index.js +1 -1
- package/admin/src/content-manager/hooks/useFetchContentTypeLayout/index.js +3 -3
- package/admin/src/content-manager/hooks/useFetchContentTypeLayout/reducer.js +1 -1
- package/admin/src/content-manager/hooks/useFetchContentTypeLayout/utils/formatLayouts.js +7 -7
- package/admin/src/content-manager/hooks/useFindRedirectionLink/index.js +1 -1
- package/admin/src/content-manager/hooks/useFindRedirectionLink/selectors.js +1 -1
- package/admin/src/content-manager/hooks/useSyncRbac/reducer.js +1 -1
- package/admin/src/content-manager/hooks/useSyncRbac/selectors.js +2 -2
- package/admin/src/content-manager/pages/App/LeftMenu/index.js +8 -8
- package/admin/src/content-manager/pages/App/index.js +3 -3
- package/admin/src/content-manager/pages/App/reducer.js +1 -1
- package/admin/src/content-manager/pages/App/selectors.js +4 -4
- package/admin/src/content-manager/pages/App/useModels.js +1 -1
- package/admin/src/content-manager/pages/App/utils/generateModelsLinks.js +2 -2
- package/admin/src/content-manager/pages/CollectionTypeRecursivePath/index.js +1 -1
- package/admin/src/content-manager/pages/ComponentSetttingsView/index.js +2 -2
- package/admin/src/content-manager/pages/EditSettingsView/components/ComponentFieldList.js +1 -1
- package/admin/src/content-manager/pages/EditSettingsView/components/DisplayedFieldButton.js +5 -5
- package/admin/src/content-manager/pages/EditSettingsView/components/DisplayedFields.js +1 -1
- package/admin/src/content-manager/pages/EditSettingsView/components/DynamicZoneList.js +1 -1
- package/admin/src/content-manager/pages/EditSettingsView/components/GenericInput.js +3 -3
- package/admin/src/content-manager/pages/EditSettingsView/components/ModalForm.js +36 -5
- package/admin/src/content-manager/pages/EditSettingsView/components/RelationalFieldButton.js +3 -3
- package/admin/src/content-manager/pages/EditSettingsView/components/RelationalFields.js +1 -1
- package/admin/src/content-manager/pages/EditSettingsView/index.js +21 -21
- package/admin/src/content-manager/pages/EditSettingsView/reducer.js +1 -1
- package/admin/src/content-manager/pages/EditSettingsView/utils/createPossibleMainFieldsForModelsAndComponents.js +2 -2
- package/admin/src/content-manager/pages/EditSettingsView/utils/getInputProps.js +1 -1
- package/admin/src/content-manager/pages/EditSettingsView/utils/layout.js +12 -12
- package/admin/src/content-manager/pages/EditView/DeleteLink/index.js +1 -1
- package/admin/src/content-manager/pages/EditView/DeleteLink/utils/connect.js +1 -1
- package/admin/src/content-manager/pages/EditView/DraftAndPublishBadge/utils/connect.js +1 -1
- package/admin/src/content-manager/pages/EditView/Header/index.js +4 -4
- package/admin/src/content-manager/pages/EditView/Header/utils/connect.js +1 -1
- package/admin/src/content-manager/pages/EditView/Header/utils/getDraftRelations.js +3 -3
- package/admin/src/content-manager/pages/EditView/Informations/utils/getUnits.js +1 -1
- package/admin/src/content-manager/pages/EditView/index.js +7 -10
- package/admin/src/content-manager/pages/EditView/utils/createAttributesLayout.js +2 -2
- package/admin/src/content-manager/pages/EditView/utils/getFieldsActionMatchingPermissions.js +1 -1
- package/admin/src/content-manager/pages/EditViewLayoutManager/Permissions.js +1 -1
- package/admin/src/content-manager/pages/EditViewLayoutManager/reducer.js +1 -1
- package/admin/src/content-manager/pages/EditViewLayoutManager/selectors.js +1 -1
- package/admin/src/content-manager/pages/ListSettingsView/components/DraggableCard.js +6 -6
- package/admin/src/content-manager/pages/ListSettingsView/components/EditFieldForm.js +4 -3
- package/admin/src/content-manager/pages/ListSettingsView/components/Settings.js +9 -9
- package/admin/src/content-manager/pages/ListSettingsView/components/SortDisplayedFields.js +2 -2
- package/admin/src/content-manager/pages/ListSettingsView/index.js +9 -9
- package/admin/src/content-manager/pages/ListSettingsView/reducer.js +1 -1
- package/admin/src/content-manager/pages/ListSettingsView/utils/ellipsisCardTitle.js +1 -1
- package/admin/src/content-manager/pages/ListView/FieldPicker/index.js +8 -7
- package/admin/src/content-manager/pages/ListView/FieldPicker/utils/getAllAllowedHeader.js +1 -1
- package/admin/src/content-manager/pages/ListView/actions.js +1 -1
- package/admin/src/content-manager/pages/ListView/index.js +3 -3
- package/admin/src/content-manager/pages/ListView/reducer.js +2 -2
- package/admin/src/content-manager/pages/ListView/selectors.js +3 -3
- package/admin/src/content-manager/pages/ListView/utils/createPluginsFilter.js +1 -1
- package/admin/src/content-manager/pages/ListViewLayoutManager/Permissions.js +2 -2
- package/admin/src/content-manager/sharedReducers/crudReducer/actions.js +3 -3
- package/admin/src/content-manager/sharedReducers/crudReducer/reducer.js +1 -1
- package/admin/src/content-manager/sharedReducers/crudReducer/selectors.js +1 -1
- package/admin/src/content-manager/utils/checkIfAttributeIsDisplayable.js +1 -1
- package/admin/src/content-manager/utils/formatLayoutToApi.js +2 -2
- package/admin/src/content-manager/utils/generatePermissionsObject.js +3 -2
- package/admin/src/content-manager/utils/getFieldName.js +2 -2
- package/admin/src/content-manager/utils/getMaxTempKey.js +2 -2
- package/admin/src/content-manager/utils/getRequestUrl.js +1 -1
- package/admin/src/content-manager/utils/getTrad.js +1 -1
- package/admin/src/content-manager/utils/mergeMetasWithSchema.js +2 -2
- package/admin/src/content-manager/utils/removeKeyInObject.js +1 -1
- package/admin/src/content-manager/utils/removePasswordFieldsFromData.js +2 -2
- package/admin/src/core/apis/Plugin.js +1 -1
- package/admin/src/core/store/configureStore.js +1 -1
- package/admin/src/core/store/createReducer.js +1 -1
- package/admin/src/core/utils/axiosInstance.js +4 -4
- package/admin/src/core/utils/createHook.js +2 -2
- package/admin/src/hooks/useFetchEnabledPlugins/index.js +3 -3
- package/admin/src/hooks/useFetchMarketplacePlugins/index.js +3 -3
- package/admin/src/hooks/useFetchMarketplacePlugins/utils/api.js +1 -1
- package/admin/src/hooks/useFetchMarketplaceProviders/index.js +3 -3
- package/admin/src/hooks/useFetchPermissionsLayout/index.js +1 -1
- package/admin/src/hooks/useFetchPermissionsLayout/reducer.js +1 -1
- package/admin/src/hooks/useFetchRole/index.js +4 -4
- package/admin/src/hooks/useFetchRole/reducer.js +1 -1
- package/admin/src/hooks/useMenu/reducer.js +1 -1
- package/admin/src/hooks/useMenu/utils/getGeneralLinks.js +3 -1
- package/admin/src/hooks/useModels/index.js +1 -1
- package/admin/src/hooks/useModels/reducer.js +3 -3
- package/admin/src/hooks/useRolesList/reducer.js +1 -1
- package/admin/src/hooks/useSettingsForm/index.js +2 -2
- package/admin/src/hooks/useSettingsForm/reducer.js +1 -1
- package/admin/src/hooks/useSettingsMenu/index.js +2 -2
- package/admin/src/hooks/useSettingsMenu/init.js +1 -1
- package/admin/src/hooks/useSettingsMenu/reducer.js +3 -3
- package/admin/src/hooks/useSettingsMenu/utils/formatLinks.js +3 -3
- package/admin/src/hooks/useSettingsMenu/utils/sortLinks.js +1 -1
- package/admin/src/index.js +1 -1
- package/admin/src/layouts/UnauthenticatedLayout/LocaleToggle/index.js +1 -1
- package/admin/src/pages/Admin/Onboarding/index.js +2 -2
- package/admin/src/pages/Admin/index.js +2 -2
- package/admin/src/pages/App/index.js +13 -5
- package/admin/src/pages/App/reducer.js +1 -1
- package/admin/src/pages/AuthPage/components/ForgotPassword/index.js +1 -1
- package/admin/src/pages/AuthPage/components/Login/BaseLogin.js +4 -4
- package/admin/src/pages/AuthPage/components/Login/index.js +2 -2
- package/admin/src/pages/AuthPage/components/Register/index.js +6 -6
- package/admin/src/pages/AuthPage/components/ResetPassword/index.js +5 -5
- package/admin/src/pages/AuthPage/init.js +1 -1
- package/admin/src/pages/AuthPage/reducer.js +1 -1
- package/admin/src/pages/AuthPage/utils/forms.js +2 -8
- package/admin/src/pages/HomePage/ContentBlocks.js +1 -1
- package/admin/src/pages/HomePage/SocialLinks.js +1 -1
- package/admin/src/pages/HomePage/index.js +3 -3
- package/admin/src/pages/InstalledPluginsPage/Plugins.js +1 -1
- package/admin/src/pages/MarketplacePage/components/NpmPackagesGrid/index.js +2 -2
- package/admin/src/pages/MarketplacePage/index.js +6 -10
- package/admin/src/pages/ProfilePage/index.js +20 -23
- package/admin/src/pages/ProfilePage/utils/api.js +1 -1
- package/admin/src/pages/SettingsPage/components/SettingsNav/index.js +4 -4
- package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/index.js +2 -2
- package/admin/src/pages/SettingsPage/pages/ApiTokens/ListView/DynamicTable/index.js +8 -6
- package/admin/src/pages/SettingsPage/pages/ApiTokens/ListView/index.js +25 -13
- package/admin/src/pages/SettingsPage/pages/ApiTokens/ListView/utils/tableHeaders.js +16 -4
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/Form/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/Form/reducer.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/LogoInput/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/LogoInput/reducer.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/LogoModalStepper/FromComputerForm.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/LogoModalStepper/FromUrlForm.js +2 -2
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/LogoModalStepper/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/LogoModalStepper/reducer.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/index.js +4 -4
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/utils/api.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/utils/getFormData.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/utils/parseFileMetadatas.js +4 -4
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/utils/prefixAllUrls.js +1 -1
- package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/utils/urlToFile.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ConditionsModal/ActionRow/index.js +4 -4
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ConditionsModal/index.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/Collapse/index.js +5 -8
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/Collapse/utils/generateCheckboxesActions.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/CollapsePropertyMatrix/ActionRow/index.js +3 -3
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/CollapsePropertyMatrix/ActionRow/utils/getRowLabelCheckboxeState.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/CollapsePropertyMatrix/Header/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/CollapsePropertyMatrix/SubActionRow/index.js +8 -12
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/CollapsePropertyMatrix/utils/generateHeadersFromActions.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/utils/activeStyle.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/utils/getAvailableActions.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapses/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Curve/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/GlobalActions/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/GlobalActions/utils/findDisplayedActions.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/GlobalActions/utils/getRowLabelCheckboxesState.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/index.js +9 -8
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/reducer.js +4 -4
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/utils/createDefaultCTFormFromLayout.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/utils/findMatchingPermissions.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/utils/formatContentTypesPermissionToAPI.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/utils/formatLayoutForSettingsAndPlugins.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/utils/formatPermissionsToAPI.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/utils/formatSettingsPermissionsToAPI.js +4 -4
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/Permissions/utils/updateConditionsToFalse.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/PluginsAndSettings/SubCategory/index.js +5 -8
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/PluginsAndSettings/SubCategory/utils/formatActions.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/PluginsAndSettings/SubCategory/utils/getConditionsButtonState.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/PluginsAndSettings/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/RoleForm/index.js +67 -69
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/RowLabelWithCheckbox/index.js +4 -3
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/utils/createArrayOfValues.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/utils/getCheckboxState.js +3 -3
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/utils/removeConditionKeyFromData.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Roles/EditPage/index.js +58 -60
- package/admin/src/pages/SettingsPage/pages/Roles/ListPage/index.js +6 -10
- package/admin/src/pages/SettingsPage/pages/Users/EditPage/index.js +3 -3
- package/admin/src/pages/SettingsPage/pages/Users/EditPage/utils/api.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Users/ListPage/DynamicTable/TableRows/index.js +4 -4
- package/admin/src/pages/SettingsPage/pages/Users/ListPage/Filters/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Users/ListPage/ModalForm/index.js +8 -8
- package/admin/src/pages/SettingsPage/pages/Users/ListPage/ModalForm/utils/schema.js +2 -8
- package/admin/src/pages/SettingsPage/pages/Users/ListPage/index.js +17 -11
- package/admin/src/pages/SettingsPage/pages/Users/ListPage/utils/api.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Users/ListPage/utils/tableHeaders.js +46 -14
- package/admin/src/pages/SettingsPage/pages/Users/components/SelectRoles/index.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Users/utils/validations/users/profile.js +1 -5
- package/admin/src/pages/SettingsPage/pages/Users/utils/validations/users/roles.js +1 -4
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/components/EventInput/EventRow.js +5 -5
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/components/EventInput/index.js +4 -4
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/components/EventInput/utils/formatValue.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/components/HeadersInput/Combobox.js +4 -4
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/components/TriggerContainer/index.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/components/utils/fieldsRegex.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/components/utils/schema.js +1 -1
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/index.js +9 -9
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/reducer.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Webhooks/EditView/utils/formatData.js +2 -2
- package/admin/src/pages/SettingsPage/pages/Webhooks/ListView/index.js +6 -6
- package/admin/src/pages/SettingsPage/pages/Webhooks/ListView/reducer.js +4 -4
- package/admin/src/pages/SettingsPage/utils/createSectionsRoutes.js +3 -3
- package/admin/src/pages/SettingsPage/utils/defaultRoutes.js +12 -12
- package/admin/src/pages/SettingsPage/utils/getSectionsToDisplay.js +2 -2
- package/admin/src/pages/UseCasePage/index.js +2 -2
- package/admin/src/shared/components/InjectionZone/index.js +1 -1
- package/admin/src/shared/hooks/useInjectionZone/index.js +1 -1
- package/admin/src/translations/ca.json +4 -4
- package/admin/src/translations/de.json +4 -4
- package/admin/src/translations/dk.json +4 -4
- package/admin/src/translations/en.json +16 -15
- package/admin/src/translations/es.json +163 -6
- package/admin/src/translations/fr.json +4 -4
- package/admin/src/translations/gu.json +4 -4
- package/admin/src/translations/he.json +3 -3
- package/admin/src/translations/hi.json +4 -4
- package/admin/src/translations/hu.json +4 -4
- package/admin/src/translations/id.json +4 -4
- package/admin/src/translations/it.json +4 -4
- package/admin/src/translations/ja.json +4 -4
- package/admin/src/translations/ko.json +4 -4
- package/admin/src/translations/ml.json +4 -4
- package/admin/src/translations/nl.json +4 -4
- package/admin/src/translations/no.json +3 -3
- package/admin/src/translations/pl.json +4 -4
- package/admin/src/translations/pt-BR.json +177 -24
- package/admin/src/translations/ru.json +4 -4
- package/admin/src/translations/sa.json +4 -4
- package/admin/src/translations/sk.json +4 -4
- package/admin/src/translations/sv.json +665 -11
- package/admin/src/translations/th.json +3 -3
- package/admin/src/translations/zh-Hans.json +12 -15
- package/admin/src/translations/zh.json +4 -4
- package/admin/src/utils/getAttributesToDisplay.js +1 -1
- package/admin/src/utils/getExistingActions.js +2 -2
- package/admin/src/utils/getFullName.js +1 -1
- package/admin/src/utils/getRequestUrl.js +1 -1
- package/admin/src/utils/makeUniqueRoutes.js +2 -2
- package/admin/src/utils/sortLinks.js +1 -1
- package/build/{1669.341e10d8.chunk.js → 1669.4ce92b2f.chunk.js} +1 -1
- package/build/{1856.6a94980b.chunk.js → 1856.d3da2fcd.chunk.js} +18 -17
- package/build/{2077.5456ccd1.chunk.js → 2077.b25a0b57.chunk.js} +6 -5
- package/build/2912.da8a70aa.chunk.js +258 -0
- package/build/{4715.a6e62860.chunk.js → 4715.3787be19.chunk.js} +20 -19
- package/build/4982.a4e36c9a.chunk.js +314 -0
- package/build/611.aa894d27.chunk.js +158 -0
- package/build/6925.f5c8b6fc.chunk.js +761 -0
- package/build/7841.922b96eb.chunk.js +258 -0
- package/build/7866.22e3c9f8.chunk.js +504 -0
- package/build/8380.ab3939f3.chunk.js +284 -0
- package/build/8469.41c8d25f.chunk.js +1 -0
- package/build/8549.0e30f86d.chunk.js +158 -0
- package/build/8773.4e36117f.chunk.js +325 -0
- package/build/{8655.9073e17e.chunk.js → 9166.280c7521.chunk.js} +62 -60
- package/build/9420.ee1ccff7.chunk.js +504 -0
- package/build/Admin-authenticatedApp.a8659dc6.chunk.js +80 -0
- package/build/Admin_InternalErrorPage.12e24216.chunk.js +1 -0
- package/build/{Admin_marketplace.8efd3fd0.chunk.js → Admin_marketplace.2d181ad7.chunk.js} +1 -1
- package/build/Admin_pluginsPage.4d59785a.chunk.js +1 -0
- package/build/Admin_profilePage.8617313a.chunk.js +15 -0
- package/build/Admin_settingsPage.e58753c8.chunk.js +178 -0
- package/build/admin-app.05edc328.chunk.js +112 -0
- package/build/admin-edit-roles-page.554ba3fa.chunk.js +1 -0
- package/build/admin-edit-users.5bebf473.chunk.js +10 -0
- package/build/admin-users.1d0aa7a0.chunk.js +11 -0
- package/build/{api-tokens-create-page.442e3be0.chunk.js → api-tokens-create-page.b4a9987d.chunk.js} +1 -1
- package/build/{api-tokens-edit-page.5f34eec7.chunk.js → api-tokens-edit-page.6f5b4e26.chunk.js} +1 -1
- package/build/api-tokens-list-page.06938769.chunk.js +15 -0
- package/build/ca-json.d16c1d28.chunk.js +1 -0
- package/build/content-manager.62390771.chunk.js +1178 -0
- package/build/content-type-builder-list-view.76a69473.chunk.js +194 -0
- package/build/content-type-builder-translation-pt-BR-json.d6c7fcc1.chunk.js +1 -0
- package/build/content-type-builder.42cecba9.chunk.js +142 -0
- package/build/de-json.a9b514dc.chunk.js +1 -0
- package/build/dk-json.09e8d145.chunk.js +1 -0
- package/build/en-json.1bf20384.chunk.js +1 -0
- package/build/es-json.bb1fc425.chunk.js +1 -0
- package/build/fr-json.a3cf2e0b.chunk.js +1 -0
- package/build/gu-json.d8311297.chunk.js +1 -0
- package/build/he-json.3b825d80.chunk.js +1 -0
- package/build/hi-json.0edb8d29.chunk.js +1 -0
- package/build/hu-json.7855529a.chunk.js +1 -0
- package/build/i18n-settings-page.bf1304b0.chunk.js +101 -0
- package/build/i18n-translation-fr-json.b401aa34.chunk.js +1 -0
- package/build/id-json.df9618f2.chunk.js +1 -0
- package/build/index.html +1 -1
- package/build/it-json.a21bf078.chunk.js +1 -0
- package/build/ja-json.7b0d9067.chunk.js +1 -0
- package/build/ko-json.983c1f8f.chunk.js +1 -0
- package/build/main.f220d4d1.js +9321 -0
- package/build/ml-json.8dd021c8.chunk.js +1 -0
- package/build/nl-json.29d2eb37.chunk.js +1 -0
- package/build/no-json.40386397.chunk.js +1 -0
- package/build/pl-json.1f04f00c.chunk.js +1 -0
- package/build/pt-BR-json.b4bc8efe.chunk.js +1 -0
- package/build/ru-json.7ab40ccf.chunk.js +1 -0
- package/build/{runtime~main.1601a98c.js → runtime~main.a3bde347.js} +2 -2
- package/build/sa-json.c5a9f4ea.chunk.js +1 -0
- package/build/sk-json.e4c24c4e.chunk.js +1 -0
- package/build/sv-json.c3f471ae.chunk.js +1 -0
- package/build/th-json.a59ffb32.chunk.js +1 -0
- package/build/{upload-settings.4bad0bdd.chunk.js → upload-settings.5dfe0fe2.chunk.js} +1 -1
- package/build/upload-translation-ca-json.00dc1f33.chunk.js +1 -0
- package/build/upload-translation-de-json.00cbbc08.chunk.js +1 -0
- package/build/upload-translation-dk-json.c787a6be.chunk.js +1 -0
- package/build/upload-translation-en-json.004a86c1.chunk.js +1 -0
- package/build/upload-translation-es-json.0f90db48.chunk.js +1 -0
- package/build/upload-translation-ko-json.392002fb.chunk.js +1 -0
- package/build/upload-translation-pl-json.136eedb6.chunk.js +1 -0
- package/build/{upload-translation-th-json.64dd70ce.chunk.js → upload-translation-th-json.9e1fda51.chunk.js} +1 -1
- package/build/upload.7084cea6.chunk.js +7 -0
- package/build/{users-advanced-settings-page.f38654fc.chunk.js → users-advanced-settings-page.f11c8af4.chunk.js} +1 -1
- package/build/users-email-settings-page.73c41236.chunk.js +1 -0
- package/build/{users-providers-settings-page.a0b0fe39.chunk.js → users-providers-settings-page.f8e78537.chunk.js} +1 -1
- package/build/users-roles-settings-page.cafb4fe5.chunk.js +30 -0
- package/build/{webhook-edit-page.3417d93c.chunk.js → webhook-edit-page.9aba79b2.chunk.js} +3 -3
- package/build/{webhook-list-page.2ab4bbf0.chunk.js → webhook-list-page.912becb8.chunk.js} +7 -6
- package/build/zh-Hans-json.77a42bc5.chunk.js +1 -0
- package/build/zh-json.451a0271.chunk.js +1 -0
- package/ee/admin/hooks/useAuthProviders/reducer.js +1 -1
- package/ee/admin/pages/AuthPage/components/Login/index.js +2 -2
- package/ee/admin/pages/AuthPage/components/Providers/SSOProviders.js +3 -3
- package/ee/admin/pages/SettingsPage/SingleSignOn/index.js +3 -3
- package/ee/admin/pages/SettingsPage/pages/Roles/CreatePage/index.js +11 -9
- package/ee/admin/pages/SettingsPage/pages/Roles/ListPage/index.js +8 -8
- package/ee/admin/pages/SettingsPage/pages/Roles/ListPage/reducer.js +1 -1
- package/ee/admin/pages/SettingsPage/utils/customRoutes.js +1 -1
- package/ee/server/controllers/authentication/middlewares.js +1 -1
- package/ee/server/controllers/authentication/utils.js +1 -1
- package/ee/server/controllers/role.js +4 -4
- package/ee/server/services/passport/provider-registry.js +1 -1
- package/ee/server/services/passport/sso.js +1 -1
- package/ee/server/services/passport.js +1 -1
- package/ee/server/services/role.js +1 -1
- package/ee/server/validation/authentication.js +1 -1
- package/ee/server/validation/role.js +3 -6
- package/ee/server/validation/user.js +1 -1
- package/env.js +2 -2
- package/index.js +2 -2
- package/jest.config.front.js +3 -1
- package/package.json +30 -21
- package/scripts/build.js +2 -2
- package/scripts/create-dev-plugins-file.js +5 -7
- package/scripts/create-plugins-file.js +2 -2
- package/server/config/admin-conditions.js +3 -3
- package/server/controllers/admin.js +1 -1
- package/server/controllers/authentication.js +1 -1
- package/server/controllers/formatters/format-actions-by-sections.js +8 -5
- package/server/controllers/role.js +1 -1
- package/server/controllers/user.js +1 -1
- package/server/controllers/webhooks.js +6 -16
- package/server/domain/action/index.js +3 -3
- package/server/domain/action/provider.js +2 -2
- package/server/domain/condition/index.js +2 -2
- package/server/domain/condition/provider.js +1 -1
- package/server/domain/permission/index.js +3 -3
- package/server/domain/user.js +2 -2
- package/server/policies/hasPermissions.js +5 -5
- package/server/policies/isAuthenticatedAdmin.js +1 -1
- package/server/routes/serve-admin-panel.js +1 -1
- package/server/routes/webhooks.js +4 -1
- package/server/services/action.js +1 -1
- package/server/services/api-token.js +5 -5
- package/server/services/auth.js +2 -2
- package/server/services/condition.js +1 -1
- package/server/services/content-type.js +5 -3
- package/server/services/passport/local-strategy.js +2 -2
- package/server/services/passport.js +2 -4
- package/server/services/permission/engine-hooks.js +1 -1
- package/server/services/permission/engine.js +9 -9
- package/server/services/permission/permissions-manager/query-builers.js +5 -5
- package/server/services/permission/permissions-manager/sanitize.js +6 -10
- package/server/services/permission/queries.js +12 -13
- package/server/services/permission/sections-builder/handlers.js +21 -19
- package/server/services/permission/sections-builder/section.js +2 -2
- package/server/services/permission/sections-builder/utils.js +5 -5
- package/server/services/project-settings.js +10 -13
- package/server/services/role.js +15 -13
- package/server/services/token.js +2 -2
- package/server/services/user.js +11 -11
- package/server/strategies/admin.js +1 -1
- package/server/strategies/api-token.js +3 -3
- package/server/utils/index.js +1 -1
- package/server/validation/action-provider.js +6 -12
- package/server/validation/api-tokens.js +4 -16
- package/server/validation/authentication/renew-token.js +1 -5
- package/server/validation/common-functions/check-fields-are-correctly-nested.js +5 -3
- package/server/validation/common-functions/check-fields-dont-have-duplicates.js +3 -2
- package/server/validation/common-validators.js +74 -71
- package/server/validation/permission.js +13 -13
- package/server/validation/policies/hasPermissions.js +2 -6
- package/server/validation/user.js +1 -5
- package/utils/create-cache-dir.js +3 -3
- package/utils/get-custom-app-config-file.js +3 -3
- package/utils/get-plugins-path.js +3 -2
- package/utils/should-build-admin.js +4 -4
- package/webpack.config.js +2 -7
- package/admin/src/content-manager/components/DynamicTable/CellContent/utils/getNumberOfDecimals.js +0 -8
- package/build/109.1464fd6e.chunk.js +0 -2
- package/build/20.9e5a98b6.chunk.js +0 -308
- package/build/3332.1e443103.chunk.js +0 -102
- package/build/413.d5986568.chunk.js +0 -284
- package/build/5520.3c6bf86a.chunk.js +0 -503
- package/build/8469.3af1823d.chunk.js +0 -1
- package/build/8773.83d4a28b.chunk.js +0 -327
- package/build/9420.ba035f29.chunk.js +0 -508
- package/build/9799.ce46400f.chunk.js +0 -760
- package/build/Admin-authenticatedApp.2cb98f7a.chunk.js +0 -80
- package/build/Admin_InternalErrorPage.25c53284.chunk.js +0 -1
- package/build/Admin_pluginsPage.0992c2b5.chunk.js +0 -1
- package/build/Admin_profilePage.35ce8e94.chunk.js +0 -15
- package/build/Admin_settingsPage.5fc517d7.chunk.js +0 -178
- package/build/admin-app.1bd5f67e.chunk.js +0 -112
- package/build/admin-edit-roles-page.358d98c1.chunk.js +0 -1
- package/build/admin-edit-users.714863af.chunk.js +0 -10
- package/build/admin-users.2bd6fb37.chunk.js +0 -11
- package/build/api-tokens-list-page.5ea3f6ce.chunk.js +0 -15
- package/build/ca-json.0097e443.chunk.js +0 -1
- package/build/content-manager.57c1cfe3.chunk.js +0 -1178
- package/build/content-type-builder-list-view.b12687b2.chunk.js +0 -194
- package/build/content-type-builder-translation-pt-BR-json.5739a2aa.chunk.js +0 -1
- package/build/content-type-builder.b2cbf2e9.chunk.js +0 -142
- package/build/de-json.0b92acd2.chunk.js +0 -1
- package/build/dk-json.9f1bc016.chunk.js +0 -1
- package/build/en-json.6d70e9ff.chunk.js +0 -1
- package/build/es-json.2a5a9fc1.chunk.js +0 -1
- package/build/fr-json.84064a0b.chunk.js +0 -1
- package/build/gu-json.dafa6f0d.chunk.js +0 -1
- package/build/he-json.d40da459.chunk.js +0 -1
- package/build/hi-json.b4ae16d1.chunk.js +0 -1
- package/build/hu-json.c81ce352.chunk.js +0 -1
- package/build/i18n-settings-page.9d426e96.chunk.js +0 -101
- package/build/i18n-translation-fr-json.0839d68d.chunk.js +0 -1
- package/build/id-json.fad45d17.chunk.js +0 -1
- package/build/it-json.12df4cdf.chunk.js +0 -1
- package/build/ja-json.850237e9.chunk.js +0 -1
- package/build/ko-json.2f3d256e.chunk.js +0 -1
- package/build/main.407d75cc.js +0 -8675
- package/build/ml-json.dc946c7f.chunk.js +0 -1
- package/build/nl-json.465b173f.chunk.js +0 -1
- package/build/no-json.e8749dd4.chunk.js +0 -1
- package/build/pl-json.4d11f53d.chunk.js +0 -1
- package/build/pt-BR-json.6301d49b.chunk.js +0 -1
- package/build/ru-json.28147733.chunk.js +0 -1
- package/build/sa-json.be504091.chunk.js +0 -1
- package/build/sk-json.5b33afc2.chunk.js +0 -1
- package/build/sv-json.cdcac02d.chunk.js +0 -1
- package/build/th-json.3aadaec6.chunk.js +0 -1
- package/build/upload-translation-ca-json.79159984.chunk.js +0 -1
- package/build/upload-translation-de-json.745613c0.chunk.js +0 -1
- package/build/upload-translation-dk-json.cb25dcf0.chunk.js +0 -1
- package/build/upload-translation-en-json.bc79c867.chunk.js +0 -1
- package/build/upload-translation-es-json.1f344b53.chunk.js +0 -1
- package/build/upload-translation-ko-json.9a2c21cb.chunk.js +0 -1
- package/build/upload-translation-pl-json.c1f86b50.chunk.js +0 -1
- package/build/upload.b2cb62bd.chunk.js +0 -7
- package/build/users-email-settings-page.824a3cdb.chunk.js +0 -101
- package/build/users-roles-settings-page.3db986a4.chunk.js +0 -30
- package/build/zh-Hans-json.eac1d90a.chunk.js +0 -1
- package/build/zh-json.96bf6019.chunk.js +0 -1
|
@@ -8,11 +8,11 @@ const DEFAULT_PROJECT_SETTINGS = {
|
|
|
8
8
|
menuLogo: null,
|
|
9
9
|
};
|
|
10
10
|
|
|
11
|
-
const parseFilesData = async files => {
|
|
11
|
+
const parseFilesData = async (files) => {
|
|
12
12
|
const formatedFilesData = {};
|
|
13
13
|
|
|
14
14
|
await Promise.all(
|
|
15
|
-
PROJECT_SETTINGS_FILE_INPUTS.map(async inputName => {
|
|
15
|
+
PROJECT_SETTINGS_FILE_INPUTS.map(async (inputName) => {
|
|
16
16
|
const file = files[inputName];
|
|
17
17
|
|
|
18
18
|
// Skip empty file inputs
|
|
@@ -23,7 +23,7 @@ const parseFilesData = async files => {
|
|
|
23
23
|
const getStream = () => fs.createReadStream(file.path);
|
|
24
24
|
|
|
25
25
|
// Add formated data for the upload provider
|
|
26
|
-
formatedFilesData[inputName] = strapi
|
|
26
|
+
formatedFilesData[inputName] = await strapi
|
|
27
27
|
.plugin('upload')
|
|
28
28
|
.service('upload')
|
|
29
29
|
.formatFileInfo({
|
|
@@ -35,10 +35,7 @@ const parseFilesData = async files => {
|
|
|
35
35
|
// Add image dimensions
|
|
36
36
|
Object.assign(
|
|
37
37
|
formatedFilesData[inputName],
|
|
38
|
-
await strapi
|
|
39
|
-
.plugin('upload')
|
|
40
|
-
.service('image-manipulation')
|
|
41
|
-
.getDimensions({ getStream })
|
|
38
|
+
await strapi.plugin('upload').service('image-manipulation').getDimensions({ getStream })
|
|
42
39
|
);
|
|
43
40
|
|
|
44
41
|
// Add file path, and stream
|
|
@@ -61,7 +58,7 @@ const getProjectSettings = async () => {
|
|
|
61
58
|
};
|
|
62
59
|
|
|
63
60
|
// Filter file input fields
|
|
64
|
-
PROJECT_SETTINGS_FILE_INPUTS.forEach(inputName => {
|
|
61
|
+
PROJECT_SETTINGS_FILE_INPUTS.forEach((inputName) => {
|
|
65
62
|
if (!projectSettings[inputName]) {
|
|
66
63
|
return;
|
|
67
64
|
}
|
|
@@ -83,14 +80,14 @@ const uploadFiles = async (files = {}) => {
|
|
|
83
80
|
// Call the provider upload function for each file
|
|
84
81
|
return Promise.all(
|
|
85
82
|
Object.values(files)
|
|
86
|
-
.filter(file => file.stream instanceof fs.ReadStream)
|
|
87
|
-
.map(file => strapi.plugin('upload').provider.uploadStream(file))
|
|
83
|
+
.filter((file) => file.stream instanceof fs.ReadStream)
|
|
84
|
+
.map((file) => strapi.plugin('upload').provider.uploadStream(file))
|
|
88
85
|
);
|
|
89
86
|
};
|
|
90
87
|
|
|
91
88
|
const deleteOldFiles = async ({ previousSettings, newSettings }) => {
|
|
92
89
|
return Promise.all(
|
|
93
|
-
PROJECT_SETTINGS_FILE_INPUTS.map(async inputName => {
|
|
90
|
+
PROJECT_SETTINGS_FILE_INPUTS.map(async (inputName) => {
|
|
94
91
|
// Skip if the store doesn't contain project settings
|
|
95
92
|
if (!previousSettings) {
|
|
96
93
|
return;
|
|
@@ -121,14 +118,14 @@ const deleteOldFiles = async ({ previousSettings, newSettings }) => {
|
|
|
121
118
|
);
|
|
122
119
|
};
|
|
123
120
|
|
|
124
|
-
const updateProjectSettings = async newSettings => {
|
|
121
|
+
const updateProjectSettings = async (newSettings) => {
|
|
125
122
|
const store = strapi.store({ type: 'core', name: 'admin' });
|
|
126
123
|
const previousSettings = await store.get({ key: 'project-settings' });
|
|
127
124
|
const files = pick(newSettings, PROJECT_SETTINGS_FILE_INPUTS);
|
|
128
125
|
|
|
129
126
|
await uploadFiles(files);
|
|
130
127
|
|
|
131
|
-
PROJECT_SETTINGS_FILE_INPUTS.forEach(inputName => {
|
|
128
|
+
PROJECT_SETTINGS_FILE_INPUTS.forEach((inputName) => {
|
|
132
129
|
// If the user input exists but is not a formdata "file" remove it
|
|
133
130
|
if (newSettings[inputName] !== undefined && !(typeof newSettings[inputName] === 'object')) {
|
|
134
131
|
newSettings[inputName] = null;
|
package/server/services/role.js
CHANGED
|
@@ -27,7 +27,7 @@ const sanitizeRole = omit(['users', 'permissions']);
|
|
|
27
27
|
const COMPARABLE_FIELDS = ['conditions', 'properties', 'subject', 'action'];
|
|
28
28
|
const pickComparableFields = pick(COMPARABLE_FIELDS);
|
|
29
29
|
|
|
30
|
-
const jsonClean = data => JSON.parse(JSON.stringify(data));
|
|
30
|
+
const jsonClean = (data) => JSON.parse(JSON.stringify(data));
|
|
31
31
|
|
|
32
32
|
/**
|
|
33
33
|
* Compare two permissions
|
|
@@ -48,7 +48,7 @@ const arePermissionsEqual = (p1, p2) => {
|
|
|
48
48
|
* @param attributes A partial role object
|
|
49
49
|
* @returns {Promise<role>}
|
|
50
50
|
*/
|
|
51
|
-
const create = async attributes => {
|
|
51
|
+
const create = async (attributes) => {
|
|
52
52
|
const alreadyExists = await exists({ name: attributes.name });
|
|
53
53
|
|
|
54
54
|
if (alreadyExists) {
|
|
@@ -107,9 +107,9 @@ const find = (params = {}, populate) => {
|
|
|
107
107
|
* Find all roles in database
|
|
108
108
|
* @returns {Promise<array>}
|
|
109
109
|
*/
|
|
110
|
-
const findAllWithUsersCount = async populate => {
|
|
110
|
+
const findAllWithUsersCount = async (populate) => {
|
|
111
111
|
const roles = await strapi.query('admin::role').findMany({ populate });
|
|
112
|
-
for (
|
|
112
|
+
for (const role of roles) {
|
|
113
113
|
role.usersCount = await getUsersCount(role.id);
|
|
114
114
|
}
|
|
115
115
|
|
|
@@ -171,7 +171,7 @@ const checkRolesIdForDeletion = async (ids = []) => {
|
|
|
171
171
|
throw new ApplicationError('You cannot delete the super admin role');
|
|
172
172
|
}
|
|
173
173
|
|
|
174
|
-
for (
|
|
174
|
+
for (const roleId of ids) {
|
|
175
175
|
const usersCount = await getUsersCount(roleId);
|
|
176
176
|
if (usersCount !== 0) {
|
|
177
177
|
throw new ApplicationError('Some roles are still assigned to some users');
|
|
@@ -205,7 +205,7 @@ const deleteByIds = async (ids = []) => {
|
|
|
205
205
|
* @returns {Promise<number>}
|
|
206
206
|
* @param roleId
|
|
207
207
|
*/
|
|
208
|
-
const getUsersCount = async roleId => {
|
|
208
|
+
const getUsersCount = async (roleId) => {
|
|
209
209
|
return strapi.query('admin::user').count({ where: { roles: { id: roleId } } });
|
|
210
210
|
};
|
|
211
211
|
|
|
@@ -231,7 +231,7 @@ const createRolesIfNoneExist = async () => {
|
|
|
231
231
|
const { actionProvider } = getService('permission');
|
|
232
232
|
|
|
233
233
|
const allActions = actionProvider.values();
|
|
234
|
-
const contentTypesActions = allActions.filter(a => a.section === 'contentTypes');
|
|
234
|
+
const contentTypesActions = allActions.filter((a) => a.section === 'contentTypes');
|
|
235
235
|
|
|
236
236
|
// create 3 roles
|
|
237
237
|
const superAdminRole = await create({
|
|
@@ -264,7 +264,7 @@ const createRolesIfNoneExist = async () => {
|
|
|
264
264
|
|
|
265
265
|
const authorPermissions = editorPermissions
|
|
266
266
|
.filter(({ action }) => action !== ACTIONS.publish)
|
|
267
|
-
.map(permission =>
|
|
267
|
+
.map((permission) =>
|
|
268
268
|
permissionDomain.create({ ...permission, conditions: ['admin::is-creator'] })
|
|
269
269
|
);
|
|
270
270
|
|
|
@@ -368,7 +368,7 @@ const addPermissions = async (roleId, permissions) => {
|
|
|
368
368
|
return createMany(permissionsWithRole);
|
|
369
369
|
};
|
|
370
370
|
|
|
371
|
-
const isContentTypeAction = action => action.section === CONTENT_TYPE_SECTION;
|
|
371
|
+
const isContentTypeAction = (action) => action.section === CONTENT_TYPE_SECTION;
|
|
372
372
|
|
|
373
373
|
/**
|
|
374
374
|
* Reset super admin permissions (giving it all permissions)
|
|
@@ -385,8 +385,8 @@ const resetSuperAdminPermissions = async () => {
|
|
|
385
385
|
|
|
386
386
|
const allActions = permissionService.actionProvider.values();
|
|
387
387
|
|
|
388
|
-
const contentTypesActions = allActions.filter(action => isContentTypeAction(action));
|
|
389
|
-
const otherActions = allActions.filter(action => !isContentTypeAction(action));
|
|
388
|
+
const contentTypesActions = allActions.filter((action) => isContentTypeAction(action));
|
|
389
|
+
const otherActions = allActions.filter((action) => !isContentTypeAction(action));
|
|
390
390
|
|
|
391
391
|
// First, get the content-types permissions
|
|
392
392
|
const permissions = contentTypeService.getPermissionsWithNestedFields(contentTypesActions);
|
|
@@ -396,7 +396,9 @@ const resetSuperAdminPermissions = async () => {
|
|
|
396
396
|
const { actionId, subjects } = action;
|
|
397
397
|
|
|
398
398
|
if (isArray(subjects)) {
|
|
399
|
-
acc.push(
|
|
399
|
+
acc.push(
|
|
400
|
+
...subjects.map((subject) => permissionDomain.create({ action: actionId, subject }))
|
|
401
|
+
);
|
|
400
402
|
} else {
|
|
401
403
|
acc.push(permissionDomain.create({ action: actionId }));
|
|
402
404
|
}
|
|
@@ -416,7 +418,7 @@ const resetSuperAdminPermissions = async () => {
|
|
|
416
418
|
* @param {object} user
|
|
417
419
|
* @return {boolean}
|
|
418
420
|
*/
|
|
419
|
-
const hasSuperAdminRole = user => {
|
|
421
|
+
const hasSuperAdminRole = (user) => {
|
|
420
422
|
const roles = _.get(user, 'roles', []);
|
|
421
423
|
|
|
422
424
|
return roles.map(prop('code')).includes(SUPER_ADMIN_CODE);
|
package/server/services/token.js
CHANGED
|
@@ -27,7 +27,7 @@ const createToken = () => {
|
|
|
27
27
|
* Creates a JWT token for an administration user
|
|
28
28
|
* @param {object} user - admin user
|
|
29
29
|
*/
|
|
30
|
-
const createJwtToken = user => {
|
|
30
|
+
const createJwtToken = (user) => {
|
|
31
31
|
const { options, secret } = getTokenOptions();
|
|
32
32
|
|
|
33
33
|
return jwt.sign({ id: user.id }, secret, options);
|
|
@@ -38,7 +38,7 @@ const createJwtToken = user => {
|
|
|
38
38
|
* @param {string} token - a token to decode
|
|
39
39
|
* @return {Object} decodeInfo - the decoded info
|
|
40
40
|
*/
|
|
41
|
-
const decodeJwtToken = token => {
|
|
41
|
+
const decodeJwtToken = (token) => {
|
|
42
42
|
const { secret } = getTokenOptions();
|
|
43
43
|
|
|
44
44
|
try {
|
package/server/services/user.js
CHANGED
|
@@ -9,13 +9,13 @@ const { password: passwordValidator } = require('../validation/common-validators
|
|
|
9
9
|
const { getService } = require('../utils');
|
|
10
10
|
const { SUPER_ADMIN_CODE } = require('./constants');
|
|
11
11
|
|
|
12
|
-
const sanitizeUserRoles = role => _.pick(role, ['id', 'name', 'description', 'code']);
|
|
12
|
+
const sanitizeUserRoles = (role) => _.pick(role, ['id', 'name', 'description', 'code']);
|
|
13
13
|
|
|
14
14
|
/**
|
|
15
15
|
* Remove private user fields
|
|
16
16
|
* @param {Object} user - user to sanitize
|
|
17
17
|
*/
|
|
18
|
-
const sanitizeUser = user => {
|
|
18
|
+
const sanitizeUser = (user) => {
|
|
19
19
|
return {
|
|
20
20
|
..._.omit(user, ['password', 'resetPasswordToken', 'registrationToken', 'roles']),
|
|
21
21
|
roles: user.roles && user.roles.map(sanitizeUserRoles),
|
|
@@ -27,7 +27,7 @@ const sanitizeUser = user => {
|
|
|
27
27
|
* @param attributes A partial user object
|
|
28
28
|
* @returns {Promise<user>}
|
|
29
29
|
*/
|
|
30
|
-
const create = async attributes => {
|
|
30
|
+
const create = async (attributes) => {
|
|
31
31
|
const userInfo = {
|
|
32
32
|
registrationToken: getService('token').createToken(),
|
|
33
33
|
...attributes,
|
|
@@ -120,7 +120,7 @@ const resetPasswordByEmail = async (email, password) => {
|
|
|
120
120
|
* Check if a user is the last super admin
|
|
121
121
|
* @param {int|string} userId user's id to look for
|
|
122
122
|
*/
|
|
123
|
-
const isLastSuperAdminUser = async userId => {
|
|
123
|
+
const isLastSuperAdminUser = async (userId) => {
|
|
124
124
|
const user = await findOne(userId);
|
|
125
125
|
const superAdminRole = await getService('role').getSuperAdminWithUsersCount();
|
|
126
126
|
|
|
@@ -141,7 +141,7 @@ const exists = async (attributes = {}) => {
|
|
|
141
141
|
* @param {string} registrationToken - a user registration token
|
|
142
142
|
* @returns {Promise<registrationInfo>} - Returns user email, firstname and lastname
|
|
143
143
|
*/
|
|
144
|
-
const findRegistrationInfo = async registrationToken => {
|
|
144
|
+
const findRegistrationInfo = async (registrationToken) => {
|
|
145
145
|
const user = await strapi.query('admin::user').findOne({ where: { registrationToken } });
|
|
146
146
|
|
|
147
147
|
if (!user) {
|
|
@@ -206,7 +206,7 @@ const findPage = async (query = {}) => {
|
|
|
206
206
|
* @param id id of the user to delete
|
|
207
207
|
* @returns {Promise<user>}
|
|
208
208
|
*/
|
|
209
|
-
const deleteById = async id => {
|
|
209
|
+
const deleteById = async (id) => {
|
|
210
210
|
// Check at least one super admin remains
|
|
211
211
|
const userToDelete = await strapi.query('admin::user').findOne({
|
|
212
212
|
where: { id },
|
|
@@ -218,7 +218,7 @@ const deleteById = async id => {
|
|
|
218
218
|
}
|
|
219
219
|
|
|
220
220
|
if (userToDelete) {
|
|
221
|
-
if (userToDelete.roles.some(r => r.code === SUPER_ADMIN_CODE)) {
|
|
221
|
+
if (userToDelete.roles.some((r) => r.code === SUPER_ADMIN_CODE)) {
|
|
222
222
|
const superAdminRole = await getService('role').getSuperAdminWithUsersCount();
|
|
223
223
|
if (superAdminRole.usersCount === 1) {
|
|
224
224
|
throw new ValidationError('You must have at least one user with super admin role.');
|
|
@@ -233,7 +233,7 @@ const deleteById = async id => {
|
|
|
233
233
|
* @param ids ids of the users to delete
|
|
234
234
|
* @returns {Promise<user>}
|
|
235
235
|
*/
|
|
236
|
-
const deleteByIds = async ids => {
|
|
236
|
+
const deleteByIds = async (ids) => {
|
|
237
237
|
// Check at least one super admin remains
|
|
238
238
|
const superAdminRole = await getService('role').getSuperAdminWithUsersCount();
|
|
239
239
|
const nbOfSuperAdminToDelete = await strapi.query('admin::user').count({
|
|
@@ -285,7 +285,7 @@ const count = async (where = {}) => {
|
|
|
285
285
|
/** Assign some roles to several users
|
|
286
286
|
* @returns {undefined}
|
|
287
287
|
*/
|
|
288
|
-
const assignARoleToAll = async roleId => {
|
|
288
|
+
const assignARoleToAll = async (roleId) => {
|
|
289
289
|
const users = await strapi.query('admin::user').findMany({
|
|
290
290
|
select: ['id'],
|
|
291
291
|
where: {
|
|
@@ -294,7 +294,7 @@ const assignARoleToAll = async roleId => {
|
|
|
294
294
|
});
|
|
295
295
|
|
|
296
296
|
await Promise.all(
|
|
297
|
-
users.map(user => {
|
|
297
|
+
users.map((user) => {
|
|
298
298
|
return strapi.query('admin::user').update({
|
|
299
299
|
where: { id: user.id },
|
|
300
300
|
data: { roles: [roleId] },
|
|
@@ -320,7 +320,7 @@ const displayWarningIfUsersDontHaveRole = async () => {
|
|
|
320
320
|
const getLanguagesInUse = async () => {
|
|
321
321
|
const users = await strapi.query('admin::user').findMany({ select: ['preferedLanguage'] });
|
|
322
322
|
|
|
323
|
-
return users.map(user => user.preferedLanguage || 'en');
|
|
323
|
+
return users.map((user) => user.preferedLanguage || 'en');
|
|
324
324
|
};
|
|
325
325
|
|
|
326
326
|
module.exports = {
|
|
@@ -4,9 +4,9 @@ const { UnauthorizedError, ForbiddenError } = require('@strapi/utils').errors;
|
|
|
4
4
|
const constants = require('../services/constants');
|
|
5
5
|
const { getService } = require('../utils');
|
|
6
6
|
|
|
7
|
-
const isReadScope = scope => scope.endsWith('find') || scope.endsWith('findOne');
|
|
7
|
+
const isReadScope = (scope) => scope.endsWith('find') || scope.endsWith('findOne');
|
|
8
8
|
|
|
9
|
-
const extractToken = ctx => {
|
|
9
|
+
const extractToken = (ctx) => {
|
|
10
10
|
if (ctx.request && ctx.request.header && ctx.request.header.authorization) {
|
|
11
11
|
const parts = ctx.request.header.authorization.split(/\s+/);
|
|
12
12
|
|
|
@@ -21,7 +21,7 @@ const extractToken = ctx => {
|
|
|
21
21
|
};
|
|
22
22
|
|
|
23
23
|
/** @type {import('.').AuthenticateFunction} */
|
|
24
|
-
const authenticate = async ctx => {
|
|
24
|
+
const authenticate = async (ctx) => {
|
|
25
25
|
const apiTokenService = getService('api-token');
|
|
26
26
|
const token = extractToken(ctx);
|
|
27
27
|
|
package/server/utils/index.js
CHANGED
|
@@ -14,13 +14,10 @@ const registerProviderActionSchema = yup
|
|
|
14
14
|
.string()
|
|
15
15
|
.matches(
|
|
16
16
|
/^[a-z]([a-z|.|-]+)[a-z]$/,
|
|
17
|
-
v => `${v.path}: The id can only contain lowercase letters, dots and hyphens.`
|
|
17
|
+
(v) => `${v.path}: The id can only contain lowercase letters, dots and hyphens.`
|
|
18
18
|
)
|
|
19
19
|
.required(),
|
|
20
|
-
section: yup
|
|
21
|
-
.string()
|
|
22
|
-
.oneOf(['contentTypes', 'plugins', 'settings'])
|
|
23
|
-
.required(),
|
|
20
|
+
section: yup.string().oneOf(['contentTypes', 'plugins', 'settings']).required(),
|
|
24
21
|
pluginName: yup.mixed().when('section', {
|
|
25
22
|
is: 'plugins',
|
|
26
23
|
then: validators.isAPluginName.required(),
|
|
@@ -28,10 +25,7 @@ const registerProviderActionSchema = yup
|
|
|
28
25
|
}),
|
|
29
26
|
subjects: yup.mixed().when('section', {
|
|
30
27
|
is: 'contentTypes',
|
|
31
|
-
then: yup
|
|
32
|
-
.array()
|
|
33
|
-
.of(yup.string())
|
|
34
|
-
.required(),
|
|
28
|
+
then: yup.array().of(yup.string()).required(),
|
|
35
29
|
otherwise: yup
|
|
36
30
|
.mixed()
|
|
37
31
|
.oneOf([undefined], 'subjects should only be defined for the "contentTypes" section'),
|
|
@@ -45,18 +39,18 @@ const registerProviderActionSchema = yup
|
|
|
45
39
|
.test(
|
|
46
40
|
'settingsCategory',
|
|
47
41
|
'category should only be defined for the "settings" section',
|
|
48
|
-
cat => cat === undefined
|
|
42
|
+
(cat) => cat === undefined
|
|
49
43
|
),
|
|
50
44
|
}),
|
|
51
45
|
subCategory: yup.mixed().when('section', {
|
|
52
|
-
is: section => ['settings', 'plugins'].includes(section),
|
|
46
|
+
is: (section) => ['settings', 'plugins'].includes(section),
|
|
53
47
|
then: yup.string(),
|
|
54
48
|
otherwise: yup
|
|
55
49
|
.mixed()
|
|
56
50
|
.test(
|
|
57
51
|
'settingsSubCategory',
|
|
58
52
|
'subCategory should only be defined for "plugins" and "settings" sections',
|
|
59
|
-
subCat => {
|
|
53
|
+
(subCat) => {
|
|
60
54
|
return subCat === undefined;
|
|
61
55
|
}
|
|
62
56
|
),
|
|
@@ -6,30 +6,18 @@ const constants = require('../services/constants');
|
|
|
6
6
|
const apiTokenCreationSchema = yup
|
|
7
7
|
.object()
|
|
8
8
|
.shape({
|
|
9
|
-
name: yup
|
|
10
|
-
.string()
|
|
11
|
-
.min(1)
|
|
12
|
-
.required(),
|
|
9
|
+
name: yup.string().min(1).required(),
|
|
13
10
|
description: yup.string().optional(),
|
|
14
|
-
type: yup
|
|
15
|
-
.string()
|
|
16
|
-
.oneOf(Object.values(constants.API_TOKEN_TYPE))
|
|
17
|
-
.required(),
|
|
11
|
+
type: yup.string().oneOf(Object.values(constants.API_TOKEN_TYPE)).required(),
|
|
18
12
|
})
|
|
19
13
|
.noUnknown();
|
|
20
14
|
|
|
21
15
|
const apiTokenUpdateSchema = yup
|
|
22
16
|
.object()
|
|
23
17
|
.shape({
|
|
24
|
-
name: yup
|
|
25
|
-
.string()
|
|
26
|
-
.min(1)
|
|
27
|
-
.notNull(),
|
|
18
|
+
name: yup.string().min(1).notNull(),
|
|
28
19
|
description: yup.string().nullable(),
|
|
29
|
-
type: yup
|
|
30
|
-
.string()
|
|
31
|
-
.oneOf(Object.values(constants.API_TOKEN_TYPE))
|
|
32
|
-
.notNull(),
|
|
20
|
+
type: yup.string().oneOf(Object.values(constants.API_TOKEN_TYPE)).notNull(),
|
|
33
21
|
})
|
|
34
22
|
.noUnknown();
|
|
35
23
|
|
|
@@ -2,10 +2,6 @@
|
|
|
2
2
|
|
|
3
3
|
const { yup, validateYupSchema } = require('@strapi/utils');
|
|
4
4
|
|
|
5
|
-
const renewToken = yup
|
|
6
|
-
.object()
|
|
7
|
-
.shape({ token: yup.string().required() })
|
|
8
|
-
.required()
|
|
9
|
-
.noUnknown();
|
|
5
|
+
const renewToken = yup.object().shape({ token: yup.string().required() }).required().noUnknown();
|
|
10
6
|
|
|
11
7
|
module.exports = validateYupSchema(renewToken);
|
|
@@ -2,11 +2,12 @@
|
|
|
2
2
|
|
|
3
3
|
const _ = require('lodash');
|
|
4
4
|
|
|
5
|
-
const checkFieldsAreCorrectlyNested = fields => {
|
|
5
|
+
const checkFieldsAreCorrectlyNested = (fields) => {
|
|
6
6
|
if (_.isNil(fields)) {
|
|
7
7
|
// Only check if the fields exist
|
|
8
8
|
return true;
|
|
9
|
-
}
|
|
9
|
+
}
|
|
10
|
+
if (!Array.isArray(fields)) {
|
|
10
11
|
return false;
|
|
11
12
|
}
|
|
12
13
|
|
|
@@ -15,7 +16,8 @@ const checkFieldsAreCorrectlyNested = fields => {
|
|
|
15
16
|
failed = fields
|
|
16
17
|
.slice(indexA + 1)
|
|
17
18
|
.some(
|
|
18
|
-
fieldB =>
|
|
19
|
+
(fieldB) =>
|
|
20
|
+
fieldB.startsWith(`${fields[indexA]}.`) || fields[indexA].startsWith(`${fieldB}.`)
|
|
19
21
|
);
|
|
20
22
|
if (failed) break;
|
|
21
23
|
}
|
|
@@ -2,11 +2,12 @@
|
|
|
2
2
|
|
|
3
3
|
const _ = require('lodash');
|
|
4
4
|
|
|
5
|
-
const checkFieldsDontHaveDuplicates = fields => {
|
|
5
|
+
const checkFieldsDontHaveDuplicates = (fields) => {
|
|
6
6
|
if (_.isNil(fields)) {
|
|
7
7
|
// Only check if the fields exist
|
|
8
8
|
return true;
|
|
9
|
-
}
|
|
9
|
+
}
|
|
10
|
+
if (!Array.isArray(fields)) {
|
|
10
11
|
return false;
|
|
11
12
|
}
|
|
12
13
|
|