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,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
-
@@ -1,181 +0,0 @@
1
- // file_description: API route for user login authentication 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 { authenticate_user } from "../../../../lib/services/login_service";
7
- import { createCrudService } from "hazo_connect/server";
8
- import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
9
- import { get_login_config } from "../../../../lib/login_config.server";
10
-
11
- // section: api_handler
12
- export async function POST(request: NextRequest) {
13
- const logger = create_app_logger();
14
-
15
- try {
16
- const body = await request.json();
17
- const { email, password, url_on_logon } = body;
18
-
19
- // Validate input
20
- if (!email || !password) {
21
- logger.warn("login_validation_failed", {
22
- filename: get_filename(),
23
- line_number: get_line_number(),
24
- email: email || "missing",
25
- has_password: !!password,
26
- });
27
-
28
- return NextResponse.json(
29
- { error: "Email and password are required" },
30
- { status: 400 }
31
- );
32
- }
33
-
34
- // Validate email format
35
- const email_pattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
36
- if (!email_pattern.test(email)) {
37
- logger.warn("login_invalid_email", {
38
- filename: get_filename(),
39
- line_number: get_line_number(),
40
- email,
41
- });
42
-
43
- return NextResponse.json(
44
- { error: "Invalid email address format" },
45
- { status: 400 }
46
- );
47
- }
48
-
49
- // Get singleton hazo_connect instance (reuses same connection across all routes)
50
- const hazoConnect = get_hazo_connect_instance();
51
-
52
- // Authenticate user using the login service
53
- const result = await authenticate_user(hazoConnect, {
54
- email,
55
- password,
56
- });
57
-
58
- if (!result.success) {
59
- const status_code = result.error === "Invalid email or password" ? 401 : 500;
60
-
61
- logger.warn("login_failed", {
62
- filename: get_filename(),
63
- line_number: get_line_number(),
64
- email,
65
- error: result.error,
66
- email_not_verified: result.email_not_verified || false,
67
- });
68
-
69
- return NextResponse.json(
70
- {
71
- error: result.error || "Login failed",
72
- email_not_verified: result.email_not_verified || false,
73
- },
74
- { status: status_code }
75
- );
76
- }
77
-
78
- // TypeScript assertion: user_id is guaranteed to be present when success is true
79
- // However, we need to check it to satisfy TypeScript's type checking
80
- if (!result.user_id) {
81
- logger.error("login_user_id_missing", {
82
- filename: get_filename(),
83
- line_number: get_line_number(),
84
- email,
85
- note: "Login succeeded but user_id is missing - this should not happen",
86
- });
87
- return NextResponse.json(
88
- { error: "Login failed - user ID not found" },
89
- { status: 500 }
90
- );
91
- }
92
-
93
- const user_id = result.user_id;
94
-
95
- logger.info("login_successful", {
96
- filename: get_filename(),
97
- line_number: get_line_number(),
98
- user_id: user_id,
99
- email,
100
- });
101
-
102
- // Reuse the existing hazoConnect instance from above
103
- const users_service = createCrudService(hazoConnect, "hazo_users");
104
- const users = await users_service.findBy({
105
- id: user_id,
106
- });
107
- const user = users && users.length > 0 ? users[0] : null;
108
- const user_name = user?.name as string | undefined;
109
-
110
- // Determine redirect URL priority:
111
- // 1. url_on_logon from request body (if valid)
112
- // 2. stored_url_on_logon from database (if available)
113
- // 3. redirect_route_on_successful_login from config
114
- // 4. Default to "/"
115
-
116
- let redirectUrl = "/";
117
-
118
- // Check priority 1: Request body
119
- if (url_on_logon && typeof url_on_logon === "string" && url_on_logon.startsWith("/") && !url_on_logon.startsWith("//")) {
120
- redirectUrl = url_on_logon;
121
- }
122
- // Check priority 2: Stored URL from DB
123
- else if (result.stored_url_on_logon && typeof result.stored_url_on_logon === "string") {
124
- redirectUrl = result.stored_url_on_logon;
125
- }
126
- // Check priority 3: Config
127
- else {
128
- const loginConfig = get_login_config();
129
- if (loginConfig.redirectRoute) {
130
- redirectUrl = loginConfig.redirectRoute;
131
- }
132
- }
133
-
134
- // Create response with cookies
135
- const response = NextResponse.json(
136
- {
137
- success: true,
138
- message: "Login successful",
139
- user_id: user_id,
140
- email,
141
- name: user_name,
142
- redirectUrl,
143
- },
144
- { status: 200 }
145
- );
146
-
147
- // Set authentication cookies
148
- response.cookies.set("hazo_auth_user_id", user_id, {
149
- httpOnly: true,
150
- secure: process.env.NODE_ENV === "production",
151
- sameSite: "lax",
152
- path: "/",
153
- maxAge: 60 * 60 * 24 * 30, // 30 days
154
- });
155
- response.cookies.set("hazo_auth_user_email", email, {
156
- httpOnly: true,
157
- secure: process.env.NODE_ENV === "production",
158
- sameSite: "lax",
159
- path: "/",
160
- maxAge: 60 * 60 * 24 * 30, // 30 days
161
- });
162
-
163
- return response;
164
- } catch (error) {
165
- const error_message = error instanceof Error ? error.message : "Unknown error";
166
- const error_stack = error instanceof Error ? error.stack : undefined;
167
-
168
- logger.error("login_error", {
169
- filename: get_filename(),
170
- line_number: get_line_number(),
171
- error_message,
172
- error_stack,
173
- });
174
-
175
- return NextResponse.json(
176
- { error: "Login failed. Please try again." },
177
- { status: 500 }
178
- );
179
- }
180
- }
181
-
@@ -1,89 +0,0 @@
1
- // file_description: API route for user logout
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { create_app_logger } from "../../../../lib/app_logger";
5
- import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
6
- import { get_auth_cache } from "../../../../lib/auth/auth_cache";
7
- import { get_auth_utility_config } from "../../../../lib/auth_utility_config.server";
8
-
9
- // section: api_handler
10
- export async function POST(request: NextRequest) {
11
- const logger = create_app_logger();
12
-
13
- try {
14
- // Get user info from cookie before clearing
15
- const user_email = request.cookies.get("hazo_auth_user_email")?.value;
16
- const user_id = request.cookies.get("hazo_auth_user_id")?.value;
17
-
18
- // Clear authentication cookies
19
- const response = NextResponse.json(
20
- {
21
- success: true,
22
- message: "Logout successful",
23
- },
24
- { status: 200 }
25
- );
26
-
27
- // Clear cookies by setting them to expire in the past
28
- response.cookies.set("hazo_auth_user_email", "", {
29
- expires: new Date(0),
30
- path: "/",
31
- });
32
- response.cookies.set("hazo_auth_user_id", "", {
33
- expires: new Date(0),
34
- path: "/",
35
- });
36
-
37
- // Invalidate user cache
38
- if (user_id) {
39
- try {
40
- const config = get_auth_utility_config();
41
- const cache = get_auth_cache(
42
- config.cache_max_users,
43
- config.cache_ttl_minutes,
44
- config.cache_max_age_minutes,
45
- );
46
- cache.invalidate_user(user_id);
47
- } catch (cache_error) {
48
- // Log but don't fail logout if cache invalidation fails
49
- const cache_error_message =
50
- cache_error instanceof Error
51
- ? cache_error.message
52
- : "Unknown error";
53
- logger.warn("logout_cache_invalidation_failed", {
54
- filename: get_filename(),
55
- line_number: get_line_number(),
56
- user_id,
57
- error: cache_error_message,
58
- });
59
- }
60
- }
61
-
62
- if (user_email || user_id) {
63
- logger.info("logout_successful", {
64
- filename: get_filename(),
65
- line_number: get_line_number(),
66
- user_id: user_id || "unknown",
67
- email: user_email || "unknown",
68
- });
69
- }
70
-
71
- return response;
72
- } catch (error) {
73
- const error_message = error instanceof Error ? error.message : "Unknown error";
74
- const error_stack = error instanceof Error ? error.stack : undefined;
75
-
76
- logger.error("logout_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: "Logout failed. Please try again." },
85
- { status: 500 }
86
- );
87
- }
88
- }
89
-
@@ -1,47 +0,0 @@
1
- // file_description: API route to get current authenticated user information
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { get_authenticated_user_with_response } from "../../../../lib/auth/auth_utils.server";
5
-
6
- // section: api_handler
7
- export async function GET(request: NextRequest) {
8
- try {
9
- // Use centralized auth utility
10
- const { auth_result, response } = await get_authenticated_user_with_response(request);
11
-
12
- // If response is provided, it means cookies were cleared (invalid auth)
13
- if (response) {
14
- return response;
15
- }
16
-
17
- // If not authenticated, return false
18
- if (!auth_result.authenticated) {
19
- return NextResponse.json(
20
- { authenticated: false },
21
- { status: 200 }
22
- );
23
- }
24
-
25
- // Return user info
26
- return NextResponse.json(
27
- {
28
- authenticated: true,
29
- user_id: auth_result.user_id,
30
- email: auth_result.email,
31
- name: auth_result.name,
32
- email_verified: auth_result.email_verified,
33
- last_logon: auth_result.last_logon,
34
- profile_picture_url: auth_result.profile_picture_url,
35
- profile_source: auth_result.profile_source,
36
- },
37
- { status: 200 }
38
- );
39
- } catch (error) {
40
- // On error, assume not authenticated
41
- return NextResponse.json(
42
- { authenticated: false },
43
- { status: 200 }
44
- );
45
- }
46
- }
47
-
@@ -1,67 +0,0 @@
1
- // file_description: API route to serve uploaded profile pictures
2
- // section: imports
3
- import { NextRequest, NextResponse } from "next/server";
4
- import { get_profile_picture_config } from "../../../../../lib/profile_picture_config.server";
5
- import fs from "fs";
6
- import path from "path";
7
-
8
- // section: api_handler
9
- export async function GET(
10
- request: NextRequest,
11
- { params }: { params: { filename: string } }
12
- ) {
13
- try {
14
- const config = get_profile_picture_config();
15
-
16
- if (!config.allow_photo_upload || !config.upload_photo_path) {
17
- return NextResponse.json(
18
- { error: "Profile picture upload is not enabled" },
19
- { status: 404 }
20
- );
21
- }
22
-
23
- const filename = params.filename;
24
-
25
- // Validate filename (prevent path traversal)
26
- if (filename.includes("..") || filename.includes("/") || filename.includes("\\")) {
27
- return NextResponse.json(
28
- { error: "Invalid filename" },
29
- { status: 400 }
30
- );
31
- }
32
-
33
- // Resolve upload path
34
- const uploadPath = path.isAbsolute(config.upload_photo_path)
35
- ? config.upload_photo_path
36
- : path.resolve(process.cwd(), config.upload_photo_path);
37
-
38
- const filePath = path.join(uploadPath, filename);
39
-
40
- // Check if file exists
41
- if (!fs.existsSync(filePath)) {
42
- return NextResponse.json(
43
- { error: "File not found" },
44
- { status: 404 }
45
- );
46
- }
47
-
48
- // Read file
49
- const fileBuffer = fs.readFileSync(filePath);
50
- const fileExt = path.extname(filename).toLowerCase();
51
- const contentType = fileExt === ".png" ? "image/png" : "image/jpeg";
52
-
53
- // Return file with appropriate content type
54
- return new NextResponse(fileBuffer, {
55
- headers: {
56
- "Content-Type": contentType,
57
- "Cache-Control": "public, max-age=31536000, immutable",
58
- },
59
- });
60
- } catch (error) {
61
- return NextResponse.json(
62
- { error: "Failed to serve profile picture" },
63
- { status: 500 }
64
- );
65
- }
66
- }
67
-