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
@@ -0,0 +1,8 @@
1
+ import { NextRequest, NextResponse } from "next/server";
2
+ export declare function POST(request: NextRequest): Promise<NextResponse<{
3
+ error: string;
4
+ }> | NextResponse<{
5
+ success: boolean;
6
+ message: string;
7
+ }>>;
8
+ //# sourceMappingURL=route.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../src/app/api/hazo_auth/change_password/route.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAUxD,wBAAsB,IAAI,CAAC,OAAO,EAAE,WAAW;;;;;IAsH9C"}
@@ -0,0 +1,98 @@
1
+ // file_description: API route for changing user password
2
+ // section: imports
3
+ import { 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
+ // section: api_handler
12
+ export async function POST(request) {
13
+ const logger = create_app_logger();
14
+ try {
15
+ // Use centralized auth check
16
+ let user_id;
17
+ try {
18
+ const user = await require_auth(request);
19
+ user_id = user.user_id;
20
+ }
21
+ catch (error) {
22
+ if (error instanceof Error && error.message === "Authentication required") {
23
+ logger.warn("password_change_authentication_failed", {
24
+ filename: get_filename(),
25
+ line_number: get_line_number(),
26
+ error: "User not authenticated",
27
+ });
28
+ return NextResponse.json({ error: "Authentication required" }, { status: 401 });
29
+ }
30
+ throw error;
31
+ }
32
+ const body = await request.json();
33
+ const { current_password, new_password } = body;
34
+ // Validate input
35
+ if (!current_password || !new_password) {
36
+ logger.warn("password_change_validation_failed", {
37
+ filename: get_filename(),
38
+ line_number: get_line_number(),
39
+ error: "Missing required fields",
40
+ has_current_password: !!current_password,
41
+ has_new_password: !!new_password,
42
+ });
43
+ return NextResponse.json({ error: "Current password and new password are required" }, { status: 400 });
44
+ }
45
+ // Get singleton hazo_connect instance
46
+ const hazoConnect = get_hazo_connect_instance();
47
+ // Change password
48
+ const result = await change_password(hazoConnect, user_id, {
49
+ current_password,
50
+ new_password,
51
+ });
52
+ if (!result.success) {
53
+ logger.warn("password_change_failed", {
54
+ filename: get_filename(),
55
+ line_number: get_line_number(),
56
+ error: result.error,
57
+ user_id,
58
+ });
59
+ return NextResponse.json({ error: result.error || "Failed to change password" }, { status: 400 });
60
+ }
61
+ // Invalidate user cache after password change
62
+ try {
63
+ const config = get_auth_utility_config();
64
+ const cache = get_auth_cache(config.cache_max_users, config.cache_ttl_minutes, config.cache_max_age_minutes);
65
+ cache.invalidate_user(user_id);
66
+ }
67
+ catch (cache_error) {
68
+ // Log but don't fail password change if cache invalidation fails
69
+ const cache_error_message = cache_error instanceof Error ? cache_error.message : "Unknown error";
70
+ logger.warn("password_change_cache_invalidation_failed", {
71
+ filename: get_filename(),
72
+ line_number: get_line_number(),
73
+ user_id,
74
+ error: cache_error_message,
75
+ });
76
+ }
77
+ logger.info("password_change_successful", {
78
+ filename: get_filename(),
79
+ line_number: get_line_number(),
80
+ user_id,
81
+ });
82
+ return NextResponse.json({
83
+ success: true,
84
+ message: "Password changed successfully",
85
+ }, { status: 200 });
86
+ }
87
+ catch (error) {
88
+ const error_message = error instanceof Error ? error.message : "Unknown error";
89
+ const error_stack = error instanceof Error ? error.stack : undefined;
90
+ logger.error("password_change_error", {
91
+ filename: get_filename(),
92
+ line_number: get_line_number(),
93
+ error_message,
94
+ error_stack,
95
+ });
96
+ return NextResponse.json({ error: "Failed to change password. Please try again." }, { status: 500 });
97
+ }
98
+ }
@@ -0,0 +1,8 @@
1
+ import { NextRequest, NextResponse } from "next/server";
2
+ export declare function POST(request: NextRequest): Promise<NextResponse<{
3
+ error: string;
4
+ }> | NextResponse<{
5
+ success: boolean;
6
+ message: string;
7
+ }>>;
8
+ //# sourceMappingURL=route.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../src/app/api/hazo_auth/forgot_password/route.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAOxD,wBAAsB,IAAI,CAAC,OAAO,EAAE,WAAW;;;;;IAgG9C"}
@@ -0,0 +1,78 @@
1
+ // file_description: API route for password reset requests using hazo_connect
2
+ // section: imports
3
+ import { 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
+ // section: api_handler
9
+ export async function POST(request) {
10
+ const logger = create_app_logger();
11
+ try {
12
+ const body = await request.json();
13
+ const { email } = body;
14
+ // Validate input
15
+ if (!email) {
16
+ logger.warn("password_reset_validation_failed", {
17
+ filename: get_filename(),
18
+ line_number: get_line_number(),
19
+ email: email || "missing",
20
+ });
21
+ return NextResponse.json({ error: "Email is required" }, { status: 400 });
22
+ }
23
+ // Validate email format
24
+ const email_pattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
25
+ if (!email_pattern.test(email)) {
26
+ logger.warn("password_reset_invalid_email", {
27
+ filename: get_filename(),
28
+ line_number: get_line_number(),
29
+ email,
30
+ });
31
+ return NextResponse.json({ error: "Invalid email address format" }, { status: 400 });
32
+ }
33
+ // Get singleton hazo_connect instance (reuses same connection across all routes)
34
+ const hazoConnect = get_hazo_connect_instance();
35
+ // Request password reset using the password reset service
36
+ const result = await request_password_reset(hazoConnect, {
37
+ email,
38
+ });
39
+ if (!result.success) {
40
+ logger.warn("password_reset_failed", {
41
+ filename: get_filename(),
42
+ line_number: get_line_number(),
43
+ email,
44
+ error: result.error,
45
+ });
46
+ // Still return 200 OK to prevent email enumeration attacks
47
+ return NextResponse.json({
48
+ success: true,
49
+ message: "If an account with that email exists, a password reset link has been sent.",
50
+ }, { status: 200 });
51
+ }
52
+ logger.info("password_reset_requested", {
53
+ filename: get_filename(),
54
+ line_number: get_line_number(),
55
+ email,
56
+ });
57
+ // Always return success to prevent email enumeration attacks
58
+ return NextResponse.json({
59
+ success: true,
60
+ message: "If an account with that email exists, a password reset link has been sent.",
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
+ logger.error("password_reset_error", {
67
+ filename: get_filename(),
68
+ line_number: get_line_number(),
69
+ error_message,
70
+ error_stack,
71
+ });
72
+ // Still return 200 OK to prevent email enumeration attacks
73
+ return NextResponse.json({
74
+ success: true,
75
+ message: "If an account with that email exists, a password reset link has been sent.",
76
+ }, { status: 200 });
77
+ }
78
+ }
@@ -0,0 +1,10 @@
1
+ import { NextRequest, NextResponse } from "next/server";
2
+ export declare const dynamic = "force-dynamic";
3
+ /**
4
+ * POST - Get authentication status and permissions
5
+ * Body: { required_permissions?: string[], strict?: boolean }
6
+ */
7
+ export declare function POST(request: NextRequest): Promise<NextResponse<{
8
+ error: string;
9
+ }> | NextResponse<import("../../../..").HazoAuthResult>>;
10
+ //# sourceMappingURL=route.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../src/app/api/hazo_auth/get_auth/route.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAOxD,eAAO,MAAM,OAAO,kBAAkB,CAAC;AAGvC;;;GAGG;AACH,wBAAsB,IAAI,CAAC,OAAO,EAAE,WAAW;;yDAuE9C"}
@@ -0,0 +1,63 @@
1
+ // file_description: API route for hazo_get_auth utility (client-side calls)
2
+ // section: imports
3
+ import { 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
+ // section: route_config
9
+ export const dynamic = "force-dynamic";
10
+ // section: api_handler
11
+ /**
12
+ * POST - Get authentication status and permissions
13
+ * Body: { required_permissions?: string[], strict?: boolean }
14
+ */
15
+ export async function POST(request) {
16
+ const logger = create_app_logger();
17
+ try {
18
+ const body = await request.json();
19
+ const { required_permissions, strict } = body;
20
+ // Validate required_permissions if provided
21
+ if (required_permissions !== undefined &&
22
+ (!Array.isArray(required_permissions) ||
23
+ !required_permissions.every((p) => typeof p === "string"))) {
24
+ return NextResponse.json({ error: "required_permissions must be an array of strings" }, { status: 400 });
25
+ }
26
+ // Validate strict if provided
27
+ if (strict !== undefined && typeof strict !== "boolean") {
28
+ return NextResponse.json({ error: "strict must be a boolean" }, { status: 400 });
29
+ }
30
+ // Call hazo_get_auth
31
+ const result = await hazo_get_auth(request, {
32
+ required_permissions,
33
+ strict,
34
+ });
35
+ return NextResponse.json(result, { status: 200 });
36
+ }
37
+ catch (error) {
38
+ // Handle PermissionError (strict mode)
39
+ if (error instanceof PermissionError) {
40
+ logger.warn("auth_utility_permission_error", {
41
+ filename: get_filename(),
42
+ line_number: get_line_number(),
43
+ missing_permissions: error.missing_permissions,
44
+ required_permissions: error.required_permissions,
45
+ });
46
+ return NextResponse.json({
47
+ error: "Permission denied",
48
+ missing_permissions: error.missing_permissions,
49
+ user_friendly_message: error.user_friendly_message,
50
+ }, { status: 403 });
51
+ }
52
+ // Handle other errors
53
+ const error_message = error instanceof Error ? error.message : "Unknown error";
54
+ const error_stack = error instanceof Error ? error.stack : undefined;
55
+ logger.error("auth_utility_api_error", {
56
+ filename: get_filename(),
57
+ line_number: get_line_number(),
58
+ error_message,
59
+ error_stack,
60
+ });
61
+ return NextResponse.json({ error: error_message }, { status: 500 });
62
+ }
63
+ }
@@ -0,0 +1,14 @@
1
+ import { NextRequest, NextResponse } from "next/server";
2
+ export declare const dynamic = "force-dynamic";
3
+ /**
4
+ * POST - Manually invalidate auth cache
5
+ * Body: { user_id?: string, role_ids?: number[], invalidate_all?: boolean }
6
+ * Requires admin permission (checked via hazo_get_auth)
7
+ */
8
+ export declare function POST(request: NextRequest): Promise<NextResponse<{
9
+ error: string;
10
+ }> | NextResponse<{
11
+ success: boolean;
12
+ message: string;
13
+ }>>;
14
+ //# sourceMappingURL=route.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../src/app/api/hazo_auth/invalidate_cache/route.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAQxD,eAAO,MAAM,OAAO,kBAAkB,CAAC;AAGvC;;;;GAIG;AACH,wBAAsB,IAAI,CAAC,OAAO,EAAE,WAAW;;;;;IAuH9C"}
@@ -0,0 +1,96 @@
1
+ // file_description: API route for manual cache invalidation (admin endpoint)
2
+ // section: imports
3
+ import { 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
+ // section: route_config
10
+ export const dynamic = "force-dynamic";
11
+ // section: api_handler
12
+ /**
13
+ * POST - Manually invalidate auth cache
14
+ * Body: { user_id?: string, role_ids?: number[], invalidate_all?: boolean }
15
+ * Requires admin permission (checked via hazo_get_auth)
16
+ */
17
+ export async function POST(request) {
18
+ const logger = create_app_logger();
19
+ try {
20
+ // Check authentication and admin permission
21
+ const auth_result = await hazo_get_auth(request, {
22
+ required_permissions: ["admin_user_management"], // Require admin permission
23
+ strict: true, // Throw error if not authorized
24
+ });
25
+ if (!auth_result.authenticated) {
26
+ return NextResponse.json({ error: "Authentication required" }, { status: 401 });
27
+ }
28
+ const body = await request.json();
29
+ const { user_id, role_ids, invalidate_all } = body;
30
+ // Validate input
31
+ if (invalidate_all !== undefined && typeof invalidate_all !== "boolean") {
32
+ return NextResponse.json({ error: "invalidate_all must be a boolean" }, { status: 400 });
33
+ }
34
+ if (user_id !== undefined && typeof user_id !== "string") {
35
+ return NextResponse.json({ error: "user_id must be a string" }, { status: 400 });
36
+ }
37
+ if (role_ids !== undefined &&
38
+ (!Array.isArray(role_ids) ||
39
+ !role_ids.every((id) => typeof id === "number"))) {
40
+ return NextResponse.json({ error: "role_ids must be an array of numbers" }, { status: 400 });
41
+ }
42
+ const config = get_auth_utility_config();
43
+ const cache = get_auth_cache(config.cache_max_users, config.cache_ttl_minutes, config.cache_max_age_minutes);
44
+ // Perform invalidation
45
+ if (invalidate_all === true) {
46
+ cache.invalidate_all();
47
+ logger.info("auth_cache_invalidated_all", {
48
+ filename: get_filename(),
49
+ line_number: get_line_number(),
50
+ user_id: auth_result.user.id,
51
+ });
52
+ }
53
+ else if (user_id) {
54
+ cache.invalidate_user(user_id);
55
+ logger.info("auth_cache_invalidated_user", {
56
+ filename: get_filename(),
57
+ line_number: get_line_number(),
58
+ invalidated_user_id: user_id,
59
+ admin_user_id: auth_result.user.id,
60
+ });
61
+ }
62
+ else if (role_ids && role_ids.length > 0) {
63
+ cache.invalidate_by_roles(role_ids);
64
+ logger.info("auth_cache_invalidated_roles", {
65
+ filename: get_filename(),
66
+ line_number: get_line_number(),
67
+ role_ids,
68
+ admin_user_id: auth_result.user.id,
69
+ });
70
+ }
71
+ else {
72
+ return NextResponse.json({
73
+ error: "Must provide user_id, role_ids, or invalidate_all=true",
74
+ }, { status: 400 });
75
+ }
76
+ return NextResponse.json({
77
+ success: true,
78
+ message: "Cache invalidated successfully",
79
+ }, { status: 200 });
80
+ }
81
+ catch (error) {
82
+ // Handle PermissionError (strict mode)
83
+ if (error instanceof Error && error.name === "PermissionError") {
84
+ return NextResponse.json({ error: "Permission denied. Admin access required." }, { status: 403 });
85
+ }
86
+ const error_message = error instanceof Error ? error.message : "Unknown error";
87
+ const error_stack = error instanceof Error ? error.stack : undefined;
88
+ logger.error("auth_cache_invalidation_error", {
89
+ filename: get_filename(),
90
+ line_number: get_line_number(),
91
+ error_message,
92
+ error_stack,
93
+ });
94
+ return NextResponse.json({ error: "Failed to invalidate cache" }, { status: 500 });
95
+ }
96
+ }
@@ -0,0 +1,9 @@
1
+ import { NextRequest, NextResponse } from "next/server";
2
+ export declare const dynamic = "force-dynamic";
3
+ export declare function GET(request: NextRequest, { params }: {
4
+ params: {
5
+ category: string;
6
+ filename: string;
7
+ };
8
+ }): Promise<NextResponse<unknown>>;
9
+ //# sourceMappingURL=route.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../../../src/app/api/hazo_auth/library_photo/[category]/[filename]/route.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AASxD,eAAO,MAAM,OAAO,kBAAkB,CAAC;AAevC,wBAAsB,GAAG,CACvB,OAAO,EAAE,WAAW,EACpB,EAAE,MAAM,EAAE,EAAE;IAAE,MAAM,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,kCA4E/D"}
@@ -0,0 +1,82 @@
1
+ // file_description: API route to serve library photos from node_modules fallback
2
+ // This route is used when library photos haven't been copied to the project's public folder
3
+ // section: imports
4
+ import { NextResponse } from "next/server";
5
+ import { get_library_photo_path } from "../../../../../../lib/services/profile_picture_service";
6
+ import { create_app_logger } from "../../../../../../lib/app_logger";
7
+ import { get_filename, get_line_number } from "../../../../../../lib/utils/api_route_helpers";
8
+ import fs from "fs";
9
+ import path from "path";
10
+ // section: route_config
11
+ // Cache library photos for 1 hour (they don't change)
12
+ export const dynamic = 'force-dynamic';
13
+ // section: constants
14
+ const MIME_TYPES = {
15
+ ".jpg": "image/jpeg",
16
+ ".jpeg": "image/jpeg",
17
+ ".png": "image/png",
18
+ ".gif": "image/gif",
19
+ ".webp": "image/webp",
20
+ ".svg": "image/svg+xml",
21
+ };
22
+ const CACHE_MAX_AGE = 3600; // 1 hour in seconds
23
+ // section: api_handler
24
+ export async function GET(request, { params }) {
25
+ const logger = create_app_logger();
26
+ const { category, filename } = params;
27
+ try {
28
+ // Validate inputs to prevent path traversal
29
+ if (category.includes("..") ||
30
+ category.includes("/") ||
31
+ category.includes("\\") ||
32
+ filename.includes("..") ||
33
+ filename.includes("/") ||
34
+ filename.includes("\\")) {
35
+ logger.warn("library_photo_invalid_path", {
36
+ filename: get_filename(),
37
+ line_number: get_line_number(),
38
+ category,
39
+ requested_filename: filename,
40
+ });
41
+ return NextResponse.json({ error: "Invalid path" }, { status: 400 });
42
+ }
43
+ // Get the physical file path
44
+ const photo_path = get_library_photo_path(category, filename);
45
+ if (!photo_path) {
46
+ logger.warn("library_photo_not_found", {
47
+ filename: get_filename(),
48
+ line_number: get_line_number(),
49
+ category,
50
+ requested_filename: filename,
51
+ });
52
+ return NextResponse.json({ error: "Photo not found" }, { status: 404 });
53
+ }
54
+ // Read the file
55
+ const file_buffer = fs.readFileSync(photo_path);
56
+ const ext = path.extname(filename).toLowerCase();
57
+ const content_type = MIME_TYPES[ext] || "application/octet-stream";
58
+ // Return the image with caching headers
59
+ return new NextResponse(file_buffer, {
60
+ status: 200,
61
+ headers: {
62
+ "Content-Type": content_type,
63
+ "Content-Length": file_buffer.length.toString(),
64
+ "Cache-Control": `public, max-age=${CACHE_MAX_AGE}, immutable`,
65
+ "X-Library-Source": "node_modules",
66
+ },
67
+ });
68
+ }
69
+ catch (error) {
70
+ const error_message = error instanceof Error ? error.message : "Unknown error";
71
+ const error_stack = error instanceof Error ? error.stack : undefined;
72
+ logger.error("library_photo_error", {
73
+ filename: get_filename(),
74
+ line_number: get_line_number(),
75
+ category,
76
+ requested_filename: filename,
77
+ error_message,
78
+ error_stack,
79
+ });
80
+ return NextResponse.json({ error: "Failed to serve photo" }, { status: 500 });
81
+ }
82
+ }
@@ -0,0 +1,22 @@
1
+ import { NextRequest, NextResponse } from "next/server";
2
+ export declare const dynamic = "force-dynamic";
3
+ export declare function GET(request: NextRequest): Promise<NextResponse<{
4
+ success: boolean;
5
+ category: string;
6
+ photos: string[];
7
+ pagination: {
8
+ page: number;
9
+ page_size: number;
10
+ total: number;
11
+ has_more: boolean;
12
+ total_pages: number;
13
+ };
14
+ source: "project" | "node_modules";
15
+ }> | NextResponse<{
16
+ success: boolean;
17
+ categories: string[];
18
+ source: "project" | "node_modules" | null;
19
+ }> | NextResponse<{
20
+ error: string;
21
+ }>>;
22
+ //# sourceMappingURL=route.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../src/app/api/hazo_auth/library_photos/route.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAUxD,eAAO,MAAM,OAAO,kBAAkB,CAAC;AAOvC,wBAAsB,GAAG,CAAC,OAAO,EAAE,WAAW;;;;;;;;;;;;;;;;;;IAmF7C"}
@@ -0,0 +1,80 @@
1
+ // file_description: API route for listing library photo categories and photos in categories with pagination support
2
+ // section: imports
3
+ import { NextResponse } from "next/server";
4
+ import { get_library_categories, get_library_photos_paginated, get_library_source } 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
+ // section: route_config
8
+ export const dynamic = 'force-dynamic';
9
+ // section: constants
10
+ const DEFAULT_PAGE_SIZE = 20;
11
+ const MAX_PAGE_SIZE = 100;
12
+ // section: api_handler
13
+ export async function GET(request) {
14
+ const logger = create_app_logger();
15
+ try {
16
+ const { searchParams } = new URL(request.url);
17
+ const category = searchParams.get("category");
18
+ const page_param = searchParams.get("page");
19
+ const page_size_param = searchParams.get("page_size");
20
+ // Parse pagination parameters
21
+ const page = page_param ? Math.max(1, parseInt(page_param, 10) || 1) : 1;
22
+ const page_size = page_size_param
23
+ ? Math.min(MAX_PAGE_SIZE, Math.max(1, parseInt(page_size_param, 10) || DEFAULT_PAGE_SIZE))
24
+ : DEFAULT_PAGE_SIZE;
25
+ if (category) {
26
+ // Return photos in the specified category with pagination
27
+ const result = get_library_photos_paginated(category, page, page_size);
28
+ logger.info("library_photos_category_requested", {
29
+ filename: get_filename(),
30
+ line_number: get_line_number(),
31
+ category,
32
+ page,
33
+ page_size,
34
+ total: result.total,
35
+ returned: result.photos.length,
36
+ source: result.source,
37
+ });
38
+ return NextResponse.json({
39
+ success: true,
40
+ category,
41
+ photos: result.photos,
42
+ pagination: {
43
+ page: result.page,
44
+ page_size: result.page_size,
45
+ total: result.total,
46
+ has_more: result.has_more,
47
+ total_pages: Math.ceil(result.total / result.page_size),
48
+ },
49
+ source: result.source,
50
+ }, { status: 200 });
51
+ }
52
+ else {
53
+ // Return list of categories
54
+ const categories = get_library_categories();
55
+ const source = get_library_source();
56
+ logger.info("library_categories_requested", {
57
+ filename: get_filename(),
58
+ line_number: get_line_number(),
59
+ categoryCount: categories.length,
60
+ source,
61
+ });
62
+ return NextResponse.json({
63
+ success: true,
64
+ categories,
65
+ source,
66
+ }, { status: 200 });
67
+ }
68
+ }
69
+ catch (error) {
70
+ const error_message = error instanceof Error ? error.message : "Unknown error";
71
+ const error_stack = error instanceof Error ? error.stack : undefined;
72
+ logger.error("library_photos_error", {
73
+ filename: get_filename(),
74
+ line_number: get_line_number(),
75
+ error_message,
76
+ error_stack,
77
+ });
78
+ return NextResponse.json({ error: "Failed to fetch library photos" }, { status: 500 });
79
+ }
80
+ }
@@ -0,0 +1,12 @@
1
+ import { NextRequest, NextResponse } from "next/server";
2
+ export declare function POST(request: NextRequest): Promise<NextResponse<{
3
+ error: string;
4
+ }> | NextResponse<{
5
+ success: boolean;
6
+ message: string;
7
+ user_id: string;
8
+ email: any;
9
+ name: string | undefined;
10
+ redirectUrl: string;
11
+ }>>;
12
+ //# sourceMappingURL=route.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route.d.ts","sourceRoot":"","sources":["../../../../../src/app/api/hazo_auth/login/route.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AASxD,wBAAsB,IAAI,CAAC,OAAO,EAAE,WAAW;;;;;;;;;IAwK9C"}