mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
* feat: add schema for registry and routes * feat: add docker registry upload * feat: add show cluster * refactor: set the registry url in image in case we have a registry asociated * feat: add update registry and fix the docker url markup * chore: remove --advertise-ip on swarm script * refactor: remove listen address of swarm initialize * feat: add table to show nodes and add dropdown to add manager & workers * refactor: improve interface for cluster * refactor: improve UI * feat: add experimental swarm settings * refactor: remove comments * refactor: prettify json of each setting * refactor: add interface tooltip * refactor: delete static form self registry * refactor: allow to se a empty registry * fix: remove text area warnings * feat: add network swarm json * refactor: update ui * revert: go back to swarm init config * refactor: remove initialization on server, only on setup script * Update LICENSE.MD * feat: appearance theme support system config * refactor: remove logs * fix(README-ru): hyperlink-ed docs url * feat: (#107) webhook listener filter docker events based on image tag. Fixes #107 * refactor: simplify comparison docker tags * refactor: remove return in res status * refactor: prevent to updates download automatically * feat: support code editor (#105) * feat: support code editor * Update codeblock * refactor: remove unused class --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix: select the right image from sourcetype (#109) * chore: bump minor version * fix: add redirect to https by default (#113) * Create FUNDING.yml * Docker compose support (#111) * 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 * chore: add recomendation to show variables * chore: add video to contributing templates * chore: bump version --------- Co-authored-by: hehehai <riverhohai@gmail.com> Co-authored-by: Bayram Tagiev <bayram.tagiev.a@gmail.com> Co-authored-by: Paulo Santana <30875229+hikinine@users.noreply.github.com>
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),
|
|
});
|