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

Side by Side Diff: chrome/browser/login_prompt.h

Issue 995004: Factoring duplicate code from platform-specific LoginHandlers into a base ... (Closed) Base URL: http://src.chromium.org/svn/trunk/src/
Patch Set: '' Created 10 years, 9 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
« no previous file with comments | « no previous file | chrome/browser/login_prompt.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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_LOGIN_PROMPT_H_ 5 #ifndef CHROME_BROWSER_LOGIN_PROMPT_H_
6 #define CHROME_BROWSER_LOGIN_PROMPT_H_ 6 #define CHROME_BROWSER_LOGIN_PROMPT_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
11 #include "base/lock.h"
12 #include "chrome/browser/password_manager/password_manager.h"
11 13
12 namespace net { 14 namespace net {
13 class AuthChallengeInfo; 15 class AuthChallengeInfo;
14 } 16 }
15 17
16 namespace webkit_glue {
17 struct PasswordForm;
18 }
19
20 class ConstrainedWindow; 18 class ConstrainedWindow;
21 class GURL; 19 class GURL;
22 class PasswordManager;
23 class TabContents; 20 class TabContents;
24 class URLRequest; 21 class URLRequest;
25 22
26 // This is the interface for the class that routes authentication info to 23 // This is the base implementation for the OS-specific classes that route
27 // the URLRequest that needs it. Used by the automation proxy for testing. 24 // authentication info to the URLRequest that needs it. These functions must
28 // These functions should be (and are, in LoginHandlerImpl) implemented in 25 // be implemented in a thread safe manner.
29 // a thread safe manner. 26 class LoginHandler : public base::RefCountedThreadSafe<LoginHandler>,
30 // 27 public LoginModelObserver {
31 // TODO(erg): Refactor the common code from all LoginHandler subclasses into a
32 // common controller class. All the methods below have the same copy/pasted
33 // implementation. This is more difficult then it should be because all these
34 // subclasses are also base::RefCountedThreadSafe<> and I'm not sure how to get
35 // ownership correct. http://crbug.com/14909
36 class LoginHandler {
37 public: 28 public:
29 explicit LoginHandler(URLRequest* request);
30 virtual ~LoginHandler();
31
38 // Builds the platform specific LoginHandler. Used from within 32 // Builds the platform specific LoginHandler. Used from within
39 // CreateLoginPrompt() which creates tasks. 33 // CreateLoginPrompt() which creates tasks.
40 static LoginHandler* Create(URLRequest* request); 34 static LoginHandler* Create(URLRequest* request);
41 35
42 // Initializes the underlying platform specific view. 36 // Initializes the underlying platform specific view.
43 virtual void BuildViewForPasswordManager(PasswordManager* manager, 37 virtual void BuildViewForPasswordManager(PasswordManager* manager,
44 std::wstring explanation) = 0; 38 std::wstring explanation) = 0;
45 39
46 // Sets information about the authentication type (|form|) and the 40 // Sets information about the authentication type (|form|) and the
47 // |password_manager| for this profile. 41 // |password_manager| for this profile.
48 virtual void SetPasswordForm(const webkit_glue::PasswordForm& form) = 0; 42 void SetPasswordForm(const webkit_glue::PasswordForm& form);
49 virtual void SetPasswordManager(PasswordManager* password_manager) = 0; 43 void SetPasswordManager(PasswordManager* password_manager);
50 44
51 // Returns the TabContents that needs authentication. 45 // Returns the TabContents that needs authentication.
52 virtual TabContents* GetTabContentsForLogin() = 0; 46 TabContents* GetTabContentsForLogin() const;
53 47
54 // Resend the request with authentication credentials. 48 // Resend the request with authentication credentials.
55 // This function can be called from either thread. 49 // This function can be called from either thread.
56 virtual void SetAuth(const std::wstring& username, 50 void SetAuth(const std::wstring& username, const std::wstring& password);
57 const std::wstring& password) = 0;
58 51
59 // Display the error page without asking for credentials again. 52 // Display the error page without asking for credentials again.
60 // This function can be called from either thread. 53 // This function can be called from either thread.
61 virtual void CancelAuth() = 0; 54 void CancelAuth();
62 55
63 // Notify the handler that the request was cancelled. 56 // Notify the handler that the request was cancelled.
64 // This function can only be called from the IO thread. 57 // This function can only be called from the IO thread.
65 virtual void OnRequestCancelled() = 0; 58 void OnRequestCancelled();
66 59
67 protected: 60 protected:
68 virtual ~LoginHandler() {} 61
62 void SetModel(LoginModel* model);
63
64 void SetDialog(ConstrainedWindow* dialog);
65
66 // Notify observers that authentication is needed or received. The automation
67 // proxy uses this for testing.
68 void SendNotifications();
69
70 void ReleaseSoon();
71
72 private:
73
74 // Returns whether authentication had been handled (SetAuth or CancelAuth).
75 // If |set_handled| is true, it will mark authentication as handled.
76 bool WasAuthHandled(bool set_handled);
77
78 // Calls SetAuth from the IO loop.
79 void SetAuthDeferred(const std::wstring& username,
80 const std::wstring& password);
81
82 // Calls CancelAuth from the IO loop.
83 void CancelAuthDeferred();
84
85 // Closes the view_contents from the UI loop.
86 void CloseContentsDeferred();
87
88 // True if we've handled auth (SetAuth or CancelAuth has been called).
89 bool handled_auth_;
90 Lock handled_auth_lock_;
91
92 // The ConstrainedWindow that is hosting our LoginView.
93 // This should only be accessed on the UI loop.
94 ConstrainedWindow* dialog_;
95
96 // The request that wants login data.
97 // This should only be accessed on the IO loop.
98 URLRequest* request_;
99
100 // The PasswordForm sent to the PasswordManager. This is so we can refer to it
101 // when later notifying the password manager if the credentials were accepted
102 // or rejected.
103 // This should only be accessed on the UI loop.
104 webkit_glue::PasswordForm password_form_;
105
106 // Points to the password manager owned by the TabContents requesting auth.
107 // Can be null if the TabContents is not a TabContents.
108 // This should only be accessed on the UI loop.
109 PasswordManager* password_manager_;
110
111 // Cached from the URLRequest, in case it goes NULL on us.
112 int render_process_host_id_;
113 int tab_contents_id_;
114
115 // If not null, points to a model we need to notify of our own destruction
116 // so it doesn't try and access this when its too late.
117 LoginModel* login_model_;
69 }; 118 };
70 119
71 // Details to provide the NotificationObserver. Used by the automation proxy 120 // Details to provide the NotificationObserver. Used by the automation proxy
72 // for testing. 121 // for testing.
73 class LoginNotificationDetails { 122 class LoginNotificationDetails {
74 public: 123 public:
75 explicit LoginNotificationDetails(LoginHandler* handler) 124 explicit LoginNotificationDetails(LoginHandler* handler)
76 : handler_(handler) {} 125 : handler_(handler) {}
77 LoginHandler* handler() const { return handler_; } 126 LoginHandler* handler() const { return handler_; }
78 127
(...skipping 19 matching lines...) Expand all
98 147
99 // Helper to remove the ref from an URLRequest to the LoginHandler. 148 // Helper to remove the ref from an URLRequest to the LoginHandler.
100 // Should only be called from the IO thread, since it accesses an URLRequest. 149 // Should only be called from the IO thread, since it accesses an URLRequest.
101 void ResetLoginHandlerForRequest(URLRequest* request); 150 void ResetLoginHandlerForRequest(URLRequest* request);
102 151
103 // Get the signon_realm under which the identity should be saved. 152 // Get the signon_realm under which the identity should be saved.
104 std::string GetSignonRealm(const GURL& url, 153 std::string GetSignonRealm(const GURL& url,
105 const net::AuthChallengeInfo& auth_info); 154 const net::AuthChallengeInfo& auth_info);
106 155
107 #endif // CHROME_BROWSER_LOGIN_PROMPT_H_ 156 #endif // CHROME_BROWSER_LOGIN_PROMPT_H_
OLDNEW
« no previous file with comments | « no previous file | chrome/browser/login_prompt.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698