 Chromium Code Reviews
 Chromium Code Reviews Issue 2772673002:
  mash: switch to the new pref service  (Closed)
    
  
    Issue 2772673002:
  mash: switch to the new pref service  (Closed) 
  | Index: chrome/browser/prefs/active_profile_pref_service.cc | 
| diff --git a/chrome/browser/prefs/active_profile_pref_service.cc b/chrome/browser/prefs/active_profile_pref_service.cc | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..cd704d2593796a0cc14150dd75bc507fe2b32cd0 | 
| --- /dev/null | 
| +++ b/chrome/browser/prefs/active_profile_pref_service.cc | 
| @@ -0,0 +1,58 @@ | 
| +// Copyright 2017 The Chromium Authors. All rights reserved. | 
| +// Use of this source code is governed by a BSD-style license that can be | 
| +// found in the LICENSE file. | 
| + | 
| +#include "chrome/browser/prefs/active_profile_pref_service.h" | 
| + | 
| +#include "chrome/browser/profiles/profile_manager.h" | 
| +#include "content/public/browser/browser_context.h" | 
| +#include "mojo/public/cpp/bindings/interface_request.h" | 
| +#include "services/service_manager/public/cpp/connector.h" | 
| +#include "services/service_manager/public/cpp/interface_registry.h" | 
| + | 
| +namespace prefs { | 
| + | 
| +ActiveProfilePrefService::ActiveProfilePrefService() = default; | 
| + | 
| +ActiveProfilePrefService::~ActiveProfilePrefService() = default; | 
| + | 
| +void ActiveProfilePrefService::Connect(mojom::PrefRegistryPtr pref_registry, | 
| + const ConnectCallback& callback) { | 
| + auto* connector = content::BrowserContext::GetConnectorFor( | 
| + ProfileManager::GetActiveUserProfile()); | 
| + connector->BindInterface(mojom::kPrefStoreServiceName, &connector_ptr_); | 
| + connector_ptr_.set_connection_error_handler(base::Bind( | 
| + &ActiveProfilePrefService::OnConnectError, base::Unretained(this))); | 
| 
jonross
2017/03/27 14:26:38
Shutdown can lead to the deletion of ActiveProfile
 
tibell
2017/03/28 00:34:31
sammc@ who is wiser in the world of Mojo than me g
 
jonross
2017/03/28 13:57:26
Acknowledged.
 | 
| + connector_ptr_->Connect(std::move(pref_registry), callback); | 
| +} | 
| + | 
| +void ActiveProfilePrefService::Create( | 
| + const service_manager::Identity& remote_identity, | 
| + prefs::mojom::PrefStoreConnectorRequest request) { | 
| + connector_bindings_.AddBinding(this, std::move(request)); | 
| +} | 
| + | 
| +void ActiveProfilePrefService::OnStart() {} | 
| + | 
| +bool ActiveProfilePrefService::OnConnect( | 
| + const service_manager::ServiceInfo& remote_info, | 
| + service_manager::InterfaceRegistry* registry) { | 
| + // N.B. This check is important as not doing it would allow one user to read | 
| + // another user's prefs. | 
| + if (remote_info.identity.user_id() != service_manager::mojom::kRootUserID) { | 
| + LOG(WARNING) << "Blocked service instance=" | 
| + << remote_info.identity.instance() | 
| + << ", name=" << remote_info.identity.name() | 
| + << ", user_id=" << remote_info.identity.user_id() | 
| + << " from connecting to the active profile's pref service."; | 
| + return false; | 
| + } | 
| + registry->AddInterface<mojom::PrefStoreConnector>(this); | 
| + return true; | 
| +} | 
| + | 
| +void ActiveProfilePrefService::OnConnectError() { | 
| + connector_bindings_.CloseAllBindings(); | 
| +} | 
| + | 
| +} // namespace prefs |