hazo_auth 1.4.2 → 1.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/SETUP_CHECKLIST.md +708 -0
- package/dist/app/api/hazo_auth/change_password/route.d.ts +8 -0
- package/dist/app/api/hazo_auth/change_password/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/change_password/route.js +98 -0
- package/dist/app/api/hazo_auth/forgot_password/route.d.ts +8 -0
- package/dist/app/api/hazo_auth/forgot_password/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/forgot_password/route.js +78 -0
- package/dist/app/api/hazo_auth/get_auth/route.d.ts +10 -0
- package/dist/app/api/hazo_auth/get_auth/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/get_auth/route.js +63 -0
- package/dist/app/api/hazo_auth/invalidate_cache/route.d.ts +14 -0
- package/dist/app/api/hazo_auth/invalidate_cache/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/invalidate_cache/route.js +96 -0
- package/dist/app/api/hazo_auth/library_photos/route.d.ts +13 -0
- package/dist/app/api/hazo_auth/library_photos/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/library_photos/route.js +55 -0
- package/dist/app/api/hazo_auth/login/route.d.ts +12 -0
- package/dist/app/api/hazo_auth/login/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/login/route.js +140 -0
- package/dist/app/api/hazo_auth/logout/route.d.ts +8 -0
- package/dist/app/api/hazo_auth/logout/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/logout/route.js +71 -0
- package/dist/app/api/hazo_auth/me/route.d.ts +3 -0
- package/dist/app/api/hazo_auth/me/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/me/route.js +34 -0
- package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts +7 -0
- package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/profile_picture/[filename]/route.js +43 -0
- package/dist/app/api/hazo_auth/register/route.d.ts +9 -0
- package/dist/app/api/hazo_auth/register/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/register/route.js +80 -0
- package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts +8 -0
- package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/remove_profile_picture/route.js +64 -0
- package/dist/app/api/hazo_auth/resend_verification/route.d.ts +8 -0
- package/dist/app/api/hazo_auth/resend_verification/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/resend_verification/route.js +79 -0
- package/dist/app/api/hazo_auth/reset_password/route.d.ts +8 -0
- package/dist/app/api/hazo_auth/reset_password/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/reset_password/route.js +76 -0
- package/dist/app/api/hazo_auth/update_user/route.d.ts +9 -0
- package/dist/app/api/hazo_auth/update_user/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/update_user/route.js +95 -0
- package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts +9 -0
- package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/upload_profile_picture/route.js +204 -0
- package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts +6 -0
- package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/validate_reset_token/route.js +58 -0
- package/dist/app/api/hazo_auth/verify_email/route.d.ts +11 -0
- package/dist/app/api/hazo_auth/verify_email/route.d.ts.map +1 -0
- package/dist/app/api/hazo_auth/verify_email/route.js +63 -0
- package/dist/cli/generate.d.ts +2 -0
- package/dist/cli/generate.d.ts.map +1 -0
- package/dist/cli/generate.js +117 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +120 -0
- package/dist/cli/validate.d.ts +15 -0
- package/dist/cli/validate.d.ts.map +1 -0
- package/dist/cli/validate.js +509 -0
- package/dist/components/ui/card.d.ts +9 -0
- package/dist/components/ui/card.d.ts.map +1 -0
- package/dist/components/ui/card.js +45 -0
- package/dist/hooks/use-mobile.d.ts.map +1 -1
- package/dist/hooks/use-mobile.js +17 -3
- package/dist/server/routes/change_password.d.ts +2 -0
- package/dist/server/routes/change_password.d.ts.map +1 -0
- package/dist/server/routes/change_password.js +2 -0
- package/dist/server/routes/forgot_password.d.ts +2 -0
- package/dist/server/routes/forgot_password.d.ts.map +1 -0
- package/dist/server/routes/forgot_password.js +2 -0
- package/dist/server/routes/get_auth.d.ts +2 -0
- package/dist/server/routes/get_auth.d.ts.map +1 -0
- package/dist/server/routes/get_auth.js +2 -0
- package/dist/server/routes/index.d.ts +18 -0
- package/dist/server/routes/index.d.ts.map +1 -0
- package/dist/server/routes/index.js +24 -0
- package/dist/server/routes/invalidate_cache.d.ts +2 -0
- package/dist/server/routes/invalidate_cache.d.ts.map +1 -0
- package/dist/server/routes/invalidate_cache.js +2 -0
- package/dist/server/routes/library_photos.d.ts +2 -0
- package/dist/server/routes/library_photos.d.ts.map +1 -0
- package/dist/server/routes/library_photos.js +2 -0
- package/dist/server/routes/login.d.ts +2 -0
- package/dist/server/routes/login.d.ts.map +1 -0
- package/dist/server/routes/login.js +2 -0
- package/dist/server/routes/logout.d.ts +2 -0
- package/dist/server/routes/logout.d.ts.map +1 -0
- package/dist/server/routes/logout.js +2 -0
- package/dist/server/routes/me.d.ts +2 -0
- package/dist/server/routes/me.d.ts.map +1 -0
- package/dist/server/routes/me.js +2 -0
- package/dist/server/routes/profile_picture_filename.d.ts +2 -0
- package/dist/server/routes/profile_picture_filename.d.ts.map +1 -0
- package/dist/server/routes/profile_picture_filename.js +3 -0
- package/dist/server/routes/register.d.ts +2 -0
- package/dist/server/routes/register.d.ts.map +1 -0
- package/dist/server/routes/register.js +2 -0
- package/dist/server/routes/remove_profile_picture.d.ts +2 -0
- package/dist/server/routes/remove_profile_picture.d.ts.map +1 -0
- package/dist/server/routes/remove_profile_picture.js +2 -0
- package/dist/server/routes/resend_verification.d.ts +2 -0
- package/dist/server/routes/resend_verification.d.ts.map +1 -0
- package/dist/server/routes/resend_verification.js +2 -0
- package/dist/server/routes/reset_password.d.ts +2 -0
- package/dist/server/routes/reset_password.d.ts.map +1 -0
- package/dist/server/routes/reset_password.js +2 -0
- package/dist/server/routes/update_user.d.ts +2 -0
- package/dist/server/routes/update_user.d.ts.map +1 -0
- package/dist/server/routes/update_user.js +2 -0
- package/dist/server/routes/upload_profile_picture.d.ts +2 -0
- package/dist/server/routes/upload_profile_picture.d.ts.map +1 -0
- package/dist/server/routes/upload_profile_picture.js +2 -0
- package/dist/server/routes/validate_reset_token.d.ts +2 -0
- package/dist/server/routes/validate_reset_token.d.ts.map +1 -0
- package/dist/server/routes/validate_reset_token.js +2 -0
- package/dist/server/routes/verify_email.d.ts +2 -0
- package/dist/server/routes/verify_email.d.ts.map +1 -0
- package/dist/server/routes/verify_email.js +2 -0
- package/package.json +12 -17
- package/components.json +0 -22
- package/instrumentation.ts +0 -32
- package/migrations/001_add_token_type_to_refresh_tokens.sql +0 -14
- package/migrations/002_add_name_to_hazo_users.sql +0 -7
- package/migrations/003_add_url_on_logon_to_hazo_users.sql +0 -8
- package/next.config.mjs +0 -67
- package/postcss.config.mjs +0 -8
- package/public/file.svg +0 -1
- package/public/globe.svg +0 -1
- package/public/next.svg +0 -1
- package/public/vercel.svg +0 -1
- package/public/window.svg +0 -1
- package/scripts/apply_migration.ts +0 -118
- package/scripts/init_users.ts +0 -378
- package/src/app/api/hazo_auth/auth/upload_profile_picture/route.ts +0 -268
- package/src/app/api/hazo_auth/change_password/route.ts +0 -132
- package/src/app/api/hazo_auth/forgot_password/route.ts +0 -107
- package/src/app/api/hazo_auth/get_auth/route.ts +0 -89
- package/src/app/api/hazo_auth/invalidate_cache/route.ts +0 -139
- package/src/app/api/hazo_auth/library_photos/route.ts +0 -73
- package/src/app/api/hazo_auth/login/route.ts +0 -181
- package/src/app/api/hazo_auth/logout/route.ts +0 -89
- package/src/app/api/hazo_auth/me/route.ts +0 -47
- package/src/app/api/hazo_auth/profile_picture/[filename]/route.ts +0 -67
- package/src/app/api/hazo_auth/register/route.ts +0 -109
- package/src/app/api/hazo_auth/remove_profile_picture/route.ts +0 -86
- package/src/app/api/hazo_auth/resend_verification/route.ts +0 -108
- package/src/app/api/hazo_auth/reset_password/route.ts +0 -107
- package/src/app/api/hazo_auth/update_user/route.ts +0 -126
- package/src/app/api/hazo_auth/upload_profile_picture/route.ts +0 -268
- package/src/app/api/hazo_auth/user_management/permissions/route.ts +0 -367
- package/src/app/api/hazo_auth/user_management/roles/route.ts +0 -442
- package/src/app/api/hazo_auth/user_management/users/roles/route.ts +0 -367
- package/src/app/api/hazo_auth/user_management/users/route.ts +0 -239
- package/src/app/api/hazo_auth/validate_reset_token/route.ts +0 -83
- package/src/app/api/hazo_auth/verify_email/route.ts +0 -88
- package/src/app/api/migrations/apply/route.ts +0 -91
- package/src/app/favicon.ico +0 -0
- package/src/app/fonts/GeistMonoVF.woff +0 -0
- package/src/app/fonts/GeistVF.woff +0 -0
- package/src/app/globals.css +0 -89
- package/src/app/hazo_auth/forgot_password/forgot_password_page_client.tsx +0 -60
- package/src/app/hazo_auth/forgot_password/page.tsx +0 -24
- package/src/app/hazo_auth/login/login_page_client.tsx +0 -86
- package/src/app/hazo_auth/login/page.tsx +0 -38
- package/src/app/hazo_auth/my_settings/my_settings_page_client.tsx +0 -120
- package/src/app/hazo_auth/my_settings/page.tsx +0 -40
- package/src/app/hazo_auth/register/page.tsx +0 -36
- package/src/app/hazo_auth/register/register_page_client.tsx +0 -81
- package/src/app/hazo_auth/reset_password/page.tsx +0 -29
- package/src/app/hazo_auth/reset_password/reset_password_page_client.tsx +0 -81
- package/src/app/hazo_auth/user_management/page.tsx +0 -14
- package/src/app/hazo_auth/user_management/user_management_page_client.tsx +0 -16
- package/src/app/hazo_auth/verify_email/page.tsx +0 -24
- package/src/app/hazo_auth/verify_email/verify_email_page_client.tsx +0 -60
- package/src/app/hazo_connect/api/sqlite/data/route.ts +0 -203
- package/src/app/hazo_connect/api/sqlite/schema/route.ts +0 -45
- package/src/app/hazo_connect/api/sqlite/tables/route.ts +0 -36
- package/src/app/hazo_connect/sqlite_admin/page.tsx +0 -51
- package/src/app/hazo_connect/sqlite_admin/sqlite-admin-client.tsx +0 -984
- package/src/app/layout.tsx +0 -43
- package/src/app/page.tsx +0 -170
- package/src/components/index.ts +0 -7
- package/src/components/layouts/email_verification/config/email_verification_field_config.ts +0 -86
- package/src/components/layouts/email_verification/hooks/use_email_verification.ts +0 -297
- package/src/components/layouts/email_verification/index.tsx +0 -297
- package/src/components/layouts/forgot_password/config/forgot_password_field_config.ts +0 -58
- package/src/components/layouts/forgot_password/hooks/use_forgot_password_form.ts +0 -179
- package/src/components/layouts/forgot_password/index.tsx +0 -168
- package/src/components/layouts/index.ts +0 -26
- package/src/components/layouts/login/config/login_field_config.ts +0 -67
- package/src/components/layouts/login/hooks/use_login_form.ts +0 -286
- package/src/components/layouts/login/index.tsx +0 -252
- package/src/components/layouts/my_settings/components/editable_field.tsx +0 -177
- package/src/components/layouts/my_settings/components/password_change_dialog.tsx +0 -301
- package/src/components/layouts/my_settings/components/profile_picture_dialog.tsx +0 -385
- package/src/components/layouts/my_settings/components/profile_picture_display.tsx +0 -66
- package/src/components/layouts/my_settings/components/profile_picture_gravatar_tab.tsx +0 -143
- package/src/components/layouts/my_settings/components/profile_picture_library_tab.tsx +0 -311
- package/src/components/layouts/my_settings/components/profile_picture_upload_tab.tsx +0 -341
- package/src/components/layouts/my_settings/config/my_settings_field_config.ts +0 -61
- package/src/components/layouts/my_settings/hooks/use_my_settings.ts +0 -458
- package/src/components/layouts/my_settings/index.tsx +0 -351
- package/src/components/layouts/register/config/register_field_config.ts +0 -101
- package/src/components/layouts/register/hooks/use_register_form.ts +0 -275
- package/src/components/layouts/register/index.tsx +0 -226
- package/src/components/layouts/reset_password/config/reset_password_field_config.ts +0 -86
- package/src/components/layouts/reset_password/hooks/use_reset_password_form.ts +0 -276
- package/src/components/layouts/reset_password/index.tsx +0 -294
- package/src/components/layouts/shared/components/already_logged_in_guard.tsx +0 -95
- package/src/components/layouts/shared/components/auth_page_shell.tsx +0 -36
- package/src/components/layouts/shared/components/field_error_message.tsx +0 -29
- package/src/components/layouts/shared/components/form_action_buttons.tsx +0 -64
- package/src/components/layouts/shared/components/form_field_wrapper.tsx +0 -44
- package/src/components/layouts/shared/components/form_header.tsx +0 -36
- package/src/components/layouts/shared/components/logout_button.tsx +0 -76
- package/src/components/layouts/shared/components/password_field.tsx +0 -72
- package/src/components/layouts/shared/components/profile_pic_menu.tsx +0 -321
- package/src/components/layouts/shared/components/profile_pic_menu_wrapper.tsx +0 -40
- package/src/components/layouts/shared/components/sidebar_layout_wrapper.tsx +0 -214
- package/src/components/layouts/shared/components/standalone_layout_wrapper.tsx +0 -53
- package/src/components/layouts/shared/components/two_column_auth_layout.tsx +0 -44
- package/src/components/layouts/shared/components/unauthorized_guard.tsx +0 -78
- package/src/components/layouts/shared/components/visual_panel.tsx +0 -41
- package/src/components/layouts/shared/config/layout_customization.ts +0 -95
- package/src/components/layouts/shared/data/layout_data_client.ts +0 -19
- package/src/components/layouts/shared/hooks/use_auth_status.ts +0 -103
- package/src/components/layouts/shared/hooks/use_hazo_auth.ts +0 -158
- package/src/components/layouts/shared/index.ts +0 -34
- package/src/components/layouts/shared/utils/ip_address.ts +0 -37
- package/src/components/layouts/shared/utils/validation.ts +0 -66
- package/src/components/layouts/user_management/components/roles_matrix.tsx +0 -607
- package/src/components/layouts/user_management/index.tsx +0 -1295
- package/src/components/ui/alert-dialog.tsx +0 -141
- package/src/components/ui/avatar.tsx +0 -50
- package/src/components/ui/button.tsx +0 -57
- package/src/components/ui/checkbox.tsx +0 -30
- package/src/components/ui/dialog.tsx +0 -122
- package/src/components/ui/dropdown-menu.tsx +0 -201
- package/src/components/ui/hazo_ui_tooltip.tsx +0 -67
- package/src/components/ui/index.ts +0 -22
- package/src/components/ui/input.tsx +0 -22
- package/src/components/ui/label.tsx +0 -26
- package/src/components/ui/separator.tsx +0 -31
- package/src/components/ui/sheet.tsx +0 -139
- package/src/components/ui/sidebar.tsx +0 -773
- package/src/components/ui/skeleton.tsx +0 -15
- package/src/components/ui/sonner.tsx +0 -31
- package/src/components/ui/switch.tsx +0 -29
- package/src/components/ui/table.tsx +0 -120
- package/src/components/ui/tabs.tsx +0 -55
- package/src/components/ui/tooltip.tsx +0 -32
- package/src/components/ui/vertical-tabs.tsx +0 -59
- package/src/hooks/use-mobile.tsx +0 -19
- package/src/index.ts +0 -7
- package/src/lib/already_logged_in_config.server.ts +0 -46
- package/src/lib/app_logger.ts +0 -24
- package/src/lib/auth/auth_cache.ts +0 -220
- package/src/lib/auth/auth_rate_limiter.ts +0 -121
- package/src/lib/auth/auth_types.ts +0 -65
- package/src/lib/auth/auth_utils.server.ts +0 -196
- package/src/lib/auth/hazo_get_auth.server.ts +0 -333
- package/src/lib/auth/index.ts +0 -23
- package/src/lib/auth/server_auth.ts +0 -88
- package/src/lib/auth_utility_config.server.ts +0 -136
- package/src/lib/config/config_loader.server.ts +0 -164
- package/src/lib/email_verification_config.server.ts +0 -32
- package/src/lib/file_types_config.server.ts +0 -25
- package/src/lib/forgot_password_config.server.ts +0 -32
- package/src/lib/hazo_connect_instance.server.ts +0 -101
- package/src/lib/hazo_connect_setup.server.ts +0 -194
- package/src/lib/hazo_connect_setup.ts +0 -54
- package/src/lib/index.ts +0 -44
- package/src/lib/login_config.server.ts +0 -71
- package/src/lib/messages_config.server.ts +0 -45
- package/src/lib/migrations/apply_migration.ts +0 -105
- package/src/lib/my_settings_config.server.ts +0 -135
- package/src/lib/password_requirements_config.server.ts +0 -39
- package/src/lib/profile_pic_menu_config.server.ts +0 -138
- package/src/lib/profile_picture_config.server.ts +0 -56
- package/src/lib/register_config.server.ts +0 -73
- package/src/lib/reset_password_config.server.ts +0 -75
- package/src/lib/services/email_service.ts +0 -581
- package/src/lib/services/email_verification_service.ts +0 -270
- package/src/lib/services/index.ts +0 -15
- package/src/lib/services/login_service.ts +0 -134
- package/src/lib/services/password_change_service.ts +0 -154
- package/src/lib/services/password_reset_service.ts +0 -405
- package/src/lib/services/profile_picture_remove_service.ts +0 -120
- package/src/lib/services/profile_picture_service.ts +0 -215
- package/src/lib/services/profile_picture_source_mapper.ts +0 -62
- package/src/lib/services/registration_service.ts +0 -184
- package/src/lib/services/token_service.ts +0 -240
- package/src/lib/services/user_profiles_service.ts +0 -143
- package/src/lib/services/user_update_service.ts +0 -141
- package/src/lib/ui_shell_config.server.ts +0 -73
- package/src/lib/ui_sizes_config.server.ts +0 -37
- package/src/lib/user_fields_config.server.ts +0 -31
- package/src/lib/user_management_config.server.ts +0 -39
- package/src/lib/utils/api_route_helpers.ts +0 -60
- package/src/lib/utils/error_sanitizer.ts +0 -75
- package/src/lib/utils.ts +0 -11
- package/src/middleware.ts +0 -94
- package/src/routes/index.ts +0 -34
- package/src/server/config/config_loader.ts +0 -496
- package/src/server/index.ts +0 -38
- package/src/server/logging/logger_service.ts +0 -56
- package/src/server/routes/root_router.ts +0 -16
- package/src/server/server.ts +0 -28
- package/src/server/types/app_types.ts +0 -74
- package/src/server/types/express.d.ts +0 -16
- package/src/stories/email_verification_layout.stories.tsx +0 -137
- package/src/stories/forgot_password_layout.stories.tsx +0 -85
- package/src/stories/login_layout.stories.tsx +0 -85
- package/src/stories/project_overview.stories.tsx +0 -33
- package/src/stories/register_layout.stories.tsx +0 -107
- package/tailwind.config.ts +0 -77
- package/tsconfig.build.json +0 -36
- package/tsconfig.json +0 -28
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
// file_description: API route for changing user password
|
|
2
|
-
// section: imports
|
|
3
|
-
import { NextRequest, NextResponse } from "next/server";
|
|
4
|
-
import { get_hazo_connect_instance } from "../../../../lib/hazo_connect_instance.server";
|
|
5
|
-
import { create_app_logger } from "../../../../lib/app_logger";
|
|
6
|
-
import { change_password } from "../../../../lib/services/password_change_service";
|
|
7
|
-
import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
|
|
8
|
-
import { require_auth } from "../../../../lib/auth/auth_utils.server";
|
|
9
|
-
import { get_auth_cache } from "../../../../lib/auth/auth_cache";
|
|
10
|
-
import { get_auth_utility_config } from "../../../../lib/auth_utility_config.server";
|
|
11
|
-
|
|
12
|
-
// section: api_handler
|
|
13
|
-
export async function POST(request: NextRequest) {
|
|
14
|
-
const logger = create_app_logger();
|
|
15
|
-
|
|
16
|
-
try {
|
|
17
|
-
// Use centralized auth check
|
|
18
|
-
let user_id: string;
|
|
19
|
-
try {
|
|
20
|
-
const user = await require_auth(request);
|
|
21
|
-
user_id = user.user_id;
|
|
22
|
-
} catch (error) {
|
|
23
|
-
if (error instanceof Error && error.message === "Authentication required") {
|
|
24
|
-
logger.warn("password_change_authentication_failed", {
|
|
25
|
-
filename: get_filename(),
|
|
26
|
-
line_number: get_line_number(),
|
|
27
|
-
error: "User not authenticated",
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
return NextResponse.json(
|
|
31
|
-
{ error: "Authentication required" },
|
|
32
|
-
{ status: 401 }
|
|
33
|
-
);
|
|
34
|
-
}
|
|
35
|
-
throw error;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const body = await request.json();
|
|
39
|
-
const { current_password, new_password } = body;
|
|
40
|
-
|
|
41
|
-
// Validate input
|
|
42
|
-
if (!current_password || !new_password) {
|
|
43
|
-
logger.warn("password_change_validation_failed", {
|
|
44
|
-
filename: get_filename(),
|
|
45
|
-
line_number: get_line_number(),
|
|
46
|
-
error: "Missing required fields",
|
|
47
|
-
has_current_password: !!current_password,
|
|
48
|
-
has_new_password: !!new_password,
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
return NextResponse.json(
|
|
52
|
-
{ error: "Current password and new password are required" },
|
|
53
|
-
{ status: 400 }
|
|
54
|
-
);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// Get singleton hazo_connect instance
|
|
58
|
-
const hazoConnect = get_hazo_connect_instance();
|
|
59
|
-
|
|
60
|
-
// Change password
|
|
61
|
-
const result = await change_password(hazoConnect, user_id, {
|
|
62
|
-
current_password,
|
|
63
|
-
new_password,
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
if (!result.success) {
|
|
67
|
-
logger.warn("password_change_failed", {
|
|
68
|
-
filename: get_filename(),
|
|
69
|
-
line_number: get_line_number(),
|
|
70
|
-
error: result.error,
|
|
71
|
-
user_id,
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
return NextResponse.json(
|
|
75
|
-
{ error: result.error || "Failed to change password" },
|
|
76
|
-
{ status: 400 }
|
|
77
|
-
);
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
// Invalidate user cache after password change
|
|
81
|
-
try {
|
|
82
|
-
const config = get_auth_utility_config();
|
|
83
|
-
const cache = get_auth_cache(
|
|
84
|
-
config.cache_max_users,
|
|
85
|
-
config.cache_ttl_minutes,
|
|
86
|
-
config.cache_max_age_minutes,
|
|
87
|
-
);
|
|
88
|
-
cache.invalidate_user(user_id);
|
|
89
|
-
} catch (cache_error) {
|
|
90
|
-
// Log but don't fail password change if cache invalidation fails
|
|
91
|
-
const cache_error_message =
|
|
92
|
-
cache_error instanceof Error ? cache_error.message : "Unknown error";
|
|
93
|
-
logger.warn("password_change_cache_invalidation_failed", {
|
|
94
|
-
filename: get_filename(),
|
|
95
|
-
line_number: get_line_number(),
|
|
96
|
-
user_id,
|
|
97
|
-
error: cache_error_message,
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
logger.info("password_change_successful", {
|
|
102
|
-
filename: get_filename(),
|
|
103
|
-
line_number: get_line_number(),
|
|
104
|
-
user_id,
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
return NextResponse.json(
|
|
108
|
-
{
|
|
109
|
-
success: true,
|
|
110
|
-
message: "Password changed successfully",
|
|
111
|
-
},
|
|
112
|
-
{ status: 200 }
|
|
113
|
-
);
|
|
114
|
-
} catch (error) {
|
|
115
|
-
const error_message =
|
|
116
|
-
error instanceof Error ? error.message : "Unknown error";
|
|
117
|
-
const error_stack = error instanceof Error ? error.stack : undefined;
|
|
118
|
-
|
|
119
|
-
logger.error("password_change_error", {
|
|
120
|
-
filename: get_filename(),
|
|
121
|
-
line_number: get_line_number(),
|
|
122
|
-
error_message,
|
|
123
|
-
error_stack,
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
return NextResponse.json(
|
|
127
|
-
{ error: "Failed to change password. Please try again." },
|
|
128
|
-
{ status: 500 }
|
|
129
|
-
);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
// file_description: API route for password reset requests using hazo_connect
|
|
2
|
-
// section: imports
|
|
3
|
-
import { NextRequest, NextResponse } from "next/server";
|
|
4
|
-
import { get_hazo_connect_instance } from "../../../../lib/hazo_connect_instance.server";
|
|
5
|
-
import { create_app_logger } from "../../../../lib/app_logger";
|
|
6
|
-
import { request_password_reset } from "../../../../lib/services/password_reset_service";
|
|
7
|
-
import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
|
|
8
|
-
|
|
9
|
-
// section: api_handler
|
|
10
|
-
export async function POST(request: NextRequest) {
|
|
11
|
-
const logger = create_app_logger();
|
|
12
|
-
|
|
13
|
-
try {
|
|
14
|
-
const body = await request.json();
|
|
15
|
-
const { email } = body;
|
|
16
|
-
|
|
17
|
-
// Validate input
|
|
18
|
-
if (!email) {
|
|
19
|
-
logger.warn("password_reset_validation_failed", {
|
|
20
|
-
filename: get_filename(),
|
|
21
|
-
line_number: get_line_number(),
|
|
22
|
-
email: email || "missing",
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
return NextResponse.json(
|
|
26
|
-
{ error: "Email is required" },
|
|
27
|
-
{ status: 400 }
|
|
28
|
-
);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
// Validate email format
|
|
32
|
-
const email_pattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
|
|
33
|
-
if (!email_pattern.test(email)) {
|
|
34
|
-
logger.warn("password_reset_invalid_email", {
|
|
35
|
-
filename: get_filename(),
|
|
36
|
-
line_number: get_line_number(),
|
|
37
|
-
email,
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
return NextResponse.json(
|
|
41
|
-
{ error: "Invalid email address format" },
|
|
42
|
-
{ status: 400 }
|
|
43
|
-
);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
// Get singleton hazo_connect instance (reuses same connection across all routes)
|
|
47
|
-
const hazoConnect = get_hazo_connect_instance();
|
|
48
|
-
|
|
49
|
-
// Request password reset using the password reset service
|
|
50
|
-
const result = await request_password_reset(hazoConnect, {
|
|
51
|
-
email,
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
if (!result.success) {
|
|
55
|
-
logger.warn("password_reset_failed", {
|
|
56
|
-
filename: get_filename(),
|
|
57
|
-
line_number: get_line_number(),
|
|
58
|
-
email,
|
|
59
|
-
error: result.error,
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
// Still return 200 OK to prevent email enumeration attacks
|
|
63
|
-
return NextResponse.json(
|
|
64
|
-
{
|
|
65
|
-
success: true,
|
|
66
|
-
message: "If an account with that email exists, a password reset link has been sent.",
|
|
67
|
-
},
|
|
68
|
-
{ status: 200 }
|
|
69
|
-
);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
logger.info("password_reset_requested", {
|
|
73
|
-
filename: get_filename(),
|
|
74
|
-
line_number: get_line_number(),
|
|
75
|
-
email,
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
// Always return success to prevent email enumeration attacks
|
|
79
|
-
return NextResponse.json(
|
|
80
|
-
{
|
|
81
|
-
success: true,
|
|
82
|
-
message: "If an account with that email exists, a password reset link has been sent.",
|
|
83
|
-
},
|
|
84
|
-
{ status: 200 }
|
|
85
|
-
);
|
|
86
|
-
} catch (error) {
|
|
87
|
-
const error_message = error instanceof Error ? error.message : "Unknown error";
|
|
88
|
-
const error_stack = error instanceof Error ? error.stack : undefined;
|
|
89
|
-
|
|
90
|
-
logger.error("password_reset_error", {
|
|
91
|
-
filename: get_filename(),
|
|
92
|
-
line_number: get_line_number(),
|
|
93
|
-
error_message,
|
|
94
|
-
error_stack,
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
// Still return 200 OK to prevent email enumeration attacks
|
|
98
|
-
return NextResponse.json(
|
|
99
|
-
{
|
|
100
|
-
success: true,
|
|
101
|
-
message: "If an account with that email exists, a password reset link has been sent.",
|
|
102
|
-
},
|
|
103
|
-
{ status: 200 }
|
|
104
|
-
);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
// file_description: API route for hazo_get_auth utility (client-side calls)
|
|
2
|
-
// section: imports
|
|
3
|
-
import { NextRequest, NextResponse } from "next/server";
|
|
4
|
-
import { hazo_get_auth } from "../../../../lib/auth/hazo_get_auth.server";
|
|
5
|
-
import { PermissionError } from "../../../../lib/auth/auth_types";
|
|
6
|
-
import { create_app_logger } from "../../../../lib/app_logger";
|
|
7
|
-
import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
|
|
8
|
-
|
|
9
|
-
// section: route_config
|
|
10
|
-
export const dynamic = "force-dynamic";
|
|
11
|
-
|
|
12
|
-
// section: api_handler
|
|
13
|
-
/**
|
|
14
|
-
* POST - Get authentication status and permissions
|
|
15
|
-
* Body: { required_permissions?: string[], strict?: boolean }
|
|
16
|
-
*/
|
|
17
|
-
export async function POST(request: NextRequest) {
|
|
18
|
-
const logger = create_app_logger();
|
|
19
|
-
|
|
20
|
-
try {
|
|
21
|
-
const body = await request.json();
|
|
22
|
-
const { required_permissions, strict } = body;
|
|
23
|
-
|
|
24
|
-
// Validate required_permissions if provided
|
|
25
|
-
if (
|
|
26
|
-
required_permissions !== undefined &&
|
|
27
|
-
(!Array.isArray(required_permissions) ||
|
|
28
|
-
!required_permissions.every((p) => typeof p === "string"))
|
|
29
|
-
) {
|
|
30
|
-
return NextResponse.json(
|
|
31
|
-
{ error: "required_permissions must be an array of strings" },
|
|
32
|
-
{ status: 400 },
|
|
33
|
-
);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
// Validate strict if provided
|
|
37
|
-
if (strict !== undefined && typeof strict !== "boolean") {
|
|
38
|
-
return NextResponse.json(
|
|
39
|
-
{ error: "strict must be a boolean" },
|
|
40
|
-
{ status: 400 },
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
// Call hazo_get_auth
|
|
45
|
-
const result = await hazo_get_auth(request, {
|
|
46
|
-
required_permissions,
|
|
47
|
-
strict,
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
return NextResponse.json(result, { status: 200 });
|
|
51
|
-
} catch (error) {
|
|
52
|
-
// Handle PermissionError (strict mode)
|
|
53
|
-
if (error instanceof PermissionError) {
|
|
54
|
-
logger.warn("auth_utility_permission_error", {
|
|
55
|
-
filename: get_filename(),
|
|
56
|
-
line_number: get_line_number(),
|
|
57
|
-
missing_permissions: error.missing_permissions,
|
|
58
|
-
required_permissions: error.required_permissions,
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
return NextResponse.json(
|
|
62
|
-
{
|
|
63
|
-
error: "Permission denied",
|
|
64
|
-
missing_permissions: error.missing_permissions,
|
|
65
|
-
user_friendly_message: error.user_friendly_message,
|
|
66
|
-
},
|
|
67
|
-
{ status: 403 },
|
|
68
|
-
);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
// Handle other errors
|
|
72
|
-
const error_message =
|
|
73
|
-
error instanceof Error ? error.message : "Unknown error";
|
|
74
|
-
const error_stack = error instanceof Error ? error.stack : undefined;
|
|
75
|
-
|
|
76
|
-
logger.error("auth_utility_api_error", {
|
|
77
|
-
filename: get_filename(),
|
|
78
|
-
line_number: get_line_number(),
|
|
79
|
-
error_message,
|
|
80
|
-
error_stack,
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
return NextResponse.json(
|
|
84
|
-
{ error: error_message },
|
|
85
|
-
{ status: 500 },
|
|
86
|
-
);
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
|
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
// file_description: API route for manual cache invalidation (admin endpoint)
|
|
2
|
-
// section: imports
|
|
3
|
-
import { NextRequest, NextResponse } from "next/server";
|
|
4
|
-
import { get_auth_cache } from "../../../../lib/auth/auth_cache";
|
|
5
|
-
import { get_auth_utility_config } from "../../../../lib/auth_utility_config.server";
|
|
6
|
-
import { create_app_logger } from "../../../../lib/app_logger";
|
|
7
|
-
import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
|
|
8
|
-
import { hazo_get_auth } from "../../../../lib/auth/hazo_get_auth.server";
|
|
9
|
-
|
|
10
|
-
// section: route_config
|
|
11
|
-
export const dynamic = "force-dynamic";
|
|
12
|
-
|
|
13
|
-
// section: api_handler
|
|
14
|
-
/**
|
|
15
|
-
* POST - Manually invalidate auth cache
|
|
16
|
-
* Body: { user_id?: string, role_ids?: number[], invalidate_all?: boolean }
|
|
17
|
-
* Requires admin permission (checked via hazo_get_auth)
|
|
18
|
-
*/
|
|
19
|
-
export async function POST(request: NextRequest) {
|
|
20
|
-
const logger = create_app_logger();
|
|
21
|
-
|
|
22
|
-
try {
|
|
23
|
-
// Check authentication and admin permission
|
|
24
|
-
const auth_result = await hazo_get_auth(request, {
|
|
25
|
-
required_permissions: ["admin_user_management"], // Require admin permission
|
|
26
|
-
strict: true, // Throw error if not authorized
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
if (!auth_result.authenticated) {
|
|
30
|
-
return NextResponse.json(
|
|
31
|
-
{ error: "Authentication required" },
|
|
32
|
-
{ status: 401 },
|
|
33
|
-
);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
const body = await request.json();
|
|
37
|
-
const { user_id, role_ids, invalidate_all } = body;
|
|
38
|
-
|
|
39
|
-
// Validate input
|
|
40
|
-
if (invalidate_all !== undefined && typeof invalidate_all !== "boolean") {
|
|
41
|
-
return NextResponse.json(
|
|
42
|
-
{ error: "invalidate_all must be a boolean" },
|
|
43
|
-
{ status: 400 },
|
|
44
|
-
);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
if (user_id !== undefined && typeof user_id !== "string") {
|
|
48
|
-
return NextResponse.json(
|
|
49
|
-
{ error: "user_id must be a string" },
|
|
50
|
-
{ status: 400 },
|
|
51
|
-
);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
if (
|
|
55
|
-
role_ids !== undefined &&
|
|
56
|
-
(!Array.isArray(role_ids) ||
|
|
57
|
-
!role_ids.every((id) => typeof id === "number"))
|
|
58
|
-
) {
|
|
59
|
-
return NextResponse.json(
|
|
60
|
-
{ error: "role_ids must be an array of numbers" },
|
|
61
|
-
{ status: 400 },
|
|
62
|
-
);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
const config = get_auth_utility_config();
|
|
66
|
-
const cache = get_auth_cache(
|
|
67
|
-
config.cache_max_users,
|
|
68
|
-
config.cache_ttl_minutes,
|
|
69
|
-
config.cache_max_age_minutes,
|
|
70
|
-
);
|
|
71
|
-
|
|
72
|
-
// Perform invalidation
|
|
73
|
-
if (invalidate_all === true) {
|
|
74
|
-
cache.invalidate_all();
|
|
75
|
-
logger.info("auth_cache_invalidated_all", {
|
|
76
|
-
filename: get_filename(),
|
|
77
|
-
line_number: get_line_number(),
|
|
78
|
-
user_id: auth_result.user.id,
|
|
79
|
-
});
|
|
80
|
-
} else if (user_id) {
|
|
81
|
-
cache.invalidate_user(user_id);
|
|
82
|
-
logger.info("auth_cache_invalidated_user", {
|
|
83
|
-
filename: get_filename(),
|
|
84
|
-
line_number: get_line_number(),
|
|
85
|
-
invalidated_user_id: user_id,
|
|
86
|
-
admin_user_id: auth_result.user.id,
|
|
87
|
-
});
|
|
88
|
-
} else if (role_ids && role_ids.length > 0) {
|
|
89
|
-
cache.invalidate_by_roles(role_ids);
|
|
90
|
-
logger.info("auth_cache_invalidated_roles", {
|
|
91
|
-
filename: get_filename(),
|
|
92
|
-
line_number: get_line_number(),
|
|
93
|
-
role_ids,
|
|
94
|
-
admin_user_id: auth_result.user.id,
|
|
95
|
-
});
|
|
96
|
-
} else {
|
|
97
|
-
return NextResponse.json(
|
|
98
|
-
{
|
|
99
|
-
error:
|
|
100
|
-
"Must provide user_id, role_ids, or invalidate_all=true",
|
|
101
|
-
},
|
|
102
|
-
{ status: 400 },
|
|
103
|
-
);
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
return NextResponse.json(
|
|
107
|
-
{
|
|
108
|
-
success: true,
|
|
109
|
-
message: "Cache invalidated successfully",
|
|
110
|
-
},
|
|
111
|
-
{ status: 200 },
|
|
112
|
-
);
|
|
113
|
-
} catch (error) {
|
|
114
|
-
// Handle PermissionError (strict mode)
|
|
115
|
-
if (error instanceof Error && error.name === "PermissionError") {
|
|
116
|
-
return NextResponse.json(
|
|
117
|
-
{ error: "Permission denied. Admin access required." },
|
|
118
|
-
{ status: 403 },
|
|
119
|
-
);
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
const error_message =
|
|
123
|
-
error instanceof Error ? error.message : "Unknown error";
|
|
124
|
-
const error_stack = error instanceof Error ? error.stack : undefined;
|
|
125
|
-
|
|
126
|
-
logger.error("auth_cache_invalidation_error", {
|
|
127
|
-
filename: get_filename(),
|
|
128
|
-
line_number: get_line_number(),
|
|
129
|
-
error_message,
|
|
130
|
-
error_stack,
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
return NextResponse.json(
|
|
134
|
-
{ error: "Failed to invalidate cache" },
|
|
135
|
-
{ status: 500 },
|
|
136
|
-
);
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
// file_description: API route for listing library photo categories and photos in categories
|
|
2
|
-
// section: imports
|
|
3
|
-
import { NextRequest, NextResponse } from "next/server";
|
|
4
|
-
import { get_library_categories, get_library_photos } from "../../../../lib/services/profile_picture_service";
|
|
5
|
-
import { create_app_logger } from "../../../../lib/app_logger";
|
|
6
|
-
import { get_filename, get_line_number } from "../../../../lib/utils/api_route_helpers";
|
|
7
|
-
|
|
8
|
-
// section: route_config
|
|
9
|
-
export const dynamic = 'force-dynamic';
|
|
10
|
-
|
|
11
|
-
// section: api_handler
|
|
12
|
-
export async function GET(request: NextRequest) {
|
|
13
|
-
const logger = create_app_logger();
|
|
14
|
-
|
|
15
|
-
try {
|
|
16
|
-
const { searchParams } = new URL(request.url);
|
|
17
|
-
const category = searchParams.get("category");
|
|
18
|
-
|
|
19
|
-
if (category) {
|
|
20
|
-
// Return photos in the specified category
|
|
21
|
-
const photos = get_library_photos(category);
|
|
22
|
-
|
|
23
|
-
logger.info("library_photos_category_requested", {
|
|
24
|
-
filename: get_filename(),
|
|
25
|
-
line_number: get_line_number(),
|
|
26
|
-
category,
|
|
27
|
-
photoCount: photos.length,
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
return NextResponse.json(
|
|
31
|
-
{
|
|
32
|
-
success: true,
|
|
33
|
-
category,
|
|
34
|
-
photos,
|
|
35
|
-
},
|
|
36
|
-
{ status: 200 }
|
|
37
|
-
);
|
|
38
|
-
} else {
|
|
39
|
-
// Return list of categories
|
|
40
|
-
const categories = get_library_categories();
|
|
41
|
-
|
|
42
|
-
logger.info("library_categories_requested", {
|
|
43
|
-
filename: get_filename(),
|
|
44
|
-
line_number: get_line_number(),
|
|
45
|
-
categoryCount: categories.length,
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
return NextResponse.json(
|
|
49
|
-
{
|
|
50
|
-
success: true,
|
|
51
|
-
categories,
|
|
52
|
-
},
|
|
53
|
-
{ status: 200 }
|
|
54
|
-
);
|
|
55
|
-
}
|
|
56
|
-
} catch (error) {
|
|
57
|
-
const error_message = error instanceof Error ? error.message : "Unknown error";
|
|
58
|
-
const error_stack = error instanceof Error ? error.stack : undefined;
|
|
59
|
-
|
|
60
|
-
logger.error("library_photos_error", {
|
|
61
|
-
filename: get_filename(),
|
|
62
|
-
line_number: get_line_number(),
|
|
63
|
-
error_message,
|
|
64
|
-
error_stack,
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
return NextResponse.json(
|
|
68
|
-
{ error: "Failed to fetch library photos" },
|
|
69
|
-
{ status: 500 }
|
|
70
|
-
);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
|