@strapi/plugin-users-permissions 0.0.0-next.f5b09a8e61e059f02784478e27c310c6290be088 → 0.0.0-next.f698d55751345c4ca87477ef683475c1a68f310a

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