/api/mek/list, /api/mek/register Endpoint 구현

This commit is contained in:
static
2024-12-29 21:52:33 +09:00
parent 3664ad66ac
commit 97f6e1e32f
6 changed files with 186 additions and 24 deletions

88
src/lib/server/db/mek.ts Normal file
View File

@@ -0,0 +1,88 @@
import { and, or, eq, lt } from "drizzle-orm";
import db from "./drizzle";
import { mek, clientMek, userClient } from "./schema";
export interface ClientMek {
clientId: number;
encMek: string;
}
export const registerActiveMek = async (
userId: number,
version: number,
createdBy: number,
clientMeks: ClientMek[],
) => {
await db.transaction(async (tx) => {
// 1. Check if the clientMeks are valid
const userClients = await tx
.select()
.from(userClient)
.where(and(eq(userClient.userId, userId), eq(userClient.state, "active")));
if (
clientMeks.length !== userClients.length ||
!clientMeks.every((clientMek) =>
userClients.some((userClient) => userClient.clientId === clientMek.clientId),
)
) {
throw new Error("Invalid key list");
}
// 2. Retire the old active MEK and insert the new one
await tx
.update(mek)
.set({
state: "retired",
retiredAt: new Date(),
})
.where(and(eq(mek.userId, userId), lt(mek.version, version), eq(mek.state, "active")))
.execute();
await tx
.insert(mek)
.values({
userId,
version,
createdBy,
createdAt: new Date(),
state: "active",
})
.execute();
// 3. Insert the new client MEKs
await tx
.insert(clientMek)
.values(
clientMeks.map(({ clientId, encMek }) => ({
userId,
clientId,
mekVersion: version,
encMek,
})),
)
.execute();
});
};
export const getActiveMek = async (userId: number) => {
const meks = await db
.select()
.from(mek)
.where(and(eq(mek.userId, userId), eq(mek.state, "active")))
.execute();
return meks[0] ?? null;
};
export const getAllValidClientMeks = async (userId: number, clientId: number) => {
return await db
.select()
.from(clientMek)
.innerJoin(mek, and(eq(clientMek.userId, mek.userId), eq(clientMek.mekVersion, mek.version)))
.where(
and(
eq(clientMek.userId, userId),
eq(clientMek.clientId, clientId),
or(eq(mek.state, "active"), eq(mek.state, "retired")),
),
)
.execute();
};