blob: 4b62c4924ca2270d3e94e23364c44d339ad3a525 [file] [log] [blame]
// Copyright (c) 2006-2008 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__
#include <string>
#include "base/basictypes.h"
namespace net {
class AuthChallengeInfo;
}
class GURL;
class MessageLoop;
class TabContents;
class URLRequest;
// This is the interface for the class that routes authentication info to
// the URLRequest that needs it. Used by the automation proxy for testing.
// These functions should be (and are, in LoginHandlerImpl) implemented in
// a thread safe manner.
class LoginHandler {
public:
// Resend the request with authentication credentials.
// This function can be called from either thread.
virtual void SetAuth(const std::wstring& username,
const std::wstring& password) = 0;
// Display the error page without asking for credentials again.
// This function can be called from either thread.
virtual void CancelAuth() = 0;
// Notify the handler that the request was cancelled.
// This function can only be called from the IO thread.
virtual void OnRequestCancelled() = 0;
};
// Details to provide the NotificationObserver. Used by the automation proxy
// for testing.
class LoginNotificationDetails {
public:
LoginNotificationDetails(LoginHandler* handler) : handler_(handler) {}
LoginHandler* handler() const { return handler_; }
private:
LoginNotificationDetails() {}
LoginHandler* handler_; // Where to send the response.
DISALLOW_EVIL_CONSTRUCTORS(LoginNotificationDetails);
};
// Prompts the user for their username and password. This is designed to
// be called on the background (I/O) thread, in response to
// 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 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 URLRequest.
LoginHandler* CreateLoginPrompt(net::AuthChallengeInfo* auth_info,
URLRequest* request,
MessageLoop* ui_loop);
// 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__