mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
114 lines
2.8 KiB
TypeScript
114 lines
2.8 KiB
TypeScript
import { relations } from "drizzle-orm";
|
|
import {
|
|
type AnyPgColumn,
|
|
boolean,
|
|
integer,
|
|
pgEnum,
|
|
pgTable,
|
|
serial,
|
|
text,
|
|
} from "drizzle-orm/pg-core";
|
|
import { createInsertSchema } from "drizzle-zod";
|
|
import { nanoid } from "nanoid";
|
|
import { z } from "zod";
|
|
import { domain } from "../validations/domain";
|
|
import { applications } from "./application";
|
|
import { compose } from "./compose";
|
|
import { certificateType } from "./shared";
|
|
import { previewDeployments } from "./preview-deployments";
|
|
|
|
export const domainType = pgEnum("domainType", [
|
|
"compose",
|
|
"application",
|
|
"preview",
|
|
]);
|
|
|
|
export const domains = pgTable("domain", {
|
|
domainId: text("domainId")
|
|
.notNull()
|
|
.primaryKey()
|
|
.$defaultFn(() => nanoid()),
|
|
host: text("host").notNull(),
|
|
https: boolean("https").notNull().default(false),
|
|
port: integer("port").default(3000),
|
|
path: text("path").default("/"),
|
|
serviceName: text("serviceName"),
|
|
domainType: domainType("domainType").default("application"),
|
|
uniqueConfigKey: serial("uniqueConfigKey"),
|
|
createdAt: text("createdAt")
|
|
.notNull()
|
|
.$defaultFn(() => new Date().toISOString()),
|
|
composeId: text("composeId").references(() => compose.composeId, {
|
|
onDelete: "cascade",
|
|
}),
|
|
applicationId: text("applicationId").references(
|
|
() => applications.applicationId,
|
|
{ onDelete: "cascade" },
|
|
),
|
|
previewDeploymentId: text("previewDeploymentId").references(
|
|
(): AnyPgColumn => previewDeployments.previewDeploymentId,
|
|
{ onDelete: "cascade" },
|
|
),
|
|
certificateType: certificateType("certificateType").notNull().default("none"),
|
|
});
|
|
|
|
export const domainsRelations = relations(domains, ({ one }) => ({
|
|
application: one(applications, {
|
|
fields: [domains.applicationId],
|
|
references: [applications.applicationId],
|
|
}),
|
|
compose: one(compose, {
|
|
fields: [domains.composeId],
|
|
references: [compose.composeId],
|
|
}),
|
|
previewDeployment: one(previewDeployments, {
|
|
fields: [domains.previewDeploymentId],
|
|
references: [previewDeployments.previewDeploymentId],
|
|
}),
|
|
}));
|
|
|
|
const createSchema = createInsertSchema(domains, domain._def.schema.shape);
|
|
|
|
export const apiCreateDomain = createSchema.pick({
|
|
host: true,
|
|
path: true,
|
|
port: true,
|
|
https: true,
|
|
applicationId: true,
|
|
certificateType: true,
|
|
composeId: true,
|
|
serviceName: true,
|
|
domainType: true,
|
|
previewDeploymentId: true,
|
|
});
|
|
|
|
export const apiFindDomain = createSchema
|
|
.pick({
|
|
domainId: true,
|
|
})
|
|
.required();
|
|
|
|
export const apiFindDomainByApplication = createSchema.pick({
|
|
applicationId: true,
|
|
});
|
|
|
|
export const apiCreateTraefikMeDomain = createSchema.pick({}).extend({
|
|
appName: z.string().min(1),
|
|
});
|
|
|
|
export const apiFindDomainByCompose = createSchema.pick({
|
|
composeId: true,
|
|
});
|
|
|
|
export const apiUpdateDomain = createSchema
|
|
.pick({
|
|
host: true,
|
|
path: true,
|
|
port: true,
|
|
https: true,
|
|
certificateType: true,
|
|
serviceName: true,
|
|
domainType: true,
|
|
})
|
|
.merge(createSchema.pick({ domainId: true }).required());
|