mirror of
https://github.com/khoaliber/dockhand.git
synced 2026-03-03 05:29:05 +00:00
41 lines
1.4 KiB
TypeScript
41 lines
1.4 KiB
TypeScript
import { json } from '@sveltejs/kit';
|
|
import { getDiskUsage } from '$lib/server/docker';
|
|
import { authorize } from '$lib/server/authorize';
|
|
import type { RequestHandler } from './$types';
|
|
|
|
const DISK_USAGE_TIMEOUT = 15000; // 15 second timeout
|
|
|
|
export const GET: RequestHandler = async ({ url, cookies }) => {
|
|
const auth = await authorize(cookies);
|
|
|
|
if (auth.authEnabled && !await auth.can('environments', 'view')) {
|
|
return json({ error: 'Permission denied' }, { status: 403 });
|
|
}
|
|
|
|
const envId = url.searchParams.get('env') ? parseInt(url.searchParams.get('env')!) : null;
|
|
|
|
if (!envId) {
|
|
return json({ error: 'Environment ID required' }, { status: 400 });
|
|
}
|
|
|
|
// Check environment access in enterprise mode
|
|
if (auth.authEnabled && auth.isEnterprise && !await auth.canAccessEnvironment(envId)) {
|
|
return json({ error: 'Access denied to this environment' }, { status: 403 });
|
|
}
|
|
|
|
try {
|
|
// Fetch disk usage with timeout
|
|
const diskUsagePromise = getDiskUsage(envId);
|
|
const timeoutPromise = new Promise((_, reject) =>
|
|
setTimeout(() => reject(new Error('Disk usage timeout')), DISK_USAGE_TIMEOUT)
|
|
);
|
|
|
|
const diskUsage = await Promise.race([diskUsagePromise, timeoutPromise]);
|
|
return json({ diskUsage });
|
|
} catch (error) {
|
|
// Return null on timeout or error - UI will show loading/unavailable state
|
|
console.log(`Disk usage fetch failed for env ${envId}:`, error instanceof Error ? error.message : String(error));
|
|
return json({ diskUsage: null });
|
|
}
|
|
};
|