3f8de4
From 62287c7af3aabd73db9bd1057c4c6cfcb5f3f67b Mon Sep 17 00:00:00 2001
3f8de4
From: Takayuki Sato <sttk.xslet@gmail.com>
3f8de4
Date: Tue, 20 Jul 2021 14:46:33 +0900
3f8de4
Subject: [PATCH] deps(glob-parent): Resolve ReDoS vulnerability from
3f8de4
 CVE-2021-35065 (#49)
3f8de4
3f8de4
Signed-off-by: rpm-build <rpm-build>
3f8de4
---
3f8de4
 node_modules/glob-parent/index.js | 27 +++++++++++++++++++++++++--
3f8de4
 1 file changed, 25 insertions(+), 2 deletions(-)
3f8de4
3f8de4
diff --git a/node_modules/glob-parent/index.js b/node_modules/glob-parent/index.js
3f8de4
index 09e257e..b182190 100644
3f8de4
--- a/node_modules/glob-parent/index.js
3f8de4
+++ b/node_modules/glob-parent/index.js
3f8de4
@@ -6,7 +6,6 @@ var isWin32 = require('os').platform() === 'win32';
3f8de4
 
3f8de4
 var slash = '/';
3f8de4
 var backslash = /\\/g;
3f8de4
-var enclosure = /[\{\[].*[\}\]]$/;
3f8de4
 var globby = /(^|[^\\])([\{\[]|\([^\)]+$)/;
3f8de4
 var escaped = /\\([\!\*\?\|\[\]\(\)\{\}])/g;
3f8de4
 
3f8de4
@@ -25,7 +24,7 @@ module.exports = function globParent(str, opts) {
3f8de4
   }
3f8de4
 
3f8de4
   // special case for strings ending in enclosure containing path separator
3f8de4
-  if (enclosure.test(str)) {
3f8de4
+  if (isEnclosure(str)) {
3f8de4
     str += slash;
3f8de4
   }
3f8de4
 
3f8de4
@@ -40,3 +39,27 @@ module.exports = function globParent(str, opts) {
3f8de4
   // remove escape chars and return result
3f8de4
   return str.replace(escaped, '$1');
3f8de4
 };
3f8de4
+
3f8de4
+
3f8de4
+function isEnclosure(str) {
3f8de4
+  var lastChar = str.slice(-1)
3f8de4
+
3f8de4
+  var enclosureStart;
3f8de4
+  switch (lastChar) {
3f8de4
+    case '}':
3f8de4
+      enclosureStart = '{';
3f8de4
+      break;
3f8de4
+    case ']':
3f8de4
+      enclosureStart = '[';
3f8de4
+      break;
3f8de4
+    default:
3f8de4
+      return false;
3f8de4
+  }
3f8de4
+
3f8de4
+  var foundIndex = str.indexOf(enclosureStart);
3f8de4
+  if (foundIndex < 0) {
3f8de4
+    return false;
3f8de4
+  }
3f8de4
+
3f8de4
+  return str.slice(foundIndex + 1, -1).includes(slash);
3f8de4
+}
3f8de4
-- 
3f8de4
2.39.2
3f8de4