NAME
libcurl-errors - error codes in libcurl
DESCRIPTION
This man page includes most, if not all, available error codes in libcurl.
Why they occur and possibly what you can do to fix the problem.
CURLcode
Almost all "easy" interface functions return a CURLcode error code. No matter
what, using the curl_easy_setopt(3) option CURLOPT_ERRORBUFFER is
a good idea as it will give you a human readable error string that may offer
more details about the error cause than just the error code
does. curl_easy_strerror(3) can be called to get an error string from a
given CURLcode number.
CURLcode is one of the following:
"CURLE_OK
All fine. Proceed as usual.
"CURLE_UNSUPPORTED_PROTOCOL
The URL you passed to libcurl used a protocol that this libcurl does not
support. The support might be a compile-time option that you didn't use, it
can be a misspelled protocol string or just a protocol libcurl has no code
for.
"CURLE_FAILED_INIT
Very early initialization code failed. This is likely to be an internal error
or problem.
"CURLE_URL_MALFORMAT
The URL was not properly formatted.
"CURLE_URL_MALFORMAT_USER
This is never returned by current libcurl.
"CURLE_COULDNT_RESOLVE_PROXY
Couldn't resolve proxy. The given proxy host could not be resolved.
"CURLE_COULDNT_RESOLVE_HOST
Couldn't resolve host. The given remote host was not resolved.
"CURLE_COULDNT_CONNECT
Failed to connect() to host or proxy.
"CURLE_FTP_WEIRD_SERVER_REPLY
After connecting to an FTP server, libcurl expects to get a certain reply
back. This error code implies that it got a strange or bad reply. The given
remote server is probably not an OK FTP server.
"CURLE_FTP_ACCESS_DENIED
We were denied access when trying to login to an FTP server or when trying to
change working directory to the one given in the URL.
"CURLE_FTP_USER_PASSWORD_INCORRECT
This is never returned by current libcurl.
"CURLE_FTP_WEIRD_PASS_REPLY
After having sent the FTP password to the server, libcurl expects a proper
reply. This error code indicates that an unexpected code was returned.
"CURLE_FTP_WEIRD_USER_REPLY
After having sent user name to the FTP server, libcurl expects a proper
reply. This error code indicates that an unexpected code was returned.
"CURLE_FTP_WEIRD_PASV_REPLY
libcurl failed to get a sensible result back from the server as a response to
either a PASV or a EPSV command. The server is flawed.
"CURLE_FTP_WEIRD_227_FORMAT
FTP servers return a 227-line as a response to a PASV command. If libcurl
fails to parse that line, this return code is passed back.
"CURLE_FTP_CANT_GET_HOST
An internal failure to lookup the host used for the new connection.
"CURLE_FTP_CANT_RECONNECT
A bad return code on either PASV or EPSV was sent by the FTP server,
preventing libcurl from being able to continue.
"CURLE_FTP_COULDNT_SET_BINARY
Received an error when trying to set the transfer mode to binary.
"CURLE_PARTIAL_FILE
A file transfer was shorter or larger than expected. This happens when the
server first reports an expected transfer size, and then delivers data that
doesn't match the previously given size.
"CURLE_FTP_COULDNT_RETR_FILE
This was either a weird reply to a 'RETR' command or a zero byte transfer
complete.
"CURLE_FTP_WRITE_ERROR
After a completed file transfer, the FTP server did not respond a proper
\"transfer successful\" code.
"CURLE_FTP_QUOTE_ERROR
When sending custom "QUOTE" commands to the remote server, one of the commands
returned an error code that was 400 or higher.
"CURLE_HTTP_RETURNED_ERROR
This is returned if CURLOPT_FAILONERROR is set TRUE and the HTTP server
returns an error code that is >= 400.
"CURLE_WRITE_ERROR
An error occurred when writing received data to a local file, or an error was
returned to libcurl from a write callback.
"CURLE_MALFORMAT_USER
This is never returned by current libcurl.
"CURLE_UPLOAD_FAILED
Failed starting the upload. For FTP, the server typcially denied the STOR
command. The error buffer usually contains the server's explanation to this.
(This error code was formerly known as CURLE_FTP_COULDNT_STOR_FILE.)
"CURLE_READ_ERROR
There was a problem reading a local file or an error returned by the read
callback.
"CURLE_OUT_OF_MEMORY
Out of memory. A memory allocation request failed. This is serious badness and
things are severely screwed up if this ever occur.
"CURLE_OPERATION_TIMEOUTED
Operation timeout. The specified time-out period was reached according to the
conditions.
"CURLE_FTP_COULDNT_SET_ASCII
libcurl failed to set ASCII transfer type (TYPE A).
"CURLE_FTP_PORT_FAILED
The FTP PORT command returned error. This mostly happen when you haven't
specified a good enough address for libcurl to use. See CURLOPT_FTPPORT.
"CURLE_FTP_COULDNT_USE_REST
The FTP REST command returned error. This should never happen if the server is
sane.
"CURLE_FTP_COULDNT_GET_SIZE
The FTP SIZE command returned error. SIZE is not a kosher FTP command, it is
an extension and not all servers support it. This is not a surprising error.
"CURLE_HTTP_RANGE_ERROR
The HTTP server does not support or accept range requests.
"CURLE_HTTP_POST_ERROR
This is an odd error that mainly occurs due to internal confusion.
"CURLE_SSL_CONNECT_ERROR
A problem occurred somewhere in the SSL/TLS handshake. You really want the
error buffer and read the message there as it pinpoints the problem slightly
more. Could be certificates (file formats, paths, permissions), passwords, and
others.
"CURLE_FTP_BAD_DOWNLOAD_RESUME
Attempting FTP resume beyond file size.
"CURLE_FILE_COULDNT_READ_FILE
A file given with FILE:// couldn't be opened. Most likely because the file
path doesn't identify an existing file. Did you check file permissions?
"CURLE_LDAP_CANNOT_BIND
LDAP cannot bind. LDAP bind operation failed.
"CURLE_LDAP_SEARCH_FAILED
LDAP search failed.
"CURLE_LIBRARY_NOT_FOUND
Library not found. The LDAP library was not found.
"CURLE_FUNCTION_NOT_FOUND
Function not found. A required LDAP function was not found.
"CURLE_ABORTED_BY_CALLBACK
Aborted by callback. A callback returned "abort" to libcurl.
"CURLE_BAD_FUNCTION_ARGUMENT
Internal error. A function was called with a bad parameter.
"CURLE_BAD_CALLING_ORDER
This is never returned by current libcurl.
"CURLE_HTTP_PORT_FAILED
Interface error. A specified outgoing interface could not be used. Set which
interface to use for outgoing connections' source IP address with
CURLOPT_INTERFACE.
"CURLE_BAD_PASSWORD_ENTERED
This is never returned by current libcurl.
"CURLE_TOO_MANY_REDIRECTS
Too many redirects. When following redirects, libcurl hit the maximum amount.
Set your limit with CURLOPT_MAXREDIRS.
"CURLE_UNKNOWN_TELNET_OPTION
An option set with CURLOPT_TELNETOPTIONS was not recognized/known. Refer to
the appropriate documentation.
"CURLE_TELNET_OPTION_SYNTAX
A telnet option string was Illegally formatted.
"CURLE_OBSOLETE
This is not an error. This used to be another error code in an old libcurl
version and is currently unused.
"CURLE_SSL_PEER_CERTIFICATE
The remote server's SSL certificate was deemed not OK.
"CURLE_GOT_NOTHING
Nothing was returned from the server, and under the circumstances, getting
nothing is considered an error.
"CURLE_SSL_ENGINE_NOTFOUND
The specified crypto engine wasn't found.
"CURLE_SSL_ENGINE_SETFAILED
Failed setting the selected SSL crypto engine as default!
"CURLE_SEND_ERROR
Failed sending network data.
"CURLE_RECV_ERROR
Failure with receiving network data.
"CURLE_SHARE_IN_USE
Share is in use
"CURLE_SSL_CERTPROBLEM
problem with the local client certificate
"CURLE_SSL_CIPHER
couldn't use specified cipher
"CURLE_SSL_CACERT
peer certificate cannot be authenticated with known CA certificates
"CURLE_BAD_CONTENT_ENCODING
Unrecognized transfer encoding
"CURLE_LDAP_INVALID_URL
Invalid LDAP URL
"CURLE_FILESIZE_EXCEEDED
Maximum file size exceeded
"CURLE_FTP_SSL_FAILED
Requested FTP SSL level failed
"CURLE_SEND_FAIL_REWIND
When doing a send operation curl had to rewind the data to retransmit, but the
rewinding operation failed
"CURLE_SSL_ENGINE_INITFAILED
Initiating the SSL Engine failed
"CURLE_LOGIN_DENIED
The remote server denied curl to login (Added in 7.13.1)
"CURLE_TFTP_NOTFOUND
File not found on TFTP server
"CURLE_TFTP_PERM
Permission problem on TFTP server
"CURLE_TFTP_DISKFULL
Out of disk space on TFTP server
"CURLE_TFTP_ILLEGAL
Illegal TFTP operation
"CURLE_TFTP_UNKNOWNID
Unknown TFTP transfer ID
"CURLE_TFTP_EXISTS
TFTP File already exists
"CURLE_TFTP_NOSUCHUSER
No such TFTP user
"CURLE_CONV_FAILED
Character conversion failed
"CURLE_CONV_REQD
Caller must register conversion callbacks
"CURLE_SSL_CACERT_BADFILE
Problem with reading the SSL CA cert (path? access rights?)
CURLMcode
This is the generic return code used by functions in the libcurl multi
interface. Also consider curl_multi_strerror(3).
"CURLM_CALL_MULTI_PERFORM
This is not really an error. It means you should call
curl_multi_perform(3) again without doing select() or similar in between.
"CURLM_OK
Things are fine.
"CURLM_BAD_HANDLE
The passed-in handle is not a valid CURLM handle.
"CURLM_BAD_EASY_HANDLE
An easy handle was not good/valid. It could mean that it isn't an easy handle
at all, or possibly that the handle already is in used by this or another
multi handle.
"CURLM_OUT_OF_MEMORY
You are doomed.
"CURLM_INTERNAL_ERROR
This can only be returned if libcurl bugs. Please report it to us!
"CURLM_BAD_SOCKET
The passed-in socket is not a valid one that libcurl already knows about.
(Added in 7.15.4)
CURLSHcode
The "share" interface will return a CURLSHcode to indicate when an error has
occurred. Also consider curl_share_strerror(3).
"CURLSHE_OK
All fine. Proceed as usual.
"CURLSHE_BAD_OPTION
An invalid option was passed to the function.
"CURLSHE_IN_USE
The share object is currently in use.
"CURLSHE_INVALID
An invalid share object was passed to the function.