Add WebRTCIPPolicy setting to webContents and webview
Resolves #8777 Code to set and get the policy come from the muon framework code: https://github.com/brave/muon/blob/master/atom/browser/api/atom_api_web_ contents.cc#L1324...L1343
This commit is contained in:
parent
4f817873f1
commit
1c2a78a896
7 changed files with 57 additions and 1 deletions
|
@ -1067,6 +1067,23 @@ void WebContents::GoToOffset(int offset) {
|
||||||
web_contents()->GetController().GoToOffset(offset);
|
web_contents()->GetController().GoToOffset(offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const std::string& WebContents::GetWebRTCIPHandlingPolicy() const {
|
||||||
|
return web_contents()->
|
||||||
|
GetMutableRendererPrefs()->webrtc_ip_handling_policy;
|
||||||
|
}
|
||||||
|
|
||||||
|
void WebContents::SetWebRTCIPHandlingPolicy(
|
||||||
|
const std::string webrtc_ip_handling_policy) {
|
||||||
|
if (GetWebRTCIPHandlingPolicy() == webrtc_ip_handling_policy)
|
||||||
|
return;
|
||||||
|
web_contents()->GetMutableRendererPrefs()->webrtc_ip_handling_policy =
|
||||||
|
webrtc_ip_handling_policy;
|
||||||
|
|
||||||
|
content::RenderViewHost* host = web_contents()->GetRenderViewHost();
|
||||||
|
if (host)
|
||||||
|
host->SyncRendererPrefs();
|
||||||
|
}
|
||||||
|
|
||||||
bool WebContents::IsCrashed() const {
|
bool WebContents::IsCrashed() const {
|
||||||
return web_contents()->IsCrashed();
|
return web_contents()->IsCrashed();
|
||||||
}
|
}
|
||||||
|
@ -1765,6 +1782,10 @@ void WebContents::BuildPrototype(v8::Isolate* isolate,
|
||||||
.SetMethod("copyImageAt", &WebContents::CopyImageAt)
|
.SetMethod("copyImageAt", &WebContents::CopyImageAt)
|
||||||
.SetMethod("capturePage", &WebContents::CapturePage)
|
.SetMethod("capturePage", &WebContents::CapturePage)
|
||||||
.SetMethod("setEmbedder", &WebContents::SetEmbedder)
|
.SetMethod("setEmbedder", &WebContents::SetEmbedder)
|
||||||
|
.SetMethod("setWebRTCIPHandlingPolicy",
|
||||||
|
&WebContents::SetWebRTCIPHandlingPolicy)
|
||||||
|
.SetMethod("getWebRTCIPHandlingPolicy",
|
||||||
|
&WebContents::GetWebRTCIPHandlingPolicy)
|
||||||
.SetProperty("id", &WebContents::ID)
|
.SetProperty("id", &WebContents::ID)
|
||||||
.SetProperty("session", &WebContents::Session)
|
.SetProperty("session", &WebContents::Session)
|
||||||
.SetProperty("hostWebContents", &WebContents::HostWebContents)
|
.SetProperty("hostWebContents", &WebContents::HostWebContents)
|
||||||
|
|
|
@ -92,6 +92,8 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
void GoBack();
|
void GoBack();
|
||||||
void GoForward();
|
void GoForward();
|
||||||
void GoToOffset(int offset);
|
void GoToOffset(int offset);
|
||||||
|
const std::string& GetWebRTCIPHandlingPolicy() const;
|
||||||
|
void SetWebRTCIPHandlingPolicy(const std::string webrtc_ip_handling_policy);
|
||||||
bool IsCrashed() const;
|
bool IsCrashed() const;
|
||||||
void SetUserAgent(const std::string& user_agent, mate::Arguments* args);
|
void SetUserAgent(const std::string& user_agent, mate::Arguments* args);
|
||||||
std::string GetUserAgent();
|
std::string GetUserAgent();
|
||||||
|
|
|
@ -1245,6 +1245,20 @@ Schedules a full repaint of the window this web contents is in.
|
||||||
If *offscreen rendering* is enabled invalidates the frame and generates a new
|
If *offscreen rendering* is enabled invalidates the frame and generates a new
|
||||||
one through the `'paint'` event.
|
one through the `'paint'` event.
|
||||||
|
|
||||||
|
#### `contents.getWebRTCIPHandlingPolicy()`
|
||||||
|
|
||||||
|
* Returns `String` - Returns the WebRTC IP Handling Policy
|
||||||
|
|
||||||
|
#### `contents.setWebRTCIPHandlingPolicy(policy)`
|
||||||
|
|
||||||
|
* `policy` String - Specify the WebRTC IP Handling Policy
|
||||||
|
* `default` - Exposes user's public and local IPs. This is the default behavior if not specified.
|
||||||
|
* `default_public_interface_only` - Exposes user's public IP, but does not expose user's local IP.
|
||||||
|
* `default_public_and_private_interfaces` - Exposes user's public and local IPs.
|
||||||
|
* `disable_non_proxied_udp` - Does not expose public or local IPs.
|
||||||
|
|
||||||
|
Setting the WebRTC IP handling policy allows you to control which IPs are exposed via WebRTC. See [BrowserLeaks](https://browserleaks.com/webrtc) for more details.
|
||||||
|
|
||||||
### Instance Properties
|
### Instance Properties
|
||||||
|
|
||||||
#### `contents.id`
|
#### `contents.id`
|
||||||
|
|
|
@ -289,6 +289,13 @@ win.on('resize', () => {
|
||||||
})
|
})
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### `webrtcippolicy`
|
||||||
|
|
||||||
|
```html
|
||||||
|
<webview src="https://browserleaks.com/webrtc" webrtcippolicy="disable_non_proxied_udp"></webview>
|
||||||
|
```
|
||||||
|
This attribute allows you to set the WebRTC IP handling policy which controls what IPs are exposed via WebRTC. See [webContents](web-contents.md#contentssetwebrtciphandlingpolicypolicy) for available policies.
|
||||||
|
|
||||||
## Methods
|
## Methods
|
||||||
|
|
||||||
The `webview` tag has the following methods:
|
The `webview` tag has the following methods:
|
||||||
|
|
|
@ -103,6 +103,9 @@ const createGuest = function (embedder, params) {
|
||||||
height: params.maxheight
|
height: params.maxheight
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
if (params.webrtcippolicy) {
|
||||||
|
guest.setWebRTCIPHandlingPolicy(params.webrtcippolicy)
|
||||||
|
}
|
||||||
if (params.src) {
|
if (params.src) {
|
||||||
const opts = {}
|
const opts = {}
|
||||||
if (params.httpreferrer) {
|
if (params.httpreferrer) {
|
||||||
|
|
|
@ -304,6 +304,13 @@ class DisableBlinkFeaturesAttribute extends WebViewAttribute {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Attribute specifies WebRTC IP handling policy for handling IP leaking.
|
||||||
|
class WebRTCIPHandlingPolicyAttribute extends WebViewAttribute {
|
||||||
|
constructor (webViewImpl) {
|
||||||
|
super(webViewConstants.ATTRIBUTE_WEBRTCIPPOLICY, webViewImpl)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Attribute that specifies the web preferences to be enabled.
|
// Attribute that specifies the web preferences to be enabled.
|
||||||
class WebPreferencesAttribute extends WebViewAttribute {
|
class WebPreferencesAttribute extends WebViewAttribute {
|
||||||
constructor (webViewImpl) {
|
constructor (webViewImpl) {
|
||||||
|
@ -329,6 +336,7 @@ WebViewImpl.prototype.setupWebViewAttributes = function () {
|
||||||
this.attributes[webViewConstants.ATTRIBUTE_GUESTINSTANCE] = new GuestInstanceAttribute(this)
|
this.attributes[webViewConstants.ATTRIBUTE_GUESTINSTANCE] = new GuestInstanceAttribute(this)
|
||||||
this.attributes[webViewConstants.ATTRIBUTE_DISABLEGUESTRESIZE] = new BooleanAttribute(webViewConstants.ATTRIBUTE_DISABLEGUESTRESIZE, this)
|
this.attributes[webViewConstants.ATTRIBUTE_DISABLEGUESTRESIZE] = new BooleanAttribute(webViewConstants.ATTRIBUTE_DISABLEGUESTRESIZE, this)
|
||||||
this.attributes[webViewConstants.ATTRIBUTE_WEBPREFERENCES] = new WebPreferencesAttribute(this)
|
this.attributes[webViewConstants.ATTRIBUTE_WEBPREFERENCES] = new WebPreferencesAttribute(this)
|
||||||
|
this.attributes[webViewConstants.ATTRIBUTE_WEBRTCIPPOLICY] = new WebRTCIPHandlingPolicyAttribute(this)
|
||||||
|
|
||||||
const autosizeAttributes = [webViewConstants.ATTRIBUTE_MAXHEIGHT, webViewConstants.ATTRIBUTE_MAXWIDTH, webViewConstants.ATTRIBUTE_MINHEIGHT, webViewConstants.ATTRIBUTE_MINWIDTH]
|
const autosizeAttributes = [webViewConstants.ATTRIBUTE_MAXHEIGHT, webViewConstants.ATTRIBUTE_MAXWIDTH, webViewConstants.ATTRIBUTE_MINHEIGHT, webViewConstants.ATTRIBUTE_MINWIDTH]
|
||||||
autosizeAttributes.forEach((attribute) => {
|
autosizeAttributes.forEach((attribute) => {
|
||||||
|
|
|
@ -20,6 +20,7 @@ module.exports = {
|
||||||
ATTRIBUTE_GUESTINSTANCE: 'guestinstance',
|
ATTRIBUTE_GUESTINSTANCE: 'guestinstance',
|
||||||
ATTRIBUTE_DISABLEGUESTRESIZE: 'disableguestresize',
|
ATTRIBUTE_DISABLEGUESTRESIZE: 'disableguestresize',
|
||||||
ATTRIBUTE_WEBPREFERENCES: 'webpreferences',
|
ATTRIBUTE_WEBPREFERENCES: 'webpreferences',
|
||||||
|
ATTRIBUTE_WEBRTCIPPOLICY: 'webrtcippolicy',
|
||||||
|
|
||||||
// Internal attribute.
|
// Internal attribute.
|
||||||
ATTRIBUTE_INTERNALINSTANCEID: 'internalinstanceid',
|
ATTRIBUTE_INTERNALINSTANCEID: 'internalinstanceid',
|
||||||
|
|
Loading…
Reference in a new issue