mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
* feat(WIP): compose implementation * feat: add volumes, networks, services name hash generate * feat: add compose config test unique * feat: add tests for each unique config * feat: implement lodash for docker compose parsing * feat: add tests for generating compose file * refactor: implement logs docker compose * refactor: composeFile set not empty * feat: implement providers for compose deployments * feat: add Files volumes to compose * feat: add stop compose button * refactor: change strategie of building compose * feat: create .env file in composepath * refactor: simplify git and github function * chore: update deps * refactor: update migrations and add badge to recognize compose type * chore: update lock yaml * refactor: use code editor * feat: add monitoring for app types * refactor: reset stats on change appName * refactor: add option to clean monitoring folder * feat: show current command that will run * feat: add prefix * fix: add missing types * refactor: add docker provider and expose by default as false * refactor: customize error page * refactor: unified deployments to be a single one * feat: add vitest to ci/cd * revert: back to initial version * refactor: add maxconcurrency vitest * refactor: add pool forks to vitest * feat: add pocketbase template * fix: update path resolution compose * removed * feat: add template pocketbase * feat: add pocketbase template * feat: add support button * feat: add plausible template * feat: add calcom template * feat: add version to each template * feat: add code editor to enviroment variables and swarm settings json * refactor: add loader when download the image * fix: use base64 to generate keys plausible * feat: add recognized domain names by enviroment compose * refactor: show alert to redeploy in each card advanced tab * refactor: add validation to prevent create compose if not have permissions * chore: add templates section to contributing * chore: add example contributing
158 lines
3.6 KiB
TypeScript
158 lines
3.6 KiB
TypeScript
import { nanoid } from "nanoid";
|
|
import { applications } from "./application";
|
|
import { relations } from "drizzle-orm";
|
|
import { createInsertSchema } from "drizzle-zod";
|
|
import { z } from "zod";
|
|
import { pgEnum, pgTable, text } from "drizzle-orm/pg-core";
|
|
import { postgres } from "./postgres";
|
|
import { mariadb } from "./mariadb";
|
|
import { mongo } from "./mongo";
|
|
import { mysql } from "./mysql";
|
|
import { redis } from "./redis";
|
|
import { compose } from "./compose";
|
|
|
|
export const serviceType = pgEnum("serviceType", [
|
|
"application",
|
|
"postgres",
|
|
"mysql",
|
|
"mariadb",
|
|
"mongo",
|
|
"redis",
|
|
"compose",
|
|
]);
|
|
|
|
export const mountType = pgEnum("mountType", ["bind", "volume", "file"]);
|
|
|
|
export const mounts = pgTable("mount", {
|
|
mountId: text("mountId")
|
|
.notNull()
|
|
.primaryKey()
|
|
.$defaultFn(() => nanoid()),
|
|
type: mountType("type").notNull(),
|
|
hostPath: text("hostPath"),
|
|
volumeName: text("volumeName"),
|
|
content: text("content"),
|
|
serviceType: serviceType("serviceType").notNull().default("application"),
|
|
mountPath: text("mountPath").notNull(),
|
|
applicationId: text("applicationId").references(
|
|
() => applications.applicationId,
|
|
{ onDelete: "cascade" },
|
|
),
|
|
postgresId: text("postgresId").references(() => postgres.postgresId, {
|
|
onDelete: "cascade",
|
|
}),
|
|
mariadbId: text("mariadbId").references(() => mariadb.mariadbId, {
|
|
onDelete: "cascade",
|
|
}),
|
|
mongoId: text("mongoId").references(() => mongo.mongoId, {
|
|
onDelete: "cascade",
|
|
}),
|
|
mysqlId: text("mysqlId").references(() => mysql.mysqlId, {
|
|
onDelete: "cascade",
|
|
}),
|
|
redisId: text("redisId").references(() => redis.redisId, {
|
|
onDelete: "cascade",
|
|
}),
|
|
composeId: text("composeId").references(() => compose.composeId, {
|
|
onDelete: "cascade",
|
|
}),
|
|
});
|
|
|
|
export const MountssRelations = relations(mounts, ({ one }) => ({
|
|
application: one(applications, {
|
|
fields: [mounts.applicationId],
|
|
references: [applications.applicationId],
|
|
}),
|
|
postgres: one(postgres, {
|
|
fields: [mounts.postgresId],
|
|
references: [postgres.postgresId],
|
|
}),
|
|
mariadb: one(mariadb, {
|
|
fields: [mounts.mariadbId],
|
|
references: [mariadb.mariadbId],
|
|
}),
|
|
mongo: one(mongo, {
|
|
fields: [mounts.mongoId],
|
|
references: [mongo.mongoId],
|
|
}),
|
|
mysql: one(mysql, {
|
|
fields: [mounts.mysqlId],
|
|
references: [mysql.mysqlId],
|
|
}),
|
|
redis: one(redis, {
|
|
fields: [mounts.redisId],
|
|
references: [redis.redisId],
|
|
}),
|
|
compose: one(compose, {
|
|
fields: [mounts.composeId],
|
|
references: [compose.composeId],
|
|
}),
|
|
}));
|
|
|
|
const createSchema = createInsertSchema(mounts, {
|
|
applicationId: z.string(),
|
|
type: z.enum(["bind", "volume", "file"]),
|
|
hostPath: z.string().optional(),
|
|
volumeName: z.string().optional(),
|
|
content: z.string().optional(),
|
|
mountPath: z.string().min(1),
|
|
mountId: z.string().optional(),
|
|
serviceType: z
|
|
.enum([
|
|
"application",
|
|
"postgres",
|
|
"mysql",
|
|
"mariadb",
|
|
"mongo",
|
|
"redis",
|
|
"compose",
|
|
])
|
|
.default("application"),
|
|
});
|
|
|
|
export type ServiceType = NonNullable<
|
|
z.infer<typeof createSchema>["serviceType"]
|
|
>;
|
|
|
|
export const apiCreateMount = createSchema
|
|
.pick({
|
|
type: true,
|
|
hostPath: true,
|
|
volumeName: true,
|
|
content: true,
|
|
mountPath: true,
|
|
serviceType: true,
|
|
})
|
|
.extend({
|
|
serviceId: z.string().min(1),
|
|
});
|
|
|
|
export const apiFindOneMount = createSchema
|
|
.pick({
|
|
mountId: true,
|
|
})
|
|
.required();
|
|
|
|
export const apiRemoveMount = createSchema
|
|
.pick({
|
|
mountId: true,
|
|
})
|
|
// .extend({
|
|
// appName: z.string().min(1),
|
|
// })
|
|
.required();
|
|
|
|
export const apiFindMountByApplicationId = createSchema
|
|
.extend({
|
|
serviceId: z.string().min(1),
|
|
})
|
|
.pick({
|
|
serviceId: true,
|
|
serviceType: true,
|
|
})
|
|
.required();
|
|
|
|
export const apiUpdateMount = createSchema.partial().extend({
|
|
mountId: z.string().min(1),
|
|
});
|