mirror of
https://github.com/git/git.git
synced 2025-03-27 17:40:00 +00:00
Use config file settings for http
Use "http." config file settings if they exist. Environment variables still work, and they will override config file settings. Signed-off-by: Nick Hengeveld <nickh@reactrix.com> Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
parent
bc8f265270
commit
d402d5566f
109
http-fetch.c
109
http-fetch.c
@ -25,7 +25,7 @@ static int active_requests = 0;
|
|||||||
static int data_received;
|
static int data_received;
|
||||||
|
|
||||||
#ifdef USE_CURL_MULTI
|
#ifdef USE_CURL_MULTI
|
||||||
static int max_requests = DEFAULT_MAX_REQUESTS;
|
static int max_requests = -1;
|
||||||
static CURLM *curlm;
|
static CURLM *curlm;
|
||||||
#endif
|
#endif
|
||||||
static CURL *curl_default;
|
static CURL *curl_default;
|
||||||
@ -85,11 +85,11 @@ struct active_request_slot
|
|||||||
static struct transfer_request *request_queue_head = NULL;
|
static struct transfer_request *request_queue_head = NULL;
|
||||||
static struct active_request_slot *active_queue_head = NULL;
|
static struct active_request_slot *active_queue_head = NULL;
|
||||||
|
|
||||||
static int curl_ssl_verify;
|
static int curl_ssl_verify = -1;
|
||||||
static char *ssl_cert;
|
static char *ssl_cert = NULL;
|
||||||
static char *ssl_key;
|
static char *ssl_key = NULL;
|
||||||
static char *ssl_capath;
|
static char *ssl_capath = NULL;
|
||||||
static char *ssl_cainfo;
|
static char *ssl_cainfo = NULL;
|
||||||
|
|
||||||
struct buffer
|
struct buffer
|
||||||
{
|
{
|
||||||
@ -98,6 +98,60 @@ struct buffer
|
|||||||
void *buffer;
|
void *buffer;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int http_options(const char *var, const char *value)
|
||||||
|
{
|
||||||
|
if (!strcmp("http.sslverify", var)) {
|
||||||
|
if (curl_ssl_verify == -1) {
|
||||||
|
curl_ssl_verify = git_config_bool(var, value);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!strcmp("http.sslcert", var)) {
|
||||||
|
if (ssl_cert == NULL) {
|
||||||
|
ssl_cert = xmalloc(strlen(value)+1);
|
||||||
|
strcpy(ssl_cert, value);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#if LIBCURL_VERSION_NUM >= 0x070902
|
||||||
|
if (!strcmp("http.sslkey", var)) {
|
||||||
|
if (ssl_key == NULL) {
|
||||||
|
ssl_key = xmalloc(strlen(value)+1);
|
||||||
|
strcpy(ssl_key, value);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if LIBCURL_VERSION_NUM >= 0x070908
|
||||||
|
if (!strcmp("http.sslcapath", var)) {
|
||||||
|
if (ssl_capath == NULL) {
|
||||||
|
ssl_capath = xmalloc(strlen(value)+1);
|
||||||
|
strcpy(ssl_capath, value);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (!strcmp("http.sslcainfo", var)) {
|
||||||
|
if (ssl_cainfo == NULL) {
|
||||||
|
ssl_cainfo = xmalloc(strlen(value)+1);
|
||||||
|
strcpy(ssl_cainfo, value);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef USE_CURL_MULTI
|
||||||
|
if (!strcmp("http.maxrequests", var)) {
|
||||||
|
if (max_requests == -1)
|
||||||
|
max_requests = git_config_int(var, value);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Fall back on the default ones */
|
||||||
|
return git_default_config(var, value);
|
||||||
|
}
|
||||||
|
|
||||||
static size_t fwrite_buffer(void *ptr, size_t eltsize, size_t nmemb,
|
static size_t fwrite_buffer(void *ptr, size_t eltsize, size_t nmemb,
|
||||||
struct buffer *buffer)
|
struct buffer *buffer)
|
||||||
{
|
{
|
||||||
@ -1114,8 +1168,6 @@ int main(int argc, char **argv)
|
|||||||
char *http_max_requests = getenv("GIT_HTTP_MAX_REQUESTS");
|
char *http_max_requests = getenv("GIT_HTTP_MAX_REQUESTS");
|
||||||
if (http_max_requests != NULL)
|
if (http_max_requests != NULL)
|
||||||
max_requests = atoi(http_max_requests);
|
max_requests = atoi(http_max_requests);
|
||||||
if (max_requests < 1)
|
|
||||||
max_requests = DEFAULT_MAX_REQUESTS;
|
|
||||||
|
|
||||||
curlm = curl_multi_init();
|
curlm = curl_multi_init();
|
||||||
if (curlm == NULL) {
|
if (curlm == NULL) {
|
||||||
@ -1123,34 +1175,49 @@ int main(int argc, char **argv)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (getenv("GIT_SSL_NO_VERIFY"))
|
||||||
|
curl_ssl_verify = 0;
|
||||||
|
|
||||||
|
ssl_cert = getenv("GIT_SSL_CERT");
|
||||||
|
#if LIBCURL_VERSION_NUM >= 0x070902
|
||||||
|
ssl_key = getenv("GIT_SSL_KEY");
|
||||||
|
#endif
|
||||||
|
#if LIBCURL_VERSION_NUM >= 0x070908
|
||||||
|
ssl_capath = getenv("GIT_SSL_CAPATH");
|
||||||
|
#endif
|
||||||
|
ssl_cainfo = getenv("GIT_SSL_CAINFO");
|
||||||
|
|
||||||
|
git_config(http_options);
|
||||||
|
|
||||||
|
if (curl_ssl_verify == -1)
|
||||||
|
curl_ssl_verify = 1;
|
||||||
|
|
||||||
|
#ifdef USE_CURL_MULTI
|
||||||
|
if (max_requests < 1)
|
||||||
|
max_requests = DEFAULT_MAX_REQUESTS;
|
||||||
|
#endif
|
||||||
|
|
||||||
pragma_header = curl_slist_append(pragma_header, "Pragma: no-cache");
|
pragma_header = curl_slist_append(pragma_header, "Pragma: no-cache");
|
||||||
no_pragma_header = curl_slist_append(no_pragma_header, "Pragma:");
|
no_pragma_header = curl_slist_append(no_pragma_header, "Pragma:");
|
||||||
no_range_header = curl_slist_append(no_range_header, "Range:");
|
no_range_header = curl_slist_append(no_range_header, "Range:");
|
||||||
|
|
||||||
curl_default = curl_easy_init();
|
curl_default = curl_easy_init();
|
||||||
|
|
||||||
curl_ssl_verify = getenv("GIT_SSL_NO_VERIFY") ? 0 : 1;
|
|
||||||
curl_easy_setopt(curl_default, CURLOPT_SSL_VERIFYPEER, curl_ssl_verify);
|
curl_easy_setopt(curl_default, CURLOPT_SSL_VERIFYPEER, curl_ssl_verify);
|
||||||
#if LIBCURL_VERSION_NUM >= 0x070907
|
#if LIBCURL_VERSION_NUM >= 0x070907
|
||||||
curl_easy_setopt(curl_default, CURLOPT_NETRC, CURL_NETRC_OPTIONAL);
|
curl_easy_setopt(curl_default, CURLOPT_NETRC, CURL_NETRC_OPTIONAL);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if ((ssl_cert = getenv("GIT_SSL_CERT")) != NULL) {
|
if (ssl_cert != NULL)
|
||||||
curl_easy_setopt(curl_default, CURLOPT_SSLCERT, ssl_cert);
|
curl_easy_setopt(curl_default, CURLOPT_SSLCERT, ssl_cert);
|
||||||
}
|
if (ssl_key != NULL)
|
||||||
#if LIBCURL_VERSION_NUM >= 0x070902
|
|
||||||
if ((ssl_key = getenv("GIT_SSL_KEY")) != NULL) {
|
|
||||||
curl_easy_setopt(curl_default, CURLOPT_SSLKEY, ssl_key);
|
curl_easy_setopt(curl_default, CURLOPT_SSLKEY, ssl_key);
|
||||||
}
|
if (ssl_capath != NULL)
|
||||||
#endif
|
|
||||||
#if LIBCURL_VERSION_NUM >= 0x070908
|
|
||||||
if ((ssl_capath = getenv("GIT_SSL_CAPATH")) != NULL) {
|
|
||||||
curl_easy_setopt(curl_default, CURLOPT_CAPATH, ssl_capath);
|
curl_easy_setopt(curl_default, CURLOPT_CAPATH, ssl_capath);
|
||||||
}
|
if (ssl_cainfo != NULL)
|
||||||
#endif
|
|
||||||
if ((ssl_cainfo = getenv("GIT_SSL_CAINFO")) != NULL) {
|
|
||||||
curl_easy_setopt(curl_default, CURLOPT_CAINFO, ssl_cainfo);
|
curl_easy_setopt(curl_default, CURLOPT_CAINFO, ssl_cainfo);
|
||||||
}
|
|
||||||
curl_easy_setopt(curl_default, CURLOPT_FAILONERROR, 1);
|
curl_easy_setopt(curl_default, CURLOPT_FAILONERROR, 1);
|
||||||
|
|
||||||
alt = xmalloc(sizeof(*alt));
|
alt = xmalloc(sizeof(*alt));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user