From a4879b4663f1cbe190bcd6e62879ab4f994a0409 Mon Sep 17 00:00:00 2001 From: Khafra Date: Wed, 22 May 2024 18:18:35 -0400 Subject: [PATCH] don't use internal header state for cookies (#3295) --- lib/web/cookies/index.js | 7 +++---- lib/web/cookies/util.js | 29 +---------------------------- lib/web/fetch/headers.js | 8 -------- test/cookie/global-headers.js | 3 +-- 4 files changed, 5 insertions(+), 42 deletions(-) diff --git a/lib/web/cookies/index.js b/lib/web/cookies/index.js index d40c71318e5..323aa9ee6fb 100644 --- a/lib/web/cookies/index.js +++ b/lib/web/cookies/index.js @@ -1,7 +1,7 @@ 'use strict' const { parseSetCookie } = require('./parse') -const { stringify, getHeadersList } = require('./util') +const { stringify } = require('./util') const { webidl } = require('../fetch/webidl') const { Headers } = require('../fetch/headers') @@ -78,14 +78,13 @@ function getSetCookies (headers) { webidl.brandCheck(headers, Headers, { strict: false }) - const cookies = getHeadersList(headers).cookies + const cookies = headers.getSetCookie() if (!cookies) { return [] } - // In older versions of undici, cookies is a list of name:value. - return cookies.map((pair) => parseSetCookie(Array.isArray(pair) ? pair[1] : pair)) + return cookies.map((pair) => parseSetCookie(pair)) } /** diff --git a/lib/web/cookies/util.js b/lib/web/cookies/util.js index 8c6a77bc717..254f5419e90 100644 --- a/lib/web/cookies/util.js +++ b/lib/web/cookies/util.js @@ -1,8 +1,5 @@ 'use strict' -const assert = require('node:assert') -const { getHeadersList: internalGetHeadersList } = require('../fetch/headers') - /** * @param {string} value * @returns {boolean} @@ -275,35 +272,11 @@ function stringify (cookie) { return out.join('; ') } -let kHeadersListNode - -function getHeadersList (headers) { - try { - return internalGetHeadersList(headers) - } catch { - // fall-through - } - - if (!kHeadersListNode) { - kHeadersListNode = Object.getOwnPropertySymbols(headers).find( - (symbol) => symbol.description === 'headers list' - ) - - assert(kHeadersListNode, 'Headers cannot be parsed') - } - - const headersList = headers[kHeadersListNode] - assert(headersList) - - return headersList -} - module.exports = { isCTLExcludingHtab, validateCookieName, validateCookiePath, validateCookieValue, toIMFDate, - stringify, - getHeadersList + stringify } diff --git a/lib/web/fetch/headers.js b/lib/web/fetch/headers.js index 679cbbf9ef0..816aceacce4 100644 --- a/lib/web/fetch/headers.js +++ b/lib/web/fetch/headers.js @@ -641,14 +641,6 @@ Object.defineProperties(Headers.prototype, { }, [util.inspect.custom]: { enumerable: false - }, - // Compatibility for global headers - [Symbol('headers list')]: { - configurable: false, - enumerable: false, - get: function () { - return getHeadersList(this) - } } }) diff --git a/test/cookie/global-headers.js b/test/cookie/global-headers.js index 4afccc490ed..c5ea92d797c 100644 --- a/test/cookie/global-headers.js +++ b/test/cookie/global-headers.js @@ -8,7 +8,6 @@ const { getSetCookies, setCookie } = require('../..') -const { getHeadersList } = require('../../lib/web/cookies/util') describe('Using global Headers', async () => { test('deleteCookies', () => { @@ -32,7 +31,7 @@ describe('Using global Headers', async () => { 'set-cookie': 'undici=getSetCookies; Secure' }) - const supportsCookies = getHeadersList(headers).cookies + const supportsCookies = headers.getSetCookie() if (!supportsCookies) { assert.deepEqual(getSetCookies(headers), [])