@strapi/plugin-users-permissions 5.12.1 → 5.12.2

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 (634) hide show
  1. package/dist/admin/components/BoundRoute/getMethodColor.js +49 -0
  2. package/dist/admin/components/BoundRoute/getMethodColor.js.map +1 -0
  3. package/dist/admin/components/BoundRoute/getMethodColor.mjs +47 -0
  4. package/dist/admin/components/BoundRoute/getMethodColor.mjs.map +1 -0
  5. package/dist/admin/components/BoundRoute/index.js +98 -0
  6. package/dist/admin/components/BoundRoute/index.js.map +1 -0
  7. package/dist/admin/components/BoundRoute/index.mjs +96 -0
  8. package/dist/admin/components/BoundRoute/index.mjs.map +1 -0
  9. package/dist/admin/components/FormModal/Input/index.js +123 -0
  10. package/dist/admin/components/FormModal/Input/index.js.map +1 -0
  11. package/dist/admin/components/FormModal/Input/index.mjs +121 -0
  12. package/dist/admin/components/FormModal/Input/index.mjs.map +1 -0
  13. package/dist/admin/components/FormModal/index.js +110 -0
  14. package/dist/admin/components/FormModal/index.js.map +1 -0
  15. package/dist/admin/components/FormModal/index.mjs +108 -0
  16. package/dist/admin/components/FormModal/index.mjs.map +1 -0
  17. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.js +33 -0
  18. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.js.map +1 -0
  19. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.mjs +31 -0
  20. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.mjs.map +1 -0
  21. package/dist/admin/components/Permissions/PermissionRow/SubCategory.js +156 -0
  22. package/dist/admin/components/Permissions/PermissionRow/SubCategory.js.map +1 -0
  23. package/dist/admin/components/Permissions/PermissionRow/SubCategory.mjs +154 -0
  24. package/dist/admin/components/Permissions/PermissionRow/SubCategory.mjs.map +1 -0
  25. package/dist/admin/components/Permissions/PermissionRow/index.js +50 -0
  26. package/dist/admin/components/Permissions/PermissionRow/index.js.map +1 -0
  27. package/dist/admin/components/Permissions/PermissionRow/index.mjs +48 -0
  28. package/dist/admin/components/Permissions/PermissionRow/index.mjs.map +1 -0
  29. package/dist/admin/components/Permissions/index.js +52 -0
  30. package/dist/admin/components/Permissions/index.js.map +1 -0
  31. package/dist/admin/components/Permissions/index.mjs +50 -0
  32. package/dist/admin/components/Permissions/index.mjs.map +1 -0
  33. package/dist/admin/components/Permissions/init.js +15 -0
  34. package/dist/admin/components/Permissions/init.js.map +1 -0
  35. package/dist/admin/components/Permissions/init.mjs +13 -0
  36. package/dist/admin/components/Permissions/init.mjs.map +1 -0
  37. package/dist/admin/components/Permissions/reducer.js +34 -0
  38. package/dist/admin/components/Permissions/reducer.js.map +1 -0
  39. package/dist/admin/components/Permissions/reducer.mjs +31 -0
  40. package/dist/admin/components/Permissions/reducer.mjs.map +1 -0
  41. package/dist/admin/components/Policies/index.js +67 -0
  42. package/dist/admin/components/Policies/index.js.map +1 -0
  43. package/dist/admin/components/Policies/index.mjs +65 -0
  44. package/dist/admin/components/Policies/index.mjs.map +1 -0
  45. package/dist/admin/components/UsersPermissions/index.js +115 -0
  46. package/dist/admin/components/UsersPermissions/index.js.map +1 -0
  47. package/dist/admin/components/UsersPermissions/index.mjs +113 -0
  48. package/dist/admin/components/UsersPermissions/index.mjs.map +1 -0
  49. package/dist/admin/components/UsersPermissions/init.js +13 -0
  50. package/dist/admin/components/UsersPermissions/init.js.map +1 -0
  51. package/dist/admin/components/UsersPermissions/init.mjs +11 -0
  52. package/dist/admin/components/UsersPermissions/init.mjs.map +1 -0
  53. package/dist/admin/components/UsersPermissions/reducer.js +73 -0
  54. package/dist/admin/components/UsersPermissions/reducer.js.map +1 -0
  55. package/dist/admin/components/UsersPermissions/reducer.mjs +68 -0
  56. package/dist/admin/components/UsersPermissions/reducer.mjs.map +1 -0
  57. package/dist/admin/constants.js +81 -0
  58. package/dist/admin/constants.js.map +1 -0
  59. package/dist/admin/constants.mjs +79 -0
  60. package/dist/admin/constants.mjs.map +1 -0
  61. package/dist/admin/contexts/UsersPermissionsContext/index.js +23 -0
  62. package/dist/admin/contexts/UsersPermissionsContext/index.js.map +1 -0
  63. package/dist/admin/contexts/UsersPermissionsContext/index.mjs +19 -0
  64. package/dist/admin/contexts/UsersPermissionsContext/index.mjs.map +1 -0
  65. package/dist/admin/index.js +119 -2
  66. package/dist/admin/index.js.map +1 -1
  67. package/dist/admin/index.mjs +120 -1
  68. package/dist/admin/index.mjs.map +1 -1
  69. package/dist/admin/package.json.js +14 -0
  70. package/dist/admin/package.json.js.map +1 -0
  71. package/dist/admin/package.json.mjs +11 -0
  72. package/dist/admin/package.json.mjs.map +1 -0
  73. package/dist/admin/{chunks/index-DFnYIqrB.js → pages/AdvancedSettings/index.js} +14 -121
  74. package/dist/admin/pages/AdvancedSettings/index.js.map +1 -0
  75. package/dist/admin/{chunks/index-Cy-tPfRk.mjs → pages/AdvancedSettings/index.mjs} +6 -94
  76. package/dist/admin/pages/AdvancedSettings/index.mjs.map +1 -0
  77. package/dist/admin/pages/AdvancedSettings/utils/layout.js +83 -0
  78. package/dist/admin/pages/AdvancedSettings/utils/layout.js.map +1 -0
  79. package/dist/admin/pages/AdvancedSettings/utils/layout.mjs +81 -0
  80. package/dist/admin/pages/AdvancedSettings/utils/layout.mjs.map +1 -0
  81. package/dist/admin/pages/AdvancedSettings/utils/schema.js +40 -0
  82. package/dist/admin/pages/AdvancedSettings/utils/schema.js.map +1 -0
  83. package/dist/admin/pages/AdvancedSettings/utils/schema.mjs +19 -0
  84. package/dist/admin/pages/AdvancedSettings/utils/schema.mjs.map +1 -0
  85. package/dist/admin/pages/EmailTemplates/components/EmailForm.js +171 -0
  86. package/dist/admin/pages/EmailTemplates/components/EmailForm.js.map +1 -0
  87. package/dist/admin/pages/EmailTemplates/components/EmailForm.mjs +169 -0
  88. package/dist/admin/pages/EmailTemplates/components/EmailForm.mjs.map +1 -0
  89. package/dist/admin/pages/EmailTemplates/components/EmailTable.js +145 -0
  90. package/dist/admin/pages/EmailTemplates/components/EmailTable.js.map +1 -0
  91. package/dist/admin/pages/EmailTemplates/components/EmailTable.mjs +143 -0
  92. package/dist/admin/pages/EmailTemplates/components/EmailTable.mjs.map +1 -0
  93. package/dist/admin/pages/EmailTemplates/index.js +157 -0
  94. package/dist/admin/pages/EmailTemplates/index.js.map +1 -0
  95. package/dist/admin/pages/EmailTemplates/index.mjs +135 -0
  96. package/dist/admin/pages/EmailTemplates/index.mjs.map +1 -0
  97. package/dist/admin/pages/EmailTemplates/utils/schema.js +50 -0
  98. package/dist/admin/pages/EmailTemplates/utils/schema.js.map +1 -0
  99. package/dist/admin/pages/EmailTemplates/utils/schema.mjs +29 -0
  100. package/dist/admin/pages/EmailTemplates/utils/schema.mjs.map +1 -0
  101. package/dist/admin/pages/Providers/index.js +278 -0
  102. package/dist/admin/pages/Providers/index.js.map +1 -0
  103. package/dist/admin/pages/Providers/index.mjs +254 -0
  104. package/dist/admin/pages/Providers/index.mjs.map +1 -0
  105. package/dist/admin/pages/Providers/utils/forms.js +281 -0
  106. package/dist/admin/pages/Providers/utils/forms.js.map +1 -0
  107. package/dist/admin/pages/Providers/utils/forms.mjs +260 -0
  108. package/dist/admin/pages/Providers/utils/forms.mjs.map +1 -0
  109. package/dist/admin/pages/Roles/constants.js +31 -0
  110. package/dist/admin/pages/Roles/constants.js.map +1 -0
  111. package/dist/admin/pages/Roles/constants.mjs +10 -0
  112. package/dist/admin/pages/Roles/constants.mjs.map +1 -0
  113. package/dist/admin/pages/Roles/hooks/usePlugins.js +78 -0
  114. package/dist/admin/pages/Roles/hooks/usePlugins.js.map +1 -0
  115. package/dist/admin/pages/Roles/hooks/usePlugins.mjs +76 -0
  116. package/dist/admin/pages/Roles/hooks/usePlugins.mjs.map +1 -0
  117. package/dist/admin/pages/Roles/index.js +35 -0
  118. package/dist/admin/pages/Roles/index.js.map +1 -0
  119. package/dist/admin/pages/Roles/index.mjs +33 -0
  120. package/dist/admin/pages/Roles/index.mjs.map +1 -0
  121. package/dist/admin/pages/Roles/pages/CreatePage.js +225 -0
  122. package/dist/admin/pages/Roles/pages/CreatePage.js.map +1 -0
  123. package/dist/admin/pages/Roles/pages/CreatePage.mjs +203 -0
  124. package/dist/admin/pages/Roles/pages/CreatePage.mjs.map +1 -0
  125. package/dist/admin/pages/Roles/pages/EditPage.js +229 -0
  126. package/dist/admin/pages/Roles/pages/EditPage.js.map +1 -0
  127. package/dist/admin/pages/Roles/pages/EditPage.mjs +207 -0
  128. package/dist/admin/pages/Roles/pages/EditPage.mjs.map +1 -0
  129. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.js +125 -0
  130. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.js.map +1 -0
  131. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.mjs +123 -0
  132. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.mjs.map +1 -0
  133. package/dist/admin/pages/Roles/pages/ListPage/index.js +237 -0
  134. package/dist/admin/pages/Roles/pages/ListPage/index.js.map +1 -0
  135. package/dist/admin/pages/Roles/pages/ListPage/index.mjs +234 -0
  136. package/dist/admin/pages/Roles/pages/ListPage/index.mjs.map +1 -0
  137. package/dist/admin/pluginId.js +8 -0
  138. package/dist/admin/pluginId.js.map +1 -0
  139. package/dist/admin/pluginId.mjs +6 -0
  140. package/dist/admin/pluginId.mjs.map +1 -0
  141. package/dist/admin/{chunks/ar-BJwjobLp.js → translations/ar.json.js} +2 -2
  142. package/dist/admin/translations/ar.json.js.map +1 -0
  143. package/dist/admin/{chunks/ar-G6bUGuUb.mjs → translations/ar.json.mjs} +1 -1
  144. package/dist/admin/translations/ar.json.mjs.map +1 -0
  145. package/dist/admin/{chunks/cs-uS_SIEo8.js → translations/cs.json.js} +2 -2
  146. package/dist/admin/translations/cs.json.js.map +1 -0
  147. package/dist/admin/{chunks/cs-Bu59JqhG.mjs → translations/cs.json.mjs} +1 -1
  148. package/dist/admin/translations/cs.json.mjs.map +1 -0
  149. package/dist/admin/{chunks/de-7MVMrqqI.js → translations/de.json.js} +2 -2
  150. package/dist/admin/translations/de.json.js.map +1 -0
  151. package/dist/admin/{chunks/de-B81A69_5.mjs → translations/de.json.mjs} +1 -1
  152. package/dist/admin/translations/de.json.mjs.map +1 -0
  153. package/dist/admin/{chunks/dk-DwCLGmy9.js → translations/dk.json.js} +2 -2
  154. package/dist/admin/translations/dk.json.js.map +1 -0
  155. package/dist/admin/{chunks/dk-BaelzvBE.mjs → translations/dk.json.mjs} +1 -1
  156. package/dist/admin/translations/dk.json.mjs.map +1 -0
  157. package/dist/admin/{chunks/en-DwQjkHi_.js → translations/en.json.js} +2 -2
  158. package/dist/admin/translations/en.json.js.map +1 -0
  159. package/dist/admin/{chunks/en-BhgCBe7M.mjs → translations/en.json.mjs} +1 -1
  160. package/dist/admin/translations/en.json.mjs.map +1 -0
  161. package/dist/admin/{chunks/es-BOJOedG5.js → translations/es.json.js} +2 -2
  162. package/dist/admin/translations/es.json.js.map +1 -0
  163. package/dist/admin/{chunks/es-B0wXmvRj.mjs → translations/es.json.mjs} +1 -1
  164. package/dist/admin/translations/es.json.mjs.map +1 -0
  165. package/dist/admin/{chunks/fr-BDNWCNs0.js → translations/fr.json.js} +2 -2
  166. package/dist/admin/translations/fr.json.js.map +1 -0
  167. package/dist/admin/{chunks/fr-CGYvGUXg.mjs → translations/fr.json.mjs} +1 -1
  168. package/dist/admin/translations/fr.json.mjs.map +1 -0
  169. package/dist/admin/{chunks/id-UqUPykHZ.js → translations/id.json.js} +2 -2
  170. package/dist/admin/translations/id.json.js.map +1 -0
  171. package/dist/admin/{chunks/id-CNzbwFjA.mjs → translations/id.json.mjs} +1 -1
  172. package/dist/admin/translations/id.json.mjs.map +1 -0
  173. package/dist/admin/{chunks/it-D5VuyoLU.js → translations/it.json.js} +2 -2
  174. package/dist/admin/translations/it.json.js.map +1 -0
  175. package/dist/admin/{chunks/it-B2H2foTf.mjs → translations/it.json.mjs} +1 -1
  176. package/dist/admin/translations/it.json.mjs.map +1 -0
  177. package/dist/admin/{chunks/ja-MpqVsCgs.js → translations/ja.json.js} +2 -2
  178. package/dist/admin/translations/ja.json.js.map +1 -0
  179. package/dist/admin/{chunks/ja-C0z9d7L9.mjs → translations/ja.json.mjs} +1 -1
  180. package/dist/admin/translations/ja.json.mjs.map +1 -0
  181. package/dist/admin/{chunks/ko-Bm-grPSc.js → translations/ko.json.js} +2 -2
  182. package/dist/admin/translations/ko.json.js.map +1 -0
  183. package/dist/admin/{chunks/ko-CzUgzpeS.mjs → translations/ko.json.mjs} +1 -1
  184. package/dist/admin/translations/ko.json.mjs.map +1 -0
  185. package/dist/admin/{chunks/ms-D7eyBD5H.js → translations/ms.json.js} +2 -2
  186. package/dist/admin/translations/ms.json.js.map +1 -0
  187. package/dist/admin/{chunks/ms-CCacxjim.mjs → translations/ms.json.mjs} +1 -1
  188. package/dist/admin/translations/ms.json.mjs.map +1 -0
  189. package/dist/admin/{chunks/nl-BIOwAQtI.js → translations/nl.json.js} +2 -2
  190. package/dist/admin/translations/nl.json.js.map +1 -0
  191. package/dist/admin/{chunks/nl-DDC3nZW-.mjs → translations/nl.json.mjs} +1 -1
  192. package/dist/admin/translations/nl.json.mjs.map +1 -0
  193. package/dist/admin/{chunks/pl-D5BeNrg_.js → translations/pl.json.js} +2 -2
  194. package/dist/admin/translations/pl.json.js.map +1 -0
  195. package/dist/admin/{chunks/pl-XkS463rN.mjs → translations/pl.json.mjs} +1 -1
  196. package/dist/admin/translations/pl.json.mjs.map +1 -0
  197. package/dist/admin/{chunks/pt-BR-DxPBzQGx.js → translations/pt-BR.json.js} +2 -2
  198. package/dist/admin/translations/pt-BR.json.js.map +1 -0
  199. package/dist/admin/{chunks/pt-BR-8cC7z8Km.mjs → translations/pt-BR.json.mjs} +1 -1
  200. package/dist/admin/translations/pt-BR.json.mjs.map +1 -0
  201. package/dist/admin/{chunks/pt-kkCwzNvH.js → translations/pt.json.js} +2 -2
  202. package/dist/admin/translations/pt.json.js.map +1 -0
  203. package/dist/admin/{chunks/pt-DQpEvio8.mjs → translations/pt.json.mjs} +1 -1
  204. package/dist/admin/translations/pt.json.mjs.map +1 -0
  205. package/dist/admin/{chunks/ru-BQ0gHmp3.js → translations/ru.json.js} +2 -2
  206. package/dist/admin/translations/ru.json.js.map +1 -0
  207. package/dist/admin/{chunks/ru-nzL_7Mhg.mjs → translations/ru.json.mjs} +1 -1
  208. package/dist/admin/translations/ru.json.mjs.map +1 -0
  209. package/dist/admin/{chunks/sk-nVwAPdYC.js → translations/sk.json.js} +2 -2
  210. package/dist/admin/translations/sk.json.js.map +1 -0
  211. package/dist/admin/{chunks/sk-Ddxc_tZA.mjs → translations/sk.json.mjs} +1 -1
  212. package/dist/admin/translations/sk.json.mjs.map +1 -0
  213. package/dist/admin/{chunks/sv-BDfk2A-F.js → translations/sv.json.js} +2 -2
  214. package/dist/admin/translations/sv.json.js.map +1 -0
  215. package/dist/admin/{chunks/sv-By3RYpMG.mjs → translations/sv.json.mjs} +1 -1
  216. package/dist/admin/translations/sv.json.mjs.map +1 -0
  217. package/dist/admin/{chunks/th-BtTtpHe2.js → translations/th.json.js} +2 -2
  218. package/dist/admin/translations/th.json.js.map +1 -0
  219. package/dist/admin/{chunks/th-COl50vqb.mjs → translations/th.json.mjs} +1 -1
  220. package/dist/admin/translations/th.json.mjs.map +1 -0
  221. package/dist/admin/{chunks/tr-Di-Nf7cT.js → translations/tr.json.js} +2 -2
  222. package/dist/admin/translations/tr.json.js.map +1 -0
  223. package/dist/admin/{chunks/tr-80SJU6jg.mjs → translations/tr.json.mjs} +1 -1
  224. package/dist/admin/translations/tr.json.mjs.map +1 -0
  225. package/dist/admin/{chunks/uk-r5zXTAS7.js → translations/uk.json.js} +2 -2
  226. package/dist/admin/translations/uk.json.js.map +1 -0
  227. package/dist/admin/{chunks/uk-DnrIlPwG.mjs → translations/uk.json.mjs} +1 -1
  228. package/dist/admin/translations/uk.json.mjs.map +1 -0
  229. package/dist/admin/{chunks/vi-D9cCsHsU.js → translations/vi.json.js} +2 -2
  230. package/dist/admin/translations/vi.json.js.map +1 -0
  231. package/dist/admin/{chunks/vi-69AF03Iv.mjs → translations/vi.json.mjs} +1 -1
  232. package/dist/admin/translations/vi.json.mjs.map +1 -0
  233. package/dist/admin/{chunks/zh-Hans-CKqQbpsM.js → translations/zh-Hans.json.js} +2 -2
  234. package/dist/admin/translations/zh-Hans.json.js.map +1 -0
  235. package/dist/admin/{chunks/zh-Hans-DmDcSsp7.mjs → translations/zh-Hans.json.mjs} +1 -1
  236. package/dist/admin/translations/zh-Hans.json.mjs.map +1 -0
  237. package/dist/admin/{chunks/zh-BzWgJEzz.js → translations/zh.json.js} +2 -2
  238. package/dist/admin/translations/zh.json.js.map +1 -0
  239. package/dist/admin/{chunks/zh-BzSkqxo-.mjs → translations/zh.json.mjs} +1 -1
  240. package/dist/admin/translations/zh.json.mjs.map +1 -0
  241. package/dist/admin/utils/cleanPermissions.js +24 -0
  242. package/dist/admin/utils/cleanPermissions.js.map +1 -0
  243. package/dist/admin/utils/cleanPermissions.mjs +22 -0
  244. package/dist/admin/utils/cleanPermissions.mjs.map +1 -0
  245. package/dist/admin/utils/formatPluginName.js +29 -0
  246. package/dist/admin/utils/formatPluginName.js.map +1 -0
  247. package/dist/admin/utils/formatPluginName.mjs +27 -0
  248. package/dist/admin/utils/formatPluginName.mjs.map +1 -0
  249. package/dist/admin/utils/getTrad.js +8 -0
  250. package/dist/admin/utils/getTrad.js.map +1 -0
  251. package/dist/admin/utils/getTrad.mjs +6 -0
  252. package/dist/admin/utils/getTrad.mjs.map +1 -0
  253. package/dist/admin/utils/prefixPluginTranslations.js +11 -0
  254. package/dist/admin/utils/prefixPluginTranslations.js.map +1 -0
  255. package/dist/admin/utils/prefixPluginTranslations.mjs +9 -0
  256. package/dist/admin/utils/prefixPluginTranslations.mjs.map +1 -0
  257. package/dist/server/_virtual/_commonjsHelpers.js +8 -0
  258. package/dist/server/_virtual/_commonjsHelpers.js.map +1 -0
  259. package/dist/server/_virtual/_commonjsHelpers.mjs +6 -0
  260. package/dist/server/_virtual/_commonjsHelpers.mjs.map +1 -0
  261. package/dist/server/bootstrap/index.js +145 -0
  262. package/dist/server/bootstrap/index.js.map +1 -0
  263. package/dist/server/bootstrap/index.mjs +143 -0
  264. package/dist/server/bootstrap/index.mjs.map +1 -0
  265. package/dist/server/bootstrap/users-permissions-actions.js +98 -0
  266. package/dist/server/bootstrap/users-permissions-actions.js.map +1 -0
  267. package/dist/server/bootstrap/users-permissions-actions.mjs +96 -0
  268. package/dist/server/bootstrap/users-permissions-actions.mjs.map +1 -0
  269. package/dist/server/config.js +54 -0
  270. package/dist/server/config.js.map +1 -0
  271. package/dist/server/config.mjs +52 -0
  272. package/dist/server/config.mjs.map +1 -0
  273. package/dist/server/content-types/index.js +30 -0
  274. package/dist/server/content-types/index.js.map +1 -0
  275. package/dist/server/content-types/index.mjs +28 -0
  276. package/dist/server/content-types/index.mjs.map +1 -0
  277. package/dist/server/content-types/permission/index.js +44 -0
  278. package/dist/server/content-types/permission/index.js.map +1 -0
  279. package/dist/server/content-types/permission/index.mjs +42 -0
  280. package/dist/server/content-types/permission/index.mjs.map +1 -0
  281. package/dist/server/content-types/role/index.js +61 -0
  282. package/dist/server/content-types/role/index.js.map +1 -0
  283. package/dist/server/content-types/role/index.mjs +59 -0
  284. package/dist/server/content-types/role/index.mjs.map +1 -0
  285. package/dist/server/content-types/user/index.js +84 -0
  286. package/dist/server/content-types/user/index.js.map +1 -0
  287. package/dist/server/content-types/user/index.mjs +82 -0
  288. package/dist/server/content-types/user/index.mjs.map +1 -0
  289. package/dist/server/content-types/user/schema-config.js +25 -0
  290. package/dist/server/content-types/user/schema-config.js.map +1 -0
  291. package/dist/server/content-types/user/schema-config.mjs +23 -0
  292. package/dist/server/content-types/user/schema-config.mjs.map +1 -0
  293. package/dist/server/controllers/auth.js +429 -0
  294. package/dist/server/controllers/auth.js.map +1 -0
  295. package/dist/server/controllers/auth.mjs +427 -0
  296. package/dist/server/controllers/auth.mjs.map +1 -0
  297. package/dist/server/controllers/content-manager-user.js +168 -0
  298. package/dist/server/controllers/content-manager-user.js.map +1 -0
  299. package/dist/server/controllers/content-manager-user.mjs +166 -0
  300. package/dist/server/controllers/content-manager-user.mjs.map +1 -0
  301. package/dist/server/controllers/index.js +33 -0
  302. package/dist/server/controllers/index.js.map +1 -0
  303. package/dist/server/controllers/index.mjs +31 -0
  304. package/dist/server/controllers/index.mjs.map +1 -0
  305. package/dist/server/controllers/permissions.js +37 -0
  306. package/dist/server/controllers/permissions.js.map +1 -0
  307. package/dist/server/controllers/permissions.mjs +35 -0
  308. package/dist/server/controllers/permissions.mjs.map +1 -0
  309. package/dist/server/controllers/role.js +91 -0
  310. package/dist/server/controllers/role.js.map +1 -0
  311. package/dist/server/controllers/role.mjs +89 -0
  312. package/dist/server/controllers/role.mjs.map +1 -0
  313. package/dist/server/controllers/settings.js +107 -0
  314. package/dist/server/controllers/settings.js.map +1 -0
  315. package/dist/server/controllers/settings.mjs +105 -0
  316. package/dist/server/controllers/settings.mjs.map +1 -0
  317. package/dist/server/controllers/user.js +201 -0
  318. package/dist/server/controllers/user.js.map +1 -0
  319. package/dist/server/controllers/user.mjs +199 -0
  320. package/dist/server/controllers/user.mjs.map +1 -0
  321. package/dist/server/controllers/validation/auth.js +131 -0
  322. package/dist/server/controllers/validation/auth.js.map +1 -0
  323. package/dist/server/controllers/validation/auth.mjs +129 -0
  324. package/dist/server/controllers/validation/auth.mjs.map +1 -0
  325. package/dist/server/controllers/validation/email-template.js +72 -0
  326. package/dist/server/controllers/validation/email-template.js.map +1 -0
  327. package/dist/server/controllers/validation/email-template.mjs +70 -0
  328. package/dist/server/controllers/validation/email-template.mjs.map +1 -0
  329. package/dist/server/controllers/validation/user.js +49 -0
  330. package/dist/server/controllers/validation/user.js.map +1 -0
  331. package/dist/server/controllers/validation/user.mjs +47 -0
  332. package/dist/server/controllers/validation/user.mjs.map +1 -0
  333. package/dist/server/graphql/index.js +66 -0
  334. package/dist/server/graphql/index.js.map +1 -0
  335. package/dist/server/graphql/index.mjs +64 -0
  336. package/dist/server/graphql/index.mjs.map +1 -0
  337. package/dist/server/graphql/mutations/auth/change-password.js +40 -0
  338. package/dist/server/graphql/mutations/auth/change-password.js.map +1 -0
  339. package/dist/server/graphql/mutations/auth/change-password.mjs +38 -0
  340. package/dist/server/graphql/mutations/auth/change-password.mjs.map +1 -0
  341. package/dist/server/graphql/mutations/auth/email-confirmation.js +38 -0
  342. package/dist/server/graphql/mutations/auth/email-confirmation.js.map +1 -0
  343. package/dist/server/graphql/mutations/auth/email-confirmation.mjs +36 -0
  344. package/dist/server/graphql/mutations/auth/email-confirmation.mjs.map +1 -0
  345. package/dist/server/graphql/mutations/auth/forgot-password.js +37 -0
  346. package/dist/server/graphql/mutations/auth/forgot-password.js.map +1 -0
  347. package/dist/server/graphql/mutations/auth/forgot-password.mjs +35 -0
  348. package/dist/server/graphql/mutations/auth/forgot-password.mjs.map +1 -0
  349. package/dist/server/graphql/mutations/auth/login.js +40 -0
  350. package/dist/server/graphql/mutations/auth/login.js.map +1 -0
  351. package/dist/server/graphql/mutations/auth/login.mjs +38 -0
  352. package/dist/server/graphql/mutations/auth/login.mjs.map +1 -0
  353. package/dist/server/graphql/mutations/auth/register.js +38 -0
  354. package/dist/server/graphql/mutations/auth/register.js.map +1 -0
  355. package/dist/server/graphql/mutations/auth/register.mjs +36 -0
  356. package/dist/server/graphql/mutations/auth/register.mjs.map +1 -0
  357. package/dist/server/graphql/mutations/auth/reset-password.js +40 -0
  358. package/dist/server/graphql/mutations/auth/reset-password.js.map +1 -0
  359. package/dist/server/graphql/mutations/auth/reset-password.mjs +38 -0
  360. package/dist/server/graphql/mutations/auth/reset-password.mjs.map +1 -0
  361. package/dist/server/graphql/mutations/crud/role/create-role.js +37 -0
  362. package/dist/server/graphql/mutations/crud/role/create-role.js.map +1 -0
  363. package/dist/server/graphql/mutations/crud/role/create-role.mjs +35 -0
  364. package/dist/server/graphql/mutations/crud/role/create-role.mjs.map +1 -0
  365. package/dist/server/graphql/mutations/crud/role/delete-role.js +32 -0
  366. package/dist/server/graphql/mutations/crud/role/delete-role.js.map +1 -0
  367. package/dist/server/graphql/mutations/crud/role/delete-role.mjs +30 -0
  368. package/dist/server/graphql/mutations/crud/role/delete-role.mjs.map +1 -0
  369. package/dist/server/graphql/mutations/crud/role/update-role.js +39 -0
  370. package/dist/server/graphql/mutations/crud/role/update-role.js.map +1 -0
  371. package/dist/server/graphql/mutations/crud/role/update-role.mjs +37 -0
  372. package/dist/server/graphql/mutations/crud/role/update-role.mjs.map +1 -0
  373. package/dist/server/graphql/mutations/crud/user/create-user.js +46 -0
  374. package/dist/server/graphql/mutations/crud/user/create-user.js.map +1 -0
  375. package/dist/server/graphql/mutations/crud/user/create-user.mjs +44 -0
  376. package/dist/server/graphql/mutations/crud/user/create-user.mjs.map +1 -0
  377. package/dist/server/graphql/mutations/crud/user/delete-user.js +44 -0
  378. package/dist/server/graphql/mutations/crud/user/delete-user.js.map +1 -0
  379. package/dist/server/graphql/mutations/crud/user/delete-user.mjs +42 -0
  380. package/dist/server/graphql/mutations/crud/user/delete-user.mjs.map +1 -0
  381. package/dist/server/graphql/mutations/crud/user/update-user.js +49 -0
  382. package/dist/server/graphql/mutations/crud/user/update-user.js.map +1 -0
  383. package/dist/server/graphql/mutations/crud/user/update-user.mjs +47 -0
  384. package/dist/server/graphql/mutations/crud/user/update-user.mjs.map +1 -0
  385. package/dist/server/graphql/mutations/index.js +58 -0
  386. package/dist/server/graphql/mutations/index.js.map +1 -0
  387. package/dist/server/graphql/mutations/index.mjs +56 -0
  388. package/dist/server/graphql/mutations/index.mjs.map +1 -0
  389. package/dist/server/graphql/queries/index.js +25 -0
  390. package/dist/server/graphql/queries/index.js.map +1 -0
  391. package/dist/server/graphql/queries/index.mjs +23 -0
  392. package/dist/server/graphql/queries/index.mjs.map +1 -0
  393. package/dist/server/graphql/queries/me.js +23 -0
  394. package/dist/server/graphql/queries/me.js.map +1 -0
  395. package/dist/server/graphql/queries/me.mjs +21 -0
  396. package/dist/server/graphql/queries/me.mjs.map +1 -0
  397. package/dist/server/graphql/resolvers-configs.js +93 -0
  398. package/dist/server/graphql/resolvers-configs.js.map +1 -0
  399. package/dist/server/graphql/resolvers-configs.mjs +91 -0
  400. package/dist/server/graphql/resolvers-configs.mjs.map +1 -0
  401. package/dist/server/graphql/types/create-role-payload.js +20 -0
  402. package/dist/server/graphql/types/create-role-payload.js.map +1 -0
  403. package/dist/server/graphql/types/create-role-payload.mjs +18 -0
  404. package/dist/server/graphql/types/create-role-payload.mjs.map +1 -0
  405. package/dist/server/graphql/types/delete-role-payload.js +20 -0
  406. package/dist/server/graphql/types/delete-role-payload.js.map +1 -0
  407. package/dist/server/graphql/types/delete-role-payload.mjs +18 -0
  408. package/dist/server/graphql/types/delete-role-payload.mjs.map +1 -0
  409. package/dist/server/graphql/types/index.js +41 -0
  410. package/dist/server/graphql/types/index.js.map +1 -0
  411. package/dist/server/graphql/types/index.mjs +39 -0
  412. package/dist/server/graphql/types/index.mjs.map +1 -0
  413. package/dist/server/graphql/types/login-input.js +24 -0
  414. package/dist/server/graphql/types/login-input.js.map +1 -0
  415. package/dist/server/graphql/types/login-input.mjs +22 -0
  416. package/dist/server/graphql/types/login-input.mjs.map +1 -0
  417. package/dist/server/graphql/types/login-payload.js +23 -0
  418. package/dist/server/graphql/types/login-payload.js.map +1 -0
  419. package/dist/server/graphql/types/login-payload.mjs +21 -0
  420. package/dist/server/graphql/types/login-payload.mjs.map +1 -0
  421. package/dist/server/graphql/types/me-role.js +23 -0
  422. package/dist/server/graphql/types/me-role.js.map +1 -0
  423. package/dist/server/graphql/types/me-role.mjs +21 -0
  424. package/dist/server/graphql/types/me-role.mjs.map +1 -0
  425. package/dist/server/graphql/types/me.js +28 -0
  426. package/dist/server/graphql/types/me.js.map +1 -0
  427. package/dist/server/graphql/types/me.mjs +26 -0
  428. package/dist/server/graphql/types/me.mjs.map +1 -0
  429. package/dist/server/graphql/types/password-payload.js +20 -0
  430. package/dist/server/graphql/types/password-payload.js.map +1 -0
  431. package/dist/server/graphql/types/password-payload.mjs +18 -0
  432. package/dist/server/graphql/types/password-payload.mjs.map +1 -0
  433. package/dist/server/graphql/types/register-input.js +22 -0
  434. package/dist/server/graphql/types/register-input.js.map +1 -0
  435. package/dist/server/graphql/types/register-input.mjs +20 -0
  436. package/dist/server/graphql/types/register-input.mjs.map +1 -0
  437. package/dist/server/graphql/types/update-role-payload.js +20 -0
  438. package/dist/server/graphql/types/update-role-payload.js.map +1 -0
  439. package/dist/server/graphql/types/update-role-payload.mjs +18 -0
  440. package/dist/server/graphql/types/update-role-payload.mjs.map +1 -0
  441. package/dist/server/graphql/types/user-input.js +26 -0
  442. package/dist/server/graphql/types/user-input.js.map +1 -0
  443. package/dist/server/graphql/types/user-input.mjs +24 -0
  444. package/dist/server/graphql/types/user-input.mjs.map +1 -0
  445. package/dist/server/graphql/utils.js +32 -0
  446. package/dist/server/graphql/utils.js.map +1 -0
  447. package/dist/server/graphql/utils.mjs +30 -0
  448. package/dist/server/graphql/utils.mjs.map +1 -0
  449. package/dist/server/index.js +4 -4760
  450. package/dist/server/index.js.map +1 -1
  451. package/dist/server/index.mjs +2 -4758
  452. package/dist/server/index.mjs.map +1 -1
  453. package/dist/server/index2.js +39 -0
  454. package/dist/server/index2.js.map +1 -0
  455. package/dist/server/index2.mjs +37 -0
  456. package/dist/server/index2.mjs.map +1 -0
  457. package/dist/server/middlewares/index.js +18 -0
  458. package/dist/server/middlewares/index.js.map +1 -0
  459. package/dist/server/middlewares/index.mjs +16 -0
  460. package/dist/server/middlewares/index.mjs.map +1 -0
  461. package/dist/server/middlewares/rateLimit.js +51 -0
  462. package/dist/server/middlewares/rateLimit.js.map +1 -0
  463. package/dist/server/middlewares/rateLimit.mjs +49 -0
  464. package/dist/server/middlewares/rateLimit.mjs.map +1 -0
  465. package/dist/server/register.js +41 -0
  466. package/dist/server/register.js.map +1 -0
  467. package/dist/server/register.mjs +39 -0
  468. package/dist/server/register.mjs.map +1 -0
  469. package/dist/server/routes/admin/index.js +27 -0
  470. package/dist/server/routes/admin/index.js.map +1 -0
  471. package/dist/server/routes/admin/index.mjs +25 -0
  472. package/dist/server/routes/admin/index.mjs.map +1 -0
  473. package/dist/server/routes/admin/permissions.js +29 -0
  474. package/dist/server/routes/admin/permissions.js.map +1 -0
  475. package/dist/server/routes/admin/permissions.mjs +27 -0
  476. package/dist/server/routes/admin/permissions.mjs.map +1 -0
  477. package/dist/server/routes/admin/role.js +99 -0
  478. package/dist/server/routes/admin/role.js.map +1 -0
  479. package/dist/server/routes/admin/role.mjs +97 -0
  480. package/dist/server/routes/admin/role.mjs.map +1 -0
  481. package/dist/server/routes/admin/settings.js +116 -0
  482. package/dist/server/routes/admin/settings.js.map +1 -0
  483. package/dist/server/routes/admin/settings.mjs +114 -0
  484. package/dist/server/routes/admin/settings.mjs.map +1 -0
  485. package/dist/server/routes/content-api/auth.js +104 -0
  486. package/dist/server/routes/content-api/auth.js.map +1 -0
  487. package/dist/server/routes/content-api/auth.mjs +102 -0
  488. package/dist/server/routes/content-api/auth.mjs.map +1 -0
  489. package/dist/server/routes/content-api/index.js +30 -0
  490. package/dist/server/routes/content-api/index.js.map +1 -0
  491. package/dist/server/routes/content-api/index.mjs +28 -0
  492. package/dist/server/routes/content-api/index.mjs.map +1 -0
  493. package/dist/server/routes/content-api/permissions.js +19 -0
  494. package/dist/server/routes/content-api/permissions.js.map +1 -0
  495. package/dist/server/routes/content-api/permissions.mjs +17 -0
  496. package/dist/server/routes/content-api/permissions.mjs.map +1 -0
  497. package/dist/server/routes/content-api/role.js +39 -0
  498. package/dist/server/routes/content-api/role.js.map +1 -0
  499. package/dist/server/routes/content-api/role.mjs +37 -0
  500. package/dist/server/routes/content-api/role.mjs.map +1 -0
  501. package/dist/server/routes/content-api/user.js +70 -0
  502. package/dist/server/routes/content-api/user.js.map +1 -0
  503. package/dist/server/routes/content-api/user.mjs +68 -0
  504. package/dist/server/routes/content-api/user.mjs.map +1 -0
  505. package/dist/server/routes/index.js +19 -0
  506. package/dist/server/routes/index.js.map +1 -0
  507. package/dist/server/routes/index.mjs +17 -0
  508. package/dist/server/routes/index.mjs.map +1 -0
  509. package/dist/server/services/index.js +36 -0
  510. package/dist/server/services/index.js.map +1 -0
  511. package/dist/server/services/index.mjs +34 -0
  512. package/dist/server/services/index.mjs.map +1 -0
  513. package/dist/server/services/jwt.js +50 -0
  514. package/dist/server/services/jwt.js.map +1 -0
  515. package/dist/server/services/jwt.mjs +48 -0
  516. package/dist/server/services/jwt.mjs.map +1 -0
  517. package/dist/server/services/permission.js +52 -0
  518. package/dist/server/services/permission.js.map +1 -0
  519. package/dist/server/services/permission.mjs +50 -0
  520. package/dist/server/services/permission.mjs.map +1 -0
  521. package/dist/server/services/providers-registry.js +555 -0
  522. package/dist/server/services/providers-registry.js.map +1 -0
  523. package/dist/server/services/providers-registry.mjs +553 -0
  524. package/dist/server/services/providers-registry.mjs.map +1 -0
  525. package/dist/server/services/providers.js +111 -0
  526. package/dist/server/services/providers.js.map +1 -0
  527. package/dist/server/services/providers.mjs +109 -0
  528. package/dist/server/services/providers.mjs.map +1 -0
  529. package/dist/server/services/role.js +186 -0
  530. package/dist/server/services/role.js.map +1 -0
  531. package/dist/server/services/role.mjs +184 -0
  532. package/dist/server/services/role.mjs.map +1 -0
  533. package/dist/server/services/user.js +179 -0
  534. package/dist/server/services/user.js.map +1 -0
  535. package/dist/server/services/user.mjs +177 -0
  536. package/dist/server/services/user.mjs.map +1 -0
  537. package/dist/server/services/users-permissions.js +247 -0
  538. package/dist/server/services/users-permissions.js.map +1 -0
  539. package/dist/server/services/users-permissions.mjs +245 -0
  540. package/dist/server/services/users-permissions.mjs.map +1 -0
  541. package/dist/server/strategies/users-permissions.js +114 -0
  542. package/dist/server/strategies/users-permissions.js.map +1 -0
  543. package/dist/server/strategies/users-permissions.mjs +112 -0
  544. package/dist/server/strategies/users-permissions.mjs.map +1 -0
  545. package/dist/server/utils/index.js +22 -0
  546. package/dist/server/utils/index.js.map +1 -0
  547. package/dist/server/utils/index.mjs +20 -0
  548. package/dist/server/utils/index.mjs.map +1 -0
  549. package/dist/server/utils/sanitize/index.js +21 -0
  550. package/dist/server/utils/sanitize/index.js.map +1 -0
  551. package/dist/server/utils/sanitize/index.mjs +19 -0
  552. package/dist/server/utils/sanitize/index.mjs.map +1 -0
  553. package/dist/server/utils/sanitize/sanitizers.js +32 -0
  554. package/dist/server/utils/sanitize/sanitizers.js.map +1 -0
  555. package/dist/server/utils/sanitize/sanitizers.mjs +30 -0
  556. package/dist/server/utils/sanitize/sanitizers.mjs.map +1 -0
  557. package/dist/server/utils/sanitize/visitors/index.js +17 -0
  558. package/dist/server/utils/sanitize/visitors/index.js.map +1 -0
  559. package/dist/server/utils/sanitize/visitors/index.mjs +15 -0
  560. package/dist/server/utils/sanitize/visitors/index.mjs.map +1 -0
  561. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +17 -0
  562. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js.map +1 -0
  563. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.mjs +15 -0
  564. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.mjs.map +1 -0
  565. package/package.json +3 -3
  566. package/rollup.config.mjs +15 -48
  567. package/dist/admin/chunks/ar-BJwjobLp.js.map +0 -1
  568. package/dist/admin/chunks/ar-G6bUGuUb.mjs.map +0 -1
  569. package/dist/admin/chunks/cs-Bu59JqhG.mjs.map +0 -1
  570. package/dist/admin/chunks/cs-uS_SIEo8.js.map +0 -1
  571. package/dist/admin/chunks/de-7MVMrqqI.js.map +0 -1
  572. package/dist/admin/chunks/de-B81A69_5.mjs.map +0 -1
  573. package/dist/admin/chunks/dk-BaelzvBE.mjs.map +0 -1
  574. package/dist/admin/chunks/dk-DwCLGmy9.js.map +0 -1
  575. package/dist/admin/chunks/en-BhgCBe7M.mjs.map +0 -1
  576. package/dist/admin/chunks/en-DwQjkHi_.js.map +0 -1
  577. package/dist/admin/chunks/es-B0wXmvRj.mjs.map +0 -1
  578. package/dist/admin/chunks/es-BOJOedG5.js.map +0 -1
  579. package/dist/admin/chunks/fr-BDNWCNs0.js.map +0 -1
  580. package/dist/admin/chunks/fr-CGYvGUXg.mjs.map +0 -1
  581. package/dist/admin/chunks/id-CNzbwFjA.mjs.map +0 -1
  582. package/dist/admin/chunks/id-UqUPykHZ.js.map +0 -1
  583. package/dist/admin/chunks/index--_o6btSC.js +0 -471
  584. package/dist/admin/chunks/index--_o6btSC.js.map +0 -1
  585. package/dist/admin/chunks/index-BBjNJt_G.mjs +0 -448
  586. package/dist/admin/chunks/index-BBjNJt_G.mjs.map +0 -1
  587. package/dist/admin/chunks/index-BgAfLcWs.mjs +0 -1516
  588. package/dist/admin/chunks/index-BgAfLcWs.mjs.map +0 -1
  589. package/dist/admin/chunks/index-CHTUC0LM.mjs +0 -718
  590. package/dist/admin/chunks/index-CHTUC0LM.mjs.map +0 -1
  591. package/dist/admin/chunks/index-CY5JZ38k.mjs +0 -213
  592. package/dist/admin/chunks/index-CY5JZ38k.mjs.map +0 -1
  593. package/dist/admin/chunks/index-Cu1VuLS3.js +0 -741
  594. package/dist/admin/chunks/index-Cu1VuLS3.js.map +0 -1
  595. package/dist/admin/chunks/index-Cy-tPfRk.mjs.map +0 -1
  596. package/dist/admin/chunks/index-DD-Z6c1S.js +0 -217
  597. package/dist/admin/chunks/index-DD-Z6c1S.js.map +0 -1
  598. package/dist/admin/chunks/index-DFnYIqrB.js.map +0 -1
  599. package/dist/admin/chunks/index-DvubCYNe.js +0 -1537
  600. package/dist/admin/chunks/index-DvubCYNe.js.map +0 -1
  601. package/dist/admin/chunks/it-B2H2foTf.mjs.map +0 -1
  602. package/dist/admin/chunks/it-D5VuyoLU.js.map +0 -1
  603. package/dist/admin/chunks/ja-C0z9d7L9.mjs.map +0 -1
  604. package/dist/admin/chunks/ja-MpqVsCgs.js.map +0 -1
  605. package/dist/admin/chunks/ko-Bm-grPSc.js.map +0 -1
  606. package/dist/admin/chunks/ko-CzUgzpeS.mjs.map +0 -1
  607. package/dist/admin/chunks/ms-CCacxjim.mjs.map +0 -1
  608. package/dist/admin/chunks/ms-D7eyBD5H.js.map +0 -1
  609. package/dist/admin/chunks/nl-BIOwAQtI.js.map +0 -1
  610. package/dist/admin/chunks/nl-DDC3nZW-.mjs.map +0 -1
  611. package/dist/admin/chunks/pl-D5BeNrg_.js.map +0 -1
  612. package/dist/admin/chunks/pl-XkS463rN.mjs.map +0 -1
  613. package/dist/admin/chunks/pt-BR-8cC7z8Km.mjs.map +0 -1
  614. package/dist/admin/chunks/pt-BR-DxPBzQGx.js.map +0 -1
  615. package/dist/admin/chunks/pt-DQpEvio8.mjs.map +0 -1
  616. package/dist/admin/chunks/pt-kkCwzNvH.js.map +0 -1
  617. package/dist/admin/chunks/ru-BQ0gHmp3.js.map +0 -1
  618. package/dist/admin/chunks/ru-nzL_7Mhg.mjs.map +0 -1
  619. package/dist/admin/chunks/sk-Ddxc_tZA.mjs.map +0 -1
  620. package/dist/admin/chunks/sk-nVwAPdYC.js.map +0 -1
  621. package/dist/admin/chunks/sv-BDfk2A-F.js.map +0 -1
  622. package/dist/admin/chunks/sv-By3RYpMG.mjs.map +0 -1
  623. package/dist/admin/chunks/th-BtTtpHe2.js.map +0 -1
  624. package/dist/admin/chunks/th-COl50vqb.mjs.map +0 -1
  625. package/dist/admin/chunks/tr-80SJU6jg.mjs.map +0 -1
  626. package/dist/admin/chunks/tr-Di-Nf7cT.js.map +0 -1
  627. package/dist/admin/chunks/uk-DnrIlPwG.mjs.map +0 -1
  628. package/dist/admin/chunks/uk-r5zXTAS7.js.map +0 -1
  629. package/dist/admin/chunks/vi-69AF03Iv.mjs.map +0 -1
  630. package/dist/admin/chunks/vi-D9cCsHsU.js.map +0 -1
  631. package/dist/admin/chunks/zh-BzSkqxo-.mjs.map +0 -1
  632. package/dist/admin/chunks/zh-BzWgJEzz.js.map +0 -1
  633. package/dist/admin/chunks/zh-Hans-CKqQbpsM.js.map +0 -1
  634. package/dist/admin/chunks/zh-Hans-DmDcSsp7.mjs.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"role.mjs","sources":["../../../server/services/role.js"],"sourcesContent":["'use strict';\n\nconst _ = require('lodash');\nconst { NotFoundError } = require('@strapi/utils').errors;\nconst { getService } = require('../utils');\n\nmodule.exports = ({ strapi }) => ({\n async createRole(params) {\n if (!params.type) {\n params.type = _.snakeCase(_.deburr(_.toLower(params.name)));\n }\n\n const role = await strapi.db\n .query('plugin::users-permissions.role')\n .create({ data: _.omit(params, ['users', 'permissions']) });\n\n const createPromises = _.flatMap(params.permissions, (type, typeName) => {\n return _.flatMap(type.controllers, (controller, controllerName) => {\n return _.reduce(\n controller,\n (acc, action, actionName) => {\n const { enabled /* policy */ } = action;\n\n if (enabled) {\n const actionID = `${typeName}.${controllerName}.${actionName}`;\n\n acc.push(\n strapi.db\n .query('plugin::users-permissions.permission')\n .create({ data: { action: actionID, role: role.id } })\n );\n }\n\n return acc;\n },\n []\n );\n });\n });\n\n await Promise.all(createPromises);\n },\n\n async findOne(roleID) {\n const role = await strapi.db\n .query('plugin::users-permissions.role')\n .findOne({ where: { id: roleID }, populate: ['permissions'] });\n\n if (!role) {\n throw new NotFoundError('Role not found');\n }\n\n const allActions = getService('users-permissions').getActions();\n\n // Group by `type`.\n role.permissions.forEach((permission) => {\n const [type, controller, action] = permission.action.split('.');\n\n _.set(allActions, `${type}.controllers.${controller}.${action}`, {\n enabled: true,\n policy: '',\n });\n });\n\n return {\n ...role,\n permissions: allActions,\n };\n },\n\n async find() {\n const roles = await strapi.db\n .query('plugin::users-permissions.role')\n .findMany({ sort: ['name'] });\n\n for (const role of roles) {\n role.nb_users = await strapi.db\n .query('plugin::users-permissions.user')\n .count({ where: { role: { id: role.id } } });\n }\n\n return roles;\n },\n\n async updateRole(roleID, data) {\n const role = await strapi.db\n .query('plugin::users-permissions.role')\n .findOne({ where: { id: roleID }, populate: ['permissions'] });\n\n if (!role) {\n throw new NotFoundError('Role not found');\n }\n\n await strapi.db.query('plugin::users-permissions.role').update({\n where: { id: roleID },\n data: _.pick(data, ['name', 'description']),\n });\n\n const { permissions } = data;\n\n const newActions = _.flatMap(permissions, (type, typeName) => {\n return _.flatMap(type.controllers, (controller, controllerName) => {\n return _.reduce(\n controller,\n (acc, action, actionName) => {\n const { enabled /* policy */ } = action;\n\n if (enabled) {\n acc.push(`${typeName}.${controllerName}.${actionName}`);\n }\n\n return acc;\n },\n []\n );\n });\n });\n\n const oldActions = role.permissions.map(({ action }) => action);\n\n const toDelete = role.permissions.reduce((acc, permission) => {\n if (!newActions.includes(permission.action)) {\n acc.push(permission);\n }\n return acc;\n }, []);\n\n const toCreate = newActions\n .filter((action) => !oldActions.includes(action))\n .map((action) => ({ action, role: role.id }));\n\n await Promise.all(\n toDelete.map((permission) =>\n strapi.db\n .query('plugin::users-permissions.permission')\n .delete({ where: { id: permission.id } })\n )\n );\n\n await Promise.all(\n toCreate.map((permissionInfo) =>\n strapi.db.query('plugin::users-permissions.permission').create({ data: permissionInfo })\n )\n );\n },\n\n async deleteRole(roleID, publicRoleID) {\n const role = await strapi.db\n .query('plugin::users-permissions.role')\n .findOne({ where: { id: roleID }, populate: ['users', 'permissions'] });\n\n if (!role) {\n throw new NotFoundError('Role not found');\n }\n\n // Move users to guest role.\n await Promise.all(\n role.users.map((user) => {\n return strapi.db.query('plugin::users-permissions.user').update({\n where: { id: user.id },\n data: { role: publicRoleID },\n });\n })\n );\n\n // Remove permissions related to this role.\n // TODO: use delete many\n await Promise.all(\n role.permissions.map((permission) => {\n return strapi.db.query('plugin::users-permissions.permission').delete({\n where: { id: permission.id },\n });\n })\n );\n\n // Delete the role.\n await strapi.db.query('plugin::users-permissions.role').delete({ where: { id: roleID } });\n },\n});\n"],"names":["_","require$$0","NotFoundError","require$$1","errors","getService","require$$2","role","strapi","createRole","params","type","snakeCase","deburr","toLower","name","db","query","create","data","omit","createPromises","flatMap","permissions","typeName","controllers","controller","controllerName","reduce","acc","action","actionName","enabled","actionID","push","id","Promise","all","findOne","roleID","where","populate","allActions","getActions","forEach","permission","split","set","policy","find","roles","findMany","sort","nb_users","count","updateRole","update","pick","newActions","oldActions","map","toDelete","includes","toCreate","filter","delete","permissionInfo","deleteRole","publicRoleID","users","user"],"mappings":"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"}
@@ -0,0 +1,179 @@
1
+ 'use strict';
2
+
3
+ var require$$0 = require('crypto');
4
+ var require$$1 = require('bcryptjs');
5
+ var require$$2 = require('url-join');
6
+ var require$$1$1 = require('@strapi/utils');
7
+ var require$$0$1 = require('lodash/fp');
8
+ var index = require('../utils/index.js');
9
+
10
+ var user;
11
+ var hasRequiredUser;
12
+ function requireUser() {
13
+ if (hasRequiredUser) return user;
14
+ hasRequiredUser = 1;
15
+ /**
16
+ * User.js service
17
+ *
18
+ * @description: A set of functions similar to controller's actions to avoid code duplication.
19
+ */ const crypto = require$$0;
20
+ const bcrypt = require$$1;
21
+ const urlJoin = require$$2;
22
+ const { sanitize } = require$$1$1;
23
+ const { toNumber, getOr } = require$$0$1;
24
+ const { getService } = index.__require();
25
+ const USER_MODEL_UID = 'plugin::users-permissions.user';
26
+ user = ({ strapi })=>({
27
+ /**
28
+ * Promise to count users
29
+ *
30
+ * @return {Promise}
31
+ */ count (params) {
32
+ return strapi.db.query(USER_MODEL_UID).count({
33
+ where: params
34
+ });
35
+ },
36
+ /**
37
+ * Hashes password fields in the provided values object if they are present.
38
+ * It checks each key in the values object against the model's attributes and
39
+ * hashes it if the attribute type is 'password',
40
+ *
41
+ * @param {object} values - The object containing the fields to be hashed.
42
+ * @return {object} The values object with hashed password fields if they were present.
43
+ */ async ensureHashedPasswords (values) {
44
+ const attributes = strapi.getModel(USER_MODEL_UID).attributes;
45
+ for(const key in values){
46
+ if (attributes[key] && attributes[key].type === 'password') {
47
+ // Check if a custom encryption.rounds has been set on the password attribute
48
+ const rounds = toNumber(getOr(10, 'encryption.rounds', attributes[key]));
49
+ values[key] = await bcrypt.hash(values[key], rounds);
50
+ }
51
+ }
52
+ return values;
53
+ },
54
+ /**
55
+ * Promise to add a/an user.
56
+ * @return {Promise}
57
+ */ async add (values) {
58
+ return strapi.db.query(USER_MODEL_UID).create({
59
+ data: await this.ensureHashedPasswords(values),
60
+ populate: [
61
+ 'role'
62
+ ]
63
+ });
64
+ },
65
+ /**
66
+ * Promise to edit a/an user.
67
+ * @param {string} userId
68
+ * @param {object} params
69
+ * @return {Promise}
70
+ */ async edit (userId, params = {}) {
71
+ return strapi.db.query(USER_MODEL_UID).update({
72
+ where: {
73
+ id: userId
74
+ },
75
+ data: await this.ensureHashedPasswords(params),
76
+ populate: [
77
+ 'role'
78
+ ]
79
+ });
80
+ },
81
+ /**
82
+ * Promise to fetch a/an user.
83
+ * @return {Promise}
84
+ */ fetch (id, params) {
85
+ const query = strapi.get('query-params').transform(USER_MODEL_UID, params ?? {});
86
+ return strapi.db.query(USER_MODEL_UID).findOne({
87
+ ...query,
88
+ where: {
89
+ $and: [
90
+ {
91
+ id
92
+ },
93
+ query.where || {}
94
+ ]
95
+ }
96
+ });
97
+ },
98
+ /**
99
+ * Promise to fetch authenticated user.
100
+ * @return {Promise}
101
+ */ fetchAuthenticatedUser (id) {
102
+ return strapi.db.query(USER_MODEL_UID).findOne({
103
+ where: {
104
+ id
105
+ },
106
+ populate: [
107
+ 'role'
108
+ ]
109
+ });
110
+ },
111
+ /**
112
+ * Promise to fetch all users.
113
+ * @return {Promise}
114
+ */ fetchAll (params) {
115
+ const query = strapi.get('query-params').transform(USER_MODEL_UID, params ?? {});
116
+ return strapi.db.query(USER_MODEL_UID).findMany(query);
117
+ },
118
+ /**
119
+ * Promise to remove a/an user.
120
+ * @return {Promise}
121
+ */ async remove (params) {
122
+ return strapi.db.query(USER_MODEL_UID).delete({
123
+ where: params
124
+ });
125
+ },
126
+ validatePassword (password, hash) {
127
+ return bcrypt.compare(password, hash);
128
+ },
129
+ async sendConfirmationEmail (user) {
130
+ const userPermissionService = getService('users-permissions');
131
+ const pluginStore = await strapi.store({
132
+ type: 'plugin',
133
+ name: 'users-permissions'
134
+ });
135
+ const userSchema = strapi.getModel(USER_MODEL_UID);
136
+ const settings = await pluginStore.get({
137
+ key: 'email'
138
+ }).then((storeEmail)=>storeEmail.email_confirmation.options);
139
+ // Sanitize the template's user information
140
+ const sanitizedUserInfo = await sanitize.sanitizers.defaultSanitizeOutput({
141
+ schema: userSchema,
142
+ getModel: strapi.getModel.bind(strapi)
143
+ }, user);
144
+ const confirmationToken = crypto.randomBytes(20).toString('hex');
145
+ await this.edit(user.id, {
146
+ confirmationToken
147
+ });
148
+ const apiPrefix = strapi.config.get('api.rest.prefix');
149
+ try {
150
+ settings.message = await userPermissionService.template(settings.message, {
151
+ URL: urlJoin(strapi.config.get('server.absoluteUrl'), apiPrefix, '/auth/email-confirmation'),
152
+ SERVER_URL: strapi.config.get('server.absoluteUrl'),
153
+ ADMIN_URL: strapi.config.get('admin.absoluteUrl'),
154
+ USER: sanitizedUserInfo,
155
+ CODE: confirmationToken
156
+ });
157
+ settings.object = await userPermissionService.template(settings.object, {
158
+ USER: sanitizedUserInfo
159
+ });
160
+ } catch {
161
+ strapi.log.error('[plugin::users-permissions.sendConfirmationEmail]: Failed to generate a template for "user confirmation email". Please make sure your email template is valid and does not contain invalid characters or patterns');
162
+ return;
163
+ }
164
+ // Send an email to the user.
165
+ await strapi.plugin('email').service('email').send({
166
+ to: user.email,
167
+ from: settings.from.email && settings.from.name ? `${settings.from.name} <${settings.from.email}>` : undefined,
168
+ replyTo: settings.response_email,
169
+ subject: settings.object,
170
+ text: settings.message,
171
+ html: settings.message
172
+ });
173
+ }
174
+ });
175
+ return user;
176
+ }
177
+
178
+ exports.__require = requireUser;
179
+ //# sourceMappingURL=user.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.js","sources":["../../../server/services/user.js"],"sourcesContent":["'use strict';\n\n/**\n * User.js service\n *\n * @description: A set of functions similar to controller's actions to avoid code duplication.\n */\n\nconst crypto = require('crypto');\nconst bcrypt = require('bcryptjs');\nconst urlJoin = require('url-join');\n\nconst { sanitize } = require('@strapi/utils');\nconst { toNumber, getOr } = require('lodash/fp');\nconst { getService } = require('../utils');\n\nconst USER_MODEL_UID = 'plugin::users-permissions.user';\n\nmodule.exports = ({ strapi }) => ({\n /**\n * Promise to count users\n *\n * @return {Promise}\n */\n\n count(params) {\n return strapi.db.query(USER_MODEL_UID).count({ where: params });\n },\n\n /**\n * Hashes password fields in the provided values object if they are present.\n * It checks each key in the values object against the model's attributes and\n * hashes it if the attribute type is 'password',\n *\n * @param {object} values - The object containing the fields to be hashed.\n * @return {object} The values object with hashed password fields if they were present.\n */\n async ensureHashedPasswords(values) {\n const attributes = strapi.getModel(USER_MODEL_UID).attributes;\n\n for (const key in values) {\n if (attributes[key] && attributes[key].type === 'password') {\n // Check if a custom encryption.rounds has been set on the password attribute\n const rounds = toNumber(getOr(10, 'encryption.rounds', attributes[key]));\n values[key] = await bcrypt.hash(values[key], rounds);\n }\n }\n\n return values;\n },\n\n /**\n * Promise to add a/an user.\n * @return {Promise}\n */\n async add(values) {\n return strapi.db.query(USER_MODEL_UID).create({\n data: await this.ensureHashedPasswords(values),\n populate: ['role'],\n });\n },\n\n /**\n * Promise to edit a/an user.\n * @param {string} userId\n * @param {object} params\n * @return {Promise}\n */\n async edit(userId, params = {}) {\n return strapi.db.query(USER_MODEL_UID).update({\n where: { id: userId },\n data: await this.ensureHashedPasswords(params),\n populate: ['role'],\n });\n },\n\n /**\n * Promise to fetch a/an user.\n * @return {Promise}\n */\n fetch(id, params) {\n const query = strapi.get('query-params').transform(USER_MODEL_UID, params ?? {});\n\n return strapi.db.query(USER_MODEL_UID).findOne({\n ...query,\n where: {\n $and: [{ id }, query.where || {}],\n },\n });\n },\n\n /**\n * Promise to fetch authenticated user.\n * @return {Promise}\n */\n fetchAuthenticatedUser(id) {\n return strapi.db.query(USER_MODEL_UID).findOne({ where: { id }, populate: ['role'] });\n },\n\n /**\n * Promise to fetch all users.\n * @return {Promise}\n */\n fetchAll(params) {\n const query = strapi.get('query-params').transform(USER_MODEL_UID, params ?? {});\n\n return strapi.db.query(USER_MODEL_UID).findMany(query);\n },\n\n /**\n * Promise to remove a/an user.\n * @return {Promise}\n */\n async remove(params) {\n return strapi.db.query(USER_MODEL_UID).delete({ where: params });\n },\n\n validatePassword(password, hash) {\n return bcrypt.compare(password, hash);\n },\n\n async sendConfirmationEmail(user) {\n const userPermissionService = getService('users-permissions');\n const pluginStore = await strapi.store({ type: 'plugin', name: 'users-permissions' });\n const userSchema = strapi.getModel(USER_MODEL_UID);\n\n const settings = await pluginStore\n .get({ key: 'email' })\n .then((storeEmail) => storeEmail.email_confirmation.options);\n\n // Sanitize the template's user information\n const sanitizedUserInfo = await sanitize.sanitizers.defaultSanitizeOutput(\n {\n schema: userSchema,\n getModel: strapi.getModel.bind(strapi),\n },\n user\n );\n\n const confirmationToken = crypto.randomBytes(20).toString('hex');\n\n await this.edit(user.id, { confirmationToken });\n\n const apiPrefix = strapi.config.get('api.rest.prefix');\n\n try {\n settings.message = await userPermissionService.template(settings.message, {\n URL: urlJoin(\n strapi.config.get('server.absoluteUrl'),\n apiPrefix,\n '/auth/email-confirmation'\n ),\n SERVER_URL: strapi.config.get('server.absoluteUrl'),\n ADMIN_URL: strapi.config.get('admin.absoluteUrl'),\n USER: sanitizedUserInfo,\n CODE: confirmationToken,\n });\n\n settings.object = await userPermissionService.template(settings.object, {\n USER: sanitizedUserInfo,\n });\n } catch {\n strapi.log.error(\n '[plugin::users-permissions.sendConfirmationEmail]: Failed to generate a template for \"user confirmation email\". Please make sure your email template is valid and does not contain invalid characters or patterns'\n );\n return;\n }\n\n // Send an email to the user.\n await strapi\n .plugin('email')\n .service('email')\n .send({\n to: user.email,\n from:\n settings.from.email && settings.from.name\n ? `${settings.from.name} <${settings.from.email}>`\n : undefined,\n replyTo: settings.response_email,\n subject: settings.object,\n text: settings.message,\n html: settings.message,\n });\n },\n});\n"],"names":["crypto","require$$0","bcrypt","require$$1","urlJoin","require$$2","sanitize","require$$3","toNumber","getOr","require$$4","getService","require$$5","USER_MODEL_UID","user","strapi","count","params","db","query","where","ensureHashedPasswords","values","attributes","getModel","key","type","rounds","hash","add","create","data","populate","edit","userId","update","id","fetch","get","transform","findOne","$and","fetchAuthenticatedUser","fetchAll","findMany","remove","delete","validatePassword","password","compare","sendConfirmationEmail","userPermissionService","pluginStore","store","name","userSchema","settings","then","storeEmail","email_confirmation","options","sanitizedUserInfo","sanitizers","defaultSanitizeOutput","schema","bind","confirmationToken","randomBytes","toString","apiPrefix","config","message","template","URL","SERVER_URL","ADMIN_URL","USER","CODE","object","log","error","plugin","service","send","to","email","from","undefined","replyTo","response_email","subject","text","html"],"mappings":"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"}
@@ -0,0 +1,177 @@
1
+ import require$$0 from 'crypto';
2
+ import require$$1 from 'bcryptjs';
3
+ import require$$2 from 'url-join';
4
+ import require$$1$1 from '@strapi/utils';
5
+ import require$$0$1 from 'lodash/fp';
6
+ import { __require as requireUtils } from '../utils/index.mjs';
7
+
8
+ var user;
9
+ var hasRequiredUser;
10
+ function requireUser() {
11
+ if (hasRequiredUser) return user;
12
+ hasRequiredUser = 1;
13
+ /**
14
+ * User.js service
15
+ *
16
+ * @description: A set of functions similar to controller's actions to avoid code duplication.
17
+ */ const crypto = require$$0;
18
+ const bcrypt = require$$1;
19
+ const urlJoin = require$$2;
20
+ const { sanitize } = require$$1$1;
21
+ const { toNumber, getOr } = require$$0$1;
22
+ const { getService } = requireUtils();
23
+ const USER_MODEL_UID = 'plugin::users-permissions.user';
24
+ user = ({ strapi })=>({
25
+ /**
26
+ * Promise to count users
27
+ *
28
+ * @return {Promise}
29
+ */ count (params) {
30
+ return strapi.db.query(USER_MODEL_UID).count({
31
+ where: params
32
+ });
33
+ },
34
+ /**
35
+ * Hashes password fields in the provided values object if they are present.
36
+ * It checks each key in the values object against the model's attributes and
37
+ * hashes it if the attribute type is 'password',
38
+ *
39
+ * @param {object} values - The object containing the fields to be hashed.
40
+ * @return {object} The values object with hashed password fields if they were present.
41
+ */ async ensureHashedPasswords (values) {
42
+ const attributes = strapi.getModel(USER_MODEL_UID).attributes;
43
+ for(const key in values){
44
+ if (attributes[key] && attributes[key].type === 'password') {
45
+ // Check if a custom encryption.rounds has been set on the password attribute
46
+ const rounds = toNumber(getOr(10, 'encryption.rounds', attributes[key]));
47
+ values[key] = await bcrypt.hash(values[key], rounds);
48
+ }
49
+ }
50
+ return values;
51
+ },
52
+ /**
53
+ * Promise to add a/an user.
54
+ * @return {Promise}
55
+ */ async add (values) {
56
+ return strapi.db.query(USER_MODEL_UID).create({
57
+ data: await this.ensureHashedPasswords(values),
58
+ populate: [
59
+ 'role'
60
+ ]
61
+ });
62
+ },
63
+ /**
64
+ * Promise to edit a/an user.
65
+ * @param {string} userId
66
+ * @param {object} params
67
+ * @return {Promise}
68
+ */ async edit (userId, params = {}) {
69
+ return strapi.db.query(USER_MODEL_UID).update({
70
+ where: {
71
+ id: userId
72
+ },
73
+ data: await this.ensureHashedPasswords(params),
74
+ populate: [
75
+ 'role'
76
+ ]
77
+ });
78
+ },
79
+ /**
80
+ * Promise to fetch a/an user.
81
+ * @return {Promise}
82
+ */ fetch (id, params) {
83
+ const query = strapi.get('query-params').transform(USER_MODEL_UID, params ?? {});
84
+ return strapi.db.query(USER_MODEL_UID).findOne({
85
+ ...query,
86
+ where: {
87
+ $and: [
88
+ {
89
+ id
90
+ },
91
+ query.where || {}
92
+ ]
93
+ }
94
+ });
95
+ },
96
+ /**
97
+ * Promise to fetch authenticated user.
98
+ * @return {Promise}
99
+ */ fetchAuthenticatedUser (id) {
100
+ return strapi.db.query(USER_MODEL_UID).findOne({
101
+ where: {
102
+ id
103
+ },
104
+ populate: [
105
+ 'role'
106
+ ]
107
+ });
108
+ },
109
+ /**
110
+ * Promise to fetch all users.
111
+ * @return {Promise}
112
+ */ fetchAll (params) {
113
+ const query = strapi.get('query-params').transform(USER_MODEL_UID, params ?? {});
114
+ return strapi.db.query(USER_MODEL_UID).findMany(query);
115
+ },
116
+ /**
117
+ * Promise to remove a/an user.
118
+ * @return {Promise}
119
+ */ async remove (params) {
120
+ return strapi.db.query(USER_MODEL_UID).delete({
121
+ where: params
122
+ });
123
+ },
124
+ validatePassword (password, hash) {
125
+ return bcrypt.compare(password, hash);
126
+ },
127
+ async sendConfirmationEmail (user) {
128
+ const userPermissionService = getService('users-permissions');
129
+ const pluginStore = await strapi.store({
130
+ type: 'plugin',
131
+ name: 'users-permissions'
132
+ });
133
+ const userSchema = strapi.getModel(USER_MODEL_UID);
134
+ const settings = await pluginStore.get({
135
+ key: 'email'
136
+ }).then((storeEmail)=>storeEmail.email_confirmation.options);
137
+ // Sanitize the template's user information
138
+ const sanitizedUserInfo = await sanitize.sanitizers.defaultSanitizeOutput({
139
+ schema: userSchema,
140
+ getModel: strapi.getModel.bind(strapi)
141
+ }, user);
142
+ const confirmationToken = crypto.randomBytes(20).toString('hex');
143
+ await this.edit(user.id, {
144
+ confirmationToken
145
+ });
146
+ const apiPrefix = strapi.config.get('api.rest.prefix');
147
+ try {
148
+ settings.message = await userPermissionService.template(settings.message, {
149
+ URL: urlJoin(strapi.config.get('server.absoluteUrl'), apiPrefix, '/auth/email-confirmation'),
150
+ SERVER_URL: strapi.config.get('server.absoluteUrl'),
151
+ ADMIN_URL: strapi.config.get('admin.absoluteUrl'),
152
+ USER: sanitizedUserInfo,
153
+ CODE: confirmationToken
154
+ });
155
+ settings.object = await userPermissionService.template(settings.object, {
156
+ USER: sanitizedUserInfo
157
+ });
158
+ } catch {
159
+ strapi.log.error('[plugin::users-permissions.sendConfirmationEmail]: Failed to generate a template for "user confirmation email". Please make sure your email template is valid and does not contain invalid characters or patterns');
160
+ return;
161
+ }
162
+ // Send an email to the user.
163
+ await strapi.plugin('email').service('email').send({
164
+ to: user.email,
165
+ from: settings.from.email && settings.from.name ? `${settings.from.name} <${settings.from.email}>` : undefined,
166
+ replyTo: settings.response_email,
167
+ subject: settings.object,
168
+ text: settings.message,
169
+ html: settings.message
170
+ });
171
+ }
172
+ });
173
+ return user;
174
+ }
175
+
176
+ export { requireUser as __require };
177
+ //# sourceMappingURL=user.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.mjs","sources":["../../../server/services/user.js"],"sourcesContent":["'use strict';\n\n/**\n * User.js service\n *\n * @description: A set of functions similar to controller's actions to avoid code duplication.\n */\n\nconst crypto = require('crypto');\nconst bcrypt = require('bcryptjs');\nconst urlJoin = require('url-join');\n\nconst { sanitize } = require('@strapi/utils');\nconst { toNumber, getOr } = require('lodash/fp');\nconst { getService } = require('../utils');\n\nconst USER_MODEL_UID = 'plugin::users-permissions.user';\n\nmodule.exports = ({ strapi }) => ({\n /**\n * Promise to count users\n *\n * @return {Promise}\n */\n\n count(params) {\n return strapi.db.query(USER_MODEL_UID).count({ where: params });\n },\n\n /**\n * Hashes password fields in the provided values object if they are present.\n * It checks each key in the values object against the model's attributes and\n * hashes it if the attribute type is 'password',\n *\n * @param {object} values - The object containing the fields to be hashed.\n * @return {object} The values object with hashed password fields if they were present.\n */\n async ensureHashedPasswords(values) {\n const attributes = strapi.getModel(USER_MODEL_UID).attributes;\n\n for (const key in values) {\n if (attributes[key] && attributes[key].type === 'password') {\n // Check if a custom encryption.rounds has been set on the password attribute\n const rounds = toNumber(getOr(10, 'encryption.rounds', attributes[key]));\n values[key] = await bcrypt.hash(values[key], rounds);\n }\n }\n\n return values;\n },\n\n /**\n * Promise to add a/an user.\n * @return {Promise}\n */\n async add(values) {\n return strapi.db.query(USER_MODEL_UID).create({\n data: await this.ensureHashedPasswords(values),\n populate: ['role'],\n });\n },\n\n /**\n * Promise to edit a/an user.\n * @param {string} userId\n * @param {object} params\n * @return {Promise}\n */\n async edit(userId, params = {}) {\n return strapi.db.query(USER_MODEL_UID).update({\n where: { id: userId },\n data: await this.ensureHashedPasswords(params),\n populate: ['role'],\n });\n },\n\n /**\n * Promise to fetch a/an user.\n * @return {Promise}\n */\n fetch(id, params) {\n const query = strapi.get('query-params').transform(USER_MODEL_UID, params ?? {});\n\n return strapi.db.query(USER_MODEL_UID).findOne({\n ...query,\n where: {\n $and: [{ id }, query.where || {}],\n },\n });\n },\n\n /**\n * Promise to fetch authenticated user.\n * @return {Promise}\n */\n fetchAuthenticatedUser(id) {\n return strapi.db.query(USER_MODEL_UID).findOne({ where: { id }, populate: ['role'] });\n },\n\n /**\n * Promise to fetch all users.\n * @return {Promise}\n */\n fetchAll(params) {\n const query = strapi.get('query-params').transform(USER_MODEL_UID, params ?? {});\n\n return strapi.db.query(USER_MODEL_UID).findMany(query);\n },\n\n /**\n * Promise to remove a/an user.\n * @return {Promise}\n */\n async remove(params) {\n return strapi.db.query(USER_MODEL_UID).delete({ where: params });\n },\n\n validatePassword(password, hash) {\n return bcrypt.compare(password, hash);\n },\n\n async sendConfirmationEmail(user) {\n const userPermissionService = getService('users-permissions');\n const pluginStore = await strapi.store({ type: 'plugin', name: 'users-permissions' });\n const userSchema = strapi.getModel(USER_MODEL_UID);\n\n const settings = await pluginStore\n .get({ key: 'email' })\n .then((storeEmail) => storeEmail.email_confirmation.options);\n\n // Sanitize the template's user information\n const sanitizedUserInfo = await sanitize.sanitizers.defaultSanitizeOutput(\n {\n schema: userSchema,\n getModel: strapi.getModel.bind(strapi),\n },\n user\n );\n\n const confirmationToken = crypto.randomBytes(20).toString('hex');\n\n await this.edit(user.id, { confirmationToken });\n\n const apiPrefix = strapi.config.get('api.rest.prefix');\n\n try {\n settings.message = await userPermissionService.template(settings.message, {\n URL: urlJoin(\n strapi.config.get('server.absoluteUrl'),\n apiPrefix,\n '/auth/email-confirmation'\n ),\n SERVER_URL: strapi.config.get('server.absoluteUrl'),\n ADMIN_URL: strapi.config.get('admin.absoluteUrl'),\n USER: sanitizedUserInfo,\n CODE: confirmationToken,\n });\n\n settings.object = await userPermissionService.template(settings.object, {\n USER: sanitizedUserInfo,\n });\n } catch {\n strapi.log.error(\n '[plugin::users-permissions.sendConfirmationEmail]: Failed to generate a template for \"user confirmation email\". Please make sure your email template is valid and does not contain invalid characters or patterns'\n );\n return;\n }\n\n // Send an email to the user.\n await strapi\n .plugin('email')\n .service('email')\n .send({\n to: user.email,\n from:\n settings.from.email && settings.from.name\n ? `${settings.from.name} <${settings.from.email}>`\n : undefined,\n replyTo: settings.response_email,\n subject: settings.object,\n text: settings.message,\n html: settings.message,\n });\n },\n});\n"],"names":["crypto","require$$0","bcrypt","require$$1","urlJoin","require$$2","sanitize","require$$3","toNumber","getOr","require$$4","getService","require$$5","USER_MODEL_UID","user","strapi","count","params","db","query","where","ensureHashedPasswords","values","attributes","getModel","key","type","rounds","hash","add","create","data","populate","edit","userId","update","id","fetch","get","transform","findOne","$and","fetchAuthenticatedUser","fetchAll","findMany","remove","delete","validatePassword","password","compare","sendConfirmationEmail","userPermissionService","pluginStore","store","name","userSchema","settings","then","storeEmail","email_confirmation","options","sanitizedUserInfo","sanitizers","defaultSanitizeOutput","schema","bind","confirmationToken","randomBytes","toString","apiPrefix","config","message","template","URL","SERVER_URL","ADMIN_URL","USER","CODE","object","log","error","plugin","service","send","to","email","from","undefined","replyTo","response_email","subject","text","html"],"mappings":"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"}