@strapi/plugin-users-permissions 0.0.0-next.f7babb775ed9a7e18d8351cb7f74c63e016323c4 → 0.0.0-next.f93d6eabe52aa7681655cfa08eedbc3708dbb90d

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 (660) hide show
  1. package/.eslintignore +2 -2
  2. package/.eslintrc +17 -0
  3. package/LICENSE +18 -3
  4. package/admin/src/components/BoundRoute/{index.js → index.jsx} +3 -3
  5. package/admin/src/components/FormModal/Input/{index.js → index.jsx} +33 -32
  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} +8 -6
  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 +21 -49
  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} +21 -18
  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/pluginId.js +2 -2
  32. package/admin/src/translations/en.json +1 -1
  33. package/admin/src/translations/uk.json +41 -4
  34. package/admin/src/translations/zh-Hans.json +80 -80
  35. package/admin/src/utils/prefixPluginTranslations.js +13 -0
  36. package/dist/admin/components/BoundRoute/getMethodColor.js +49 -0
  37. package/dist/admin/components/BoundRoute/getMethodColor.js.map +1 -0
  38. package/dist/admin/components/BoundRoute/getMethodColor.mjs +47 -0
  39. package/dist/admin/components/BoundRoute/getMethodColor.mjs.map +1 -0
  40. package/dist/admin/components/BoundRoute/index.js +98 -0
  41. package/dist/admin/components/BoundRoute/index.js.map +1 -0
  42. package/dist/admin/components/BoundRoute/index.mjs +96 -0
  43. package/dist/admin/components/BoundRoute/index.mjs.map +1 -0
  44. package/dist/admin/components/FormModal/Input/index.js +123 -0
  45. package/dist/admin/components/FormModal/Input/index.js.map +1 -0
  46. package/dist/admin/components/FormModal/Input/index.mjs +121 -0
  47. package/dist/admin/components/FormModal/Input/index.mjs.map +1 -0
  48. package/dist/admin/components/FormModal/index.js +110 -0
  49. package/dist/admin/components/FormModal/index.js.map +1 -0
  50. package/dist/admin/components/FormModal/index.mjs +108 -0
  51. package/dist/admin/components/FormModal/index.mjs.map +1 -0
  52. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.js +33 -0
  53. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.js.map +1 -0
  54. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.mjs +31 -0
  55. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.mjs.map +1 -0
  56. package/dist/admin/components/Permissions/PermissionRow/SubCategory.js +156 -0
  57. package/dist/admin/components/Permissions/PermissionRow/SubCategory.js.map +1 -0
  58. package/dist/admin/components/Permissions/PermissionRow/SubCategory.mjs +154 -0
  59. package/dist/admin/components/Permissions/PermissionRow/SubCategory.mjs.map +1 -0
  60. package/dist/admin/components/Permissions/PermissionRow/index.js +50 -0
  61. package/dist/admin/components/Permissions/PermissionRow/index.js.map +1 -0
  62. package/dist/admin/components/Permissions/PermissionRow/index.mjs +48 -0
  63. package/dist/admin/components/Permissions/PermissionRow/index.mjs.map +1 -0
  64. package/dist/admin/components/Permissions/index.js +52 -0
  65. package/dist/admin/components/Permissions/index.js.map +1 -0
  66. package/dist/admin/components/Permissions/index.mjs +50 -0
  67. package/dist/admin/components/Permissions/index.mjs.map +1 -0
  68. package/dist/admin/components/Permissions/init.js +15 -0
  69. package/dist/admin/components/Permissions/init.js.map +1 -0
  70. package/dist/admin/components/Permissions/init.mjs +13 -0
  71. package/dist/admin/components/Permissions/init.mjs.map +1 -0
  72. package/dist/admin/components/Permissions/reducer.js +34 -0
  73. package/dist/admin/components/Permissions/reducer.js.map +1 -0
  74. package/dist/admin/components/Permissions/reducer.mjs +31 -0
  75. package/dist/admin/components/Permissions/reducer.mjs.map +1 -0
  76. package/dist/admin/components/Policies/index.js +67 -0
  77. package/dist/admin/components/Policies/index.js.map +1 -0
  78. package/dist/admin/components/Policies/index.mjs +65 -0
  79. package/dist/admin/components/Policies/index.mjs.map +1 -0
  80. package/dist/admin/components/UsersPermissions/index.js +115 -0
  81. package/dist/admin/components/UsersPermissions/index.js.map +1 -0
  82. package/dist/admin/components/UsersPermissions/index.mjs +113 -0
  83. package/dist/admin/components/UsersPermissions/index.mjs.map +1 -0
  84. package/dist/admin/components/UsersPermissions/init.js +13 -0
  85. package/dist/admin/components/UsersPermissions/init.js.map +1 -0
  86. package/dist/admin/components/UsersPermissions/init.mjs +11 -0
  87. package/dist/admin/components/UsersPermissions/init.mjs.map +1 -0
  88. package/dist/admin/components/UsersPermissions/reducer.js +73 -0
  89. package/dist/admin/components/UsersPermissions/reducer.js.map +1 -0
  90. package/dist/admin/components/UsersPermissions/reducer.mjs +68 -0
  91. package/dist/admin/components/UsersPermissions/reducer.mjs.map +1 -0
  92. package/dist/admin/constants.js +81 -0
  93. package/dist/admin/constants.js.map +1 -0
  94. package/dist/admin/constants.mjs +79 -0
  95. package/dist/admin/constants.mjs.map +1 -0
  96. package/dist/admin/contexts/UsersPermissionsContext/index.js +23 -0
  97. package/dist/admin/contexts/UsersPermissionsContext/index.js.map +1 -0
  98. package/dist/admin/contexts/UsersPermissionsContext/index.mjs +19 -0
  99. package/dist/admin/contexts/UsersPermissionsContext/index.mjs.map +1 -0
  100. package/dist/admin/index.js +125 -0
  101. package/dist/admin/index.js.map +1 -0
  102. package/dist/admin/index.mjs +121 -0
  103. package/dist/admin/index.mjs.map +1 -0
  104. package/dist/admin/package.json.js +14 -0
  105. package/dist/admin/package.json.js.map +1 -0
  106. package/dist/admin/package.json.mjs +11 -0
  107. package/dist/admin/package.json.mjs.map +1 -0
  108. package/dist/admin/pages/AdvancedSettings/index.js +194 -0
  109. package/dist/admin/pages/AdvancedSettings/index.js.map +1 -0
  110. package/dist/admin/pages/AdvancedSettings/index.mjs +191 -0
  111. package/dist/admin/pages/AdvancedSettings/index.mjs.map +1 -0
  112. package/dist/admin/pages/AdvancedSettings/utils/layout.js +83 -0
  113. package/dist/admin/pages/AdvancedSettings/utils/layout.js.map +1 -0
  114. package/dist/admin/pages/AdvancedSettings/utils/layout.mjs +81 -0
  115. package/dist/admin/pages/AdvancedSettings/utils/layout.mjs.map +1 -0
  116. package/dist/admin/pages/AdvancedSettings/utils/schema.js +40 -0
  117. package/dist/admin/pages/AdvancedSettings/utils/schema.js.map +1 -0
  118. package/dist/admin/pages/AdvancedSettings/utils/schema.mjs +19 -0
  119. package/dist/admin/pages/AdvancedSettings/utils/schema.mjs.map +1 -0
  120. package/dist/admin/pages/EmailTemplates/components/EmailForm.js +171 -0
  121. package/dist/admin/pages/EmailTemplates/components/EmailForm.js.map +1 -0
  122. package/dist/admin/pages/EmailTemplates/components/EmailForm.mjs +169 -0
  123. package/dist/admin/pages/EmailTemplates/components/EmailForm.mjs.map +1 -0
  124. package/dist/admin/pages/EmailTemplates/components/EmailTable.js +145 -0
  125. package/dist/admin/pages/EmailTemplates/components/EmailTable.js.map +1 -0
  126. package/dist/admin/pages/EmailTemplates/components/EmailTable.mjs +143 -0
  127. package/dist/admin/pages/EmailTemplates/components/EmailTable.mjs.map +1 -0
  128. package/dist/admin/pages/EmailTemplates/index.js +157 -0
  129. package/dist/admin/pages/EmailTemplates/index.js.map +1 -0
  130. package/dist/admin/pages/EmailTemplates/index.mjs +135 -0
  131. package/dist/admin/pages/EmailTemplates/index.mjs.map +1 -0
  132. package/dist/admin/pages/EmailTemplates/utils/schema.js +50 -0
  133. package/dist/admin/pages/EmailTemplates/utils/schema.js.map +1 -0
  134. package/dist/admin/pages/EmailTemplates/utils/schema.mjs +29 -0
  135. package/dist/admin/pages/EmailTemplates/utils/schema.mjs.map +1 -0
  136. package/dist/admin/pages/Providers/index.js +278 -0
  137. package/dist/admin/pages/Providers/index.js.map +1 -0
  138. package/dist/admin/pages/Providers/index.mjs +254 -0
  139. package/dist/admin/pages/Providers/index.mjs.map +1 -0
  140. package/dist/admin/pages/Providers/utils/forms.js +281 -0
  141. package/dist/admin/pages/Providers/utils/forms.js.map +1 -0
  142. package/dist/admin/pages/Providers/utils/forms.mjs +260 -0
  143. package/dist/admin/pages/Providers/utils/forms.mjs.map +1 -0
  144. package/dist/admin/pages/Roles/constants.js +31 -0
  145. package/dist/admin/pages/Roles/constants.js.map +1 -0
  146. package/dist/admin/pages/Roles/constants.mjs +10 -0
  147. package/dist/admin/pages/Roles/constants.mjs.map +1 -0
  148. package/dist/admin/pages/Roles/hooks/usePlugins.js +78 -0
  149. package/dist/admin/pages/Roles/hooks/usePlugins.js.map +1 -0
  150. package/dist/admin/pages/Roles/hooks/usePlugins.mjs +76 -0
  151. package/dist/admin/pages/Roles/hooks/usePlugins.mjs.map +1 -0
  152. package/dist/admin/pages/Roles/index.js +35 -0
  153. package/dist/admin/pages/Roles/index.js.map +1 -0
  154. package/dist/admin/pages/Roles/index.mjs +33 -0
  155. package/dist/admin/pages/Roles/index.mjs.map +1 -0
  156. package/dist/admin/pages/Roles/pages/CreatePage.js +225 -0
  157. package/dist/admin/pages/Roles/pages/CreatePage.js.map +1 -0
  158. package/dist/admin/pages/Roles/pages/CreatePage.mjs +203 -0
  159. package/dist/admin/pages/Roles/pages/CreatePage.mjs.map +1 -0
  160. package/dist/admin/pages/Roles/pages/EditPage.js +229 -0
  161. package/dist/admin/pages/Roles/pages/EditPage.js.map +1 -0
  162. package/dist/admin/pages/Roles/pages/EditPage.mjs +207 -0
  163. package/dist/admin/pages/Roles/pages/EditPage.mjs.map +1 -0
  164. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.js +125 -0
  165. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.js.map +1 -0
  166. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.mjs +123 -0
  167. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.mjs.map +1 -0
  168. package/dist/admin/pages/Roles/pages/ListPage/index.js +237 -0
  169. package/dist/admin/pages/Roles/pages/ListPage/index.js.map +1 -0
  170. package/dist/admin/pages/Roles/pages/ListPage/index.mjs +234 -0
  171. package/dist/admin/pages/Roles/pages/ListPage/index.mjs.map +1 -0
  172. package/dist/admin/pluginId.js +8 -0
  173. package/dist/admin/pluginId.js.map +1 -0
  174. package/dist/admin/pluginId.mjs +6 -0
  175. package/dist/admin/pluginId.mjs.map +1 -0
  176. package/dist/admin/translations/ar.json.js +45 -0
  177. package/dist/admin/translations/ar.json.js.map +1 -0
  178. package/dist/admin/translations/ar.json.mjs +43 -0
  179. package/dist/admin/translations/ar.json.mjs.map +1 -0
  180. package/dist/admin/translations/cs.json.js +51 -0
  181. package/dist/admin/translations/cs.json.js.map +1 -0
  182. package/dist/admin/translations/cs.json.mjs +49 -0
  183. package/dist/admin/translations/cs.json.mjs.map +1 -0
  184. package/dist/admin/translations/de.json.js +63 -0
  185. package/dist/admin/translations/de.json.js.map +1 -0
  186. package/dist/admin/translations/de.json.mjs +61 -0
  187. package/dist/admin/translations/de.json.mjs.map +1 -0
  188. package/dist/admin/translations/dk.json.js +87 -0
  189. package/dist/admin/translations/dk.json.js.map +1 -0
  190. package/dist/admin/translations/dk.json.mjs +85 -0
  191. package/dist/admin/translations/dk.json.mjs.map +1 -0
  192. package/dist/admin/translations/en.json.js +87 -0
  193. package/dist/admin/translations/en.json.js.map +1 -0
  194. package/dist/admin/translations/en.json.mjs +85 -0
  195. package/dist/admin/translations/en.json.mjs.map +1 -0
  196. package/dist/admin/translations/es.json.js +87 -0
  197. package/dist/admin/translations/es.json.js.map +1 -0
  198. package/dist/admin/translations/es.json.mjs +85 -0
  199. package/dist/admin/translations/es.json.mjs.map +1 -0
  200. package/dist/admin/translations/fr.json.js +51 -0
  201. package/dist/admin/translations/fr.json.js.map +1 -0
  202. package/dist/admin/translations/fr.json.mjs +49 -0
  203. package/dist/admin/translations/fr.json.mjs.map +1 -0
  204. package/dist/admin/translations/id.json.js +63 -0
  205. package/dist/admin/translations/id.json.js.map +1 -0
  206. package/dist/admin/translations/id.json.mjs +61 -0
  207. package/dist/admin/translations/id.json.mjs.map +1 -0
  208. package/dist/admin/translations/it.json.js +63 -0
  209. package/dist/admin/translations/it.json.js.map +1 -0
  210. package/dist/admin/translations/it.json.mjs +61 -0
  211. package/dist/admin/translations/it.json.mjs.map +1 -0
  212. package/dist/admin/translations/ja.json.js +49 -0
  213. package/dist/admin/translations/ja.json.js.map +1 -0
  214. package/dist/admin/translations/ja.json.mjs +47 -0
  215. package/dist/admin/translations/ja.json.mjs.map +1 -0
  216. package/dist/admin/translations/ko.json.js +87 -0
  217. package/dist/admin/translations/ko.json.js.map +1 -0
  218. package/dist/admin/translations/ko.json.mjs +85 -0
  219. package/dist/admin/translations/ko.json.mjs.map +1 -0
  220. package/dist/admin/translations/ms.json.js +50 -0
  221. package/dist/admin/translations/ms.json.js.map +1 -0
  222. package/dist/admin/translations/ms.json.mjs +48 -0
  223. package/dist/admin/translations/ms.json.mjs.map +1 -0
  224. package/dist/admin/translations/nl.json.js +49 -0
  225. package/dist/admin/translations/nl.json.js.map +1 -0
  226. package/dist/admin/translations/nl.json.mjs +47 -0
  227. package/dist/admin/translations/nl.json.mjs.map +1 -0
  228. package/dist/admin/translations/pl.json.js +87 -0
  229. package/dist/admin/translations/pl.json.js.map +1 -0
  230. package/dist/admin/translations/pl.json.mjs +85 -0
  231. package/dist/admin/translations/pl.json.mjs.map +1 -0
  232. package/dist/admin/translations/pt-BR.json.js +45 -0
  233. package/dist/admin/translations/pt-BR.json.js.map +1 -0
  234. package/dist/admin/translations/pt-BR.json.mjs +43 -0
  235. package/dist/admin/translations/pt-BR.json.mjs.map +1 -0
  236. package/dist/admin/translations/pt.json.js +49 -0
  237. package/dist/admin/translations/pt.json.js.map +1 -0
  238. package/dist/admin/translations/pt.json.mjs +47 -0
  239. package/dist/admin/translations/pt.json.mjs.map +1 -0
  240. package/dist/admin/translations/ru.json.js +87 -0
  241. package/dist/admin/translations/ru.json.js.map +1 -0
  242. package/dist/admin/translations/ru.json.mjs +85 -0
  243. package/dist/admin/translations/ru.json.mjs.map +1 -0
  244. package/dist/admin/translations/sk.json.js +51 -0
  245. package/dist/admin/translations/sk.json.js.map +1 -0
  246. package/dist/admin/translations/sk.json.mjs +49 -0
  247. package/dist/admin/translations/sk.json.mjs.map +1 -0
  248. package/dist/admin/translations/sv.json.js +87 -0
  249. package/dist/admin/translations/sv.json.js.map +1 -0
  250. package/dist/admin/translations/sv.json.mjs +85 -0
  251. package/dist/admin/translations/sv.json.mjs.map +1 -0
  252. package/dist/admin/translations/th.json.js +61 -0
  253. package/dist/admin/translations/th.json.js.map +1 -0
  254. package/dist/admin/translations/th.json.mjs +59 -0
  255. package/dist/admin/translations/th.json.mjs.map +1 -0
  256. package/dist/admin/translations/tr.json.js +86 -0
  257. package/dist/admin/translations/tr.json.js.map +1 -0
  258. package/dist/admin/translations/tr.json.mjs +84 -0
  259. package/dist/admin/translations/tr.json.mjs.map +1 -0
  260. package/dist/admin/translations/uk.json.js +87 -0
  261. package/dist/admin/translations/uk.json.js.map +1 -0
  262. package/dist/admin/translations/uk.json.mjs +85 -0
  263. package/dist/admin/translations/uk.json.mjs.map +1 -0
  264. package/dist/admin/translations/vi.json.js +51 -0
  265. package/dist/admin/translations/vi.json.js.map +1 -0
  266. package/dist/admin/translations/vi.json.mjs +49 -0
  267. package/dist/admin/translations/vi.json.mjs.map +1 -0
  268. package/dist/admin/translations/zh-Hans.json.js +87 -0
  269. package/dist/admin/translations/zh-Hans.json.js.map +1 -0
  270. package/dist/admin/translations/zh-Hans.json.mjs +85 -0
  271. package/dist/admin/translations/zh-Hans.json.mjs.map +1 -0
  272. package/dist/admin/translations/zh.json.js +87 -0
  273. package/dist/admin/translations/zh.json.js.map +1 -0
  274. package/dist/admin/translations/zh.json.mjs +85 -0
  275. package/dist/admin/translations/zh.json.mjs.map +1 -0
  276. package/dist/admin/utils/cleanPermissions.js +24 -0
  277. package/dist/admin/utils/cleanPermissions.js.map +1 -0
  278. package/dist/admin/utils/cleanPermissions.mjs +22 -0
  279. package/dist/admin/utils/cleanPermissions.mjs.map +1 -0
  280. package/dist/admin/utils/formatPluginName.js +29 -0
  281. package/dist/admin/utils/formatPluginName.js.map +1 -0
  282. package/dist/admin/utils/formatPluginName.mjs +27 -0
  283. package/dist/admin/utils/formatPluginName.mjs.map +1 -0
  284. package/dist/admin/utils/getTrad.js +8 -0
  285. package/dist/admin/utils/getTrad.js.map +1 -0
  286. package/dist/admin/utils/getTrad.mjs +6 -0
  287. package/dist/admin/utils/getTrad.mjs.map +1 -0
  288. package/dist/admin/utils/prefixPluginTranslations.js +11 -0
  289. package/dist/admin/utils/prefixPluginTranslations.js.map +1 -0
  290. package/dist/admin/utils/prefixPluginTranslations.mjs +9 -0
  291. package/dist/admin/utils/prefixPluginTranslations.mjs.map +1 -0
  292. package/dist/server/_virtual/_commonjsHelpers.js +8 -0
  293. package/dist/server/_virtual/_commonjsHelpers.js.map +1 -0
  294. package/dist/server/_virtual/_commonjsHelpers.mjs +6 -0
  295. package/dist/server/_virtual/_commonjsHelpers.mjs.map +1 -0
  296. package/dist/server/bootstrap/index.js +145 -0
  297. package/dist/server/bootstrap/index.js.map +1 -0
  298. package/dist/server/bootstrap/index.mjs +143 -0
  299. package/dist/server/bootstrap/index.mjs.map +1 -0
  300. package/dist/server/bootstrap/users-permissions-actions.js +98 -0
  301. package/dist/server/bootstrap/users-permissions-actions.js.map +1 -0
  302. package/dist/server/bootstrap/users-permissions-actions.mjs +96 -0
  303. package/dist/server/bootstrap/users-permissions-actions.mjs.map +1 -0
  304. package/dist/server/config.js +54 -0
  305. package/dist/server/config.js.map +1 -0
  306. package/dist/server/config.mjs +52 -0
  307. package/dist/server/config.mjs.map +1 -0
  308. package/dist/server/content-types/index.js +30 -0
  309. package/dist/server/content-types/index.js.map +1 -0
  310. package/dist/server/content-types/index.mjs +28 -0
  311. package/dist/server/content-types/index.mjs.map +1 -0
  312. package/dist/server/content-types/permission/index.js +44 -0
  313. package/dist/server/content-types/permission/index.js.map +1 -0
  314. package/dist/server/content-types/permission/index.mjs +42 -0
  315. package/dist/server/content-types/permission/index.mjs.map +1 -0
  316. package/dist/server/content-types/role/index.js +61 -0
  317. package/dist/server/content-types/role/index.js.map +1 -0
  318. package/dist/server/content-types/role/index.mjs +59 -0
  319. package/dist/server/content-types/role/index.mjs.map +1 -0
  320. package/dist/server/content-types/user/index.js +84 -0
  321. package/dist/server/content-types/user/index.js.map +1 -0
  322. package/dist/server/content-types/user/index.mjs +82 -0
  323. package/dist/server/content-types/user/index.mjs.map +1 -0
  324. package/dist/server/content-types/user/schema-config.js +25 -0
  325. package/dist/server/content-types/user/schema-config.js.map +1 -0
  326. package/dist/server/content-types/user/schema-config.mjs +23 -0
  327. package/dist/server/content-types/user/schema-config.mjs.map +1 -0
  328. package/dist/server/controllers/auth.js +429 -0
  329. package/dist/server/controllers/auth.js.map +1 -0
  330. package/dist/server/controllers/auth.mjs +427 -0
  331. package/dist/server/controllers/auth.mjs.map +1 -0
  332. package/dist/server/controllers/content-manager-user.js +168 -0
  333. package/dist/server/controllers/content-manager-user.js.map +1 -0
  334. package/dist/server/controllers/content-manager-user.mjs +166 -0
  335. package/dist/server/controllers/content-manager-user.mjs.map +1 -0
  336. package/dist/server/controllers/index.js +33 -0
  337. package/dist/server/controllers/index.js.map +1 -0
  338. package/dist/server/controllers/index.mjs +31 -0
  339. package/dist/server/controllers/index.mjs.map +1 -0
  340. package/dist/server/controllers/permissions.js +37 -0
  341. package/dist/server/controllers/permissions.js.map +1 -0
  342. package/dist/server/controllers/permissions.mjs +35 -0
  343. package/dist/server/controllers/permissions.mjs.map +1 -0
  344. package/dist/server/controllers/role.js +91 -0
  345. package/dist/server/controllers/role.js.map +1 -0
  346. package/dist/server/controllers/role.mjs +89 -0
  347. package/dist/server/controllers/role.mjs.map +1 -0
  348. package/dist/server/controllers/settings.js +107 -0
  349. package/dist/server/controllers/settings.js.map +1 -0
  350. package/dist/server/controllers/settings.mjs +105 -0
  351. package/dist/server/controllers/settings.mjs.map +1 -0
  352. package/dist/server/controllers/user.js +201 -0
  353. package/dist/server/controllers/user.js.map +1 -0
  354. package/dist/server/controllers/user.mjs +199 -0
  355. package/dist/server/controllers/user.mjs.map +1 -0
  356. package/dist/server/controllers/validation/auth.js +131 -0
  357. package/dist/server/controllers/validation/auth.js.map +1 -0
  358. package/dist/server/controllers/validation/auth.mjs +129 -0
  359. package/dist/server/controllers/validation/auth.mjs.map +1 -0
  360. package/dist/server/controllers/validation/email-template.js +72 -0
  361. package/dist/server/controllers/validation/email-template.js.map +1 -0
  362. package/dist/server/controllers/validation/email-template.mjs +70 -0
  363. package/dist/server/controllers/validation/email-template.mjs.map +1 -0
  364. package/dist/server/controllers/validation/user.js +49 -0
  365. package/dist/server/controllers/validation/user.js.map +1 -0
  366. package/dist/server/controllers/validation/user.mjs +47 -0
  367. package/dist/server/controllers/validation/user.mjs.map +1 -0
  368. package/dist/server/graphql/index.js +66 -0
  369. package/dist/server/graphql/index.js.map +1 -0
  370. package/dist/server/graphql/index.mjs +64 -0
  371. package/dist/server/graphql/index.mjs.map +1 -0
  372. package/dist/server/graphql/mutations/auth/change-password.js +40 -0
  373. package/dist/server/graphql/mutations/auth/change-password.js.map +1 -0
  374. package/dist/server/graphql/mutations/auth/change-password.mjs +38 -0
  375. package/dist/server/graphql/mutations/auth/change-password.mjs.map +1 -0
  376. package/dist/server/graphql/mutations/auth/email-confirmation.js +38 -0
  377. package/dist/server/graphql/mutations/auth/email-confirmation.js.map +1 -0
  378. package/dist/server/graphql/mutations/auth/email-confirmation.mjs +36 -0
  379. package/dist/server/graphql/mutations/auth/email-confirmation.mjs.map +1 -0
  380. package/dist/server/graphql/mutations/auth/forgot-password.js +37 -0
  381. package/dist/server/graphql/mutations/auth/forgot-password.js.map +1 -0
  382. package/dist/server/graphql/mutations/auth/forgot-password.mjs +35 -0
  383. package/dist/server/graphql/mutations/auth/forgot-password.mjs.map +1 -0
  384. package/dist/server/graphql/mutations/auth/login.js +40 -0
  385. package/dist/server/graphql/mutations/auth/login.js.map +1 -0
  386. package/dist/server/graphql/mutations/auth/login.mjs +38 -0
  387. package/dist/server/graphql/mutations/auth/login.mjs.map +1 -0
  388. package/dist/server/graphql/mutations/auth/register.js +38 -0
  389. package/dist/server/graphql/mutations/auth/register.js.map +1 -0
  390. package/dist/server/graphql/mutations/auth/register.mjs +36 -0
  391. package/dist/server/graphql/mutations/auth/register.mjs.map +1 -0
  392. package/dist/server/graphql/mutations/auth/reset-password.js +40 -0
  393. package/dist/server/graphql/mutations/auth/reset-password.js.map +1 -0
  394. package/dist/server/graphql/mutations/auth/reset-password.mjs +38 -0
  395. package/dist/server/graphql/mutations/auth/reset-password.mjs.map +1 -0
  396. package/dist/server/graphql/mutations/crud/role/create-role.js +37 -0
  397. package/dist/server/graphql/mutations/crud/role/create-role.js.map +1 -0
  398. package/dist/server/graphql/mutations/crud/role/create-role.mjs +35 -0
  399. package/dist/server/graphql/mutations/crud/role/create-role.mjs.map +1 -0
  400. package/dist/server/graphql/mutations/crud/role/delete-role.js +32 -0
  401. package/dist/server/graphql/mutations/crud/role/delete-role.js.map +1 -0
  402. package/dist/server/graphql/mutations/crud/role/delete-role.mjs +30 -0
  403. package/dist/server/graphql/mutations/crud/role/delete-role.mjs.map +1 -0
  404. package/dist/server/graphql/mutations/crud/role/update-role.js +39 -0
  405. package/dist/server/graphql/mutations/crud/role/update-role.js.map +1 -0
  406. package/dist/server/graphql/mutations/crud/role/update-role.mjs +37 -0
  407. package/dist/server/graphql/mutations/crud/role/update-role.mjs.map +1 -0
  408. package/dist/server/graphql/mutations/crud/user/create-user.js +46 -0
  409. package/dist/server/graphql/mutations/crud/user/create-user.js.map +1 -0
  410. package/dist/server/graphql/mutations/crud/user/create-user.mjs +44 -0
  411. package/dist/server/graphql/mutations/crud/user/create-user.mjs.map +1 -0
  412. package/dist/server/graphql/mutations/crud/user/delete-user.js +44 -0
  413. package/dist/server/graphql/mutations/crud/user/delete-user.js.map +1 -0
  414. package/dist/server/graphql/mutations/crud/user/delete-user.mjs +42 -0
  415. package/dist/server/graphql/mutations/crud/user/delete-user.mjs.map +1 -0
  416. package/dist/server/graphql/mutations/crud/user/update-user.js +49 -0
  417. package/dist/server/graphql/mutations/crud/user/update-user.js.map +1 -0
  418. package/dist/server/graphql/mutations/crud/user/update-user.mjs +47 -0
  419. package/dist/server/graphql/mutations/crud/user/update-user.mjs.map +1 -0
  420. package/dist/server/graphql/mutations/index.js +58 -0
  421. package/dist/server/graphql/mutations/index.js.map +1 -0
  422. package/dist/server/graphql/mutations/index.mjs +56 -0
  423. package/dist/server/graphql/mutations/index.mjs.map +1 -0
  424. package/dist/server/graphql/queries/index.js +25 -0
  425. package/dist/server/graphql/queries/index.js.map +1 -0
  426. package/dist/server/graphql/queries/index.mjs +23 -0
  427. package/dist/server/graphql/queries/index.mjs.map +1 -0
  428. package/dist/server/graphql/queries/me.js +23 -0
  429. package/dist/server/graphql/queries/me.js.map +1 -0
  430. package/dist/server/graphql/queries/me.mjs +21 -0
  431. package/dist/server/graphql/queries/me.mjs.map +1 -0
  432. package/dist/server/graphql/resolvers-configs.js +93 -0
  433. package/dist/server/graphql/resolvers-configs.js.map +1 -0
  434. package/dist/server/graphql/resolvers-configs.mjs +91 -0
  435. package/dist/server/graphql/resolvers-configs.mjs.map +1 -0
  436. package/dist/server/graphql/types/create-role-payload.js +20 -0
  437. package/dist/server/graphql/types/create-role-payload.js.map +1 -0
  438. package/dist/server/graphql/types/create-role-payload.mjs +18 -0
  439. package/dist/server/graphql/types/create-role-payload.mjs.map +1 -0
  440. package/dist/server/graphql/types/delete-role-payload.js +20 -0
  441. package/dist/server/graphql/types/delete-role-payload.js.map +1 -0
  442. package/dist/server/graphql/types/delete-role-payload.mjs +18 -0
  443. package/dist/server/graphql/types/delete-role-payload.mjs.map +1 -0
  444. package/dist/server/graphql/types/index.js +41 -0
  445. package/dist/server/graphql/types/index.js.map +1 -0
  446. package/dist/server/graphql/types/index.mjs +39 -0
  447. package/dist/server/graphql/types/index.mjs.map +1 -0
  448. package/dist/server/graphql/types/login-input.js +24 -0
  449. package/dist/server/graphql/types/login-input.js.map +1 -0
  450. package/dist/server/graphql/types/login-input.mjs +22 -0
  451. package/dist/server/graphql/types/login-input.mjs.map +1 -0
  452. package/dist/server/graphql/types/login-payload.js +23 -0
  453. package/dist/server/graphql/types/login-payload.js.map +1 -0
  454. package/dist/server/graphql/types/login-payload.mjs +21 -0
  455. package/dist/server/graphql/types/login-payload.mjs.map +1 -0
  456. package/dist/server/graphql/types/me-role.js +23 -0
  457. package/dist/server/graphql/types/me-role.js.map +1 -0
  458. package/dist/server/graphql/types/me-role.mjs +21 -0
  459. package/dist/server/graphql/types/me-role.mjs.map +1 -0
  460. package/dist/server/graphql/types/me.js +28 -0
  461. package/dist/server/graphql/types/me.js.map +1 -0
  462. package/dist/server/graphql/types/me.mjs +26 -0
  463. package/dist/server/graphql/types/me.mjs.map +1 -0
  464. package/dist/server/graphql/types/password-payload.js +20 -0
  465. package/dist/server/graphql/types/password-payload.js.map +1 -0
  466. package/dist/server/graphql/types/password-payload.mjs +18 -0
  467. package/dist/server/graphql/types/password-payload.mjs.map +1 -0
  468. package/dist/server/graphql/types/register-input.js +22 -0
  469. package/dist/server/graphql/types/register-input.js.map +1 -0
  470. package/dist/server/graphql/types/register-input.mjs +20 -0
  471. package/dist/server/graphql/types/register-input.mjs.map +1 -0
  472. package/dist/server/graphql/types/update-role-payload.js +20 -0
  473. package/dist/server/graphql/types/update-role-payload.js.map +1 -0
  474. package/dist/server/graphql/types/update-role-payload.mjs +18 -0
  475. package/dist/server/graphql/types/update-role-payload.mjs.map +1 -0
  476. package/dist/server/graphql/types/user-input.js +26 -0
  477. package/dist/server/graphql/types/user-input.js.map +1 -0
  478. package/dist/server/graphql/types/user-input.mjs +24 -0
  479. package/dist/server/graphql/types/user-input.mjs.map +1 -0
  480. package/dist/server/graphql/utils.js +32 -0
  481. package/dist/server/graphql/utils.js.map +1 -0
  482. package/dist/server/graphql/utils.mjs +30 -0
  483. package/dist/server/graphql/utils.mjs.map +1 -0
  484. package/dist/server/index.js +10 -0
  485. package/dist/server/index.js.map +1 -0
  486. package/dist/server/index.mjs +8 -0
  487. package/dist/server/index.mjs.map +1 -0
  488. package/dist/server/index2.js +39 -0
  489. package/dist/server/index2.js.map +1 -0
  490. package/dist/server/index2.mjs +37 -0
  491. package/dist/server/index2.mjs.map +1 -0
  492. package/dist/server/middlewares/index.js +18 -0
  493. package/dist/server/middlewares/index.js.map +1 -0
  494. package/dist/server/middlewares/index.mjs +16 -0
  495. package/dist/server/middlewares/index.mjs.map +1 -0
  496. package/dist/server/middlewares/rateLimit.js +51 -0
  497. package/dist/server/middlewares/rateLimit.js.map +1 -0
  498. package/dist/server/middlewares/rateLimit.mjs +49 -0
  499. package/dist/server/middlewares/rateLimit.mjs.map +1 -0
  500. package/dist/server/register.js +41 -0
  501. package/dist/server/register.js.map +1 -0
  502. package/dist/server/register.mjs +39 -0
  503. package/dist/server/register.mjs.map +1 -0
  504. package/dist/server/routes/admin/index.js +27 -0
  505. package/dist/server/routes/admin/index.js.map +1 -0
  506. package/dist/server/routes/admin/index.mjs +25 -0
  507. package/dist/server/routes/admin/index.mjs.map +1 -0
  508. package/dist/server/routes/admin/permissions.js +29 -0
  509. package/dist/server/routes/admin/permissions.js.map +1 -0
  510. package/dist/server/routes/admin/permissions.mjs +27 -0
  511. package/dist/server/routes/admin/permissions.mjs.map +1 -0
  512. package/dist/server/routes/admin/role.js +99 -0
  513. package/dist/server/routes/admin/role.js.map +1 -0
  514. package/dist/server/routes/admin/role.mjs +97 -0
  515. package/dist/server/routes/admin/role.mjs.map +1 -0
  516. package/dist/server/routes/admin/settings.js +116 -0
  517. package/dist/server/routes/admin/settings.js.map +1 -0
  518. package/dist/server/routes/admin/settings.mjs +114 -0
  519. package/dist/server/routes/admin/settings.mjs.map +1 -0
  520. package/dist/server/routes/content-api/auth.js +104 -0
  521. package/dist/server/routes/content-api/auth.js.map +1 -0
  522. package/dist/server/routes/content-api/auth.mjs +102 -0
  523. package/dist/server/routes/content-api/auth.mjs.map +1 -0
  524. package/dist/server/routes/content-api/index.js +30 -0
  525. package/dist/server/routes/content-api/index.js.map +1 -0
  526. package/dist/server/routes/content-api/index.mjs +28 -0
  527. package/dist/server/routes/content-api/index.mjs.map +1 -0
  528. package/dist/server/routes/content-api/permissions.js +19 -0
  529. package/dist/server/routes/content-api/permissions.js.map +1 -0
  530. package/dist/server/routes/content-api/permissions.mjs +17 -0
  531. package/dist/server/routes/content-api/permissions.mjs.map +1 -0
  532. package/dist/server/routes/content-api/role.js +39 -0
  533. package/dist/server/routes/content-api/role.js.map +1 -0
  534. package/dist/server/routes/content-api/role.mjs +37 -0
  535. package/dist/server/routes/content-api/role.mjs.map +1 -0
  536. package/dist/server/routes/content-api/user.js +70 -0
  537. package/dist/server/routes/content-api/user.js.map +1 -0
  538. package/dist/server/routes/content-api/user.mjs +68 -0
  539. package/dist/server/routes/content-api/user.mjs.map +1 -0
  540. package/dist/server/routes/index.js +19 -0
  541. package/dist/server/routes/index.js.map +1 -0
  542. package/dist/server/routes/index.mjs +17 -0
  543. package/dist/server/routes/index.mjs.map +1 -0
  544. package/dist/server/services/index.js +36 -0
  545. package/dist/server/services/index.js.map +1 -0
  546. package/dist/server/services/index.mjs +34 -0
  547. package/dist/server/services/index.mjs.map +1 -0
  548. package/dist/server/services/jwt.js +50 -0
  549. package/dist/server/services/jwt.js.map +1 -0
  550. package/dist/server/services/jwt.mjs +48 -0
  551. package/dist/server/services/jwt.mjs.map +1 -0
  552. package/dist/server/services/permission.js +52 -0
  553. package/dist/server/services/permission.js.map +1 -0
  554. package/dist/server/services/permission.mjs +50 -0
  555. package/dist/server/services/permission.mjs.map +1 -0
  556. package/dist/server/services/providers-registry.js +555 -0
  557. package/dist/server/services/providers-registry.js.map +1 -0
  558. package/dist/server/services/providers-registry.mjs +553 -0
  559. package/dist/server/services/providers-registry.mjs.map +1 -0
  560. package/dist/server/services/providers.js +111 -0
  561. package/dist/server/services/providers.js.map +1 -0
  562. package/dist/server/services/providers.mjs +109 -0
  563. package/dist/server/services/providers.mjs.map +1 -0
  564. package/dist/server/services/role.js +186 -0
  565. package/dist/server/services/role.js.map +1 -0
  566. package/dist/server/services/role.mjs +184 -0
  567. package/dist/server/services/role.mjs.map +1 -0
  568. package/dist/server/services/user.js +179 -0
  569. package/dist/server/services/user.js.map +1 -0
  570. package/dist/server/services/user.mjs +177 -0
  571. package/dist/server/services/user.mjs.map +1 -0
  572. package/dist/server/services/users-permissions.js +247 -0
  573. package/dist/server/services/users-permissions.js.map +1 -0
  574. package/dist/server/services/users-permissions.mjs +245 -0
  575. package/dist/server/services/users-permissions.mjs.map +1 -0
  576. package/dist/server/strategies/users-permissions.js +114 -0
  577. package/dist/server/strategies/users-permissions.js.map +1 -0
  578. package/dist/server/strategies/users-permissions.mjs +112 -0
  579. package/dist/server/strategies/users-permissions.mjs.map +1 -0
  580. package/dist/server/utils/index.js +22 -0
  581. package/dist/server/utils/index.js.map +1 -0
  582. package/dist/server/utils/index.mjs +20 -0
  583. package/dist/server/utils/index.mjs.map +1 -0
  584. package/dist/server/utils/sanitize/index.js +21 -0
  585. package/dist/server/utils/sanitize/index.js.map +1 -0
  586. package/dist/server/utils/sanitize/index.mjs +19 -0
  587. package/dist/server/utils/sanitize/index.mjs.map +1 -0
  588. package/dist/server/utils/sanitize/sanitizers.js +32 -0
  589. package/dist/server/utils/sanitize/sanitizers.js.map +1 -0
  590. package/dist/server/utils/sanitize/sanitizers.mjs +30 -0
  591. package/dist/server/utils/sanitize/sanitizers.mjs.map +1 -0
  592. package/dist/server/utils/sanitize/visitors/index.js +17 -0
  593. package/dist/server/utils/sanitize/visitors/index.js.map +1 -0
  594. package/dist/server/utils/sanitize/visitors/index.mjs +15 -0
  595. package/dist/server/utils/sanitize/visitors/index.mjs.map +1 -0
  596. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +17 -0
  597. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js.map +1 -0
  598. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.mjs +15 -0
  599. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.mjs.map +1 -0
  600. package/documentation/content-api.yaml +1 -1
  601. package/jest.config.front.js +1 -1
  602. package/package.json +48 -29
  603. package/rollup.config.mjs +19 -0
  604. package/server/bootstrap/index.js +18 -15
  605. package/server/bootstrap/users-permissions-actions.js +6 -0
  606. package/server/config.js +29 -0
  607. package/server/content-types/user/index.js +0 -1
  608. package/server/controllers/auth.js +75 -39
  609. package/server/controllers/content-manager-user.js +28 -30
  610. package/server/controllers/role.js +17 -4
  611. package/server/controllers/user.js +18 -8
  612. package/server/controllers/validation/auth.js +104 -25
  613. package/server/graphql/types/index.js +1 -0
  614. package/server/graphql/types/me.js +1 -0
  615. package/server/graphql/types/user-input.js +20 -0
  616. package/server/middlewares/rateLimit.js +2 -2
  617. package/server/register.js +2 -2
  618. package/server/services/jwt.js +3 -3
  619. package/server/services/permission.js +3 -7
  620. package/server/services/providers-registry.js +469 -261
  621. package/server/services/providers.js +10 -5
  622. package/server/services/role.js +15 -13
  623. package/server/services/user.js +56 -19
  624. package/server/services/users-permissions.js +15 -13
  625. package/server/utils/index.d.ts +2 -1
  626. package/server/utils/sanitize/sanitizers.js +7 -3
  627. package/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +2 -2
  628. package/.eslintrc.js +0 -14
  629. package/admin/src/components/FormModal/index.js +0 -126
  630. package/admin/src/components/Permissions/index.js +0 -57
  631. package/admin/src/hooks/index.js +0 -5
  632. package/admin/src/hooks/useFetchRole/index.js +0 -67
  633. package/admin/src/hooks/useFetchRole/reducer.js +0 -31
  634. package/admin/src/hooks/useForm/index.js +0 -68
  635. package/admin/src/hooks/useForm/reducer.js +0 -40
  636. package/admin/src/hooks/useRolesList/index.js +0 -65
  637. package/admin/src/hooks/useRolesList/init.js +0 -5
  638. package/admin/src/hooks/useRolesList/reducer.js +0 -31
  639. package/admin/src/pages/AdvancedSettings/index.js +0 -242
  640. package/admin/src/pages/AdvancedSettings/utils/api.js +0 -16
  641. package/admin/src/pages/EmailTemplates/components/EmailForm.js +0 -176
  642. package/admin/src/pages/EmailTemplates/index.js +0 -159
  643. package/admin/src/pages/EmailTemplates/utils/api.js +0 -16
  644. package/admin/src/pages/Providers/index.js +0 -271
  645. package/admin/src/pages/Providers/reducer.js +0 -54
  646. package/admin/src/pages/Providers/utils/api.js +0 -24
  647. package/admin/src/pages/Providers/utils/createProvidersArray.js +0 -21
  648. package/admin/src/pages/Roles/CreatePage.js +0 -185
  649. package/admin/src/pages/Roles/EditPage.js +0 -197
  650. package/admin/src/pages/Roles/ListPage/components/TableBody.js +0 -93
  651. package/admin/src/pages/Roles/ListPage/utils/api.js +0 -30
  652. package/admin/src/pages/Roles/ProtectedCreatePage.js +0 -15
  653. package/admin/src/pages/Roles/ProtectedEditPage.js +0 -15
  654. package/admin/src/pages/Roles/ProtectedListPage.js +0 -17
  655. package/admin/src/pages/Roles/index.js +0 -30
  656. package/server/bootstrap/grant-config.js +0 -131
  657. package/strapi-admin.js +0 -3
  658. package/strapi-server.js +0 -3
  659. /package/admin/src/components/Permissions/PermissionRow/{index.js → index.jsx} +0 -0
  660. /package/admin/src/contexts/UsersPermissionsContext/{index.js → index.jsx} +0 -0
@@ -2,6 +2,7 @@
2
2
 
3
3
  const { strict: assert } = require('assert');
4
4
  const jwt = require('jsonwebtoken');
5
+ const urljoin = require('url-join');
5
6
  const jwkToPem = require('jwk-to-pem');
6
7
 
7
8
  const getCognitoPayload = async ({ idToken, jwksUrl, purest }) => {
@@ -45,315 +46,522 @@ const getCognitoPayload = async ({ idToken, jwksUrl, purest }) => {
45
46
  }
46
47
  };
47
48
 
48
- const getInitialProviders = ({ purest }) => ({
49
- async discord({ accessToken }) {
50
- const discord = purest({ provider: 'discord' });
51
-
52
- return discord
53
- .get('users/@me')
54
- .auth(accessToken)
55
- .request()
56
- .then(({ body }) => {
57
- // Combine username and discriminator because discord username is not unique
58
- const username = `${body.username}#${body.discriminator}`;
59
- return {
60
- username,
61
- email: body.email,
62
- };
63
- });
49
+ const initProviders = ({ baseURL, purest }) => ({
50
+ email: {
51
+ enabled: true,
52
+ icon: 'envelope',
53
+ grantConfig: {},
64
54
  },
65
- async cognito({ query, providers }) {
66
- const jwksUrl = new URL(providers.cognito.jwksurl);
67
- const idToken = query.id_token;
68
- const tokenPayload = await getCognitoPayload({ idToken, jwksUrl, purest });
69
- return {
70
- username: tokenPayload['cognito:username'],
71
- email: tokenPayload.email,
72
- };
55
+ discord: {
56
+ enabled: false,
57
+ icon: 'discord',
58
+ grantConfig: {
59
+ key: '',
60
+ secret: '',
61
+ callbackUrl: `${baseURL}/discord/callback`,
62
+ scope: ['identify', 'email'],
63
+ },
64
+ async authCallback({ accessToken }) {
65
+ const discord = purest({ provider: 'discord' });
66
+
67
+ return discord
68
+ .get('users/@me')
69
+ .auth(accessToken)
70
+ .request()
71
+ .then(({ body }) => {
72
+ // Combine username and discriminator (if discriminator exists and not equal to 0)
73
+ const username =
74
+ body.discriminator && body.discriminator !== '0'
75
+ ? `${body.username}#${body.discriminator}`
76
+ : body.username;
77
+ return {
78
+ username,
79
+ email: body.email,
80
+ };
81
+ });
82
+ },
73
83
  },
74
- async facebook({ accessToken }) {
75
- const facebook = purest({ provider: 'facebook' });
76
-
77
- return facebook
78
- .get('me')
79
- .auth(accessToken)
80
- .qs({ fields: 'name,email' })
81
- .request()
82
- .then(({ body }) => ({
83
- username: body.name,
84
- email: body.email,
85
- }));
84
+ facebook: {
85
+ enabled: false,
86
+ icon: 'facebook-square',
87
+ grantConfig: {
88
+ key: '',
89
+ secret: '',
90
+ callbackUrl: `${baseURL}/facebook/callback`,
91
+ scope: ['email'],
92
+ },
93
+ async authCallback({ accessToken }) {
94
+ const facebook = purest({ provider: 'facebook' });
95
+
96
+ return facebook
97
+ .get('me')
98
+ .auth(accessToken)
99
+ .qs({ fields: 'name,email' })
100
+ .request()
101
+ .then(({ body }) => ({
102
+ username: body.name,
103
+ email: body.email,
104
+ }));
105
+ },
86
106
  },
87
- async google({ accessToken }) {
88
- const google = purest({ provider: 'google' });
89
-
90
- return google
91
- .query('oauth')
92
- .get('tokeninfo')
93
- .qs({ accessToken })
94
- .request()
95
- .then(({ body }) => ({
96
- username: body.email.split('@')[0],
97
- email: body.email,
98
- }));
107
+ google: {
108
+ enabled: false,
109
+ icon: 'google',
110
+ grantConfig: {
111
+ key: '',
112
+ secret: '',
113
+ callbackUrl: `${baseURL}/google/callback`,
114
+ scope: ['email'],
115
+ },
116
+ async authCallback({ accessToken }) {
117
+ const google = purest({ provider: 'google' });
118
+
119
+ return google
120
+ .query('oauth')
121
+ .get('tokeninfo')
122
+ .qs({ accessToken })
123
+ .request()
124
+ .then(({ body }) => ({
125
+ username: body.email.split('@')[0],
126
+ email: body.email,
127
+ }));
128
+ },
99
129
  },
100
- async github({ accessToken }) {
101
- const github = purest({
102
- provider: 'github',
103
- defaults: {
104
- headers: {
105
- 'user-agent': 'strapi',
130
+ github: {
131
+ enabled: false,
132
+ icon: 'github',
133
+ grantConfig: {
134
+ key: '',
135
+ secret: '',
136
+ callbackUrl: `${baseURL}/github/callback`,
137
+ scope: ['user', 'user:email'],
138
+ },
139
+ async authCallback({ accessToken }) {
140
+ const github = purest({
141
+ provider: 'github',
142
+ defaults: {
143
+ headers: {
144
+ 'user-agent': 'strapi',
145
+ },
106
146
  },
107
- },
108
- });
147
+ });
109
148
 
110
- const { body: userBody } = await github.get('user').auth(accessToken).request();
149
+ const { body: userBody } = await github.get('user').auth(accessToken).request();
150
+
151
+ // This is the public email on the github profile
152
+ if (userBody.email) {
153
+ return {
154
+ username: userBody.login,
155
+ email: userBody.email,
156
+ };
157
+ }
158
+ // Get the email with Github's user/emails API
159
+ const { body: emailBody } = await github.get('user/emails').auth(accessToken).request();
111
160
 
112
- // This is the public email on the github profile
113
- if (userBody.email) {
114
161
  return {
115
162
  username: userBody.login,
116
- email: userBody.email,
163
+ email: Array.isArray(emailBody)
164
+ ? emailBody.find((email) => email.primary === true).email
165
+ : null,
117
166
  };
118
- }
119
- // Get the email with Github's user/emails API
120
- const { body: emailBody } = await github.get('user/emails').auth(accessToken).request();
121
-
122
- return {
123
- username: userBody.login,
124
- email: Array.isArray(emailBody)
125
- ? emailBody.find((email) => email.primary === true).email
126
- : null,
127
- };
167
+ },
128
168
  },
129
- async microsoft({ accessToken }) {
130
- const microsoft = purest({ provider: 'microsoft' });
131
-
132
- return microsoft
133
- .get('me')
134
- .auth(accessToken)
135
- .request()
136
- .then(({ body }) => ({
137
- username: body.userPrincipalName,
138
- email: body.userPrincipalName,
139
- }));
169
+ microsoft: {
170
+ enabled: false,
171
+ icon: 'windows',
172
+ grantConfig: {
173
+ key: '',
174
+ secret: '',
175
+ callbackUrl: `${baseURL}/microsoft/callback`,
176
+ scope: ['user.read'],
177
+ },
178
+ async authCallback({ accessToken }) {
179
+ const microsoft = purest({ provider: 'microsoft' });
180
+
181
+ return microsoft
182
+ .get('me')
183
+ .auth(accessToken)
184
+ .request()
185
+ .then(({ body }) => ({
186
+ username: body.userPrincipalName,
187
+ email: body.userPrincipalName,
188
+ }));
189
+ },
140
190
  },
141
- async twitter({ accessToken, query, providers }) {
142
- const twitter = purest({
143
- provider: 'twitter',
144
- defaults: {
145
- oauth: {
146
- consumer_key: providers.twitter.key,
147
- consumer_secret: providers.twitter.secret,
191
+
192
+ twitter: {
193
+ enabled: false,
194
+ icon: 'twitter',
195
+ grantConfig: {
196
+ key: '',
197
+ secret: '',
198
+ callbackUrl: `${baseURL}/twitter/callback`,
199
+ },
200
+ async authCallback({ accessToken, query, providers }) {
201
+ const twitter = purest({
202
+ provider: 'twitter',
203
+ defaults: {
204
+ oauth: {
205
+ consumer_key: providers.twitter.key,
206
+ consumer_secret: providers.twitter.secret,
207
+ },
148
208
  },
149
- },
150
- });
209
+ });
151
210
 
152
- return twitter
153
- .get('account/verify_credentials')
154
- .auth(accessToken, query.access_secret)
155
- .qs({ screen_name: query['raw[screen_name]'], include_email: 'true' })
156
- .request()
157
- .then(({ body }) => ({
158
- username: body.screen_name,
159
- email: body.email,
160
- }));
211
+ return twitter
212
+ .get('account/verify_credentials')
213
+ .auth(accessToken, query.access_secret)
214
+ .qs({ screen_name: query['raw[screen_name]'], include_email: 'true' })
215
+ .request()
216
+ .then(({ body }) => ({
217
+ username: body.screen_name,
218
+ email: body.email,
219
+ }));
220
+ },
161
221
  },
162
- async instagram({ accessToken }) {
163
- const instagram = purest({ provider: 'instagram' });
164
-
165
- return instagram
166
- .get('me')
167
- .auth(accessToken)
168
- .qs({ fields: 'id,username' })
169
- .request()
170
- .then(({ body }) => ({
171
- username: body.username,
172
- email: `${body.username}@strapi.io`, // dummy email as Instagram does not provide user email
173
- }));
222
+ instagram: {
223
+ enabled: false,
224
+ icon: 'instagram',
225
+ grantConfig: {
226
+ key: '',
227
+ secret: '',
228
+ callbackUrl: `${baseURL}/instagram/callback`,
229
+ scope: ['user_profile'],
230
+ },
231
+ async authCallback({ accessToken }) {
232
+ const instagram = purest({ provider: 'instagram' });
233
+
234
+ return instagram
235
+ .get('me')
236
+ .auth(accessToken)
237
+ .qs({ fields: 'id,username' })
238
+ .request()
239
+ .then(({ body }) => ({
240
+ username: body.username,
241
+ email: `${body.username}@strapi.io`, // dummy email as Instagram does not provide user email
242
+ }));
243
+ },
174
244
  },
175
- async vk({ accessToken, query }) {
176
- const vk = purest({ provider: 'vk' });
177
-
178
- return vk
179
- .get('users')
180
- .auth(accessToken)
181
- .qs({ id: query.raw.user_id, v: '5.122' })
182
- .request()
183
- .then(({ body }) => ({
184
- username: `${body.response[0].last_name} ${body.response[0].first_name}`,
185
- email: query.raw.email,
186
- }));
245
+ vk: {
246
+ enabled: false,
247
+ icon: 'vk',
248
+ grantConfig: {
249
+ key: '',
250
+ secret: '',
251
+ callbackUrl: `${baseURL}/vk/callback`,
252
+ scope: ['email'],
253
+ },
254
+ async authCallback({ accessToken, query }) {
255
+ const vk = purest({ provider: 'vk' });
256
+
257
+ return vk
258
+ .get('users')
259
+ .auth(accessToken)
260
+ .qs({ id: query.raw.user_id, v: '5.122' })
261
+ .request()
262
+ .then(({ body }) => ({
263
+ username: `${body.response[0].last_name} ${body.response[0].first_name}`,
264
+ email: query.raw.email,
265
+ }));
266
+ },
187
267
  },
188
- async twitch({ accessToken, providers }) {
189
- const twitch = purest({
190
- provider: 'twitch',
191
- config: {
192
- twitch: {
193
- default: {
194
- origin: 'https://api.twitch.tv',
195
- path: 'helix/{path}',
196
- headers: {
197
- Authorization: 'Bearer {auth}',
198
- 'Client-Id': '{auth}',
268
+
269
+ twitch: {
270
+ enabled: false,
271
+ icon: 'twitch',
272
+ grantConfig: {
273
+ key: '',
274
+ secret: '',
275
+ callbackUrl: `${baseURL}/twitch/callback`,
276
+ scope: ['user:read:email'],
277
+ },
278
+ async authCallback({ accessToken, providers }) {
279
+ const twitch = purest({
280
+ provider: 'twitch',
281
+ config: {
282
+ twitch: {
283
+ default: {
284
+ origin: 'https://api.twitch.tv',
285
+ path: 'helix/{path}',
286
+ headers: {
287
+ Authorization: 'Bearer {auth}',
288
+ 'Client-Id': '{auth}',
289
+ },
199
290
  },
200
291
  },
201
292
  },
202
- },
203
- });
293
+ });
204
294
 
205
- return twitch
206
- .get('users')
207
- .auth(accessToken, providers.twitch.key)
208
- .request()
209
- .then(({ body }) => ({
210
- username: body.data[0].login,
211
- email: body.data[0].email,
212
- }));
295
+ return twitch
296
+ .get('users')
297
+ .auth(accessToken, providers.twitch.key)
298
+ .request()
299
+ .then(({ body }) => ({
300
+ username: body.data[0].login,
301
+ email: body.data[0].email,
302
+ }));
303
+ },
213
304
  },
214
- async linkedin({ accessToken }) {
215
- const linkedIn = purest({ provider: 'linkedin' });
216
- const {
217
- body: { localizedFirstName },
218
- } = await linkedIn.get('me').auth(accessToken).request();
219
- const {
220
- body: { elements },
221
- } = await linkedIn
222
- .get('emailAddress?q=members&projection=(elements*(handle~))')
223
- .auth(accessToken)
224
- .request();
225
-
226
- const email = elements[0]['handle~'];
227
-
228
- return {
229
- username: localizedFirstName,
230
- email: email.emailAddress,
231
- };
305
+
306
+ linkedin: {
307
+ enabled: false,
308
+ icon: 'linkedin',
309
+ grantConfig: {
310
+ key: '',
311
+ secret: '',
312
+ callbackUrl: `${baseURL}/linkedin/callback`,
313
+ scope: ['r_liteprofile', 'r_emailaddress'],
314
+ },
315
+ async authCallback({ accessToken }) {
316
+ const linkedIn = purest({ provider: 'linkedin' });
317
+ const {
318
+ body: { localizedFirstName },
319
+ } = await linkedIn.get('me').auth(accessToken).request();
320
+ const {
321
+ body: { elements },
322
+ } = await linkedIn
323
+ .get('emailAddress?q=members&projection=(elements*(handle~))')
324
+ .auth(accessToken)
325
+ .request();
326
+
327
+ const email = elements[0]['handle~'];
328
+
329
+ return {
330
+ username: localizedFirstName,
331
+ email: email.emailAddress,
332
+ };
333
+ },
232
334
  },
233
- async reddit({ accessToken }) {
234
- const reddit = purest({
235
- provider: 'reddit',
236
- config: {
237
- reddit: {
238
- default: {
239
- origin: 'https://oauth.reddit.com',
240
- path: 'api/{version}/{path}',
241
- version: 'v1',
242
- headers: {
243
- Authorization: 'Bearer {auth}',
244
- 'user-agent': 'strapi',
335
+
336
+ cognito: {
337
+ enabled: false,
338
+ icon: 'aws',
339
+ grantConfig: {
340
+ key: '',
341
+ secret: '',
342
+ subdomain: 'my.subdomain.com',
343
+ callback: `${baseURL}/cognito/callback`,
344
+ scope: ['email', 'openid', 'profile'],
345
+ },
346
+ async authCallback({ query, providers }) {
347
+ const jwksUrl = new URL(providers.cognito.jwksurl);
348
+ const idToken = query.id_token;
349
+ const tokenPayload = await getCognitoPayload({ idToken, jwksUrl, purest });
350
+ return {
351
+ username: tokenPayload['cognito:username'],
352
+ email: tokenPayload.email,
353
+ };
354
+ },
355
+ },
356
+
357
+ reddit: {
358
+ enabled: false,
359
+ icon: 'reddit',
360
+ grantConfig: {
361
+ key: '',
362
+ secret: '',
363
+ callback: `${baseURL}/reddit/callback`,
364
+ scope: ['identity'],
365
+ },
366
+ async authCallback({ accessToken }) {
367
+ const reddit = purest({
368
+ provider: 'reddit',
369
+ config: {
370
+ reddit: {
371
+ default: {
372
+ origin: 'https://oauth.reddit.com',
373
+ path: 'api/{version}/{path}',
374
+ version: 'v1',
375
+ headers: {
376
+ Authorization: 'Bearer {auth}',
377
+ 'user-agent': 'strapi',
378
+ },
245
379
  },
246
380
  },
247
381
  },
248
- },
249
- });
382
+ });
250
383
 
251
- return reddit
252
- .get('me')
253
- .auth(accessToken)
254
- .request()
255
- .then(({ body }) => ({
256
- username: body.name,
257
- email: `${body.name}@strapi.io`, // dummy email as Reddit does not provide user email
258
- }));
384
+ return reddit
385
+ .get('me')
386
+ .auth(accessToken)
387
+ .request()
388
+ .then(({ body }) => ({
389
+ username: body.name,
390
+ email: `${body.name}@strapi.io`, // dummy email as Reddit does not provide user email
391
+ }));
392
+ },
259
393
  },
260
- async auth0({ accessToken, providers }) {
261
- const auth0 = purest({ provider: 'auth0' });
262
-
263
- return auth0
264
- .get('userinfo')
265
- .subdomain(providers.auth0.subdomain)
266
- .auth(accessToken)
267
- .request()
268
- .then(({ body }) => {
269
- const username = body.username || body.nickname || body.name || body.email.split('@')[0];
270
- const email = body.email || `${username.replace(/\s+/g, '.')}@strapi.io`;
271
394
 
272
- return {
273
- username,
274
- email,
275
- };
276
- });
395
+ auth0: {
396
+ enabled: false,
397
+ icon: '',
398
+ grantConfig: {
399
+ key: '',
400
+ secret: '',
401
+ subdomain: 'my-tenant.eu',
402
+ callback: `${baseURL}/auth0/callback`,
403
+ scope: ['openid', 'email', 'profile'],
404
+ },
405
+ async authCallback({ accessToken, providers }) {
406
+ const auth0 = purest({ provider: 'auth0' });
407
+
408
+ return auth0
409
+ .get('userinfo')
410
+ .subdomain(providers.auth0.subdomain)
411
+ .auth(accessToken)
412
+ .request()
413
+ .then(({ body }) => {
414
+ const username = body.username || body.nickname || body.name || body.email.split('@')[0];
415
+ const email = body.email || `${username.replace(/\s+/g, '.')}@strapi.io`;
416
+
417
+ return {
418
+ username,
419
+ email,
420
+ };
421
+ });
422
+ },
277
423
  },
278
- async cas({ accessToken, providers }) {
279
- const cas = purest({ provider: 'cas' });
280
-
281
- return cas
282
- .get('oidc/profile')
283
- .subdomain(providers.cas.subdomain)
284
- .auth(accessToken)
285
- .request()
286
- .then(({ body }) => {
287
- // CAS attribute may be in body.attributes or "FLAT", depending on CAS config
288
- const username = body.attributes
289
- ? body.attributes.strapiusername || body.id || body.sub
290
- : body.strapiusername || body.id || body.sub;
291
- const email = body.attributes
292
- ? body.attributes.strapiemail || body.attributes.email
293
- : body.strapiemail || body.email;
294
- if (!username || !email) {
295
- strapi.log.warn(
296
- `CAS Response Body did not contain required attributes: ${JSON.stringify(body)}`
297
- );
298
- }
299
- return {
300
- username,
301
- email,
302
- };
303
- });
424
+
425
+ cas: {
426
+ enabled: false,
427
+ icon: 'book',
428
+ grantConfig: {
429
+ key: '',
430
+ secret: '',
431
+ callback: `${baseURL}/cas/callback`,
432
+ scope: ['openid email'], // scopes should be space delimited
433
+ subdomain: 'my.subdomain.com/cas',
434
+ },
435
+ async authCallback({ accessToken, providers }) {
436
+ const cas = purest({ provider: 'cas' });
437
+
438
+ return cas
439
+ .get('oidc/profile')
440
+ .subdomain(providers.cas.subdomain)
441
+ .auth(accessToken)
442
+ .request()
443
+ .then(({ body }) => {
444
+ // CAS attribute may be in body.attributes or "FLAT", depending on CAS config
445
+ const username = body.attributes
446
+ ? body.attributes.strapiusername || body.id || body.sub
447
+ : body.strapiusername || body.id || body.sub;
448
+ const email = body.attributes
449
+ ? body.attributes.strapiemail || body.attributes.email
450
+ : body.strapiemail || body.email;
451
+ if (!username || !email) {
452
+ strapi.log.warn(
453
+ `CAS Response Body did not contain required attributes: ${JSON.stringify(body)}`
454
+ );
455
+ }
456
+ return {
457
+ username,
458
+ email,
459
+ };
460
+ });
461
+ },
304
462
  },
305
- async patreon({ accessToken }) {
306
- const patreon = purest({
307
- provider: 'patreon',
308
- config: {
309
- patreon: {
310
- default: {
311
- origin: 'https://www.patreon.com',
312
- path: 'api/oauth2/{path}',
313
- headers: {
314
- authorization: 'Bearer {auth}',
463
+
464
+ patreon: {
465
+ enabled: false,
466
+ icon: '',
467
+ grantConfig: {
468
+ key: '',
469
+ secret: '',
470
+ callback: `${baseURL}/patreon/callback`,
471
+ scope: ['identity', 'identity[email]'],
472
+ },
473
+ async authCallback({ accessToken }) {
474
+ const patreon = purest({
475
+ provider: 'patreon',
476
+ config: {
477
+ patreon: {
478
+ default: {
479
+ origin: 'https://www.patreon.com',
480
+ path: 'api/oauth2/{path}',
481
+ headers: {
482
+ authorization: 'Bearer {auth}',
483
+ },
315
484
  },
316
485
  },
317
486
  },
318
- },
319
- });
320
-
321
- return patreon
322
- .get('v2/identity')
323
- .auth(accessToken)
324
- .qs(new URLSearchParams({ 'fields[user]': 'full_name,email' }).toString())
325
- .request()
326
- .then(({ body }) => {
327
- const patreonData = body.data.attributes;
328
- return {
329
- username: patreonData.full_name,
330
- email: patreonData.email,
331
- };
332
487
  });
488
+
489
+ return patreon
490
+ .get('v2/identity')
491
+ .auth(accessToken)
492
+ .qs(new URLSearchParams({ 'fields[user]': 'full_name,email' }).toString())
493
+ .request()
494
+ .then(({ body }) => {
495
+ const patreonData = body.data.attributes;
496
+ return {
497
+ username: patreonData.full_name,
498
+ email: patreonData.email,
499
+ };
500
+ });
501
+ },
502
+ },
503
+ keycloak: {
504
+ enabled: false,
505
+ icon: '',
506
+ grantConfig: {
507
+ key: '',
508
+ secret: '',
509
+ subdomain: 'myKeycloakProvider.com/realms/myrealm',
510
+ callback: `${baseURL}/keycloak/callback`,
511
+ scope: ['openid', 'email', 'profile'],
512
+ },
513
+ async authCallback({ accessToken, providers }) {
514
+ const keycloak = purest({ provider: 'keycloak' });
515
+
516
+ return keycloak
517
+ .subdomain(providers.keycloak.subdomain)
518
+ .get('protocol/openid-connect/userinfo')
519
+ .auth(accessToken)
520
+ .request()
521
+ .then(({ body }) => {
522
+ return {
523
+ username: body.preferred_username,
524
+ email: body.email,
525
+ };
526
+ });
527
+ },
333
528
  },
334
529
  });
335
530
 
336
531
  module.exports = () => {
337
532
  const purest = require('purest');
338
533
 
339
- const providersCallbacks = getInitialProviders({ purest });
534
+ const apiPrefix = strapi.config.get('api.rest.prefix');
535
+ const baseURL = urljoin(strapi.config.server.url, apiPrefix, 'auth');
340
536
 
341
- return {
342
- register(providerName, provider) {
343
- assert(typeof providerName === 'string', 'Provider name must be a string');
344
- assert(typeof provider === 'function', 'Provider callback must be a function');
537
+ const authProviders = initProviders({ baseURL, purest });
345
538
 
346
- providersCallbacks[providerName] = provider({ purest });
539
+ /**
540
+ * @public
541
+ */
542
+ return {
543
+ getAll() {
544
+ return authProviders;
545
+ },
546
+ get(name) {
547
+ return authProviders[name];
548
+ },
549
+ add(name, config) {
550
+ authProviders[name] = config;
551
+ },
552
+ remove(name) {
553
+ delete authProviders[name];
347
554
  },
348
555
 
556
+ /**
557
+ * @internal
558
+ */
349
559
  async run({ provider, accessToken, query, providers }) {
350
- if (!providersCallbacks[provider]) {
351
- throw new Error('Unknown provider.');
352
- }
560
+ const authProvider = authProviders[provider];
353
561
 
354
- const providerCb = providersCallbacks[provider];
562
+ assert(authProvider, 'Unknown auth provider');
355
563
 
356
- return providerCb({ accessToken, query, providers });
564
+ return authProvider.authCallback({ accessToken, query, providers, purest });
357
565
  },
358
566
  };
359
567
  };