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

Side by Side Diff: components/proximity_auth/screenlock_bridge.cc

Issue 1096293003: Move screenlock_bridge to components/proximity_auth (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add proximity auth client and the chrome glue. Created 5 years, 8 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
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 "chrome/browser/signin/screenlock_bridge.h" 5 #include "components/proximity_auth/screenlock_bridge.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/strings/string16.h" 8 #include "base/strings/string16.h"
9 #include "chrome/browser/profiles/profile_window.h" 9 #include "components/proximity_auth/proximity_auth_client.h"
10 #include "chrome/browser/signin/signin_manager_factory.h"
11 #include "components/signin/core/browser/signin_manager.h"
12 10
13 #if defined(OS_CHROMEOS) 11 #if defined(OS_CHROMEOS)
14 #include "chromeos/dbus/dbus_thread_manager.h" 12 #include "chromeos/dbus/dbus_thread_manager.h"
15 #include "chromeos/dbus/session_manager_client.h" 13 #include "chromeos/dbus/session_manager_client.h"
16 #endif 14 #endif
17 15
18 namespace { 16 namespace {
19 17
20 base::LazyInstance<ScreenlockBridge> g_screenlock_bridge_bridge_instance =
21 LAZY_INSTANCE_INITIALIZER;
22
23 // Ids for the icons that are supported by lock screen and signin screen 18 // Ids for the icons that are supported by lock screen and signin screen
24 // account picker as user pod custom icons. 19 // account picker as user pod custom icons.
25 // The id's should be kept in sync with values used by user_pod_row.js. 20 // The id's should be kept in sync with values used by user_pod_row.js.
26 const char kLockedUserPodCustomIconId[] = "locked"; 21 const char kLockedUserPodCustomIconId[] = "locked";
27 const char kLockedToBeActivatedUserPodCustomIconId[] = "locked-to-be-activated"; 22 const char kLockedToBeActivatedUserPodCustomIconId[] = "locked-to-be-activated";
28 const char kLockedWithProximityHintUserPodCustomIconId[] = 23 const char kLockedWithProximityHintUserPodCustomIconId[] =
29 "locked-with-proximity-hint"; 24 "locked-with-proximity-hint";
30 const char kUnlockedUserPodCustomIconId[] = "unlocked"; 25 const char kUnlockedUserPodCustomIconId[] = "unlocked";
31 const char kHardlockedUserPodCustomIconId[] = "hardlocked"; 26 const char kHardlockedUserPodCustomIconId[] = "hardlocked";
32 const char kSpinnerUserPodCustomIconId[] = "spinner"; 27 const char kSpinnerUserPodCustomIconId[] = "spinner";
(...skipping 13 matching lines...) Expand all
46 return kHardlockedUserPodCustomIconId; 41 return kHardlockedUserPodCustomIconId;
47 case ScreenlockBridge::USER_POD_CUSTOM_ICON_SPINNER: 42 case ScreenlockBridge::USER_POD_CUSTOM_ICON_SPINNER:
48 return kSpinnerUserPodCustomIconId; 43 return kSpinnerUserPodCustomIconId;
49 default: 44 default:
50 return ""; 45 return "";
51 } 46 }
52 } 47 }
53 48
54 } // namespace 49 } // namespace
55 50
56 // static 51 ScreenlockBridge::ScreenlockBridge(ProximityAuthClient* client)
57 ScreenlockBridge* ScreenlockBridge::Get() { 52 : client_(client), lock_handler_(NULL) {
Ilya Sherman 2015/04/23 20:52:53 nit: s/NULL/nullptr
msarda 2015/04/24 15:47:06 Done.
58 return g_screenlock_bridge_bridge_instance.Pointer(); 53 DCHECK(client_);
54 }
55
56 ScreenlockBridge::~ScreenlockBridge() {
59 } 57 }
60 58
61 ScreenlockBridge::UserPodCustomIconOptions::UserPodCustomIconOptions() 59 ScreenlockBridge::UserPodCustomIconOptions::UserPodCustomIconOptions()
62 : autoshow_tooltip_(false), 60 : autoshow_tooltip_(false),
63 hardlock_on_click_(false), 61 hardlock_on_click_(false),
64 is_trial_run_(false) { 62 is_trial_run_(false) {
65 } 63 }
66 64
67 ScreenlockBridge::UserPodCustomIconOptions::~UserPodCustomIconOptions() {} 65 ScreenlockBridge::UserPodCustomIconOptions::~UserPodCustomIconOptions() {
66 }
68 67
69 scoped_ptr<base::DictionaryValue> 68 scoped_ptr<base::DictionaryValue>
70 ScreenlockBridge::UserPodCustomIconOptions::ToDictionaryValue() const { 69 ScreenlockBridge::UserPodCustomIconOptions::ToDictionaryValue() const {
71 scoped_ptr<base::DictionaryValue> result(new base::DictionaryValue()); 70 scoped_ptr<base::DictionaryValue> result(new base::DictionaryValue());
72 std::string icon_id = GetIdForIcon(icon_); 71 std::string icon_id = GetIdForIcon(icon_);
73 result->SetString("id", icon_id); 72 result->SetString("id", icon_id);
74 73
75 if (!tooltip_.empty()) { 74 if (!tooltip_.empty()) {
76 base::DictionaryValue* tooltip_options = new base::DictionaryValue(); 75 base::DictionaryValue* tooltip_options = new base::DictionaryValue();
77 tooltip_options->SetString("text", tooltip_); 76 tooltip_options->SetString("text", tooltip_);
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
109 } 108 }
110 109
111 void ScreenlockBridge::UserPodCustomIconOptions::SetHardlockOnClick() { 110 void ScreenlockBridge::UserPodCustomIconOptions::SetHardlockOnClick() {
112 hardlock_on_click_ = true; 111 hardlock_on_click_ = true;
113 } 112 }
114 113
115 void ScreenlockBridge::UserPodCustomIconOptions::SetTrialRun() { 114 void ScreenlockBridge::UserPodCustomIconOptions::SetTrialRun() {
116 is_trial_run_ = true; 115 is_trial_run_ = true;
117 } 116 }
118 117
119 // static
120 std::string ScreenlockBridge::GetAuthenticatedUserEmail(
121 const Profile* profile) {
122 // |profile| has to be a signed-in profile with SigninManager already
123 // created. Otherwise, just crash to collect stack.
124 const SigninManagerBase* signin_manager =
125 SigninManagerFactory::GetForProfileIfExists(profile);
126 return signin_manager->GetAuthenticatedUsername();
127 }
128
129 ScreenlockBridge::ScreenlockBridge() : lock_handler_(NULL) {
130 }
131
132 ScreenlockBridge::~ScreenlockBridge() {
133 }
134
135 void ScreenlockBridge::SetLockHandler(LockHandler* lock_handler) { 118 void ScreenlockBridge::SetLockHandler(LockHandler* lock_handler) {
136 DCHECK(lock_handler_ == NULL || lock_handler == NULL); 119 DCHECK(lock_handler_ == NULL || lock_handler == NULL);
137 120
138 // Don't notify observers if there is no change -- i.e. if the screen was 121 // Don't notify observers if there is no change -- i.e. if the screen was
139 // already unlocked, and is remaining unlocked. 122 // already unlocked, and is remaining unlocked.
140 if (lock_handler == lock_handler_) 123 if (lock_handler == lock_handler_)
141 return; 124 return;
142 125
143 // TODO(isherman): If |lock_handler| is null, then |lock_handler_| might have 126 // TODO(isherman): If |lock_handler| is null, then |lock_handler_| might have
144 // been freed. Cache the screen type rather than querying it below. 127 // been freed. Cache the screen type rather than querying it below.
(...skipping 14 matching lines...) Expand all
159 if (user_id == focused_user_id_) 142 if (user_id == focused_user_id_)
160 return; 143 return;
161 focused_user_id_ = user_id; 144 focused_user_id_ = user_id;
162 FOR_EACH_OBSERVER(Observer, observers_, OnFocusedUserChanged(user_id)); 145 FOR_EACH_OBSERVER(Observer, observers_, OnFocusedUserChanged(user_id));
163 } 146 }
164 147
165 bool ScreenlockBridge::IsLocked() const { 148 bool ScreenlockBridge::IsLocked() const {
166 return lock_handler_ != NULL; 149 return lock_handler_ != NULL;
167 } 150 }
168 151
169 void ScreenlockBridge::Lock(Profile* profile) { 152 void ScreenlockBridge::Lock(content::BrowserContext* browser_context) {
170 #if defined(OS_CHROMEOS) 153 #if defined(OS_CHROMEOS)
171 chromeos::SessionManagerClient* session_manager = 154 chromeos::SessionManagerClient* session_manager =
172 chromeos::DBusThreadManager::Get()->GetSessionManagerClient(); 155 chromeos::DBusThreadManager::Get()->GetSessionManagerClient();
173 session_manager->RequestLockScreen(); 156 session_manager->RequestLockScreen();
174 #else 157 #else
175 profiles::LockProfile(profile); 158 client_->Lock(browser_context);
176 #endif 159 #endif
177 } 160 }
178 161
179 void ScreenlockBridge::Unlock(Profile* profile) { 162 void ScreenlockBridge::Unlock(content::BrowserContext* browser_context) {
180 if (lock_handler_) 163 if (lock_handler_) {
181 lock_handler_->Unlock(GetAuthenticatedUserEmail(profile)); 164 lock_handler_->Unlock(client_->GetAuthenticatedUsername(browser_context));
165 }
182 } 166 }
183 167
184 void ScreenlockBridge::AddObserver(Observer* observer) { 168 void ScreenlockBridge::AddObserver(Observer* observer) {
185 observers_.AddObserver(observer); 169 observers_.AddObserver(observer);
186 } 170 }
187 171
188 void ScreenlockBridge::RemoveObserver(Observer* observer) { 172 void ScreenlockBridge::RemoveObserver(Observer* observer) {
189 observers_.RemoveObserver(observer); 173 observers_.RemoveObserver(observer);
190 } 174 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698