@strapi/plugin-users-permissions 0.0.0-next.f5107c72369ee86a8ec1b6782f2e890925033ca3 → 0.0.0-next.f5312617ca16b870c2bf1adcea2c69b676979e29

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.
Files changed (218) hide show
  1. package/.eslintignore +1 -2
  2. package/.eslintrc +17 -0
  3. package/LICENSE +18 -3
  4. package/admin/src/components/BoundRoute/{index.js → index.jsx} +2 -2
  5. package/admin/src/components/FormModal/Input/{index.js → index.jsx} +32 -31
  6. package/admin/src/components/FormModal/index.jsx +115 -0
  7. package/admin/src/components/Permissions/PermissionRow/{CheckboxWrapper.js → CheckboxWrapper.jsx} +4 -3
  8. package/admin/src/components/Permissions/PermissionRow/{SubCategory.js → SubCategory.jsx} +13 -22
  9. package/admin/src/components/Permissions/index.jsx +47 -0
  10. package/admin/src/components/Permissions/reducer.js +1 -1
  11. package/admin/src/components/Policies/{index.js → index.jsx} +7 -5
  12. package/admin/src/components/UsersPermissions/{index.js → index.jsx} +15 -7
  13. package/admin/src/components/UsersPermissions/reducer.js +1 -1
  14. package/admin/src/index.js +19 -47
  15. package/admin/src/pages/AdvancedSettings/index.jsx +214 -0
  16. package/admin/src/pages/AdvancedSettings/utils/layout.js +20 -35
  17. package/admin/src/pages/AdvancedSettings/utils/schema.js +5 -2
  18. package/admin/src/pages/EmailTemplates/components/EmailForm.jsx +156 -0
  19. package/admin/src/pages/EmailTemplates/components/{EmailTable.js → EmailTable.jsx} +20 -17
  20. package/admin/src/pages/EmailTemplates/index.jsx +148 -0
  21. package/admin/src/pages/EmailTemplates/utils/schema.js +18 -6
  22. package/admin/src/pages/Providers/index.jsx +262 -0
  23. package/admin/src/pages/Providers/utils/forms.js +23 -11
  24. package/admin/src/pages/Roles/constants.js +3 -3
  25. package/admin/src/{hooks → pages/Roles/hooks}/usePlugins.js +19 -12
  26. package/admin/src/pages/Roles/index.jsx +24 -0
  27. package/admin/src/pages/Roles/pages/CreatePage.jsx +194 -0
  28. package/admin/src/pages/Roles/pages/EditPage.jsx +215 -0
  29. package/admin/src/pages/Roles/pages/ListPage/components/TableBody.jsx +119 -0
  30. package/admin/src/pages/Roles/{ListPage/index.js → pages/ListPage/index.jsx} +93 -65
  31. package/admin/src/translations/en.json +1 -1
  32. package/admin/src/translations/zh-Hans.json +80 -80
  33. package/admin/src/utils/prefixPluginTranslations.js +13 -0
  34. package/dist/_chunks/ar-BguGUqwK.js +44 -0
  35. package/dist/_chunks/ar-BguGUqwK.js.map +1 -0
  36. package/dist/_chunks/ar-CK8BRRXB.mjs +44 -0
  37. package/dist/_chunks/ar-CK8BRRXB.mjs.map +1 -0
  38. package/dist/_chunks/cs-BVigMk0l.mjs +50 -0
  39. package/dist/_chunks/cs-BVigMk0l.mjs.map +1 -0
  40. package/dist/_chunks/cs-BW8-K_GY.js +50 -0
  41. package/dist/_chunks/cs-BW8-K_GY.js.map +1 -0
  42. package/dist/_chunks/de-BKUdRFI4.mjs +62 -0
  43. package/dist/_chunks/de-BKUdRFI4.mjs.map +1 -0
  44. package/dist/_chunks/de-owXpVluI.js +62 -0
  45. package/dist/_chunks/de-owXpVluI.js.map +1 -0
  46. package/dist/_chunks/dk-BQiTK50l.mjs +86 -0
  47. package/dist/_chunks/dk-BQiTK50l.mjs.map +1 -0
  48. package/dist/_chunks/dk-LXAnbuBk.js +86 -0
  49. package/dist/_chunks/dk-LXAnbuBk.js.map +1 -0
  50. package/dist/_chunks/en-DOHtPf-2.mjs +86 -0
  51. package/dist/_chunks/en-DOHtPf-2.mjs.map +1 -0
  52. package/dist/_chunks/en-MHo5mcsU.js +86 -0
  53. package/dist/_chunks/en-MHo5mcsU.js.map +1 -0
  54. package/dist/_chunks/es-BwLCLXAQ.js +86 -0
  55. package/dist/_chunks/es-BwLCLXAQ.js.map +1 -0
  56. package/dist/_chunks/es-DNgOVMjD.mjs +86 -0
  57. package/dist/_chunks/es-DNgOVMjD.mjs.map +1 -0
  58. package/dist/_chunks/fr-DkgRugiU.mjs +50 -0
  59. package/dist/_chunks/fr-DkgRugiU.mjs.map +1 -0
  60. package/dist/_chunks/fr-DkhpSjjm.js +50 -0
  61. package/dist/_chunks/fr-DkhpSjjm.js.map +1 -0
  62. package/dist/_chunks/id-BTemOeTZ.js +62 -0
  63. package/dist/_chunks/id-BTemOeTZ.js.map +1 -0
  64. package/dist/_chunks/id-BdEsvnaF.mjs +62 -0
  65. package/dist/_chunks/id-BdEsvnaF.mjs.map +1 -0
  66. package/dist/_chunks/index-BH6NqE8I.js +245 -0
  67. package/dist/_chunks/index-BH6NqE8I.js.map +1 -0
  68. package/dist/_chunks/index-C3i__jX-.js +281 -0
  69. package/dist/_chunks/index-C3i__jX-.js.map +1 -0
  70. package/dist/_chunks/index-CFzpNgIL.js +640 -0
  71. package/dist/_chunks/index-CFzpNgIL.js.map +1 -0
  72. package/dist/_chunks/index-CJUWqtrZ.mjs +344 -0
  73. package/dist/_chunks/index-CJUWqtrZ.mjs.map +1 -0
  74. package/dist/_chunks/index-CcWTKtCY.js +366 -0
  75. package/dist/_chunks/index-CcWTKtCY.js.map +1 -0
  76. package/dist/_chunks/index-CnX2wiLY.mjs +1142 -0
  77. package/dist/_chunks/index-CnX2wiLY.mjs.map +1 -0
  78. package/dist/_chunks/index-DUWx-KG9-C1E7ADbJ.mjs +11984 -0
  79. package/dist/_chunks/index-DUWx-KG9-C1E7ADbJ.mjs.map +1 -0
  80. package/dist/_chunks/index-DUWx-KG9-fMZ4nmrb.js +12008 -0
  81. package/dist/_chunks/index-DUWx-KG9-fMZ4nmrb.js.map +1 -0
  82. package/dist/_chunks/index-DruWuFWL.js +1172 -0
  83. package/dist/_chunks/index-DruWuFWL.js.map +1 -0
  84. package/dist/_chunks/index-PJoz36kJ.mjs +262 -0
  85. package/dist/_chunks/index-PJoz36kJ.mjs.map +1 -0
  86. package/dist/_chunks/index-R4R0dEOv.mjs +246 -0
  87. package/dist/_chunks/index-R4R0dEOv.mjs.map +1 -0
  88. package/dist/_chunks/index-XOcQhJMB.mjs +617 -0
  89. package/dist/_chunks/index-XOcQhJMB.mjs.map +1 -0
  90. package/dist/_chunks/it-B-rv0E24.mjs +62 -0
  91. package/dist/_chunks/it-B-rv0E24.mjs.map +1 -0
  92. package/dist/_chunks/it-D1rH6V6_.js +62 -0
  93. package/dist/_chunks/it-D1rH6V6_.js.map +1 -0
  94. package/dist/_chunks/ja-C8K-VBPD.mjs +48 -0
  95. package/dist/_chunks/ja-C8K-VBPD.mjs.map +1 -0
  96. package/dist/_chunks/ja-DqShgTMf.js +48 -0
  97. package/dist/_chunks/ja-DqShgTMf.js.map +1 -0
  98. package/dist/_chunks/ko-B9DGEPWH.js +86 -0
  99. package/dist/_chunks/ko-B9DGEPWH.js.map +1 -0
  100. package/dist/_chunks/ko-Busb0wIY.mjs +86 -0
  101. package/dist/_chunks/ko-Busb0wIY.mjs.map +1 -0
  102. package/dist/_chunks/ms-ByvsQjRt.mjs +49 -0
  103. package/dist/_chunks/ms-ByvsQjRt.mjs.map +1 -0
  104. package/dist/_chunks/ms-CPBU3LWf.js +49 -0
  105. package/dist/_chunks/ms-CPBU3LWf.js.map +1 -0
  106. package/dist/_chunks/nl-5qO8Rpcy.mjs +48 -0
  107. package/dist/_chunks/nl-5qO8Rpcy.mjs.map +1 -0
  108. package/dist/_chunks/nl-CwNB6YoO.js +48 -0
  109. package/dist/_chunks/nl-CwNB6YoO.js.map +1 -0
  110. package/dist/_chunks/pl-BdIzifBE.mjs +86 -0
  111. package/dist/_chunks/pl-BdIzifBE.mjs.map +1 -0
  112. package/dist/_chunks/pl-Do9UD69f.js +86 -0
  113. package/dist/_chunks/pl-Do9UD69f.js.map +1 -0
  114. package/dist/_chunks/pt-BIO24ioG.mjs +48 -0
  115. package/dist/_chunks/pt-BIO24ioG.mjs.map +1 -0
  116. package/dist/_chunks/pt-BR-D7dZhxuP.js +44 -0
  117. package/dist/_chunks/pt-BR-D7dZhxuP.js.map +1 -0
  118. package/dist/_chunks/pt-BR-f0p23AQZ.mjs +44 -0
  119. package/dist/_chunks/pt-BR-f0p23AQZ.mjs.map +1 -0
  120. package/dist/_chunks/pt-fdvyOnUp.js +48 -0
  121. package/dist/_chunks/pt-fdvyOnUp.js.map +1 -0
  122. package/dist/_chunks/ru-C94rjPGA.js +86 -0
  123. package/dist/_chunks/ru-C94rjPGA.js.map +1 -0
  124. package/dist/_chunks/ru-VWy-IB7K.mjs +86 -0
  125. package/dist/_chunks/ru-VWy-IB7K.mjs.map +1 -0
  126. package/dist/_chunks/sk-BABEhykl.js +50 -0
  127. package/dist/_chunks/sk-BABEhykl.js.map +1 -0
  128. package/dist/_chunks/sk-B_LIcepm.mjs +50 -0
  129. package/dist/_chunks/sk-B_LIcepm.mjs.map +1 -0
  130. package/dist/_chunks/sv-ABLKOokl.mjs +86 -0
  131. package/dist/_chunks/sv-ABLKOokl.mjs.map +1 -0
  132. package/dist/_chunks/sv-Be43LhA9.js +86 -0
  133. package/dist/_chunks/sv-Be43LhA9.js.map +1 -0
  134. package/dist/_chunks/th-DKyP7ueR.mjs +60 -0
  135. package/dist/_chunks/th-DKyP7ueR.mjs.map +1 -0
  136. package/dist/_chunks/th-DgVhVLhL.js +60 -0
  137. package/dist/_chunks/th-DgVhVLhL.js.map +1 -0
  138. package/dist/_chunks/tr-B_idhkEs.js +85 -0
  139. package/dist/_chunks/tr-B_idhkEs.js.map +1 -0
  140. package/dist/_chunks/tr-qa1Q5UjC.mjs +85 -0
  141. package/dist/_chunks/tr-qa1Q5UjC.mjs.map +1 -0
  142. package/dist/_chunks/uk-BmRqbeQc.mjs +49 -0
  143. package/dist/_chunks/uk-BmRqbeQc.mjs.map +1 -0
  144. package/dist/_chunks/uk-LHOivnhP.js +49 -0
  145. package/dist/_chunks/uk-LHOivnhP.js.map +1 -0
  146. package/dist/_chunks/vi-CdVRdKDw.js +50 -0
  147. package/dist/_chunks/vi-CdVRdKDw.js.map +1 -0
  148. package/dist/_chunks/vi-HW-EdMea.mjs +50 -0
  149. package/dist/_chunks/vi-HW-EdMea.mjs.map +1 -0
  150. package/dist/_chunks/zh-5hKkVPA4.mjs +86 -0
  151. package/dist/_chunks/zh-5hKkVPA4.mjs.map +1 -0
  152. package/dist/_chunks/zh-Cuq8gMnF.js +86 -0
  153. package/dist/_chunks/zh-Cuq8gMnF.js.map +1 -0
  154. package/dist/_chunks/zh-Hans-BHilK-yc.mjs +86 -0
  155. package/dist/_chunks/zh-Hans-BHilK-yc.mjs.map +1 -0
  156. package/dist/_chunks/zh-Hans-GQDMKtY4.js +86 -0
  157. package/dist/_chunks/zh-Hans-GQDMKtY4.js.map +1 -0
  158. package/dist/admin/index.js +4 -0
  159. package/dist/admin/index.js.map +1 -0
  160. package/dist/admin/index.mjs +5 -0
  161. package/dist/admin/index.mjs.map +1 -0
  162. package/jest.config.front.js +1 -1
  163. package/package.json +46 -27
  164. package/packup.config.ts +22 -0
  165. package/server/bootstrap/index.js +18 -15
  166. package/server/bootstrap/users-permissions-actions.js +6 -0
  167. package/server/config.js +29 -0
  168. package/server/content-types/user/index.js +0 -1
  169. package/server/controllers/auth.js +74 -38
  170. package/server/controllers/content-manager-user.js +28 -30
  171. package/server/controllers/role.js +17 -4
  172. package/server/controllers/user.js +18 -8
  173. package/server/controllers/validation/auth.js +81 -25
  174. package/server/middlewares/rateLimit.js +1 -1
  175. package/server/register.js +1 -1
  176. package/server/services/jwt.js +3 -3
  177. package/server/services/permission.js +3 -7
  178. package/server/services/providers-registry.js +469 -261
  179. package/server/services/providers.js +10 -5
  180. package/server/services/role.js +15 -13
  181. package/server/services/user.js +56 -19
  182. package/server/services/users-permissions.js +15 -13
  183. package/server/utils/index.d.ts +2 -1
  184. package/server/utils/sanitize/sanitizers.js +7 -3
  185. package/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +2 -2
  186. package/.eslintrc.js +0 -14
  187. package/admin/src/components/FormModal/index.js +0 -126
  188. package/admin/src/components/Permissions/index.js +0 -57
  189. package/admin/src/hooks/index.js +0 -5
  190. package/admin/src/hooks/useFetchRole/index.js +0 -67
  191. package/admin/src/hooks/useFetchRole/reducer.js +0 -31
  192. package/admin/src/hooks/useForm/index.js +0 -68
  193. package/admin/src/hooks/useForm/reducer.js +0 -40
  194. package/admin/src/hooks/useRolesList/index.js +0 -65
  195. package/admin/src/hooks/useRolesList/init.js +0 -5
  196. package/admin/src/hooks/useRolesList/reducer.js +0 -31
  197. package/admin/src/pages/AdvancedSettings/index.js +0 -242
  198. package/admin/src/pages/AdvancedSettings/utils/api.js +0 -16
  199. package/admin/src/pages/EmailTemplates/components/EmailForm.js +0 -176
  200. package/admin/src/pages/EmailTemplates/index.js +0 -159
  201. package/admin/src/pages/EmailTemplates/utils/api.js +0 -16
  202. package/admin/src/pages/Providers/index.js +0 -271
  203. package/admin/src/pages/Providers/reducer.js +0 -54
  204. package/admin/src/pages/Providers/utils/api.js +0 -24
  205. package/admin/src/pages/Providers/utils/createProvidersArray.js +0 -21
  206. package/admin/src/pages/Roles/CreatePage.js +0 -185
  207. package/admin/src/pages/Roles/EditPage.js +0 -197
  208. package/admin/src/pages/Roles/ListPage/components/TableBody.js +0 -93
  209. package/admin/src/pages/Roles/ListPage/utils/api.js +0 -30
  210. package/admin/src/pages/Roles/ProtectedCreatePage.js +0 -15
  211. package/admin/src/pages/Roles/ProtectedEditPage.js +0 -15
  212. package/admin/src/pages/Roles/ProtectedListPage.js +0 -17
  213. package/admin/src/pages/Roles/index.js +0 -30
  214. package/server/bootstrap/grant-config.js +0 -131
  215. package/strapi-admin.js +0 -3
  216. package/strapi-server.js +0 -3
  217. /package/admin/src/components/Permissions/PermissionRow/{index.js → index.jsx} +0 -0
  218. /package/admin/src/contexts/UsersPermissionsContext/{index.js → index.jsx} +0 -0
@@ -0,0 +1,640 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("react/jsx-runtime");
4
+ const React = require("react");
5
+ const indexDUWxKG9 = require("./index-DUWx-KG9-fMZ4nmrb.js");
6
+ const designSystem = require("@strapi/design-system");
7
+ const icons = require("@strapi/icons");
8
+ const admin = require("@strapi/strapi/admin");
9
+ const upperFirst = require("lodash/upperFirst");
10
+ const reactIntl = require("react-intl");
11
+ const reactQuery = require("react-query");
12
+ const formik = require("formik");
13
+ const PropTypes = require("prop-types");
14
+ const index = require("./index-BH6NqE8I.js");
15
+ require("lodash/isEmpty");
16
+ const yup = require("yup");
17
+ const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
18
+ function _interopNamespace(e) {
19
+ if (e && e.__esModule)
20
+ return e;
21
+ const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
22
+ if (e) {
23
+ for (const k in e) {
24
+ if (k !== "default") {
25
+ const d = Object.getOwnPropertyDescriptor(e, k);
26
+ Object.defineProperty(n, k, d.get ? d : {
27
+ enumerable: true,
28
+ get: () => e[k]
29
+ });
30
+ }
31
+ }
32
+ }
33
+ n.default = e;
34
+ return Object.freeze(n);
35
+ }
36
+ const React__namespace = /* @__PURE__ */ _interopNamespace(React);
37
+ const upperFirst__default = /* @__PURE__ */ _interopDefault(upperFirst);
38
+ const PropTypes__default = /* @__PURE__ */ _interopDefault(PropTypes);
39
+ const yup__namespace = /* @__PURE__ */ _interopNamespace(yup);
40
+ const Input = ({
41
+ description,
42
+ disabled,
43
+ intlLabel,
44
+ error,
45
+ name,
46
+ onChange,
47
+ placeholder,
48
+ providerToEditName,
49
+ type,
50
+ value
51
+ }) => {
52
+ const { formatMessage } = reactIntl.useIntl();
53
+ const inputValue = name === "noName" ? `${window.strapi.backendURL}/api/connect/${providerToEditName}/callback` : value;
54
+ const label = formatMessage(
55
+ { id: intlLabel.id, defaultMessage: intlLabel.defaultMessage },
56
+ { provider: providerToEditName, ...intlLabel.values }
57
+ );
58
+ const hint = description ? formatMessage(
59
+ { id: description.id, defaultMessage: description.defaultMessage },
60
+ { provider: providerToEditName, ...description.values }
61
+ ) : "";
62
+ if (type === "bool") {
63
+ return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Field.Root, { hint, name, children: [
64
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: label }),
65
+ /* @__PURE__ */ jsxRuntime.jsx(
66
+ designSystem.Toggle,
67
+ {
68
+ "aria-label": name,
69
+ checked: value,
70
+ disabled,
71
+ offLabel: formatMessage({
72
+ id: "app.components.ToggleCheckbox.off-label",
73
+ defaultMessage: "Off"
74
+ }),
75
+ onLabel: formatMessage({
76
+ id: "app.components.ToggleCheckbox.on-label",
77
+ defaultMessage: "On"
78
+ }),
79
+ onChange: (e) => {
80
+ onChange({ target: { name, value: e.target.checked } });
81
+ }
82
+ }
83
+ ),
84
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
85
+ ] });
86
+ }
87
+ const formattedPlaceholder = placeholder ? formatMessage(
88
+ { id: placeholder.id, defaultMessage: placeholder.defaultMessage },
89
+ { ...placeholder.values }
90
+ ) : "";
91
+ const errorMessage = error ? formatMessage({ id: error, defaultMessage: error }) : "";
92
+ return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Field.Root, { error: errorMessage, name, children: [
93
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: label }),
94
+ /* @__PURE__ */ jsxRuntime.jsx(
95
+ designSystem.TextInput,
96
+ {
97
+ disabled,
98
+ onChange,
99
+ placeholder: formattedPlaceholder,
100
+ type,
101
+ value: inputValue
102
+ }
103
+ ),
104
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Error, {})
105
+ ] });
106
+ };
107
+ Input.defaultProps = {
108
+ description: null,
109
+ disabled: false,
110
+ error: "",
111
+ placeholder: null,
112
+ value: ""
113
+ };
114
+ Input.propTypes = {
115
+ description: PropTypes__default.default.shape({
116
+ id: PropTypes__default.default.string.isRequired,
117
+ defaultMessage: PropTypes__default.default.string.isRequired,
118
+ values: PropTypes__default.default.object
119
+ }),
120
+ disabled: PropTypes__default.default.bool,
121
+ error: PropTypes__default.default.string,
122
+ intlLabel: PropTypes__default.default.shape({
123
+ id: PropTypes__default.default.string.isRequired,
124
+ defaultMessage: PropTypes__default.default.string.isRequired,
125
+ values: PropTypes__default.default.object
126
+ }).isRequired,
127
+ name: PropTypes__default.default.string.isRequired,
128
+ onChange: PropTypes__default.default.func.isRequired,
129
+ placeholder: PropTypes__default.default.shape({
130
+ id: PropTypes__default.default.string.isRequired,
131
+ defaultMessage: PropTypes__default.default.string.isRequired,
132
+ values: PropTypes__default.default.object
133
+ }),
134
+ providerToEditName: PropTypes__default.default.string.isRequired,
135
+ type: PropTypes__default.default.string.isRequired,
136
+ value: PropTypes__default.default.oneOfType([PropTypes__default.default.bool, PropTypes__default.default.string])
137
+ };
138
+ const FormModal = ({
139
+ headerBreadcrumbs,
140
+ initialData,
141
+ isSubmiting,
142
+ layout,
143
+ isOpen,
144
+ onSubmit,
145
+ onToggle,
146
+ providerToEditName
147
+ }) => {
148
+ const { formatMessage } = reactIntl.useIntl();
149
+ return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Modal.Root, { open: isOpen, onOpenChange: onToggle, children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Modal.Content, { children: [
150
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Modal.Header, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Breadcrumbs, { label: headerBreadcrumbs.join(", "), children: headerBreadcrumbs.map((crumb, index2, arr) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.Crumb, { isCurrent: index2 === arr.length - 1, children: crumb }, crumb)) }) }),
151
+ /* @__PURE__ */ jsxRuntime.jsx(
152
+ formik.Formik,
153
+ {
154
+ onSubmit: (values) => onSubmit(values),
155
+ initialValues: initialData,
156
+ validationSchema: layout.schema,
157
+ validateOnChange: false,
158
+ children: ({ errors, handleChange, values }) => {
159
+ return /* @__PURE__ */ jsxRuntime.jsxs(formik.Form, { children: [
160
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Modal.Body, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 1, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Root, { gap: 5, children: layout.form.map((row) => {
161
+ return row.map((input) => {
162
+ return /* @__PURE__ */ jsxRuntime.jsx(
163
+ designSystem.Grid.Item,
164
+ {
165
+ col: input.size,
166
+ xs: 12,
167
+ direction: "column",
168
+ alignItems: "stretch",
169
+ children: /* @__PURE__ */ jsxRuntime.jsx(
170
+ Input,
171
+ {
172
+ ...input,
173
+ error: errors[input.name],
174
+ onChange: handleChange,
175
+ value: values[input.name],
176
+ providerToEditName
177
+ }
178
+ )
179
+ },
180
+ input.name
181
+ );
182
+ });
183
+ }) }) }) }),
184
+ /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Modal.Footer, { children: [
185
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { variant: "tertiary", onClick: onToggle, type: "button", children: formatMessage({
186
+ id: "app.components.Button.cancel",
187
+ defaultMessage: "Cancel"
188
+ }) }),
189
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { type: "submit", loading: isSubmiting, children: formatMessage({ id: "global.save", defaultMessage: "Save" }) })
190
+ ] })
191
+ ] });
192
+ }
193
+ }
194
+ )
195
+ ] }) });
196
+ };
197
+ FormModal.defaultProps = {
198
+ initialData: null,
199
+ providerToEditName: null
200
+ };
201
+ FormModal.propTypes = {
202
+ headerBreadcrumbs: PropTypes__default.default.arrayOf(PropTypes__default.default.string).isRequired,
203
+ initialData: PropTypes__default.default.object,
204
+ layout: PropTypes__default.default.shape({
205
+ form: PropTypes__default.default.arrayOf(PropTypes__default.default.array),
206
+ schema: PropTypes__default.default.object
207
+ }).isRequired,
208
+ isOpen: PropTypes__default.default.bool.isRequired,
209
+ isSubmiting: PropTypes__default.default.bool.isRequired,
210
+ onSubmit: PropTypes__default.default.func.isRequired,
211
+ onToggle: PropTypes__default.default.func.isRequired,
212
+ providerToEditName: PropTypes__default.default.string
213
+ };
214
+ const callbackLabel = {
215
+ id: index.getTrad("PopUpForm.Providers.redirectURL.front-end.label"),
216
+ defaultMessage: "The redirect URL to your front-end app"
217
+ };
218
+ const callbackPlaceholder = {
219
+ id: "http://www.client-app.com",
220
+ defaultMessage: "http://www.client-app.com"
221
+ };
222
+ const enabledDescription = {
223
+ id: index.getTrad("PopUpForm.Providers.enabled.description"),
224
+ defaultMessage: "If disabled, users won't be able to use this provider."
225
+ };
226
+ const enabledLabel = {
227
+ id: index.getTrad("PopUpForm.Providers.enabled.label"),
228
+ defaultMessage: "Enable"
229
+ };
230
+ const keyLabel = { id: index.getTrad("PopUpForm.Providers.key.label"), defaultMessage: "Client ID" };
231
+ const hintLabel = {
232
+ id: index.getTrad("PopUpForm.Providers.redirectURL.label"),
233
+ defaultMessage: "The redirect URL to add in your {provider} application configurations"
234
+ };
235
+ const textPlaceholder = {
236
+ id: index.getTrad("PopUpForm.Providers.key.placeholder"),
237
+ defaultMessage: "TEXT"
238
+ };
239
+ const secretLabel = {
240
+ id: index.getTrad("PopUpForm.Providers.secret.label"),
241
+ defaultMessage: "Client Secret"
242
+ };
243
+ const CALLBACK_REGEX = /^$|^[a-z][a-z0-9+.-]*:\/\/[^\s/$.?#](?:[^\s]*[^\s/$.?#])?$/i;
244
+ const SUBDOMAIN_REGEX = /^(([a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]+)(:\d+)?(\/\S*)?$/i;
245
+ const forms = {
246
+ email: {
247
+ form: [
248
+ [
249
+ {
250
+ intlLabel: enabledLabel,
251
+ name: "enabled",
252
+ type: "bool",
253
+ description: enabledDescription,
254
+ size: 6
255
+ // TODO check if still needed
256
+ // validations: {
257
+ // required: true,
258
+ // },
259
+ }
260
+ ]
261
+ ],
262
+ schema: yup__namespace.object().shape({
263
+ enabled: yup__namespace.bool().required(admin.translatedErrors.required.id)
264
+ })
265
+ },
266
+ providers: {
267
+ form: [
268
+ [
269
+ {
270
+ intlLabel: enabledLabel,
271
+ name: "enabled",
272
+ type: "bool",
273
+ description: enabledDescription,
274
+ size: 6,
275
+ validations: {
276
+ required: true
277
+ }
278
+ }
279
+ ],
280
+ [
281
+ {
282
+ intlLabel: keyLabel,
283
+ name: "key",
284
+ type: "text",
285
+ placeholder: textPlaceholder,
286
+ size: 12,
287
+ validations: {
288
+ required: true
289
+ }
290
+ }
291
+ ],
292
+ [
293
+ {
294
+ intlLabel: secretLabel,
295
+ name: "secret",
296
+ type: "text",
297
+ placeholder: textPlaceholder,
298
+ size: 12,
299
+ validations: {
300
+ required: true
301
+ }
302
+ }
303
+ ],
304
+ [
305
+ {
306
+ intlLabel: callbackLabel,
307
+ placeholder: callbackPlaceholder,
308
+ name: "callback",
309
+ type: "text",
310
+ size: 12,
311
+ validations: {
312
+ required: true
313
+ }
314
+ }
315
+ ],
316
+ [
317
+ {
318
+ intlLabel: hintLabel,
319
+ name: "noName",
320
+ type: "text",
321
+ validations: {},
322
+ size: 12,
323
+ disabled: true
324
+ }
325
+ ]
326
+ ],
327
+ schema: yup__namespace.object().shape({
328
+ enabled: yup__namespace.bool().required(admin.translatedErrors.required.id),
329
+ key: yup__namespace.string().when("enabled", {
330
+ is: true,
331
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
332
+ otherwise: yup__namespace.string()
333
+ }),
334
+ secret: yup__namespace.string().when("enabled", {
335
+ is: true,
336
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
337
+ otherwise: yup__namespace.string()
338
+ }),
339
+ callback: yup__namespace.string().when("enabled", {
340
+ is: true,
341
+ then: yup__namespace.string().matches(CALLBACK_REGEX, admin.translatedErrors.regex.id).required(admin.translatedErrors.required.id),
342
+ otherwise: yup__namespace.string()
343
+ })
344
+ })
345
+ },
346
+ providersWithSubdomain: {
347
+ form: [
348
+ [
349
+ {
350
+ intlLabel: enabledLabel,
351
+ name: "enabled",
352
+ type: "bool",
353
+ description: enabledDescription,
354
+ size: 6,
355
+ validations: {
356
+ required: true
357
+ }
358
+ }
359
+ ],
360
+ [
361
+ {
362
+ intlLabel: keyLabel,
363
+ name: "key",
364
+ type: "text",
365
+ placeholder: textPlaceholder,
366
+ size: 12,
367
+ validations: {
368
+ required: true
369
+ }
370
+ }
371
+ ],
372
+ [
373
+ {
374
+ intlLabel: secretLabel,
375
+ name: "secret",
376
+ type: "text",
377
+ placeholder: textPlaceholder,
378
+ size: 12,
379
+ validations: {
380
+ required: true
381
+ }
382
+ }
383
+ ],
384
+ [
385
+ {
386
+ intlLabel: {
387
+ id: index.getTrad({ id: "PopUpForm.Providers.jwksurl.label" }),
388
+ defaultMessage: "JWKS URL"
389
+ },
390
+ name: "jwksurl",
391
+ type: "text",
392
+ placeholder: textPlaceholder,
393
+ size: 12,
394
+ validations: {
395
+ required: false
396
+ }
397
+ }
398
+ ],
399
+ [
400
+ {
401
+ intlLabel: {
402
+ id: index.getTrad("PopUpForm.Providers.subdomain.label"),
403
+ defaultMessage: "Host URI (Subdomain)"
404
+ },
405
+ name: "subdomain",
406
+ type: "text",
407
+ placeholder: {
408
+ id: index.getTrad("PopUpForm.Providers.subdomain.placeholder"),
409
+ defaultMessage: "my.subdomain.com"
410
+ },
411
+ size: 12,
412
+ validations: {
413
+ required: true
414
+ }
415
+ }
416
+ ],
417
+ [
418
+ {
419
+ intlLabel: callbackLabel,
420
+ placeholder: callbackPlaceholder,
421
+ name: "callback",
422
+ type: "text",
423
+ size: 12,
424
+ validations: {
425
+ required: true
426
+ }
427
+ }
428
+ ],
429
+ [
430
+ {
431
+ intlLabel: hintLabel,
432
+ name: "noName",
433
+ type: "text",
434
+ validations: {},
435
+ size: 12,
436
+ disabled: true
437
+ }
438
+ ]
439
+ ],
440
+ schema: yup__namespace.object().shape({
441
+ enabled: yup__namespace.bool().required(admin.translatedErrors.required.id),
442
+ key: yup__namespace.string().when("enabled", {
443
+ is: true,
444
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
445
+ otherwise: yup__namespace.string()
446
+ }),
447
+ secret: yup__namespace.string().when("enabled", {
448
+ is: true,
449
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
450
+ otherwise: yup__namespace.string()
451
+ }),
452
+ subdomain: yup__namespace.string().when("enabled", {
453
+ is: true,
454
+ then: yup__namespace.string().matches(SUBDOMAIN_REGEX, admin.translatedErrors.regex.id).required(admin.translatedErrors.required.id),
455
+ otherwise: yup__namespace.string()
456
+ }),
457
+ callback: yup__namespace.string().when("enabled", {
458
+ is: true,
459
+ then: yup__namespace.string().matches(CALLBACK_REGEX, admin.translatedErrors.regex.id).required(admin.translatedErrors.required.id),
460
+ otherwise: yup__namespace.string()
461
+ })
462
+ })
463
+ }
464
+ };
465
+ const ProvidersPage = () => {
466
+ const { formatMessage, locale } = reactIntl.useIntl();
467
+ const queryClient = reactQuery.useQueryClient();
468
+ const { trackUsage } = indexDUWxKG9.useTracking();
469
+ const [isOpen, setIsOpen] = React__namespace.useState(false);
470
+ const [providerToEditName, setProviderToEditName] = React__namespace.useState(null);
471
+ const { toggleNotification } = admin.useNotification();
472
+ const { get, put } = admin.useFetchClient();
473
+ const { formatAPIError } = admin.useAPIErrorHandler();
474
+ const formatter = designSystem.useCollator(locale, {
475
+ sensitivity: "base"
476
+ });
477
+ const {
478
+ isLoading: isLoadingPermissions,
479
+ allowedActions: { canUpdate }
480
+ } = admin.useRBAC({ update: index.PERMISSIONS.updateProviders });
481
+ const { isLoading: isLoadingData, data } = reactQuery.useQuery(
482
+ ["users-permissions", "get-providers"],
483
+ async () => {
484
+ const { data: data2 } = await get("/users-permissions/providers");
485
+ return data2;
486
+ },
487
+ {
488
+ initialData: {}
489
+ }
490
+ );
491
+ const submitMutation = reactQuery.useMutation((body) => put("/users-permissions/providers", body), {
492
+ async onSuccess() {
493
+ await queryClient.invalidateQueries(["users-permissions", "get-providers"]);
494
+ toggleNotification({
495
+ type: "success",
496
+ message: formatMessage({ id: index.getTrad("notification.success.submit") })
497
+ });
498
+ trackUsage("didEditAuthenticationProvider");
499
+ handleToggleModal();
500
+ },
501
+ onError(error) {
502
+ toggleNotification({
503
+ type: "danger",
504
+ message: formatAPIError(error)
505
+ });
506
+ },
507
+ refetchActive: false
508
+ });
509
+ const providers = Object.entries(data).reduce((acc, [name, provider]) => {
510
+ const { icon, enabled, subdomain } = provider;
511
+ acc.push({
512
+ name,
513
+ icon: icon === "envelope" ? ["fas", "envelope"] : ["fab", icon],
514
+ enabled,
515
+ subdomain
516
+ });
517
+ return acc;
518
+ }, []).sort((a, b) => formatter.compare(a.name, b.name));
519
+ const isLoading = isLoadingData || isLoadingPermissions;
520
+ const isProviderWithSubdomain = React__namespace.useMemo(() => {
521
+ if (!providerToEditName) {
522
+ return false;
523
+ }
524
+ const providerToEdit = providers.find((obj) => obj.name === providerToEditName);
525
+ return !!providerToEdit?.subdomain;
526
+ }, [providers, providerToEditName]);
527
+ const layoutToRender = React__namespace.useMemo(() => {
528
+ if (providerToEditName === "email") {
529
+ return forms.email;
530
+ }
531
+ if (isProviderWithSubdomain) {
532
+ return forms.providersWithSubdomain;
533
+ }
534
+ return forms.providers;
535
+ }, [providerToEditName, isProviderWithSubdomain]);
536
+ const handleToggleModal = () => {
537
+ setIsOpen((prev) => !prev);
538
+ };
539
+ const handleClickEdit = (provider) => {
540
+ if (canUpdate) {
541
+ setProviderToEditName(provider.name);
542
+ handleToggleModal();
543
+ }
544
+ };
545
+ const handleSubmit = async (values) => {
546
+ trackUsage("willEditAuthenticationProvider");
547
+ submitMutation.mutate({ providers: { ...data, [providerToEditName]: values } });
548
+ };
549
+ if (isLoading) {
550
+ return /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Loading, {});
551
+ }
552
+ return /* @__PURE__ */ jsxRuntime.jsxs(indexDUWxKG9.Layouts.Root, { children: [
553
+ /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Title, { children: formatMessage(
554
+ { id: "Settings.PageTitle", defaultMessage: "Settings - {name}" },
555
+ {
556
+ name: formatMessage({
557
+ id: index.getTrad("HeaderNav.link.providers"),
558
+ defaultMessage: "Providers"
559
+ })
560
+ }
561
+ ) }),
562
+ /* @__PURE__ */ jsxRuntime.jsxs(admin.Page.Main, { children: [
563
+ /* @__PURE__ */ jsxRuntime.jsx(
564
+ indexDUWxKG9.Layouts.Header,
565
+ {
566
+ title: formatMessage({
567
+ id: index.getTrad("HeaderNav.link.providers"),
568
+ defaultMessage: "Providers"
569
+ })
570
+ }
571
+ ),
572
+ /* @__PURE__ */ jsxRuntime.jsx(indexDUWxKG9.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Table, { colCount: 3, rowCount: providers.length + 1, children: [
573
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Thead, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { children: [
574
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({ id: "global.name", defaultMessage: "Name" }) }) }),
575
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({ id: index.getTrad("Providers.status"), defaultMessage: "Status" }) }) }),
576
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.VisuallyHidden, { children: formatMessage({
577
+ id: "global.settings",
578
+ defaultMessage: "Settings"
579
+ }) }) }) })
580
+ ] }) }),
581
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Tbody, { children: providers.map((provider) => /* @__PURE__ */ jsxRuntime.jsxs(
582
+ designSystem.Tr,
583
+ {
584
+ onClick: () => canUpdate ? handleClickEdit(provider) : void 0,
585
+ children: [
586
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { width: "45%", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { fontWeight: "semiBold", textColor: "neutral800", children: provider.name }) }),
587
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { width: "65%", children: /* @__PURE__ */ jsxRuntime.jsx(
588
+ designSystem.Typography,
589
+ {
590
+ textColor: provider.enabled ? "success600" : "danger600",
591
+ "data-testid": `enable-${provider.name}`,
592
+ children: provider.enabled ? formatMessage({
593
+ id: "global.enabled",
594
+ defaultMessage: "Enabled"
595
+ }) : formatMessage({
596
+ id: "global.disabled",
597
+ defaultMessage: "Disabled"
598
+ })
599
+ }
600
+ ) }),
601
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { onClick: (e) => e.stopPropagation(), children: canUpdate && /* @__PURE__ */ jsxRuntime.jsx(
602
+ designSystem.IconButton,
603
+ {
604
+ onClick: () => handleClickEdit(provider),
605
+ variant: "ghost",
606
+ label: "Edit",
607
+ children: /* @__PURE__ */ jsxRuntime.jsx(icons.Pencil, {})
608
+ }
609
+ ) })
610
+ ]
611
+ },
612
+ provider.name
613
+ )) })
614
+ ] }) })
615
+ ] }),
616
+ /* @__PURE__ */ jsxRuntime.jsx(
617
+ FormModal,
618
+ {
619
+ initialData: data[providerToEditName],
620
+ isOpen,
621
+ isSubmiting: submitMutation.isLoading,
622
+ layout: layoutToRender,
623
+ headerBreadcrumbs: [
624
+ formatMessage({
625
+ id: index.getTrad("PopUpForm.header.edit.providers"),
626
+ defaultMessage: "Edit Provider"
627
+ }),
628
+ upperFirst__default.default(providerToEditName)
629
+ ],
630
+ onToggle: handleToggleModal,
631
+ onSubmit: handleSubmit,
632
+ providerToEditName
633
+ }
634
+ )
635
+ ] });
636
+ };
637
+ const ProtectedProvidersPage = () => /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Protect, { permissions: index.PERMISSIONS.readProviders, children: /* @__PURE__ */ jsxRuntime.jsx(ProvidersPage, {}) });
638
+ exports.ProvidersPage = ProvidersPage;
639
+ exports.default = ProtectedProvidersPage;
640
+ //# sourceMappingURL=index-CFzpNgIL.js.map