dsql-admin/dsql-app/package-shared/functions/backend/cookies/get-auth-cookie-names.ts

47 lines
1.5 KiB
TypeScript
Raw Normal View History

2025-01-13 08:00:21 +00:00
type Param = {
database?: string;
userId?: string | number;
};
type Return = {
keyCookieName: string;
csrfCookieName: string;
oneTimeCodeName: string;
};
2024-12-08 08:57:48 +00:00
/**
* # Grab Auth Cookie Names
*/
2025-01-13 08:00:21 +00:00
export default function getAuthCookieNames(params?: Param): Return {
2024-12-06 13:24:26 +00:00
const cookiesPrefix = process.env.DSQL_COOKIES_PREFIX || "dsql_";
const cookiesKeyName = process.env.DSQL_COOKIES_KEY_NAME || "key";
const cookiesCSRFName = process.env.DSQL_COOKIES_CSRF_NAME || "csrf";
2024-12-15 11:27:16 +00:00
const cookieOneTimeCodeName =
process.env.DSQL_COOKIES_ONE_TIME_CODE_NAME || "one-time-code";
2024-12-06 13:24:26 +00:00
2024-12-09 12:27:08 +00:00
const targetDatabase =
2024-12-15 11:27:16 +00:00
params?.database?.replace(/^datasquirel_user_\d+_/, "") ||
2024-12-09 12:27:08 +00:00
process.env.DSQL_DB_NAME?.replace(/^datasquirel_user_\d+_/, "");
2024-12-08 08:57:48 +00:00
let keyCookieName = cookiesPrefix;
if (params?.userId) keyCookieName += `user_${params.userId}_`;
2024-12-09 12:27:08 +00:00
if (targetDatabase) keyCookieName += `${targetDatabase}_`;
2024-12-08 08:57:48 +00:00
keyCookieName += cookiesKeyName;
let csrfCookieName = cookiesPrefix;
if (params?.userId) csrfCookieName += `user_${params.userId}_`;
2024-12-09 12:27:08 +00:00
if (targetDatabase) csrfCookieName += `${targetDatabase}_`;
2024-12-08 08:57:48 +00:00
csrfCookieName += cookiesCSRFName;
2024-12-06 13:24:26 +00:00
2024-12-15 11:27:16 +00:00
let oneTimeCodeName = cookiesPrefix;
if (params?.userId) oneTimeCodeName += `user_${params.userId}_`;
if (targetDatabase) oneTimeCodeName += `${targetDatabase}_`;
oneTimeCodeName += cookieOneTimeCodeName;
2024-12-06 13:24:26 +00:00
return {
keyCookieName,
csrfCookieName,
2024-12-15 11:27:16 +00:00
oneTimeCodeName,
2024-12-06 13:24:26 +00:00
};
2025-01-13 08:00:21 +00:00
}