Files
chaos-api/web/default/src/lib/secure-verification.ts
T
t0ng7u d146e45e2f ⚖️ chore(web/default): add reusable copyright header tooling
Add a Bun script to apply and normalize AGPL copyright headers across the default frontend source files.

The script keeps headers idempotent, upgrades existing headers to the 2023-2026 QuantumNous range, and is exposed through `bun run copyright` for future maintenance.
2026-05-09 11:35:07 +08:00

67 lines
1.9 KiB
TypeScript
Vendored

/*
Copyright (C) 2023-2026 QuantumNous
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
For commercial licensing, please contact support@quantumnous.com
*/
import type { AxiosError } from 'axios'
export interface VerificationRequiredInfo {
code?: string
message: string
required: boolean
}
/**
* Determine whether an Axios error indicates secure verification is required.
*/
export function isVerificationRequiredError(
error: unknown
): error is AxiosError {
if (!error || typeof error !== 'object') return false
const axiosError = error as AxiosError<{ code?: string }>
const status = axiosError.response?.status
if (status !== 403) return false
const code = axiosError.response?.data?.code
if (!code) return false
const verificationCodes = new Set([
'VERIFICATION_REQUIRED',
'VERIFICATION_EXPIRED',
'VERIFICATION_INVALID',
])
return verificationCodes.has(code)
}
/**
* Extract verification requirement info from an Axios error.
*/
export function extractVerificationInfo(
error: unknown
): VerificationRequiredInfo {
const axiosError = error as AxiosError<{ code?: string; message?: string }>
const code = axiosError.response?.data?.code
const message =
axiosError.response?.data?.message ?? 'Secure verification is required'
return {
code,
message,
required: true,
}
}