Spracherkennung für: .ts vermutete Sprache: Unknown {[0] [0] [0]} [Methode: Schwerpunktbildung, einfache Gewichte, sechs Dimensionen]
import { isLoopbackHost } from "../gateway/net.js";
type HostSource = string | null | undefined;
type CanvasHostUrlParams = {
canvasPort?: number;
hostOverride?: HostSource;
requestHost?: HostSource;
forwardedProto?: HostSource | HostSource[];
localAddress?: HostSource;
scheme?: "http" | "https";
};
const normalizeHost = (value: HostSource, rejectLoopback: boolean) => {
if (!value) {
return "";
}
const trimmed = value.trim();
if (!trimmed) {
return "";
}
if (rejectLoopback && isLoopbackHost(trimmed)) {
return "";
}
return trimmed;
};
type ParsedHostHeader = {
host: string;
port?: number;
};
const parseHostHeader = (value: HostSource): ParsedHostHeader => {
if (!value) {
return { host: "" };
}
try {
const parsed = new URL(`
http://${value.trim()}`);
const portRaw = parsed.port.trim();
const port = portRaw ? Number.parseInt(portRaw, 10) : undefined;
return {
host: parsed.hostname,
port: Number.isFinite(port) ? port : undefined,
};
} catch {
return { host: "" };
}
};
const parseForwardedProto = (value: HostSource | HostSource[]) => {
if (Array.isArray(value)) {
return value[0];
}
return value;
};
export function resolveCanvasHostUrl(params: CanvasHostUrlParams) {
const port = params.canvasPort;
if (!port) {
return undefined;
}
const scheme =
params.scheme ??
(parseForwardedProto(params.forwardedProto)?.trim() === "https" ? "https" : "http");
const override = normalizeHost(params.hostOverride, true);
const parsedRequestHost = parseHostHeader(params.requestHost);
const requestHost = normalizeHost(parsedRequestHost.host, !!override);
const localAddress = normalizeHost(params.localAddress, Boolean(override || requestHos
t));
const host = override || requestHost || localAddress;
if (!host) {
return undefined;
}
// When the websocket is proxied over HTTPS (for example Tailscale Serve), the gateway's
// internal listener still runs on 18789. In that case, expose the public port instead of
// advertising the internal one back to clients.
let exposedPort = port;
if (!override && requestHost && port === 18789) {
if (parsedRequestHost.port && parsedRequestHost.port > 0) {
exposedPort = parsedRequestHost.port;
} else if (scheme === "https") {
exposedPort = 443;
} else if (scheme === "http") {
exposedPort = 80;
}
}
const formatted = host.includes(":") ? `[${host}]` : host;
return `${scheme}://${formatted}:${exposedPort}`;
}