mirror of
https://github.com/khoaliber/dockhand.git
synced 2026-03-04 13:19:57 +00:00
97 lines
2.9 KiB
TypeScript
97 lines
2.9 KiB
TypeScript
import { json } from '@sveltejs/kit';
|
|
import type { RequestHandler } from './$types';
|
|
import { getRegistry, updateRegistry, deleteRegistry, setDefaultRegistry } from '$lib/server/db';
|
|
import { authorize } from '$lib/server/authorize';
|
|
|
|
export const GET: RequestHandler = async ({ params, cookies }) => {
|
|
const auth = await authorize(cookies);
|
|
if (auth.authEnabled && !await auth.can('registries', 'view')) {
|
|
return json({ error: 'Permission denied' }, { status: 403 });
|
|
}
|
|
|
|
try {
|
|
const id = parseInt(params.id);
|
|
if (isNaN(id)) {
|
|
return json({ error: 'Invalid registry ID' }, { status: 400 });
|
|
}
|
|
|
|
const registry = await getRegistry(id);
|
|
if (!registry) {
|
|
return json({ error: 'Registry not found' }, { status: 404 });
|
|
}
|
|
|
|
// Don't expose password
|
|
const { password, ...safeRegistry } = registry;
|
|
return json({ ...safeRegistry, hasCredentials: !!password });
|
|
} catch (error) {
|
|
console.error('Error fetching registry:', error);
|
|
return json({ error: 'Failed to fetch registry' }, { status: 500 });
|
|
}
|
|
};
|
|
|
|
export const PUT: RequestHandler = async ({ params, request, cookies }) => {
|
|
const auth = await authorize(cookies);
|
|
if (auth.authEnabled && !await auth.can('registries', 'edit')) {
|
|
return json({ error: 'Permission denied' }, { status: 403 });
|
|
}
|
|
|
|
try {
|
|
const id = parseInt(params.id);
|
|
if (isNaN(id)) {
|
|
return json({ error: 'Invalid registry ID' }, { status: 400 });
|
|
}
|
|
|
|
const data = await request.json();
|
|
const registry = await updateRegistry(id, {
|
|
name: data.name,
|
|
url: data.url,
|
|
username: data.username,
|
|
password: data.password,
|
|
isDefault: data.isDefault
|
|
});
|
|
|
|
if (!registry) {
|
|
return json({ error: 'Registry not found' }, { status: 404 });
|
|
}
|
|
|
|
// If this registry should be default, set it
|
|
if (data.isDefault) {
|
|
await setDefaultRegistry(id);
|
|
}
|
|
|
|
// Don't expose password
|
|
const { password, ...safeRegistry } = registry;
|
|
return json({ ...safeRegistry, hasCredentials: !!password });
|
|
} catch (error: any) {
|
|
console.error('Error updating registry:', error);
|
|
if (error.message?.includes('UNIQUE constraint failed')) {
|
|
return json({ error: 'A registry with this name already exists' }, { status: 400 });
|
|
}
|
|
return json({ error: 'Failed to update registry' }, { status: 500 });
|
|
}
|
|
};
|
|
|
|
export const DELETE: RequestHandler = async ({ params, cookies }) => {
|
|
const auth = await authorize(cookies);
|
|
if (auth.authEnabled && !await auth.can('registries', 'delete')) {
|
|
return json({ error: 'Permission denied' }, { status: 403 });
|
|
}
|
|
|
|
try {
|
|
const id = parseInt(params.id);
|
|
if (isNaN(id)) {
|
|
return json({ error: 'Invalid registry ID' }, { status: 400 });
|
|
}
|
|
|
|
const deleted = await deleteRegistry(id);
|
|
if (!deleted) {
|
|
return json({ error: 'Registry not found or cannot be deleted' }, { status: 404 });
|
|
}
|
|
|
|
return json({ success: true });
|
|
} catch (error) {
|
|
console.error('Error deleting registry:', error);
|
|
return json({ error: 'Failed to delete registry' }, { status: 500 });
|
|
}
|
|
};
|