Chromium Code Reviews| Index: chrome/browser/profiles/profile_io_data.cc |
| diff --git a/chrome/browser/profiles/profile_io_data.cc b/chrome/browser/profiles/profile_io_data.cc |
| index 99f3793c0157f18618222399755b10c33e6dcb0b..2c983506ee371fefe515a913a131dfebdc83bdc7 100644 |
| --- a/chrome/browser/profiles/profile_io_data.cc |
| +++ b/chrome/browser/profiles/profile_io_data.cc |
| @@ -63,7 +63,6 @@ |
| #include "content/public/browser/notification_service.h" |
| #include "content/public/browser/resource_context.h" |
| #include "extensions/common/constants.h" |
| -#include "net/cert/cert_verifier.h" |
| #include "net/cookies/canonical_cookie.h" |
| #include "net/cookies/cookie_monster.h" |
| #include "net/http/http_transaction_factory.h" |
| @@ -88,10 +87,10 @@ |
| #if defined(OS_CHROMEOS) |
| #include "chrome/browser/chromeos/drive/drive_protocol_handler.h" |
| +#include "chrome/browser/chromeos/policy/network_policy_service.h" |
| +#include "chrome/browser/chromeos/policy/network_policy_service_factory.h" |
| #include "chrome/browser/chromeos/policy/policy_cert_verifier.h" |
| #include "chrome/browser/chromeos/settings/cros_settings.h" |
| -#include "chrome/browser/policy/profile_policy_connector.h" |
| -#include "chrome/browser/policy/profile_policy_connector_factory.h" |
| #include "chromeos/settings/cros_settings_names.h" |
| #endif // defined(OS_CHROMEOS) |
| @@ -226,18 +225,26 @@ class DebugDevToolsInterceptor |
| #if defined(OS_CHROMEOS) |
| scoped_ptr<policy::PolicyCertVerifier> CreatePolicyCertVerifier( |
| Profile* profile) { |
| - policy::ProfilePolicyConnector* connector = |
| - policy::ProfilePolicyConnectorFactory::GetForProfile(profile); |
| - base::Closure policy_cert_trusted_callback = |
| - base::Bind(base::IgnoreResult(&content::BrowserThread::PostTask), |
| - content::BrowserThread::UI, |
| - FROM_HERE, |
| - connector->GetPolicyCertTrustedCallback()); |
| + policy::NetworkPolicyService* service = |
| + policy::NetworkPolicyServiceFactory::GetForProfile(profile); |
| + if (!service) |
| + return scoped_ptr<policy::PolicyCertVerifier>(); |
| + |
| scoped_ptr<policy::PolicyCertVerifier> cert_verifier( |
| - new policy::PolicyCertVerifier(policy_cert_trusted_callback)); |
| - connector->SetPolicyCertVerifier(cert_verifier.get()); |
| + new policy::PolicyCertVerifier(service->GetPolicyCertTrustedCallback())); |
| + service->AddPolicyCertVerifier(cert_verifier.get()); |
| return cert_verifier.Pass(); |
| } |
| + |
| +void ReleasePolicyCertVerifier(policy::PolicyCertVerifier* cert_verifier, |
| + Profile* profile) { |
| + cert_verifier->UnsetTrustAnchorUsedCallback(); |
| + |
| + policy::NetworkPolicyService* service = |
| + policy::NetworkPolicyServiceFactory::GetForProfile(profile); |
| + if (service) |
| + service->RemovePolicyCertVerifier(cert_verifier); |
| +} |
| #endif |
| } // namespace |
| @@ -295,7 +302,7 @@ void ProfileIOData::InitializeOnUIThread(Profile* profile) { |
| managed_user_service->GetURLFilterForIOThread(); |
| #endif |
| #if defined(OS_CHROMEOS) |
| - params->cert_verifier = CreatePolicyCertVerifier(profile); |
| + cert_verifier_ = CreatePolicyCertVerifier(profile); |
|
Joao da Silva
2013/10/25 11:57:10
Move this below, next to the initialization of the
pneubeck (no reviews)
2013/10/25 12:17:00
Done.
|
| #endif |
| params->profile = profile; |
| @@ -825,9 +832,13 @@ void ProfileIOData::Init(content::ProtocolHandlerMap* protocol_handlers) const { |
| #endif |
| #if defined(OS_CHROMEOS) |
| - profile_params_->cert_verifier->InitializeOnIOThread(); |
| - cert_verifier_ = profile_params_->cert_verifier.Pass(); |
| - main_request_context_->set_cert_verifier(cert_verifier_.get()); |
| + if (cert_verifier_) { |
| + cert_verifier_->InitializeOnIOThread(); |
| + main_request_context_->set_cert_verifier(cert_verifier_.get()); |
| + } else { |
| + main_request_context_->set_cert_verifier( |
| + io_thread_globals->cert_verifier.get()); |
| + } |
| #else |
| main_request_context_->set_cert_verifier( |
| io_thread_globals->cert_verifier.get()); |
| @@ -911,6 +922,13 @@ scoped_ptr<net::URLRequestJobFactory> ProfileIOData::SetUpJobFactoryDefaults( |
| } |
| } |
| +void ProfileIOData::ReleaseFromBrowserContextServices(Profile* profile) { |
| +#if defined(OS_CHROMEOS) |
| + if (cert_verifier_) |
| + ReleasePolicyCertVerifier(cert_verifier_.get(), profile); |
| +#endif |
| +} |
| + |
| void ProfileIOData::ShutdownOnUIThread() { |
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |