From 635ed5a6e3afcb3a5728d15c52cc22f84cf60ae3 Mon Sep 17 00:00:00 2001 From: Milan Burda Date: Thu, 8 Jul 2021 09:19:16 +0200 Subject: [PATCH] feat: add missing resourceType conversions for webRequest listener details (#29902) --- docs/api/web-request.md | 16 +++++------ shell/browser/api/electron_api_web_request.cc | 28 ++++++++++--------- 2 files changed, 23 insertions(+), 21 deletions(-) diff --git a/docs/api/web-request.md b/docs/api/web-request.md index 7b7598c6f03f..fa1039b5e862 100644 --- a/docs/api/web-request.md +++ b/docs/api/web-request.md @@ -54,7 +54,7 @@ The following methods are available on instances of `WebRequest`: * `webContentsId` Integer (optional) * `webContents` WebContents (optional) * `frame` WebFrameMain (optional) - * `resourceType` String + * `resourceType` String - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`. * `referrer` String * `timestamp` Double * `uploadData` [UploadData[]](structures/upload-data.md) @@ -99,7 +99,7 @@ Some examples of valid `urls`: * `webContentsId` Integer (optional) * `webContents` WebContents (optional) * `frame` WebFrameMain (optional) - * `resourceType` String + * `resourceType` String - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`. * `referrer` String * `timestamp` Double * `requestHeaders` Record @@ -128,7 +128,7 @@ The `callback` has to be called with a `response` object. * `webContentsId` Integer (optional) * `webContents` WebContents (optional) * `frame` WebFrameMain (optional) - * `resourceType` String + * `resourceType` String - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`. * `referrer` String * `timestamp` Double * `requestHeaders` Record @@ -150,7 +150,7 @@ response are visible by the time this listener is fired. * `webContentsId` Integer (optional) * `webContents` WebContents (optional) * `frame` WebFrameMain (optional) - * `resourceType` String + * `resourceType` String - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`. * `referrer` String * `timestamp` Double * `statusLine` String @@ -183,7 +183,7 @@ The `callback` has to be called with a `response` object. * `webContentsId` Integer (optional) * `webContents` WebContents (optional) * `frame` WebFrameMain (optional) - * `resourceType` String + * `resourceType` String - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`. * `referrer` String * `timestamp` Double * `responseHeaders` Record (optional) @@ -209,7 +209,7 @@ and response headers are available. * `webContentsId` Integer (optional) * `webContents` WebContents (optional) * `frame` WebFrameMain (optional) - * `resourceType` String + * `resourceType` String - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`. * `referrer` String * `timestamp` Double * `redirectURL` String @@ -236,7 +236,7 @@ redirect is about to occur. * `webContentsId` Integer (optional) * `webContents` WebContents (optional) * `frame` WebFrameMain (optional) - * `resourceType` String + * `resourceType` String - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`. * `referrer` String * `timestamp` Double * `responseHeaders` Record (optional) @@ -261,7 +261,7 @@ completed. * `webContentsId` Integer (optional) * `webContents` WebContents (optional) * `frame` WebFrameMain (optional) - * `resourceType` String + * `resourceType` String - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`. * `referrer` String * `timestamp` Double * `fromCache` Boolean diff --git a/shell/browser/api/electron_api_web_request.cc b/shell/browser/api/electron_api_web_request.cc index 56845a6ced0c..fd2622dbcf1d 100644 --- a/shell/browser/api/electron_api_web_request.cc +++ b/shell/browser/api/electron_api_web_request.cc @@ -29,19 +29,6 @@ namespace gin { -template <> -struct Converter { - static bool FromV8(v8::Isolate* isolate, - v8::Local val, - URLPattern* out) { - std::string pattern; - if (!ConvertFromV8(isolate, val, &pattern)) - return false; - *out = URLPattern(URLPattern::SCHEME_ALL); - return out->Parse(pattern) == URLPattern::ParseResult::kSuccess; - } -}; - template <> struct Converter { static v8::Local ToV8(v8::Isolate* isolate, @@ -63,12 +50,27 @@ struct Converter { case extensions::WebRequestResourceType::IMAGE: result = "image"; break; + case extensions::WebRequestResourceType::FONT: + result = "font"; + break; case extensions::WebRequestResourceType::OBJECT: result = "object"; break; case extensions::WebRequestResourceType::XHR: result = "xhr"; break; + case extensions::WebRequestResourceType::PING: + result = "ping"; + break; + case extensions::WebRequestResourceType::CSP_REPORT: + result = "cspReport"; + break; + case extensions::WebRequestResourceType::MEDIA: + result = "media"; + break; + case extensions::WebRequestResourceType::WEB_SOCKET: + result = "webSocket"; + break; default: result = "other"; }