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

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 (678) 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} +20 -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} +9 -6
  12. package/admin/src/components/UsersPermissions/{index.js → index.jsx} +16 -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 +157 -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 +260 -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 +207 -0
  28. package/admin/src/pages/Roles/pages/EditPage.jsx +220 -0
  29. package/admin/src/pages/Roles/pages/ListPage/components/TableBody.jsx +119 -0
  30. package/admin/src/pages/Roles/pages/ListPage/index.jsx +264 -0
  31. package/admin/src/pluginId.js +2 -2
  32. package/admin/src/translations/en.json +2 -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/formatPluginName.js +1 -1
  36. package/admin/src/utils/prefixPluginTranslations.js +13 -0
  37. package/dist/admin/components/BoundRoute/getMethodColor.js +49 -0
  38. package/dist/admin/components/BoundRoute/getMethodColor.js.map +1 -0
  39. package/dist/admin/components/BoundRoute/getMethodColor.mjs +47 -0
  40. package/dist/admin/components/BoundRoute/getMethodColor.mjs.map +1 -0
  41. package/dist/admin/components/BoundRoute/index.js +98 -0
  42. package/dist/admin/components/BoundRoute/index.js.map +1 -0
  43. package/dist/admin/components/BoundRoute/index.mjs +96 -0
  44. package/dist/admin/components/BoundRoute/index.mjs.map +1 -0
  45. package/dist/admin/components/FormModal/Input/index.js +123 -0
  46. package/dist/admin/components/FormModal/Input/index.js.map +1 -0
  47. package/dist/admin/components/FormModal/Input/index.mjs +121 -0
  48. package/dist/admin/components/FormModal/Input/index.mjs.map +1 -0
  49. package/dist/admin/components/FormModal/index.js +110 -0
  50. package/dist/admin/components/FormModal/index.js.map +1 -0
  51. package/dist/admin/components/FormModal/index.mjs +108 -0
  52. package/dist/admin/components/FormModal/index.mjs.map +1 -0
  53. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.js +33 -0
  54. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.js.map +1 -0
  55. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.mjs +31 -0
  56. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.mjs.map +1 -0
  57. package/dist/admin/components/Permissions/PermissionRow/SubCategory.js +158 -0
  58. package/dist/admin/components/Permissions/PermissionRow/SubCategory.js.map +1 -0
  59. package/dist/admin/components/Permissions/PermissionRow/SubCategory.mjs +156 -0
  60. package/dist/admin/components/Permissions/PermissionRow/SubCategory.mjs.map +1 -0
  61. package/dist/admin/components/Permissions/PermissionRow/index.js +50 -0
  62. package/dist/admin/components/Permissions/PermissionRow/index.js.map +1 -0
  63. package/dist/admin/components/Permissions/PermissionRow/index.mjs +48 -0
  64. package/dist/admin/components/Permissions/PermissionRow/index.mjs.map +1 -0
  65. package/dist/admin/components/Permissions/index.js +52 -0
  66. package/dist/admin/components/Permissions/index.js.map +1 -0
  67. package/dist/admin/components/Permissions/index.mjs +50 -0
  68. package/dist/admin/components/Permissions/index.mjs.map +1 -0
  69. package/dist/admin/components/Permissions/init.js +15 -0
  70. package/dist/admin/components/Permissions/init.js.map +1 -0
  71. package/dist/admin/components/Permissions/init.mjs +13 -0
  72. package/dist/admin/components/Permissions/init.mjs.map +1 -0
  73. package/dist/admin/components/Permissions/reducer.js +34 -0
  74. package/dist/admin/components/Permissions/reducer.js.map +1 -0
  75. package/dist/admin/components/Permissions/reducer.mjs +31 -0
  76. package/dist/admin/components/Permissions/reducer.mjs.map +1 -0
  77. package/dist/admin/components/Policies/index.js +68 -0
  78. package/dist/admin/components/Policies/index.js.map +1 -0
  79. package/dist/admin/components/Policies/index.mjs +66 -0
  80. package/dist/admin/components/Policies/index.mjs.map +1 -0
  81. package/dist/admin/components/UsersPermissions/index.js +116 -0
  82. package/dist/admin/components/UsersPermissions/index.js.map +1 -0
  83. package/dist/admin/components/UsersPermissions/index.mjs +114 -0
  84. package/dist/admin/components/UsersPermissions/index.mjs.map +1 -0
  85. package/dist/admin/components/UsersPermissions/init.js +13 -0
  86. package/dist/admin/components/UsersPermissions/init.js.map +1 -0
  87. package/dist/admin/components/UsersPermissions/init.mjs +11 -0
  88. package/dist/admin/components/UsersPermissions/init.mjs.map +1 -0
  89. package/dist/admin/components/UsersPermissions/reducer.js +73 -0
  90. package/dist/admin/components/UsersPermissions/reducer.js.map +1 -0
  91. package/dist/admin/components/UsersPermissions/reducer.mjs +68 -0
  92. package/dist/admin/components/UsersPermissions/reducer.mjs.map +1 -0
  93. package/dist/admin/constants.js +81 -0
  94. package/dist/admin/constants.js.map +1 -0
  95. package/dist/admin/constants.mjs +79 -0
  96. package/dist/admin/constants.mjs.map +1 -0
  97. package/dist/admin/contexts/UsersPermissionsContext/index.js +23 -0
  98. package/dist/admin/contexts/UsersPermissionsContext/index.js.map +1 -0
  99. package/dist/admin/contexts/UsersPermissionsContext/index.mjs +19 -0
  100. package/dist/admin/contexts/UsersPermissionsContext/index.mjs.map +1 -0
  101. package/dist/admin/index.js +125 -0
  102. package/dist/admin/index.js.map +1 -0
  103. package/dist/admin/index.mjs +121 -0
  104. package/dist/admin/index.mjs.map +1 -0
  105. package/dist/admin/package.json.js +14 -0
  106. package/dist/admin/package.json.js.map +1 -0
  107. package/dist/admin/package.json.mjs +11 -0
  108. package/dist/admin/package.json.mjs.map +1 -0
  109. package/dist/admin/pages/AdvancedSettings/index.js +194 -0
  110. package/dist/admin/pages/AdvancedSettings/index.js.map +1 -0
  111. package/dist/admin/pages/AdvancedSettings/index.mjs +191 -0
  112. package/dist/admin/pages/AdvancedSettings/index.mjs.map +1 -0
  113. package/dist/admin/pages/AdvancedSettings/utils/layout.js +83 -0
  114. package/dist/admin/pages/AdvancedSettings/utils/layout.js.map +1 -0
  115. package/dist/admin/pages/AdvancedSettings/utils/layout.mjs +81 -0
  116. package/dist/admin/pages/AdvancedSettings/utils/layout.mjs.map +1 -0
  117. package/dist/admin/pages/AdvancedSettings/utils/schema.js +40 -0
  118. package/dist/admin/pages/AdvancedSettings/utils/schema.js.map +1 -0
  119. package/dist/admin/pages/AdvancedSettings/utils/schema.mjs +19 -0
  120. package/dist/admin/pages/AdvancedSettings/utils/schema.mjs.map +1 -0
  121. package/dist/admin/pages/EmailTemplates/components/EmailForm.js +172 -0
  122. package/dist/admin/pages/EmailTemplates/components/EmailForm.js.map +1 -0
  123. package/dist/admin/pages/EmailTemplates/components/EmailForm.mjs +170 -0
  124. package/dist/admin/pages/EmailTemplates/components/EmailForm.mjs.map +1 -0
  125. package/dist/admin/pages/EmailTemplates/components/EmailTable.js +145 -0
  126. package/dist/admin/pages/EmailTemplates/components/EmailTable.js.map +1 -0
  127. package/dist/admin/pages/EmailTemplates/components/EmailTable.mjs +143 -0
  128. package/dist/admin/pages/EmailTemplates/components/EmailTable.mjs.map +1 -0
  129. package/dist/admin/pages/EmailTemplates/index.js +157 -0
  130. package/dist/admin/pages/EmailTemplates/index.js.map +1 -0
  131. package/dist/admin/pages/EmailTemplates/index.mjs +135 -0
  132. package/dist/admin/pages/EmailTemplates/index.mjs.map +1 -0
  133. package/dist/admin/pages/EmailTemplates/utils/schema.js +50 -0
  134. package/dist/admin/pages/EmailTemplates/utils/schema.js.map +1 -0
  135. package/dist/admin/pages/EmailTemplates/utils/schema.mjs +29 -0
  136. package/dist/admin/pages/EmailTemplates/utils/schema.mjs.map +1 -0
  137. package/dist/admin/pages/Providers/index.js +274 -0
  138. package/dist/admin/pages/Providers/index.js.map +1 -0
  139. package/dist/admin/pages/Providers/index.mjs +250 -0
  140. package/dist/admin/pages/Providers/index.mjs.map +1 -0
  141. package/dist/admin/pages/Providers/utils/forms.js +281 -0
  142. package/dist/admin/pages/Providers/utils/forms.js.map +1 -0
  143. package/dist/admin/pages/Providers/utils/forms.mjs +260 -0
  144. package/dist/admin/pages/Providers/utils/forms.mjs.map +1 -0
  145. package/dist/admin/pages/Roles/constants.js +31 -0
  146. package/dist/admin/pages/Roles/constants.js.map +1 -0
  147. package/dist/admin/pages/Roles/constants.mjs +10 -0
  148. package/dist/admin/pages/Roles/constants.mjs.map +1 -0
  149. package/dist/admin/pages/Roles/hooks/usePlugins.js +78 -0
  150. package/dist/admin/pages/Roles/hooks/usePlugins.js.map +1 -0
  151. package/dist/admin/pages/Roles/hooks/usePlugins.mjs +76 -0
  152. package/dist/admin/pages/Roles/hooks/usePlugins.mjs.map +1 -0
  153. package/dist/admin/pages/Roles/index.js +35 -0
  154. package/dist/admin/pages/Roles/index.js.map +1 -0
  155. package/dist/admin/pages/Roles/index.mjs +33 -0
  156. package/dist/admin/pages/Roles/index.mjs.map +1 -0
  157. package/dist/admin/pages/Roles/pages/CreatePage.js +238 -0
  158. package/dist/admin/pages/Roles/pages/CreatePage.js.map +1 -0
  159. package/dist/admin/pages/Roles/pages/CreatePage.mjs +216 -0
  160. package/dist/admin/pages/Roles/pages/CreatePage.mjs.map +1 -0
  161. package/dist/admin/pages/Roles/pages/EditPage.js +239 -0
  162. package/dist/admin/pages/Roles/pages/EditPage.js.map +1 -0
  163. package/dist/admin/pages/Roles/pages/EditPage.mjs +217 -0
  164. package/dist/admin/pages/Roles/pages/EditPage.mjs.map +1 -0
  165. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.js +125 -0
  166. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.js.map +1 -0
  167. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.mjs +123 -0
  168. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.mjs.map +1 -0
  169. package/dist/admin/pages/Roles/pages/ListPage/index.js +233 -0
  170. package/dist/admin/pages/Roles/pages/ListPage/index.js.map +1 -0
  171. package/dist/admin/pages/Roles/pages/ListPage/index.mjs +230 -0
  172. package/dist/admin/pages/Roles/pages/ListPage/index.mjs.map +1 -0
  173. package/dist/admin/pluginId.js +8 -0
  174. package/dist/admin/pluginId.js.map +1 -0
  175. package/dist/admin/pluginId.mjs +6 -0
  176. package/dist/admin/pluginId.mjs.map +1 -0
  177. package/dist/admin/translations/ar.json.js +45 -0
  178. package/dist/admin/translations/ar.json.js.map +1 -0
  179. package/dist/admin/translations/ar.json.mjs +43 -0
  180. package/dist/admin/translations/ar.json.mjs.map +1 -0
  181. package/dist/admin/translations/cs.json.js +51 -0
  182. package/dist/admin/translations/cs.json.js.map +1 -0
  183. package/dist/admin/translations/cs.json.mjs +49 -0
  184. package/dist/admin/translations/cs.json.mjs.map +1 -0
  185. package/dist/admin/translations/de.json.js +63 -0
  186. package/dist/admin/translations/de.json.js.map +1 -0
  187. package/dist/admin/translations/de.json.mjs +61 -0
  188. package/dist/admin/translations/de.json.mjs.map +1 -0
  189. package/dist/admin/translations/dk.json.js +87 -0
  190. package/dist/admin/translations/dk.json.js.map +1 -0
  191. package/dist/admin/translations/dk.json.mjs +85 -0
  192. package/dist/admin/translations/dk.json.mjs.map +1 -0
  193. package/dist/admin/translations/en.json.js +88 -0
  194. package/dist/admin/translations/en.json.js.map +1 -0
  195. package/dist/admin/translations/en.json.mjs +86 -0
  196. package/dist/admin/translations/en.json.mjs.map +1 -0
  197. package/dist/admin/translations/es.json.js +87 -0
  198. package/dist/admin/translations/es.json.js.map +1 -0
  199. package/dist/admin/translations/es.json.mjs +85 -0
  200. package/dist/admin/translations/es.json.mjs.map +1 -0
  201. package/dist/admin/translations/fr.json.js +51 -0
  202. package/dist/admin/translations/fr.json.js.map +1 -0
  203. package/dist/admin/translations/fr.json.mjs +49 -0
  204. package/dist/admin/translations/fr.json.mjs.map +1 -0
  205. package/dist/admin/translations/id.json.js +63 -0
  206. package/dist/admin/translations/id.json.js.map +1 -0
  207. package/dist/admin/translations/id.json.mjs +61 -0
  208. package/dist/admin/translations/id.json.mjs.map +1 -0
  209. package/dist/admin/translations/it.json.js +63 -0
  210. package/dist/admin/translations/it.json.js.map +1 -0
  211. package/dist/admin/translations/it.json.mjs +61 -0
  212. package/dist/admin/translations/it.json.mjs.map +1 -0
  213. package/dist/admin/translations/ja.json.js +49 -0
  214. package/dist/admin/translations/ja.json.js.map +1 -0
  215. package/dist/admin/translations/ja.json.mjs +47 -0
  216. package/dist/admin/translations/ja.json.mjs.map +1 -0
  217. package/dist/admin/translations/ko.json.js +87 -0
  218. package/dist/admin/translations/ko.json.js.map +1 -0
  219. package/dist/admin/translations/ko.json.mjs +85 -0
  220. package/dist/admin/translations/ko.json.mjs.map +1 -0
  221. package/dist/admin/translations/ms.json.js +50 -0
  222. package/dist/admin/translations/ms.json.js.map +1 -0
  223. package/dist/admin/translations/ms.json.mjs +48 -0
  224. package/dist/admin/translations/ms.json.mjs.map +1 -0
  225. package/dist/admin/translations/nl.json.js +49 -0
  226. package/dist/admin/translations/nl.json.js.map +1 -0
  227. package/dist/admin/translations/nl.json.mjs +47 -0
  228. package/dist/admin/translations/nl.json.mjs.map +1 -0
  229. package/dist/admin/translations/pl.json.js +87 -0
  230. package/dist/admin/translations/pl.json.js.map +1 -0
  231. package/dist/admin/translations/pl.json.mjs +85 -0
  232. package/dist/admin/translations/pl.json.mjs.map +1 -0
  233. package/dist/admin/translations/pt-BR.json.js +45 -0
  234. package/dist/admin/translations/pt-BR.json.js.map +1 -0
  235. package/dist/admin/translations/pt-BR.json.mjs +43 -0
  236. package/dist/admin/translations/pt-BR.json.mjs.map +1 -0
  237. package/dist/admin/translations/pt.json.js +49 -0
  238. package/dist/admin/translations/pt.json.js.map +1 -0
  239. package/dist/admin/translations/pt.json.mjs +47 -0
  240. package/dist/admin/translations/pt.json.mjs.map +1 -0
  241. package/dist/admin/translations/ru.json.js +87 -0
  242. package/dist/admin/translations/ru.json.js.map +1 -0
  243. package/dist/admin/translations/ru.json.mjs +85 -0
  244. package/dist/admin/translations/ru.json.mjs.map +1 -0
  245. package/dist/admin/translations/sk.json.js +51 -0
  246. package/dist/admin/translations/sk.json.js.map +1 -0
  247. package/dist/admin/translations/sk.json.mjs +49 -0
  248. package/dist/admin/translations/sk.json.mjs.map +1 -0
  249. package/dist/admin/translations/sv.json.js +87 -0
  250. package/dist/admin/translations/sv.json.js.map +1 -0
  251. package/dist/admin/translations/sv.json.mjs +85 -0
  252. package/dist/admin/translations/sv.json.mjs.map +1 -0
  253. package/dist/admin/translations/th.json.js +61 -0
  254. package/dist/admin/translations/th.json.js.map +1 -0
  255. package/dist/admin/translations/th.json.mjs +59 -0
  256. package/dist/admin/translations/th.json.mjs.map +1 -0
  257. package/dist/admin/translations/tr.json.js +86 -0
  258. package/dist/admin/translations/tr.json.js.map +1 -0
  259. package/dist/admin/translations/tr.json.mjs +84 -0
  260. package/dist/admin/translations/tr.json.mjs.map +1 -0
  261. package/dist/admin/translations/uk.json.js +87 -0
  262. package/dist/admin/translations/uk.json.js.map +1 -0
  263. package/dist/admin/translations/uk.json.mjs +85 -0
  264. package/dist/admin/translations/uk.json.mjs.map +1 -0
  265. package/dist/admin/translations/vi.json.js +51 -0
  266. package/dist/admin/translations/vi.json.js.map +1 -0
  267. package/dist/admin/translations/vi.json.mjs +49 -0
  268. package/dist/admin/translations/vi.json.mjs.map +1 -0
  269. package/dist/admin/translations/zh-Hans.json.js +87 -0
  270. package/dist/admin/translations/zh-Hans.json.js.map +1 -0
  271. package/dist/admin/translations/zh-Hans.json.mjs +85 -0
  272. package/dist/admin/translations/zh-Hans.json.mjs.map +1 -0
  273. package/dist/admin/translations/zh.json.js +87 -0
  274. package/dist/admin/translations/zh.json.js.map +1 -0
  275. package/dist/admin/translations/zh.json.mjs +85 -0
  276. package/dist/admin/translations/zh.json.mjs.map +1 -0
  277. package/dist/admin/utils/cleanPermissions.js +24 -0
  278. package/dist/admin/utils/cleanPermissions.js.map +1 -0
  279. package/dist/admin/utils/cleanPermissions.mjs +22 -0
  280. package/dist/admin/utils/cleanPermissions.mjs.map +1 -0
  281. package/dist/admin/utils/formatPluginName.js +29 -0
  282. package/dist/admin/utils/formatPluginName.js.map +1 -0
  283. package/dist/admin/utils/formatPluginName.mjs +27 -0
  284. package/dist/admin/utils/formatPluginName.mjs.map +1 -0
  285. package/dist/admin/utils/getTrad.js +8 -0
  286. package/dist/admin/utils/getTrad.js.map +1 -0
  287. package/dist/admin/utils/getTrad.mjs +6 -0
  288. package/dist/admin/utils/getTrad.mjs.map +1 -0
  289. package/dist/admin/utils/prefixPluginTranslations.js +11 -0
  290. package/dist/admin/utils/prefixPluginTranslations.js.map +1 -0
  291. package/dist/admin/utils/prefixPluginTranslations.mjs +9 -0
  292. package/dist/admin/utils/prefixPluginTranslations.mjs.map +1 -0
  293. package/dist/server/_virtual/_commonjsHelpers.js +8 -0
  294. package/dist/server/_virtual/_commonjsHelpers.js.map +1 -0
  295. package/dist/server/_virtual/_commonjsHelpers.mjs +6 -0
  296. package/dist/server/_virtual/_commonjsHelpers.mjs.map +1 -0
  297. package/dist/server/bootstrap/index.js +166 -0
  298. package/dist/server/bootstrap/index.js.map +1 -0
  299. package/dist/server/bootstrap/index.mjs +164 -0
  300. package/dist/server/bootstrap/index.mjs.map +1 -0
  301. package/dist/server/bootstrap/users-permissions-actions.js +98 -0
  302. package/dist/server/bootstrap/users-permissions-actions.js.map +1 -0
  303. package/dist/server/bootstrap/users-permissions-actions.mjs +96 -0
  304. package/dist/server/bootstrap/users-permissions-actions.mjs.map +1 -0
  305. package/dist/server/config.js +70 -0
  306. package/dist/server/config.js.map +1 -0
  307. package/dist/server/config.mjs +68 -0
  308. package/dist/server/config.mjs.map +1 -0
  309. package/dist/server/content-types/index.js +30 -0
  310. package/dist/server/content-types/index.js.map +1 -0
  311. package/dist/server/content-types/index.mjs +28 -0
  312. package/dist/server/content-types/index.mjs.map +1 -0
  313. package/dist/server/content-types/permission/index.js +44 -0
  314. package/dist/server/content-types/permission/index.js.map +1 -0
  315. package/dist/server/content-types/permission/index.mjs +42 -0
  316. package/dist/server/content-types/permission/index.mjs.map +1 -0
  317. package/dist/server/content-types/role/index.js +61 -0
  318. package/dist/server/content-types/role/index.js.map +1 -0
  319. package/dist/server/content-types/role/index.mjs +59 -0
  320. package/dist/server/content-types/role/index.mjs.map +1 -0
  321. package/dist/server/content-types/user/index.js +84 -0
  322. package/dist/server/content-types/user/index.js.map +1 -0
  323. package/dist/server/content-types/user/index.mjs +82 -0
  324. package/dist/server/content-types/user/index.mjs.map +1 -0
  325. package/dist/server/content-types/user/schema-config.js +25 -0
  326. package/dist/server/content-types/user/schema-config.js.map +1 -0
  327. package/dist/server/content-types/user/schema-config.mjs +23 -0
  328. package/dist/server/content-types/user/schema-config.mjs.map +1 -0
  329. package/dist/server/controllers/auth.js +630 -0
  330. package/dist/server/controllers/auth.js.map +1 -0
  331. package/dist/server/controllers/auth.mjs +628 -0
  332. package/dist/server/controllers/auth.mjs.map +1 -0
  333. package/dist/server/controllers/content-manager-user.js +168 -0
  334. package/dist/server/controllers/content-manager-user.js.map +1 -0
  335. package/dist/server/controllers/content-manager-user.mjs +166 -0
  336. package/dist/server/controllers/content-manager-user.mjs.map +1 -0
  337. package/dist/server/controllers/index.js +33 -0
  338. package/dist/server/controllers/index.js.map +1 -0
  339. package/dist/server/controllers/index.mjs +31 -0
  340. package/dist/server/controllers/index.mjs.map +1 -0
  341. package/dist/server/controllers/permissions.js +37 -0
  342. package/dist/server/controllers/permissions.js.map +1 -0
  343. package/dist/server/controllers/permissions.mjs +35 -0
  344. package/dist/server/controllers/permissions.mjs.map +1 -0
  345. package/dist/server/controllers/role.js +91 -0
  346. package/dist/server/controllers/role.js.map +1 -0
  347. package/dist/server/controllers/role.mjs +89 -0
  348. package/dist/server/controllers/role.mjs.map +1 -0
  349. package/dist/server/controllers/settings.js +107 -0
  350. package/dist/server/controllers/settings.js.map +1 -0
  351. package/dist/server/controllers/settings.mjs +105 -0
  352. package/dist/server/controllers/settings.mjs.map +1 -0
  353. package/dist/server/controllers/user.js +201 -0
  354. package/dist/server/controllers/user.js.map +1 -0
  355. package/dist/server/controllers/user.mjs +199 -0
  356. package/dist/server/controllers/user.mjs.map +1 -0
  357. package/dist/server/controllers/validation/auth.js +131 -0
  358. package/dist/server/controllers/validation/auth.js.map +1 -0
  359. package/dist/server/controllers/validation/auth.mjs +129 -0
  360. package/dist/server/controllers/validation/auth.mjs.map +1 -0
  361. package/dist/server/controllers/validation/email-template.js +72 -0
  362. package/dist/server/controllers/validation/email-template.js.map +1 -0
  363. package/dist/server/controllers/validation/email-template.mjs +70 -0
  364. package/dist/server/controllers/validation/email-template.mjs.map +1 -0
  365. package/dist/server/controllers/validation/user.js +54 -0
  366. package/dist/server/controllers/validation/user.js.map +1 -0
  367. package/dist/server/controllers/validation/user.mjs +52 -0
  368. package/dist/server/controllers/validation/user.mjs.map +1 -0
  369. package/dist/server/graphql/index.js +66 -0
  370. package/dist/server/graphql/index.js.map +1 -0
  371. package/dist/server/graphql/index.mjs +64 -0
  372. package/dist/server/graphql/index.mjs.map +1 -0
  373. package/dist/server/graphql/mutations/auth/change-password.js +40 -0
  374. package/dist/server/graphql/mutations/auth/change-password.js.map +1 -0
  375. package/dist/server/graphql/mutations/auth/change-password.mjs +38 -0
  376. package/dist/server/graphql/mutations/auth/change-password.mjs.map +1 -0
  377. package/dist/server/graphql/mutations/auth/email-confirmation.js +38 -0
  378. package/dist/server/graphql/mutations/auth/email-confirmation.js.map +1 -0
  379. package/dist/server/graphql/mutations/auth/email-confirmation.mjs +36 -0
  380. package/dist/server/graphql/mutations/auth/email-confirmation.mjs.map +1 -0
  381. package/dist/server/graphql/mutations/auth/forgot-password.js +37 -0
  382. package/dist/server/graphql/mutations/auth/forgot-password.js.map +1 -0
  383. package/dist/server/graphql/mutations/auth/forgot-password.mjs +35 -0
  384. package/dist/server/graphql/mutations/auth/forgot-password.mjs.map +1 -0
  385. package/dist/server/graphql/mutations/auth/login.js +40 -0
  386. package/dist/server/graphql/mutations/auth/login.js.map +1 -0
  387. package/dist/server/graphql/mutations/auth/login.mjs +38 -0
  388. package/dist/server/graphql/mutations/auth/login.mjs.map +1 -0
  389. package/dist/server/graphql/mutations/auth/register.js +38 -0
  390. package/dist/server/graphql/mutations/auth/register.js.map +1 -0
  391. package/dist/server/graphql/mutations/auth/register.mjs +36 -0
  392. package/dist/server/graphql/mutations/auth/register.mjs.map +1 -0
  393. package/dist/server/graphql/mutations/auth/reset-password.js +40 -0
  394. package/dist/server/graphql/mutations/auth/reset-password.js.map +1 -0
  395. package/dist/server/graphql/mutations/auth/reset-password.mjs +38 -0
  396. package/dist/server/graphql/mutations/auth/reset-password.mjs.map +1 -0
  397. package/dist/server/graphql/mutations/crud/role/create-role.js +37 -0
  398. package/dist/server/graphql/mutations/crud/role/create-role.js.map +1 -0
  399. package/dist/server/graphql/mutations/crud/role/create-role.mjs +35 -0
  400. package/dist/server/graphql/mutations/crud/role/create-role.mjs.map +1 -0
  401. package/dist/server/graphql/mutations/crud/role/delete-role.js +32 -0
  402. package/dist/server/graphql/mutations/crud/role/delete-role.js.map +1 -0
  403. package/dist/server/graphql/mutations/crud/role/delete-role.mjs +30 -0
  404. package/dist/server/graphql/mutations/crud/role/delete-role.mjs.map +1 -0
  405. package/dist/server/graphql/mutations/crud/role/update-role.js +39 -0
  406. package/dist/server/graphql/mutations/crud/role/update-role.js.map +1 -0
  407. package/dist/server/graphql/mutations/crud/role/update-role.mjs +37 -0
  408. package/dist/server/graphql/mutations/crud/role/update-role.mjs.map +1 -0
  409. package/dist/server/graphql/mutations/crud/user/create-user.js +46 -0
  410. package/dist/server/graphql/mutations/crud/user/create-user.js.map +1 -0
  411. package/dist/server/graphql/mutations/crud/user/create-user.mjs +44 -0
  412. package/dist/server/graphql/mutations/crud/user/create-user.mjs.map +1 -0
  413. package/dist/server/graphql/mutations/crud/user/delete-user.js +44 -0
  414. package/dist/server/graphql/mutations/crud/user/delete-user.js.map +1 -0
  415. package/dist/server/graphql/mutations/crud/user/delete-user.mjs +42 -0
  416. package/dist/server/graphql/mutations/crud/user/delete-user.mjs.map +1 -0
  417. package/dist/server/graphql/mutations/crud/user/update-user.js +49 -0
  418. package/dist/server/graphql/mutations/crud/user/update-user.js.map +1 -0
  419. package/dist/server/graphql/mutations/crud/user/update-user.mjs +47 -0
  420. package/dist/server/graphql/mutations/crud/user/update-user.mjs.map +1 -0
  421. package/dist/server/graphql/mutations/index.js +58 -0
  422. package/dist/server/graphql/mutations/index.js.map +1 -0
  423. package/dist/server/graphql/mutations/index.mjs +56 -0
  424. package/dist/server/graphql/mutations/index.mjs.map +1 -0
  425. package/dist/server/graphql/queries/index.js +25 -0
  426. package/dist/server/graphql/queries/index.js.map +1 -0
  427. package/dist/server/graphql/queries/index.mjs +23 -0
  428. package/dist/server/graphql/queries/index.mjs.map +1 -0
  429. package/dist/server/graphql/queries/me.js +23 -0
  430. package/dist/server/graphql/queries/me.js.map +1 -0
  431. package/dist/server/graphql/queries/me.mjs +21 -0
  432. package/dist/server/graphql/queries/me.mjs.map +1 -0
  433. package/dist/server/graphql/resolvers-configs.js +93 -0
  434. package/dist/server/graphql/resolvers-configs.js.map +1 -0
  435. package/dist/server/graphql/resolvers-configs.mjs +91 -0
  436. package/dist/server/graphql/resolvers-configs.mjs.map +1 -0
  437. package/dist/server/graphql/types/create-role-payload.js +20 -0
  438. package/dist/server/graphql/types/create-role-payload.js.map +1 -0
  439. package/dist/server/graphql/types/create-role-payload.mjs +18 -0
  440. package/dist/server/graphql/types/create-role-payload.mjs.map +1 -0
  441. package/dist/server/graphql/types/delete-role-payload.js +20 -0
  442. package/dist/server/graphql/types/delete-role-payload.js.map +1 -0
  443. package/dist/server/graphql/types/delete-role-payload.mjs +18 -0
  444. package/dist/server/graphql/types/delete-role-payload.mjs.map +1 -0
  445. package/dist/server/graphql/types/index.js +41 -0
  446. package/dist/server/graphql/types/index.js.map +1 -0
  447. package/dist/server/graphql/types/index.mjs +39 -0
  448. package/dist/server/graphql/types/index.mjs.map +1 -0
  449. package/dist/server/graphql/types/login-input.js +24 -0
  450. package/dist/server/graphql/types/login-input.js.map +1 -0
  451. package/dist/server/graphql/types/login-input.mjs +22 -0
  452. package/dist/server/graphql/types/login-input.mjs.map +1 -0
  453. package/dist/server/graphql/types/login-payload.js +23 -0
  454. package/dist/server/graphql/types/login-payload.js.map +1 -0
  455. package/dist/server/graphql/types/login-payload.mjs +21 -0
  456. package/dist/server/graphql/types/login-payload.mjs.map +1 -0
  457. package/dist/server/graphql/types/me-role.js +23 -0
  458. package/dist/server/graphql/types/me-role.js.map +1 -0
  459. package/dist/server/graphql/types/me-role.mjs +21 -0
  460. package/dist/server/graphql/types/me-role.mjs.map +1 -0
  461. package/dist/server/graphql/types/me.js +28 -0
  462. package/dist/server/graphql/types/me.js.map +1 -0
  463. package/dist/server/graphql/types/me.mjs +26 -0
  464. package/dist/server/graphql/types/me.mjs.map +1 -0
  465. package/dist/server/graphql/types/password-payload.js +20 -0
  466. package/dist/server/graphql/types/password-payload.js.map +1 -0
  467. package/dist/server/graphql/types/password-payload.mjs +18 -0
  468. package/dist/server/graphql/types/password-payload.mjs.map +1 -0
  469. package/dist/server/graphql/types/register-input.js +22 -0
  470. package/dist/server/graphql/types/register-input.js.map +1 -0
  471. package/dist/server/graphql/types/register-input.mjs +20 -0
  472. package/dist/server/graphql/types/register-input.mjs.map +1 -0
  473. package/dist/server/graphql/types/update-role-payload.js +20 -0
  474. package/dist/server/graphql/types/update-role-payload.js.map +1 -0
  475. package/dist/server/graphql/types/update-role-payload.mjs +18 -0
  476. package/dist/server/graphql/types/update-role-payload.mjs.map +1 -0
  477. package/dist/server/graphql/types/user-input.js +26 -0
  478. package/dist/server/graphql/types/user-input.js.map +1 -0
  479. package/dist/server/graphql/types/user-input.mjs +24 -0
  480. package/dist/server/graphql/types/user-input.mjs.map +1 -0
  481. package/dist/server/graphql/utils.js +32 -0
  482. package/dist/server/graphql/utils.js.map +1 -0
  483. package/dist/server/graphql/utils.mjs +30 -0
  484. package/dist/server/graphql/utils.mjs.map +1 -0
  485. package/dist/server/index.js +10 -0
  486. package/dist/server/index.js.map +1 -0
  487. package/dist/server/index.mjs +8 -0
  488. package/dist/server/index.mjs.map +1 -0
  489. package/dist/server/index2.js +39 -0
  490. package/dist/server/index2.js.map +1 -0
  491. package/dist/server/index2.mjs +37 -0
  492. package/dist/server/index2.mjs.map +1 -0
  493. package/dist/server/middlewares/index.js +18 -0
  494. package/dist/server/middlewares/index.js.map +1 -0
  495. package/dist/server/middlewares/index.mjs +16 -0
  496. package/dist/server/middlewares/index.mjs.map +1 -0
  497. package/dist/server/middlewares/rateLimit.js +51 -0
  498. package/dist/server/middlewares/rateLimit.js.map +1 -0
  499. package/dist/server/middlewares/rateLimit.mjs +49 -0
  500. package/dist/server/middlewares/rateLimit.mjs.map +1 -0
  501. package/dist/server/register.js +41 -0
  502. package/dist/server/register.js.map +1 -0
  503. package/dist/server/register.mjs +39 -0
  504. package/dist/server/register.mjs.map +1 -0
  505. package/dist/server/routes/admin/index.js +27 -0
  506. package/dist/server/routes/admin/index.js.map +1 -0
  507. package/dist/server/routes/admin/index.mjs +25 -0
  508. package/dist/server/routes/admin/index.mjs.map +1 -0
  509. package/dist/server/routes/admin/permissions.js +29 -0
  510. package/dist/server/routes/admin/permissions.js.map +1 -0
  511. package/dist/server/routes/admin/permissions.mjs +27 -0
  512. package/dist/server/routes/admin/permissions.mjs.map +1 -0
  513. package/dist/server/routes/admin/role.js +99 -0
  514. package/dist/server/routes/admin/role.js.map +1 -0
  515. package/dist/server/routes/admin/role.mjs +97 -0
  516. package/dist/server/routes/admin/role.mjs.map +1 -0
  517. package/dist/server/routes/admin/settings.js +116 -0
  518. package/dist/server/routes/admin/settings.js.map +1 -0
  519. package/dist/server/routes/admin/settings.mjs +114 -0
  520. package/dist/server/routes/admin/settings.mjs.map +1 -0
  521. package/dist/server/routes/content-api/auth.js +168 -0
  522. package/dist/server/routes/content-api/auth.js.map +1 -0
  523. package/dist/server/routes/content-api/auth.mjs +166 -0
  524. package/dist/server/routes/content-api/auth.mjs.map +1 -0
  525. package/dist/server/routes/content-api/index.js +32 -0
  526. package/dist/server/routes/content-api/index.js.map +1 -0
  527. package/dist/server/routes/content-api/index.mjs +30 -0
  528. package/dist/server/routes/content-api/index.mjs.map +1 -0
  529. package/dist/server/routes/content-api/permissions.js +26 -0
  530. package/dist/server/routes/content-api/permissions.js.map +1 -0
  531. package/dist/server/routes/content-api/permissions.mjs +24 -0
  532. package/dist/server/routes/content-api/permissions.mjs.map +1 -0
  533. package/dist/server/routes/content-api/role.js +73 -0
  534. package/dist/server/routes/content-api/role.js.map +1 -0
  535. package/dist/server/routes/content-api/role.mjs +71 -0
  536. package/dist/server/routes/content-api/role.mjs.map +1 -0
  537. package/dist/server/routes/content-api/user.js +132 -0
  538. package/dist/server/routes/content-api/user.js.map +1 -0
  539. package/dist/server/routes/content-api/user.mjs +130 -0
  540. package/dist/server/routes/content-api/user.mjs.map +1 -0
  541. package/dist/server/routes/content-api/validation.js +217 -0
  542. package/dist/server/routes/content-api/validation.js.map +1 -0
  543. package/dist/server/routes/content-api/validation.mjs +215 -0
  544. package/dist/server/routes/content-api/validation.mjs.map +1 -0
  545. package/dist/server/routes/index.js +19 -0
  546. package/dist/server/routes/index.js.map +1 -0
  547. package/dist/server/routes/index.mjs +17 -0
  548. package/dist/server/routes/index.mjs.map +1 -0
  549. package/dist/server/services/constants.js +19 -0
  550. package/dist/server/services/constants.js.map +1 -0
  551. package/dist/server/services/constants.mjs +17 -0
  552. package/dist/server/services/constants.mjs.map +1 -0
  553. package/dist/server/services/index.js +36 -0
  554. package/dist/server/services/index.js.map +1 -0
  555. package/dist/server/services/index.mjs +34 -0
  556. package/dist/server/services/index.mjs.map +1 -0
  557. package/dist/server/services/jwt.js +93 -0
  558. package/dist/server/services/jwt.js.map +1 -0
  559. package/dist/server/services/jwt.mjs +91 -0
  560. package/dist/server/services/jwt.mjs.map +1 -0
  561. package/dist/server/services/permission.js +52 -0
  562. package/dist/server/services/permission.js.map +1 -0
  563. package/dist/server/services/permission.mjs +50 -0
  564. package/dist/server/services/permission.mjs.map +1 -0
  565. package/dist/server/services/providers-registry.js +555 -0
  566. package/dist/server/services/providers-registry.js.map +1 -0
  567. package/dist/server/services/providers-registry.mjs +553 -0
  568. package/dist/server/services/providers-registry.mjs.map +1 -0
  569. package/dist/server/services/providers.js +111 -0
  570. package/dist/server/services/providers.js.map +1 -0
  571. package/dist/server/services/providers.mjs +109 -0
  572. package/dist/server/services/providers.mjs.map +1 -0
  573. package/dist/server/services/role.js +186 -0
  574. package/dist/server/services/role.js.map +1 -0
  575. package/dist/server/services/role.mjs +184 -0
  576. package/dist/server/services/role.mjs.map +1 -0
  577. package/dist/server/services/user.js +188 -0
  578. package/dist/server/services/user.js.map +1 -0
  579. package/dist/server/services/user.mjs +186 -0
  580. package/dist/server/services/user.mjs.map +1 -0
  581. package/dist/server/services/users-permissions.js +256 -0
  582. package/dist/server/services/users-permissions.js.map +1 -0
  583. package/dist/server/services/users-permissions.mjs +254 -0
  584. package/dist/server/services/users-permissions.mjs.map +1 -0
  585. package/dist/server/strategies/users-permissions.js +114 -0
  586. package/dist/server/strategies/users-permissions.js.map +1 -0
  587. package/dist/server/strategies/users-permissions.mjs +112 -0
  588. package/dist/server/strategies/users-permissions.mjs.map +1 -0
  589. package/dist/server/utils/index.js +22 -0
  590. package/dist/server/utils/index.js.map +1 -0
  591. package/dist/server/utils/index.mjs +20 -0
  592. package/dist/server/utils/index.mjs.map +1 -0
  593. package/dist/server/utils/sanitize/index.js +21 -0
  594. package/dist/server/utils/sanitize/index.js.map +1 -0
  595. package/dist/server/utils/sanitize/index.mjs +19 -0
  596. package/dist/server/utils/sanitize/index.mjs.map +1 -0
  597. package/dist/server/utils/sanitize/sanitizers.js +32 -0
  598. package/dist/server/utils/sanitize/sanitizers.js.map +1 -0
  599. package/dist/server/utils/sanitize/sanitizers.mjs +30 -0
  600. package/dist/server/utils/sanitize/sanitizers.mjs.map +1 -0
  601. package/dist/server/utils/sanitize/visitors/index.js +17 -0
  602. package/dist/server/utils/sanitize/visitors/index.js.map +1 -0
  603. package/dist/server/utils/sanitize/visitors/index.mjs +15 -0
  604. package/dist/server/utils/sanitize/visitors/index.mjs.map +1 -0
  605. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +17 -0
  606. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js.map +1 -0
  607. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.mjs +15 -0
  608. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.mjs.map +1 -0
  609. package/documentation/content-api.yaml +1 -1
  610. package/jest.config.front.js +1 -1
  611. package/package.json +50 -30
  612. package/rollup.config.mjs +19 -0
  613. package/server/bootstrap/index.js +49 -15
  614. package/server/bootstrap/users-permissions-actions.js +6 -0
  615. package/server/config.js +51 -0
  616. package/server/content-types/user/index.js +0 -1
  617. package/server/controllers/auth.js +323 -47
  618. package/server/controllers/content-manager-user.js +31 -34
  619. package/server/controllers/role.js +17 -4
  620. package/server/controllers/user.js +18 -8
  621. package/server/controllers/validation/auth.js +104 -25
  622. package/server/controllers/validation/user.js +12 -1
  623. package/server/graphql/types/index.js +1 -0
  624. package/server/graphql/types/me.js +1 -0
  625. package/server/graphql/types/user-input.js +20 -0
  626. package/server/middlewares/rateLimit.js +2 -2
  627. package/server/register.js +2 -2
  628. package/server/routes/content-api/auth.js +119 -71
  629. package/server/routes/content-api/index.js +11 -4
  630. package/server/routes/content-api/permissions.js +14 -7
  631. package/server/routes/content-api/role.js +57 -27
  632. package/server/routes/content-api/user.js +108 -51
  633. package/server/routes/content-api/validation.js +250 -0
  634. package/server/services/constants.js +9 -0
  635. package/server/services/jwt.js +53 -5
  636. package/server/services/permission.js +3 -7
  637. package/server/services/providers-registry.js +469 -261
  638. package/server/services/providers.js +10 -5
  639. package/server/services/role.js +15 -13
  640. package/server/services/user.js +67 -19
  641. package/server/services/users-permissions.js +21 -15
  642. package/server/utils/index.d.ts +2 -1
  643. package/server/utils/sanitize/sanitizers.js +7 -3
  644. package/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +2 -2
  645. package/.eslintrc.js +0 -14
  646. package/admin/src/components/FormModal/index.js +0 -126
  647. package/admin/src/components/Permissions/index.js +0 -57
  648. package/admin/src/hooks/index.js +0 -5
  649. package/admin/src/hooks/useFetchRole/index.js +0 -67
  650. package/admin/src/hooks/useFetchRole/reducer.js +0 -31
  651. package/admin/src/hooks/useForm/index.js +0 -68
  652. package/admin/src/hooks/useForm/reducer.js +0 -40
  653. package/admin/src/hooks/useRolesList/index.js +0 -65
  654. package/admin/src/hooks/useRolesList/init.js +0 -5
  655. package/admin/src/hooks/useRolesList/reducer.js +0 -31
  656. package/admin/src/pages/AdvancedSettings/index.js +0 -242
  657. package/admin/src/pages/AdvancedSettings/utils/api.js +0 -16
  658. package/admin/src/pages/EmailTemplates/components/EmailForm.js +0 -176
  659. package/admin/src/pages/EmailTemplates/index.js +0 -159
  660. package/admin/src/pages/EmailTemplates/utils/api.js +0 -16
  661. package/admin/src/pages/Providers/index.js +0 -271
  662. package/admin/src/pages/Providers/reducer.js +0 -54
  663. package/admin/src/pages/Providers/utils/api.js +0 -24
  664. package/admin/src/pages/Providers/utils/createProvidersArray.js +0 -21
  665. package/admin/src/pages/Roles/CreatePage.js +0 -185
  666. package/admin/src/pages/Roles/EditPage.js +0 -197
  667. package/admin/src/pages/Roles/ListPage/components/TableBody.js +0 -93
  668. package/admin/src/pages/Roles/ListPage/index.js +0 -238
  669. package/admin/src/pages/Roles/ListPage/utils/api.js +0 -30
  670. package/admin/src/pages/Roles/ProtectedCreatePage.js +0 -15
  671. package/admin/src/pages/Roles/ProtectedEditPage.js +0 -15
  672. package/admin/src/pages/Roles/ProtectedListPage.js +0 -17
  673. package/admin/src/pages/Roles/index.js +0 -30
  674. package/server/bootstrap/grant-config.js +0 -131
  675. package/strapi-admin.js +0 -3
  676. package/strapi-server.js +0 -3
  677. /package/admin/src/components/Permissions/PermissionRow/{index.js → index.jsx} +0 -0
  678. /package/admin/src/contexts/UsersPermissionsContext/{index.js → index.jsx} +0 -0
@@ -0,0 +1,628 @@
1
+ import require$$0 from 'crypto';
2
+ import require$$0$1 from 'lodash';
3
+ import require$$0$2 from 'lodash/fp';
4
+ import require$$1 from '@strapi/utils';
5
+ import { __require as requireUtils } from '../utils/index.mjs';
6
+ import { __require as requireAuth$1 } from './validation/auth.mjs';
7
+ import require$$6 from 'grant';
8
+
9
+ var auth;
10
+ var hasRequiredAuth;
11
+ function requireAuth() {
12
+ if (hasRequiredAuth) return auth;
13
+ hasRequiredAuth = 1;
14
+ /**
15
+ * Auth.js controller
16
+ *
17
+ * @description: A set of functions called "actions" for managing `Auth`.
18
+ */ /* eslint-disable no-useless-escape */ const crypto = require$$0;
19
+ const _ = require$$0$1;
20
+ const { concat, compact, isArray } = require$$0$2;
21
+ const utils = require$$1;
22
+ const { getService } = requireUtils();
23
+ const { validateCallbackBody, validateRegisterBody, validateSendEmailConfirmationBody, validateForgotPasswordBody, validateResetPasswordBody, validateEmailConfirmationBody, validateChangePasswordBody } = requireAuth$1();
24
+ const { ApplicationError, ValidationError, ForbiddenError } = utils.errors;
25
+ const sanitizeUser = (user, ctx)=>{
26
+ const { auth } = ctx.state;
27
+ const userSchema = strapi.getModel('plugin::users-permissions.user');
28
+ return strapi.contentAPI.sanitize.output(user, userSchema, {
29
+ auth
30
+ });
31
+ };
32
+ const extractDeviceId = (requestBody)=>{
33
+ const { deviceId } = requestBody || {};
34
+ return typeof deviceId === 'string' && deviceId.length > 0 ? deviceId : undefined;
35
+ };
36
+ auth = ({ strapi: strapi1 })=>({
37
+ async callback (ctx) {
38
+ const provider = ctx.params.provider || 'local';
39
+ const params = ctx.request.body;
40
+ const store = strapi1.store({
41
+ type: 'plugin',
42
+ name: 'users-permissions'
43
+ });
44
+ const grantSettings = await store.get({
45
+ key: 'grant'
46
+ });
47
+ const grantProvider = provider === 'local' ? 'email' : provider;
48
+ if (!_.get(grantSettings, [
49
+ grantProvider,
50
+ 'enabled'
51
+ ])) {
52
+ throw new ApplicationError('This provider is disabled');
53
+ }
54
+ if (provider === 'local') {
55
+ await validateCallbackBody(params);
56
+ const { identifier } = params;
57
+ // Check if the user exists.
58
+ const user = await strapi1.db.query('plugin::users-permissions.user').findOne({
59
+ where: {
60
+ provider,
61
+ $or: [
62
+ {
63
+ email: identifier.toLowerCase()
64
+ },
65
+ {
66
+ username: identifier
67
+ }
68
+ ]
69
+ }
70
+ });
71
+ if (!user) {
72
+ throw new ValidationError('Invalid identifier or password');
73
+ }
74
+ if (!user.password) {
75
+ throw new ValidationError('Invalid identifier or password');
76
+ }
77
+ const validPassword = await getService('user').validatePassword(params.password, user.password);
78
+ if (!validPassword) {
79
+ throw new ValidationError('Invalid identifier or password');
80
+ }
81
+ const advancedSettings = await store.get({
82
+ key: 'advanced'
83
+ });
84
+ const requiresConfirmation = _.get(advancedSettings, 'email_confirmation');
85
+ if (requiresConfirmation && user.confirmed !== true) {
86
+ throw new ApplicationError('Your account email is not confirmed');
87
+ }
88
+ if (user.blocked === true) {
89
+ throw new ApplicationError('Your account has been blocked by an administrator');
90
+ }
91
+ const mode = strapi1.config.get('plugin::users-permissions.jwtManagement', 'legacy-support');
92
+ if (mode === 'refresh') {
93
+ const deviceId = extractDeviceId(ctx.request.body);
94
+ const refresh = await strapi1.sessionManager('users-permissions').generateRefreshToken(String(user.id), deviceId, {
95
+ type: 'refresh'
96
+ });
97
+ const access = await strapi1.sessionManager('users-permissions').generateAccessToken(refresh.token);
98
+ if ('error' in access) {
99
+ throw new ApplicationError('Invalid credentials');
100
+ }
101
+ const upSessions = strapi1.config.get('plugin::users-permissions.sessions');
102
+ const requestHttpOnly = ctx.request.header['x-strapi-refresh-cookie'] === 'httpOnly';
103
+ if (upSessions?.httpOnly || requestHttpOnly) {
104
+ const cookieName = upSessions.cookie?.name || 'strapi_up_refresh';
105
+ const isProduction = process.env.NODE_ENV === 'production';
106
+ const isSecure = typeof upSessions.cookie?.secure === 'boolean' ? upSessions.cookie?.secure : isProduction;
107
+ const cookieOptions = {
108
+ httpOnly: true,
109
+ secure: isSecure,
110
+ sameSite: upSessions.cookie?.sameSite ?? 'lax',
111
+ path: upSessions.cookie?.path ?? '/',
112
+ domain: upSessions.cookie?.domain,
113
+ overwrite: true
114
+ };
115
+ ctx.cookies.set(cookieName, refresh.token, cookieOptions);
116
+ return ctx.send({
117
+ jwt: access.token,
118
+ user: await sanitizeUser(user, ctx)
119
+ });
120
+ }
121
+ return ctx.send({
122
+ jwt: access.token,
123
+ refreshToken: refresh.token,
124
+ user: await sanitizeUser(user, ctx)
125
+ });
126
+ }
127
+ return ctx.send({
128
+ jwt: getService('jwt').issue({
129
+ id: user.id
130
+ }),
131
+ user: await sanitizeUser(user, ctx)
132
+ });
133
+ }
134
+ // Connect the user with the third-party provider.
135
+ try {
136
+ const user = await getService('providers').connect(provider, ctx.query);
137
+ if (user.blocked) {
138
+ throw new ForbiddenError('Your account has been blocked by an administrator');
139
+ }
140
+ const mode = strapi1.config.get('plugin::users-permissions.jwtManagement', 'legacy-support');
141
+ if (mode === 'refresh') {
142
+ const deviceId = extractDeviceId(ctx.request.body);
143
+ const refresh = await strapi1.sessionManager('users-permissions').generateRefreshToken(String(user.id), deviceId, {
144
+ type: 'refresh'
145
+ });
146
+ const access = await strapi1.sessionManager('users-permissions').generateAccessToken(refresh.token);
147
+ if ('error' in access) {
148
+ throw new ApplicationError('Invalid credentials');
149
+ }
150
+ const upSessions = strapi1.config.get('plugin::users-permissions.sessions');
151
+ const requestHttpOnly = ctx.request.header['x-strapi-refresh-cookie'] === 'httpOnly';
152
+ if (upSessions?.httpOnly || requestHttpOnly) {
153
+ const cookieName = upSessions.cookie?.name || 'strapi_up_refresh';
154
+ const isProduction = process.env.NODE_ENV === 'production';
155
+ const isSecure = typeof upSessions.cookie?.secure === 'boolean' ? upSessions.cookie?.secure : isProduction;
156
+ const cookieOptions = {
157
+ httpOnly: true,
158
+ secure: isSecure,
159
+ sameSite: upSessions.cookie?.sameSite ?? 'lax',
160
+ path: upSessions.cookie?.path ?? '/',
161
+ domain: upSessions.cookie?.domain,
162
+ overwrite: true
163
+ };
164
+ ctx.cookies.set(cookieName, refresh.token, cookieOptions);
165
+ return ctx.send({
166
+ jwt: access.token,
167
+ user: await sanitizeUser(user, ctx)
168
+ });
169
+ }
170
+ return ctx.send({
171
+ jwt: access.token,
172
+ refreshToken: refresh.token,
173
+ user: await sanitizeUser(user, ctx)
174
+ });
175
+ }
176
+ return ctx.send({
177
+ jwt: getService('jwt').issue({
178
+ id: user.id
179
+ }),
180
+ user: await sanitizeUser(user, ctx)
181
+ });
182
+ } catch (error) {
183
+ throw new ApplicationError(error.message);
184
+ }
185
+ },
186
+ async changePassword (ctx) {
187
+ if (!ctx.state.user) {
188
+ throw new ApplicationError('You must be authenticated to reset your password');
189
+ }
190
+ const validations = strapi1.config.get('plugin::users-permissions.validationRules');
191
+ const { currentPassword, password } = await validateChangePasswordBody(ctx.request.body, validations);
192
+ const user = await strapi1.db.query('plugin::users-permissions.user').findOne({
193
+ where: {
194
+ id: ctx.state.user.id
195
+ }
196
+ });
197
+ const validPassword = await getService('user').validatePassword(currentPassword, user.password);
198
+ if (!validPassword) {
199
+ throw new ValidationError('The provided current password is invalid');
200
+ }
201
+ if (currentPassword === password) {
202
+ throw new ValidationError('Your new password must be different than your current password');
203
+ }
204
+ await getService('user').edit(user.id, {
205
+ password
206
+ });
207
+ const mode = strapi1.config.get('plugin::users-permissions.jwtManagement', 'legacy-support');
208
+ if (mode === 'refresh') {
209
+ const deviceId = extractDeviceId(ctx.request.body);
210
+ if (deviceId) {
211
+ // Invalidate sessions: specific device if deviceId provided
212
+ await strapi1.sessionManager('users-permissions').invalidateRefreshToken(String(user.id), deviceId);
213
+ }
214
+ const newDeviceId = deviceId || crypto.randomUUID();
215
+ const refresh = await strapi1.sessionManager('users-permissions').generateRefreshToken(String(user.id), newDeviceId, {
216
+ type: 'refresh'
217
+ });
218
+ const access = await strapi1.sessionManager('users-permissions').generateAccessToken(refresh.token);
219
+ if ('error' in access) {
220
+ throw new ApplicationError('Invalid credentials');
221
+ }
222
+ return ctx.send({
223
+ jwt: access.token,
224
+ refreshToken: refresh.token,
225
+ user: await sanitizeUser(user, ctx)
226
+ });
227
+ }
228
+ return ctx.send({
229
+ jwt: getService('jwt').issue({
230
+ id: user.id
231
+ }),
232
+ user: await sanitizeUser(user, ctx)
233
+ });
234
+ },
235
+ async resetPassword (ctx) {
236
+ const validations = strapi1.config.get('plugin::users-permissions.validationRules');
237
+ const { password, passwordConfirmation, code } = await validateResetPasswordBody(ctx.request.body, validations);
238
+ if (password !== passwordConfirmation) {
239
+ throw new ValidationError('Passwords do not match');
240
+ }
241
+ const user = await strapi1.db.query('plugin::users-permissions.user').findOne({
242
+ where: {
243
+ resetPasswordToken: code
244
+ }
245
+ });
246
+ if (!user) {
247
+ throw new ValidationError('Incorrect code provided');
248
+ }
249
+ await getService('user').edit(user.id, {
250
+ resetPasswordToken: null,
251
+ password
252
+ });
253
+ const mode = strapi1.config.get('plugin::users-permissions.jwtManagement', 'legacy-support');
254
+ if (mode === 'refresh') {
255
+ const deviceId = extractDeviceId(ctx.request.body);
256
+ if (deviceId) {
257
+ // Invalidate sessions: specific device if deviceId provided
258
+ await strapi1.sessionManager('users-permissions').invalidateRefreshToken(String(user.id), deviceId);
259
+ }
260
+ const newDeviceId = deviceId || crypto.randomUUID();
261
+ const refresh = await strapi1.sessionManager('users-permissions').generateRefreshToken(String(user.id), newDeviceId, {
262
+ type: 'refresh'
263
+ });
264
+ const access = await strapi1.sessionManager('users-permissions').generateAccessToken(refresh.token);
265
+ if ('error' in access) {
266
+ throw new ApplicationError('Invalid credentials');
267
+ }
268
+ return ctx.send({
269
+ jwt: access.token,
270
+ refreshToken: refresh.token,
271
+ user: await sanitizeUser(user, ctx)
272
+ });
273
+ }
274
+ return ctx.send({
275
+ jwt: getService('jwt').issue({
276
+ id: user.id
277
+ }),
278
+ user: await sanitizeUser(user, ctx)
279
+ });
280
+ },
281
+ async refresh (ctx) {
282
+ const mode = strapi1.config.get('plugin::users-permissions.jwtManagement', 'legacy-support');
283
+ if (mode !== 'refresh') {
284
+ return ctx.notFound();
285
+ }
286
+ const { refreshToken } = ctx.request.body || {};
287
+ if (!refreshToken || typeof refreshToken !== 'string') {
288
+ return ctx.badRequest('Missing refresh token');
289
+ }
290
+ const rotation = await strapi1.sessionManager('users-permissions').rotateRefreshToken(refreshToken);
291
+ if ('error' in rotation) {
292
+ return ctx.unauthorized('Invalid refresh token');
293
+ }
294
+ const result = await strapi1.sessionManager('users-permissions').generateAccessToken(rotation.token);
295
+ if ('error' in result) {
296
+ return ctx.unauthorized('Invalid refresh token');
297
+ }
298
+ const upSessions = strapi1.config.get('plugin::users-permissions.sessions');
299
+ const requestHttpOnly = ctx.request.header['x-strapi-refresh-cookie'] === 'httpOnly';
300
+ if (upSessions?.httpOnly || requestHttpOnly) {
301
+ const cookieName = upSessions.cookie?.name || 'strapi_up_refresh';
302
+ const isProduction = process.env.NODE_ENV === 'production';
303
+ const isSecure = typeof upSessions.cookie?.secure === 'boolean' ? upSessions.cookie?.secure : isProduction;
304
+ const cookieOptions = {
305
+ httpOnly: true,
306
+ secure: isSecure,
307
+ sameSite: upSessions.cookie?.sameSite ?? 'lax',
308
+ path: upSessions.cookie?.path ?? '/',
309
+ domain: upSessions.cookie?.domain,
310
+ overwrite: true
311
+ };
312
+ ctx.cookies.set(cookieName, rotation.token, cookieOptions);
313
+ return ctx.send({
314
+ jwt: result.token
315
+ });
316
+ }
317
+ return ctx.send({
318
+ jwt: result.token,
319
+ refreshToken: rotation.token
320
+ });
321
+ },
322
+ async logout (ctx) {
323
+ const mode = strapi1.config.get('plugin::users-permissions.jwtManagement', 'legacy-support');
324
+ if (mode !== 'refresh') {
325
+ return ctx.notFound();
326
+ }
327
+ // Invalidate all sessions for the authenticated user, or by deviceId if provided
328
+ if (!ctx.state.user) {
329
+ return ctx.unauthorized('Missing authentication');
330
+ }
331
+ const deviceId = extractDeviceId(ctx.request.body);
332
+ try {
333
+ await strapi1.sessionManager('users-permissions').invalidateRefreshToken(String(ctx.state.user.id), deviceId);
334
+ } catch (err) {
335
+ strapi1.log.error('UP logout failed', err);
336
+ }
337
+ const upSessions = strapi1.config.get('plugin::users-permissions.sessions');
338
+ const requestHttpOnly = ctx.request.header['x-strapi-refresh-cookie'] === 'httpOnly';
339
+ if (upSessions?.httpOnly || requestHttpOnly) {
340
+ const cookieName = upSessions.cookie?.name || 'strapi_up_refresh';
341
+ ctx.cookies.set(cookieName, '', {
342
+ expires: new Date(0)
343
+ });
344
+ }
345
+ return ctx.send({
346
+ ok: true
347
+ });
348
+ },
349
+ async connect (ctx, next) {
350
+ const grant = require$$6.koa();
351
+ const providers = await strapi1.store({
352
+ type: 'plugin',
353
+ name: 'users-permissions',
354
+ key: 'grant'
355
+ }).get();
356
+ const apiPrefix = strapi1.config.get('api.rest.prefix');
357
+ const grantConfig = {
358
+ defaults: {
359
+ prefix: `${apiPrefix}/connect`
360
+ },
361
+ ...providers
362
+ };
363
+ const [requestPath] = ctx.request.url.split('?');
364
+ const provider = requestPath.split('/connect/')[1].split('/')[0];
365
+ if (!_.get(grantConfig[provider], 'enabled')) {
366
+ throw new ApplicationError('This provider is disabled');
367
+ }
368
+ if (!strapi1.config.server.url.startsWith('http')) {
369
+ strapi1.log.warn('You are using a third party provider for login. Make sure to set an absolute url in config/server.js. More info here: https://docs.strapi.io/developer-docs/latest/plugins/users-permissions.html#setting-up-the-server-url');
370
+ }
371
+ // Ability to pass OAuth callback dynamically
372
+ const queryCustomCallback = _.get(ctx, 'query.callback');
373
+ const dynamicSessionCallback = _.get(ctx, 'session.grant.dynamic.callback');
374
+ const customCallback = queryCustomCallback ?? dynamicSessionCallback;
375
+ // The custom callback is validated to make sure it's not redirecting to an unwanted actor.
376
+ if (customCallback !== undefined) {
377
+ try {
378
+ // We're extracting the callback validator from the plugin config since it can be user-customized
379
+ const { validate: validateCallback } = strapi1.plugin('users-permissions').config('callback');
380
+ await validateCallback(customCallback, grantConfig[provider]);
381
+ grantConfig[provider].callback = customCallback;
382
+ } catch (e) {
383
+ throw new ValidationError('Invalid callback URL provided', {
384
+ callback: customCallback
385
+ });
386
+ }
387
+ }
388
+ // Build a valid redirect URI for the current provider
389
+ grantConfig[provider].redirect_uri = getService('providers').buildRedirectUri(provider);
390
+ return grant(grantConfig)(ctx, next);
391
+ },
392
+ async forgotPassword (ctx) {
393
+ const { email } = await validateForgotPasswordBody(ctx.request.body);
394
+ const pluginStore = await strapi1.store({
395
+ type: 'plugin',
396
+ name: 'users-permissions'
397
+ });
398
+ const emailSettings = await pluginStore.get({
399
+ key: 'email'
400
+ });
401
+ const advancedSettings = await pluginStore.get({
402
+ key: 'advanced'
403
+ });
404
+ // Find the user by email.
405
+ const user = await strapi1.db.query('plugin::users-permissions.user').findOne({
406
+ where: {
407
+ email: email.toLowerCase()
408
+ }
409
+ });
410
+ if (!user || user.blocked) {
411
+ return ctx.send({
412
+ ok: true
413
+ });
414
+ }
415
+ // Generate random token.
416
+ const userInfo = await sanitizeUser(user, ctx);
417
+ const resetPasswordToken = crypto.randomBytes(64).toString('hex');
418
+ const resetPasswordSettings = _.get(emailSettings, 'reset_password.options', {});
419
+ const emailBody = await getService('users-permissions').template(resetPasswordSettings.message, {
420
+ URL: advancedSettings.email_reset_password,
421
+ SERVER_URL: strapi1.config.get('server.absoluteUrl'),
422
+ ADMIN_URL: strapi1.config.get('admin.absoluteUrl'),
423
+ USER: userInfo,
424
+ TOKEN: resetPasswordToken
425
+ });
426
+ const emailObject = await getService('users-permissions').template(resetPasswordSettings.object, {
427
+ USER: userInfo
428
+ });
429
+ const emailToSend = {
430
+ to: user.email,
431
+ from: resetPasswordSettings.from.email || resetPasswordSettings.from.name ? `${resetPasswordSettings.from.name} <${resetPasswordSettings.from.email}>` : undefined,
432
+ replyTo: resetPasswordSettings.response_email,
433
+ subject: emailObject,
434
+ text: emailBody,
435
+ html: emailBody
436
+ };
437
+ // NOTE: Update the user before sending the email so an Admin can generate the link if the email fails
438
+ await getService('user').edit(user.id, {
439
+ resetPasswordToken
440
+ });
441
+ // Send an email to the user.
442
+ await strapi1.plugin('email').service('email').send(emailToSend);
443
+ ctx.send({
444
+ ok: true
445
+ });
446
+ },
447
+ async register (ctx) {
448
+ const pluginStore = await strapi1.store({
449
+ type: 'plugin',
450
+ name: 'users-permissions'
451
+ });
452
+ const settings = await pluginStore.get({
453
+ key: 'advanced'
454
+ });
455
+ if (!settings.allow_register) {
456
+ throw new ApplicationError('Register action is currently disabled');
457
+ }
458
+ const { register } = strapi1.config.get('plugin::users-permissions');
459
+ const alwaysAllowedKeys = [
460
+ 'username',
461
+ 'password',
462
+ 'email'
463
+ ];
464
+ // Note that we intentionally do not filter allowedFields to allow a project to explicitly accept private or other Strapi field on registration
465
+ const allowedKeys = compact(concat(alwaysAllowedKeys, isArray(register?.allowedFields) ? register.allowedFields : []));
466
+ // Check if there are any keys in requestBody that are not in allowedKeys
467
+ const invalidKeys = Object.keys(ctx.request.body).filter((key)=>!allowedKeys.includes(key));
468
+ if (invalidKeys.length > 0) {
469
+ // If there are invalid keys, throw an error
470
+ throw new ValidationError(`Invalid parameters: ${invalidKeys.join(', ')}`);
471
+ }
472
+ const params = {
473
+ ..._.pick(ctx.request.body, allowedKeys),
474
+ provider: 'local'
475
+ };
476
+ const validations = strapi1.config.get('plugin::users-permissions.validationRules');
477
+ await validateRegisterBody(params, validations);
478
+ const role = await strapi1.db.query('plugin::users-permissions.role').findOne({
479
+ where: {
480
+ type: settings.default_role
481
+ }
482
+ });
483
+ if (!role) {
484
+ throw new ApplicationError('Impossible to find the default role');
485
+ }
486
+ const { email, username, provider } = params;
487
+ const identifierFilter = {
488
+ $or: [
489
+ {
490
+ email: email.toLowerCase()
491
+ },
492
+ {
493
+ username: email.toLowerCase()
494
+ },
495
+ {
496
+ username
497
+ },
498
+ {
499
+ email: username
500
+ }
501
+ ]
502
+ };
503
+ const conflictingUserCount = await strapi1.db.query('plugin::users-permissions.user').count({
504
+ where: {
505
+ ...identifierFilter,
506
+ provider
507
+ }
508
+ });
509
+ if (conflictingUserCount > 0) {
510
+ throw new ApplicationError('Email or Username are already taken');
511
+ }
512
+ if (settings.unique_email) {
513
+ const conflictingUserCount = await strapi1.db.query('plugin::users-permissions.user').count({
514
+ where: {
515
+ ...identifierFilter
516
+ }
517
+ });
518
+ if (conflictingUserCount > 0) {
519
+ throw new ApplicationError('Email or Username are already taken');
520
+ }
521
+ }
522
+ const newUser = {
523
+ ...params,
524
+ role: role.id,
525
+ email: email.toLowerCase(),
526
+ username,
527
+ confirmed: !settings.email_confirmation
528
+ };
529
+ const user = await getService('user').add(newUser);
530
+ const sanitizedUser = await sanitizeUser(user, ctx);
531
+ if (settings.email_confirmation) {
532
+ try {
533
+ await getService('user').sendConfirmationEmail(sanitizedUser);
534
+ } catch (err) {
535
+ strapi1.log.error(err);
536
+ throw new ApplicationError('Error sending confirmation email');
537
+ }
538
+ return ctx.send({
539
+ user: sanitizedUser
540
+ });
541
+ }
542
+ const mode = strapi1.config.get('plugin::users-permissions.jwtManagement', 'legacy-support');
543
+ if (mode === 'refresh') {
544
+ const deviceId = extractDeviceId(ctx.request.body) || crypto.randomUUID();
545
+ const refresh = await strapi1.sessionManager('users-permissions').generateRefreshToken(String(user.id), deviceId, {
546
+ type: 'refresh'
547
+ });
548
+ const access = await strapi1.sessionManager('users-permissions').generateAccessToken(refresh.token);
549
+ if ('error' in access) {
550
+ throw new ApplicationError('Invalid credentials');
551
+ }
552
+ return ctx.send({
553
+ jwt: access.token,
554
+ refreshToken: refresh.token,
555
+ user: sanitizedUser
556
+ });
557
+ }
558
+ const jwt = getService('jwt').issue(_.pick(user, [
559
+ 'id'
560
+ ]));
561
+ return ctx.send({
562
+ jwt,
563
+ user: sanitizedUser
564
+ });
565
+ },
566
+ async emailConfirmation (ctx, next, returnUser) {
567
+ const { confirmation: confirmationToken } = await validateEmailConfirmationBody(ctx.query);
568
+ const userService = getService('user');
569
+ const jwtService = getService('jwt');
570
+ const [user] = await userService.fetchAll({
571
+ filters: {
572
+ confirmationToken
573
+ }
574
+ });
575
+ if (!user) {
576
+ throw new ValidationError('Invalid token');
577
+ }
578
+ await userService.edit(user.id, {
579
+ confirmed: true,
580
+ confirmationToken: null
581
+ });
582
+ if (returnUser) {
583
+ ctx.send({
584
+ jwt: jwtService.issue({
585
+ id: user.id
586
+ }),
587
+ user: await sanitizeUser(user, ctx)
588
+ });
589
+ } else {
590
+ const settings = await strapi1.store({
591
+ type: 'plugin',
592
+ name: 'users-permissions',
593
+ key: 'advanced'
594
+ }).get();
595
+ ctx.redirect(settings.email_confirmation_redirection || '/');
596
+ }
597
+ },
598
+ async sendEmailConfirmation (ctx) {
599
+ const { email } = await validateSendEmailConfirmationBody(ctx.request.body);
600
+ const user = await strapi1.db.query('plugin::users-permissions.user').findOne({
601
+ where: {
602
+ email: email.toLowerCase()
603
+ }
604
+ });
605
+ if (!user) {
606
+ return ctx.send({
607
+ email,
608
+ sent: true
609
+ });
610
+ }
611
+ if (user.confirmed) {
612
+ throw new ApplicationError('Already confirmed');
613
+ }
614
+ if (user.blocked) {
615
+ throw new ApplicationError('User blocked');
616
+ }
617
+ await getService('user').sendConfirmationEmail(user);
618
+ ctx.send({
619
+ email: user.email,
620
+ sent: true
621
+ });
622
+ }
623
+ });
624
+ return auth;
625
+ }
626
+
627
+ export { requireAuth as __require };
628
+ //# sourceMappingURL=auth.mjs.map