mirror of
https://github.com/zitadel/zitadel.git
synced 2025-12-12 07:02:49 +00:00
153 lines
3.7 KiB
TypeScript
153 lines
3.7 KiB
TypeScript
"use server";
|
|
|
|
import { cookies } from "next/headers";
|
|
|
|
export type SessionCookie = {
|
|
id: string;
|
|
token: string;
|
|
loginName: string;
|
|
changeDate: string;
|
|
};
|
|
|
|
async function set(sessions: SessionCookie[]) {
|
|
const cookiesList = cookies();
|
|
// @ts-ignore
|
|
cookiesList.set({
|
|
name: "sessions",
|
|
value: JSON.stringify(sessions),
|
|
httpOnly: true,
|
|
path: "/",
|
|
});
|
|
}
|
|
|
|
export async function addSessionToCookie(session: SessionCookie): Promise<any> {
|
|
const cookiesList = cookies();
|
|
// const hasSessions = cookiesList.has("sessions");
|
|
// if (hasSessions) {
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
const currentSessions: SessionCookie[] = stringifiedCookie?.value
|
|
? JSON.parse(stringifiedCookie?.value)
|
|
: [];
|
|
|
|
// @ts-ignore
|
|
return cookiesList.set({
|
|
name: "sessions",
|
|
value: JSON.stringify([...currentSessions, session]),
|
|
httpOnly: true,
|
|
path: "/",
|
|
});
|
|
// } else {
|
|
// return set([session]);
|
|
// }
|
|
}
|
|
|
|
export async function updateSessionCookie(
|
|
id: string,
|
|
session: SessionCookie
|
|
): Promise<any> {
|
|
const cookiesList = cookies();
|
|
// const hasSessions = cookiesList.has("sessions");
|
|
// if (hasSessions) {
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
const sessions: SessionCookie[] = stringifiedCookie?.value
|
|
? JSON.parse(stringifiedCookie?.value)
|
|
: [session];
|
|
|
|
const foundIndex = sessions.findIndex((session) => session.id === id);
|
|
sessions[foundIndex] = session;
|
|
|
|
// @ts-ignore
|
|
return cookiesList.set({
|
|
name: "sessions",
|
|
value: JSON.stringify(sessions),
|
|
httpOnly: true,
|
|
path: "/",
|
|
});
|
|
// } else {
|
|
// return Promise.reject();
|
|
// }
|
|
}
|
|
|
|
export async function removeSessionFromCookie(
|
|
session: SessionCookie
|
|
): Promise<any> {
|
|
const cookiesList = cookies();
|
|
// const hasSessions = cookiesList.has("sessions");
|
|
// if (hasSessions) {
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
const sessions: SessionCookie[] = stringifiedCookie?.value
|
|
? JSON.parse(stringifiedCookie?.value)
|
|
: [session];
|
|
|
|
const filteredSessions = sessions.filter(
|
|
(session) => session.id !== session.id
|
|
);
|
|
|
|
// @ts-ignore
|
|
return cookiesList.set({
|
|
name: "sessions",
|
|
value: JSON.stringify(filteredSessions),
|
|
httpOnly: true,
|
|
path: "/",
|
|
});
|
|
// } else {
|
|
// return Promise.reject();
|
|
// }
|
|
}
|
|
|
|
export async function getMostRecentSessionCookie(): Promise<any> {
|
|
const cookiesList = cookies();
|
|
// const hasSessions = cookiesList.has("sessions");
|
|
// if (hasSessions) {
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
if (stringifiedCookie?.value) {
|
|
const sessions: SessionCookie[] = JSON.parse(stringifiedCookie?.value);
|
|
|
|
console.log(sessions);
|
|
const latest = sessions.reduce((prev, current) => {
|
|
return new Date(prev.changeDate).getTime() >
|
|
new Date(current.changeDate).getTime()
|
|
? prev
|
|
: current;
|
|
});
|
|
|
|
return latest;
|
|
} else {
|
|
return Promise.reject();
|
|
}
|
|
// } else {
|
|
// return Promise.reject();
|
|
// }
|
|
}
|
|
|
|
export async function getMostRecentCookieWithLoginname(
|
|
loginName: string
|
|
): Promise<any> {
|
|
const cookiesList = cookies();
|
|
|
|
const stringifiedCookie = cookiesList.get("sessions");
|
|
|
|
if (stringifiedCookie?.value) {
|
|
const sessions: SessionCookie[] = JSON.parse(stringifiedCookie?.value);
|
|
|
|
const latest = sessions
|
|
.filter((cookie) => cookie.loginName === loginName)
|
|
.reduce((prev, current) => {
|
|
return new Date(prev.changeDate).getTime() >
|
|
new Date(current.changeDate).getTime()
|
|
? prev
|
|
: current;
|
|
});
|
|
|
|
return latest;
|
|
} else {
|
|
return Promise.reject();
|
|
}
|
|
}
|
|
|
|
export async function clearSessions() {}
|