From 6bf0a5cb5034a7e684dcc3500e841785237ce2dd Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 19:32:43 +0200 Subject: Adding upstream version 1:115.7.0. Signed-off-by: Daniel Baumann --- .../network-observer/WildcardToRegexp.sys.mjs | 28 ++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 devtools/shared/network-observer/WildcardToRegexp.sys.mjs (limited to 'devtools/shared/network-observer/WildcardToRegexp.sys.mjs') diff --git a/devtools/shared/network-observer/WildcardToRegexp.sys.mjs b/devtools/shared/network-observer/WildcardToRegexp.sys.mjs new file mode 100644 index 0000000000..4c495fdd78 --- /dev/null +++ b/devtools/shared/network-observer/WildcardToRegexp.sys.mjs @@ -0,0 +1,28 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +/** + * Converts a URL-like string which might include the `*` character as a wildcard + * to a regular expression. They are used to match against actual URLs for the + * request blocking feature from DevTools. + * + * The returned regular expression is case insensitive. + * + * @param {string} url + * A URL-like string which can contain one or several `*` as wildcard + * characters. + * @return {RegExp} + * A regular expression which can be used to match URLs compatible with the + * provided url "template". + */ +export function wildcardToRegExp(url) { + return new RegExp(url.split("*").map(regExpEscape).join(".*"), "i"); +} + +/** + * Escapes all special RegExp characters in the given string. + */ +const regExpEscape = s => { + return s.replace(/[|\\{}()[\]^$+*?.]/g, "\\$&"); +}; -- cgit v1.2.3