// Copyright (c) 2011 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_CHROMEOS_LOGIN_CLIENT_LOGIN_RESPONSE_HANDLER_H_ #define CHROME_BROWSER_CHROMEOS_LOGIN_CLIENT_LOGIN_RESPONSE_HANDLER_H_ #pragma once #include <string> #include "base/basictypes.h" #include "chrome/browser/chromeos/login/auth_response_handler.h" namespace net { class URLRequestContextGetter; } namespace chromeos { // Handles responses to a fetch executed upon the Google Accounts ClientLogin // endpoint. The cookies that are sent back in the response body are // reformatted into a request for an time-limited authorization token, which // is then sent to the IssueAuthToken endpoint. class ClientLoginResponseHandler : public AuthResponseHandler { public: explicit ClientLoginResponseHandler(net::URLRequestContextGetter* getter) : getter_(getter) {} ~ClientLoginResponseHandler() {} // Overridden from AuthResponseHandler. virtual bool CanHandle(const GURL& url); // Overridden from AuthResponseHandler. // Takes in a response from ClientLogin, formats into an appropriate query // to sent to IssueAuthToken and issues said query. |catcher| will receive // the response to the fetch. virtual URLFetcher* Handle(const std::string& to_process, URLFetcher::Delegate* catcher); // exposed for tests. std::string payload() { return payload_; } // A string that tells the Accounts backend to which service we're trying to // authenticate. static const char kService[]; private: std::string payload_; net::URLRequestContextGetter* getter_; DISALLOW_COPY_AND_ASSIGN(ClientLoginResponseHandler); }; } // namespace chromeos #endif // CHROME_BROWSER_CHROMEOS_LOGIN_CLIENT_LOGIN_RESPONSE_HANDLER_H_