import { json } from '@sveltejs/kit'; import type { RequestHandler } from './$types'; import { connectContainerToNetwork, inspectNetwork } from '$lib/server/docker'; import { authorize } from '$lib/server/authorize'; import { auditNetwork } from '$lib/server/audit'; export const POST: RequestHandler = async (event) => { const { params, url, request, cookies } = event; const auth = await authorize(cookies); const envId = url.searchParams.get('env'); const envIdNum = envId ? parseInt(envId) : undefined; // Permission check with environment context if (auth.authEnabled && !await auth.can('networks', 'connect', envIdNum)) { return json({ error: 'Permission denied' }, { status: 403 }); } try { const body = await request.json(); const { containerId, containerName } = body; if (!containerId) { return json({ error: 'Container ID is required' }, { status: 400 }); } // Get network name for audit let networkName = params.id; try { const networkInfo = await inspectNetwork(params.id, envIdNum); networkName = networkInfo.Name || params.id; } catch { // Use ID if can't get name } await connectContainerToNetwork(params.id, containerId, envIdNum); // Audit log await auditNetwork(event, 'connect', params.id, networkName, envIdNum, { containerId, containerName: containerName || containerId }); return json({ success: true }); } catch (error: any) { console.error('Failed to connect container to network:', error); return json({ error: 'Failed to connect container to network', details: error.message }, { status: 500 }); } };