mirror of
https://github.com/pocoproject/poco.git
synced 2025-01-07 09:48:04 +01:00
93 lines
2.4 KiB
C++
93 lines
2.4 KiB
C++
//
|
|
// HTTPStreamFactory.h
|
|
//
|
|
// Library: Net
|
|
// Package: HTTP
|
|
// Module: HTTPStreamFactory
|
|
//
|
|
// Definition of the HTTPStreamFactory class.
|
|
//
|
|
// Copyright (c) 2005-2006, Applied Informatics Software Engineering GmbH.
|
|
// and Contributors.
|
|
//
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
//
|
|
|
|
|
|
#ifndef Net_HTTPStreamFactory_INCLUDED
|
|
#define Net_HTTPStreamFactory_INCLUDED
|
|
|
|
|
|
#include "Poco/Net/Net.h"
|
|
#include "Poco/Net/HTTPSession.h"
|
|
#include "Poco/URIStreamFactory.h"
|
|
|
|
|
|
namespace Poco {
|
|
namespace Net {
|
|
|
|
|
|
class Net_API HTTPStreamFactory: public Poco::URIStreamFactory
|
|
/// An implementation of the URIStreamFactory interface
|
|
/// that handles Hyper-Text Transfer Protocol (http) URIs.
|
|
{
|
|
public:
|
|
HTTPStreamFactory();
|
|
/// Creates the HTTPStreamFactory.
|
|
|
|
HTTPStreamFactory(const std::string& proxyHost, Poco::UInt16 proxyPort = HTTPSession::HTTP_PORT);
|
|
/// Creates the HTTPStreamFactory.
|
|
///
|
|
/// HTTP connections will use the given proxy.
|
|
|
|
HTTPStreamFactory(const std::string& proxyHost, Poco::UInt16 proxyPort, const std::string& proxyUsername, const std::string& proxyPassword);
|
|
/// Creates the HTTPStreamFactory.
|
|
///
|
|
/// HTTP connections will use the given proxy and
|
|
/// will be authorized against the proxy using Basic authentication
|
|
/// with the given proxyUsername and proxyPassword.
|
|
|
|
virtual ~HTTPStreamFactory();
|
|
/// Destroys the HTTPStreamFactory.
|
|
|
|
virtual std::istream* open(const Poco::URI& uri);
|
|
/// Creates and opens a HTTP stream for the given URI.
|
|
/// The URI must be a http://... URI.
|
|
///
|
|
/// Throws a NetException if anything goes wrong.
|
|
///
|
|
/// Redirect responses are handled and the redirect
|
|
/// location is automatically resolved, as long
|
|
/// as the redirect location is still accessible
|
|
/// via the HTTP protocol. If a redirection to
|
|
/// a non http://... URI is received, a
|
|
/// UnsupportedRedirectException exception is thrown.
|
|
/// The offending URI can then be obtained via the message()
|
|
/// method of UnsupportedRedirectException.
|
|
|
|
static void registerFactory();
|
|
/// Registers the HTTPStreamFactory with the
|
|
/// default URIStreamOpener instance.
|
|
|
|
static void unregisterFactory();
|
|
/// Unregisters the HTTPStreamFactory with the
|
|
/// default URIStreamOpener instance.
|
|
|
|
private:
|
|
enum
|
|
{
|
|
MAX_REDIRECTS = 10
|
|
};
|
|
|
|
std::string _proxyHost;
|
|
Poco::UInt16 _proxyPort;
|
|
std::string _proxyUsername;
|
|
std::string _proxyPassword;
|
|
};
|
|
|
|
|
|
} } // namespace Poco::Net
|
|
|
|
|
|
#endif // Net_HTTPStreamFactory_INCLUDED
|