From ac470326a20c95bf1909cbbbb12b2bdfa0960cd8 Mon Sep 17 00:00:00 2001 From: Antoine du Hamel Date: Sun, 15 Nov 2020 20:13:24 +0100 Subject: [PATCH] policy: refactor to use more primordials MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit PR-URL: https://github.com/nodejs/node/pull/36210 Reviewed-By: Michaël Zasso Reviewed-By: James M Snell Reviewed-By: Juan José Arboleda Reviewed-By: Rich Trott Reviewed-By: Bradley Farias --- lib/internal/policy/manifest.js | 18 +++++++++--------- lib/internal/policy/sri.js | 11 +++++------ 2 files changed, 14 insertions(+), 15 deletions(-) diff --git a/lib/internal/policy/manifest.js b/lib/internal/policy/manifest.js index ba90de055c0949..6f4f094c980524 100644 --- a/lib/internal/policy/manifest.js +++ b/lib/internal/policy/manifest.js @@ -2,8 +2,6 @@ const { ArrayIsArray, - Map, - MapPrototypeSet, ObjectCreate, ObjectEntries, ObjectFreeze, @@ -12,6 +10,8 @@ const { RegExpPrototypeTest, SafeMap, SafeSet, + StringPrototypeEndsWith, + StringPrototypeReplace, Symbol, uncurryThis, } = primordials; @@ -334,14 +334,15 @@ class Manifest { * @returns {string} */ const protocolOrResolve = (resourceHREF) => { - if (resourceHREF.endsWith(':')) { + if (StringPrototypeEndsWith(resourceHREF, ':')) { // URL parse will trim these anyway, save the compute - resourceHREF = resourceHREF.replace( + resourceHREF = StringPrototypeReplace( + resourceHREF, // eslint-disable-next-line /^[\x00-\x1F\x20]|\x09\x0A\x0D|[\x00-\x1F\x20]$/g, '' ); - if (/^[a-zA-Z][a-zA-Z+\-.]*:$/.test(resourceHREF)) { + if (RegExpPrototypeTest(/^[a-zA-Z][a-zA-Z+\-.]*:$/, resourceHREF)) { return resourceHREF; } } @@ -424,7 +425,7 @@ class Manifest { // Only a few schemes are hierarchical if (kSpecialSchemes.has(currentURL.protocol)) { // Make first '..' act like '.' - if (currentURL.pathname.slice(-1) !== '/') { + if (!StringPrototypeEndsWith(currentURL.pathname, '/')) { currentURL.pathname += '/'; } let lastHREF; @@ -476,7 +477,7 @@ class Manifest { assertIntegrity(url, content) { const href = `${url}`; debug('Checking integrity of %s', href); - const realIntegrities = new Map(); + const realIntegrities = new SafeMap(); const integrities = this.#resourceIntegrities; function processEntry(href) { let integrityEntries = integrities.get(href); @@ -505,8 +506,7 @@ class Manifest { timingSafeEqual(digest, expected)) { return true; } - MapPrototypeSet( - realIntegrities, + realIntegrities.set( algorithm, BufferToString(digest, 'base64') ); diff --git a/lib/internal/policy/sri.js b/lib/internal/policy/sri.js index ddb06a2e1a6051..6728ff4de22bd1 100644 --- a/lib/internal/policy/sri.js +++ b/lib/internal/policy/sri.js @@ -3,9 +3,9 @@ // https://w3c.github.io/webappsec-subresource-integrity/#the-integrity-attribute const { + ArrayPrototype, ObjectDefineProperty, ObjectFreeze, - ObjectGetPrototypeOf, ObjectSeal, ObjectSetPrototypeOf, RegExp, @@ -32,7 +32,6 @@ const kAllWSP = RegExp(`^${kWSP}*$`); ObjectSeal(kAllWSP); const BufferFrom = require('buffer').Buffer.from; -const RealArrayPrototype = ObjectGetPrototypeOf([]); // Returns {algorithm, value (in base64 string), options,}[] const parse = (str) => { @@ -41,10 +40,10 @@ const parse = (str) => { const entries = []; while (match = RegExpPrototypeExec(kSRIPattern, str)) { if (match.index !== prevIndex) { - throw new ERR_SRI_PARSE(str, str.charAt(prevIndex), prevIndex); + throw new ERR_SRI_PARSE(str, str[prevIndex], prevIndex); } if (entries.length > 0 && match[1] === '') { - throw new ERR_SRI_PARSE(str, str.charAt(prevIndex), prevIndex); + throw new ERR_SRI_PARSE(str, str[prevIndex], prevIndex); } // Avoid setters being fired @@ -63,10 +62,10 @@ const parse = (str) => { if (prevIndex !== str.length) { if (!RegExpPrototypeTest(kAllWSP, StringPrototypeSlice(str, prevIndex))) { - throw new ERR_SRI_PARSE(str, str.charAt(prevIndex), prevIndex); + throw new ERR_SRI_PARSE(str, str[prevIndex], prevIndex); } } - return ObjectSetPrototypeOf(entries, RealArrayPrototype); + return ObjectSetPrototypeOf(entries, ArrayPrototype); }; module.exports = {