api/cookie/manager: pass cookiePath to writeChanges()
Some checks are pending
CodeQL / Analyze (${{ matrix.language }}) (none, javascript-typescript) (push) Waiting to run
Run service tests / test service functionality (push) Waiting to run
Run service tests / test service: ${{ matrix.service }} (push) Blocked by required conditions
Run tests / check lockfile correctness (push) Waiting to run
Run tests / web sanity check (push) Waiting to run
Run tests / api sanity check (push) Waiting to run

also reordered functions to maintain the hierarchy
This commit is contained in:
wukko 2024-10-28 12:08:12 +06:00
parent 7798844755
commit 7c516c0468
No known key found for this signature in database
GPG key ID: 3E30B3F26C7B4AA2

View file

@ -1,26 +1,15 @@
import Cookie from './cookie.js'; import Cookie from './cookie.js';
import { readFile, writeFile } from 'fs/promises'; import { readFile, writeFile } from 'fs/promises';
import { parse as parseSetCookie, splitCookiesString } from 'set-cookie-parser';
import { Green, Yellow } from '../../misc/console-text.js'; import { Green, Yellow } from '../../misc/console-text.js';
import { parse as parseSetCookie, splitCookiesString } from 'set-cookie-parser';
const WRITE_INTERVAL = 60000, const WRITE_INTERVAL = 60000,
COUNTER = Symbol('counter'); COUNTER = Symbol('counter');
let cookies = {}, dirty = false, intervalId; let cookies = {}, dirty = false, intervalId;
export const setup = async (cookiePath) => { function writeChanges(cookiePath) {
try {
cookies = await readFile(cookiePath, 'utf8');
cookies = JSON.parse(cookies);
intervalId = setInterval(writeChanges, WRITE_INTERVAL);
console.log(`${Green('[✓]')} cookies loaded successfully!`)
} catch(e) {
console.error(`${Yellow('[!]')} failed to load cookies.`);
console.error('error:', e);
}
}
function writeChanges() {
if (!dirty) return; if (!dirty) return;
dirty = false; dirty = false;
@ -29,6 +18,18 @@ function writeChanges() {
}) })
} }
export const setup = async (cookiePath) => {
try {
cookies = await readFile(cookiePath, 'utf8');
cookies = JSON.parse(cookies);
intervalId = setInterval(() => writeChanges(cookiePath), WRITE_INTERVAL);
console.log(`${Green('[✓]')} cookies loaded successfully!`)
} catch(e) {
console.error(`${Yellow('[!]')} failed to load cookies.`);
console.error('error:', e);
}
}
export function getCookie(service) { export function getCookie(service) {
if (!cookies[service] || !cookies[service].length) return; if (!cookies[service] || !cookies[service].length) return;
@ -46,6 +47,11 @@ export function getCookie(service) {
return cookies[service][n] return cookies[service][n]
} }
export function updateCookieValues(cookie, values) {
cookie.set(values);
if (Object.keys(values).length) dirty = true
}
export function updateCookie(cookie, headers) { export function updateCookie(cookie, headers) {
if (!cookie) return; if (!cookie) return;
@ -58,8 +64,3 @@ export function updateCookie(cookie, headers) {
parsed.filter(c => !c.expires || c.expires > new Date()).forEach(c => values[c.name] = c.value); parsed.filter(c => !c.expires || c.expires > new Date()).forEach(c => values[c.name] = c.value);
updateCookieValues(cookie, values); updateCookieValues(cookie, values);
} }
export function updateCookieValues(cookie, values) {
cookie.set(values);
if (Object.keys(values).length) dirty = true
}