From ae9030a4b05937556d3fa171f0b64cadb29024ef Mon Sep 17 00:00:00 2001 From: NotII <46204250+NotII@users.noreply.github.com> Date: Mon, 10 Mar 2025 18:31:05 +0000 Subject: [PATCH] Update server-service.ts --- lib/server-service.ts | 59 +++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 57 insertions(+), 2 deletions(-) diff --git a/lib/server-service.ts b/lib/server-service.ts index d3badfb..88ad6fa 100644 --- a/lib/server-service.ts +++ b/lib/server-service.ts @@ -5,9 +5,18 @@ import { redirect } from 'next/navigation'; * Gets the base URL for server API requests with proper fallbacks */ function getBaseUrl() { + // Check if we're running in Tor mode + const torMode = process.env.NEXT_PUBLIC_TOR_MODE === 'true'; + // First check for the specific server API URL environment variable if (process.env.SERVER_API_URL) { console.log(`Using SERVER_API_URL: ${process.env.SERVER_API_URL}`); + + // If we're in Tor mode and the SERVER_API_URL is set to a relative path, use it directly + if (torMode && process.env.SERVER_API_URL.startsWith('/')) { + return process.env.SERVER_API_URL; + } + return process.env.SERVER_API_URL; } @@ -20,6 +29,11 @@ function getBaseUrl() { // Check if we're running in a container/production environment const inContainer = process.env.NODE_ENV === 'production'; + // If in Tor mode, prefer relative URLs + if (torMode && apiUrl && apiUrl.startsWith('/')) { + return apiUrl; + } + // We need to get the host from somewhere to construct the URL // In production, we can rely on the VERCEL_URL or similar if (process.env.VERCEL_URL) { @@ -37,13 +51,22 @@ function getBaseUrl() { const port = process.env.INTERNAL_API_PORT || '3000'; const protocol = (process.env.USE_HTTPS === 'false') ? 'http' : 'https'; + // If in Tor mode, prefer relative URLs + if (torMode) { + return apiUrl.startsWith('/') ? apiUrl : `/${apiUrl}`; + } + // Otherwise, it's likely a relative path like /api // Use localhost with the correct port for container environments return `${protocol}://localhost:${port}${apiUrl.startsWith('/') ? apiUrl : `/${apiUrl}`}`; } - // Last resort fallback - // Use http for container environment, https for external services + // Last resort fallback - if in Tor mode, use a relative URL + if (torMode) { + return '/api'; + } + + // For regular container environments const protocol = (process.env.USE_HTTPS === 'false') ? 'http' : 'https'; const port = process.env.INTERNAL_API_PORT || '3000'; return `${protocol}://localhost:${port}/api`; @@ -63,7 +86,39 @@ export async function fetchServer( try { const baseUrl = getBaseUrl(); + const torMode = process.env.NEXT_PUBLIC_TOR_MODE === 'true'; + // Special handling for Tor mode + if (torMode) { + // For Tor, we need to be extra careful with URL construction + + // Remove leading slash from endpoint if present + const normalizedEndpoint = endpoint.startsWith('/') ? endpoint.substring(1) : endpoint; + + // If baseUrl is a relative path (starts with /) + if (baseUrl.startsWith('/')) { + // Combine paths carefully to create a relative URL + const url = `${baseUrl}${baseUrl.endsWith('/') ? '' : '/'}${normalizedEndpoint}`; + console.log(`Tor mode: Using relative URL for server fetch: ${url}`); + + const res = await fetch(url, { + ...options, + headers: { + 'Content-Type': 'application/json', + Authorization: `Bearer ${authToken}`, + ...options.headers, + }, + cache: 'no-store', + }); + + if (res.status === 401) redirect('/login'); + if (!res.ok) throw new Error(`Request failed: ${res.statusText}`); + + return res.json(); + } + } + + // Regular URL construction for non-Tor environments // Ensure endpoint doesn't start with a slash if baseUrl ends with one const normalizedEndpoint = endpoint.startsWith('/') ? endpoint.substring(1) : endpoint;