| Index: lib/filterClasses.js |
| =================================================================== |
| --- a/lib/filterClasses.js |
| +++ b/lib/filterClasses.js |
| @@ -766,16 +766,17 @@ |
| let contentType = null; |
| let matchCase = null; |
| let domains = null; |
| let sitekeys = null; |
| let thirdParty = null; |
| let collapse = null; |
| let csp = null; |
| + let rewrite = null; |
| let options; |
| let match = (text.indexOf("$") >= 0 ? Filter.optionsRegExp.exec(text) : null); |
| if (match) |
| { |
| options = match[1].split(","); |
| text = match.input.substr(0, match.index); |
| for (let option of options) |
| { |
| @@ -813,30 +814,32 @@ |
| else if (option == "~THIRD_PARTY") |
| thirdParty = false; |
| else if (option == "COLLAPSE") |
| collapse = true; |
| else if (option == "~COLLAPSE") |
| collapse = false; |
| else if (option == "SITEKEY" && value) |
| sitekeys = value.toUpperCase(); |
| + else if (option == "REWRITE" && value) |
| + rewrite = value; |
| else |
| return new InvalidFilter(origText, "filter_unknown_option"); |
| } |
| } |
| try |
| { |
| if (blocking) |
| { |
| if (csp && Filter.invalidCSPRegExp.test(csp)) |
| return new InvalidFilter(origText, "filter_invalid_csp"); |
| return new BlockingFilter(origText, text, contentType, matchCase, domains, |
| - thirdParty, sitekeys, collapse, csp); |
| + thirdParty, sitekeys, collapse, csp, rewrite); |
| } |
| return new WhitelistFilter(origText, text, contentType, matchCase, domains, |
| thirdParty, sitekeys); |
| } |
| catch (e) |
| { |
| return new InvalidFilter(origText, "filter_invalid_regexp"); |
| } |
| @@ -889,27 +892,30 @@ |
| * @param {boolean} matchCase see RegExpFilter() |
| * @param {string} domains see RegExpFilter() |
| * @param {boolean} thirdParty see RegExpFilter() |
| * @param {string} sitekeys see RegExpFilter() |
| * @param {boolean} collapse |
| * defines whether the filter should collapse blocked content, can be null |
| * @param {string} [csp] |
| * Content Security Policy to inject when the filter matches |
| + * @param {string} [rewrite] |
| + * The rewrite expression |
| * @constructor |
| * @augments RegExpFilter |
| */ |
| function BlockingFilter(text, regexpSource, contentType, matchCase, domains, |
| - thirdParty, sitekeys, collapse, csp) |
| + thirdParty, sitekeys, collapse, csp, rewrite) |
| { |
| RegExpFilter.call(this, text, regexpSource, contentType, matchCase, domains, |
| thirdParty, sitekeys); |
| this.collapse = collapse; |
| this.csp = csp; |
| + this.rewrite = rewrite; |
| } |
| exports.BlockingFilter = BlockingFilter; |
| BlockingFilter.prototype = extend(RegExpFilter, { |
| type: "blocking", |
| /** |
| * Defines whether the filter should collapse blocked content. |
| @@ -917,17 +923,43 @@ |
| * @type {boolean} |
| */ |
| collapse: null, |
| /** |
| * Content Security Policy to inject for matching requests. |
| * @type {string} |
| */ |
| - csp: null |
| + csp: null, |
| + |
| + /** |
| + * The rewrite expression |
| + * @type {string} |
|
Manish Jethani
2018/05/11 13:59:29
This should be {?string} now after rebasing.
hub
2018/05/11 15:57:33
Done.
|
| + */ |
| + rewrite: null, |
| + |
| + /** |
| + * Rewrites an URL. |
| + * @param {string} url the URL to rewrite |
|
Sebastian Noack
2018/05/08 17:09:30
The type annotated here is incorrect. We expect an
hub
2018/05/08 17:14:49
In the onBeforeRequest listener we pass details.ur
Sebastian Noack
2018/05/08 17:25:37
You are right. But didn't Manish suggest to pass i
Manish Jethani
2018/05/08 18:52:31
I was thinking that we already have a URL object o
|
| + * @return {string} the rewritten URL, or the original in case of failure |
| + */ |
| + rewriteUrl(url) |
| + { |
| + try |
| + { |
| + let rewrittenUrl = new URL(url.replace(this.regexp, this.rewrite), url); |
| + if (rewrittenUrl.origin == new URL(url).origin) |
| + return rewrittenUrl.href; |
| + } |
| + catch (e) |
| + { |
| + } |
| + |
| + return url; |
| + } |
| }); |
| /** |
| * Class for whitelist filters |
| * @param {string} text see Filter() |
| * @param {string} regexpSource see RegExpFilter() |
| * @param {number} contentType see RegExpFilter() |
| * @param {boolean} matchCase see RegExpFilter() |