mirror of
https://github.com/fosrl/pangolin.git
synced 2025-07-10 14:04:51 +02:00
minor bug files, remove unqiue constraint, and start migration
This commit is contained in:
parent
ff37e07ce6
commit
e11748fe30
5 changed files with 97 additions and 10 deletions
|
@ -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)
|
||||||
|
|
|
@ -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()
|
||||||
})
|
})
|
||||||
),
|
),
|
||||||
|
|
|
@ -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(),
|
||||||
|
|
78
server/setup/scripts/1.0.0-beta15.ts
Normal file
78
server/setup/scripts/1.0.0-beta15.ts
Normal 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`);
|
||||||
|
}
|
|
@ -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();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue