Blame HTTPConnect.h

Packit a4aae4
Packit a4aae4
// -*- mode: c++; c-basic-offset:4 -*-
Packit a4aae4
Packit a4aae4
// This file is part of libdap, A C++ implementation of the OPeNDAP Data
Packit a4aae4
// Access Protocol.
Packit a4aae4
Packit a4aae4
// Copyright (c) 2002,2003 OPeNDAP, Inc.
Packit a4aae4
// Author: James Gallagher <jgallagher@opendap.org>
Packit a4aae4
//
Packit a4aae4
// This library is free software; you can redistribute it and/or
Packit a4aae4
// modify it under the terms of the GNU Lesser General Public
Packit a4aae4
// License as published by the Free Software Foundation; either
Packit a4aae4
// version 2.1 of the License, or (at your option) any later version.
Packit a4aae4
//
Packit a4aae4
// This library is distributed in the hope that it will be useful,
Packit a4aae4
// but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit a4aae4
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit a4aae4
// Lesser General Public License for more details.
Packit a4aae4
//
Packit a4aae4
// You should have received a copy of the GNU Lesser General Public
Packit a4aae4
// License along with this library; if not, write to the Free Software
Packit a4aae4
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
Packit a4aae4
//
Packit a4aae4
// You can contact OPeNDAP, Inc. at PO Box 112, Saunderstown, RI. 02874-0112.
Packit a4aae4
Packit a4aae4
#ifndef _httpconnect_h
Packit a4aae4
#define _httpconnect_h
Packit a4aae4
Packit a4aae4
Packit a4aae4
#include <string>
Packit a4aae4
Packit a4aae4
#include <curl/curl.h>
Packit a4aae4
//No longer used in CURL - pwest April 09, 2012
Packit a4aae4
//#include <curl/types.h>
Packit a4aae4
#include <curl/easy.h>
Packit a4aae4
Packit a4aae4
#ifndef _rc_reader_h_
Packit a4aae4
#include "RCReader.h"
Packit a4aae4
#endif
Packit a4aae4
Packit a4aae4
#ifndef _object_type_h
Packit a4aae4
#include "ObjectType.h"
Packit a4aae4
#endif
Packit a4aae4
Packit a4aae4
#ifndef _http_cache_h
Packit a4aae4
#include "HTTPCache.h"
Packit a4aae4
#endif
Packit a4aae4
Packit a4aae4
#ifndef http_response_h
Packit a4aae4
#include "HTTPResponse.h"
Packit a4aae4
#endif
Packit a4aae4
Packit a4aae4
#ifndef _util_h
Packit a4aae4
#include "util.h"
Packit a4aae4
#endif
Packit a4aae4
Packit a4aae4
using std::string;
Packit a4aae4
using std::vector;
Packit a4aae4
Packit a4aae4
namespace libdap
Packit a4aae4
{
Packit a4aae4
Packit a4aae4
extern int www_trace;
Packit a4aae4
extern int dods_keep_temps;
Packit a4aae4
Packit a4aae4
/** Use the CURL library to dereference a HTTP URL. Scan the response for
Packit a4aae4
    headers used by DAP 2.0 and extract their values. The body of the
Packit a4aae4
    response is made available using a FILE pointer.
Packit a4aae4
Packit a4aae4
    @author jhrg */
Packit a4aae4
Packit a4aae4
class HTTPConnect
Packit a4aae4
{
Packit a4aae4
private:
Packit a4aae4
    CURL *d_curl;
Packit a4aae4
    RCReader *d_rcr;
Packit a4aae4
    HTTPCache *d_http_cache;
Packit a4aae4
Packit a4aae4
    char d_error_buffer[CURL_ERROR_SIZE]; // A human-readable message.
Packit a4aae4
    std::string d_content_type; // apparently read by libcurl; this is valid only after curl_easy_perform()
Packit a4aae4
Packit a4aae4
    bool d_accept_deflate;
Packit a4aae4
Packit a4aae4
    string d_username;  // extracted from URL
Packit a4aae4
    string d_password;  // extracted from URL
Packit a4aae4
    string d_upstring;  // used to pass info into curl
Packit a4aae4
Packit a4aae4
    string d_cookie_jar;
Packit a4aae4
Packit a4aae4
    vector<string> d_request_headers; // Request headers
Packit a4aae4
Packit a4aae4
    int d_dap_client_protocol_major;
Packit a4aae4
    int d_dap_client_protocol_minor;
Packit a4aae4
Packit a4aae4
    bool d_use_cpp_streams;	// Build HTTPResponse objects using fstream and not FILE*
Packit a4aae4
Packit a4aae4
    void www_lib_init();
Packit a4aae4
    long read_url(const string &url, FILE *stream, vector<string> *resp_hdrs,
Packit a4aae4
                  const vector<string> *headers = 0);
Packit a4aae4
Packit a4aae4
    HTTPResponse *plain_fetch_url(const string &url;;
Packit a4aae4
    HTTPResponse *caching_fetch_url(const string &url;;
Packit a4aae4
Packit a4aae4
    bool url_uses_proxy_for(const string &url;;
Packit a4aae4
    bool url_uses_no_proxy_for(const string &url) throw();
Packit a4aae4
Packit a4aae4
    void extract_auth_info(string &url;;
Packit a4aae4
Packit a4aae4
    friend size_t save_raw_http_header(void *ptr, size_t size, size_t nmemb,
Packit a4aae4
                                       void *http_connect);
Packit a4aae4
    friend class HTTPConnectTest;
Packit a4aae4
    friend class ParseHeader;
Packit a4aae4
Packit a4aae4
protected:
Packit a4aae4
    /** @name Suppress default methods
Packit a4aae4
    These methods are not supported and are implemented here as protected
Packit a4aae4
    methods to suppress the C++-supplied default versions (which will
Packit a4aae4
    break this object). */
Packit a4aae4
    //@{
Packit a4aae4
    HTTPConnect();
Packit a4aae4
	HTTPConnect(const HTTPConnect &);
Packit a4aae4
	HTTPConnect &operator=(const HTTPConnect &);
Packit a4aae4
    //@}
Packit a4aae4
Packit a4aae4
public:
Packit a4aae4
    HTTPConnect(RCReader *rcr, bool use_cpp = false);
Packit a4aae4
Packit a4aae4
    virtual ~HTTPConnect();
Packit a4aae4
Packit a4aae4
    void set_credentials(const string &u, const string &p);
Packit a4aae4
    void set_accept_deflate(bool defalte);
Packit a4aae4
    void set_xdap_protocol(int major, int minor);
Packit a4aae4
Packit a4aae4
    bool use_cpp_streams() const { return d_use_cpp_streams; }
Packit a4aae4
    void set_use_cpp_streams(bool use_cpp_streams) { d_use_cpp_streams = use_cpp_streams; }
Packit a4aae4
Packit a4aae4
    /** Set the cookie jar. This function sets the name of a file used to store
Packit a4aae4
    cookies returned by servers. This will help with things like single
Packit a4aae4
    sign on systems.
Packit a4aae4
Packit a4aae4
    @param cookie_jar The pathname to the file that stores cookies. If this
Packit a4aae4
    is the empty string saving cookies is disabled. */
Packit a4aae4
    void set_cookie_jar(const string &cookie_jar) { d_cookie_jar = cookie_jar; }
Packit a4aae4
Packit a4aae4
    /** Set the state of the HTTP cache. By default, the HTTP cache is
Packit a4aae4
    enabled or disabled using the value of the \c USE_CACHE property in
Packit a4aae4
    the \c .dodsrc file. Use this method to set the state from within a
Packit a4aae4
    program.
Packit a4aae4
    @param enabled True to use the cache, False to disable. */
Packit a4aae4
    void set_cache_enabled(bool enabled) {
Packit a4aae4
        if (d_http_cache)
Packit a4aae4
            d_http_cache->set_cache_enabled(enabled);
Packit a4aae4
    }
Packit a4aae4
Packit a4aae4
    /** Return the current state of the HTTP cache. */
Packit a4aae4
    bool is_cache_enabled() { return (d_http_cache) ? d_http_cache->is_cache_enabled() : false; }
Packit a4aae4
Packit a4aae4
    HTTPResponse *fetch_url(const string &url;;
Packit a4aae4
};
Packit a4aae4
Packit a4aae4
} // namespace libdap
Packit a4aae4
Packit a4aae4
#endif // _httpconnect_h