hazo_auth 1.4.1 → 1.6.0

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 (478) hide show
  1. package/README.md +25 -38
  2. package/SETUP_CHECKLIST.md +708 -0
  3. package/dist/app/api/hazo_auth/change_password/route.d.ts +8 -0
  4. package/dist/app/api/hazo_auth/change_password/route.d.ts.map +1 -0
  5. package/dist/app/api/hazo_auth/change_password/route.js +98 -0
  6. package/dist/app/api/hazo_auth/forgot_password/route.d.ts +8 -0
  7. package/dist/app/api/hazo_auth/forgot_password/route.d.ts.map +1 -0
  8. package/dist/app/api/hazo_auth/forgot_password/route.js +78 -0
  9. package/dist/app/api/hazo_auth/get_auth/route.d.ts +10 -0
  10. package/dist/app/api/hazo_auth/get_auth/route.d.ts.map +1 -0
  11. package/dist/app/api/hazo_auth/get_auth/route.js +63 -0
  12. package/dist/app/api/hazo_auth/invalidate_cache/route.d.ts +14 -0
  13. package/dist/app/api/hazo_auth/invalidate_cache/route.d.ts.map +1 -0
  14. package/dist/app/api/hazo_auth/invalidate_cache/route.js +96 -0
  15. package/dist/app/api/hazo_auth/library_photos/route.d.ts +13 -0
  16. package/dist/app/api/hazo_auth/library_photos/route.d.ts.map +1 -0
  17. package/dist/app/api/hazo_auth/library_photos/route.js +55 -0
  18. package/dist/app/api/hazo_auth/login/route.d.ts +12 -0
  19. package/dist/app/api/hazo_auth/login/route.d.ts.map +1 -0
  20. package/dist/app/api/hazo_auth/login/route.js +140 -0
  21. package/dist/app/api/hazo_auth/logout/route.d.ts +8 -0
  22. package/dist/app/api/hazo_auth/logout/route.d.ts.map +1 -0
  23. package/dist/app/api/hazo_auth/logout/route.js +71 -0
  24. package/dist/app/api/hazo_auth/me/route.d.ts +3 -0
  25. package/dist/app/api/hazo_auth/me/route.d.ts.map +1 -0
  26. package/dist/app/api/hazo_auth/me/route.js +34 -0
  27. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts +7 -0
  28. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts.map +1 -0
  29. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.js +43 -0
  30. package/dist/app/api/hazo_auth/register/route.d.ts +9 -0
  31. package/dist/app/api/hazo_auth/register/route.d.ts.map +1 -0
  32. package/dist/app/api/hazo_auth/register/route.js +80 -0
  33. package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts +8 -0
  34. package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts.map +1 -0
  35. package/dist/app/api/hazo_auth/remove_profile_picture/route.js +64 -0
  36. package/dist/app/api/hazo_auth/resend_verification/route.d.ts +8 -0
  37. package/dist/app/api/hazo_auth/resend_verification/route.d.ts.map +1 -0
  38. package/dist/app/api/hazo_auth/resend_verification/route.js +79 -0
  39. package/dist/app/api/hazo_auth/reset_password/route.d.ts +8 -0
  40. package/dist/app/api/hazo_auth/reset_password/route.d.ts.map +1 -0
  41. package/dist/app/api/hazo_auth/reset_password/route.js +76 -0
  42. package/dist/app/api/hazo_auth/update_user/route.d.ts +9 -0
  43. package/dist/app/api/hazo_auth/update_user/route.d.ts.map +1 -0
  44. package/dist/app/api/hazo_auth/update_user/route.js +95 -0
  45. package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts +9 -0
  46. package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts.map +1 -0
  47. package/dist/app/api/hazo_auth/upload_profile_picture/route.js +204 -0
  48. package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts +6 -0
  49. package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts.map +1 -0
  50. package/dist/app/api/hazo_auth/validate_reset_token/route.js +58 -0
  51. package/dist/app/api/hazo_auth/verify_email/route.d.ts +11 -0
  52. package/dist/app/api/hazo_auth/verify_email/route.d.ts.map +1 -0
  53. package/dist/app/api/hazo_auth/verify_email/route.js +63 -0
  54. package/dist/cli/generate.d.ts +2 -0
  55. package/dist/cli/generate.d.ts.map +1 -0
  56. package/dist/cli/generate.js +117 -0
  57. package/dist/cli/index.d.ts +3 -0
  58. package/dist/cli/index.d.ts.map +1 -0
  59. package/dist/cli/index.js +120 -0
  60. package/dist/cli/validate.d.ts +15 -0
  61. package/dist/cli/validate.d.ts.map +1 -0
  62. package/dist/cli/validate.js +509 -0
  63. package/dist/components/layouts/email_verification/config/email_verification_field_config.d.ts +2 -2
  64. package/dist/components/layouts/email_verification/config/email_verification_field_config.d.ts.map +1 -1
  65. package/dist/components/layouts/email_verification/config/email_verification_field_config.js +1 -1
  66. package/dist/components/layouts/email_verification/hooks/use_email_verification.d.ts +2 -2
  67. package/dist/components/layouts/email_verification/hooks/use_email_verification.d.ts.map +1 -1
  68. package/dist/components/layouts/email_verification/hooks/use_email_verification.js +2 -2
  69. package/dist/components/layouts/email_verification/index.d.ts +3 -3
  70. package/dist/components/layouts/email_verification/index.d.ts.map +1 -1
  71. package/dist/components/layouts/email_verification/index.js +9 -9
  72. package/dist/components/layouts/forgot_password/config/forgot_password_field_config.d.ts +2 -2
  73. package/dist/components/layouts/forgot_password/config/forgot_password_field_config.d.ts.map +1 -1
  74. package/dist/components/layouts/forgot_password/config/forgot_password_field_config.js +1 -1
  75. package/dist/components/layouts/forgot_password/hooks/use_forgot_password_form.d.ts +2 -2
  76. package/dist/components/layouts/forgot_password/hooks/use_forgot_password_form.d.ts.map +1 -1
  77. package/dist/components/layouts/forgot_password/hooks/use_forgot_password_form.js +2 -2
  78. package/dist/components/layouts/forgot_password/index.d.ts +2 -2
  79. package/dist/components/layouts/forgot_password/index.d.ts.map +1 -1
  80. package/dist/components/layouts/forgot_password/index.js +8 -8
  81. package/dist/components/layouts/login/config/login_field_config.d.ts +2 -2
  82. package/dist/components/layouts/login/config/login_field_config.d.ts.map +1 -1
  83. package/dist/components/layouts/login/config/login_field_config.js +1 -1
  84. package/dist/components/layouts/login/hooks/use_login_form.d.ts +2 -2
  85. package/dist/components/layouts/login/hooks/use_login_form.d.ts.map +1 -1
  86. package/dist/components/layouts/login/hooks/use_login_form.js +4 -4
  87. package/dist/components/layouts/login/index.d.ts +2 -2
  88. package/dist/components/layouts/login/index.d.ts.map +1 -1
  89. package/dist/components/layouts/login/index.js +9 -9
  90. package/dist/components/layouts/my_settings/components/editable_field.js +3 -3
  91. package/dist/components/layouts/my_settings/components/password_change_dialog.d.ts +1 -1
  92. package/dist/components/layouts/my_settings/components/password_change_dialog.d.ts.map +1 -1
  93. package/dist/components/layouts/my_settings/components/password_change_dialog.js +4 -4
  94. package/dist/components/layouts/my_settings/components/profile_picture_dialog.js +7 -7
  95. package/dist/components/layouts/my_settings/components/profile_picture_display.js +1 -1
  96. package/dist/components/layouts/my_settings/components/profile_picture_gravatar_tab.js +3 -3
  97. package/dist/components/layouts/my_settings/components/profile_picture_library_tab.js +5 -5
  98. package/dist/components/layouts/my_settings/components/profile_picture_upload_tab.js +4 -4
  99. package/dist/components/layouts/my_settings/config/my_settings_field_config.d.ts +1 -1
  100. package/dist/components/layouts/my_settings/config/my_settings_field_config.d.ts.map +1 -1
  101. package/dist/components/layouts/my_settings/config/my_settings_field_config.js +1 -1
  102. package/dist/components/layouts/my_settings/hooks/use_my_settings.d.ts +1 -1
  103. package/dist/components/layouts/my_settings/hooks/use_my_settings.d.ts.map +1 -1
  104. package/dist/components/layouts/my_settings/hooks/use_my_settings.js +1 -1
  105. package/dist/components/layouts/my_settings/index.d.ts +2 -2
  106. package/dist/components/layouts/my_settings/index.d.ts.map +1 -1
  107. package/dist/components/layouts/my_settings/index.js +9 -9
  108. package/dist/components/layouts/register/config/register_field_config.d.ts +2 -2
  109. package/dist/components/layouts/register/config/register_field_config.d.ts.map +1 -1
  110. package/dist/components/layouts/register/config/register_field_config.js +1 -1
  111. package/dist/components/layouts/register/hooks/use_register_form.d.ts +3 -3
  112. package/dist/components/layouts/register/hooks/use_register_form.d.ts.map +1 -1
  113. package/dist/components/layouts/register/hooks/use_register_form.js +2 -2
  114. package/dist/components/layouts/register/index.d.ts +2 -2
  115. package/dist/components/layouts/register/index.d.ts.map +1 -1
  116. package/dist/components/layouts/register/index.js +9 -9
  117. package/dist/components/layouts/reset_password/config/reset_password_field_config.d.ts +2 -2
  118. package/dist/components/layouts/reset_password/config/reset_password_field_config.d.ts.map +1 -1
  119. package/dist/components/layouts/reset_password/config/reset_password_field_config.js +1 -1
  120. package/dist/components/layouts/reset_password/hooks/use_reset_password_form.d.ts +3 -3
  121. package/dist/components/layouts/reset_password/hooks/use_reset_password_form.d.ts.map +1 -1
  122. package/dist/components/layouts/reset_password/hooks/use_reset_password_form.js +2 -2
  123. package/dist/components/layouts/reset_password/index.d.ts +2 -2
  124. package/dist/components/layouts/reset_password/index.d.ts.map +1 -1
  125. package/dist/components/layouts/reset_password/index.js +8 -8
  126. package/dist/components/layouts/shared/components/already_logged_in_guard.js +4 -4
  127. package/dist/components/layouts/shared/components/auth_page_shell.js +3 -3
  128. package/dist/components/layouts/shared/components/form_action_buttons.d.ts +1 -1
  129. package/dist/components/layouts/shared/components/form_action_buttons.d.ts.map +1 -1
  130. package/dist/components/layouts/shared/components/form_action_buttons.js +1 -1
  131. package/dist/components/layouts/shared/components/form_field_wrapper.js +2 -2
  132. package/dist/components/layouts/shared/components/logout_button.js +2 -2
  133. package/dist/components/layouts/shared/components/password_field.js +3 -3
  134. package/dist/components/layouts/shared/components/profile_pic_menu.d.ts +1 -1
  135. package/dist/components/layouts/shared/components/profile_pic_menu.d.ts.map +1 -1
  136. package/dist/components/layouts/shared/components/profile_pic_menu.js +4 -4
  137. package/dist/components/layouts/shared/components/profile_pic_menu_wrapper.js +2 -2
  138. package/dist/components/layouts/shared/components/sidebar_layout_wrapper.js +3 -3
  139. package/dist/components/layouts/shared/components/standalone_layout_wrapper.js +1 -1
  140. package/dist/components/layouts/shared/components/two_column_auth_layout.js +1 -1
  141. package/dist/components/layouts/shared/components/unauthorized_guard.js +2 -2
  142. package/dist/components/layouts/shared/hooks/use_hazo_auth.d.ts +1 -1
  143. package/dist/components/layouts/shared/hooks/use_hazo_auth.d.ts.map +1 -1
  144. package/dist/components/layouts/shared/utils/validation.d.ts +1 -1
  145. package/dist/components/layouts/shared/utils/validation.d.ts.map +1 -1
  146. package/dist/components/layouts/user_management/components/roles_matrix.js +7 -7
  147. package/dist/components/layouts/user_management/index.js +11 -11
  148. package/dist/components/ui/alert-dialog.js +2 -2
  149. package/dist/components/ui/avatar.js +1 -1
  150. package/dist/components/ui/button.js +1 -1
  151. package/dist/components/ui/card.d.ts +9 -0
  152. package/dist/components/ui/card.d.ts.map +1 -0
  153. package/dist/components/ui/card.js +45 -0
  154. package/dist/components/ui/checkbox.js +1 -1
  155. package/dist/components/ui/dialog.js +1 -1
  156. package/dist/components/ui/dropdown-menu.js +1 -1
  157. package/dist/components/ui/hazo_ui_tooltip.js +1 -1
  158. package/dist/components/ui/input.js +1 -1
  159. package/dist/components/ui/label.js +1 -1
  160. package/dist/components/ui/separator.js +1 -1
  161. package/dist/components/ui/sheet.js +1 -1
  162. package/dist/components/ui/sidebar.d.ts +2 -2
  163. package/dist/components/ui/sidebar.d.ts.map +1 -1
  164. package/dist/components/ui/sidebar.js +8 -8
  165. package/dist/components/ui/skeleton.js +1 -1
  166. package/dist/components/ui/switch.js +1 -1
  167. package/dist/components/ui/table.js +1 -1
  168. package/dist/components/ui/tabs.js +1 -1
  169. package/dist/components/ui/tooltip.js +1 -1
  170. package/dist/components/ui/vertical-tabs.js +1 -1
  171. package/dist/hooks/use-mobile.d.ts.map +1 -1
  172. package/dist/hooks/use-mobile.js +17 -3
  173. package/dist/lib/already_logged_in_config.server.js +1 -1
  174. package/dist/lib/app_logger.js +1 -1
  175. package/dist/lib/auth/auth_cache.d.ts +1 -1
  176. package/dist/lib/auth/auth_cache.d.ts.map +1 -1
  177. package/dist/lib/auth/auth_utils.server.js +2 -2
  178. package/dist/lib/auth/hazo_get_auth.server.d.ts +1 -1
  179. package/dist/lib/auth/hazo_get_auth.server.d.ts.map +1 -1
  180. package/dist/lib/auth/hazo_get_auth.server.js +7 -7
  181. package/dist/lib/auth/server_auth.js +2 -2
  182. package/dist/lib/auth_utility_config.server.js +1 -1
  183. package/dist/lib/config/config_loader.server.js +1 -1
  184. package/dist/lib/email_verification_config.server.js +1 -1
  185. package/dist/lib/file_types_config.server.js +1 -1
  186. package/dist/lib/forgot_password_config.server.js +1 -1
  187. package/dist/lib/hazo_connect_instance.server.js +2 -2
  188. package/dist/lib/hazo_connect_setup.server.js +2 -2
  189. package/dist/lib/login_config.server.js +2 -2
  190. package/dist/lib/messages_config.server.js +1 -1
  191. package/dist/lib/my_settings_config.server.js +7 -7
  192. package/dist/lib/password_requirements_config.server.js +1 -1
  193. package/dist/lib/profile_pic_menu_config.server.js +1 -1
  194. package/dist/lib/profile_picture_config.server.js +2 -2
  195. package/dist/lib/register_config.server.js +4 -4
  196. package/dist/lib/reset_password_config.server.js +3 -3
  197. package/dist/lib/services/email_service.js +2 -2
  198. package/dist/lib/services/email_verification_service.js +3 -3
  199. package/dist/lib/services/login_service.js +3 -3
  200. package/dist/lib/services/password_change_service.js +3 -3
  201. package/dist/lib/services/password_reset_service.js +3 -3
  202. package/dist/lib/services/profile_picture_remove_service.js +3 -3
  203. package/dist/lib/services/profile_picture_service.d.ts +1 -1
  204. package/dist/lib/services/profile_picture_service.d.ts.map +1 -1
  205. package/dist/lib/services/profile_picture_service.js +5 -5
  206. package/dist/lib/services/registration_service.js +8 -8
  207. package/dist/lib/services/token_service.js +2 -2
  208. package/dist/lib/services/user_profiles_service.js +2 -2
  209. package/dist/lib/services/user_update_service.d.ts +1 -1
  210. package/dist/lib/services/user_update_service.d.ts.map +1 -1
  211. package/dist/lib/services/user_update_service.js +4 -4
  212. package/dist/lib/ui_shell_config.server.js +1 -1
  213. package/dist/lib/ui_sizes_config.server.js +1 -1
  214. package/dist/lib/user_fields_config.server.js +1 -1
  215. package/dist/lib/user_management_config.server.js +1 -1
  216. package/dist/lib/utils/error_sanitizer.d.ts +1 -1
  217. package/dist/lib/utils/error_sanitizer.d.ts.map +1 -1
  218. package/dist/server/config/config_loader.d.ts +1 -1
  219. package/dist/server/config/config_loader.d.ts.map +1 -1
  220. package/dist/server/config/config_loader.js +1 -1
  221. package/dist/server/index.js +2 -2
  222. package/dist/server/logging/logger_service.d.ts +1 -1
  223. package/dist/server/logging/logger_service.d.ts.map +1 -1
  224. package/dist/server/routes/change_password.d.ts +2 -0
  225. package/dist/server/routes/change_password.d.ts.map +1 -0
  226. package/dist/server/routes/change_password.js +2 -0
  227. package/dist/server/routes/forgot_password.d.ts +2 -0
  228. package/dist/server/routes/forgot_password.d.ts.map +1 -0
  229. package/dist/server/routes/forgot_password.js +2 -0
  230. package/dist/server/routes/get_auth.d.ts +2 -0
  231. package/dist/server/routes/get_auth.d.ts.map +1 -0
  232. package/dist/server/routes/get_auth.js +2 -0
  233. package/dist/server/routes/index.d.ts +18 -0
  234. package/dist/server/routes/index.d.ts.map +1 -0
  235. package/dist/server/routes/index.js +24 -0
  236. package/dist/server/routes/invalidate_cache.d.ts +2 -0
  237. package/dist/server/routes/invalidate_cache.d.ts.map +1 -0
  238. package/dist/server/routes/invalidate_cache.js +2 -0
  239. package/dist/server/routes/library_photos.d.ts +2 -0
  240. package/dist/server/routes/library_photos.d.ts.map +1 -0
  241. package/dist/server/routes/library_photos.js +2 -0
  242. package/dist/server/routes/login.d.ts +2 -0
  243. package/dist/server/routes/login.d.ts.map +1 -0
  244. package/dist/server/routes/login.js +2 -0
  245. package/dist/server/routes/logout.d.ts +2 -0
  246. package/dist/server/routes/logout.d.ts.map +1 -0
  247. package/dist/server/routes/logout.js +2 -0
  248. package/dist/server/routes/me.d.ts +2 -0
  249. package/dist/server/routes/me.d.ts.map +1 -0
  250. package/dist/server/routes/me.js +2 -0
  251. package/dist/server/routes/profile_picture_filename.d.ts +2 -0
  252. package/dist/server/routes/profile_picture_filename.d.ts.map +1 -0
  253. package/dist/server/routes/profile_picture_filename.js +3 -0
  254. package/dist/server/routes/register.d.ts +2 -0
  255. package/dist/server/routes/register.d.ts.map +1 -0
  256. package/dist/server/routes/register.js +2 -0
  257. package/dist/server/routes/remove_profile_picture.d.ts +2 -0
  258. package/dist/server/routes/remove_profile_picture.d.ts.map +1 -0
  259. package/dist/server/routes/remove_profile_picture.js +2 -0
  260. package/dist/server/routes/resend_verification.d.ts +2 -0
  261. package/dist/server/routes/resend_verification.d.ts.map +1 -0
  262. package/dist/server/routes/resend_verification.js +2 -0
  263. package/dist/server/routes/reset_password.d.ts +2 -0
  264. package/dist/server/routes/reset_password.d.ts.map +1 -0
  265. package/dist/server/routes/reset_password.js +2 -0
  266. package/dist/server/routes/update_user.d.ts +2 -0
  267. package/dist/server/routes/update_user.d.ts.map +1 -0
  268. package/dist/server/routes/update_user.js +2 -0
  269. package/dist/server/routes/upload_profile_picture.d.ts +2 -0
  270. package/dist/server/routes/upload_profile_picture.d.ts.map +1 -0
  271. package/dist/server/routes/upload_profile_picture.js +2 -0
  272. package/dist/server/routes/validate_reset_token.d.ts +2 -0
  273. package/dist/server/routes/validate_reset_token.d.ts.map +1 -0
  274. package/dist/server/routes/validate_reset_token.js +2 -0
  275. package/dist/server/routes/verify_email.d.ts +2 -0
  276. package/dist/server/routes/verify_email.d.ts.map +1 -0
  277. package/dist/server/routes/verify_email.js +2 -0
  278. package/dist/server/server.js +2 -2
  279. package/package.json +14 -115
  280. package/components.json +0 -22
  281. package/instrumentation.ts +0 -32
  282. package/migrations/001_add_token_type_to_refresh_tokens.sql +0 -14
  283. package/migrations/002_add_name_to_hazo_users.sql +0 -7
  284. package/migrations/003_add_url_on_logon_to_hazo_users.sql +0 -8
  285. package/next.config.mjs +0 -67
  286. package/postcss.config.mjs +0 -8
  287. package/public/file.svg +0 -1
  288. package/public/globe.svg +0 -1
  289. package/public/next.svg +0 -1
  290. package/public/vercel.svg +0 -1
  291. package/public/window.svg +0 -1
  292. package/scripts/apply_migration.ts +0 -118
  293. package/scripts/init_users.ts +0 -378
  294. package/src/app/api/hazo_auth/auth/upload_profile_picture/route.ts +0 -268
  295. package/src/app/api/hazo_auth/change_password/route.ts +0 -132
  296. package/src/app/api/hazo_auth/forgot_password/route.ts +0 -107
  297. package/src/app/api/hazo_auth/get_auth/route.ts +0 -89
  298. package/src/app/api/hazo_auth/invalidate_cache/route.ts +0 -139
  299. package/src/app/api/hazo_auth/library_photos/route.ts +0 -73
  300. package/src/app/api/hazo_auth/login/route.ts +0 -181
  301. package/src/app/api/hazo_auth/logout/route.ts +0 -89
  302. package/src/app/api/hazo_auth/me/route.ts +0 -47
  303. package/src/app/api/hazo_auth/profile_picture/[filename]/route.ts +0 -67
  304. package/src/app/api/hazo_auth/register/route.ts +0 -109
  305. package/src/app/api/hazo_auth/remove_profile_picture/route.ts +0 -86
  306. package/src/app/api/hazo_auth/resend_verification/route.ts +0 -108
  307. package/src/app/api/hazo_auth/reset_password/route.ts +0 -107
  308. package/src/app/api/hazo_auth/update_user/route.ts +0 -126
  309. package/src/app/api/hazo_auth/upload_profile_picture/route.ts +0 -268
  310. package/src/app/api/hazo_auth/user_management/permissions/route.ts +0 -367
  311. package/src/app/api/hazo_auth/user_management/roles/route.ts +0 -442
  312. package/src/app/api/hazo_auth/user_management/users/roles/route.ts +0 -367
  313. package/src/app/api/hazo_auth/user_management/users/route.ts +0 -239
  314. package/src/app/api/hazo_auth/validate_reset_token/route.ts +0 -83
  315. package/src/app/api/hazo_auth/verify_email/route.ts +0 -88
  316. package/src/app/api/migrations/apply/route.ts +0 -91
  317. package/src/app/favicon.ico +0 -0
  318. package/src/app/fonts/GeistMonoVF.woff +0 -0
  319. package/src/app/fonts/GeistVF.woff +0 -0
  320. package/src/app/globals.css +0 -89
  321. package/src/app/hazo_auth/forgot_password/forgot_password_page_client.tsx +0 -60
  322. package/src/app/hazo_auth/forgot_password/page.tsx +0 -24
  323. package/src/app/hazo_auth/login/login_page_client.tsx +0 -86
  324. package/src/app/hazo_auth/login/page.tsx +0 -38
  325. package/src/app/hazo_auth/my_settings/my_settings_page_client.tsx +0 -120
  326. package/src/app/hazo_auth/my_settings/page.tsx +0 -40
  327. package/src/app/hazo_auth/register/page.tsx +0 -36
  328. package/src/app/hazo_auth/register/register_page_client.tsx +0 -81
  329. package/src/app/hazo_auth/reset_password/page.tsx +0 -29
  330. package/src/app/hazo_auth/reset_password/reset_password_page_client.tsx +0 -81
  331. package/src/app/hazo_auth/user_management/page.tsx +0 -14
  332. package/src/app/hazo_auth/user_management/user_management_page_client.tsx +0 -16
  333. package/src/app/hazo_auth/verify_email/page.tsx +0 -24
  334. package/src/app/hazo_auth/verify_email/verify_email_page_client.tsx +0 -60
  335. package/src/app/hazo_connect/api/sqlite/data/route.ts +0 -203
  336. package/src/app/hazo_connect/api/sqlite/schema/route.ts +0 -45
  337. package/src/app/hazo_connect/api/sqlite/tables/route.ts +0 -36
  338. package/src/app/hazo_connect/sqlite_admin/page.tsx +0 -51
  339. package/src/app/hazo_connect/sqlite_admin/sqlite-admin-client.tsx +0 -984
  340. package/src/app/layout.tsx +0 -43
  341. package/src/app/page.tsx +0 -170
  342. package/src/components/index.ts +0 -7
  343. package/src/components/layouts/email_verification/config/email_verification_field_config.ts +0 -86
  344. package/src/components/layouts/email_verification/hooks/use_email_verification.ts +0 -297
  345. package/src/components/layouts/email_verification/index.tsx +0 -297
  346. package/src/components/layouts/forgot_password/config/forgot_password_field_config.ts +0 -58
  347. package/src/components/layouts/forgot_password/hooks/use_forgot_password_form.ts +0 -179
  348. package/src/components/layouts/forgot_password/index.tsx +0 -168
  349. package/src/components/layouts/index.ts +0 -26
  350. package/src/components/layouts/login/config/login_field_config.ts +0 -67
  351. package/src/components/layouts/login/hooks/use_login_form.ts +0 -286
  352. package/src/components/layouts/login/index.tsx +0 -252
  353. package/src/components/layouts/my_settings/components/editable_field.tsx +0 -177
  354. package/src/components/layouts/my_settings/components/password_change_dialog.tsx +0 -301
  355. package/src/components/layouts/my_settings/components/profile_picture_dialog.tsx +0 -385
  356. package/src/components/layouts/my_settings/components/profile_picture_display.tsx +0 -66
  357. package/src/components/layouts/my_settings/components/profile_picture_gravatar_tab.tsx +0 -143
  358. package/src/components/layouts/my_settings/components/profile_picture_library_tab.tsx +0 -311
  359. package/src/components/layouts/my_settings/components/profile_picture_upload_tab.tsx +0 -341
  360. package/src/components/layouts/my_settings/config/my_settings_field_config.ts +0 -61
  361. package/src/components/layouts/my_settings/hooks/use_my_settings.ts +0 -458
  362. package/src/components/layouts/my_settings/index.tsx +0 -351
  363. package/src/components/layouts/register/config/register_field_config.ts +0 -101
  364. package/src/components/layouts/register/hooks/use_register_form.ts +0 -275
  365. package/src/components/layouts/register/index.tsx +0 -226
  366. package/src/components/layouts/reset_password/config/reset_password_field_config.ts +0 -86
  367. package/src/components/layouts/reset_password/hooks/use_reset_password_form.ts +0 -276
  368. package/src/components/layouts/reset_password/index.tsx +0 -294
  369. package/src/components/layouts/shared/components/already_logged_in_guard.tsx +0 -95
  370. package/src/components/layouts/shared/components/auth_page_shell.tsx +0 -36
  371. package/src/components/layouts/shared/components/field_error_message.tsx +0 -29
  372. package/src/components/layouts/shared/components/form_action_buttons.tsx +0 -64
  373. package/src/components/layouts/shared/components/form_field_wrapper.tsx +0 -44
  374. package/src/components/layouts/shared/components/form_header.tsx +0 -36
  375. package/src/components/layouts/shared/components/logout_button.tsx +0 -76
  376. package/src/components/layouts/shared/components/password_field.tsx +0 -72
  377. package/src/components/layouts/shared/components/profile_pic_menu.tsx +0 -321
  378. package/src/components/layouts/shared/components/profile_pic_menu_wrapper.tsx +0 -40
  379. package/src/components/layouts/shared/components/sidebar_layout_wrapper.tsx +0 -214
  380. package/src/components/layouts/shared/components/standalone_layout_wrapper.tsx +0 -53
  381. package/src/components/layouts/shared/components/two_column_auth_layout.tsx +0 -44
  382. package/src/components/layouts/shared/components/unauthorized_guard.tsx +0 -78
  383. package/src/components/layouts/shared/components/visual_panel.tsx +0 -41
  384. package/src/components/layouts/shared/config/layout_customization.ts +0 -95
  385. package/src/components/layouts/shared/data/layout_data_client.ts +0 -19
  386. package/src/components/layouts/shared/hooks/use_auth_status.ts +0 -103
  387. package/src/components/layouts/shared/hooks/use_hazo_auth.ts +0 -158
  388. package/src/components/layouts/shared/index.ts +0 -34
  389. package/src/components/layouts/shared/utils/ip_address.ts +0 -37
  390. package/src/components/layouts/shared/utils/validation.ts +0 -66
  391. package/src/components/layouts/user_management/components/roles_matrix.tsx +0 -607
  392. package/src/components/layouts/user_management/index.tsx +0 -1295
  393. package/src/components/ui/alert-dialog.tsx +0 -141
  394. package/src/components/ui/avatar.tsx +0 -50
  395. package/src/components/ui/button.tsx +0 -57
  396. package/src/components/ui/checkbox.tsx +0 -30
  397. package/src/components/ui/dialog.tsx +0 -122
  398. package/src/components/ui/dropdown-menu.tsx +0 -201
  399. package/src/components/ui/hazo_ui_tooltip.tsx +0 -67
  400. package/src/components/ui/index.ts +0 -22
  401. package/src/components/ui/input.tsx +0 -22
  402. package/src/components/ui/label.tsx +0 -26
  403. package/src/components/ui/separator.tsx +0 -31
  404. package/src/components/ui/sheet.tsx +0 -139
  405. package/src/components/ui/sidebar.tsx +0 -773
  406. package/src/components/ui/skeleton.tsx +0 -15
  407. package/src/components/ui/sonner.tsx +0 -31
  408. package/src/components/ui/switch.tsx +0 -29
  409. package/src/components/ui/table.tsx +0 -120
  410. package/src/components/ui/tabs.tsx +0 -55
  411. package/src/components/ui/tooltip.tsx +0 -32
  412. package/src/components/ui/vertical-tabs.tsx +0 -59
  413. package/src/hooks/use-mobile.tsx +0 -19
  414. package/src/index.ts +0 -7
  415. package/src/lib/already_logged_in_config.server.ts +0 -46
  416. package/src/lib/app_logger.ts +0 -24
  417. package/src/lib/auth/auth_cache.ts +0 -220
  418. package/src/lib/auth/auth_rate_limiter.ts +0 -121
  419. package/src/lib/auth/auth_types.ts +0 -65
  420. package/src/lib/auth/auth_utils.server.ts +0 -196
  421. package/src/lib/auth/hazo_get_auth.server.ts +0 -333
  422. package/src/lib/auth/index.ts +0 -23
  423. package/src/lib/auth/server_auth.ts +0 -88
  424. package/src/lib/auth_utility_config.server.ts +0 -136
  425. package/src/lib/config/config_loader.server.ts +0 -164
  426. package/src/lib/email_verification_config.server.ts +0 -32
  427. package/src/lib/file_types_config.server.ts +0 -25
  428. package/src/lib/forgot_password_config.server.ts +0 -32
  429. package/src/lib/hazo_connect_instance.server.ts +0 -101
  430. package/src/lib/hazo_connect_setup.server.ts +0 -194
  431. package/src/lib/hazo_connect_setup.ts +0 -54
  432. package/src/lib/index.ts +0 -44
  433. package/src/lib/login_config.server.ts +0 -71
  434. package/src/lib/messages_config.server.ts +0 -45
  435. package/src/lib/migrations/apply_migration.ts +0 -105
  436. package/src/lib/my_settings_config.server.ts +0 -135
  437. package/src/lib/password_requirements_config.server.ts +0 -39
  438. package/src/lib/profile_pic_menu_config.server.ts +0 -138
  439. package/src/lib/profile_picture_config.server.ts +0 -56
  440. package/src/lib/register_config.server.ts +0 -73
  441. package/src/lib/reset_password_config.server.ts +0 -75
  442. package/src/lib/services/email_service.ts +0 -581
  443. package/src/lib/services/email_verification_service.ts +0 -270
  444. package/src/lib/services/index.ts +0 -15
  445. package/src/lib/services/login_service.ts +0 -134
  446. package/src/lib/services/password_change_service.ts +0 -154
  447. package/src/lib/services/password_reset_service.ts +0 -405
  448. package/src/lib/services/profile_picture_remove_service.ts +0 -120
  449. package/src/lib/services/profile_picture_service.ts +0 -215
  450. package/src/lib/services/profile_picture_source_mapper.ts +0 -62
  451. package/src/lib/services/registration_service.ts +0 -184
  452. package/src/lib/services/token_service.ts +0 -240
  453. package/src/lib/services/user_profiles_service.ts +0 -143
  454. package/src/lib/services/user_update_service.ts +0 -141
  455. package/src/lib/ui_shell_config.server.ts +0 -73
  456. package/src/lib/ui_sizes_config.server.ts +0 -37
  457. package/src/lib/user_fields_config.server.ts +0 -31
  458. package/src/lib/user_management_config.server.ts +0 -39
  459. package/src/lib/utils/api_route_helpers.ts +0 -60
  460. package/src/lib/utils/error_sanitizer.ts +0 -75
  461. package/src/lib/utils.ts +0 -11
  462. package/src/middleware.ts +0 -94
  463. package/src/routes/index.ts +0 -34
  464. package/src/server/config/config_loader.ts +0 -496
  465. package/src/server/index.ts +0 -38
  466. package/src/server/logging/logger_service.ts +0 -56
  467. package/src/server/routes/root_router.ts +0 -16
  468. package/src/server/server.ts +0 -28
  469. package/src/server/types/app_types.ts +0 -74
  470. package/src/server/types/express.d.ts +0 -16
  471. package/src/stories/email_verification_layout.stories.tsx +0 -137
  472. package/src/stories/forgot_password_layout.stories.tsx +0 -85
  473. package/src/stories/login_layout.stories.tsx +0 -85
  474. package/src/stories/project_overview.stories.tsx +0 -33
  475. package/src/stories/register_layout.stories.tsx +0 -107
  476. package/tailwind.config.ts +0 -77
  477. package/tsconfig.build.json +0 -39
  478. package/tsconfig.json +0 -28
@@ -1,268 +0,0 @@
1
- // file_description: API route for uploading profile pictures
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { get_hazo_connect_instance } from "../../../../lib/hazo_connect_instance.server";
5
- import { create_app_logger } from "../../../../lib/app_logger";
6
- import { get_profile_picture_config } from "../../../../lib/profile_picture_config.server";
7
- import { get_file_types_config } from "../../../../lib/file_types_config.server";
8
- import { update_user_profile_picture } from "../../../../lib/services/profile_picture_service";
9
- import { createCrudService } from "hazo_connect/server";
10
- import { map_db_source_to_ui } from "../../../../lib/services/profile_picture_source_mapper";
11
- import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
12
- import fs from "fs";
13
- import path from "path";
14
-
15
- // section: api_handler
16
- export async function POST(request: NextRequest) {
17
- const logger = create_app_logger();
18
-
19
- try {
20
- // Use centralized auth check
21
- let user_id: string;
22
- try {
23
- const { require_auth } = await import("../../../../lib/auth/auth_utils.server");
24
- const user = await require_auth(request);
25
- user_id = user.user_id;
26
- } catch (error) {
27
- if (error instanceof Error && error.message === "Authentication required") {
28
- logger.warn("profile_picture_upload_authentication_failed", {
29
- filename: get_filename(),
30
- line_number: get_line_number(),
31
- error: "User not authenticated",
32
- });
33
-
34
- return NextResponse.json(
35
- { error: "Authentication required" },
36
- { status: 401 }
37
- );
38
- }
39
- throw error;
40
- }
41
-
42
- // Check if upload is enabled
43
- const config = get_profile_picture_config();
44
- if (!config.allow_photo_upload) {
45
- logger.warn("profile_picture_upload_disabled", {
46
- filename: get_filename(),
47
- line_number: get_line_number(),
48
- user_id,
49
- });
50
-
51
- return NextResponse.json(
52
- { error: "Photo upload is not enabled" },
53
- { status: 403 }
54
- );
55
- }
56
-
57
- if (!config.upload_photo_path) {
58
- logger.warn("profile_picture_upload_path_not_configured", {
59
- filename: get_filename(),
60
- line_number: get_line_number(),
61
- user_id,
62
- });
63
-
64
- return NextResponse.json(
65
- { error: "Upload path is not configured" },
66
- { status: 500 }
67
- );
68
- }
69
-
70
- // Get FormData
71
- const formData = await request.formData();
72
- const file = formData.get("file") as File | null;
73
-
74
- if (!file) {
75
- logger.warn("profile_picture_upload_no_file", {
76
- filename: get_filename(),
77
- line_number: get_line_number(),
78
- user_id,
79
- });
80
-
81
- return NextResponse.json(
82
- { error: "No file provided" },
83
- { status: 400 }
84
- );
85
- }
86
-
87
- // Validate file type
88
- const fileTypes = get_file_types_config();
89
- const fileType = file.type;
90
- if (!fileTypes.allowed_image_mime_types.includes(fileType)) {
91
- logger.warn("profile_picture_upload_invalid_type", {
92
- filename: get_filename(),
93
- line_number: get_line_number(),
94
- user_id,
95
- fileType,
96
- });
97
-
98
- return NextResponse.json(
99
- { error: "Invalid file type. Only JPG and PNG files are allowed." },
100
- { status: 400 }
101
- );
102
- }
103
-
104
- // Validate file size (should already be compressed client-side, but check server-side too)
105
- const fileSize = file.size;
106
- if (fileSize > config.max_photo_size) {
107
- logger.warn("profile_picture_upload_too_large", {
108
- filename: get_filename(),
109
- line_number: get_line_number(),
110
- user_id,
111
- fileSize,
112
- maxSize: config.max_photo_size,
113
- });
114
-
115
- return NextResponse.json(
116
- { error: `File size exceeds maximum allowed size of ${config.max_photo_size} bytes` },
117
- { status: 400 }
118
- );
119
- }
120
-
121
- // Get current user profile picture info before updating
122
- const hazoConnect = get_hazo_connect_instance();
123
- const users_service = createCrudService(hazoConnect, "hazo_users");
124
- const current_users = await users_service.findBy({ id: user_id });
125
-
126
- let oldProfilePictureUrl: string | null = null;
127
- let oldProfileSource: string | null = null;
128
-
129
- if (Array.isArray(current_users) && current_users.length > 0) {
130
- const current_user = current_users[0];
131
- oldProfilePictureUrl = (current_user.profile_picture_url as string) || null;
132
- oldProfileSource = (current_user.profile_source as string) || null;
133
- }
134
-
135
- // Determine file extension from MIME type
136
- const mimeToExt: Record<string, string> = {
137
- "image/jpeg": "jpg",
138
- "image/jpg": "jpg",
139
- "image/png": "png",
140
- };
141
- const fileExtension = mimeToExt[fileType] || "jpg";
142
- const fileName = `${user_id}.${fileExtension}`;
143
-
144
- // Resolve upload path
145
- const uploadPath = path.isAbsolute(config.upload_photo_path)
146
- ? config.upload_photo_path
147
- : path.resolve(process.cwd(), config.upload_photo_path);
148
-
149
- // Create upload directory if it doesn't exist
150
- if (!fs.existsSync(uploadPath)) {
151
- fs.mkdirSync(uploadPath, { recursive: true });
152
- }
153
-
154
- // Save file
155
- const filePath = path.join(uploadPath, fileName);
156
- const arrayBuffer = await file.arrayBuffer();
157
- const buffer = Buffer.from(arrayBuffer);
158
- fs.writeFileSync(filePath, buffer);
159
-
160
- // Generate URL (relative to public or absolute)
161
- // For Next.js, we'll serve from a public route or use absolute path
162
- // For now, use a relative path that can be served via API or static file serving
163
- const profilePictureUrl = `/api/hazo_auth/profile_picture/${fileName}`;
164
-
165
- // Update user record
166
- const updateResult = await update_user_profile_picture(
167
- hazoConnect,
168
- user_id,
169
- profilePictureUrl,
170
- "upload",
171
- );
172
-
173
- if (!updateResult.success) {
174
- // Clean up uploaded file
175
- try {
176
- fs.unlinkSync(filePath);
177
- } catch (error) {
178
- // Ignore cleanup errors
179
- }
180
-
181
- logger.warn("profile_picture_upload_update_failed", {
182
- filename: get_filename(),
183
- line_number: get_line_number(),
184
- user_id,
185
- error: updateResult.error,
186
- });
187
-
188
- return NextResponse.json(
189
- { error: updateResult.error || "Failed to update profile picture" },
190
- { status: 500 }
191
- );
192
- }
193
-
194
- // Delete old profile picture file if it exists and was an uploaded file
195
- if (oldProfilePictureUrl && oldProfileSource) {
196
- const oldSourceUI = map_db_source_to_ui(oldProfileSource);
197
-
198
- // Only delete if the old profile picture was an uploaded file
199
- if (oldSourceUI === "upload") {
200
- try {
201
- // Extract filename from URL (e.g., /api/hazo_auth/profile_picture/user_id.jpg)
202
- const oldFileName = oldProfilePictureUrl.split("/").pop();
203
-
204
- if (oldFileName) {
205
- // Check if it's a user-specific file (starts with user_id)
206
- if (oldFileName.startsWith(user_id)) {
207
- const oldFilePath = path.join(uploadPath, oldFileName);
208
-
209
- // Only delete if it's a different file (different extension)
210
- if (oldFilePath !== filePath && fs.existsSync(oldFilePath)) {
211
- fs.unlinkSync(oldFilePath);
212
-
213
- logger.info("profile_picture_old_file_deleted", {
214
- filename: get_filename(),
215
- line_number: get_line_number(),
216
- user_id,
217
- oldFileName,
218
- });
219
- }
220
- }
221
- }
222
- } catch (error) {
223
- // Log error but don't fail the request
224
- logger.warn("profile_picture_old_file_delete_failed", {
225
- filename: get_filename(),
226
- line_number: get_line_number(),
227
- user_id,
228
- oldProfilePictureUrl,
229
- error: error instanceof Error ? error.message : "Unknown error",
230
- });
231
- }
232
- }
233
- }
234
-
235
- logger.info("profile_picture_upload_successful", {
236
- filename: get_filename(),
237
- line_number: get_line_number(),
238
- user_id,
239
- fileName,
240
- fileSize,
241
- });
242
-
243
- return NextResponse.json(
244
- {
245
- success: true,
246
- profile_picture_url: profilePictureUrl,
247
- message: "Profile picture uploaded successfully",
248
- },
249
- { status: 200 }
250
- );
251
- } catch (error) {
252
- const error_message = error instanceof Error ? error.message : "Unknown error";
253
- const error_stack = error instanceof Error ? error.stack : undefined;
254
-
255
- logger.error("profile_picture_upload_error", {
256
- filename: get_filename(),
257
- line_number: get_line_number(),
258
- error_message,
259
- error_stack,
260
- });
261
-
262
- return NextResponse.json(
263
- { error: "Failed to upload profile picture. Please try again." },
264
- { status: 500 }
265
- );
266
- }
267
- }
268
-
@@ -1,367 +0,0 @@
1
- // file_description: API route for permissions management operations (list, migrate from config, update, delete)
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { get_hazo_connect_instance } from "../../../../../lib/hazo_connect_instance.server";
5
- import { createCrudService } from "hazo_connect/server";
6
- import { create_app_logger } from "../../../../../lib/app_logger";
7
- import { get_filename, get_line_number } from "../../../../../lib/utils/api_route_helpers";
8
- import { get_user_management_config } from "../../../../../lib/user_management_config.server";
9
-
10
- // section: route_config
11
- export const dynamic = 'force-dynamic';
12
-
13
- // section: api_handler
14
- /**
15
- * GET - Fetch all permissions from database and config
16
- */
17
- export async function GET(request: NextRequest) {
18
- const logger = create_app_logger();
19
-
20
- try {
21
- const hazoConnect = get_hazo_connect_instance();
22
- const permissions_service = createCrudService(hazoConnect, "hazo_permissions");
23
-
24
- // Fetch all permissions from database (empty object means no filter - get all records)
25
- const db_permissions = await permissions_service.findBy({});
26
-
27
- if (!Array.isArray(db_permissions)) {
28
- return NextResponse.json(
29
- { error: "Failed to fetch permissions" },
30
- { status: 500 }
31
- );
32
- }
33
-
34
- // Get config permissions
35
- const config = get_user_management_config();
36
- const config_permission_names = config.application_permission_list_defaults || [];
37
-
38
- // Get DB permission names
39
- const db_permission_names = db_permissions.map((p) => p.permission_name as string);
40
-
41
- // Find config permissions not in DB
42
- const config_only_permissions = config_permission_names.filter(
43
- (name) => !db_permission_names.includes(name)
44
- );
45
-
46
- logger.info("user_management_permissions_fetched", {
47
- filename: get_filename(),
48
- line_number: get_line_number(),
49
- db_count: db_permissions.length,
50
- config_count: config_permission_names.length,
51
- });
52
-
53
- return NextResponse.json(
54
- {
55
- success: true,
56
- db_permissions: db_permissions.map((p) => ({
57
- id: p.id,
58
- permission_name: p.permission_name,
59
- description: p.description || "",
60
- })),
61
- config_permissions: config_only_permissions,
62
- },
63
- { status: 200 }
64
- );
65
- } catch (error) {
66
- const error_message = error instanceof Error ? error.message : "Unknown error";
67
- const error_stack = error instanceof Error ? error.stack : undefined;
68
-
69
- logger.error("user_management_permissions_fetch_error", {
70
- filename: get_filename(),
71
- line_number: get_line_number(),
72
- error_message,
73
- error_stack,
74
- });
75
-
76
- return NextResponse.json(
77
- { error: "Failed to fetch permissions" },
78
- { status: 500 }
79
- );
80
- }
81
- }
82
-
83
- /**
84
- * POST - Create new permission or migrate config permissions to database
85
- */
86
- export async function POST(request: NextRequest) {
87
- const logger = create_app_logger();
88
-
89
- try {
90
- const { searchParams } = new URL(request.url);
91
- const action = searchParams.get("action");
92
-
93
- // Handle migrate action
94
- if (action === "migrate") {
95
- const hazoConnect = get_hazo_connect_instance();
96
- const permissions_service = createCrudService(hazoConnect, "hazo_permissions");
97
-
98
- // Get config permissions
99
- const config = get_user_management_config();
100
- const config_permission_names = config.application_permission_list_defaults || [];
101
-
102
- if (config_permission_names.length === 0) {
103
- return NextResponse.json(
104
- {
105
- success: true,
106
- message: "No permissions to migrate",
107
- created: [],
108
- skipped: [],
109
- },
110
- { status: 200 }
111
- );
112
- }
113
-
114
- // Get existing permissions from DB (empty object means no filter - get all records)
115
- const db_permissions = await permissions_service.findBy({});
116
- const db_permission_names = Array.isArray(db_permissions)
117
- ? db_permissions.map((p) => p.permission_name as string)
118
- : [];
119
-
120
- const now = new Date().toISOString();
121
- const created: string[] = [];
122
- const skipped: string[] = [];
123
-
124
- // Migrate each config permission
125
- for (const permission_name of config_permission_names) {
126
- if (db_permission_names.includes(permission_name)) {
127
- // Skip if already exists
128
- skipped.push(permission_name);
129
- continue;
130
- }
131
-
132
- // Create new permission
133
- await permissions_service.insert({
134
- permission_name: permission_name.trim(),
135
- description: "",
136
- created_at: now,
137
- changed_at: now,
138
- });
139
-
140
- created.push(permission_name);
141
- }
142
-
143
- logger.info("user_management_permissions_migrated", {
144
- filename: get_filename(),
145
- line_number: get_line_number(),
146
- created_count: created.length,
147
- skipped_count: skipped.length,
148
- });
149
-
150
- return NextResponse.json(
151
- {
152
- success: true,
153
- created,
154
- skipped,
155
- },
156
- { status: 200 }
157
- );
158
- }
159
-
160
- // Handle create new permission
161
- const body = await request.json();
162
- const { permission_name, description } = body;
163
-
164
- if (!permission_name || typeof permission_name !== "string" || permission_name.trim().length === 0) {
165
- return NextResponse.json(
166
- { error: "permission_name is required and must be a non-empty string" },
167
- { status: 400 }
168
- );
169
- }
170
-
171
- const hazoConnect = get_hazo_connect_instance();
172
- const permissions_service = createCrudService(hazoConnect, "hazo_permissions");
173
-
174
- // Check if permission already exists
175
- const existing_permissions = await permissions_service.findBy({
176
- permission_name: permission_name.trim(),
177
- });
178
-
179
- if (Array.isArray(existing_permissions) && existing_permissions.length > 0) {
180
- return NextResponse.json(
181
- { error: "Permission with this name already exists" },
182
- { status: 409 }
183
- );
184
- }
185
-
186
- // Create new permission
187
- const now = new Date().toISOString();
188
- const new_permission_result = await permissions_service.insert({
189
- permission_name: permission_name.trim(),
190
- description: (description || "").trim(),
191
- created_at: now,
192
- changed_at: now,
193
- });
194
-
195
- // insert() returns an array, get the first element
196
- if (!Array.isArray(new_permission_result) || new_permission_result.length === 0) {
197
- return NextResponse.json(
198
- { error: "Failed to create permission - no record returned" },
199
- { status: 500 }
200
- );
201
- }
202
-
203
- const new_permission = new_permission_result[0] as { id: number; permission_name: string; description: string };
204
-
205
- logger.info("user_management_permission_created", {
206
- filename: get_filename(),
207
- line_number: get_line_number(),
208
- permission_id: new_permission.id,
209
- permission_name: permission_name.trim(),
210
- });
211
-
212
- return NextResponse.json(
213
- {
214
- success: true,
215
- permission: {
216
- id: new_permission.id,
217
- permission_name: permission_name.trim(),
218
- description: (description || "").trim(),
219
- },
220
- },
221
- { status: 201 }
222
- );
223
- } catch (error) {
224
- const error_message = error instanceof Error ? error.message : "Unknown error";
225
- const error_stack = error instanceof Error ? error.stack : undefined;
226
-
227
- logger.error("user_management_permissions_post_error", {
228
- filename: get_filename(),
229
- line_number: get_line_number(),
230
- error_message,
231
- error_stack,
232
- });
233
-
234
- return NextResponse.json(
235
- { error: "Failed to create permission" },
236
- { status: 500 }
237
- );
238
- }
239
- }
240
-
241
- /**
242
- * PUT - Update permission description
243
- */
244
- export async function PUT(request: NextRequest) {
245
- const logger = create_app_logger();
246
-
247
- try {
248
- const body = await request.json();
249
- const { permission_id, description } = body;
250
-
251
- if (!permission_id || typeof description !== "string") {
252
- return NextResponse.json(
253
- { error: "permission_id and description are required" },
254
- { status: 400 }
255
- );
256
- }
257
-
258
- const hazoConnect = get_hazo_connect_instance();
259
- const permissions_service = createCrudService(hazoConnect, "hazo_permissions");
260
-
261
- // Update permission with changed_at timestamp
262
- const now = new Date().toISOString();
263
- await permissions_service.updateById(permission_id, {
264
- description: description.trim(),
265
- changed_at: now,
266
- });
267
-
268
- logger.info("user_management_permission_updated", {
269
- filename: get_filename(),
270
- line_number: get_line_number(),
271
- permission_id,
272
- });
273
-
274
- return NextResponse.json(
275
- { success: true },
276
- { status: 200 }
277
- );
278
- } catch (error) {
279
- const error_message = error instanceof Error ? error.message : "Unknown error";
280
- const error_stack = error instanceof Error ? error.stack : undefined;
281
-
282
- logger.error("user_management_permission_update_error", {
283
- filename: get_filename(),
284
- line_number: get_line_number(),
285
- error_message,
286
- error_stack,
287
- });
288
-
289
- return NextResponse.json(
290
- { error: "Failed to update permission" },
291
- { status: 500 }
292
- );
293
- }
294
- }
295
-
296
- /**
297
- * DELETE - Delete permission from database
298
- */
299
- export async function DELETE(request: NextRequest) {
300
- const logger = create_app_logger();
301
-
302
- try {
303
- const { searchParams } = new URL(request.url);
304
- const permission_id = searchParams.get("permission_id");
305
-
306
- if (!permission_id) {
307
- return NextResponse.json(
308
- { error: "permission_id is required" },
309
- { status: 400 }
310
- );
311
- }
312
-
313
- const permission_id_num = parseInt(permission_id, 10);
314
- if (isNaN(permission_id_num)) {
315
- return NextResponse.json(
316
- { error: "permission_id must be a number" },
317
- { status: 400 }
318
- );
319
- }
320
-
321
- const hazoConnect = get_hazo_connect_instance();
322
- const permissions_service = createCrudService(hazoConnect, "hazo_permissions");
323
- const role_permissions_service = createCrudService(hazoConnect, "hazo_role_permissions");
324
-
325
- // Check if permission is used in any role
326
- const role_permissions = await role_permissions_service.findBy({
327
- permission_id: permission_id_num,
328
- });
329
-
330
- if (Array.isArray(role_permissions) && role_permissions.length > 0) {
331
- return NextResponse.json(
332
- { error: "Cannot delete permission that is assigned to roles" },
333
- { status: 409 }
334
- );
335
- }
336
-
337
- // Delete permission
338
- await permissions_service.deleteById(permission_id_num);
339
-
340
- logger.info("user_management_permission_deleted", {
341
- filename: get_filename(),
342
- line_number: get_line_number(),
343
- permission_id: permission_id_num,
344
- });
345
-
346
- return NextResponse.json(
347
- { success: true },
348
- { status: 200 }
349
- );
350
- } catch (error) {
351
- const error_message = error instanceof Error ? error.message : "Unknown error";
352
- const error_stack = error instanceof Error ? error.stack : undefined;
353
-
354
- logger.error("user_management_permission_delete_error", {
355
- filename: get_filename(),
356
- line_number: get_line_number(),
357
- error_message,
358
- error_stack,
359
- });
360
-
361
- return NextResponse.json(
362
- { error: "Failed to delete permission" },
363
- { status: 500 }
364
- );
365
- }
366
- }
367
-