mirror of
https://github.com/nicotsx/zerobyte.git
synced 2026-04-18 13:57:52 -04:00
test: use better-auth built-in test plugin refactor: map auth errors server side refactor: native trusted providers callback usage <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit ## Release Notes * **New Features** * Enhanced SSO authentication error messaging with specific guidance for different failure scenarios (account linking required, email verification needed, banned accounts, invite-only access). * **Chores** * Updated authentication dependencies to version 1.5.0. * **Tests** * Extended test coverage for SSO error code handling and authentication scenarios. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
46 lines
1.4 KiB
TypeScript
46 lines
1.4 KiB
TypeScript
export type LoginErrorCode =
|
|
| "ACCOUNT_LINK_REQUIRED"
|
|
| "EMAIL_NOT_VERIFIED"
|
|
| "INVITE_REQUIRED"
|
|
| "BANNED_USER"
|
|
| "SSO_LOGIN_FAILED";
|
|
|
|
const VALID_ERROR_CODES: Set<LoginErrorCode> = new Set([
|
|
"ACCOUNT_LINK_REQUIRED",
|
|
"EMAIL_NOT_VERIFIED",
|
|
"INVITE_REQUIRED",
|
|
"BANNED_USER",
|
|
"SSO_LOGIN_FAILED",
|
|
]);
|
|
|
|
export function decodeLoginError(error?: string): LoginErrorCode | null {
|
|
if (!error) {
|
|
return null;
|
|
}
|
|
|
|
const code = decodeURIComponent(error);
|
|
|
|
if (VALID_ERROR_CODES.has(code as LoginErrorCode)) {
|
|
return code as LoginErrorCode;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
export function getLoginErrorDescription(errorCode: LoginErrorCode | null): string | null {
|
|
switch (errorCode) {
|
|
case "ACCOUNT_LINK_REQUIRED":
|
|
return "Your account exists but is not linked to this SSO provider. Sign in with username/password first, then enable auto linking in your provider settings or contact your administrator.";
|
|
case "EMAIL_NOT_VERIFIED":
|
|
return "Your identity provider did not mark your email as verified.";
|
|
case "INVITE_REQUIRED":
|
|
return "Access is invite-only. Ask an organization admin to send you an invitation before signing in with SSO.";
|
|
case "BANNED_USER":
|
|
return "You have been banned from this application. Please contact support if you believe this is an error.";
|
|
case "SSO_LOGIN_FAILED":
|
|
return "SSO authentication failed. Please try again.";
|
|
default:
|
|
return null;
|
|
}
|
|
}
|