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