• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef CHROME_BROWSER_BROWSER_SIGNIN_H_
6 #define CHROME_BROWSER_BROWSER_SIGNIN_H_
7 #pragma once
8 
9 #include <string>
10 
11 #include "base/memory/scoped_ptr.h"
12 #include "chrome/common/net/gaia/google_service_auth_error.h"
13 #include "content/common/notification_observer.h"
14 #include "content/common/notification_registrar.h"
15 
16 class BrowserSigninHtml;
17 class Profile;
18 class ProfileSyncService;
19 class TabContents;
20 
21 // The BrowserSignin class provides a login screen which allows the
22 // user to signin to the browser.  Currently the signin is coordinated
23 // through the Chrome Sync logic.
24 //
25 // TODO(johnnyg): Separate this from the sync logic and make it the
26 // sole co-ordinator of browser signin.
27 //
28 // This class should only be accessed on the UI thread.
29 class BrowserSignin : public NotificationObserver {
30  public:
31   explicit BrowserSignin(Profile* profile);
32   virtual ~BrowserSignin();
33 
34   // The delegate class is invoked on success and failure.
35   class SigninDelegate {
36    public:
~SigninDelegate()37     virtual ~SigninDelegate() {}
38 
39     // The login was successful.
40     virtual void OnLoginSuccess() = 0;
41 
42     // The login failed.
43     virtual void OnLoginFailure(const GoogleServiceAuthError& error) = 0;
44   };
45 
46   // Request that the user signin, modal to TabContents provided.
47   // If a user is already signed in, this will show a login dialog where
48   // the username is not editable.
49   //
50   // A custom HTML string can be provided that will be displayed next
51   // to the signin dialog.
52   //
53   // Only one sign-in can be in process at a time; if there is one in
54   // progress already it will be canceled in favor of this one.
55   //
56   // The delegate will eventually be called with OnLoginSuccess() or
57   // OnLoginFailure(), but never both.  virtual for test override.
58   virtual void RequestSignin(TabContents* tab_contents,
59                              const string16& suggested_email,
60                              const string16& login_message,
61                              SigninDelegate* delegate);
62 
63   // Returns the username of the user currently signed in.  If no
64   // user is signed in, returns the empty string.  virtual for test
65   // override.
66   virtual std::string GetSignedInUsername() const;
67 
68   // NotificationObserver implementation.
69   virtual void Observe(NotificationType type,
70                        const NotificationSource& source,
71                        const NotificationDetails& details);
72 
73   ProfileSyncService* GetProfileSyncService() const;
74 
75   // Close the dialog.  Delegate's OnLoginFailure method will be called.
76   void Cancel();
77 
78  private:
79   // Create the HTML Dialog content.
80   BrowserSigninHtml* CreateHtmlDialogUI();
81 
82   // When the dialog is closed.
83   void OnLoginFinished();
84 
85   // Turn auth notifications on.
86   void RegisterAuthNotifications();
87 
88   // Turn auth notifications off.
89   void UnregisterAuthNotifications();
90 
91   // Show the dialog Tab-Modal.
92   void ShowSigninTabModal(TabContents* tab_contents);
93 
94   // Non-owned pointer to the profile (which owns this object).
95   Profile* profile_;
96 
97   // Suggested email for the current login prompt.
98   string16 suggested_email_;
99 
100   // Current login message.
101   string16 login_message_;
102 
103   // Delegate for the current sign in request.
104   SigninDelegate* delegate_;
105 
106   // Current HTML Dialog information.  Pointer is owned by the WebUI it will be
107   // attached to.
108   BrowserSigninHtml* html_dialog_ui_delegate_;
109 
110   NotificationRegistrar registrar_;
111 
112   DISALLOW_COPY_AND_ASSIGN(BrowserSignin);
113 };
114 
115 
116 #endif  // CHROME_BROWSER_BROWSER_SIGNIN_H_
117