mirror of
https://github.com/curl/curl.git
synced 2024-12-03 06:20:31 +08:00
01f05d0c75
Stop the abuse of CURLE_FAILED_INIT as return code for things not being init related by introducing two new return codes: CURLE_NOT_BUILT_IN and CURLE_UNKNOWN_OPTION CURLE_NOT_BUILT_IN replaces return code 4 that has been obsoleted for several years. It is used for returning error when something is attempted to be used but the feature/option was not enabled or explictitly disabled at build-time. Getting this error mostly means that libcurl needs to be rebuilt. CURLE_FAILED_INIT is now saved and used strictly for init failures. Getting this problem means something went seriously wrong, like a resource shortage or similar. CURLE_UNKNOWN_OPTION is the option formerly known as CURLE_UNKNOWN_TELNET_OPTION (and the old name is still present, separately defined to be removed in a very distant future). This error code is meant to be used to return when an option is given to libcurl that isn't known. This problem would mostly indicate a problem in the program that uses libcurl.
78 lines
2.7 KiB
C
78 lines
2.7 KiB
C
#ifndef __CURL_SOCKS_H
|
|
#define __CURL_SOCKS_H
|
|
/***************************************************************************
|
|
* _ _ ____ _
|
|
* Project ___| | | | _ \| |
|
|
* / __| | | | |_) | |
|
|
* | (__| |_| | _ <| |___
|
|
* \___|\___/|_| \_\_____|
|
|
*
|
|
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
*
|
|
* This software is licensed as described in the file COPYING, which
|
|
* you should have received as part of this distribution. The terms
|
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
|
*
|
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
* copies of the Software, and permit persons to whom the Software is
|
|
* furnished to do so, under the terms of the COPYING file.
|
|
*
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
* KIND, either express or implied.
|
|
*
|
|
***************************************************************************/
|
|
|
|
#include "setup.h"
|
|
|
|
#ifdef CURL_DISABLE_PROXY
|
|
#define Curl_SOCKS4(a,b,c,d,e,f) CURLE_NOT_BUILT_IN
|
|
#define Curl_SOCKS5(a,b,c,d,e,f) CURLE_NOT_BUILT_IN
|
|
#else
|
|
/*
|
|
* Helper read-from-socket functions. Does the same as Curl_read() but it
|
|
* blocks until all bytes amount of buffersize will be read. No more, no less.
|
|
*
|
|
* This is STUPID BLOCKING behaviour which we frown upon, but right now this
|
|
* is what we have...
|
|
*/
|
|
int Curl_blockread_all(struct connectdata *conn,
|
|
curl_socket_t sockfd,
|
|
char *buf,
|
|
ssize_t buffersize,
|
|
ssize_t *n,
|
|
long conn_timeout);
|
|
|
|
/*
|
|
* This function logs in to a SOCKS4(a) proxy and sends the specifics to the
|
|
* final destination server.
|
|
*/
|
|
CURLcode Curl_SOCKS4(const char *proxy_name,
|
|
const char *hostname,
|
|
int remote_port,
|
|
int sockindex,
|
|
struct connectdata *conn,
|
|
bool protocol4a);
|
|
|
|
/*
|
|
* This function logs in to a SOCKS5 proxy and sends the specifics to the
|
|
* final destination server.
|
|
*/
|
|
CURLcode Curl_SOCKS5(const char *proxy_name,
|
|
const char *proxy_password,
|
|
const char *hostname,
|
|
int remote_port,
|
|
int sockindex,
|
|
struct connectdata *conn);
|
|
|
|
#if defined(HAVE_GSSAPI) || defined(USE_WINDOWS_SSPI)
|
|
/*
|
|
* This function handles the sockss5 gssapie negotiation and initialisation
|
|
*/
|
|
CURLcode Curl_SOCKS5_gssapi_negotiate(int sockindex,
|
|
struct connectdata *conn);
|
|
#endif
|
|
|
|
#endif /* CURL_DISABLE_PROXY */
|
|
|
|
#endif /* __CURL_SOCKS_H */
|