2022-08-15 17:33:25 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) Sapphirecode - All Rights Reserved
|
|
|
|
* This file is part of Auth-Server-Helper which is released under MIT.
|
|
|
|
* See file 'LICENSE' for full license details.
|
|
|
|
* Created by Timo Hocker <timo@scode.ovh>, August 2022
|
|
|
|
*/
|
|
|
|
|
2022-01-08 22:10:02 +01:00
|
|
|
import { run_regex } from '@sapphirecode/utilities';
|
|
|
|
import { debug } from './debug';
|
|
|
|
|
|
|
|
const logger = debug ('cookies');
|
|
|
|
|
2022-01-10 10:06:54 +01:00
|
|
|
type SameSiteValue = 'Lax' | 'None' | 'Strict';
|
|
|
|
|
|
|
|
interface CookieSettings {
|
|
|
|
name: string;
|
|
|
|
secure?: boolean;
|
|
|
|
http_only?: boolean;
|
|
|
|
same_site?: SameSiteValue|null;
|
|
|
|
expires?: string;
|
|
|
|
max_age?: number;
|
|
|
|
domain?: string;
|
|
|
|
path?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const default_settings: Omit<CookieSettings, 'name'> = {
|
|
|
|
secure: true,
|
|
|
|
http_only: true,
|
|
|
|
same_site: 'Strict'
|
|
|
|
};
|
|
|
|
|
|
|
|
function build_cookie (
|
|
|
|
settings: CookieSettings,
|
|
|
|
value: string
|
|
|
|
): string {
|
|
|
|
const local_settings = { ...default_settings, ...settings };
|
|
|
|
const sections = [ `${local_settings.name}=${value}` ];
|
|
|
|
|
|
|
|
if (local_settings.secure)
|
|
|
|
sections.push ('Secure');
|
|
|
|
if (local_settings.http_only)
|
|
|
|
sections.push ('HttpOnly');
|
|
|
|
if (
|
|
|
|
typeof local_settings.same_site !== 'undefined'
|
|
|
|
&& local_settings.same_site !== null
|
|
|
|
)
|
|
|
|
sections.push (`SameSite=${local_settings.same_site}`);
|
|
|
|
if (typeof local_settings.expires !== 'undefined')
|
|
|
|
sections.push (`Expires=${local_settings.expires}`);
|
|
|
|
if (typeof local_settings.max_age !== 'undefined')
|
|
|
|
sections.push (`Max-Age=${local_settings.max_age}`);
|
|
|
|
if (typeof local_settings.domain !== 'undefined')
|
|
|
|
sections.push (`Domain=${local_settings.domain}`);
|
|
|
|
if (typeof local_settings.path !== 'undefined')
|
|
|
|
sections.push (`Path=${local_settings.path}`);
|
|
|
|
|
|
|
|
return sections.join ('; ');
|
2022-01-08 22:10:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function extract_cookie (
|
|
|
|
name: string|undefined,
|
|
|
|
header: string|undefined
|
|
|
|
): string| null {
|
2022-08-15 17:33:25 +02:00
|
|
|
const log = logger.extend ('extract_cookie');
|
|
|
|
log (`extracting cookie ${name}`);
|
2022-01-08 22:10:02 +01:00
|
|
|
|
|
|
|
const cookie_regex = /(?:^|;)\s*(?<name>[^;=]+)=(?<value>[^;]+)/gu;
|
|
|
|
|
|
|
|
let result = null;
|
|
|
|
|
|
|
|
run_regex (
|
|
|
|
cookie_regex,
|
|
|
|
header,
|
|
|
|
(res: RegExpMatchArray) => {
|
2022-08-15 17:33:25 +02:00
|
|
|
log ('parsing cookie %s', res.groups?.name);
|
2022-01-08 22:10:02 +01:00
|
|
|
if (res.groups?.name === name) {
|
2022-08-15 17:33:25 +02:00
|
|
|
log ('found cookie');
|
2022-01-08 22:10:02 +01:00
|
|
|
result = res.groups?.value as string;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2022-01-10 10:06:54 +01:00
|
|
|
export { build_cookie, extract_cookie, SameSiteValue, CookieSettings };
|