2022-03-01 11:10:10 +01:00
|
|
|
import { getUserDetails } from '$lib/common';
|
2022-02-10 15:47:44 +01:00
|
|
|
import * as db from '$lib/database';
|
2022-02-14 09:28:37 +01:00
|
|
|
import { listSettings, ErrorHandler } from '$lib/database';
|
2022-02-10 15:47:44 +01:00
|
|
|
import type { RequestHandler } from '@sveltejs/kit';
|
2022-02-18 08:48:05 +01:00
|
|
|
import { promises as dns } from 'dns';
|
2022-02-10 15:47:44 +01:00
|
|
|
|
|
|
|
export const get: RequestHandler = async (event) => {
|
|
|
|
const { status, body } = await getUserDetails(event);
|
|
|
|
if (status === 401) return { status, body };
|
|
|
|
|
|
|
|
try {
|
|
|
|
const settings = await listSettings();
|
|
|
|
return {
|
|
|
|
status: 200,
|
|
|
|
body: {
|
|
|
|
settings
|
|
|
|
}
|
|
|
|
};
|
|
|
|
} catch (error) {
|
2022-02-14 09:28:37 +01:00
|
|
|
return ErrorHandler(error);
|
2022-02-10 15:47:44 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const del: RequestHandler = async (event) => {
|
|
|
|
const { teamId, status, body } = await getUserDetails(event);
|
|
|
|
if (teamId !== '0')
|
|
|
|
return {
|
|
|
|
status: 401,
|
|
|
|
body: {
|
|
|
|
message: 'You do not have permission to do this. \nAsk an admin to modify your permissions.'
|
|
|
|
}
|
|
|
|
};
|
|
|
|
if (status === 401) return { status, body };
|
|
|
|
|
|
|
|
const { fqdn } = await event.request.json();
|
2022-02-19 22:37:45 +01:00
|
|
|
let ip;
|
|
|
|
try {
|
|
|
|
ip = await dns.resolve(fqdn);
|
|
|
|
} catch (error) {
|
|
|
|
// Do not care.
|
|
|
|
}
|
2022-02-10 15:47:44 +01:00
|
|
|
try {
|
2022-02-13 22:56:37 +01:00
|
|
|
await db.prisma.setting.update({ where: { fqdn }, data: { fqdn: null } });
|
2022-02-10 15:47:44 +01:00
|
|
|
return {
|
2022-02-17 22:14:06 +01:00
|
|
|
status: 200,
|
|
|
|
body: {
|
|
|
|
message: 'Domain removed',
|
2022-02-19 22:37:45 +01:00
|
|
|
redirect: ip ? `http://${ip[0]}:3000/settings` : undefined
|
2022-02-17 22:14:06 +01:00
|
|
|
}
|
2022-02-10 15:47:44 +01:00
|
|
|
};
|
|
|
|
} catch (error) {
|
2022-02-14 09:28:37 +01:00
|
|
|
return ErrorHandler(error);
|
2022-02-10 15:47:44 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
export const post: RequestHandler = async (event) => {
|
|
|
|
const { teamId, status, body } = await getUserDetails(event);
|
|
|
|
if (teamId !== '0')
|
|
|
|
return {
|
|
|
|
status: 401,
|
|
|
|
body: {
|
|
|
|
message: 'You do not have permission to do this. \nAsk an admin to modify your permissions.'
|
|
|
|
}
|
|
|
|
};
|
|
|
|
if (status === 401) return { status, body };
|
|
|
|
|
2022-02-22 10:35:39 +01:00
|
|
|
const { fqdn, isRegistrationEnabled, dualCerts, minPort, maxPort } = await event.request.json();
|
2022-02-10 15:47:44 +01:00
|
|
|
try {
|
2022-03-01 11:10:10 +01:00
|
|
|
const { id } = await db.listSettings();
|
|
|
|
if (isRegistrationEnabled) {
|
2022-02-10 15:47:44 +01:00
|
|
|
await db.prisma.setting.update({ where: { id }, data: { isRegistrationEnabled } });
|
|
|
|
}
|
|
|
|
if (fqdn) {
|
|
|
|
await db.prisma.setting.update({ where: { id }, data: { fqdn } });
|
2022-03-01 11:10:10 +01:00
|
|
|
}
|
|
|
|
if (dualCerts) {
|
|
|
|
await db.prisma.setting.update({ where: { id }, data: { dualCerts } });
|
2022-02-10 15:47:44 +01:00
|
|
|
}
|
2022-02-22 10:35:39 +01:00
|
|
|
if (minPort && maxPort) {
|
|
|
|
await db.prisma.setting.update({ where: { id }, data: { minPort, maxPort } });
|
|
|
|
}
|
2022-02-10 15:47:44 +01:00
|
|
|
return {
|
|
|
|
status: 201
|
|
|
|
};
|
|
|
|
} catch (error) {
|
2022-02-14 09:28:37 +01:00
|
|
|
return ErrorHandler(error);
|
2022-02-10 15:47:44 +01:00
|
|
|
}
|
|
|
|
};
|