@strapi/plugin-users-permissions 0.0.0-next.d2c02ba7d58eb81b8c45c3d12076d6413ecde204 → 0.0.0-next.d2d15ef227d67cce89c2673764c0555c841cd29c

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 (194) 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 +16 -43
  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.js → index.jsx} +36 -62
  21. package/admin/src/pages/EmailTemplates/utils/schema.js +18 -6
  22. package/admin/src/pages/Providers/{index.js → index.jsx} +98 -113
  23. package/admin/src/pages/Providers/utils/forms.js +11 -11
  24. package/admin/src/pages/Roles/constants.js +3 -3
  25. package/admin/src/pages/Roles/hooks/usePlugins.js +4 -4
  26. package/admin/src/pages/Roles/index.jsx +24 -0
  27. package/admin/src/pages/Roles/pages/{CreatePage.js → CreatePage.jsx} +53 -58
  28. package/admin/src/pages/Roles/pages/{EditPage.js → EditPage.jsx} +63 -68
  29. package/admin/src/pages/Roles/pages/ListPage/components/{TableBody.js → TableBody.jsx} +27 -31
  30. package/admin/src/pages/Roles/pages/ListPage/{index.js → index.jsx} +81 -55
  31. package/admin/src/translations/en.json +1 -1
  32. package/admin/src/utils/prefixPluginTranslations.js +13 -0
  33. package/dist/_chunks/ar-BguGUqwK.js +44 -0
  34. package/dist/_chunks/ar-BguGUqwK.js.map +1 -0
  35. package/dist/_chunks/ar-CK8BRRXB.mjs +44 -0
  36. package/dist/_chunks/ar-CK8BRRXB.mjs.map +1 -0
  37. package/dist/_chunks/cs-BVigMk0l.mjs +50 -0
  38. package/dist/_chunks/cs-BVigMk0l.mjs.map +1 -0
  39. package/dist/_chunks/cs-BW8-K_GY.js +50 -0
  40. package/dist/_chunks/cs-BW8-K_GY.js.map +1 -0
  41. package/dist/_chunks/de-BKUdRFI4.mjs +62 -0
  42. package/dist/_chunks/de-BKUdRFI4.mjs.map +1 -0
  43. package/dist/_chunks/de-owXpVluI.js +62 -0
  44. package/dist/_chunks/de-owXpVluI.js.map +1 -0
  45. package/dist/_chunks/dk-BQiTK50l.mjs +86 -0
  46. package/dist/_chunks/dk-BQiTK50l.mjs.map +1 -0
  47. package/dist/_chunks/dk-LXAnbuBk.js +86 -0
  48. package/dist/_chunks/dk-LXAnbuBk.js.map +1 -0
  49. package/dist/_chunks/en-DOHtPf-2.mjs +86 -0
  50. package/dist/_chunks/en-DOHtPf-2.mjs.map +1 -0
  51. package/dist/_chunks/en-MHo5mcsU.js +86 -0
  52. package/dist/_chunks/en-MHo5mcsU.js.map +1 -0
  53. package/dist/_chunks/es-BwLCLXAQ.js +86 -0
  54. package/dist/_chunks/es-BwLCLXAQ.js.map +1 -0
  55. package/dist/_chunks/es-DNgOVMjD.mjs +86 -0
  56. package/dist/_chunks/es-DNgOVMjD.mjs.map +1 -0
  57. package/dist/_chunks/fr-DkgRugiU.mjs +50 -0
  58. package/dist/_chunks/fr-DkgRugiU.mjs.map +1 -0
  59. package/dist/_chunks/fr-DkhpSjjm.js +50 -0
  60. package/dist/_chunks/fr-DkhpSjjm.js.map +1 -0
  61. package/dist/_chunks/id-BTemOeTZ.js +62 -0
  62. package/dist/_chunks/id-BTemOeTZ.js.map +1 -0
  63. package/dist/_chunks/id-BdEsvnaF.mjs +62 -0
  64. package/dist/_chunks/id-BdEsvnaF.mjs.map +1 -0
  65. package/dist/_chunks/index-B9cFxoCN.mjs +615 -0
  66. package/dist/_chunks/index-B9cFxoCN.mjs.map +1 -0
  67. package/dist/_chunks/index-BJTnrL31.js +281 -0
  68. package/dist/_chunks/index-BJTnrL31.js.map +1 -0
  69. package/dist/_chunks/index-CAgV-G5k.js +1173 -0
  70. package/dist/_chunks/index-CAgV-G5k.js.map +1 -0
  71. package/dist/_chunks/index-CI_b1cXd.mjs +1143 -0
  72. package/dist/_chunks/index-CI_b1cXd.mjs.map +1 -0
  73. package/dist/_chunks/index-Cb03Ke48.js +366 -0
  74. package/dist/_chunks/index-Cb03Ke48.js.map +1 -0
  75. package/dist/_chunks/index-DDglyd0X.mjs +262 -0
  76. package/dist/_chunks/index-DDglyd0X.mjs.map +1 -0
  77. package/dist/_chunks/index-DJOPnOVo.mjs +344 -0
  78. package/dist/_chunks/index-DJOPnOVo.mjs.map +1 -0
  79. package/dist/_chunks/index-QPUYgtlo-BfJxOAzF.mjs +11845 -0
  80. package/dist/_chunks/index-QPUYgtlo-BfJxOAzF.mjs.map +1 -0
  81. package/dist/_chunks/index-QPUYgtlo-QiBdpWEj.js +11869 -0
  82. package/dist/_chunks/index-QPUYgtlo-QiBdpWEj.js.map +1 -0
  83. package/dist/_chunks/index-_vrdPeYp.js +248 -0
  84. package/dist/_chunks/index-_vrdPeYp.js.map +1 -0
  85. package/dist/_chunks/index-bDCZWhLO.mjs +249 -0
  86. package/dist/_chunks/index-bDCZWhLO.mjs.map +1 -0
  87. package/dist/_chunks/index-cL_YxyjM.js +638 -0
  88. package/dist/_chunks/index-cL_YxyjM.js.map +1 -0
  89. package/dist/_chunks/it-B-rv0E24.mjs +62 -0
  90. package/dist/_chunks/it-B-rv0E24.mjs.map +1 -0
  91. package/dist/_chunks/it-D1rH6V6_.js +62 -0
  92. package/dist/_chunks/it-D1rH6V6_.js.map +1 -0
  93. package/dist/_chunks/ja-C8K-VBPD.mjs +48 -0
  94. package/dist/_chunks/ja-C8K-VBPD.mjs.map +1 -0
  95. package/dist/_chunks/ja-DqShgTMf.js +48 -0
  96. package/dist/_chunks/ja-DqShgTMf.js.map +1 -0
  97. package/dist/_chunks/ko-B9DGEPWH.js +86 -0
  98. package/dist/_chunks/ko-B9DGEPWH.js.map +1 -0
  99. package/dist/_chunks/ko-Busb0wIY.mjs +86 -0
  100. package/dist/_chunks/ko-Busb0wIY.mjs.map +1 -0
  101. package/dist/_chunks/ms-ByvsQjRt.mjs +49 -0
  102. package/dist/_chunks/ms-ByvsQjRt.mjs.map +1 -0
  103. package/dist/_chunks/ms-CPBU3LWf.js +49 -0
  104. package/dist/_chunks/ms-CPBU3LWf.js.map +1 -0
  105. package/dist/_chunks/nl-5qO8Rpcy.mjs +48 -0
  106. package/dist/_chunks/nl-5qO8Rpcy.mjs.map +1 -0
  107. package/dist/_chunks/nl-CwNB6YoO.js +48 -0
  108. package/dist/_chunks/nl-CwNB6YoO.js.map +1 -0
  109. package/dist/_chunks/pl-BdIzifBE.mjs +86 -0
  110. package/dist/_chunks/pl-BdIzifBE.mjs.map +1 -0
  111. package/dist/_chunks/pl-Do9UD69f.js +86 -0
  112. package/dist/_chunks/pl-Do9UD69f.js.map +1 -0
  113. package/dist/_chunks/pt-BIO24ioG.mjs +48 -0
  114. package/dist/_chunks/pt-BIO24ioG.mjs.map +1 -0
  115. package/dist/_chunks/pt-BR-D7dZhxuP.js +44 -0
  116. package/dist/_chunks/pt-BR-D7dZhxuP.js.map +1 -0
  117. package/dist/_chunks/pt-BR-f0p23AQZ.mjs +44 -0
  118. package/dist/_chunks/pt-BR-f0p23AQZ.mjs.map +1 -0
  119. package/dist/_chunks/pt-fdvyOnUp.js +48 -0
  120. package/dist/_chunks/pt-fdvyOnUp.js.map +1 -0
  121. package/dist/_chunks/ru-C94rjPGA.js +86 -0
  122. package/dist/_chunks/ru-C94rjPGA.js.map +1 -0
  123. package/dist/_chunks/ru-VWy-IB7K.mjs +86 -0
  124. package/dist/_chunks/ru-VWy-IB7K.mjs.map +1 -0
  125. package/dist/_chunks/sk-BABEhykl.js +50 -0
  126. package/dist/_chunks/sk-BABEhykl.js.map +1 -0
  127. package/dist/_chunks/sk-B_LIcepm.mjs +50 -0
  128. package/dist/_chunks/sk-B_LIcepm.mjs.map +1 -0
  129. package/dist/_chunks/sv-ABLKOokl.mjs +86 -0
  130. package/dist/_chunks/sv-ABLKOokl.mjs.map +1 -0
  131. package/dist/_chunks/sv-Be43LhA9.js +86 -0
  132. package/dist/_chunks/sv-Be43LhA9.js.map +1 -0
  133. package/dist/_chunks/th-DKyP7ueR.mjs +60 -0
  134. package/dist/_chunks/th-DKyP7ueR.mjs.map +1 -0
  135. package/dist/_chunks/th-DgVhVLhL.js +60 -0
  136. package/dist/_chunks/th-DgVhVLhL.js.map +1 -0
  137. package/dist/_chunks/tr-B_idhkEs.js +85 -0
  138. package/dist/_chunks/tr-B_idhkEs.js.map +1 -0
  139. package/dist/_chunks/tr-qa1Q5UjC.mjs +85 -0
  140. package/dist/_chunks/tr-qa1Q5UjC.mjs.map +1 -0
  141. package/dist/_chunks/uk-BmRqbeQc.mjs +49 -0
  142. package/dist/_chunks/uk-BmRqbeQc.mjs.map +1 -0
  143. package/dist/_chunks/uk-LHOivnhP.js +49 -0
  144. package/dist/_chunks/uk-LHOivnhP.js.map +1 -0
  145. package/dist/_chunks/vi-CdVRdKDw.js +50 -0
  146. package/dist/_chunks/vi-CdVRdKDw.js.map +1 -0
  147. package/dist/_chunks/vi-HW-EdMea.mjs +50 -0
  148. package/dist/_chunks/vi-HW-EdMea.mjs.map +1 -0
  149. package/dist/_chunks/zh-5hKkVPA4.mjs +86 -0
  150. package/dist/_chunks/zh-5hKkVPA4.mjs.map +1 -0
  151. package/dist/_chunks/zh-Cuq8gMnF.js +86 -0
  152. package/dist/_chunks/zh-Cuq8gMnF.js.map +1 -0
  153. package/dist/_chunks/zh-Hans-BHilK-yc.mjs +86 -0
  154. package/dist/_chunks/zh-Hans-BHilK-yc.mjs.map +1 -0
  155. package/dist/_chunks/zh-Hans-GQDMKtY4.js +86 -0
  156. package/dist/_chunks/zh-Hans-GQDMKtY4.js.map +1 -0
  157. package/dist/admin/index.js +4 -0
  158. package/dist/admin/index.js.map +1 -0
  159. package/dist/admin/index.mjs +5 -0
  160. package/dist/admin/index.mjs.map +1 -0
  161. package/package.json +45 -26
  162. package/packup.config.ts +22 -0
  163. package/server/bootstrap/index.js +18 -51
  164. package/server/bootstrap/users-permissions-actions.js +6 -0
  165. package/server/config.js +29 -0
  166. package/server/content-types/user/index.js +0 -1
  167. package/server/controllers/auth.js +48 -59
  168. package/server/controllers/content-manager-user.js +28 -30
  169. package/server/controllers/role.js +1 -1
  170. package/server/controllers/user.js +8 -9
  171. package/server/middlewares/rateLimit.js +1 -1
  172. package/server/register.js +1 -1
  173. package/server/services/jwt.js +3 -3
  174. package/server/services/permission.js +3 -7
  175. package/server/services/providers-registry.js +469 -261
  176. package/server/services/providers.js +10 -5
  177. package/server/services/role.js +15 -13
  178. package/server/services/user.js +56 -19
  179. package/server/services/users-permissions.js +15 -13
  180. package/server/utils/index.d.ts +2 -1
  181. package/server/utils/sanitize/sanitizers.js +7 -3
  182. package/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +2 -2
  183. package/.eslintrc.js +0 -14
  184. package/admin/src/components/FormModal/index.js +0 -126
  185. package/admin/src/components/Permissions/index.js +0 -55
  186. package/admin/src/pages/AdvancedSettings/index.js +0 -259
  187. package/admin/src/pages/EmailTemplates/components/EmailForm.js +0 -176
  188. package/admin/src/pages/Roles/index.js +0 -33
  189. package/admin/src/pages/Roles/pages/ListPage/utils/api.js +0 -30
  190. package/server/bootstrap/grant-config.js +0 -131
  191. package/strapi-admin.js +0 -3
  192. package/strapi-server.js +0 -3
  193. /package/admin/src/components/Permissions/PermissionRow/{index.js → index.jsx} +0 -0
  194. /package/admin/src/contexts/UsersPermissionsContext/{index.js → index.jsx} +0 -0
@@ -0,0 +1,638 @@
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 indexQPUYgtlo = require("./index-QPUYgtlo-QiBdpWEj.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-_vrdPeYp.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 forms = {
244
+ email: {
245
+ form: [
246
+ [
247
+ {
248
+ intlLabel: enabledLabel,
249
+ name: "enabled",
250
+ type: "bool",
251
+ description: enabledDescription,
252
+ size: 6
253
+ // TODO check if still needed
254
+ // validations: {
255
+ // required: true,
256
+ // },
257
+ }
258
+ ]
259
+ ],
260
+ schema: yup__namespace.object().shape({
261
+ enabled: yup__namespace.bool().required(admin.translatedErrors.required.id)
262
+ })
263
+ },
264
+ providers: {
265
+ form: [
266
+ [
267
+ {
268
+ intlLabel: enabledLabel,
269
+ name: "enabled",
270
+ type: "bool",
271
+ description: enabledDescription,
272
+ size: 6,
273
+ validations: {
274
+ required: true
275
+ }
276
+ }
277
+ ],
278
+ [
279
+ {
280
+ intlLabel: keyLabel,
281
+ name: "key",
282
+ type: "text",
283
+ placeholder: textPlaceholder,
284
+ size: 12,
285
+ validations: {
286
+ required: true
287
+ }
288
+ }
289
+ ],
290
+ [
291
+ {
292
+ intlLabel: secretLabel,
293
+ name: "secret",
294
+ type: "text",
295
+ placeholder: textPlaceholder,
296
+ size: 12,
297
+ validations: {
298
+ required: true
299
+ }
300
+ }
301
+ ],
302
+ [
303
+ {
304
+ intlLabel: callbackLabel,
305
+ placeholder: callbackPlaceholder,
306
+ name: "callback",
307
+ type: "text",
308
+ size: 12,
309
+ validations: {
310
+ required: true
311
+ }
312
+ }
313
+ ],
314
+ [
315
+ {
316
+ intlLabel: hintLabel,
317
+ name: "noName",
318
+ type: "text",
319
+ validations: {},
320
+ size: 12,
321
+ disabled: true
322
+ }
323
+ ]
324
+ ],
325
+ schema: yup__namespace.object().shape({
326
+ enabled: yup__namespace.bool().required(admin.translatedErrors.required.id),
327
+ key: yup__namespace.string().when("enabled", {
328
+ is: true,
329
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
330
+ otherwise: yup__namespace.string()
331
+ }),
332
+ secret: yup__namespace.string().when("enabled", {
333
+ is: true,
334
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
335
+ otherwise: yup__namespace.string()
336
+ }),
337
+ callback: yup__namespace.string().when("enabled", {
338
+ is: true,
339
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
340
+ otherwise: yup__namespace.string()
341
+ })
342
+ })
343
+ },
344
+ providersWithSubdomain: {
345
+ form: [
346
+ [
347
+ {
348
+ intlLabel: enabledLabel,
349
+ name: "enabled",
350
+ type: "bool",
351
+ description: enabledDescription,
352
+ size: 6,
353
+ validations: {
354
+ required: true
355
+ }
356
+ }
357
+ ],
358
+ [
359
+ {
360
+ intlLabel: keyLabel,
361
+ name: "key",
362
+ type: "text",
363
+ placeholder: textPlaceholder,
364
+ size: 12,
365
+ validations: {
366
+ required: true
367
+ }
368
+ }
369
+ ],
370
+ [
371
+ {
372
+ intlLabel: secretLabel,
373
+ name: "secret",
374
+ type: "text",
375
+ placeholder: textPlaceholder,
376
+ size: 12,
377
+ validations: {
378
+ required: true
379
+ }
380
+ }
381
+ ],
382
+ [
383
+ {
384
+ intlLabel: {
385
+ id: index.getTrad({ id: "PopUpForm.Providers.jwksurl.label" }),
386
+ defaultMessage: "JWKS URL"
387
+ },
388
+ name: "jwksurl",
389
+ type: "text",
390
+ placeholder: textPlaceholder,
391
+ size: 12,
392
+ validations: {
393
+ required: false
394
+ }
395
+ }
396
+ ],
397
+ [
398
+ {
399
+ intlLabel: {
400
+ id: index.getTrad("PopUpForm.Providers.subdomain.label"),
401
+ defaultMessage: "Host URI (Subdomain)"
402
+ },
403
+ name: "subdomain",
404
+ type: "text",
405
+ placeholder: {
406
+ id: index.getTrad("PopUpForm.Providers.subdomain.placeholder"),
407
+ defaultMessage: "my.subdomain.com"
408
+ },
409
+ size: 12,
410
+ validations: {
411
+ required: true
412
+ }
413
+ }
414
+ ],
415
+ [
416
+ {
417
+ intlLabel: callbackLabel,
418
+ placeholder: callbackPlaceholder,
419
+ name: "callback",
420
+ type: "text",
421
+ size: 12,
422
+ validations: {
423
+ required: true
424
+ }
425
+ }
426
+ ],
427
+ [
428
+ {
429
+ intlLabel: hintLabel,
430
+ name: "noName",
431
+ type: "text",
432
+ validations: {},
433
+ size: 12,
434
+ disabled: true
435
+ }
436
+ ]
437
+ ],
438
+ schema: yup__namespace.object().shape({
439
+ enabled: yup__namespace.bool().required(admin.translatedErrors.required.id),
440
+ key: yup__namespace.string().when("enabled", {
441
+ is: true,
442
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
443
+ otherwise: yup__namespace.string()
444
+ }),
445
+ secret: yup__namespace.string().when("enabled", {
446
+ is: true,
447
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
448
+ otherwise: yup__namespace.string()
449
+ }),
450
+ subdomain: yup__namespace.string().when("enabled", {
451
+ is: true,
452
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
453
+ otherwise: yup__namespace.string()
454
+ }),
455
+ callback: yup__namespace.string().when("enabled", {
456
+ is: true,
457
+ then: yup__namespace.string().required(admin.translatedErrors.required.id),
458
+ otherwise: yup__namespace.string()
459
+ })
460
+ })
461
+ }
462
+ };
463
+ const ProvidersPage = () => {
464
+ const { formatMessage, locale } = reactIntl.useIntl();
465
+ const queryClient = reactQuery.useQueryClient();
466
+ const { trackUsage } = indexQPUYgtlo.useTracking();
467
+ const [isOpen, setIsOpen] = React__namespace.useState(false);
468
+ const [providerToEditName, setProviderToEditName] = React__namespace.useState(null);
469
+ const { toggleNotification } = admin.useNotification();
470
+ const { get, put } = admin.useFetchClient();
471
+ const { formatAPIError } = admin.useAPIErrorHandler();
472
+ const formatter = designSystem.useCollator(locale, {
473
+ sensitivity: "base"
474
+ });
475
+ const {
476
+ isLoading: isLoadingPermissions,
477
+ allowedActions: { canUpdate }
478
+ } = admin.useRBAC({ update: index.PERMISSIONS.updateProviders });
479
+ const { isLoading: isLoadingData, data } = reactQuery.useQuery(
480
+ ["users-permissions", "get-providers"],
481
+ async () => {
482
+ const { data: data2 } = await get("/users-permissions/providers");
483
+ return data2;
484
+ },
485
+ {
486
+ initialData: {}
487
+ }
488
+ );
489
+ const submitMutation = reactQuery.useMutation((body) => put("/users-permissions/providers", body), {
490
+ async onSuccess() {
491
+ await queryClient.invalidateQueries(["users-permissions", "get-providers"]);
492
+ toggleNotification({
493
+ type: "success",
494
+ message: formatMessage({ id: index.getTrad("notification.success.submit") })
495
+ });
496
+ trackUsage("didEditAuthenticationProvider");
497
+ handleToggleModal();
498
+ },
499
+ onError(error) {
500
+ toggleNotification({
501
+ type: "danger",
502
+ message: formatAPIError(error)
503
+ });
504
+ },
505
+ refetchActive: false
506
+ });
507
+ const providers = Object.entries(data).reduce((acc, [name, provider]) => {
508
+ const { icon, enabled, subdomain } = provider;
509
+ acc.push({
510
+ name,
511
+ icon: icon === "envelope" ? ["fas", "envelope"] : ["fab", icon],
512
+ enabled,
513
+ subdomain
514
+ });
515
+ return acc;
516
+ }, []).sort((a, b) => formatter.compare(a.name, b.name));
517
+ const isLoading = isLoadingData || isLoadingPermissions;
518
+ const isProviderWithSubdomain = React__namespace.useMemo(() => {
519
+ if (!providerToEditName) {
520
+ return false;
521
+ }
522
+ const providerToEdit = providers.find((obj) => obj.name === providerToEditName);
523
+ return !!providerToEdit?.subdomain;
524
+ }, [providers, providerToEditName]);
525
+ const layoutToRender = React__namespace.useMemo(() => {
526
+ if (providerToEditName === "email") {
527
+ return forms.email;
528
+ }
529
+ if (isProviderWithSubdomain) {
530
+ return forms.providersWithSubdomain;
531
+ }
532
+ return forms.providers;
533
+ }, [providerToEditName, isProviderWithSubdomain]);
534
+ const handleToggleModal = () => {
535
+ setIsOpen((prev) => !prev);
536
+ };
537
+ const handleClickEdit = (provider) => {
538
+ if (canUpdate) {
539
+ setProviderToEditName(provider.name);
540
+ handleToggleModal();
541
+ }
542
+ };
543
+ const handleSubmit = async (values) => {
544
+ trackUsage("willEditAuthenticationProvider");
545
+ submitMutation.mutate({ providers: { ...data, [providerToEditName]: values } });
546
+ };
547
+ if (isLoading) {
548
+ return /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Loading, {});
549
+ }
550
+ return /* @__PURE__ */ jsxRuntime.jsxs(indexQPUYgtlo.Layouts.Root, { children: [
551
+ /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Title, { children: formatMessage(
552
+ { id: "Settings.PageTitle", defaultMessage: "Settings - {name}" },
553
+ {
554
+ name: formatMessage({
555
+ id: index.getTrad("HeaderNav.link.providers"),
556
+ defaultMessage: "Providers"
557
+ })
558
+ }
559
+ ) }),
560
+ /* @__PURE__ */ jsxRuntime.jsxs(admin.Page.Main, { children: [
561
+ /* @__PURE__ */ jsxRuntime.jsx(
562
+ indexQPUYgtlo.Layouts.Header,
563
+ {
564
+ title: formatMessage({
565
+ id: index.getTrad("HeaderNav.link.providers"),
566
+ defaultMessage: "Providers"
567
+ })
568
+ }
569
+ ),
570
+ /* @__PURE__ */ jsxRuntime.jsx(indexQPUYgtlo.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Table, { colCount: 3, rowCount: providers.length + 1, children: [
571
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Thead, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { children: [
572
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({ id: "global.name", defaultMessage: "Name" }) }) }),
573
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({ id: index.getTrad("Providers.status"), defaultMessage: "Status" }) }) }),
574
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.VisuallyHidden, { children: formatMessage({
575
+ id: "global.settings",
576
+ defaultMessage: "Settings"
577
+ }) }) }) })
578
+ ] }) }),
579
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Tbody, { children: providers.map((provider) => /* @__PURE__ */ jsxRuntime.jsxs(
580
+ designSystem.Tr,
581
+ {
582
+ onClick: () => canUpdate ? handleClickEdit(provider) : void 0,
583
+ children: [
584
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { width: "45%", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { fontWeight: "semiBold", textColor: "neutral800", children: provider.name }) }),
585
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { width: "65%", children: /* @__PURE__ */ jsxRuntime.jsx(
586
+ designSystem.Typography,
587
+ {
588
+ textColor: provider.enabled ? "success600" : "danger600",
589
+ "data-testid": `enable-${provider.name}`,
590
+ children: provider.enabled ? formatMessage({
591
+ id: "global.enabled",
592
+ defaultMessage: "Enabled"
593
+ }) : formatMessage({
594
+ id: "global.disabled",
595
+ defaultMessage: "Disabled"
596
+ })
597
+ }
598
+ ) }),
599
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { onClick: (e) => e.stopPropagation(), children: canUpdate && /* @__PURE__ */ jsxRuntime.jsx(
600
+ designSystem.IconButton,
601
+ {
602
+ onClick: () => handleClickEdit(provider),
603
+ variant: "ghost",
604
+ label: "Edit",
605
+ children: /* @__PURE__ */ jsxRuntime.jsx(icons.Pencil, {})
606
+ }
607
+ ) })
608
+ ]
609
+ },
610
+ provider.name
611
+ )) })
612
+ ] }) })
613
+ ] }),
614
+ /* @__PURE__ */ jsxRuntime.jsx(
615
+ FormModal,
616
+ {
617
+ initialData: data[providerToEditName],
618
+ isOpen,
619
+ isSubmiting: submitMutation.isLoading,
620
+ layout: layoutToRender,
621
+ headerBreadcrumbs: [
622
+ formatMessage({
623
+ id: index.getTrad("PopUpForm.header.edit.providers"),
624
+ defaultMessage: "Edit Provider"
625
+ }),
626
+ upperFirst__default.default(providerToEditName)
627
+ ],
628
+ onToggle: handleToggleModal,
629
+ onSubmit: handleSubmit,
630
+ providerToEditName
631
+ }
632
+ )
633
+ ] });
634
+ };
635
+ const ProtectedProvidersPage = () => /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Protect, { permissions: index.PERMISSIONS.readProviders, children: /* @__PURE__ */ jsxRuntime.jsx(ProvidersPage, {}) });
636
+ exports.ProvidersPage = ProvidersPage;
637
+ exports.default = ProtectedProvidersPage;
638
+ //# sourceMappingURL=index-cL_YxyjM.js.map