mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
79 lines
1.6 KiB
TypeScript
79 lines
1.6 KiB
TypeScript
import { db } from "@/server/db";
|
|
import {
|
|
type apiCreateSshKey,
|
|
type apiFindOneSshKey,
|
|
type apiRemoveSshKey,
|
|
type apiUpdateSshKey,
|
|
sshKeys,
|
|
} from "@/server/db/schema";
|
|
import { removeSSHKey, saveSSHKey } from "@/server/utils/filesystem/ssh";
|
|
import { TRPCError } from "@trpc/server";
|
|
import { eq } from "drizzle-orm";
|
|
|
|
export const createSshKey = async ({
|
|
privateKey,
|
|
...input
|
|
}: typeof apiCreateSshKey._type) => {
|
|
await db.transaction(async (tx) => {
|
|
const sshKey = await tx
|
|
.insert(sshKeys)
|
|
.values(input)
|
|
.returning()
|
|
.then((response) => response[0])
|
|
.catch((e) => console.error(e));
|
|
|
|
if (sshKey) {
|
|
saveSSHKey(sshKey.sshKeyId, sshKey.publicKey, privateKey);
|
|
}
|
|
|
|
if (!sshKey) {
|
|
throw new TRPCError({
|
|
code: "BAD_REQUEST",
|
|
message: "Error to create the ssh key",
|
|
});
|
|
}
|
|
return sshKey;
|
|
});
|
|
};
|
|
|
|
export const removeSSHKeyById = async (
|
|
sshKeyId: (typeof apiRemoveSshKey._type)["sshKeyId"],
|
|
) => {
|
|
const result = await db
|
|
.delete(sshKeys)
|
|
.where(eq(sshKeys.sshKeyId, sshKeyId))
|
|
.returning();
|
|
|
|
removeSSHKey(sshKeyId);
|
|
|
|
return result[0];
|
|
};
|
|
|
|
export const updateSSHKeyById = async ({
|
|
sshKeyId,
|
|
...input
|
|
}: typeof apiUpdateSshKey._type) => {
|
|
const result = await db
|
|
.update(sshKeys)
|
|
.set(input)
|
|
.where(eq(sshKeys.sshKeyId, sshKeyId))
|
|
.returning();
|
|
|
|
return result[0];
|
|
};
|
|
|
|
export const findSSHKeyById = async (
|
|
sshKeyId: (typeof apiFindOneSshKey._type)["sshKeyId"],
|
|
) => {
|
|
const sshKey = await db.query.sshKeys.findFirst({
|
|
where: eq(sshKeys.sshKeyId, sshKeyId),
|
|
});
|
|
if (!sshKey) {
|
|
throw new TRPCError({
|
|
code: "NOT_FOUND",
|
|
message: "SSH Key not found",
|
|
});
|
|
}
|
|
return sshKey;
|
|
};
|