mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
* feat: add start monitoring remote servers * reafctor: update * refactor: update * refactor: update * refactor: update * refactor: update * refactor: update * refactor: update * refactor: * refactor: add metrics * feat: add disk monitoring * refactor: translate to english * refacotor: add stats * refactor: remove color * feat: add log server metrics * refactor: remove unused deps * refactor: add origin * refactor: add logs * refactor: update * feat: add series monitoring * refactor: add system monitoring * feat: add benchmark to optimize data * refactor: update fn * refactor: remove comments * refactor: update * refactor: exclude items * feat: add refresh rate * feat: add monitoring remote servers * refactor: update * refactor: remove unsued volumes * refactor: update monitoring * refactor: add more presets * feat: add container metrics * feat: add docker monitoring * refactor: update conversion * refactor: remove unused code * refactor: update * refactor: add docker compose logs * refactor: add docker cli * refactor: add install curl * refactor: add get update * refactor: add monitoring remote servers * refactor: add containers config * feat: add container specification * refactor: update path * refactor: add server filter * refactor: simplify logic * fix: verify if file exist before get stats * refactor: update * refactor: remove unused deps * test: add test for containers * refactor: update * refactor add memory collector * refactor: update * refactor: update * refactor: update * refactor: remove * refactor: add memory * refactor: add server memory usage * refactor: change memory * refactor: update * refactor: update * refactor: add container metrics * refactor: comment code * refactor: mount proc bind * refactor: change interval with node cron * refactor: remove opening file * refactor: use streams * refactor: remove unused ws * refactor: disable live when is all * refactor: add sqlite * refactor: update * feat: add golang benchmark * refactor: update go * refactor: update dockerfile * refactor: update db * refactor: add env * refactor: separate logic * refactor: split logic * refactor: update logs * refactor: update dockerfile * refactor: hide .env * refactor: update * chore: hide ,.ebnv * refactor: add end angle * refactor: update * refactor: update * refactor: update * refactor: update * refactor: update * refactor: update monitoring * refactor: add mount db * refactor: add metrics and url callback * refactor: add middleware * refactor: add threshold property * feat: add memory and cpu threshold notification * feat: send notifications to the server * feat: add metrics for dokploy server * refactor: add dokploy server to monitoring * refactor: update methods * refactor: add admin to useeffect * refactor: stop monitoring containers if elements are 0 * refactor: cancel request if appName is empty * refactor: reuse methods * chore; add feat monitoring * refactor: set base url * refactor: adjust monitoring * refactor: delete migrations * feat: add columns * fix: add missing flag * refactor: add free metrics * refactor: add paid monitoring * refactor: update methods * feat: improve ui * feat: add container stats * refactor: add all container metrics * refactor: add color primary * refactor: change default rate limiting refresher * refactor: update retention days * refactor: use json instead of individual properties * refactor: lint * refactor: pass json env * refactor: update * refactor: delete * refactor: update * refactor: fix types * refactor: add retention days * chore: add license * refactor: create db * refactor: update path * refactor: update setup * refactor: update * refactor: create files * refactor: update * refactor: delete * refactor: update * refactor: update token metrics * fix: typechecks * refactor: setup web server * refactor: update error handling and add monitoring * refactor: add local storage save * refactor: add spacing * refactor: update * refactor: upgrade drizzle * refactor: delete * refactor: uppgrade drizzle kit * refactor: update search with jsonB * chore: upgrade drizzle * chore: update packages * refactor: add missing type * refactor: add serverType * refactor: update url * refactor: update * refactor: update * refactor: hide monitoring on self hosted * refactor: update server * refactor: update * refactor: update * refactor: pin node version
196 lines
4.3 KiB
TypeScript
196 lines
4.3 KiB
TypeScript
import { relations } from "drizzle-orm";
|
|
import {
|
|
boolean,
|
|
integer,
|
|
jsonb,
|
|
pgEnum,
|
|
pgTable,
|
|
text,
|
|
} from "drizzle-orm/pg-core";
|
|
import { createInsertSchema } from "drizzle-zod";
|
|
import { nanoid } from "nanoid";
|
|
import { z } from "zod";
|
|
|
|
import { admins } from "./admin";
|
|
import { applications } from "./application";
|
|
import { certificates } from "./certificate";
|
|
import { compose } from "./compose";
|
|
import { deployments } from "./deployment";
|
|
import { mariadb } from "./mariadb";
|
|
import { mongo } from "./mongo";
|
|
import { mysql } from "./mysql";
|
|
import { postgres } from "./postgres";
|
|
import { redis } from "./redis";
|
|
import { sshKeys } from "./ssh-key";
|
|
import { generateAppName } from "./utils";
|
|
|
|
export const serverStatus = pgEnum("serverStatus", ["active", "inactive"]);
|
|
|
|
export const server = pgTable("server", {
|
|
serverId: text("serverId")
|
|
.notNull()
|
|
.primaryKey()
|
|
.$defaultFn(() => nanoid()),
|
|
name: text("name").notNull(),
|
|
description: text("description"),
|
|
ipAddress: text("ipAddress").notNull(),
|
|
port: integer("port").notNull(),
|
|
username: text("username").notNull().default("root"),
|
|
appName: text("appName")
|
|
.notNull()
|
|
.$defaultFn(() => generateAppName("server")),
|
|
enableDockerCleanup: boolean("enableDockerCleanup").notNull().default(false),
|
|
createdAt: text("createdAt")
|
|
.notNull()
|
|
.$defaultFn(() => new Date().toISOString()),
|
|
adminId: text("adminId")
|
|
.notNull()
|
|
.references(() => admins.adminId, { onDelete: "cascade" }),
|
|
serverStatus: serverStatus("serverStatus").notNull().default("active"),
|
|
command: text("command").notNull().default(""),
|
|
sshKeyId: text("sshKeyId").references(() => sshKeys.sshKeyId, {
|
|
onDelete: "set null",
|
|
}),
|
|
metricsConfig: jsonb("metricsConfig")
|
|
.$type<{
|
|
server: {
|
|
type: "Dokploy" | "Remote";
|
|
refreshRate: number;
|
|
port: number;
|
|
token: string;
|
|
urlCallback: string;
|
|
retentionDays: number;
|
|
cronJob: string;
|
|
thresholds: {
|
|
cpu: number;
|
|
memory: number;
|
|
};
|
|
};
|
|
containers: {
|
|
refreshRate: number;
|
|
services: {
|
|
include: string[];
|
|
exclude: string[];
|
|
};
|
|
};
|
|
}>()
|
|
.notNull()
|
|
.default({
|
|
server: {
|
|
type: "Remote",
|
|
refreshRate: 60,
|
|
port: 4500,
|
|
token: "",
|
|
urlCallback: "",
|
|
cronJob: "",
|
|
retentionDays: 2,
|
|
thresholds: {
|
|
cpu: 0,
|
|
memory: 0,
|
|
},
|
|
},
|
|
containers: {
|
|
refreshRate: 60,
|
|
services: {
|
|
include: [],
|
|
exclude: [],
|
|
},
|
|
},
|
|
}),
|
|
});
|
|
|
|
export const serverRelations = relations(server, ({ one, many }) => ({
|
|
admin: one(admins, {
|
|
fields: [server.adminId],
|
|
references: [admins.adminId],
|
|
}),
|
|
deployments: many(deployments),
|
|
sshKey: one(sshKeys, {
|
|
fields: [server.sshKeyId],
|
|
references: [sshKeys.sshKeyId],
|
|
}),
|
|
applications: many(applications),
|
|
compose: many(compose),
|
|
redis: many(redis),
|
|
mariadb: many(mariadb),
|
|
mongo: many(mongo),
|
|
mysql: many(mysql),
|
|
postgres: many(postgres),
|
|
certificates: many(certificates),
|
|
}));
|
|
|
|
const createSchema = createInsertSchema(server, {
|
|
serverId: z.string().min(1),
|
|
name: z.string().min(1),
|
|
description: z.string().optional(),
|
|
});
|
|
|
|
export const apiCreateServer = createSchema
|
|
.pick({
|
|
name: true,
|
|
description: true,
|
|
ipAddress: true,
|
|
port: true,
|
|
username: true,
|
|
sshKeyId: true,
|
|
})
|
|
.required();
|
|
|
|
export const apiFindOneServer = createSchema
|
|
.pick({
|
|
serverId: true,
|
|
})
|
|
.required();
|
|
|
|
export const apiRemoveServer = createSchema
|
|
.pick({
|
|
serverId: true,
|
|
})
|
|
.required();
|
|
|
|
export const apiUpdateServer = createSchema
|
|
.pick({
|
|
name: true,
|
|
description: true,
|
|
serverId: true,
|
|
ipAddress: true,
|
|
port: true,
|
|
username: true,
|
|
sshKeyId: true,
|
|
})
|
|
.required()
|
|
.extend({
|
|
command: z.string().optional(),
|
|
});
|
|
|
|
export const apiUpdateServerMonitoring = createSchema
|
|
.pick({
|
|
serverId: true,
|
|
})
|
|
.required()
|
|
.extend({
|
|
metricsConfig: z
|
|
.object({
|
|
server: z.object({
|
|
refreshRate: z.number().min(2),
|
|
port: z.number().min(1),
|
|
token: z.string(),
|
|
urlCallback: z.string().url(),
|
|
retentionDays: z.number().min(1),
|
|
cronJob: z.string().min(1),
|
|
thresholds: z.object({
|
|
cpu: z.number().min(0),
|
|
memory: z.number().min(0),
|
|
}),
|
|
}),
|
|
containers: z.object({
|
|
refreshRate: z.number().min(2),
|
|
services: z.object({
|
|
include: z.array(z.string()).optional(),
|
|
exclude: z.array(z.string()).optional(),
|
|
}),
|
|
}),
|
|
})
|
|
.required(),
|
|
});
|