blob: 6284d03248e90961f1430c9863a82646a961b777 [file] [log] [blame]
/**
* Copyright 2010 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// Author: jmarantz@google.com (Joshua Marantz)
//
// UrlFetcher is an interface for asynchronously fetching urls. The
// caller must supply a callback to be called when the fetch is complete.
#ifndef NET_INSTAWEB_UTIL_PUBLIC_URL_ASYNC_FETCHER_H_
#define NET_INSTAWEB_UTIL_PUBLIC_URL_ASYNC_FETCHER_H_
#include <string>
namespace net_instaweb {
class MessageHandler;
class MetaData;
class Writer;
class UrlAsyncFetcher {
public:
struct Callback {
virtual ~Callback();
virtual void Done(bool success) = 0;
// Set to true if it's OK to call the callback from a different
// thread. The base class implementation returns false.
virtual bool EnableThreaded() const;
};
virtual ~UrlAsyncFetcher();
// Fetch a URL, streaming the output to fetched_content_writer, and
// returning the headers. request_headers is optional -- it can be NULL.
// response_headers and fetched_content_writer must be valid until
// the call to Done().
//
// This function returns true if the request was immediately satisfied.
// In either case, the callback will be called with the completion status,
// so it's safe to ignore the return value.
virtual bool StreamingFetch(const std::string& url,
const MetaData& request_headers,
MetaData* response_headers,
Writer* response_writer,
MessageHandler* message_handler,
Callback* callback) = 0;
};
} // namespace net_instaweb
#endif // NET_INSTAWEB_UTIL_PUBLIC_URL_ASYNC_FETCHER_H_