presenton/servers/nextjs/utils/api.ts
sudipnext 5766e252aa feat: Implement PDF export functionality with session handling
- Added middleware to handle session cookies for the PDF export route.
- Introduced a new API endpoint for exporting presentation data using session cookies.
- Updated the PdfMakerPage component to accept and utilize the export cookie.
- Enhanced the presentation export logic to include session token extraction from cookies.
- Updated routing configuration to include the new PDF maker path.
2026-04-27 21:13:57 +05:45

122 lines
3.4 KiB
TypeScript

// Utility to get the FastAPI base URL
export function getFastAPIUrl(): string {
if (process.env.NEXT_PUBLIC_FAST_API) {
return process.env.NEXT_PUBLIC_FAST_API;
}
const queryFastApiUrl = getFastApiUrlFromQuery();
if (queryFastApiUrl) {
return queryFastApiUrl;
}
// Docker/web runtime: route backend assets and APIs through current origin
// (nginx reverse-proxies /api/v1, /app_data, /static).
if (typeof window !== "undefined") {
return window.location.origin;
}
return "http://127.0.0.1:5000";
}
function getFastApiUrlFromQuery(): string | null {
if (typeof window === "undefined") return null;
try {
const params = new URLSearchParams(window.location.search);
const value = params.get("fastapiUrl");
if (!value) return null;
const parsed = new URL(value);
if (parsed.protocol !== "http:" && parsed.protocol !== "https:") {
return null;
}
return parsed.origin;
} catch {
return null;
}
}
function isAbsoluteHttpUrl(path: string): boolean {
return /^https?:\/\//i.test(path);
}
function withLeadingSlash(path: string): string {
return path.startsWith("/") ? path : `/${path}`;
}
// Utility to construct API URL for Docker/web runtime.
export function getApiUrl(path: string): string {
if (isAbsoluteHttpUrl(path)) {
return path;
}
const normalizedPath = withLeadingSlash(path);
const isFastApiEndpoint = normalizedPath.startsWith("/api/v1/");
const hasConfiguredFastApi = !!process.env.NEXT_PUBLIC_FAST_API;
// In web/docker, /api/v1 is typically reverse-proxied by the web server.
// Keep browser requests same-origin so session cookies stay attached.
// Server-side callers can still use configured FastAPI base URLs directly.
if (isFastApiEndpoint && typeof window === "undefined" && hasConfiguredFastApi) {
return `${getFastAPIUrl()}${normalizedPath}`;
}
return normalizedPath;
}
/**
* getApiUrl may return a path without host (e.g. `/api/v1/...`). A single-argument
* `new URL("/api/...")` call is invalid; use this before `new URL(..., ...)`-style
* builds or to obtain an absolute string for `URL` + `searchParams`.
*/
export function buildAbsoluteApiRequestUrl(
path: string,
baseForRelative: string = typeof window !== "undefined" &&
window.location?.origin
? window.location.origin
: "http://127.0.0.1:5000"
): string {
const resolved = getApiUrl(path);
if (isAbsoluteHttpUrl(resolved)) {
return resolved;
}
return new URL(resolved, baseForRelative).toString();
}
function hasBackendAssetPrefix(path: string): boolean {
return path.startsWith("/static/") || path.startsWith("/app_data/");
}
// Resolve backend-served asset paths to the FastAPI origin.
export function resolveBackendAssetUrl(path?: string): string {
if (!path) return "";
const trimmedPath = path.trim();
if (!trimmedPath) return "";
if (
trimmedPath.startsWith("data:") ||
trimmedPath.startsWith("blob:") ||
trimmedPath.startsWith("file:")
) {
return trimmedPath;
}
if (isAbsoluteHttpUrl(trimmedPath)) {
try {
const parsed = new URL(trimmedPath);
if (hasBackendAssetPrefix(parsed.pathname)) {
return `${getFastAPIUrl()}${parsed.pathname}${parsed.search}${parsed.hash}`;
}
return trimmedPath;
} catch {
return trimmedPath;
}
}
const normalizedPath = withLeadingSlash(trimmedPath);
if (hasBackendAssetPrefix(normalizedPath)) {
return `${getFastAPIUrl()}${normalizedPath}`;
}
return trimmedPath;
}