mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
75 lines
1.5 KiB
TypeScript
75 lines
1.5 KiB
TypeScript
import { db } from "@/server/db";
|
|
import { type apiCreateServer, server } from "@/server/db/schema";
|
|
import { generatePassword } from "@/templates/utils";
|
|
import { TRPCError } from "@trpc/server";
|
|
import { eq } from "drizzle-orm";
|
|
|
|
export type Server = typeof server.$inferSelect;
|
|
|
|
export const createServer = async (
|
|
input: typeof apiCreateServer._type,
|
|
adminId: string,
|
|
) => {
|
|
const newServer = await db
|
|
.insert(server)
|
|
.values({
|
|
...input,
|
|
adminId: adminId,
|
|
redisPassword: generatePassword(12),
|
|
})
|
|
.returning()
|
|
.then((value) => value[0]);
|
|
|
|
if (!newServer) {
|
|
throw new TRPCError({
|
|
code: "BAD_REQUEST",
|
|
message: "Error to create the server",
|
|
});
|
|
}
|
|
|
|
return newServer;
|
|
};
|
|
|
|
export const findServerById = async (serverId: string) => {
|
|
const currentServer = await db.query.server.findFirst({
|
|
where: eq(server.serverId, serverId),
|
|
with: {
|
|
deployments: true,
|
|
sshKey: true,
|
|
},
|
|
});
|
|
if (!currentServer) {
|
|
throw new TRPCError({
|
|
code: "NOT_FOUND",
|
|
message: "Server not found",
|
|
});
|
|
}
|
|
return currentServer;
|
|
};
|
|
|
|
export const deleteServer = async (serverId: string) => {
|
|
const currentServer = await db
|
|
.delete(server)
|
|
.where(eq(server.serverId, serverId))
|
|
.returning()
|
|
.then((value) => value[0]);
|
|
|
|
return currentServer;
|
|
};
|
|
|
|
export const updateServerById = async (
|
|
serverId: string,
|
|
serverData: Partial<Server>,
|
|
) => {
|
|
const result = await db
|
|
.update(server)
|
|
.set({
|
|
...serverData,
|
|
})
|
|
.where(eq(server.serverId, serverId))
|
|
.returning()
|
|
.then((res) => res[0]);
|
|
|
|
return result;
|
|
};
|