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

Unified Diff: chrome/browser/login_prompt.h

Issue 5606002: Move:... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 10 years 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/login_model.h ('k') | chrome/browser/login_prompt.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/login_prompt.h
===================================================================
--- chrome/browser/login_prompt.h (revision 68044)
+++ chrome/browser/login_prompt.h (working copy)
@@ -1,214 +0,0 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#ifndef CHROME_BROWSER_LOGIN_PROMPT_H_
-#define CHROME_BROWSER_LOGIN_PROMPT_H_
-#pragma once
-
-#include <string>
-
-#include "base/basictypes.h"
-#include "base/lock.h"
-#include "base/ref_counted.h"
-#include "chrome/browser/password_manager/password_manager.h"
-#include "chrome/common/notification_observer.h"
-#include "chrome/common/notification_registrar.h"
-
-namespace net {
-class AuthChallengeInfo;
-class URLRequest;
-} // namespace net
-
-class ConstrainedWindow;
-class GURL;
-
-// This is the base implementation for the OS-specific classes that route
-// authentication info to the net::URLRequest that needs it. These functions
-// must be implemented in a thread safe manner.
-class LoginHandler : public base::RefCountedThreadSafe<LoginHandler>,
- public LoginModelObserver,
- public NotificationObserver {
- public:
- LoginHandler(net::AuthChallengeInfo* auth_info, net::URLRequest* request);
- virtual ~LoginHandler();
-
- // Builds the platform specific LoginHandler. Used from within
- // CreateLoginPrompt() which creates tasks.
- static LoginHandler* Create(net::AuthChallengeInfo* auth_info,
- net::URLRequest* request);
-
- // Initializes the underlying platform specific view.
- virtual void BuildViewForPasswordManager(PasswordManager* manager,
- std::wstring explanation) = 0;
-
- // Sets information about the authentication type (|form|) and the
- // |password_manager| for this profile.
- void SetPasswordForm(const webkit_glue::PasswordForm& form);
- void SetPasswordManager(PasswordManager* password_manager);
-
- // Returns the TabContents that needs authentication.
- TabContents* GetTabContentsForLogin() const;
-
- // Resend the request with authentication credentials.
- // This function can be called from either thread.
- void SetAuth(const std::wstring& username, const std::wstring& password);
-
- // Display the error page without asking for credentials again.
- // This function can be called from either thread.
- void CancelAuth();
-
- // Notify the handler that the request was cancelled.
- // This function can only be called from the IO thread.
- void OnRequestCancelled();
-
- // Implements the NotificationObserver interface.
- // Listens for AUTH_SUPPLIED and AUTH_CANCELLED notifications from other
- // LoginHandlers so that this LoginHandler has the chance to dismiss itself
- // if it was waiting for the same authentication.
- virtual void Observe(NotificationType type,
- const NotificationSource& source,
- const NotificationDetails& details);
-
- protected:
- void SetModel(LoginModel* model);
-
- void SetDialog(ConstrainedWindow* dialog);
-
- // Notify observers that authentication is needed.
- void NotifyAuthNeeded();
-
- // Performs necessary cleanup before deletion.
- void ReleaseSoon();
-
- // Who/where/what asked for the authentication.
- net::AuthChallengeInfo* auth_info() const { return auth_info_.get(); }
-
- private:
- // Starts observing notifications from other LoginHandlers.
- void AddObservers();
-
- // Stops observing notifications from other LoginHandlers.
- void RemoveObservers();
-
- // Notify observers that authentication is supplied.
- void NotifyAuthSupplied(const std::wstring& username,
- const std::wstring& password);
-
- // Notify observers that authentication is cancelled.
- void NotifyAuthCancelled();
-
- // Returns whether authentication had been handled (SetAuth or CancelAuth).
- // If |set_handled| is true, it will mark authentication as handled.
- bool WasAuthHandled(bool set_handled);
-
- // Calls SetAuth from the IO loop.
- void SetAuthDeferred(const std::wstring& username,
- const std::wstring& password);
-
- // Calls CancelAuth from the IO loop.
- void CancelAuthDeferred();
-
- // Closes the view_contents from the UI loop.
- void CloseContentsDeferred();
-
- // True if we've handled auth (SetAuth or CancelAuth has been called).
- bool handled_auth_;
- Lock handled_auth_lock_;
-
- // The ConstrainedWindow that is hosting our LoginView.
- // This should only be accessed on the UI loop.
- ConstrainedWindow* dialog_;
-
- // Who/where/what asked for the authentication.
- scoped_refptr<net::AuthChallengeInfo> auth_info_;
-
- // The request that wants login data.
- // This should only be accessed on the IO loop.
- net::URLRequest* request_;
-
- // The PasswordForm sent to the PasswordManager. This is so we can refer to it
- // when later notifying the password manager if the credentials were accepted
- // or rejected.
- // This should only be accessed on the UI loop.
- webkit_glue::PasswordForm password_form_;
-
- // Points to the password manager owned by the TabContents requesting auth.
- // Can be null if the TabContents is not a TabContents.
- // This should only be accessed on the UI loop.
- PasswordManager* password_manager_;
-
- // Cached from the net::URLRequest, in case it goes NULL on us.
- int render_process_host_id_;
- int tab_contents_id_;
-
- // If not null, points to a model we need to notify of our own destruction
- // so it doesn't try and access this when its too late.
- LoginModel* login_model_;
-
- // Observes other login handlers so this login handler can respond.
- NotificationRegistrar registrar_;
-};
-
-// Details to provide the NotificationObserver. Used by the automation proxy
-// for testing.
-class LoginNotificationDetails {
- public:
- explicit LoginNotificationDetails(LoginHandler* handler)
- : handler_(handler) {}
- LoginHandler* handler() const { return handler_; }
-
- private:
- LoginNotificationDetails() {}
-
- LoginHandler* handler_; // Where to send the response.
-
- DISALLOW_COPY_AND_ASSIGN(LoginNotificationDetails);
-};
-
-// Details to provide the NotificationObserver. Used by the automation proxy
-// for testing and by other LoginHandlers to dismiss themselves when an
-// identical auth is supplied.
-class AuthSuppliedLoginNotificationDetails : public LoginNotificationDetails {
- public:
- AuthSuppliedLoginNotificationDetails(LoginHandler* handler,
- const std::wstring& username,
- const std::wstring& password)
- : LoginNotificationDetails(handler),
- username_(username),
- password_(password) {}
- const std::wstring& username() const { return username_; }
- const std::wstring& password() const { return password_; }
-
- private:
- // The username that was used for the authentication.
- const std::wstring username_;
-
- // The password that was used for the authentication.
- const std::wstring password_;
-
- DISALLOW_COPY_AND_ASSIGN(AuthSuppliedLoginNotificationDetails);
-};
-
-// Prompts the user for their username and password. This is designed to
-// be called on the background (I/O) thread, in response to
-// net::URLRequest::Delegate::OnAuthRequired. The prompt will be created
-// on the main UI thread via a call to UI loop's InvokeLater, and will send the
-// credentials back to the net::URLRequest on the calling thread.
-// A LoginHandler object (which lives on the calling thread) is returned,
-// which can be used to set or cancel authentication programmatically. The
-// caller must invoke OnRequestCancelled() on this LoginHandler before
-// destroying the net::URLRequest.
-LoginHandler* CreateLoginPrompt(net::AuthChallengeInfo* auth_info,
- net::URLRequest* request);
-
-// Helper to remove the ref from an net::URLRequest to the LoginHandler.
-// Should only be called from the IO thread, since it accesses an
-// net::URLRequest.
-void ResetLoginHandlerForRequest(net::URLRequest* request);
-
-// Get the signon_realm under which the identity should be saved.
-std::string GetSignonRealm(const GURL& url,
- const net::AuthChallengeInfo& auth_info);
-
-#endif // CHROME_BROWSER_LOGIN_PROMPT_H_
« no previous file with comments | « chrome/browser/login_model.h ('k') | chrome/browser/login_prompt.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698