| 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_
|
|
|