mirror of
https://github.com/Drop-OSS/drop.git
synced 2025-11-13 16:22:39 +10:00
store sessions in db
This commit is contained in:
@ -50,3 +50,8 @@ model Certificate {
|
|||||||
|
|
||||||
blacklisted Boolean @default(false)
|
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 moment from "moment";
|
||||||
import { parse as parseCookies } from "cookie-es";
|
import { parse as parseCookies } from "cookie-es";
|
||||||
import { MinimumRequestObject } from "~/server/h3";
|
import { MinimumRequestObject } from "~/server/h3";
|
||||||
|
import createDBSessionHandler from "./db";
|
||||||
|
|
||||||
/*
|
/*
|
||||||
This implementation may need work.
|
This implementation may need work.
|
||||||
@ -24,11 +25,12 @@ export class SessionHandler {
|
|||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
// Create a new provider
|
// Create a new provider
|
||||||
this.sessionProvider = createMemorySessionProvider();
|
this.sessionProvider = createDBSessionHandler();
|
||||||
|
// this.sessionProvider = createMemorySessionProvider();
|
||||||
}
|
}
|
||||||
|
|
||||||
private getSessionToken(request: MinimumRequestObject | undefined) {
|
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");
|
const cookieHeader = request.headers.get("Cookie");
|
||||||
if (!cookieHeader) return undefined;
|
if (!cookieHeader) return undefined;
|
||||||
const cookies = parseCookies(cookieHeader);
|
const cookies = parseCookies(cookieHeader);
|
||||||
|
|||||||
Reference in New Issue
Block a user