2023-05-17 13:46:44 +02:00
|
|
|
"use server";
|
|
|
|
|
|
|
|
|
|
import { cookies } from "next/headers";
|
|
|
|
|
|
|
|
|
|
export type SessionCookie = {
|
|
|
|
|
id: string;
|
|
|
|
|
token: string;
|
|
|
|
|
loginName: string;
|
|
|
|
|
changeDate: string;
|
2023-08-21 15:14:12 +02:00
|
|
|
authRequestId?: string; // if its linked to an OIDC flow
|
2023-05-17 13:46:44 +02:00
|
|
|
};
|
|
|
|
|
|
2023-05-24 18:00:45 +02:00
|
|
|
function setSessionHttpOnlyCookie(sessions: SessionCookie[]) {
|
2023-05-24 22:57:45 +02:00
|
|
|
const cookiesList = cookies();
|
2023-05-24 18:47:30 +02:00
|
|
|
// @ts-ignore
|
2023-05-24 18:00:45 +02:00
|
|
|
return cookiesList.set({
|
|
|
|
|
name: "sessions",
|
|
|
|
|
value: JSON.stringify(sessions),
|
|
|
|
|
httpOnly: true,
|
|
|
|
|
path: "/",
|
|
|
|
|
});
|
|
|
|
|
}
|
2023-06-29 14:54:07 +02:00
|
|
|
|
2023-05-17 13:46:44 +02:00
|
|
|
export async function addSessionToCookie(session: SessionCookie): Promise<any> {
|
|
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
2023-05-23 09:22:15 +02:00
|
|
|
let currentSessions: SessionCookie[] = stringifiedCookie?.value
|
2023-05-17 13:46:44 +02:00
|
|
|
? JSON.parse(stringifiedCookie?.value)
|
|
|
|
|
: [];
|
|
|
|
|
|
2023-05-23 09:22:15 +02:00
|
|
|
const index = currentSessions.findIndex(
|
|
|
|
|
(s) => s.loginName === session.loginName
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (index > -1) {
|
|
|
|
|
currentSessions[index] = session;
|
|
|
|
|
} else {
|
|
|
|
|
currentSessions = [...currentSessions, session];
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-29 14:54:07 +02:00
|
|
|
return setSessionHttpOnlyCookie(currentSessions);
|
2023-05-17 13:46:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export async function updateSessionCookie(
|
|
|
|
|
id: string,
|
|
|
|
|
session: SessionCookie
|
|
|
|
|
): Promise<any> {
|
|
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
|
|
|
|
const sessions: SessionCookie[] = stringifiedCookie?.value
|
|
|
|
|
? JSON.parse(stringifiedCookie?.value)
|
|
|
|
|
: [session];
|
|
|
|
|
|
|
|
|
|
const foundIndex = sessions.findIndex((session) => session.id === id);
|
2023-06-30 14:13:03 +02:00
|
|
|
if (foundIndex > -1) {
|
|
|
|
|
sessions[foundIndex] = session;
|
|
|
|
|
return setSessionHttpOnlyCookie(sessions);
|
|
|
|
|
} else {
|
|
|
|
|
throw "updateSessionCookie: session id now found";
|
|
|
|
|
}
|
2023-05-17 13:46:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export async function removeSessionFromCookie(
|
|
|
|
|
session: SessionCookie
|
|
|
|
|
): Promise<any> {
|
|
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
|
|
|
|
const sessions: SessionCookie[] = stringifiedCookie?.value
|
|
|
|
|
? JSON.parse(stringifiedCookie?.value)
|
|
|
|
|
: [session];
|
|
|
|
|
|
2023-05-24 14:12:38 +02:00
|
|
|
const filteredSessions = sessions.filter((s) => s.id !== session.id);
|
2023-05-17 13:46:44 +02:00
|
|
|
|
2023-05-24 18:00:45 +02:00
|
|
|
return setSessionHttpOnlyCookie(filteredSessions);
|
2023-05-17 13:46:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export async function getMostRecentSessionCookie(): Promise<any> {
|
|
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
|
|
|
|
if (stringifiedCookie?.value) {
|
|
|
|
|
const sessions: SessionCookie[] = JSON.parse(stringifiedCookie?.value);
|
|
|
|
|
|
|
|
|
|
const latest = sessions.reduce((prev, current) => {
|
|
|
|
|
return new Date(prev.changeDate).getTime() >
|
|
|
|
|
new Date(current.changeDate).getTime()
|
|
|
|
|
? prev
|
|
|
|
|
: current;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
return latest;
|
|
|
|
|
} else {
|
2023-06-29 17:04:34 +02:00
|
|
|
return Promise.reject("no session cookie found");
|
2023-05-17 13:46:44 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-29 17:04:34 +02:00
|
|
|
export async function getSessionCookieById(id: string): Promise<SessionCookie> {
|
2023-06-06 17:11:49 +02:00
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
|
|
|
|
if (stringifiedCookie?.value) {
|
|
|
|
|
const sessions: SessionCookie[] = JSON.parse(stringifiedCookie?.value);
|
|
|
|
|
|
|
|
|
|
const found = sessions.find((s) => s.id === id);
|
|
|
|
|
if (found) {
|
|
|
|
|
return found;
|
|
|
|
|
} else {
|
|
|
|
|
return Promise.reject();
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
return Promise.reject();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-29 17:04:34 +02:00
|
|
|
export async function getSessionCookieByLoginName(
|
|
|
|
|
loginName: string
|
|
|
|
|
): Promise<SessionCookie> {
|
|
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
|
|
|
|
if (stringifiedCookie?.value) {
|
|
|
|
|
const sessions: SessionCookie[] = JSON.parse(stringifiedCookie?.value);
|
|
|
|
|
|
|
|
|
|
const found = sessions.find((s) => s.loginName === loginName);
|
|
|
|
|
if (found) {
|
|
|
|
|
return found;
|
|
|
|
|
} else {
|
|
|
|
|
return Promise.reject("no cookie found with loginName: " + loginName);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
return Promise.reject("no session cookie found");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-17 15:25:25 +02:00
|
|
|
export async function getAllSessionIds(): Promise<any> {
|
|
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
|
|
|
|
if (stringifiedCookie?.value) {
|
|
|
|
|
const sessions: SessionCookie[] = JSON.parse(stringifiedCookie?.value);
|
|
|
|
|
return sessions.map((session) => session.id);
|
|
|
|
|
} else {
|
2023-05-25 08:40:53 +02:00
|
|
|
return [];
|
2023-05-17 15:25:25 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-21 15:14:12 +02:00
|
|
|
export async function getAllSessions(): Promise<SessionCookie[]> {
|
|
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
|
|
|
|
if (stringifiedCookie?.value) {
|
|
|
|
|
const sessions: SessionCookie[] = JSON.parse(stringifiedCookie?.value);
|
|
|
|
|
return sessions;
|
|
|
|
|
} else {
|
|
|
|
|
return [];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-17 15:25:25 +02:00
|
|
|
/**
|
|
|
|
|
* Returns most recent session filtered by optinal loginName
|
|
|
|
|
* @param loginName
|
|
|
|
|
* @returns most recent session
|
|
|
|
|
*/
|
2023-05-17 13:46:44 +02:00
|
|
|
export async function getMostRecentCookieWithLoginname(
|
2023-05-17 15:25:25 +02:00
|
|
|
loginName?: string
|
2023-05-17 13:46:44 +02:00
|
|
|
): Promise<any> {
|
|
|
|
|
const cookiesList = cookies();
|
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
|
|
|
|
|
|
if (stringifiedCookie?.value) {
|
|
|
|
|
const sessions: SessionCookie[] = JSON.parse(stringifiedCookie?.value);
|
2023-05-19 10:13:05 +02:00
|
|
|
const filtered = sessions.filter((cookie) => {
|
|
|
|
|
return !!loginName ? cookie.loginName === loginName : true;
|
|
|
|
|
});
|
2023-05-17 13:46:44 +02:00
|
|
|
|
2023-05-19 10:13:05 +02:00
|
|
|
const latest =
|
|
|
|
|
filtered && filtered.length
|
|
|
|
|
? filtered.reduce((prev, current) => {
|
|
|
|
|
return new Date(prev.changeDate).getTime() >
|
|
|
|
|
new Date(current.changeDate).getTime()
|
|
|
|
|
? prev
|
|
|
|
|
: current;
|
|
|
|
|
})
|
|
|
|
|
: undefined;
|
|
|
|
|
|
|
|
|
|
if (latest) {
|
|
|
|
|
return latest;
|
|
|
|
|
} else {
|
2023-06-21 13:13:51 +02:00
|
|
|
return Promise.reject("Could not get the context or retrieve a session");
|
2023-05-19 10:13:05 +02:00
|
|
|
}
|
2023-05-17 13:46:44 +02:00
|
|
|
} else {
|
2023-06-21 13:13:51 +02:00
|
|
|
return Promise.reject("Could not read session cookie");
|
2023-05-17 13:46:44 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export async function clearSessions() {}
|