hazo_auth 1.4.2 → 1.6.1

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 (354) hide show
  1. package/README.md +65 -19
  2. package/SETUP_CHECKLIST.md +779 -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_photo/[category]/[filename]/route.d.ts +9 -0
  16. package/dist/app/api/hazo_auth/library_photo/[category]/[filename]/route.d.ts.map +1 -0
  17. package/dist/app/api/hazo_auth/library_photo/[category]/[filename]/route.js +82 -0
  18. package/dist/app/api/hazo_auth/library_photos/route.d.ts +22 -0
  19. package/dist/app/api/hazo_auth/library_photos/route.d.ts.map +1 -0
  20. package/dist/app/api/hazo_auth/library_photos/route.js +80 -0
  21. package/dist/app/api/hazo_auth/login/route.d.ts +12 -0
  22. package/dist/app/api/hazo_auth/login/route.d.ts.map +1 -0
  23. package/dist/app/api/hazo_auth/login/route.js +140 -0
  24. package/dist/app/api/hazo_auth/logout/route.d.ts +8 -0
  25. package/dist/app/api/hazo_auth/logout/route.d.ts.map +1 -0
  26. package/dist/app/api/hazo_auth/logout/route.js +71 -0
  27. package/dist/app/api/hazo_auth/me/route.d.ts +3 -0
  28. package/dist/app/api/hazo_auth/me/route.d.ts.map +1 -0
  29. package/dist/app/api/hazo_auth/me/route.js +34 -0
  30. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts +7 -0
  31. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts.map +1 -0
  32. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.js +43 -0
  33. package/dist/app/api/hazo_auth/register/route.d.ts +9 -0
  34. package/dist/app/api/hazo_auth/register/route.d.ts.map +1 -0
  35. package/dist/app/api/hazo_auth/register/route.js +80 -0
  36. package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts +8 -0
  37. package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts.map +1 -0
  38. package/dist/app/api/hazo_auth/remove_profile_picture/route.js +64 -0
  39. package/dist/app/api/hazo_auth/resend_verification/route.d.ts +8 -0
  40. package/dist/app/api/hazo_auth/resend_verification/route.d.ts.map +1 -0
  41. package/dist/app/api/hazo_auth/resend_verification/route.js +79 -0
  42. package/dist/app/api/hazo_auth/reset_password/route.d.ts +8 -0
  43. package/dist/app/api/hazo_auth/reset_password/route.d.ts.map +1 -0
  44. package/dist/app/api/hazo_auth/reset_password/route.js +76 -0
  45. package/dist/app/api/hazo_auth/update_user/route.d.ts +9 -0
  46. package/dist/app/api/hazo_auth/update_user/route.d.ts.map +1 -0
  47. package/dist/app/api/hazo_auth/update_user/route.js +95 -0
  48. package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts +9 -0
  49. package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts.map +1 -0
  50. package/dist/app/api/hazo_auth/upload_profile_picture/route.js +204 -0
  51. package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts +6 -0
  52. package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts.map +1 -0
  53. package/dist/app/api/hazo_auth/validate_reset_token/route.js +58 -0
  54. package/dist/app/api/hazo_auth/verify_email/route.d.ts +11 -0
  55. package/dist/app/api/hazo_auth/verify_email/route.d.ts.map +1 -0
  56. package/dist/app/api/hazo_auth/verify_email/route.js +63 -0
  57. package/dist/cli/generate.d.ts +7 -0
  58. package/dist/cli/generate.d.ts.map +1 -0
  59. package/dist/cli/generate.js +184 -0
  60. package/dist/cli/index.d.ts +3 -0
  61. package/dist/cli/index.d.ts.map +1 -0
  62. package/dist/cli/index.js +173 -0
  63. package/dist/cli/init.d.ts +2 -0
  64. package/dist/cli/init.d.ts.map +1 -0
  65. package/dist/cli/init.js +201 -0
  66. package/dist/cli/validate.d.ts +15 -0
  67. package/dist/cli/validate.d.ts.map +1 -0
  68. package/dist/cli/validate.js +509 -0
  69. package/dist/components/ui/card.d.ts +9 -0
  70. package/dist/components/ui/card.d.ts.map +1 -0
  71. package/dist/components/ui/card.js +45 -0
  72. package/dist/hooks/use-mobile.d.ts.map +1 -1
  73. package/dist/hooks/use-mobile.js +17 -3
  74. package/dist/lib/services/profile_picture_service.d.ts +34 -2
  75. package/dist/lib/services/profile_picture_service.d.ts.map +1 -1
  76. package/dist/lib/services/profile_picture_service.js +157 -15
  77. package/dist/page_components/forgot_password.d.ts +19 -0
  78. package/dist/page_components/forgot_password.d.ts.map +1 -0
  79. package/dist/page_components/forgot_password.js +36 -0
  80. package/dist/page_components/index.d.ts +7 -0
  81. package/dist/page_components/index.d.ts.map +1 -0
  82. package/dist/page_components/index.js +9 -0
  83. package/dist/page_components/login.d.ts +26 -0
  84. package/dist/page_components/login.d.ts.map +1 -0
  85. package/dist/page_components/login.js +40 -0
  86. package/dist/page_components/my_settings.d.ts +64 -0
  87. package/dist/page_components/my_settings.d.ts.map +1 -0
  88. package/dist/page_components/my_settings.js +67 -0
  89. package/dist/page_components/register.d.ts +25 -0
  90. package/dist/page_components/register.d.ts.map +1 -0
  91. package/dist/page_components/register.js +43 -0
  92. package/dist/page_components/reset_password.d.ts +25 -0
  93. package/dist/page_components/reset_password.d.ts.map +1 -0
  94. package/dist/page_components/reset_password.js +43 -0
  95. package/dist/page_components/verify_email.d.ts +21 -0
  96. package/dist/page_components/verify_email.d.ts.map +1 -0
  97. package/dist/page_components/verify_email.js +36 -0
  98. package/dist/server/routes/change_password.d.ts +2 -0
  99. package/dist/server/routes/change_password.d.ts.map +1 -0
  100. package/dist/server/routes/change_password.js +2 -0
  101. package/dist/server/routes/forgot_password.d.ts +2 -0
  102. package/dist/server/routes/forgot_password.d.ts.map +1 -0
  103. package/dist/server/routes/forgot_password.js +2 -0
  104. package/dist/server/routes/get_auth.d.ts +2 -0
  105. package/dist/server/routes/get_auth.d.ts.map +1 -0
  106. package/dist/server/routes/get_auth.js +2 -0
  107. package/dist/server/routes/index.d.ts +19 -0
  108. package/dist/server/routes/index.d.ts.map +1 -0
  109. package/dist/server/routes/index.js +25 -0
  110. package/dist/server/routes/invalidate_cache.d.ts +2 -0
  111. package/dist/server/routes/invalidate_cache.d.ts.map +1 -0
  112. package/dist/server/routes/invalidate_cache.js +2 -0
  113. package/dist/server/routes/library_photo.d.ts +2 -0
  114. package/dist/server/routes/library_photo.d.ts.map +1 -0
  115. package/dist/server/routes/library_photo.js +3 -0
  116. package/dist/server/routes/library_photos.d.ts +2 -0
  117. package/dist/server/routes/library_photos.d.ts.map +1 -0
  118. package/dist/server/routes/library_photos.js +2 -0
  119. package/dist/server/routes/login.d.ts +2 -0
  120. package/dist/server/routes/login.d.ts.map +1 -0
  121. package/dist/server/routes/login.js +2 -0
  122. package/dist/server/routes/logout.d.ts +2 -0
  123. package/dist/server/routes/logout.d.ts.map +1 -0
  124. package/dist/server/routes/logout.js +2 -0
  125. package/dist/server/routes/me.d.ts +2 -0
  126. package/dist/server/routes/me.d.ts.map +1 -0
  127. package/dist/server/routes/me.js +2 -0
  128. package/dist/server/routes/profile_picture_filename.d.ts +2 -0
  129. package/dist/server/routes/profile_picture_filename.d.ts.map +1 -0
  130. package/dist/server/routes/profile_picture_filename.js +3 -0
  131. package/dist/server/routes/register.d.ts +2 -0
  132. package/dist/server/routes/register.d.ts.map +1 -0
  133. package/dist/server/routes/register.js +2 -0
  134. package/dist/server/routes/remove_profile_picture.d.ts +2 -0
  135. package/dist/server/routes/remove_profile_picture.d.ts.map +1 -0
  136. package/dist/server/routes/remove_profile_picture.js +2 -0
  137. package/dist/server/routes/resend_verification.d.ts +2 -0
  138. package/dist/server/routes/resend_verification.d.ts.map +1 -0
  139. package/dist/server/routes/resend_verification.js +2 -0
  140. package/dist/server/routes/reset_password.d.ts +2 -0
  141. package/dist/server/routes/reset_password.d.ts.map +1 -0
  142. package/dist/server/routes/reset_password.js +2 -0
  143. package/dist/server/routes/update_user.d.ts +2 -0
  144. package/dist/server/routes/update_user.d.ts.map +1 -0
  145. package/dist/server/routes/update_user.js +2 -0
  146. package/dist/server/routes/upload_profile_picture.d.ts +2 -0
  147. package/dist/server/routes/upload_profile_picture.d.ts.map +1 -0
  148. package/dist/server/routes/upload_profile_picture.js +2 -0
  149. package/dist/server/routes/validate_reset_token.d.ts +2 -0
  150. package/dist/server/routes/validate_reset_token.d.ts.map +1 -0
  151. package/dist/server/routes/validate_reset_token.js +2 -0
  152. package/dist/server/routes/verify_email.d.ts +2 -0
  153. package/dist/server/routes/verify_email.d.ts.map +1 -0
  154. package/dist/server/routes/verify_email.js +2 -0
  155. package/package.json +40 -17
  156. package/components.json +0 -22
  157. package/instrumentation.ts +0 -32
  158. package/migrations/001_add_token_type_to_refresh_tokens.sql +0 -14
  159. package/migrations/002_add_name_to_hazo_users.sql +0 -7
  160. package/migrations/003_add_url_on_logon_to_hazo_users.sql +0 -8
  161. package/next.config.mjs +0 -67
  162. package/postcss.config.mjs +0 -8
  163. package/public/file.svg +0 -1
  164. package/public/globe.svg +0 -1
  165. package/public/next.svg +0 -1
  166. package/public/vercel.svg +0 -1
  167. package/public/window.svg +0 -1
  168. package/scripts/apply_migration.ts +0 -118
  169. package/scripts/init_users.ts +0 -378
  170. package/src/app/api/hazo_auth/auth/upload_profile_picture/route.ts +0 -268
  171. package/src/app/api/hazo_auth/change_password/route.ts +0 -132
  172. package/src/app/api/hazo_auth/forgot_password/route.ts +0 -107
  173. package/src/app/api/hazo_auth/get_auth/route.ts +0 -89
  174. package/src/app/api/hazo_auth/invalidate_cache/route.ts +0 -139
  175. package/src/app/api/hazo_auth/library_photos/route.ts +0 -73
  176. package/src/app/api/hazo_auth/login/route.ts +0 -181
  177. package/src/app/api/hazo_auth/logout/route.ts +0 -89
  178. package/src/app/api/hazo_auth/me/route.ts +0 -47
  179. package/src/app/api/hazo_auth/profile_picture/[filename]/route.ts +0 -67
  180. package/src/app/api/hazo_auth/register/route.ts +0 -109
  181. package/src/app/api/hazo_auth/remove_profile_picture/route.ts +0 -86
  182. package/src/app/api/hazo_auth/resend_verification/route.ts +0 -108
  183. package/src/app/api/hazo_auth/reset_password/route.ts +0 -107
  184. package/src/app/api/hazo_auth/update_user/route.ts +0 -126
  185. package/src/app/api/hazo_auth/upload_profile_picture/route.ts +0 -268
  186. package/src/app/api/hazo_auth/user_management/permissions/route.ts +0 -367
  187. package/src/app/api/hazo_auth/user_management/roles/route.ts +0 -442
  188. package/src/app/api/hazo_auth/user_management/users/roles/route.ts +0 -367
  189. package/src/app/api/hazo_auth/user_management/users/route.ts +0 -239
  190. package/src/app/api/hazo_auth/validate_reset_token/route.ts +0 -83
  191. package/src/app/api/hazo_auth/verify_email/route.ts +0 -88
  192. package/src/app/api/migrations/apply/route.ts +0 -91
  193. package/src/app/favicon.ico +0 -0
  194. package/src/app/fonts/GeistMonoVF.woff +0 -0
  195. package/src/app/fonts/GeistVF.woff +0 -0
  196. package/src/app/globals.css +0 -89
  197. package/src/app/hazo_auth/forgot_password/forgot_password_page_client.tsx +0 -60
  198. package/src/app/hazo_auth/forgot_password/page.tsx +0 -24
  199. package/src/app/hazo_auth/login/login_page_client.tsx +0 -86
  200. package/src/app/hazo_auth/login/page.tsx +0 -38
  201. package/src/app/hazo_auth/my_settings/my_settings_page_client.tsx +0 -120
  202. package/src/app/hazo_auth/my_settings/page.tsx +0 -40
  203. package/src/app/hazo_auth/register/page.tsx +0 -36
  204. package/src/app/hazo_auth/register/register_page_client.tsx +0 -81
  205. package/src/app/hazo_auth/reset_password/page.tsx +0 -29
  206. package/src/app/hazo_auth/reset_password/reset_password_page_client.tsx +0 -81
  207. package/src/app/hazo_auth/user_management/page.tsx +0 -14
  208. package/src/app/hazo_auth/user_management/user_management_page_client.tsx +0 -16
  209. package/src/app/hazo_auth/verify_email/page.tsx +0 -24
  210. package/src/app/hazo_auth/verify_email/verify_email_page_client.tsx +0 -60
  211. package/src/app/hazo_connect/api/sqlite/data/route.ts +0 -203
  212. package/src/app/hazo_connect/api/sqlite/schema/route.ts +0 -45
  213. package/src/app/hazo_connect/api/sqlite/tables/route.ts +0 -36
  214. package/src/app/hazo_connect/sqlite_admin/page.tsx +0 -51
  215. package/src/app/hazo_connect/sqlite_admin/sqlite-admin-client.tsx +0 -984
  216. package/src/app/layout.tsx +0 -43
  217. package/src/app/page.tsx +0 -170
  218. package/src/components/index.ts +0 -7
  219. package/src/components/layouts/email_verification/config/email_verification_field_config.ts +0 -86
  220. package/src/components/layouts/email_verification/hooks/use_email_verification.ts +0 -297
  221. package/src/components/layouts/email_verification/index.tsx +0 -297
  222. package/src/components/layouts/forgot_password/config/forgot_password_field_config.ts +0 -58
  223. package/src/components/layouts/forgot_password/hooks/use_forgot_password_form.ts +0 -179
  224. package/src/components/layouts/forgot_password/index.tsx +0 -168
  225. package/src/components/layouts/index.ts +0 -26
  226. package/src/components/layouts/login/config/login_field_config.ts +0 -67
  227. package/src/components/layouts/login/hooks/use_login_form.ts +0 -286
  228. package/src/components/layouts/login/index.tsx +0 -252
  229. package/src/components/layouts/my_settings/components/editable_field.tsx +0 -177
  230. package/src/components/layouts/my_settings/components/password_change_dialog.tsx +0 -301
  231. package/src/components/layouts/my_settings/components/profile_picture_dialog.tsx +0 -385
  232. package/src/components/layouts/my_settings/components/profile_picture_display.tsx +0 -66
  233. package/src/components/layouts/my_settings/components/profile_picture_gravatar_tab.tsx +0 -143
  234. package/src/components/layouts/my_settings/components/profile_picture_library_tab.tsx +0 -311
  235. package/src/components/layouts/my_settings/components/profile_picture_upload_tab.tsx +0 -341
  236. package/src/components/layouts/my_settings/config/my_settings_field_config.ts +0 -61
  237. package/src/components/layouts/my_settings/hooks/use_my_settings.ts +0 -458
  238. package/src/components/layouts/my_settings/index.tsx +0 -351
  239. package/src/components/layouts/register/config/register_field_config.ts +0 -101
  240. package/src/components/layouts/register/hooks/use_register_form.ts +0 -275
  241. package/src/components/layouts/register/index.tsx +0 -226
  242. package/src/components/layouts/reset_password/config/reset_password_field_config.ts +0 -86
  243. package/src/components/layouts/reset_password/hooks/use_reset_password_form.ts +0 -276
  244. package/src/components/layouts/reset_password/index.tsx +0 -294
  245. package/src/components/layouts/shared/components/already_logged_in_guard.tsx +0 -95
  246. package/src/components/layouts/shared/components/auth_page_shell.tsx +0 -36
  247. package/src/components/layouts/shared/components/field_error_message.tsx +0 -29
  248. package/src/components/layouts/shared/components/form_action_buttons.tsx +0 -64
  249. package/src/components/layouts/shared/components/form_field_wrapper.tsx +0 -44
  250. package/src/components/layouts/shared/components/form_header.tsx +0 -36
  251. package/src/components/layouts/shared/components/logout_button.tsx +0 -76
  252. package/src/components/layouts/shared/components/password_field.tsx +0 -72
  253. package/src/components/layouts/shared/components/profile_pic_menu.tsx +0 -321
  254. package/src/components/layouts/shared/components/profile_pic_menu_wrapper.tsx +0 -40
  255. package/src/components/layouts/shared/components/sidebar_layout_wrapper.tsx +0 -214
  256. package/src/components/layouts/shared/components/standalone_layout_wrapper.tsx +0 -53
  257. package/src/components/layouts/shared/components/two_column_auth_layout.tsx +0 -44
  258. package/src/components/layouts/shared/components/unauthorized_guard.tsx +0 -78
  259. package/src/components/layouts/shared/components/visual_panel.tsx +0 -41
  260. package/src/components/layouts/shared/config/layout_customization.ts +0 -95
  261. package/src/components/layouts/shared/data/layout_data_client.ts +0 -19
  262. package/src/components/layouts/shared/hooks/use_auth_status.ts +0 -103
  263. package/src/components/layouts/shared/hooks/use_hazo_auth.ts +0 -158
  264. package/src/components/layouts/shared/index.ts +0 -34
  265. package/src/components/layouts/shared/utils/ip_address.ts +0 -37
  266. package/src/components/layouts/shared/utils/validation.ts +0 -66
  267. package/src/components/layouts/user_management/components/roles_matrix.tsx +0 -607
  268. package/src/components/layouts/user_management/index.tsx +0 -1295
  269. package/src/components/ui/alert-dialog.tsx +0 -141
  270. package/src/components/ui/avatar.tsx +0 -50
  271. package/src/components/ui/button.tsx +0 -57
  272. package/src/components/ui/checkbox.tsx +0 -30
  273. package/src/components/ui/dialog.tsx +0 -122
  274. package/src/components/ui/dropdown-menu.tsx +0 -201
  275. package/src/components/ui/hazo_ui_tooltip.tsx +0 -67
  276. package/src/components/ui/index.ts +0 -22
  277. package/src/components/ui/input.tsx +0 -22
  278. package/src/components/ui/label.tsx +0 -26
  279. package/src/components/ui/separator.tsx +0 -31
  280. package/src/components/ui/sheet.tsx +0 -139
  281. package/src/components/ui/sidebar.tsx +0 -773
  282. package/src/components/ui/skeleton.tsx +0 -15
  283. package/src/components/ui/sonner.tsx +0 -31
  284. package/src/components/ui/switch.tsx +0 -29
  285. package/src/components/ui/table.tsx +0 -120
  286. package/src/components/ui/tabs.tsx +0 -55
  287. package/src/components/ui/tooltip.tsx +0 -32
  288. package/src/components/ui/vertical-tabs.tsx +0 -59
  289. package/src/hooks/use-mobile.tsx +0 -19
  290. package/src/index.ts +0 -7
  291. package/src/lib/already_logged_in_config.server.ts +0 -46
  292. package/src/lib/app_logger.ts +0 -24
  293. package/src/lib/auth/auth_cache.ts +0 -220
  294. package/src/lib/auth/auth_rate_limiter.ts +0 -121
  295. package/src/lib/auth/auth_types.ts +0 -65
  296. package/src/lib/auth/auth_utils.server.ts +0 -196
  297. package/src/lib/auth/hazo_get_auth.server.ts +0 -333
  298. package/src/lib/auth/index.ts +0 -23
  299. package/src/lib/auth/server_auth.ts +0 -88
  300. package/src/lib/auth_utility_config.server.ts +0 -136
  301. package/src/lib/config/config_loader.server.ts +0 -164
  302. package/src/lib/email_verification_config.server.ts +0 -32
  303. package/src/lib/file_types_config.server.ts +0 -25
  304. package/src/lib/forgot_password_config.server.ts +0 -32
  305. package/src/lib/hazo_connect_instance.server.ts +0 -101
  306. package/src/lib/hazo_connect_setup.server.ts +0 -194
  307. package/src/lib/hazo_connect_setup.ts +0 -54
  308. package/src/lib/index.ts +0 -44
  309. package/src/lib/login_config.server.ts +0 -71
  310. package/src/lib/messages_config.server.ts +0 -45
  311. package/src/lib/migrations/apply_migration.ts +0 -105
  312. package/src/lib/my_settings_config.server.ts +0 -135
  313. package/src/lib/password_requirements_config.server.ts +0 -39
  314. package/src/lib/profile_pic_menu_config.server.ts +0 -138
  315. package/src/lib/profile_picture_config.server.ts +0 -56
  316. package/src/lib/register_config.server.ts +0 -73
  317. package/src/lib/reset_password_config.server.ts +0 -75
  318. package/src/lib/services/email_service.ts +0 -581
  319. package/src/lib/services/email_verification_service.ts +0 -270
  320. package/src/lib/services/index.ts +0 -15
  321. package/src/lib/services/login_service.ts +0 -134
  322. package/src/lib/services/password_change_service.ts +0 -154
  323. package/src/lib/services/password_reset_service.ts +0 -405
  324. package/src/lib/services/profile_picture_remove_service.ts +0 -120
  325. package/src/lib/services/profile_picture_service.ts +0 -215
  326. package/src/lib/services/profile_picture_source_mapper.ts +0 -62
  327. package/src/lib/services/registration_service.ts +0 -184
  328. package/src/lib/services/token_service.ts +0 -240
  329. package/src/lib/services/user_profiles_service.ts +0 -143
  330. package/src/lib/services/user_update_service.ts +0 -141
  331. package/src/lib/ui_shell_config.server.ts +0 -73
  332. package/src/lib/ui_sizes_config.server.ts +0 -37
  333. package/src/lib/user_fields_config.server.ts +0 -31
  334. package/src/lib/user_management_config.server.ts +0 -39
  335. package/src/lib/utils/api_route_helpers.ts +0 -60
  336. package/src/lib/utils/error_sanitizer.ts +0 -75
  337. package/src/lib/utils.ts +0 -11
  338. package/src/middleware.ts +0 -94
  339. package/src/routes/index.ts +0 -34
  340. package/src/server/config/config_loader.ts +0 -496
  341. package/src/server/index.ts +0 -38
  342. package/src/server/logging/logger_service.ts +0 -56
  343. package/src/server/routes/root_router.ts +0 -16
  344. package/src/server/server.ts +0 -28
  345. package/src/server/types/app_types.ts +0 -74
  346. package/src/server/types/express.d.ts +0 -16
  347. package/src/stories/email_verification_layout.stories.tsx +0 -137
  348. package/src/stories/forgot_password_layout.stories.tsx +0 -85
  349. package/src/stories/login_layout.stories.tsx +0 -85
  350. package/src/stories/project_overview.stories.tsx +0 -33
  351. package/src/stories/register_layout.stories.tsx +0 -107
  352. package/tailwind.config.ts +0 -77
  353. package/tsconfig.build.json +0 -36
  354. package/tsconfig.json +0 -28
@@ -1,367 +0,0 @@
1
- // file_description: API route for managing user roles (assigning roles to users)
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, getSqliteAdminService } 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_auth_cache } from "../../../../../../lib/auth/auth_cache";
9
- import { get_auth_utility_config } from "../../../../../../lib/auth_utility_config.server";
10
-
11
- // section: route_config
12
- export const dynamic = 'force-dynamic';
13
-
14
- // section: api_handler
15
- /**
16
- * GET - Get roles assigned to a user
17
- * Query params: user_id (string)
18
- */
19
- export async function GET(request: NextRequest) {
20
- const logger = create_app_logger();
21
-
22
- try {
23
- const { searchParams } = new URL(request.url);
24
- const user_id = searchParams.get("user_id");
25
-
26
- if (!user_id || typeof user_id !== "string") {
27
- return NextResponse.json(
28
- { error: "user_id is required as a query parameter" },
29
- { status: 400 }
30
- );
31
- }
32
-
33
- const hazoConnect = get_hazo_connect_instance();
34
- const user_roles_service = createCrudService(hazoConnect, "hazo_user_roles");
35
-
36
- // Get all roles assigned to this user
37
- const user_roles = await user_roles_service.findBy({
38
- user_id,
39
- });
40
-
41
- if (!Array.isArray(user_roles)) {
42
- return NextResponse.json(
43
- { error: "Failed to fetch user roles" },
44
- { status: 500 }
45
- );
46
- }
47
-
48
- // Extract role IDs
49
- const role_ids = user_roles.map((ur) => ur.role_id as number).filter((id) => id !== undefined);
50
-
51
- return NextResponse.json(
52
- {
53
- success: true,
54
- role_ids,
55
- },
56
- { status: 200 }
57
- );
58
- } catch (error) {
59
- const error_message = error instanceof Error ? error.message : "Unknown error";
60
- logger.error("user_management_user_roles_fetch_failed", {
61
- filename: get_filename(),
62
- line_number: get_line_number(),
63
- error: error_message,
64
- });
65
-
66
- return NextResponse.json(
67
- { error: "Failed to fetch user roles" },
68
- { status: 500 }
69
- );
70
- }
71
- }
72
-
73
- /**
74
- * POST - Assign a role to a user
75
- * Body: { user_id: string, role_id: number }
76
- */
77
- export async function POST(request: NextRequest) {
78
- const logger = create_app_logger();
79
-
80
- try {
81
- const body = await request.json();
82
- const { user_id, role_id } = body;
83
-
84
- if (!user_id || typeof user_id !== "string") {
85
- return NextResponse.json(
86
- { error: "user_id is required and must be a string" },
87
- { status: 400 }
88
- );
89
- }
90
-
91
- if (!role_id || typeof role_id !== "number") {
92
- return NextResponse.json(
93
- { error: "role_id is required and must be a number" },
94
- { status: 400 }
95
- );
96
- }
97
-
98
- const hazoConnect = get_hazo_connect_instance();
99
- const user_roles_service = createCrudService(hazoConnect, "hazo_user_roles");
100
-
101
- // Check if user exists
102
- const users_service = createCrudService(hazoConnect, "hazo_users");
103
- const users = await users_service.findBy({ id: user_id });
104
- if (!Array.isArray(users) || users.length === 0) {
105
- return NextResponse.json(
106
- { error: "User not found" },
107
- { status: 404 }
108
- );
109
- }
110
-
111
- // Check if role exists
112
- const roles_service = createCrudService(hazoConnect, "hazo_roles");
113
- const roles = await roles_service.findBy({ id: role_id });
114
- if (!Array.isArray(roles) || roles.length === 0) {
115
- return NextResponse.json(
116
- { error: "Role not found" },
117
- { status: 404 }
118
- );
119
- }
120
-
121
- // Check if role is already assigned to user
122
- const existing_assignments = await user_roles_service.findBy({
123
- user_id,
124
- role_id,
125
- });
126
-
127
- if (Array.isArray(existing_assignments) && existing_assignments.length > 0) {
128
- return NextResponse.json(
129
- { error: "Role is already assigned to this user" },
130
- { status: 409 }
131
- );
132
- }
133
-
134
- // Assign role to user
135
- const now = new Date().toISOString();
136
- const new_assignment = await user_roles_service.insert({
137
- user_id,
138
- role_id,
139
- created_at: now,
140
- changed_at: now,
141
- });
142
-
143
- logger.info("user_management_user_role_assigned", {
144
- filename: get_filename(),
145
- line_number: get_line_number(),
146
- user_id,
147
- role_id,
148
- assignment_id: (new_assignment as { user_id?: string; role_id?: number }).user_id,
149
- });
150
-
151
- return NextResponse.json(
152
- {
153
- success: true,
154
- assignment: {
155
- user_id,
156
- role_id,
157
- },
158
- },
159
- { status: 201 }
160
- );
161
- } catch (error) {
162
- const error_message = error instanceof Error ? error.message : "Unknown error";
163
- logger.error("user_management_user_role_assign_failed", {
164
- filename: get_filename(),
165
- line_number: get_line_number(),
166
- error: error_message,
167
- });
168
-
169
- return NextResponse.json(
170
- { error: "Failed to assign role to user" },
171
- { status: 500 }
172
- );
173
- }
174
- }
175
-
176
- /**
177
- * PUT - Update user roles (bulk assignment/removal)
178
- * Body: { user_id: string, role_ids: number[] }
179
- */
180
- export async function PUT(request: NextRequest) {
181
- const logger = create_app_logger();
182
-
183
- try {
184
- const body = await request.json();
185
- const { user_id, role_ids } = body;
186
-
187
- if (!user_id || typeof user_id !== "string") {
188
- return NextResponse.json(
189
- { error: "user_id is required and must be a string" },
190
- { status: 400 }
191
- );
192
- }
193
-
194
- if (!Array.isArray(role_ids)) {
195
- return NextResponse.json(
196
- { error: "role_ids is required and must be an array" },
197
- { status: 400 }
198
- );
199
- }
200
-
201
- const hazoConnect = get_hazo_connect_instance();
202
- const user_roles_service = createCrudService(hazoConnect, "hazo_user_roles");
203
-
204
- // Check if user exists
205
- const users_service = createCrudService(hazoConnect, "hazo_users");
206
- const users = await users_service.findBy({ id: user_id });
207
- if (!Array.isArray(users) || users.length === 0) {
208
- return NextResponse.json(
209
- { error: "User not found" },
210
- { status: 404 }
211
- );
212
- }
213
-
214
- // Get current user roles
215
- const current_user_roles = await user_roles_service.findBy({
216
- user_id,
217
- });
218
-
219
- if (!Array.isArray(current_user_roles)) {
220
- return NextResponse.json(
221
- { error: "Failed to fetch current user roles" },
222
- { status: 500 }
223
- );
224
- }
225
-
226
- const current_role_ids = current_user_roles.map((ur) => ur.role_id as number).filter((id) => id !== undefined);
227
- const target_role_ids = role_ids.filter((id) => typeof id === "number");
228
-
229
- // Find roles to add and remove
230
- const to_add = target_role_ids.filter((id) => !current_role_ids.includes(id));
231
- const to_remove = current_role_ids.filter((id) => !target_role_ids.includes(id));
232
-
233
- const now = new Date().toISOString();
234
-
235
- // Add new roles
236
- for (const role_id of to_add) {
237
- // Check if role exists
238
- const roles_service = createCrudService(hazoConnect, "hazo_roles");
239
- const roles = await roles_service.findBy({ id: role_id });
240
- if (Array.isArray(roles) && roles.length > 0) {
241
- await user_roles_service.insert({
242
- user_id,
243
- role_id,
244
- created_at: now,
245
- changed_at: now,
246
- });
247
- }
248
- }
249
-
250
- // Remove roles
251
- // Note: hazo_user_roles is a junction table without an id column
252
- // We need to use SQLite admin service to delete by composite key (user_id, role_id)
253
- if (to_remove.length > 0) {
254
- try {
255
- const admin_service = getSqliteAdminService();
256
-
257
- for (const role_id of to_remove) {
258
- // Delete using SQLite admin service with criteria (user_id and role_id)
259
- await admin_service.deleteRows("hazo_user_roles", {
260
- user_id,
261
- role_id,
262
- });
263
- }
264
- } catch (adminError) {
265
- // Fallback: try using createCrudService deleteById if rowid exists
266
- // SQLite tables have a hidden rowid column that can be used
267
- const error_message = adminError instanceof Error ? adminError.message : "Unknown error";
268
- logger.warn("user_management_user_role_delete_admin_failed", {
269
- filename: get_filename(),
270
- line_number: get_line_number(),
271
- error: error_message,
272
- note: "Trying fallback method",
273
- });
274
-
275
- // Fallback: try to find and delete using rowid if available
276
- for (const role_id of to_remove) {
277
- const assignments_to_remove = await user_roles_service.findBy({
278
- user_id,
279
- role_id,
280
- });
281
-
282
- if (Array.isArray(assignments_to_remove) && assignments_to_remove.length > 0) {
283
- for (const assignment of assignments_to_remove) {
284
- // Try deleteById with rowid (SQLite has hidden rowid)
285
- try {
286
- // Check if assignment has an id field (could be rowid)
287
- if ((assignment as { id?: number }).id !== undefined) {
288
- await user_roles_service.deleteById((assignment as { id: number }).id);
289
- } else if ((assignment as { rowid?: number }).rowid !== undefined) {
290
- await user_roles_service.deleteById((assignment as { rowid: number }).rowid);
291
- } else {
292
- // Last resort: log error
293
- logger.error("user_management_user_role_delete_no_id", {
294
- filename: get_filename(),
295
- line_number: get_line_number(),
296
- user_id,
297
- role_id,
298
- assignment,
299
- });
300
- }
301
- } catch (deleteError) {
302
- const delete_error_message = deleteError instanceof Error ? deleteError.message : "Unknown error";
303
- logger.error("user_management_user_role_delete_failed", {
304
- filename: get_filename(),
305
- line_number: get_line_number(),
306
- user_id,
307
- role_id,
308
- error: delete_error_message,
309
- });
310
- }
311
- }
312
- }
313
- }
314
- }
315
- }
316
-
317
- // Invalidate user cache after role assignment changes
318
- try {
319
- const config = get_auth_utility_config();
320
- const cache = get_auth_cache(
321
- config.cache_max_users,
322
- config.cache_ttl_minutes,
323
- config.cache_max_age_minutes,
324
- );
325
- cache.invalidate_user(user_id);
326
- } catch (cache_error) {
327
- // Log but don't fail role update if cache invalidation fails
328
- const cache_error_message =
329
- cache_error instanceof Error ? cache_error.message : "Unknown error";
330
- logger.warn("user_management_user_roles_cache_invalidation_failed", {
331
- filename: get_filename(),
332
- line_number: get_line_number(),
333
- user_id,
334
- error: cache_error_message,
335
- });
336
- }
337
-
338
- logger.info("user_management_user_roles_updated", {
339
- filename: get_filename(),
340
- line_number: get_line_number(),
341
- user_id,
342
- added: to_add.length,
343
- removed: to_remove.length,
344
- });
345
-
346
- return NextResponse.json(
347
- {
348
- success: true,
349
- added: to_add.length,
350
- removed: to_remove.length,
351
- },
352
- { status: 200 }
353
- );
354
- } catch (error) {
355
- const error_message = error instanceof Error ? error.message : "Unknown error";
356
- logger.error("user_management_user_roles_update_failed", {
357
- filename: get_filename(),
358
- line_number: get_line_number(),
359
- error: error_message,
360
- });
361
-
362
- return NextResponse.json(
363
- { error: "Failed to update user roles" },
364
- { status: 500 }
365
- );
366
- }
367
- }
@@ -1,239 +0,0 @@
1
- // file_description: API route for user management operations (list users, deactivate, reset password)
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 { request_password_reset } from "../../../../../lib/services/password_reset_service";
9
- import { get_auth_cache } from "../../../../../lib/auth/auth_cache";
10
- import { get_auth_utility_config } from "../../../../../lib/auth_utility_config.server";
11
-
12
- // section: route_config
13
- export const dynamic = 'force-dynamic';
14
-
15
- // section: api_handler
16
- /**
17
- * GET - Fetch all users with details or a specific user by id
18
- * Query params: id (optional) - if provided, returns only that user
19
- */
20
- export async function GET(request: NextRequest) {
21
- const logger = create_app_logger();
22
-
23
- try {
24
- const { searchParams } = new URL(request.url);
25
- const user_id = searchParams.get("id");
26
-
27
- const hazoConnect = get_hazo_connect_instance();
28
- const users_service = createCrudService(hazoConnect, "hazo_users");
29
-
30
- // Fetch users - filter by id if provided, otherwise get all
31
- const users = await users_service.findBy(user_id ? { id: user_id } : {});
32
-
33
- if (!Array.isArray(users)) {
34
- return NextResponse.json(
35
- { error: "Failed to fetch users" },
36
- { status: 500 }
37
- );
38
- }
39
-
40
- logger.info("user_management_users_fetched", {
41
- filename: get_filename(),
42
- line_number: get_line_number(),
43
- user_count: users.length,
44
- });
45
-
46
- return NextResponse.json(
47
- {
48
- success: true,
49
- users: users.map((user) => ({
50
- id: user.id,
51
- name: user.name || null,
52
- email_address: user.email_address,
53
- email_verified: user.email_verified || false,
54
- is_active: user.is_active !== false,
55
- last_logon: user.last_logon || null,
56
- created_at: user.created_at || null,
57
- profile_picture_url: user.profile_picture_url || null,
58
- profile_source: user.profile_source || null,
59
- })),
60
- },
61
- { status: 200 }
62
- );
63
- } catch (error) {
64
- const error_message = error instanceof Error ? error.message : "Unknown error";
65
- const error_stack = error instanceof Error ? error.stack : undefined;
66
-
67
- logger.error("user_management_users_fetch_error", {
68
- filename: get_filename(),
69
- line_number: get_line_number(),
70
- error_message,
71
- error_stack,
72
- });
73
-
74
- return NextResponse.json(
75
- { error: "Failed to fetch users" },
76
- { status: 500 }
77
- );
78
- }
79
- }
80
-
81
- /**
82
- * PATCH - Update user (deactivate: set is_active to false)
83
- */
84
- export async function PATCH(request: NextRequest) {
85
- const logger = create_app_logger();
86
-
87
- try {
88
- const body = await request.json();
89
- const { user_id, is_active } = body;
90
-
91
- if (!user_id || typeof is_active !== "boolean") {
92
- return NextResponse.json(
93
- { error: "user_id and is_active (boolean) are required" },
94
- { status: 400 }
95
- );
96
- }
97
-
98
- const hazoConnect = get_hazo_connect_instance();
99
- const users_service = createCrudService(hazoConnect, "hazo_users");
100
-
101
- // Update user with changed_at timestamp
102
- const now = new Date().toISOString();
103
- await users_service.updateById(user_id, {
104
- is_active,
105
- changed_at: now,
106
- });
107
-
108
- // Invalidate user cache after deactivation
109
- if (is_active === false) {
110
- try {
111
- const config = get_auth_utility_config();
112
- const cache = get_auth_cache(
113
- config.cache_max_users,
114
- config.cache_ttl_minutes,
115
- config.cache_max_age_minutes,
116
- );
117
- cache.invalidate_user(user_id);
118
- } catch (cache_error) {
119
- // Log but don't fail user update if cache invalidation fails
120
- const cache_error_message =
121
- cache_error instanceof Error ? cache_error.message : "Unknown error";
122
- logger.warn("user_management_user_cache_invalidation_failed", {
123
- filename: get_filename(),
124
- line_number: get_line_number(),
125
- user_id,
126
- error: cache_error_message,
127
- });
128
- }
129
- }
130
-
131
- logger.info("user_management_user_updated", {
132
- filename: get_filename(),
133
- line_number: get_line_number(),
134
- user_id,
135
- is_active,
136
- });
137
-
138
- return NextResponse.json(
139
- { success: true },
140
- { status: 200 }
141
- );
142
- } catch (error) {
143
- const error_message = error instanceof Error ? error.message : "Unknown error";
144
- const error_stack = error instanceof Error ? error.stack : undefined;
145
-
146
- logger.error("user_management_user_update_error", {
147
- filename: get_filename(),
148
- line_number: get_line_number(),
149
- error_message,
150
- error_stack,
151
- });
152
-
153
- return NextResponse.json(
154
- { error: "Failed to update user" },
155
- { status: 500 }
156
- );
157
- }
158
- }
159
-
160
- /**
161
- * POST - Send password reset email to user
162
- */
163
- export async function POST(request: NextRequest) {
164
- const logger = create_app_logger();
165
-
166
- try {
167
- const body = await request.json();
168
- const { user_id } = body;
169
-
170
- if (!user_id) {
171
- return NextResponse.json(
172
- { error: "user_id is required" },
173
- { status: 400 }
174
- );
175
- }
176
-
177
- const hazoConnect = get_hazo_connect_instance();
178
- const users_service = createCrudService(hazoConnect, "hazo_users");
179
-
180
- // Get user by ID
181
- const users = await users_service.findBy({ id: user_id });
182
-
183
- if (!Array.isArray(users) || users.length === 0) {
184
- return NextResponse.json(
185
- { error: "User not found" },
186
- { status: 404 }
187
- );
188
- }
189
-
190
- const user = users[0];
191
- const email = user.email_address as string;
192
-
193
- // Request password reset using existing service
194
- const result = await request_password_reset(hazoConnect, { email });
195
-
196
- if (!result.success) {
197
- logger.warn("user_management_password_reset_failed", {
198
- filename: get_filename(),
199
- line_number: get_line_number(),
200
- user_id,
201
- email,
202
- error: result.error,
203
- });
204
-
205
- return NextResponse.json(
206
- { error: result.error || "Failed to send password reset email" },
207
- { status: 500 }
208
- );
209
- }
210
-
211
- logger.info("user_management_password_reset_sent", {
212
- filename: get_filename(),
213
- line_number: get_line_number(),
214
- user_id,
215
- email,
216
- });
217
-
218
- return NextResponse.json(
219
- { success: true },
220
- { status: 200 }
221
- );
222
- } catch (error) {
223
- const error_message = error instanceof Error ? error.message : "Unknown error";
224
- const error_stack = error instanceof Error ? error.stack : undefined;
225
-
226
- logger.error("user_management_password_reset_error", {
227
- filename: get_filename(),
228
- line_number: get_line_number(),
229
- error_message,
230
- error_stack,
231
- });
232
-
233
- return NextResponse.json(
234
- { error: "Failed to send password reset email" },
235
- { status: 500 }
236
- );
237
- }
238
- }
239
-
@@ -1,83 +0,0 @@
1
- // file_description: API route for validating password reset token without resetting password
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { get_hazo_connect_instance } from "../../../../lib/hazo_connect_instance.server";
5
- import { validate_password_reset_token } from "../../../../lib/services/password_reset_service";
6
- import { create_app_logger } from "../../../../lib/app_logger";
7
- import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
8
-
9
- // section: route_config
10
- export const dynamic = 'force-dynamic';
11
-
12
- // section: api_handler
13
- export async function GET(request: NextRequest) {
14
- const logger = create_app_logger();
15
-
16
- try {
17
- const { searchParams } = new URL(request.url);
18
- const token = searchParams.get("token");
19
-
20
- // Validate input
21
- if (!token) {
22
- logger.warn("password_reset_token_validation_failed", {
23
- filename: get_filename(),
24
- line_number: get_line_number(),
25
- error: "Token is required",
26
- });
27
-
28
- return NextResponse.json(
29
- { success: false, error: "Token is required" },
30
- { status: 400 }
31
- );
32
- }
33
-
34
- // Get singleton hazo_connect instance (reuses same connection across all routes)
35
- const hazoConnect = get_hazo_connect_instance();
36
-
37
- // Validate token using the password reset service
38
- const result = await validate_password_reset_token(hazoConnect, {
39
- token,
40
- });
41
-
42
- if (!result.success) {
43
- logger.warn("password_reset_token_validation_failed", {
44
- filename: get_filename(),
45
- line_number: get_line_number(),
46
- error: result.error,
47
- });
48
-
49
- return NextResponse.json(
50
- {
51
- success: false,
52
- error: result.error || "Invalid or expired reset token",
53
- },
54
- { status: 400 }
55
- );
56
- }
57
-
58
- return NextResponse.json(
59
- {
60
- success: true,
61
- },
62
- { status: 200 }
63
- );
64
- } catch (error) {
65
- const error_message =
66
- error instanceof Error ? error.message : "Unknown error";
67
-
68
- logger.error("password_reset_token_validation_error", {
69
- filename: get_filename(),
70
- line_number: get_line_number(),
71
- error: error_message,
72
- });
73
-
74
- return NextResponse.json(
75
- {
76
- success: false,
77
- error: "An error occurred while validating the reset token",
78
- },
79
- { status: 500 }
80
- );
81
- }
82
- }
83
-