[FEATURE] Initial Backup Interval

This commit is contained in:
Dunemask 2024-01-11 11:21:12 -07:00
parent a5ffe1694e
commit b538ab5089
5 changed files with 77 additions and 4 deletions

View file

@ -16,12 +16,20 @@ function payloadFilter(req, res) {
const serverSpec = req.body;
if (!serverSpec) return res.sendStatus(400);
const { name, host, version, serverType, memory } = serverSpec;
const { backupHost, backupBucket, backupId, backupKey } = serverSpec;
if (!name) return res.status(400).send("Server name is required!");
if (!host) return res.status(400).send("Server host is required!");
if (!dnsRegex.test(host)) return res.status(400).send("Hostname invalid!");
if (!version) return res.status(400).send("Server version is required!");
if (!serverType) return res.status(400).send("Server type is required!");
if (!memory) return res.status(400).send("Memory is required!");
if (!!backupHost || !!backupBucket || !!backupId || !!backupKey) {
// If any keys are required, all are required
if (!(!!backupHost && !!backupBucket && !!backupId && !!backupKey))
return res.status(400).send("All backup keys are required!");
if (!dnsRegex.test(backupHost))
return res.status(400).send("Backup Host invalid!");
}
return "filtered";
}

View file

@ -9,8 +9,9 @@ CREATE TABLE servers (
memory varchar(63) DEFAULT '512',
backup_host varchar(255) DEFAULT NULL,
backup_bucket_path varchar(255) DEFAULT NULL,
backup_user varchar(255) DEFAULT NULL,
backup_pass varchar(255) DEFAULT NULL,
backup_id varchar(255) DEFAULT NULL,
backup_key varchar(255) DEFAULT NULL,
backup_interval varchar(255) DEFAULT NULL,
CONSTRAINT unique_host UNIQUE(host)
);
ALTER SEQUENCE servers_id_seq OWNED BY servers.id;

View file

@ -10,8 +10,28 @@ const asExpressClientError = (e) => {
const getMclName = (host, id) => `${host.replaceAll(".", "-")}-${id}`;
export async function createServerEntry(serverSpec) {
const { name, host, version, serverType: server_type, memory } = serverSpec;
var q = insertQuery(table, { name, host, version, server_type, memory });
const {
name,
host,
version,
serverType: server_type,
memory,
backupHost: backup_host,
backupBucket: backup_bucket_path,
backupId: backup_id,
backupKey: backup_key,
} = serverSpec;
var q = insertQuery(table, {
name,
host,
version,
server_type,
memory,
backup_host,
backup_bucket_path,
backup_id,
backup_key,
});
q += "\n RETURNING *";
try {
const entries = await pg.query(q);