Clean error alerts and harden startup migration
This commit is contained in:
@@ -1,26 +1,37 @@
|
||||
import axios from "axios";
|
||||
import { clearAuthClientState, getCsrfToken } from "./auth";
|
||||
|
||||
function looksLikeHtml(value: string) {
|
||||
return /<\s*html\b|<\s*body\b|<\s*head\b|<\s*title\b|<\s*!doctype\b/i.test(value);
|
||||
}
|
||||
|
||||
function sanitizeServerMessage(value: string, fallback: string) {
|
||||
const text = value.trim();
|
||||
if (!text) return fallback;
|
||||
if (looksLikeHtml(text)) return fallback;
|
||||
return text.length > 300 ? `${text.slice(0, 297).trimEnd()}...` : text;
|
||||
}
|
||||
|
||||
export function getApiErrorMessage(error: any, fallback = "Request failed.") {
|
||||
const data = error?.response?.data;
|
||||
if (typeof data === "string" && data.trim()) return data.trim();
|
||||
if (typeof data?.message === "string" && data.message.trim()) return data.message.trim();
|
||||
if (typeof data?.detail === "string" && data.detail.trim()) return data.detail.trim();
|
||||
if (typeof data?.title === "string" && data.title.trim()) return data.title.trim();
|
||||
if (typeof data === "string" && data.trim()) return sanitizeServerMessage(data, fallback);
|
||||
if (typeof data?.message === "string" && data.message.trim()) return sanitizeServerMessage(data.message, fallback);
|
||||
if (typeof data?.detail === "string" && data.detail.trim()) return sanitizeServerMessage(data.detail, fallback);
|
||||
if (typeof data?.title === "string" && data.title.trim()) return sanitizeServerMessage(data.title, fallback);
|
||||
if (Array.isArray(data?.errors)) {
|
||||
const first = data.errors.find((value: unknown) => typeof value === "string" && value.trim());
|
||||
if (first) return first;
|
||||
if (first) return sanitizeServerMessage(first, fallback);
|
||||
}
|
||||
if (data?.errors && typeof data.errors === "object") {
|
||||
for (const value of Object.values(data.errors)) {
|
||||
if (Array.isArray(value)) {
|
||||
const first = value.find((item: unknown) => typeof item === "string" && item.trim());
|
||||
if (first) return first;
|
||||
if (first) return sanitizeServerMessage(first, fallback);
|
||||
}
|
||||
if (typeof value === "string" && value.trim()) return value.trim();
|
||||
if (typeof value === "string" && value.trim()) return sanitizeServerMessage(value, fallback);
|
||||
}
|
||||
}
|
||||
if (typeof error?.message === "string" && error.message.trim()) return error.message.trim();
|
||||
if (typeof error?.message === "string" && error.message.trim()) return sanitizeServerMessage(error.message, fallback);
|
||||
return fallback;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user