OPeNDAP Hyrax Back End Server (BES)  Updated for version 3.8.3
curl_utils.h
Go to the documentation of this file.
1 // -*- mode: c++; c-basic-offset:4 -*-
2 
3 // This file is part of gateway_module, A C++ module that can be loaded in to
4 // the OPeNDAP Back-End Server (BES) and is able to handle remote requests.
5 
6 // Copyright (c) 2013 OPeNDAP, Inc.
7 // Author: Nathan Potter <ndp@opendap.org>
8 //
9 // This library is free software; you can redistribute it and/or
10 // modify it under the terms of the GNU Lesser General Public
11 // License as published by the Free Software Foundation; either
12 // version 2.1 of the License, or (at your option) any later version.
13 //
14 // This library is distributed in the hope that it will be useful,
15 // but WITHOUT ANY WARRANTY; without even the implied warranty of
16 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 // Lesser General Public License for more details.
18 //
19 // You should have received a copy of the GNU Lesser General Public
20 // License along with this library; if not, write to the Free Software
21 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 //
23 // You can contact OPeNDAP, Inc. at PO Box 112, Saunderstown, RI. 02874-0112.
24 
25 // (c) COPYRIGHT URI/MIT 1994-1999
26 // Please read the full copyright statement in the file COPYRIGHT_URI.
27 //
28 // Authors:
29 // ndp Nathan Potter <ndp@opendap.org>
30 
31 #ifndef CURL_UTILS_H_
32 #define CURL_UTILS_H_
33 
34 
35 #include <curl/curl.h>
36 #include <curl/easy.h>
37 
38 #include "util.h"
39 #include "BESDebug.h"
40 
41 
42 
43 using std::vector;
44 
45 
46 
47 namespace libcurl {
48 
49 
50 CURL *init(char *error_buffer);
51 
52 bool configureProxy(CURL *curl, const string &url);
53 
54 long read_url(CURL *curl,
55  const string &url,
56  int fd,
57  vector<string> *resp_hdrs,
58  const vector<string> *headers,
59  char error_buffer[]);
60 
61 string http_status_to_string(int status);
62 
63 
64 } /* namespace libcurl */
65 #endif /* CURL_UTILS_H_ */
bool configureProxy(CURL *curl, const string &url)
Configure the proxy options for the passed curl object.
Definition: curl_utils.cc:304
string http_status_to_string(int status)
This function translates an HTTP status code into an error messages.
Definition: curl_utils.cc:84
long read_url(CURL *curl, const string &url, int fd, vector< string > *resp_hdrs, const vector< string > *request_headers, char error_buffer[])
Use libcurl to dereference a URL.
Definition: curl_utils.cc:527
CURL * init(char *error_buffer)
Get's a new instance of CURL* and performs basic configuration of that instance.
Definition: curl_utils.cc:426