@strapi/plugin-users-permissions 0.0.0-next.fb3a0b82484ce466b1efb1b28f16fc8ef73aba4a → 0.0.0-next.fd9757603c653ca239c45d6e28ab536d2dae0b39

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 (157) hide show
  1. package/.eslintignore +1 -2
  2. package/.eslintrc +17 -0
  3. package/LICENSE +18 -3
  4. package/admin/src/index.js +5 -15
  5. package/admin/src/pages/Providers/{index.js → index.jsx} +1 -1
  6. package/dist/_chunks/ar-MvD8Ghac.mjs +44 -0
  7. package/dist/_chunks/ar-MvD8Ghac.mjs.map +1 -0
  8. package/dist/_chunks/ar-t5qTFaAD.js +44 -0
  9. package/dist/_chunks/ar-t5qTFaAD.js.map +1 -0
  10. package/dist/_chunks/cs-BMuXwxA1.mjs +50 -0
  11. package/dist/_chunks/cs-BMuXwxA1.mjs.map +1 -0
  12. package/dist/_chunks/cs-I8N4u-Sd.js +50 -0
  13. package/dist/_chunks/cs-I8N4u-Sd.js.map +1 -0
  14. package/dist/_chunks/de-YTjtq89K.js +62 -0
  15. package/dist/_chunks/de-YTjtq89K.js.map +1 -0
  16. package/dist/_chunks/de-zs2qqc0W.mjs +62 -0
  17. package/dist/_chunks/de-zs2qqc0W.mjs.map +1 -0
  18. package/dist/_chunks/dk-HctVBMsG.mjs +86 -0
  19. package/dist/_chunks/dk-HctVBMsG.mjs.map +1 -0
  20. package/dist/_chunks/dk-TF-dWjzl.js +86 -0
  21. package/dist/_chunks/dk-TF-dWjzl.js.map +1 -0
  22. package/dist/_chunks/en-CE3wEy_c.mjs +86 -0
  23. package/dist/_chunks/en-CE3wEy_c.mjs.map +1 -0
  24. package/dist/_chunks/en-m608rMZx.js +86 -0
  25. package/dist/_chunks/en-m608rMZx.js.map +1 -0
  26. package/dist/_chunks/es-9381tih_.mjs +86 -0
  27. package/dist/_chunks/es-9381tih_.mjs.map +1 -0
  28. package/dist/_chunks/es-XBQsB8_9.js +86 -0
  29. package/dist/_chunks/es-XBQsB8_9.js.map +1 -0
  30. package/dist/_chunks/fr-6cz3U-IF.js +50 -0
  31. package/dist/_chunks/fr-6cz3U-IF.js.map +1 -0
  32. package/dist/_chunks/fr-CMSc77If.mjs +50 -0
  33. package/dist/_chunks/fr-CMSc77If.mjs.map +1 -0
  34. package/dist/_chunks/id-RJ934rq-.js +62 -0
  35. package/dist/_chunks/id-RJ934rq-.js.map +1 -0
  36. package/dist/_chunks/id-SDuyIkZa.mjs +62 -0
  37. package/dist/_chunks/id-SDuyIkZa.mjs.map +1 -0
  38. package/dist/_chunks/index-7cDy9OFu.mjs +301 -0
  39. package/dist/_chunks/index-7cDy9OFu.mjs.map +1 -0
  40. package/dist/_chunks/index-F7bt_caK.mjs +1159 -0
  41. package/dist/_chunks/index-F7bt_caK.mjs.map +1 -0
  42. package/dist/_chunks/index-H1mhyWXP.mjs +385 -0
  43. package/dist/_chunks/index-H1mhyWXP.mjs.map +1 -0
  44. package/dist/_chunks/index-Uclk5uc0.mjs +250 -0
  45. package/dist/_chunks/index-Uclk5uc0.mjs.map +1 -0
  46. package/dist/_chunks/index-cNS7FpQt.js +320 -0
  47. package/dist/_chunks/index-cNS7FpQt.js.map +1 -0
  48. package/dist/_chunks/index-e4dnRonE.js +407 -0
  49. package/dist/_chunks/index-e4dnRonE.js.map +1 -0
  50. package/dist/_chunks/index-oFjO2L1S.mjs +615 -0
  51. package/dist/_chunks/index-oFjO2L1S.mjs.map +1 -0
  52. package/dist/_chunks/index-rU_BkerL.js +1191 -0
  53. package/dist/_chunks/index-rU_BkerL.js.map +1 -0
  54. package/dist/_chunks/index-sm9u2cPw.js +638 -0
  55. package/dist/_chunks/index-sm9u2cPw.js.map +1 -0
  56. package/dist/_chunks/index-vLWD-DRR.js +249 -0
  57. package/dist/_chunks/index-vLWD-DRR.js.map +1 -0
  58. package/dist/_chunks/it-YhZOlM2X.js +62 -0
  59. package/dist/_chunks/it-YhZOlM2X.js.map +1 -0
  60. package/dist/_chunks/it-bvH7DgQo.mjs +62 -0
  61. package/dist/_chunks/it-bvH7DgQo.mjs.map +1 -0
  62. package/dist/_chunks/ja-o_-JPvQv.mjs +48 -0
  63. package/dist/_chunks/ja-o_-JPvQv.mjs.map +1 -0
  64. package/dist/_chunks/ja-xssHUXFv.js +48 -0
  65. package/dist/_chunks/ja-xssHUXFv.js.map +1 -0
  66. package/dist/_chunks/ko-C3mHUSJa.js +86 -0
  67. package/dist/_chunks/ko-C3mHUSJa.js.map +1 -0
  68. package/dist/_chunks/ko-XJbPSez_.mjs +86 -0
  69. package/dist/_chunks/ko-XJbPSez_.mjs.map +1 -0
  70. package/dist/_chunks/ms-II5Ea73J.mjs +49 -0
  71. package/dist/_chunks/ms-II5Ea73J.mjs.map +1 -0
  72. package/dist/_chunks/ms-d0hfg65Z.js +49 -0
  73. package/dist/_chunks/ms-d0hfg65Z.js.map +1 -0
  74. package/dist/_chunks/nl-TA7TfK_5.js +48 -0
  75. package/dist/_chunks/nl-TA7TfK_5.js.map +1 -0
  76. package/dist/_chunks/nl-vEy6TN0K.mjs +48 -0
  77. package/dist/_chunks/nl-vEy6TN0K.mjs.map +1 -0
  78. package/dist/_chunks/pl-0pUL9hdA.js +86 -0
  79. package/dist/_chunks/pl-0pUL9hdA.js.map +1 -0
  80. package/dist/_chunks/pl-2VowaFGt.mjs +86 -0
  81. package/dist/_chunks/pl-2VowaFGt.mjs.map +1 -0
  82. package/dist/_chunks/pt-BR-WNOhafR4.js +44 -0
  83. package/dist/_chunks/pt-BR-WNOhafR4.js.map +1 -0
  84. package/dist/_chunks/pt-BR-sS1Xp3Jt.mjs +44 -0
  85. package/dist/_chunks/pt-BR-sS1Xp3Jt.mjs.map +1 -0
  86. package/dist/_chunks/pt-Rf9W51IO.mjs +48 -0
  87. package/dist/_chunks/pt-Rf9W51IO.mjs.map +1 -0
  88. package/dist/_chunks/pt-guNR9Gax.js +48 -0
  89. package/dist/_chunks/pt-guNR9Gax.js.map +1 -0
  90. package/dist/_chunks/ru-X3BMXDds.js +86 -0
  91. package/dist/_chunks/ru-X3BMXDds.js.map +1 -0
  92. package/dist/_chunks/ru-qKHnd5or.mjs +86 -0
  93. package/dist/_chunks/ru-qKHnd5or.mjs.map +1 -0
  94. package/dist/_chunks/sk-NWPw1oTN.js +50 -0
  95. package/dist/_chunks/sk-NWPw1oTN.js.map +1 -0
  96. package/dist/_chunks/sk-_Ryr-eTT.mjs +50 -0
  97. package/dist/_chunks/sk-_Ryr-eTT.mjs.map +1 -0
  98. package/dist/_chunks/sv-76NnbB__.js +86 -0
  99. package/dist/_chunks/sv-76NnbB__.js.map +1 -0
  100. package/dist/_chunks/sv-BqzScFXS.mjs +86 -0
  101. package/dist/_chunks/sv-BqzScFXS.mjs.map +1 -0
  102. package/dist/_chunks/th-WsknMEpq.mjs +60 -0
  103. package/dist/_chunks/th-WsknMEpq.mjs.map +1 -0
  104. package/dist/_chunks/th-cbppX21D.js +60 -0
  105. package/dist/_chunks/th-cbppX21D.js.map +1 -0
  106. package/dist/_chunks/tr-6mm_Fmz7.js +85 -0
  107. package/dist/_chunks/tr-6mm_Fmz7.js.map +1 -0
  108. package/dist/_chunks/tr-_DB1F1GW.mjs +85 -0
  109. package/dist/_chunks/tr-_DB1F1GW.mjs.map +1 -0
  110. package/dist/_chunks/uk-sI2I1ogF.js +49 -0
  111. package/dist/_chunks/uk-sI2I1ogF.js.map +1 -0
  112. package/dist/_chunks/uk-yxMSQAwI.mjs +49 -0
  113. package/dist/_chunks/uk-yxMSQAwI.mjs.map +1 -0
  114. package/dist/_chunks/vi-A3zJxaiI.js +50 -0
  115. package/dist/_chunks/vi-A3zJxaiI.js.map +1 -0
  116. package/dist/_chunks/vi-xY0zCW3d.mjs +50 -0
  117. package/dist/_chunks/vi-xY0zCW3d.mjs.map +1 -0
  118. package/dist/_chunks/zh-72SpmFXa.js +86 -0
  119. package/dist/_chunks/zh-72SpmFXa.js.map +1 -0
  120. package/dist/_chunks/zh-Hans-ArWWtyP4.js +86 -0
  121. package/dist/_chunks/zh-Hans-ArWWtyP4.js.map +1 -0
  122. package/dist/_chunks/zh-Hans-E84cu4kP.mjs +86 -0
  123. package/dist/_chunks/zh-Hans-E84cu4kP.mjs.map +1 -0
  124. package/dist/_chunks/zh-OFeldzbX.mjs +86 -0
  125. package/dist/_chunks/zh-OFeldzbX.mjs.map +1 -0
  126. package/dist/admin/index.js +5 -0
  127. package/dist/admin/index.js.map +1 -0
  128. package/dist/admin/index.mjs +6 -0
  129. package/dist/admin/index.mjs.map +1 -0
  130. package/package.json +33 -13
  131. package/packup.config.ts +22 -0
  132. package/server/bootstrap/grant-config.js +9 -0
  133. package/server/bootstrap/users-permissions-actions.js +6 -0
  134. package/server/config.js +29 -0
  135. package/server/controllers/auth.js +22 -4
  136. package/server/services/providers-registry.js +21 -2
  137. package/.eslintrc.js +0 -14
  138. package/strapi-admin.js +0 -3
  139. /package/admin/src/components/BoundRoute/{index.js → index.jsx} +0 -0
  140. /package/admin/src/components/FormModal/Input/{index.js → index.jsx} +0 -0
  141. /package/admin/src/components/FormModal/{index.js → index.jsx} +0 -0
  142. /package/admin/src/components/Permissions/PermissionRow/{CheckboxWrapper.js → CheckboxWrapper.jsx} +0 -0
  143. /package/admin/src/components/Permissions/PermissionRow/{SubCategory.js → SubCategory.jsx} +0 -0
  144. /package/admin/src/components/Permissions/PermissionRow/{index.js → index.jsx} +0 -0
  145. /package/admin/src/components/Permissions/{index.js → index.jsx} +0 -0
  146. /package/admin/src/components/Policies/{index.js → index.jsx} +0 -0
  147. /package/admin/src/components/UsersPermissions/{index.js → index.jsx} +0 -0
  148. /package/admin/src/contexts/UsersPermissionsContext/{index.js → index.jsx} +0 -0
  149. /package/admin/src/pages/AdvancedSettings/{index.js → index.jsx} +0 -0
  150. /package/admin/src/pages/EmailTemplates/components/{EmailForm.js → EmailForm.jsx} +0 -0
  151. /package/admin/src/pages/EmailTemplates/components/{EmailTable.js → EmailTable.jsx} +0 -0
  152. /package/admin/src/pages/EmailTemplates/{index.js → index.jsx} +0 -0
  153. /package/admin/src/pages/Roles/{index.js → index.jsx} +0 -0
  154. /package/admin/src/pages/Roles/pages/{CreatePage.js → CreatePage.jsx} +0 -0
  155. /package/admin/src/pages/Roles/pages/{EditPage.js → EditPage.jsx} +0 -0
  156. /package/admin/src/pages/Roles/pages/ListPage/components/{TableBody.js → TableBody.jsx} +0 -0
  157. /package/admin/src/pages/Roles/pages/ListPage/{index.js → index.jsx} +0 -0
@@ -201,10 +201,28 @@ module.exports = {
201
201
  }
202
202
 
203
203
  // Ability to pass OAuth callback dynamically
204
- grantConfig[provider].callback =
205
- _.get(ctx, 'query.callback') ||
206
- _.get(ctx, 'session.grant.dynamic.callback') ||
207
- grantConfig[provider].callback;
204
+ const queryCustomCallback = _.get(ctx, 'query.callback');
205
+ const dynamicSessionCallback = _.get(ctx, 'session.grant.dynamic.callback');
206
+
207
+ const customCallback = queryCustomCallback ?? dynamicSessionCallback;
208
+
209
+ // The custom callback is validated to make sure it's not redirecting to an unwanted actor.
210
+ if (customCallback !== undefined) {
211
+ try {
212
+ // We're extracting the callback validator from the plugin config since it can be user-customized
213
+ const { validate: validateCallback } = strapi
214
+ .plugin('users-permissions')
215
+ .config('callback');
216
+
217
+ await validateCallback(customCallback, grantConfig[provider]);
218
+
219
+ grantConfig[provider].callback = customCallback;
220
+ } catch (e) {
221
+ throw new ValidationError('Invalid callback URL provided', { callback: customCallback });
222
+ }
223
+ }
224
+
225
+ // Build a valid redirect URI for the current provider
208
226
  grantConfig[provider].redirect_uri = getService('providers').buildRedirectUri(provider);
209
227
 
210
228
  return grant(grantConfig)(ctx, next);
@@ -54,8 +54,11 @@ const getInitialProviders = ({ purest }) => ({
54
54
  .auth(accessToken)
55
55
  .request()
56
56
  .then(({ body }) => {
57
- // Combine username and discriminator because discord username is not unique
58
- const username = `${body.username}#${body.discriminator}`;
57
+ // Combine username and discriminator (if discriminator exists and not equal to 0)
58
+ const username =
59
+ body.discriminator && body.discriminator !== '0'
60
+ ? `${body.username}#${body.discriminator}`
61
+ : body.username;
59
62
  return {
60
63
  username,
61
64
  email: body.email,
@@ -311,6 +314,7 @@ const getInitialProviders = ({ purest }) => ({
311
314
  origin: 'https://www.patreon.com',
312
315
  path: 'api/oauth2/{path}',
313
316
  headers: {
317
+ 'user-agent': 'strapi',
314
318
  authorization: 'Bearer {auth}',
315
319
  },
316
320
  },
@@ -331,6 +335,21 @@ const getInitialProviders = ({ purest }) => ({
331
335
  };
332
336
  });
333
337
  },
338
+ async keycloak({ accessToken, providers }) {
339
+ const keycloak = purest({ provider: 'keycloak' });
340
+
341
+ return keycloak
342
+ .subdomain(providers.keycloak.subdomain)
343
+ .get('protocol/openid-connect/userinfo')
344
+ .auth(accessToken)
345
+ .request()
346
+ .then(({ body }) => {
347
+ return {
348
+ username: body.preferred_username,
349
+ email: body.email,
350
+ };
351
+ });
352
+ },
334
353
  });
335
354
 
336
355
  module.exports = () => {
package/.eslintrc.js DELETED
@@ -1,14 +0,0 @@
1
- module.exports = {
2
- root: true,
3
- overrides: [
4
- {
5
- files: ['admin/**/*'],
6
- extends: ['custom/front'],
7
- },
8
- {
9
- files: ['**/*'],
10
- excludedFiles: ['admin/**/*'],
11
- extends: ['custom/back'],
12
- },
13
- ],
14
- };
package/strapi-admin.js DELETED
@@ -1,3 +0,0 @@
1
- 'use strict';
2
-
3
- module.exports = require('./admin/src').default;
File without changes