From 6688569a50f14fc9e5a5c43f5422edde3f7cb71e Mon Sep 17 00:00:00 2001 From: Antoine du Hamel Date: Fri, 12 Feb 2021 12:10:57 +0100 Subject: [PATCH] http: refactor to avoid unsafe array iteration PR-URL: https://github.com/nodejs/node/pull/37654 Reviewed-By: Darshan Sen Reviewed-By: Zijian Liu --- lib/_http_agent.js | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/lib/_http_agent.js b/lib/_http_agent.js index 646f26bf0d57ce..883803dd54484b 100644 --- a/lib/_http_agent.js +++ b/lib/_http_agent.js @@ -27,6 +27,7 @@ const { ArrayPrototypePop, ArrayPrototypePush, ArrayPrototypeShift, + ArrayPrototypeSome, ArrayPrototypeSplice, FunctionPrototypeCall, NumberIsNaN, @@ -390,10 +391,10 @@ function installListeners(agent, s, options) { // Destroy if in free list. // TODO(ronag): Always destroy, even if not in free list. const sockets = agent.freeSockets; - for (const name of ObjectKeys(sockets)) { - if (ArrayPrototypeIncludes(sockets[name], s)) { - return s.destroy(); - } + if (ArrayPrototypeSome(ObjectKeys(sockets), (name) => + ArrayPrototypeIncludes(sockets[name], s) + )) { + return s.destroy(); } } s.on('timeout', onTimeout); @@ -449,7 +450,9 @@ Agent.prototype.removeSocket = function removeSocket(s, options) { // There might be older requests in a different origin, but // if the origin which releases the socket has pending requests // that will be prioritized. - for (const prop of ObjectKeys(this.requests)) { + const keys = ObjectKeys(this.requests); + for (let i = 0; i < keys.length; i++) { + const prop = keys[i]; // Check whether this specific origin is already at maxSockets if (this.sockets[prop] && this.sockets[prop].length) break; debug('removeSocket, have a request with different origin,' +