sendou.ink/app/utils/sql.ts
Kalle c1cc82c807
Some checks are pending
E2E Tests / e2e (push) Waiting to run
Tests and checks on push / run-checks-and-tests (push) Waiting to run
Updates translation progress / update-translation-progress-issue (push) Waiting to run
Migrate /u/:identifier/edit to SendouForm, fix bad IGN (#2849)
2026-03-03 07:12:04 +02:00

30 lines
717 B
TypeScript

export function errorIsSqliteForeignKeyConstraintFailure(
error: unknown,
): error is Error {
return (
error instanceof Error &&
error?.message?.includes("FOREIGN KEY constraint failed")
);
}
export function parseDBJsonArray(value: any) {
const parsed = JSON.parse(value);
// If the returned array of JSON objects from DB is empty
// it will be returned as object with all values being null
// this is a (hacky) workaround for that
return parsed.filter((item: any) =>
Object.values(item).some((val) => val !== null),
);
}
export function parseDBArray(value: any) {
const parsed = JSON.parse(value);
if (!parsed || (parsed.length === 1 && parsed[0] === null)) {
return [];
}
return parsed;
}