Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(60)

Side by Side Diff: components/wifi_sync/wifi_credential_syncable_service_factory.cc

Issue 876833002: wifi_sync: allow WifiCredentialSyncableServiceFactory to ignore LoginState (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@submit-4.3-syncable-service
Patch Set: add comments explaining use of BrowserContext::GetPath() Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « components/wifi_sync/wifi_credential_syncable_service_factory.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "components/wifi_sync/wifi_credential_syncable_service_factory.h" 5 #include "components/wifi_sync/wifi_credential_syncable_service_factory.h"
6 6
7 #include <string>
8
7 #include "base/logging.h" 9 #include "base/logging.h"
8 #include "base/memory/scoped_ptr.h" 10 #include "base/memory/scoped_ptr.h"
9 #include "components/keyed_service/content/browser_context_dependency_manager.h" 11 #include "components/keyed_service/content/browser_context_dependency_manager.h"
12 #include "components/wifi_sync/wifi_config_delegate.h"
10 #include "components/wifi_sync/wifi_credential_syncable_service.h" 13 #include "components/wifi_sync/wifi_credential_syncable_service.h"
14 #include "content/public/browser/browser_context.h"
11 15
12 #if defined(OS_CHROMEOS) 16 #if defined(OS_CHROMEOS)
17 #include "base/files/file_path.h"
13 #include "chromeos/login/login_state.h" 18 #include "chromeos/login/login_state.h"
14 #include "chromeos/network/network_handler.h" 19 #include "chromeos/network/network_handler.h"
15 #include "components/wifi_sync/wifi_config_delegate_chromeos.h" 20 #include "components/wifi_sync/wifi_config_delegate_chromeos.h"
16 #endif 21 #endif
17 22
18 namespace wifi_sync { 23 namespace wifi_sync {
19 24
20 namespace { 25 namespace {
21 26
22 scoped_ptr<WifiConfigDelegate> BuildConfigDelegate(
23 content::BrowserContext* context) {
24 #if defined(OS_CHROMEOS) 27 #if defined(OS_CHROMEOS)
25 const chromeos::LoginState* login_state = chromeos::LoginState::Get(); 28 // Returns a string identifying a ChromeOS network settings profile,
26 DCHECK(login_state->IsUserLoggedIn()); 29 // by that profile's UserHash property. This value may be communicated
27 DCHECK(!login_state->primary_user_hash().empty()); 30 // to the ChromeOS connection manager ("Shill"), but must not be
28 // TODO(quiche): Verify that |context| is the primary user's context. 31 // exposed to any untrusted code (e.g., via web APIs).
mukesh agrawal 2015/02/06 02:40:55 I believe this (newly added) comment captures how
29 32 std::string GetUserHash(content::BrowserContext* context,
30 // Note: NetworkHandler is a singleton that is managed by 33 bool use_login_state) {
31 // ChromeBrowserMainPartsChromeos, and destroyed after all 34 if (use_login_state) {
32 // KeyedService instances are destroyed. 35 const chromeos::LoginState* login_state = chromeos::LoginState::Get();
33 chromeos::NetworkHandler* network_handler = chromeos::NetworkHandler::Get(); 36 DCHECK(login_state->IsUserLoggedIn());
34 return make_scoped_ptr(new WifiConfigDelegateChromeOs( 37 DCHECK(!login_state->primary_user_hash().empty());
35 login_state->primary_user_hash(), 38 // TODO(quiche): Verify that |context| is the primary user's context.
36 network_handler->managed_network_configuration_handler())); 39 return login_state->primary_user_hash();
37 #else 40 } else {
38 NOTREACHED(); 41 // In WiFi credential sync tests, LoginState is not
39 return nullptr; 42 // available. Instead, those tests set their Shill profiles'
43 // UserHashes based on the corresponding BrowserContexts' storage
44 // paths.
mukesh agrawal 2015/02/06 02:40:55 This (newly added) comment should explain why this
45 return context->GetPath().BaseName().value();
46 }
47 }
40 #endif 48 #endif
41 }
42 49
43 } // namespace 50 } // namespace
44 51
45 // static 52 // static
46 WifiCredentialSyncableService* 53 WifiCredentialSyncableService*
47 WifiCredentialSyncableServiceFactory::GetForBrowserContext( 54 WifiCredentialSyncableServiceFactory::GetForBrowserContext(
48 content::BrowserContext* browser_context) { 55 content::BrowserContext* browser_context) {
49 return static_cast<WifiCredentialSyncableService*>( 56 return static_cast<WifiCredentialSyncableService*>(
50 GetInstance()->GetServiceForBrowserContext(browser_context, true)); 57 GetInstance()->GetServiceForBrowserContext(browser_context, true));
51 } 58 }
(...skipping 12 matching lines...) Expand all
64 BrowserContextDependencyManager::GetInstance()) { 71 BrowserContextDependencyManager::GetInstance()) {
65 } 72 }
66 73
67 WifiCredentialSyncableServiceFactory::~WifiCredentialSyncableServiceFactory() { 74 WifiCredentialSyncableServiceFactory::~WifiCredentialSyncableServiceFactory() {
68 } 75 }
69 76
70 KeyedService* WifiCredentialSyncableServiceFactory::BuildServiceInstanceFor( 77 KeyedService* WifiCredentialSyncableServiceFactory::BuildServiceInstanceFor(
71 content::BrowserContext* context) const { 78 content::BrowserContext* context) const {
72 // TODO(quiche): Figure out if this behaves properly for multi-profile. 79 // TODO(quiche): Figure out if this behaves properly for multi-profile.
73 // crbug.com/430681. 80 // crbug.com/430681.
74 return new WifiCredentialSyncableService(BuildConfigDelegate(context)); 81 #if defined(OS_CHROMEOS)
82 return new WifiCredentialSyncableService(
83 BuildWifiConfigDelegateChromeOs(context));
84 #else
85 NOTREACHED();
86 return nullptr;
87 #endif
75 } 88 }
76 89
90 #if defined(OS_CHROMEOS)
91 scoped_ptr<WifiConfigDelegate>
92 WifiCredentialSyncableServiceFactory::BuildWifiConfigDelegateChromeOs(
93 content::BrowserContext* context) const {
94 // Note: NetworkHandler is a singleton that is managed by
95 // ChromeBrowserMainPartsChromeos, and destroyed after all
96 // KeyedService instances are destroyed.
97 chromeos::NetworkHandler* network_handler = chromeos::NetworkHandler::Get();
98 return make_scoped_ptr(new WifiConfigDelegateChromeOs(
99 GetUserHash(context, !ignore_login_state_for_test_),
100 network_handler->managed_network_configuration_handler()));
101 }
102 #endif
103
77 } // namespace wifi_sync 104 } // namespace wifi_sync
OLDNEW
« no previous file with comments | « components/wifi_sync/wifi_credential_syncable_service_factory.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698