From cb13d7a0a88e6737223c5ddae277d9a9133aeb5f Mon Sep 17 00:00:00 2001 From: Jeremy Apthorp Date: Fri, 3 May 2019 14:30:25 -0700 Subject: [PATCH] refactor: session.clearAuthCache nws13n (#17970) --- atom/browser/api/atom_api_session.cc | 97 +++------------------------- atom/browser/api/atom_api_session.h | 2 +- 2 files changed, 11 insertions(+), 88 deletions(-) diff --git a/atom/browser/api/atom_api_session.cc b/atom/browser/api/atom_api_session.cc index 5fab46573266..af6a858b6549 100644 --- a/atom/browser/api/atom_api_session.cc +++ b/atom/browser/api/atom_api_session.cc @@ -72,15 +72,6 @@ struct ClearStorageDataOptions { uint32_t quota_types = StoragePartition::QUOTA_MANAGED_STORAGE_MASK_ALL; }; -struct ClearAuthCacheOptions { - std::string type; - GURL origin; - std::string realm; - base::string16 username; - base::string16 password; - net::HttpAuth::Scheme auth_scheme; -}; - uint32_t GetStorageMask(const std::vector& storage_types) { uint32_t storage_mask = 0; for (const auto& it : storage_types) { @@ -121,18 +112,6 @@ uint32_t GetQuotaMask(const std::vector& quota_types) { return quota_mask; } -net::HttpAuth::Scheme GetAuthSchemeFromString(const std::string& scheme) { - if (scheme == "basic") - return net::HttpAuth::AUTH_SCHEME_BASIC; - if (scheme == "digest") - return net::HttpAuth::AUTH_SCHEME_DIGEST; - if (scheme == "ntlm") - return net::HttpAuth::AUTH_SCHEME_NTLM; - if (scheme == "negotiate") - return net::HttpAuth::AUTH_SCHEME_NEGOTIATE; - return net::HttpAuth::AUTH_SCHEME_MAX; -} - void SetUserAgentInIO(scoped_refptr getter, const std::string& accept_lang, const std::string& user_agent) { @@ -164,26 +143,6 @@ struct Converter { } }; -template <> -struct Converter { - static bool FromV8(v8::Isolate* isolate, - v8::Local val, - ClearAuthCacheOptions* out) { - mate::Dictionary options; - if (!ConvertFromV8(isolate, val, &options)) - return false; - options.Get("type", &out->type); - options.Get("origin", &out->origin); - options.Get("realm", &out->realm); - options.Get("username", &out->username); - options.Get("password", &out->password); - std::string scheme; - if (options.Get("scheme", &scheme)) - out->auth_scheme = GetAuthSchemeFromString(scheme); - return true; - } -}; - template <> struct Converter { static v8::Local ToV8(v8::Isolate* isolate, @@ -218,34 +177,6 @@ void SetCertVerifyProcInIO( ->SetVerifyProc(proc); } -void ClearAuthCacheInIO( - const scoped_refptr& context_getter, - const ClearAuthCacheOptions& options, - util::Promise promise) { - auto* request_context = context_getter->GetURLRequestContext(); - auto* network_session = - request_context->http_transaction_factory()->GetSession(); - if (network_session) { - if (options.type == "password") { - auto* auth_cache = network_session->http_auth_cache(); - if (!options.origin.is_empty()) { - auth_cache->Remove( - options.origin, options.realm, options.auth_scheme, - net::AuthCredentials(options.username, options.password)); - } else { - auth_cache->ClearAllEntries(); - } - } else if (options.type == "clientCertificate") { - auto* client_auth_cache = network_session->ssl_client_auth_cache(); - client_auth_cache->Remove(net::HostPortPair::FromURL(options.origin)); - } - network_session->CloseAllConnections(); - } - base::PostTaskWithTraits( - FROM_HERE, {BrowserThread::UI}, - base::BindOnce(util::Promise::ResolveEmptyPromise, std::move(promise))); -} - void AllowNTLMCredentialsForDomainsInIO( const scoped_refptr& context_getter, const std::string& domains) { @@ -550,32 +481,24 @@ v8::Local Session::ClearHostResolverCache(mate::Arguments* args) { content::BrowserContext::GetDefaultStoragePartition(browser_context_.get()) ->GetNetworkContext() - ->ClearHostCache( - nullptr, base::BindOnce( - [](util::Promise promise) { - util::Promise::ResolveEmptyPromise(std::move(promise)); - }, - std::move(promise))); + ->ClearHostCache(nullptr, + base::BindOnce(util::Promise::ResolveEmptyPromise, + std::move(promise))); return handle; } -v8::Local Session::ClearAuthCache(mate::Arguments* args) { - v8::Isolate* isolate = args->isolate(); +v8::Local Session::ClearAuthCache() { + auto* isolate = v8::Isolate::GetCurrent(); util::Promise promise(isolate); v8::Local handle = promise.GetHandle(); - ClearAuthCacheOptions options; - if (!args->GetNext(&options)) { - promise.RejectWithErrorMessage("Must specify options object"); - return handle; - } + content::BrowserContext::GetDefaultStoragePartition(browser_context_.get()) + ->GetNetworkContext() + ->ClearHttpAuthCache(base::Time(), + base::BindOnce(util::Promise::ResolveEmptyPromise, + std::move(promise))); - base::PostTaskWithTraits( - FROM_HERE, {BrowserThread::IO}, - base::BindOnce(&ClearAuthCacheInIO, - WrapRefCounted(browser_context_->GetRequestContext()), - options, std::move(promise))); return handle; } diff --git a/atom/browser/api/atom_api_session.h b/atom/browser/api/atom_api_session.h index 3b2a638143ca..7996a759d7dd 100644 --- a/atom/browser/api/atom_api_session.h +++ b/atom/browser/api/atom_api_session.h @@ -77,7 +77,7 @@ class Session : public mate::TrackableObject, void SetPermissionCheckHandler(v8::Local val, mate::Arguments* args); v8::Local ClearHostResolverCache(mate::Arguments* args); - v8::Local ClearAuthCache(mate::Arguments* args); + v8::Local ClearAuthCache(); void AllowNTLMCredentialsForDomains(const std::string& domains); void SetUserAgent(const std::string& user_agent, mate::Arguments* args); std::string GetUserAgent();