minor bug files, remove unqiue constraint, and start migration

This commit is contained in:
miloschwartz 2025-02-24 22:06:21 -05:00
parent ff37e07ce6
commit e11748fe30
No known key found for this signature in database
5 changed files with 97 additions and 10 deletions

View file

@ -3,7 +3,7 @@ import { sqliteTable, text, integer } from "drizzle-orm/sqlite-core";
export const domains = sqliteTable("domains", { export const domains = sqliteTable("domains", {
domainId: text("domainId").primaryKey(), domainId: text("domainId").primaryKey(),
baseDomain: text("baseDomain").notNull().unique(), baseDomain: text("baseDomain").notNull(),
configManaged: integer("configManaged", { mode: "boolean" }) configManaged: integer("configManaged", { mode: "boolean" })
.notNull() .notNull()
.default(false) .default(false)

View file

@ -42,7 +42,7 @@ const configSchema = z.object({
z.string(), z.string(),
z.object({ z.object({
base_domain: hostnameSchema.transform((url) => url.toLowerCase()), base_domain: hostnameSchema.transform((url) => url.toLowerCase()),
cert_resolver: z.string(), cert_resolver: z.string().optional(),
prefer_wildcard_cert: z.boolean().optional() prefer_wildcard_cert: z.boolean().optional()
}) })
), ),

View file

@ -68,6 +68,8 @@ const updateHttpResourceBodySchema = z
} }
); );
export type UpdateResourceResponse = Resource;
const updateRawResourceBodySchema = z const updateRawResourceBodySchema = z
.object({ .object({
name: z.string().min(1).max(255).optional(), name: z.string().min(1).max(255).optional(),

View file

@ -0,0 +1,78 @@
import db from "@server/db";
import { configFilePath1, configFilePath2 } from "@server/lib/consts";
import fs from "fs";
import yaml from "js-yaml";
import { sql } from "drizzle-orm";
const version = "1.0.0-beta.15";
export default async function migration() {
console.log(`Running setup script ${version}...`);
try {
db.transaction((trx) => {});
console.log(`Migrated database schema`);
} catch (e) {
console.log("Unable to migrate database schema");
throw e;
}
try {
// Determine which config file exists
const filePaths = [configFilePath1, configFilePath2];
let filePath = "";
for (const path of filePaths) {
if (fs.existsSync(path)) {
filePath = path;
break;
}
}
if (!filePath) {
throw new Error(
`No config file found (expected config.yml or config.yaml).`
);
}
// Read and parse the YAML file
let rawConfig: any;
const fileContents = fs.readFileSync(filePath, "utf8");
rawConfig = yaml.load(fileContents);
const baseDomain = rawConfig.app.base_domain;
const certResolver = rawConfig.traefik.cert_resolver;
const preferWildcardCert = rawConfig.traefik.prefer_wildcard_cert;
delete rawConfig.traefik.prefer_wildcard_cert;
delete rawConfig.traefik.cert_resolver;
delete rawConfig.app.base_domain;
rawConfig.domains = {
domain1: {
base_domain: baseDomain
}
};
if (certResolver) {
rawConfig.domains.domain1.cert_resolver = certResolver;
}
if (preferWildcardCert) {
rawConfig.domains.domain1.prefer_wildcard_cert = preferWildcardCert;
}
// Write the updated YAML back to the file
const updatedYaml = yaml.dump(rawConfig);
fs.writeFileSync(filePath, updatedYaml, "utf8");
console.log(`Moved base_domain to new domains section`);
} catch (e) {
console.log(
`Unable to migrate config file and move base_domain to domains. Error: ${e}`
);
return;
}
console.log(`${version} migration complete`);
}

View file

@ -60,6 +60,7 @@ import {
SelectTrigger, SelectTrigger,
SelectValue SelectValue
} from "@app/components/ui/select"; } from "@app/components/ui/select";
import { UpdateResourceResponse } from "@server/routers/resource";
const GeneralFormSchema = z const GeneralFormSchema = z
.object({ .object({
@ -191,13 +192,16 @@ export default function GeneralForm() {
setSaveLoading(true); setSaveLoading(true);
const res = await api const res = await api
.post(`resource/${resource?.resourceId}`, { .post<AxiosResponse<UpdateResourceResponse>>(
name: data.name, `resource/${resource?.resourceId}`,
subdomain: data.http ? data.subdomain : undefined, {
proxyPort: data.proxyPort, name: data.name,
isBaseDomain: data.http ? data.isBaseDomain : undefined, subdomain: data.http ? data.subdomain : undefined,
domainId: data.http ? data.domainId : undefined proxyPort: data.proxyPort,
}) isBaseDomain: data.http ? data.isBaseDomain : undefined,
domainId: data.http ? data.domainId : undefined
}
)
.catch((e) => { .catch((e) => {
toast({ toast({
variant: "destructive", variant: "destructive",
@ -215,11 +219,14 @@ export default function GeneralForm() {
description: "The resource has been updated successfully" description: "The resource has been updated successfully"
}); });
const resource = res.data.data;
updateResource({ updateResource({
name: data.name, name: data.name,
subdomain: data.subdomain, subdomain: data.subdomain,
proxyPort: data.proxyPort, proxyPort: data.proxyPort,
isBaseDomain: data.isBaseDomain isBaseDomain: data.isBaseDomain,
fullDomain: resource.fullDomain
}); });
router.refresh(); router.refresh();