2
0
mirror of https://codeberg.org/kiss-community/repo synced 2025-01-09 20:30:11 -07:00
repo/core/curl/files/CURLOPT_USERPWD.3

80 lines
2.7 KiB
Groff
Raw Normal View History

.\" generated by cd2nroff 0.1 from CURLOPT_USERPWD.md
2024-12-25 11:28:33 -07:00
.TH CURLOPT_USERPWD 3 "2024-12-25" libcurl
.SH NAME
2024-03-30 12:28:04 -06:00
CURLOPT_USERPWD \- username and password to use in authentication
.SH SYNOPSIS
.nf
#include <curl/curl.h>
CURLcode curl_easy_setopt(CURL *handle, CURLOPT_USERPWD, char *userpwd);
.fi
.SH DESCRIPTION
Pass a char pointer as parameter, pointing to a null\-terminated login details
2024-03-30 12:28:04 -06:00
string for the connection. The format of which is: [username]:[password].
When using Kerberos V5 authentication with a Windows based server, you should
2024-03-30 12:28:04 -06:00
specify the username part with the domain name in order for the server to
successfully obtain a Kerberos Ticket. If you do not then the initial part of
the authentication handshake may fail.
2024-03-30 12:28:04 -06:00
When using NTLM, the username can be specified simply as the username without
the domain name should the server be part of a single domain and forest.
To specify the domain name use either Down\-Level Logon Name or UPN (User
Principal Name) formats. For example \fBEXAMPLE\user\fP and \fBuser@example.com\fP
respectively.
Some HTTP servers (on Windows) support inclusion of the domain for Basic
authentication as well.
When using HTTP and \fICURLOPT_FOLLOWLOCATION(3)\fP, libcurl might perform several
requests to possibly different hosts. libcurl only sends this user and
password information to hosts using the initial hostname (unless
\fICURLOPT_UNRESTRICTED_AUTH(3)\fP is set), so if libcurl follows redirects to other
hosts, it does not send the user and password to those. This is enforced to
prevent accidental information leakage.
Use \fICURLOPT_HTTPAUTH(3)\fP to specify the authentication method for HTTP
based connections or \fICURLOPT_LOGIN_OPTIONS(3)\fP to control IMAP, POP3 and
SMTP options.
The user and password strings are not URL decoded, so there is no way to send
2024-03-30 12:28:04 -06:00
in a username containing a colon using this option. Use \fICURLOPT_USERNAME(3)\fP
for that, or include it in the URL.
The application does not have to keep the string around after setting this
option.
2024-09-15 18:10:01 -06:00
Using this option multiple times makes the last set string override the
previous ones. Set it to NULL to disable its use again.
.SH DEFAULT
NULL
.SH PROTOCOLS
2024-07-29 18:00:04 -06:00
This functionality affects all supported protocols
.SH EXAMPLE
.nf
int main(void)
{
CURL *curl = curl_easy_init();
if(curl) {
CURLcode res;
curl_easy_setopt(curl, CURLOPT_URL, "https://example.com/foo.bin");
curl_easy_setopt(curl, CURLOPT_USERPWD, "clark:kent");
res = curl_easy_perform(curl);
curl_easy_cleanup(curl);
}
}
.fi
.SH AVAILABILITY
2024-07-29 18:00:04 -06:00
Added in curl 7.1
.SH RETURN VALUE
Returns CURLE_OK on success or
CURLE_OUT_OF_MEMORY if there was insufficient heap space.
.SH SEE ALSO
.BR CURLOPT_PASSWORD (3),
.BR CURLOPT_PROXYUSERPWD (3),
.BR CURLOPT_USERNAME (3)