mirror of
https://github.com/Drop-OSS/drop.git
synced 2025-11-13 00:02:37 +10:00
store sessions in db
This commit is contained in:
@ -50,3 +50,8 @@ model Certificate {
|
||||
|
||||
blacklisted Boolean @default(false)
|
||||
}
|
||||
|
||||
model Session {
|
||||
token String @id
|
||||
data Json
|
||||
}
|
||||
|
||||
79
server/internal/session/db.ts
Normal file
79
server/internal/session/db.ts
Normal file
@ -0,0 +1,79 @@
|
||||
import { json } from "stream/consumers";
|
||||
import prisma from "../db/database";
|
||||
import { Session, SessionProvider } from "./types";
|
||||
import { Prisma } from "@prisma/client";
|
||||
|
||||
export default function createDBSessionHandler(): SessionProvider {
|
||||
return {
|
||||
async setSession(token, data) {
|
||||
// const strData = JSON.stringify(data);
|
||||
await prisma.session.upsert({
|
||||
where: {
|
||||
token,
|
||||
},
|
||||
create: {
|
||||
token,
|
||||
data,
|
||||
},
|
||||
update: {
|
||||
data,
|
||||
},
|
||||
});
|
||||
return true;
|
||||
},
|
||||
async updateSession(token, key, data) {
|
||||
const newObj: { [key: string]: any } = {};
|
||||
newObj[key] = data;
|
||||
|
||||
const session = await prisma.session.upsert({
|
||||
where: {
|
||||
token,
|
||||
},
|
||||
create: {
|
||||
token,
|
||||
data: newObj,
|
||||
},
|
||||
update: {},
|
||||
});
|
||||
|
||||
// if json object and not arrary, update session
|
||||
if (
|
||||
typeof session.data === "object" &&
|
||||
!Array.isArray(session.data) &&
|
||||
session.data !== null
|
||||
) {
|
||||
// means we set it above
|
||||
if (session.data[key] === data) return true;
|
||||
|
||||
// else we need to set it ourselves
|
||||
(session.data as Prisma.JsonObject)[key] = data;
|
||||
await prisma.session.update({
|
||||
where: {
|
||||
token,
|
||||
},
|
||||
data: {
|
||||
data: session.data,
|
||||
},
|
||||
});
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
async getSession<T>(token: string) {
|
||||
const result = await prisma.session.findUnique({
|
||||
where: {
|
||||
token,
|
||||
},
|
||||
});
|
||||
if (result === null) return undefined;
|
||||
return result.data as T;
|
||||
},
|
||||
async clearSession(token) {
|
||||
await prisma.session.delete({
|
||||
where: {
|
||||
token,
|
||||
},
|
||||
});
|
||||
},
|
||||
};
|
||||
}
|
||||
@ -6,6 +6,7 @@ import { v4 as uuidv4 } from "uuid";
|
||||
import moment from "moment";
|
||||
import { parse as parseCookies } from "cookie-es";
|
||||
import { MinimumRequestObject } from "~/server/h3";
|
||||
import createDBSessionHandler from "./db";
|
||||
|
||||
/*
|
||||
This implementation may need work.
|
||||
@ -24,11 +25,12 @@ export class SessionHandler {
|
||||
|
||||
constructor() {
|
||||
// Create a new provider
|
||||
this.sessionProvider = createMemorySessionProvider();
|
||||
this.sessionProvider = createDBSessionHandler();
|
||||
// this.sessionProvider = createMemorySessionProvider();
|
||||
}
|
||||
|
||||
private getSessionToken(request: MinimumRequestObject | undefined) {
|
||||
if(!request) throw new Error("Native web request not available");
|
||||
if (!request) throw new Error("Native web request not available");
|
||||
const cookieHeader = request.headers.get("Cookie");
|
||||
if (!cookieHeader) return undefined;
|
||||
const cookies = parseCookies(cookieHeader);
|
||||
|
||||
Reference in New Issue
Block a user