From 61d0aeba2ec3590ddea08987b1f834e0d79e9fa0 Mon Sep 17 00:00:00 2001 From: Hazelnoot Date: Mon, 3 Mar 2025 01:03:21 -0500 Subject: add renderInlineError to serialize errors in a consistent way --- packages/backend/src/misc/render-inline-error.ts | 35 ++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 packages/backend/src/misc/render-inline-error.ts (limited to 'packages/backend/src/misc/render-inline-error.ts') diff --git a/packages/backend/src/misc/render-inline-error.ts b/packages/backend/src/misc/render-inline-error.ts new file mode 100644 index 0000000000..36de0262ef --- /dev/null +++ b/packages/backend/src/misc/render-inline-error.ts @@ -0,0 +1,35 @@ +/* + * SPDX-FileCopyrightText: hazelnoot and other Sharkey contributors + * SPDX-License-Identifier: AGPL-3.0-only + */ + +import { IdentifiableError } from '@/misc/identifiable-error.js'; +import { StatusError } from '@/misc/status-error.js'; + +export function renderInlineError(err: unknown): string { + if (err instanceof IdentifiableError) { + if (err.message) { + return `${err.name} ${err.id}: ${err.message}`; + } else { + return `${err.name} ${err.id}`; + } + } + + if (err instanceof StatusError) { + if (err.message) { + return `${err.name} ${err.statusCode}: ${err.message}`; + } else { + return `${err.name} ${err.statusCode}`; + } + } + + if (err instanceof Error) { + if (err.message) { + return `${err.name}: ${err.message}`; + } else { + return err.name; + } + } + + return String(err); +} -- cgit v1.2.3-freya