Merge branch 'master' into chrome51
This commit is contained in:
commit
9f858e1243
13 changed files with 94 additions and 54 deletions
|
@ -375,12 +375,6 @@ void App::SetDesktopName(const std::string& desktop_name) {
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void App::AllowNTLMCredentialsForAllDomains(bool should_allow) {
|
|
||||||
auto browser_context = static_cast<AtomBrowserContext*>(
|
|
||||||
AtomBrowserMainParts::Get()->browser_context());
|
|
||||||
browser_context->AllowNTLMCredentialsForAllDomains(should_allow);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string App::GetLocale() {
|
std::string App::GetLocale() {
|
||||||
return l10n_util::GetApplicationLocale("");
|
return l10n_util::GetApplicationLocale("");
|
||||||
}
|
}
|
||||||
|
@ -482,8 +476,6 @@ void App::BuildPrototype(
|
||||||
.SetMethod("setPath", &App::SetPath)
|
.SetMethod("setPath", &App::SetPath)
|
||||||
.SetMethod("getPath", &App::GetPath)
|
.SetMethod("getPath", &App::GetPath)
|
||||||
.SetMethod("setDesktopName", &App::SetDesktopName)
|
.SetMethod("setDesktopName", &App::SetDesktopName)
|
||||||
.SetMethod("allowNTLMCredentialsForAllDomains",
|
|
||||||
&App::AllowNTLMCredentialsForAllDomains)
|
|
||||||
.SetMethod("getLocale", &App::GetLocale)
|
.SetMethod("getLocale", &App::GetLocale)
|
||||||
#if defined(USE_NSS_CERTS)
|
#if defined(USE_NSS_CERTS)
|
||||||
.SetMethod("importCertificate", &App::ImportCertificate)
|
.SetMethod("importCertificate", &App::ImportCertificate)
|
||||||
|
|
|
@ -106,7 +106,6 @@ class App : public AtomBrowserClient::Delegate,
|
||||||
const base::FilePath& path);
|
const base::FilePath& path);
|
||||||
|
|
||||||
void SetDesktopName(const std::string& desktop_name);
|
void SetDesktopName(const std::string& desktop_name);
|
||||||
void AllowNTLMCredentialsForAllDomains(bool should_allow);
|
|
||||||
bool MakeSingleInstance(
|
bool MakeSingleInstance(
|
||||||
const ProcessSingleton::NotificationCallback& callback);
|
const ProcessSingleton::NotificationCallback& callback);
|
||||||
std::string GetLocale();
|
std::string GetLocale();
|
||||||
|
|
|
@ -36,6 +36,8 @@
|
||||||
#include "net/base/load_flags.h"
|
#include "net/base/load_flags.h"
|
||||||
#include "net/disk_cache/disk_cache.h"
|
#include "net/disk_cache/disk_cache.h"
|
||||||
#include "net/dns/host_cache.h"
|
#include "net/dns/host_cache.h"
|
||||||
|
#include "net/http/http_auth_handler_factory.h"
|
||||||
|
#include "net/http/http_auth_preferences.h"
|
||||||
#include "net/proxy/proxy_service.h"
|
#include "net/proxy/proxy_service.h"
|
||||||
#include "net/proxy/proxy_config_service_fixed.h"
|
#include "net/proxy/proxy_config_service_fixed.h"
|
||||||
#include "net/url_request/url_request_context.h"
|
#include "net/url_request/url_request_context.h"
|
||||||
|
@ -284,6 +286,19 @@ void ClearHostResolverCacheInIO(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AllowNTLMCredentialsForDomainsInIO(
|
||||||
|
const scoped_refptr<net::URLRequestContextGetter>& context_getter,
|
||||||
|
const std::string& domains) {
|
||||||
|
auto request_context = context_getter->GetURLRequestContext();
|
||||||
|
auto auth_handler = request_context->http_auth_handler_factory();
|
||||||
|
if (auth_handler) {
|
||||||
|
auto auth_preferences = const_cast<net::HttpAuthPreferences*>(
|
||||||
|
auth_handler->http_auth_preferences());
|
||||||
|
if (auth_preferences)
|
||||||
|
auth_preferences->set_server_whitelist(domains);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
Session::Session(v8::Isolate* isolate, AtomBrowserContext* browser_context)
|
Session::Session(v8::Isolate* isolate, AtomBrowserContext* browser_context)
|
||||||
|
@ -432,6 +447,13 @@ void Session::ClearHostResolverCache(mate::Arguments* args) {
|
||||||
callback));
|
callback));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Session::AllowNTLMCredentialsForDomains(const std::string& domains) {
|
||||||
|
BrowserThread::PostTask(BrowserThread::IO, FROM_HERE,
|
||||||
|
base::Bind(&AllowNTLMCredentialsForDomainsInIO,
|
||||||
|
make_scoped_refptr(browser_context_->GetRequestContext()),
|
||||||
|
domains));
|
||||||
|
}
|
||||||
|
|
||||||
v8::Local<v8::Value> Session::Cookies(v8::Isolate* isolate) {
|
v8::Local<v8::Value> Session::Cookies(v8::Isolate* isolate) {
|
||||||
if (cookies_.IsEmpty()) {
|
if (cookies_.IsEmpty()) {
|
||||||
auto handle = atom::api::Cookies::Create(isolate, browser_context());
|
auto handle = atom::api::Cookies::Create(isolate, browser_context());
|
||||||
|
@ -487,6 +509,8 @@ void Session::BuildPrototype(v8::Isolate* isolate,
|
||||||
.SetMethod("setPermissionRequestHandler",
|
.SetMethod("setPermissionRequestHandler",
|
||||||
&Session::SetPermissionRequestHandler)
|
&Session::SetPermissionRequestHandler)
|
||||||
.SetMethod("clearHostResolverCache", &Session::ClearHostResolverCache)
|
.SetMethod("clearHostResolverCache", &Session::ClearHostResolverCache)
|
||||||
|
.SetMethod("allowNTLMCredentialsForDomains",
|
||||||
|
&Session::AllowNTLMCredentialsForDomains)
|
||||||
.SetProperty("cookies", &Session::Cookies)
|
.SetProperty("cookies", &Session::Cookies)
|
||||||
.SetProperty("webRequest", &Session::WebRequest);
|
.SetProperty("webRequest", &Session::WebRequest);
|
||||||
}
|
}
|
||||||
|
|
|
@ -79,6 +79,7 @@ class Session: public mate::TrackableObject<Session>,
|
||||||
void SetPermissionRequestHandler(v8::Local<v8::Value> val,
|
void SetPermissionRequestHandler(v8::Local<v8::Value> val,
|
||||||
mate::Arguments* args);
|
mate::Arguments* args);
|
||||||
void ClearHostResolverCache(mate::Arguments* args);
|
void ClearHostResolverCache(mate::Arguments* args);
|
||||||
|
void AllowNTLMCredentialsForDomains(const std::string& domains);
|
||||||
v8::Local<v8::Value> Cookies(v8::Isolate* isolate);
|
v8::Local<v8::Value> Cookies(v8::Isolate* isolate);
|
||||||
v8::Local<v8::Value> WebRequest(v8::Isolate* isolate);
|
v8::Local<v8::Value> WebRequest(v8::Isolate* isolate);
|
||||||
|
|
||||||
|
|
|
@ -67,8 +67,7 @@ AtomBrowserContext::AtomBrowserContext(const std::string& partition,
|
||||||
: brightray::BrowserContext(partition, in_memory),
|
: brightray::BrowserContext(partition, in_memory),
|
||||||
cert_verifier_(new AtomCertVerifier),
|
cert_verifier_(new AtomCertVerifier),
|
||||||
job_factory_(new AtomURLRequestJobFactory),
|
job_factory_(new AtomURLRequestJobFactory),
|
||||||
network_delegate_(new AtomNetworkDelegate),
|
network_delegate_(new AtomNetworkDelegate) {
|
||||||
allow_ntlm_everywhere_(false) {
|
|
||||||
}
|
}
|
||||||
|
|
||||||
AtomBrowserContext::~AtomBrowserContext() {
|
AtomBrowserContext::~AtomBrowserContext() {
|
||||||
|
@ -195,16 +194,6 @@ void AtomBrowserContext::RegisterPrefs(PrefRegistrySimple* pref_registry) {
|
||||||
pref_registry->RegisterDictionaryPref(prefs::kDevToolsFileSystemPaths);
|
pref_registry->RegisterDictionaryPref(prefs::kDevToolsFileSystemPaths);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AtomBrowserContext::AllowNTLMCredentialsForDomain(const GURL& origin) {
|
|
||||||
if (allow_ntlm_everywhere_)
|
|
||||||
return true;
|
|
||||||
return Delegate::AllowNTLMCredentialsForDomain(origin);
|
|
||||||
}
|
|
||||||
|
|
||||||
void AtomBrowserContext::AllowNTLMCredentialsForAllDomains(bool should_allow) {
|
|
||||||
allow_ntlm_everywhere_ = should_allow;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
||||||
namespace brightray {
|
namespace brightray {
|
||||||
|
|
|
@ -33,7 +33,6 @@ class AtomBrowserContext : public brightray::BrowserContext {
|
||||||
const base::FilePath& base_path) override;
|
const base::FilePath& base_path) override;
|
||||||
std::unique_ptr<net::CertVerifier> CreateCertVerifier() override;
|
std::unique_ptr<net::CertVerifier> CreateCertVerifier() override;
|
||||||
net::SSLConfigService* CreateSSLConfigService() override;
|
net::SSLConfigService* CreateSSLConfigService() override;
|
||||||
bool AllowNTLMCredentialsForDomain(const GURL& auth_origin) override;
|
|
||||||
|
|
||||||
// content::BrowserContext:
|
// content::BrowserContext:
|
||||||
content::DownloadManagerDelegate* GetDownloadManagerDelegate() override;
|
content::DownloadManagerDelegate* GetDownloadManagerDelegate() override;
|
||||||
|
@ -43,8 +42,6 @@ class AtomBrowserContext : public brightray::BrowserContext {
|
||||||
// brightray::BrowserContext:
|
// brightray::BrowserContext:
|
||||||
void RegisterPrefs(PrefRegistrySimple* pref_registry) override;
|
void RegisterPrefs(PrefRegistrySimple* pref_registry) override;
|
||||||
|
|
||||||
void AllowNTLMCredentialsForAllDomains(bool should_allow);
|
|
||||||
|
|
||||||
AtomCertVerifier* cert_verifier() const { return cert_verifier_; }
|
AtomCertVerifier* cert_verifier() const { return cert_verifier_; }
|
||||||
|
|
||||||
AtomURLRequestJobFactory* job_factory() const { return job_factory_; }
|
AtomURLRequestJobFactory* job_factory() const { return job_factory_; }
|
||||||
|
@ -61,8 +58,6 @@ class AtomBrowserContext : public brightray::BrowserContext {
|
||||||
AtomURLRequestJobFactory* job_factory_;
|
AtomURLRequestJobFactory* job_factory_;
|
||||||
AtomNetworkDelegate* network_delegate_;
|
AtomNetworkDelegate* network_delegate_;
|
||||||
|
|
||||||
bool allow_ntlm_everywhere_;
|
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(AtomBrowserContext);
|
DISALLOW_COPY_AND_ASSIGN(AtomBrowserContext);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -191,7 +191,7 @@ class NativeWindow : public base::SupportsUserData,
|
||||||
// Set the aspect ratio when resizing window.
|
// Set the aspect ratio when resizing window.
|
||||||
double GetAspectRatio();
|
double GetAspectRatio();
|
||||||
gfx::Size GetAspectRatioExtraSize();
|
gfx::Size GetAspectRatioExtraSize();
|
||||||
void SetAspectRatio(double aspect_ratio, const gfx::Size& extra_size);
|
virtual void SetAspectRatio(double aspect_ratio, const gfx::Size& extra_size);
|
||||||
|
|
||||||
base::WeakPtr<NativeWindow> GetWeakPtr() {
|
base::WeakPtr<NativeWindow> GetWeakPtr() {
|
||||||
return weak_factory_.GetWeakPtr();
|
return weak_factory_.GetWeakPtr();
|
||||||
|
|
|
@ -49,6 +49,8 @@ class NativeWindowMac : public NativeWindow {
|
||||||
void SetResizable(bool resizable) override;
|
void SetResizable(bool resizable) override;
|
||||||
bool IsResizable() override;
|
bool IsResizable() override;
|
||||||
void SetMovable(bool movable) override;
|
void SetMovable(bool movable) override;
|
||||||
|
void SetAspectRatio(double aspect_ratio, const gfx::Size& extra_size)
|
||||||
|
override;
|
||||||
bool IsMovable() override;
|
bool IsMovable() override;
|
||||||
void SetMinimizable(bool minimizable) override;
|
void SetMinimizable(bool minimizable) override;
|
||||||
bool IsMinimizable() override;
|
bool IsMinimizable() override;
|
||||||
|
|
|
@ -141,22 +141,9 @@ bool ScopedDisableResize::disable_resize_ = false;
|
||||||
newSize.width =
|
newSize.width =
|
||||||
roundf((frameSize.height - extraHeightPlusFrame) * aspectRatio +
|
roundf((frameSize.height - extraHeightPlusFrame) * aspectRatio +
|
||||||
extraWidthPlusFrame);
|
extraWidthPlusFrame);
|
||||||
|
|
||||||
// If the new width is less than the frame size use it as the primary
|
|
||||||
// constraint. This ensures that the value returned by this method will
|
|
||||||
// never be larger than the users requested window size.
|
|
||||||
if (newSize.width <= frameSize.width) {
|
|
||||||
newSize.height =
|
newSize.height =
|
||||||
roundf((newSize.width - extraWidthPlusFrame) / aspectRatio +
|
roundf((newSize.width - extraWidthPlusFrame) / aspectRatio +
|
||||||
extraHeightPlusFrame);
|
extraHeightPlusFrame);
|
||||||
} else {
|
|
||||||
newSize.height =
|
|
||||||
roundf((frameSize.width - extraWidthPlusFrame) / aspectRatio +
|
|
||||||
extraHeightPlusFrame);
|
|
||||||
newSize.width =
|
|
||||||
roundf((newSize.height - extraHeightPlusFrame) * aspectRatio +
|
|
||||||
extraWidthPlusFrame);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return newSize;
|
return newSize;
|
||||||
|
@ -721,6 +708,20 @@ bool NativeWindowMac::IsResizable() {
|
||||||
return [window_ styleMask] & NSResizableWindowMask;
|
return [window_ styleMask] & NSResizableWindowMask;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void NativeWindowMac::SetAspectRatio(double aspect_ratio,
|
||||||
|
const gfx::Size& extra_size) {
|
||||||
|
NativeWindow::SetAspectRatio(aspect_ratio, extra_size);
|
||||||
|
|
||||||
|
// We can't just pass the aspect ratio to Cocoa, since our API receives
|
||||||
|
// it as a float, and Cocoa expects an NSRect with explicit width & height
|
||||||
|
// arguments. Instead we derive those args ourselves from the given aspect
|
||||||
|
// ratio.
|
||||||
|
double width = roundf([window_ frame].size.height * aspect_ratio);
|
||||||
|
double height = roundf(width / aspect_ratio);
|
||||||
|
|
||||||
|
[window_ setAspectRatio:NSMakeSize(width, height)];
|
||||||
|
}
|
||||||
|
|
||||||
void NativeWindowMac::SetMovable(bool movable) {
|
void NativeWindowMac::SetMovable(bool movable) {
|
||||||
[window_ setMovable:movable];
|
[window_ setMovable:movable];
|
||||||
}
|
}
|
||||||
|
|
|
@ -443,16 +443,6 @@ Adds `tasks` to the [Tasks][tasks] category of the JumpList on Windows.
|
||||||
consists of two or more icons, set this value to identify the icon. If an
|
consists of two or more icons, set this value to identify the icon. If an
|
||||||
icon file consists of one icon, this value is 0.
|
icon file consists of one icon, this value is 0.
|
||||||
|
|
||||||
### `app.allowNTLMCredentialsForAllDomains(allow)`
|
|
||||||
|
|
||||||
* `allow` Boolean
|
|
||||||
|
|
||||||
Dynamically sets whether to always send credentials for HTTP NTLM or Negotiate
|
|
||||||
authentication - normally, Electron will only send NTLM/Kerberos credentials for
|
|
||||||
URLs that fall under "Local Intranet" sites (i.e. are in the same domain as you).
|
|
||||||
However, this detection often fails when corporate networks are badly configured,
|
|
||||||
so this lets you co-opt this behavior and enable it for all URLs.
|
|
||||||
|
|
||||||
### `app.makeSingleInstance(callback)`
|
### `app.makeSingleInstance(callback)`
|
||||||
|
|
||||||
* `callback` Function
|
* `callback` Function
|
||||||
|
|
|
@ -95,6 +95,24 @@ connection, and the endpoint host in a `SOCKS` proxy connection).
|
||||||
|
|
||||||
Like `--host-rules` but these `rules` only apply to the host resolver.
|
Like `--host-rules` but these `rules` only apply to the host resolver.
|
||||||
|
|
||||||
|
## --auth-server-whitelist=`url`
|
||||||
|
|
||||||
|
A comma-separated list of servers for which integrated authentication is enabled.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
```
|
||||||
|
--auth-server-whitelist='*example.com, *foobar.com, *baz'
|
||||||
|
```
|
||||||
|
|
||||||
|
then any `url` ending with `example.com`, `foobar.com`, `baz` will be considered
|
||||||
|
for integrated authentication. Without `*` prefix the url has to match exactly.
|
||||||
|
|
||||||
|
## --auth-negotiate-delegate-whitelist=`url`
|
||||||
|
|
||||||
|
A comma-separated list of servers for which delegation of user credentials is required.
|
||||||
|
Without `*` prefix the url has to match exactly.
|
||||||
|
|
||||||
## --ignore-certificate-errors
|
## --ignore-certificate-errors
|
||||||
|
|
||||||
Ignores certificate related errors.
|
Ignores certificate related errors.
|
||||||
|
|
|
@ -323,6 +323,23 @@ session.fromPartition(partition).setPermissionRequestHandler((webContents, permi
|
||||||
|
|
||||||
Clears the host resolver cache.
|
Clears the host resolver cache.
|
||||||
|
|
||||||
|
#### `ses.allowNTLMCredentialsForDomains(domains)`
|
||||||
|
|
||||||
|
* `domains` String - A comma-seperated list of servers for which
|
||||||
|
integrated authentication is enabled.
|
||||||
|
|
||||||
|
Dynamically sets whether to always send credentials for HTTP NTLM or Negotiate
|
||||||
|
authentication.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
// consider any url ending with `example.com`, `foobar.com`, `baz`
|
||||||
|
// for integrated authentication.
|
||||||
|
session.defaultSession.allowNTLMCredentialsForDomains('*example.com, *foobar.com, *baz')
|
||||||
|
|
||||||
|
// consider all urls for integrated authentication.
|
||||||
|
session.defaultSession.allowNTLMCredentialsForDomains('*')
|
||||||
|
```
|
||||||
|
|
||||||
#### `ses.webRequest`
|
#### `ses.webRequest`
|
||||||
|
|
||||||
The `webRequest` API set allows to intercept and modify contents of a request at
|
The `webRequest` API set allows to intercept and modify contents of a request at
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
'use strict'
|
'use strict'
|
||||||
|
|
||||||
const {Menu} = require('electron')
|
const {deprecate, Menu, session} = require('electron')
|
||||||
const {EventEmitter} = require('events')
|
const {EventEmitter} = require('events')
|
||||||
|
|
||||||
const bindings = process.atomBinding('app')
|
const bindings = process.atomBinding('app')
|
||||||
|
@ -41,6 +41,18 @@ if (process.platform === 'darwin') {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
app.allowNTLMCredentialsForAllDomains = function (allow) {
|
||||||
|
if (!process.noDeprecations) {
|
||||||
|
deprecate.warn('app.allowNTLMCredentialsForAllDomains', 'session.allowNTLMCredentialsForDomains')
|
||||||
|
}
|
||||||
|
let domains = allow ? '*' : ''
|
||||||
|
if (!this.isReady()) {
|
||||||
|
this.commandLine.appendSwitch('auth-server-whitelist', domains)
|
||||||
|
} else {
|
||||||
|
session.defaultSession.allowNTLMCredentialsForDomains(domains)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Routes the events to webContents.
|
// Routes the events to webContents.
|
||||||
const events = ['login', 'certificate-error', 'select-client-certificate']
|
const events = ['login', 'certificate-error', 'select-client-certificate']
|
||||||
for (let name of events) {
|
for (let name of events) {
|
||||||
|
|
Loading…
Reference in a new issue