hazo_auth 1.4.2 → 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 (320) hide show
  1. package/SETUP_CHECKLIST.md +708 -0
  2. package/dist/app/api/hazo_auth/change_password/route.d.ts +8 -0
  3. package/dist/app/api/hazo_auth/change_password/route.d.ts.map +1 -0
  4. package/dist/app/api/hazo_auth/change_password/route.js +98 -0
  5. package/dist/app/api/hazo_auth/forgot_password/route.d.ts +8 -0
  6. package/dist/app/api/hazo_auth/forgot_password/route.d.ts.map +1 -0
  7. package/dist/app/api/hazo_auth/forgot_password/route.js +78 -0
  8. package/dist/app/api/hazo_auth/get_auth/route.d.ts +10 -0
  9. package/dist/app/api/hazo_auth/get_auth/route.d.ts.map +1 -0
  10. package/dist/app/api/hazo_auth/get_auth/route.js +63 -0
  11. package/dist/app/api/hazo_auth/invalidate_cache/route.d.ts +14 -0
  12. package/dist/app/api/hazo_auth/invalidate_cache/route.d.ts.map +1 -0
  13. package/dist/app/api/hazo_auth/invalidate_cache/route.js +96 -0
  14. package/dist/app/api/hazo_auth/library_photos/route.d.ts +13 -0
  15. package/dist/app/api/hazo_auth/library_photos/route.d.ts.map +1 -0
  16. package/dist/app/api/hazo_auth/library_photos/route.js +55 -0
  17. package/dist/app/api/hazo_auth/login/route.d.ts +12 -0
  18. package/dist/app/api/hazo_auth/login/route.d.ts.map +1 -0
  19. package/dist/app/api/hazo_auth/login/route.js +140 -0
  20. package/dist/app/api/hazo_auth/logout/route.d.ts +8 -0
  21. package/dist/app/api/hazo_auth/logout/route.d.ts.map +1 -0
  22. package/dist/app/api/hazo_auth/logout/route.js +71 -0
  23. package/dist/app/api/hazo_auth/me/route.d.ts +3 -0
  24. package/dist/app/api/hazo_auth/me/route.d.ts.map +1 -0
  25. package/dist/app/api/hazo_auth/me/route.js +34 -0
  26. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts +7 -0
  27. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts.map +1 -0
  28. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.js +43 -0
  29. package/dist/app/api/hazo_auth/register/route.d.ts +9 -0
  30. package/dist/app/api/hazo_auth/register/route.d.ts.map +1 -0
  31. package/dist/app/api/hazo_auth/register/route.js +80 -0
  32. package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts +8 -0
  33. package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts.map +1 -0
  34. package/dist/app/api/hazo_auth/remove_profile_picture/route.js +64 -0
  35. package/dist/app/api/hazo_auth/resend_verification/route.d.ts +8 -0
  36. package/dist/app/api/hazo_auth/resend_verification/route.d.ts.map +1 -0
  37. package/dist/app/api/hazo_auth/resend_verification/route.js +79 -0
  38. package/dist/app/api/hazo_auth/reset_password/route.d.ts +8 -0
  39. package/dist/app/api/hazo_auth/reset_password/route.d.ts.map +1 -0
  40. package/dist/app/api/hazo_auth/reset_password/route.js +76 -0
  41. package/dist/app/api/hazo_auth/update_user/route.d.ts +9 -0
  42. package/dist/app/api/hazo_auth/update_user/route.d.ts.map +1 -0
  43. package/dist/app/api/hazo_auth/update_user/route.js +95 -0
  44. package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts +9 -0
  45. package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts.map +1 -0
  46. package/dist/app/api/hazo_auth/upload_profile_picture/route.js +204 -0
  47. package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts +6 -0
  48. package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts.map +1 -0
  49. package/dist/app/api/hazo_auth/validate_reset_token/route.js +58 -0
  50. package/dist/app/api/hazo_auth/verify_email/route.d.ts +11 -0
  51. package/dist/app/api/hazo_auth/verify_email/route.d.ts.map +1 -0
  52. package/dist/app/api/hazo_auth/verify_email/route.js +63 -0
  53. package/dist/cli/generate.d.ts +2 -0
  54. package/dist/cli/generate.d.ts.map +1 -0
  55. package/dist/cli/generate.js +117 -0
  56. package/dist/cli/index.d.ts +3 -0
  57. package/dist/cli/index.d.ts.map +1 -0
  58. package/dist/cli/index.js +120 -0
  59. package/dist/cli/validate.d.ts +15 -0
  60. package/dist/cli/validate.d.ts.map +1 -0
  61. package/dist/cli/validate.js +509 -0
  62. package/dist/components/ui/card.d.ts +9 -0
  63. package/dist/components/ui/card.d.ts.map +1 -0
  64. package/dist/components/ui/card.js +45 -0
  65. package/dist/hooks/use-mobile.d.ts.map +1 -1
  66. package/dist/hooks/use-mobile.js +17 -3
  67. package/dist/server/routes/change_password.d.ts +2 -0
  68. package/dist/server/routes/change_password.d.ts.map +1 -0
  69. package/dist/server/routes/change_password.js +2 -0
  70. package/dist/server/routes/forgot_password.d.ts +2 -0
  71. package/dist/server/routes/forgot_password.d.ts.map +1 -0
  72. package/dist/server/routes/forgot_password.js +2 -0
  73. package/dist/server/routes/get_auth.d.ts +2 -0
  74. package/dist/server/routes/get_auth.d.ts.map +1 -0
  75. package/dist/server/routes/get_auth.js +2 -0
  76. package/dist/server/routes/index.d.ts +18 -0
  77. package/dist/server/routes/index.d.ts.map +1 -0
  78. package/dist/server/routes/index.js +24 -0
  79. package/dist/server/routes/invalidate_cache.d.ts +2 -0
  80. package/dist/server/routes/invalidate_cache.d.ts.map +1 -0
  81. package/dist/server/routes/invalidate_cache.js +2 -0
  82. package/dist/server/routes/library_photos.d.ts +2 -0
  83. package/dist/server/routes/library_photos.d.ts.map +1 -0
  84. package/dist/server/routes/library_photos.js +2 -0
  85. package/dist/server/routes/login.d.ts +2 -0
  86. package/dist/server/routes/login.d.ts.map +1 -0
  87. package/dist/server/routes/login.js +2 -0
  88. package/dist/server/routes/logout.d.ts +2 -0
  89. package/dist/server/routes/logout.d.ts.map +1 -0
  90. package/dist/server/routes/logout.js +2 -0
  91. package/dist/server/routes/me.d.ts +2 -0
  92. package/dist/server/routes/me.d.ts.map +1 -0
  93. package/dist/server/routes/me.js +2 -0
  94. package/dist/server/routes/profile_picture_filename.d.ts +2 -0
  95. package/dist/server/routes/profile_picture_filename.d.ts.map +1 -0
  96. package/dist/server/routes/profile_picture_filename.js +3 -0
  97. package/dist/server/routes/register.d.ts +2 -0
  98. package/dist/server/routes/register.d.ts.map +1 -0
  99. package/dist/server/routes/register.js +2 -0
  100. package/dist/server/routes/remove_profile_picture.d.ts +2 -0
  101. package/dist/server/routes/remove_profile_picture.d.ts.map +1 -0
  102. package/dist/server/routes/remove_profile_picture.js +2 -0
  103. package/dist/server/routes/resend_verification.d.ts +2 -0
  104. package/dist/server/routes/resend_verification.d.ts.map +1 -0
  105. package/dist/server/routes/resend_verification.js +2 -0
  106. package/dist/server/routes/reset_password.d.ts +2 -0
  107. package/dist/server/routes/reset_password.d.ts.map +1 -0
  108. package/dist/server/routes/reset_password.js +2 -0
  109. package/dist/server/routes/update_user.d.ts +2 -0
  110. package/dist/server/routes/update_user.d.ts.map +1 -0
  111. package/dist/server/routes/update_user.js +2 -0
  112. package/dist/server/routes/upload_profile_picture.d.ts +2 -0
  113. package/dist/server/routes/upload_profile_picture.d.ts.map +1 -0
  114. package/dist/server/routes/upload_profile_picture.js +2 -0
  115. package/dist/server/routes/validate_reset_token.d.ts +2 -0
  116. package/dist/server/routes/validate_reset_token.d.ts.map +1 -0
  117. package/dist/server/routes/validate_reset_token.js +2 -0
  118. package/dist/server/routes/verify_email.d.ts +2 -0
  119. package/dist/server/routes/verify_email.d.ts.map +1 -0
  120. package/dist/server/routes/verify_email.js +2 -0
  121. package/package.json +12 -17
  122. package/components.json +0 -22
  123. package/instrumentation.ts +0 -32
  124. package/migrations/001_add_token_type_to_refresh_tokens.sql +0 -14
  125. package/migrations/002_add_name_to_hazo_users.sql +0 -7
  126. package/migrations/003_add_url_on_logon_to_hazo_users.sql +0 -8
  127. package/next.config.mjs +0 -67
  128. package/postcss.config.mjs +0 -8
  129. package/public/file.svg +0 -1
  130. package/public/globe.svg +0 -1
  131. package/public/next.svg +0 -1
  132. package/public/vercel.svg +0 -1
  133. package/public/window.svg +0 -1
  134. package/scripts/apply_migration.ts +0 -118
  135. package/scripts/init_users.ts +0 -378
  136. package/src/app/api/hazo_auth/auth/upload_profile_picture/route.ts +0 -268
  137. package/src/app/api/hazo_auth/change_password/route.ts +0 -132
  138. package/src/app/api/hazo_auth/forgot_password/route.ts +0 -107
  139. package/src/app/api/hazo_auth/get_auth/route.ts +0 -89
  140. package/src/app/api/hazo_auth/invalidate_cache/route.ts +0 -139
  141. package/src/app/api/hazo_auth/library_photos/route.ts +0 -73
  142. package/src/app/api/hazo_auth/login/route.ts +0 -181
  143. package/src/app/api/hazo_auth/logout/route.ts +0 -89
  144. package/src/app/api/hazo_auth/me/route.ts +0 -47
  145. package/src/app/api/hazo_auth/profile_picture/[filename]/route.ts +0 -67
  146. package/src/app/api/hazo_auth/register/route.ts +0 -109
  147. package/src/app/api/hazo_auth/remove_profile_picture/route.ts +0 -86
  148. package/src/app/api/hazo_auth/resend_verification/route.ts +0 -108
  149. package/src/app/api/hazo_auth/reset_password/route.ts +0 -107
  150. package/src/app/api/hazo_auth/update_user/route.ts +0 -126
  151. package/src/app/api/hazo_auth/upload_profile_picture/route.ts +0 -268
  152. package/src/app/api/hazo_auth/user_management/permissions/route.ts +0 -367
  153. package/src/app/api/hazo_auth/user_management/roles/route.ts +0 -442
  154. package/src/app/api/hazo_auth/user_management/users/roles/route.ts +0 -367
  155. package/src/app/api/hazo_auth/user_management/users/route.ts +0 -239
  156. package/src/app/api/hazo_auth/validate_reset_token/route.ts +0 -83
  157. package/src/app/api/hazo_auth/verify_email/route.ts +0 -88
  158. package/src/app/api/migrations/apply/route.ts +0 -91
  159. package/src/app/favicon.ico +0 -0
  160. package/src/app/fonts/GeistMonoVF.woff +0 -0
  161. package/src/app/fonts/GeistVF.woff +0 -0
  162. package/src/app/globals.css +0 -89
  163. package/src/app/hazo_auth/forgot_password/forgot_password_page_client.tsx +0 -60
  164. package/src/app/hazo_auth/forgot_password/page.tsx +0 -24
  165. package/src/app/hazo_auth/login/login_page_client.tsx +0 -86
  166. package/src/app/hazo_auth/login/page.tsx +0 -38
  167. package/src/app/hazo_auth/my_settings/my_settings_page_client.tsx +0 -120
  168. package/src/app/hazo_auth/my_settings/page.tsx +0 -40
  169. package/src/app/hazo_auth/register/page.tsx +0 -36
  170. package/src/app/hazo_auth/register/register_page_client.tsx +0 -81
  171. package/src/app/hazo_auth/reset_password/page.tsx +0 -29
  172. package/src/app/hazo_auth/reset_password/reset_password_page_client.tsx +0 -81
  173. package/src/app/hazo_auth/user_management/page.tsx +0 -14
  174. package/src/app/hazo_auth/user_management/user_management_page_client.tsx +0 -16
  175. package/src/app/hazo_auth/verify_email/page.tsx +0 -24
  176. package/src/app/hazo_auth/verify_email/verify_email_page_client.tsx +0 -60
  177. package/src/app/hazo_connect/api/sqlite/data/route.ts +0 -203
  178. package/src/app/hazo_connect/api/sqlite/schema/route.ts +0 -45
  179. package/src/app/hazo_connect/api/sqlite/tables/route.ts +0 -36
  180. package/src/app/hazo_connect/sqlite_admin/page.tsx +0 -51
  181. package/src/app/hazo_connect/sqlite_admin/sqlite-admin-client.tsx +0 -984
  182. package/src/app/layout.tsx +0 -43
  183. package/src/app/page.tsx +0 -170
  184. package/src/components/index.ts +0 -7
  185. package/src/components/layouts/email_verification/config/email_verification_field_config.ts +0 -86
  186. package/src/components/layouts/email_verification/hooks/use_email_verification.ts +0 -297
  187. package/src/components/layouts/email_verification/index.tsx +0 -297
  188. package/src/components/layouts/forgot_password/config/forgot_password_field_config.ts +0 -58
  189. package/src/components/layouts/forgot_password/hooks/use_forgot_password_form.ts +0 -179
  190. package/src/components/layouts/forgot_password/index.tsx +0 -168
  191. package/src/components/layouts/index.ts +0 -26
  192. package/src/components/layouts/login/config/login_field_config.ts +0 -67
  193. package/src/components/layouts/login/hooks/use_login_form.ts +0 -286
  194. package/src/components/layouts/login/index.tsx +0 -252
  195. package/src/components/layouts/my_settings/components/editable_field.tsx +0 -177
  196. package/src/components/layouts/my_settings/components/password_change_dialog.tsx +0 -301
  197. package/src/components/layouts/my_settings/components/profile_picture_dialog.tsx +0 -385
  198. package/src/components/layouts/my_settings/components/profile_picture_display.tsx +0 -66
  199. package/src/components/layouts/my_settings/components/profile_picture_gravatar_tab.tsx +0 -143
  200. package/src/components/layouts/my_settings/components/profile_picture_library_tab.tsx +0 -311
  201. package/src/components/layouts/my_settings/components/profile_picture_upload_tab.tsx +0 -341
  202. package/src/components/layouts/my_settings/config/my_settings_field_config.ts +0 -61
  203. package/src/components/layouts/my_settings/hooks/use_my_settings.ts +0 -458
  204. package/src/components/layouts/my_settings/index.tsx +0 -351
  205. package/src/components/layouts/register/config/register_field_config.ts +0 -101
  206. package/src/components/layouts/register/hooks/use_register_form.ts +0 -275
  207. package/src/components/layouts/register/index.tsx +0 -226
  208. package/src/components/layouts/reset_password/config/reset_password_field_config.ts +0 -86
  209. package/src/components/layouts/reset_password/hooks/use_reset_password_form.ts +0 -276
  210. package/src/components/layouts/reset_password/index.tsx +0 -294
  211. package/src/components/layouts/shared/components/already_logged_in_guard.tsx +0 -95
  212. package/src/components/layouts/shared/components/auth_page_shell.tsx +0 -36
  213. package/src/components/layouts/shared/components/field_error_message.tsx +0 -29
  214. package/src/components/layouts/shared/components/form_action_buttons.tsx +0 -64
  215. package/src/components/layouts/shared/components/form_field_wrapper.tsx +0 -44
  216. package/src/components/layouts/shared/components/form_header.tsx +0 -36
  217. package/src/components/layouts/shared/components/logout_button.tsx +0 -76
  218. package/src/components/layouts/shared/components/password_field.tsx +0 -72
  219. package/src/components/layouts/shared/components/profile_pic_menu.tsx +0 -321
  220. package/src/components/layouts/shared/components/profile_pic_menu_wrapper.tsx +0 -40
  221. package/src/components/layouts/shared/components/sidebar_layout_wrapper.tsx +0 -214
  222. package/src/components/layouts/shared/components/standalone_layout_wrapper.tsx +0 -53
  223. package/src/components/layouts/shared/components/two_column_auth_layout.tsx +0 -44
  224. package/src/components/layouts/shared/components/unauthorized_guard.tsx +0 -78
  225. package/src/components/layouts/shared/components/visual_panel.tsx +0 -41
  226. package/src/components/layouts/shared/config/layout_customization.ts +0 -95
  227. package/src/components/layouts/shared/data/layout_data_client.ts +0 -19
  228. package/src/components/layouts/shared/hooks/use_auth_status.ts +0 -103
  229. package/src/components/layouts/shared/hooks/use_hazo_auth.ts +0 -158
  230. package/src/components/layouts/shared/index.ts +0 -34
  231. package/src/components/layouts/shared/utils/ip_address.ts +0 -37
  232. package/src/components/layouts/shared/utils/validation.ts +0 -66
  233. package/src/components/layouts/user_management/components/roles_matrix.tsx +0 -607
  234. package/src/components/layouts/user_management/index.tsx +0 -1295
  235. package/src/components/ui/alert-dialog.tsx +0 -141
  236. package/src/components/ui/avatar.tsx +0 -50
  237. package/src/components/ui/button.tsx +0 -57
  238. package/src/components/ui/checkbox.tsx +0 -30
  239. package/src/components/ui/dialog.tsx +0 -122
  240. package/src/components/ui/dropdown-menu.tsx +0 -201
  241. package/src/components/ui/hazo_ui_tooltip.tsx +0 -67
  242. package/src/components/ui/index.ts +0 -22
  243. package/src/components/ui/input.tsx +0 -22
  244. package/src/components/ui/label.tsx +0 -26
  245. package/src/components/ui/separator.tsx +0 -31
  246. package/src/components/ui/sheet.tsx +0 -139
  247. package/src/components/ui/sidebar.tsx +0 -773
  248. package/src/components/ui/skeleton.tsx +0 -15
  249. package/src/components/ui/sonner.tsx +0 -31
  250. package/src/components/ui/switch.tsx +0 -29
  251. package/src/components/ui/table.tsx +0 -120
  252. package/src/components/ui/tabs.tsx +0 -55
  253. package/src/components/ui/tooltip.tsx +0 -32
  254. package/src/components/ui/vertical-tabs.tsx +0 -59
  255. package/src/hooks/use-mobile.tsx +0 -19
  256. package/src/index.ts +0 -7
  257. package/src/lib/already_logged_in_config.server.ts +0 -46
  258. package/src/lib/app_logger.ts +0 -24
  259. package/src/lib/auth/auth_cache.ts +0 -220
  260. package/src/lib/auth/auth_rate_limiter.ts +0 -121
  261. package/src/lib/auth/auth_types.ts +0 -65
  262. package/src/lib/auth/auth_utils.server.ts +0 -196
  263. package/src/lib/auth/hazo_get_auth.server.ts +0 -333
  264. package/src/lib/auth/index.ts +0 -23
  265. package/src/lib/auth/server_auth.ts +0 -88
  266. package/src/lib/auth_utility_config.server.ts +0 -136
  267. package/src/lib/config/config_loader.server.ts +0 -164
  268. package/src/lib/email_verification_config.server.ts +0 -32
  269. package/src/lib/file_types_config.server.ts +0 -25
  270. package/src/lib/forgot_password_config.server.ts +0 -32
  271. package/src/lib/hazo_connect_instance.server.ts +0 -101
  272. package/src/lib/hazo_connect_setup.server.ts +0 -194
  273. package/src/lib/hazo_connect_setup.ts +0 -54
  274. package/src/lib/index.ts +0 -44
  275. package/src/lib/login_config.server.ts +0 -71
  276. package/src/lib/messages_config.server.ts +0 -45
  277. package/src/lib/migrations/apply_migration.ts +0 -105
  278. package/src/lib/my_settings_config.server.ts +0 -135
  279. package/src/lib/password_requirements_config.server.ts +0 -39
  280. package/src/lib/profile_pic_menu_config.server.ts +0 -138
  281. package/src/lib/profile_picture_config.server.ts +0 -56
  282. package/src/lib/register_config.server.ts +0 -73
  283. package/src/lib/reset_password_config.server.ts +0 -75
  284. package/src/lib/services/email_service.ts +0 -581
  285. package/src/lib/services/email_verification_service.ts +0 -270
  286. package/src/lib/services/index.ts +0 -15
  287. package/src/lib/services/login_service.ts +0 -134
  288. package/src/lib/services/password_change_service.ts +0 -154
  289. package/src/lib/services/password_reset_service.ts +0 -405
  290. package/src/lib/services/profile_picture_remove_service.ts +0 -120
  291. package/src/lib/services/profile_picture_service.ts +0 -215
  292. package/src/lib/services/profile_picture_source_mapper.ts +0 -62
  293. package/src/lib/services/registration_service.ts +0 -184
  294. package/src/lib/services/token_service.ts +0 -240
  295. package/src/lib/services/user_profiles_service.ts +0 -143
  296. package/src/lib/services/user_update_service.ts +0 -141
  297. package/src/lib/ui_shell_config.server.ts +0 -73
  298. package/src/lib/ui_sizes_config.server.ts +0 -37
  299. package/src/lib/user_fields_config.server.ts +0 -31
  300. package/src/lib/user_management_config.server.ts +0 -39
  301. package/src/lib/utils/api_route_helpers.ts +0 -60
  302. package/src/lib/utils/error_sanitizer.ts +0 -75
  303. package/src/lib/utils.ts +0 -11
  304. package/src/middleware.ts +0 -94
  305. package/src/routes/index.ts +0 -34
  306. package/src/server/config/config_loader.ts +0 -496
  307. package/src/server/index.ts +0 -38
  308. package/src/server/logging/logger_service.ts +0 -56
  309. package/src/server/routes/root_router.ts +0 -16
  310. package/src/server/server.ts +0 -28
  311. package/src/server/types/app_types.ts +0 -74
  312. package/src/server/types/express.d.ts +0 -16
  313. package/src/stories/email_verification_layout.stories.tsx +0 -137
  314. package/src/stories/forgot_password_layout.stories.tsx +0 -85
  315. package/src/stories/login_layout.stories.tsx +0 -85
  316. package/src/stories/project_overview.stories.tsx +0 -33
  317. package/src/stories/register_layout.stories.tsx +0 -107
  318. package/tailwind.config.ts +0 -77
  319. package/tsconfig.build.json +0 -36
  320. package/tsconfig.json +0 -28
@@ -1,132 +0,0 @@
1
- // file_description: API route for changing user 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 { create_app_logger } from "../../../../lib/app_logger";
6
- import { change_password } from "../../../../lib/services/password_change_service";
7
- import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
8
- import { require_auth } from "../../../../lib/auth/auth_utils.server";
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: api_handler
13
- export async function POST(request: NextRequest) {
14
- const logger = create_app_logger();
15
-
16
- try {
17
- // Use centralized auth check
18
- let user_id: string;
19
- try {
20
- const user = await require_auth(request);
21
- user_id = user.user_id;
22
- } catch (error) {
23
- if (error instanceof Error && error.message === "Authentication required") {
24
- logger.warn("password_change_authentication_failed", {
25
- filename: get_filename(),
26
- line_number: get_line_number(),
27
- error: "User not authenticated",
28
- });
29
-
30
- return NextResponse.json(
31
- { error: "Authentication required" },
32
- { status: 401 }
33
- );
34
- }
35
- throw error;
36
- }
37
-
38
- const body = await request.json();
39
- const { current_password, new_password } = body;
40
-
41
- // Validate input
42
- if (!current_password || !new_password) {
43
- logger.warn("password_change_validation_failed", {
44
- filename: get_filename(),
45
- line_number: get_line_number(),
46
- error: "Missing required fields",
47
- has_current_password: !!current_password,
48
- has_new_password: !!new_password,
49
- });
50
-
51
- return NextResponse.json(
52
- { error: "Current password and new password are required" },
53
- { status: 400 }
54
- );
55
- }
56
-
57
- // Get singleton hazo_connect instance
58
- const hazoConnect = get_hazo_connect_instance();
59
-
60
- // Change password
61
- const result = await change_password(hazoConnect, user_id, {
62
- current_password,
63
- new_password,
64
- });
65
-
66
- if (!result.success) {
67
- logger.warn("password_change_failed", {
68
- filename: get_filename(),
69
- line_number: get_line_number(),
70
- error: result.error,
71
- user_id,
72
- });
73
-
74
- return NextResponse.json(
75
- { error: result.error || "Failed to change password" },
76
- { status: 400 }
77
- );
78
- }
79
-
80
- // Invalidate user cache after password change
81
- try {
82
- const config = get_auth_utility_config();
83
- const cache = get_auth_cache(
84
- config.cache_max_users,
85
- config.cache_ttl_minutes,
86
- config.cache_max_age_minutes,
87
- );
88
- cache.invalidate_user(user_id);
89
- } catch (cache_error) {
90
- // Log but don't fail password change if cache invalidation fails
91
- const cache_error_message =
92
- cache_error instanceof Error ? cache_error.message : "Unknown error";
93
- logger.warn("password_change_cache_invalidation_failed", {
94
- filename: get_filename(),
95
- line_number: get_line_number(),
96
- user_id,
97
- error: cache_error_message,
98
- });
99
- }
100
-
101
- logger.info("password_change_successful", {
102
- filename: get_filename(),
103
- line_number: get_line_number(),
104
- user_id,
105
- });
106
-
107
- return NextResponse.json(
108
- {
109
- success: true,
110
- message: "Password changed successfully",
111
- },
112
- { status: 200 }
113
- );
114
- } catch (error) {
115
- const error_message =
116
- error instanceof Error ? error.message : "Unknown error";
117
- const error_stack = error instanceof Error ? error.stack : undefined;
118
-
119
- logger.error("password_change_error", {
120
- filename: get_filename(),
121
- line_number: get_line_number(),
122
- error_message,
123
- error_stack,
124
- });
125
-
126
- return NextResponse.json(
127
- { error: "Failed to change password. Please try again." },
128
- { status: 500 }
129
- );
130
- }
131
- }
132
-
@@ -1,107 +0,0 @@
1
- // file_description: API route for password reset requests using hazo_connect
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 { request_password_reset } from "../../../../lib/services/password_reset_service";
7
- import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
8
-
9
- // section: api_handler
10
- export async function POST(request: NextRequest) {
11
- const logger = create_app_logger();
12
-
13
- try {
14
- const body = await request.json();
15
- const { email } = body;
16
-
17
- // Validate input
18
- if (!email) {
19
- logger.warn("password_reset_validation_failed", {
20
- filename: get_filename(),
21
- line_number: get_line_number(),
22
- email: email || "missing",
23
- });
24
-
25
- return NextResponse.json(
26
- { error: "Email is required" },
27
- { status: 400 }
28
- );
29
- }
30
-
31
- // Validate email format
32
- const email_pattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
33
- if (!email_pattern.test(email)) {
34
- logger.warn("password_reset_invalid_email", {
35
- filename: get_filename(),
36
- line_number: get_line_number(),
37
- email,
38
- });
39
-
40
- return NextResponse.json(
41
- { error: "Invalid email address format" },
42
- { status: 400 }
43
- );
44
- }
45
-
46
- // Get singleton hazo_connect instance (reuses same connection across all routes)
47
- const hazoConnect = get_hazo_connect_instance();
48
-
49
- // Request password reset using the password reset service
50
- const result = await request_password_reset(hazoConnect, {
51
- email,
52
- });
53
-
54
- if (!result.success) {
55
- logger.warn("password_reset_failed", {
56
- filename: get_filename(),
57
- line_number: get_line_number(),
58
- email,
59
- error: result.error,
60
- });
61
-
62
- // Still return 200 OK to prevent email enumeration attacks
63
- return NextResponse.json(
64
- {
65
- success: true,
66
- message: "If an account with that email exists, a password reset link has been sent.",
67
- },
68
- { status: 200 }
69
- );
70
- }
71
-
72
- logger.info("password_reset_requested", {
73
- filename: get_filename(),
74
- line_number: get_line_number(),
75
- email,
76
- });
77
-
78
- // Always return success to prevent email enumeration attacks
79
- return NextResponse.json(
80
- {
81
- success: true,
82
- message: "If an account with that email exists, a password reset link has been sent.",
83
- },
84
- { status: 200 }
85
- );
86
- } catch (error) {
87
- const error_message = error instanceof Error ? error.message : "Unknown error";
88
- const error_stack = error instanceof Error ? error.stack : undefined;
89
-
90
- logger.error("password_reset_error", {
91
- filename: get_filename(),
92
- line_number: get_line_number(),
93
- error_message,
94
- error_stack,
95
- });
96
-
97
- // Still return 200 OK to prevent email enumeration attacks
98
- return NextResponse.json(
99
- {
100
- success: true,
101
- message: "If an account with that email exists, a password reset link has been sent.",
102
- },
103
- { status: 200 }
104
- );
105
- }
106
- }
107
-
@@ -1,89 +0,0 @@
1
- // file_description: API route for hazo_get_auth utility (client-side calls)
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { hazo_get_auth } from "../../../../lib/auth/hazo_get_auth.server";
5
- import { PermissionError } from "../../../../lib/auth/auth_types";
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
- /**
14
- * POST - Get authentication status and permissions
15
- * Body: { required_permissions?: string[], strict?: boolean }
16
- */
17
- export async function POST(request: NextRequest) {
18
- const logger = create_app_logger();
19
-
20
- try {
21
- const body = await request.json();
22
- const { required_permissions, strict } = body;
23
-
24
- // Validate required_permissions if provided
25
- if (
26
- required_permissions !== undefined &&
27
- (!Array.isArray(required_permissions) ||
28
- !required_permissions.every((p) => typeof p === "string"))
29
- ) {
30
- return NextResponse.json(
31
- { error: "required_permissions must be an array of strings" },
32
- { status: 400 },
33
- );
34
- }
35
-
36
- // Validate strict if provided
37
- if (strict !== undefined && typeof strict !== "boolean") {
38
- return NextResponse.json(
39
- { error: "strict must be a boolean" },
40
- { status: 400 },
41
- );
42
- }
43
-
44
- // Call hazo_get_auth
45
- const result = await hazo_get_auth(request, {
46
- required_permissions,
47
- strict,
48
- });
49
-
50
- return NextResponse.json(result, { status: 200 });
51
- } catch (error) {
52
- // Handle PermissionError (strict mode)
53
- if (error instanceof PermissionError) {
54
- logger.warn("auth_utility_permission_error", {
55
- filename: get_filename(),
56
- line_number: get_line_number(),
57
- missing_permissions: error.missing_permissions,
58
- required_permissions: error.required_permissions,
59
- });
60
-
61
- return NextResponse.json(
62
- {
63
- error: "Permission denied",
64
- missing_permissions: error.missing_permissions,
65
- user_friendly_message: error.user_friendly_message,
66
- },
67
- { status: 403 },
68
- );
69
- }
70
-
71
- // Handle other errors
72
- const error_message =
73
- error instanceof Error ? error.message : "Unknown error";
74
- const error_stack = error instanceof Error ? error.stack : undefined;
75
-
76
- logger.error("auth_utility_api_error", {
77
- filename: get_filename(),
78
- line_number: get_line_number(),
79
- error_message,
80
- error_stack,
81
- });
82
-
83
- return NextResponse.json(
84
- { error: error_message },
85
- { status: 500 },
86
- );
87
- }
88
- }
89
-
@@ -1,139 +0,0 @@
1
- // file_description: API route for manual cache invalidation (admin endpoint)
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { get_auth_cache } from "../../../../lib/auth/auth_cache";
5
- import { get_auth_utility_config } from "../../../../lib/auth_utility_config.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 { hazo_get_auth } from "../../../../lib/auth/hazo_get_auth.server";
9
-
10
- // section: route_config
11
- export const dynamic = "force-dynamic";
12
-
13
- // section: api_handler
14
- /**
15
- * POST - Manually invalidate auth cache
16
- * Body: { user_id?: string, role_ids?: number[], invalidate_all?: boolean }
17
- * Requires admin permission (checked via hazo_get_auth)
18
- */
19
- export async function POST(request: NextRequest) {
20
- const logger = create_app_logger();
21
-
22
- try {
23
- // Check authentication and admin permission
24
- const auth_result = await hazo_get_auth(request, {
25
- required_permissions: ["admin_user_management"], // Require admin permission
26
- strict: true, // Throw error if not authorized
27
- });
28
-
29
- if (!auth_result.authenticated) {
30
- return NextResponse.json(
31
- { error: "Authentication required" },
32
- { status: 401 },
33
- );
34
- }
35
-
36
- const body = await request.json();
37
- const { user_id, role_ids, invalidate_all } = body;
38
-
39
- // Validate input
40
- if (invalidate_all !== undefined && typeof invalidate_all !== "boolean") {
41
- return NextResponse.json(
42
- { error: "invalidate_all must be a boolean" },
43
- { status: 400 },
44
- );
45
- }
46
-
47
- if (user_id !== undefined && typeof user_id !== "string") {
48
- return NextResponse.json(
49
- { error: "user_id must be a string" },
50
- { status: 400 },
51
- );
52
- }
53
-
54
- if (
55
- role_ids !== undefined &&
56
- (!Array.isArray(role_ids) ||
57
- !role_ids.every((id) => typeof id === "number"))
58
- ) {
59
- return NextResponse.json(
60
- { error: "role_ids must be an array of numbers" },
61
- { status: 400 },
62
- );
63
- }
64
-
65
- const config = get_auth_utility_config();
66
- const cache = get_auth_cache(
67
- config.cache_max_users,
68
- config.cache_ttl_minutes,
69
- config.cache_max_age_minutes,
70
- );
71
-
72
- // Perform invalidation
73
- if (invalidate_all === true) {
74
- cache.invalidate_all();
75
- logger.info("auth_cache_invalidated_all", {
76
- filename: get_filename(),
77
- line_number: get_line_number(),
78
- user_id: auth_result.user.id,
79
- });
80
- } else if (user_id) {
81
- cache.invalidate_user(user_id);
82
- logger.info("auth_cache_invalidated_user", {
83
- filename: get_filename(),
84
- line_number: get_line_number(),
85
- invalidated_user_id: user_id,
86
- admin_user_id: auth_result.user.id,
87
- });
88
- } else if (role_ids && role_ids.length > 0) {
89
- cache.invalidate_by_roles(role_ids);
90
- logger.info("auth_cache_invalidated_roles", {
91
- filename: get_filename(),
92
- line_number: get_line_number(),
93
- role_ids,
94
- admin_user_id: auth_result.user.id,
95
- });
96
- } else {
97
- return NextResponse.json(
98
- {
99
- error:
100
- "Must provide user_id, role_ids, or invalidate_all=true",
101
- },
102
- { status: 400 },
103
- );
104
- }
105
-
106
- return NextResponse.json(
107
- {
108
- success: true,
109
- message: "Cache invalidated successfully",
110
- },
111
- { status: 200 },
112
- );
113
- } catch (error) {
114
- // Handle PermissionError (strict mode)
115
- if (error instanceof Error && error.name === "PermissionError") {
116
- return NextResponse.json(
117
- { error: "Permission denied. Admin access required." },
118
- { status: 403 },
119
- );
120
- }
121
-
122
- const error_message =
123
- error instanceof Error ? error.message : "Unknown error";
124
- const error_stack = error instanceof Error ? error.stack : undefined;
125
-
126
- logger.error("auth_cache_invalidation_error", {
127
- filename: get_filename(),
128
- line_number: get_line_number(),
129
- error_message,
130
- error_stack,
131
- });
132
-
133
- return NextResponse.json(
134
- { error: "Failed to invalidate cache" },
135
- { status: 500 },
136
- );
137
- }
138
- }
139
-
@@ -1,73 +0,0 @@
1
- // file_description: API route for listing library photo categories and photos in categories
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { get_library_categories, get_library_photos } from "../../../../lib/services/profile_picture_service";
5
- import { create_app_logger } from "../../../../lib/app_logger";
6
- import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
7
-
8
- // section: route_config
9
- export const dynamic = 'force-dynamic';
10
-
11
- // section: api_handler
12
- export async function GET(request: NextRequest) {
13
- const logger = create_app_logger();
14
-
15
- try {
16
- const { searchParams } = new URL(request.url);
17
- const category = searchParams.get("category");
18
-
19
- if (category) {
20
- // Return photos in the specified category
21
- const photos = get_library_photos(category);
22
-
23
- logger.info("library_photos_category_requested", {
24
- filename: get_filename(),
25
- line_number: get_line_number(),
26
- category,
27
- photoCount: photos.length,
28
- });
29
-
30
- return NextResponse.json(
31
- {
32
- success: true,
33
- category,
34
- photos,
35
- },
36
- { status: 200 }
37
- );
38
- } else {
39
- // Return list of categories
40
- const categories = get_library_categories();
41
-
42
- logger.info("library_categories_requested", {
43
- filename: get_filename(),
44
- line_number: get_line_number(),
45
- categoryCount: categories.length,
46
- });
47
-
48
- return NextResponse.json(
49
- {
50
- success: true,
51
- categories,
52
- },
53
- { status: 200 }
54
- );
55
- }
56
- } catch (error) {
57
- const error_message = error instanceof Error ? error.message : "Unknown error";
58
- const error_stack = error instanceof Error ? error.stack : undefined;
59
-
60
- logger.error("library_photos_error", {
61
- filename: get_filename(),
62
- line_number: get_line_number(),
63
- error_message,
64
- error_stack,
65
- });
66
-
67
- return NextResponse.json(
68
- { error: "Failed to fetch library photos" },
69
- { status: 500 }
70
- );
71
- }
72
- }
73
-