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

Side by Side Diff: chrome/browser/chromeos/policy/consumer_management_service.h

Issue 468873002: Show a desktop notification when the enrollment is completed or failed. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 4 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 | Annotate | Revision Log
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 #ifndef CHROME_BROWSER_CHROMEOS_POLICY_CONSUMER_MANAGEMENT_SERVICE_H_ 5 #ifndef CHROME_BROWSER_CHROMEOS_POLICY_CONSUMER_MANAGEMENT_SERVICE_H_
6 #define CHROME_BROWSER_CHROMEOS_POLICY_CONSUMER_MANAGEMENT_SERVICE_H_ 6 #define CHROME_BROWSER_CHROMEOS_POLICY_CONSUMER_MANAGEMENT_SERVICE_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/callback_forward.h" 10 #include "base/callback_forward.h"
11 #include "base/compiler_specific.h" 11 #include "base/compiler_specific.h"
12 #include "base/macros.h" 12 #include "base/macros.h"
13 #include "base/memory/scoped_ptr.h" 13 #include "base/memory/scoped_ptr.h"
14 #include "base/memory/weak_ptr.h" 14 #include "base/memory/weak_ptr.h"
15 #include "base/strings/string16.h"
16 #include "chrome/browser/notifications/notification_delegate.h"
15 #include "chromeos/dbus/dbus_method_call_status.h" 17 #include "chromeos/dbus/dbus_method_call_status.h"
16 #include "content/public/browser/notification_observer.h" 18 #include "content/public/browser/notification_observer.h"
17 #include "content/public/browser/notification_registrar.h" 19 #include "content/public/browser/notification_registrar.h"
18 #include "google_apis/gaia/oauth2_token_service.h" 20 #include "google_apis/gaia/oauth2_token_service.h"
19 21
20 class PrefRegistrySimple; 22 class PrefRegistrySimple;
21 class Profile; 23 class Profile;
22 class ProfileOAuth2TokenService; 24 class ProfileOAuth2TokenService;
bartfab (slow) 2014/08/21 12:04:25 Nit: No longer used.
davidyu 2014/08/22 04:23:10 Done.
23 25
24 namespace chromeos { 26 namespace chromeos {
25 class CryptohomeClient; 27 class CryptohomeClient;
26 } 28 }
27 29
28 namespace cryptohome { 30 namespace cryptohome {
29 class BaseReply; 31 class BaseReply;
30 } 32 }
31 33
32 namespace policy { 34 namespace policy {
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after
110 const base::Time& expiration_time) OVERRIDE; 112 const base::Time& expiration_time) OVERRIDE;
111 virtual void OnGetTokenFailure( 113 virtual void OnGetTokenFailure(
112 const OAuth2TokenService::Request* request, 114 const OAuth2TokenService::Request* request,
113 const GoogleServiceAuthError& error) OVERRIDE; 115 const GoogleServiceAuthError& error) OVERRIDE;
114 116
115 OAuth2TokenService::Request* GetTokenRequestForTesting() { 117 OAuth2TokenService::Request* GetTokenRequestForTesting() {
116 return token_request_.get(); 118 return token_request_.get();
117 } 119 }
118 120
119 private: 121 private:
122 class DesktopNotificationDelegate : public NotificationDelegate {
oshima 2014/08/21 22:47:07 Looks like you're not using this in the header. In
bartfab (slow) 2014/08/21 23:35:45 I have seen inlining of virtual methods done in .c
oshima 2014/08/22 00:44:05 http://www.chromium.org/developers/coding-style/cp
davidyu 2014/08/22 04:23:10 Moved to .cc.
bartfab (slow) 2014/08/25 13:07:30 In addition to the Dos and Don'ts you linked to, t
oshima 2014/08/25 13:42:04 That line describe the rule for accessor method. T
123 public:
124 // |button_click_callback| is called when the button in the notification is
125 // clicked.
126 DesktopNotificationDelegate(
127 const std::string& id,
128 const base::Closure& button_click_callback);
129
130 virtual ~DesktopNotificationDelegate();
131
132 // NotificationDelegate:
133 virtual std::string id() const OVERRIDE;
134 virtual content::WebContents* GetWebContents() const OVERRIDE;
135 virtual void Display() OVERRIDE;
136 virtual void ButtonClick(int button_index) OVERRIDE;
137 virtual void Error() OVERRIDE;
138 virtual void Close(bool by_user) OVERRIDE;
139 virtual void Click() OVERRIDE;
140
141 private:
142 std::string id_;
143 base::Closure button_click_callback_;
144
145 DISALLOW_COPY_AND_ASSIGN(DesktopNotificationDelegate);
146 };
147
120 void OnGetBootAttributeDone( 148 void OnGetBootAttributeDone(
121 const GetOwnerCallback& callback, 149 const GetOwnerCallback& callback,
122 chromeos::DBusMethodCallStatus call_status, 150 chromeos::DBusMethodCallStatus call_status,
123 bool dbus_success, 151 bool dbus_success,
124 const cryptohome::BaseReply& reply); 152 const cryptohome::BaseReply& reply);
125 153
126 void OnSetBootAttributeDone(const SetOwnerCallback& callback, 154 void OnSetBootAttributeDone(const SetOwnerCallback& callback,
127 chromeos::DBusMethodCallStatus call_status, 155 chromeos::DBusMethodCallStatus call_status,
128 bool dbus_success, 156 bool dbus_success,
129 const cryptohome::BaseReply& reply); 157 const cryptohome::BaseReply& reply);
(...skipping 18 matching lines...) Expand all
148 void OnOwnerAccessTokenAvailable(const std::string& access_token); 176 void OnOwnerAccessTokenAvailable(const std::string& access_token);
149 177
150 // Called upon the completion of the enrollment process. 178 // Called upon the completion of the enrollment process.
151 void OnEnrollmentCompleted(EnrollmentStatus status); 179 void OnEnrollmentCompleted(EnrollmentStatus status);
152 180
153 // Ends the enrollment process and shows a desktop notification if the 181 // Ends the enrollment process and shows a desktop notification if the
154 // current user is the owner. 182 // current user is the owner.
155 void EndEnrollment(ConsumerEnrollmentState state); 183 void EndEnrollment(ConsumerEnrollmentState state);
156 184
157 // Shows a desktop notification and resets the enrollment state. 185 // Shows a desktop notification and resets the enrollment state.
158 void ShowDesktopNotificationAndResetState(ConsumerEnrollmentState state); 186 void ShowDesktopNotificationAndResetState(ConsumerEnrollmentState state,
187 Profile* profile);
188
189 // Opens the settings page.
190 void OpenSettingsPage(Profile* profile) const;
191
192 // Opens the enrollment confirmation dialog in the settings page.
193 void TryEnrollmentAgain(Profile* profile) const;
194
195 // Returns the sign-in authenticated account ID of the profile.
196 const std::string& GetAccountIdFromProfile(Profile* profile) const;
bartfab (slow) 2014/08/21 12:04:25 Nit 1: "sign-in authenticated account ID" is reall
davidyu 2014/08/22 04:23:10 Done.
159 197
160 chromeos::CryptohomeClient* client_; 198 chromeos::CryptohomeClient* client_;
161 199
162 std::string enrolling_account_id_; 200 Profile* enrolling_profile_;
163 ProfileOAuth2TokenService* enrolling_token_service_;
164
165 scoped_ptr<OAuth2TokenService::Request> token_request_; 201 scoped_ptr<OAuth2TokenService::Request> token_request_;
166 content::NotificationRegistrar registrar_; 202 content::NotificationRegistrar registrar_;
167 base::WeakPtrFactory<ConsumerManagementService> weak_ptr_factory_; 203 base::WeakPtrFactory<ConsumerManagementService> weak_ptr_factory_;
168 204
169 DISALLOW_COPY_AND_ASSIGN(ConsumerManagementService); 205 DISALLOW_COPY_AND_ASSIGN(ConsumerManagementService);
170 }; 206 };
171 207
172 } // namespace policy 208 } // namespace policy
173 209
174 #endif // CHROME_BROWSER_CHROMEOS_POLICY_CONSUMER_MANAGEMENT_SERVICE_H_ 210 #endif // CHROME_BROWSER_CHROMEOS_POLICY_CONSUMER_MANAGEMENT_SERVICE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698