Merge branch 'backport/jk/curl-avoid-deprecated-api' into maint-2.30
Deal with a few deprecation warning from cURL library. * jk/curl-avoid-deprecated-api: http: support CURLOPT_PROTOCOLS_STR http: prefer CURLOPT_SEEKFUNCTION to CURLOPT_IOCTLFUNCTION http-push: prefer CURLOPT_UPLOAD to CURLOPT_PUT
This commit is contained in:
commit
3c7896e362
4
INSTALL
4
INSTALL
@ -145,6 +145,10 @@ Issues of note:
|
||||
patches into an IMAP mailbox, you do not have to have them
|
||||
(use NO_CURL).
|
||||
|
||||
Git requires version "7.19.5" or later of "libcurl" to build
|
||||
without NO_CURL. This version requirement may be bumped in
|
||||
the future.
|
||||
|
||||
- "expat" library; git-http-push uses it for remote lock
|
||||
management over DAV. Similar to "curl" above, this is optional
|
||||
(with NO_EXPAT).
|
||||
|
@ -198,14 +198,14 @@ static void curl_setup_http(CURL *curl, const char *url,
|
||||
const char *custom_req, struct buffer *buffer,
|
||||
curl_write_callback write_fn)
|
||||
{
|
||||
curl_easy_setopt(curl, CURLOPT_PUT, 1);
|
||||
curl_easy_setopt(curl, CURLOPT_UPLOAD, 1);
|
||||
curl_easy_setopt(curl, CURLOPT_URL, url);
|
||||
curl_easy_setopt(curl, CURLOPT_INFILE, buffer);
|
||||
curl_easy_setopt(curl, CURLOPT_INFILESIZE, buffer->buf.len);
|
||||
curl_easy_setopt(curl, CURLOPT_READFUNCTION, fread_buffer);
|
||||
#ifndef NO_CURL_IOCTL
|
||||
curl_easy_setopt(curl, CURLOPT_IOCTLFUNCTION, ioctl_buffer);
|
||||
curl_easy_setopt(curl, CURLOPT_IOCTLDATA, buffer);
|
||||
#ifndef NO_CURL_SEEK
|
||||
curl_easy_setopt(curl, CURLOPT_SEEKFUNCTION, seek_buffer);
|
||||
curl_easy_setopt(curl, CURLOPT_SEEKDATA, buffer);
|
||||
#endif
|
||||
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_fn);
|
||||
curl_easy_setopt(curl, CURLOPT_NOBODY, 0);
|
||||
|
79
http.c
79
http.c
@ -186,22 +186,20 @@ size_t fread_buffer(char *ptr, size_t eltsize, size_t nmemb, void *buffer_)
|
||||
return size / eltsize;
|
||||
}
|
||||
|
||||
#ifndef NO_CURL_IOCTL
|
||||
curlioerr ioctl_buffer(CURL *handle, int cmd, void *clientp)
|
||||
#ifndef NO_CURL_SEEK
|
||||
int seek_buffer(void *clientp, curl_off_t offset, int origin)
|
||||
{
|
||||
struct buffer *buffer = clientp;
|
||||
|
||||
switch (cmd) {
|
||||
case CURLIOCMD_NOP:
|
||||
return CURLIOE_OK;
|
||||
|
||||
case CURLIOCMD_RESTARTREAD:
|
||||
buffer->posn = 0;
|
||||
return CURLIOE_OK;
|
||||
|
||||
default:
|
||||
return CURLIOE_UNKNOWNCMD;
|
||||
if (origin != SEEK_SET)
|
||||
BUG("seek_buffer only handles SEEK_SET");
|
||||
if (offset < 0 || offset >= buffer->buf.len) {
|
||||
error("curl seek would be outside of buffer");
|
||||
return CURL_SEEKFUNC_FAIL;
|
||||
}
|
||||
|
||||
buffer->posn = offset;
|
||||
return CURL_SEEKFUNC_OK;
|
||||
}
|
||||
#endif
|
||||
|
||||
@ -810,20 +808,37 @@ void setup_curl_trace(CURL *handle)
|
||||
}
|
||||
|
||||
#ifdef CURLPROTO_HTTP
|
||||
static long get_curl_allowed_protocols(int from_user)
|
||||
static void proto_list_append(struct strbuf *list, const char *proto)
|
||||
{
|
||||
long allowed_protocols = 0;
|
||||
if (!list)
|
||||
return;
|
||||
if (list->len)
|
||||
strbuf_addch(list, ',');
|
||||
strbuf_addstr(list, proto);
|
||||
}
|
||||
|
||||
if (is_transport_allowed("http", from_user))
|
||||
allowed_protocols |= CURLPROTO_HTTP;
|
||||
if (is_transport_allowed("https", from_user))
|
||||
allowed_protocols |= CURLPROTO_HTTPS;
|
||||
if (is_transport_allowed("ftp", from_user))
|
||||
allowed_protocols |= CURLPROTO_FTP;
|
||||
if (is_transport_allowed("ftps", from_user))
|
||||
allowed_protocols |= CURLPROTO_FTPS;
|
||||
static long get_curl_allowed_protocols(int from_user, struct strbuf *list)
|
||||
{
|
||||
long bits = 0;
|
||||
|
||||
return allowed_protocols;
|
||||
if (is_transport_allowed("http", from_user)) {
|
||||
bits |= CURLPROTO_HTTP;
|
||||
proto_list_append(list, "http");
|
||||
}
|
||||
if (is_transport_allowed("https", from_user)) {
|
||||
bits |= CURLPROTO_HTTPS;
|
||||
proto_list_append(list, "https");
|
||||
}
|
||||
if (is_transport_allowed("ftp", from_user)) {
|
||||
bits |= CURLPROTO_FTP;
|
||||
proto_list_append(list, "ftp");
|
||||
}
|
||||
if (is_transport_allowed("ftps", from_user)) {
|
||||
bits |= CURLPROTO_FTPS;
|
||||
proto_list_append(list, "ftps");
|
||||
}
|
||||
|
||||
return bits;
|
||||
}
|
||||
#endif
|
||||
|
||||
@ -981,10 +996,24 @@ static CURL *get_curl_handle(void)
|
||||
curl_easy_setopt(result, CURLOPT_POST301, 1);
|
||||
#endif
|
||||
#ifdef CURLPROTO_HTTP
|
||||
#if LIBCURL_VERSION_NUM >= 0x075500
|
||||
{
|
||||
struct strbuf buf = STRBUF_INIT;
|
||||
|
||||
get_curl_allowed_protocols(0, &buf);
|
||||
curl_easy_setopt(result, CURLOPT_REDIR_PROTOCOLS_STR, buf.buf);
|
||||
strbuf_reset(&buf);
|
||||
|
||||
get_curl_allowed_protocols(-1, &buf);
|
||||
curl_easy_setopt(result, CURLOPT_PROTOCOLS_STR, buf.buf);
|
||||
strbuf_release(&buf);
|
||||
}
|
||||
#else
|
||||
curl_easy_setopt(result, CURLOPT_REDIR_PROTOCOLS,
|
||||
get_curl_allowed_protocols(0));
|
||||
get_curl_allowed_protocols(0, NULL));
|
||||
curl_easy_setopt(result, CURLOPT_PROTOCOLS,
|
||||
get_curl_allowed_protocols(-1));
|
||||
get_curl_allowed_protocols(-1, NULL));
|
||||
#endif
|
||||
#else
|
||||
warning(_("Protocol restrictions not supported with cURL < 7.19.4"));
|
||||
#endif
|
||||
|
8
http.h
8
http.h
@ -41,8 +41,8 @@
|
||||
#define CURLE_HTTP_RETURNED_ERROR CURLE_HTTP_NOT_FOUND
|
||||
#endif
|
||||
|
||||
#if LIBCURL_VERSION_NUM < 0x070c03
|
||||
#define NO_CURL_IOCTL
|
||||
#if LIBCURL_VERSION_NUM < 0x071200
|
||||
#define NO_CURL_SEEK
|
||||
#endif
|
||||
|
||||
/*
|
||||
@ -82,8 +82,8 @@ struct buffer {
|
||||
size_t fread_buffer(char *ptr, size_t eltsize, size_t nmemb, void *strbuf);
|
||||
size_t fwrite_buffer(char *ptr, size_t eltsize, size_t nmemb, void *strbuf);
|
||||
size_t fwrite_null(char *ptr, size_t eltsize, size_t nmemb, void *strbuf);
|
||||
#ifndef NO_CURL_IOCTL
|
||||
curlioerr ioctl_buffer(CURL *handle, int cmd, void *clientp);
|
||||
#ifndef NO_CURL_SEEK
|
||||
int seek_buffer(void *clientp, curl_off_t offset, int origin);
|
||||
#endif
|
||||
|
||||
/* Slot lifecycle functions */
|
||||
|
@ -707,26 +707,24 @@ static size_t rpc_out(void *ptr, size_t eltsize,
|
||||
return avail;
|
||||
}
|
||||
|
||||
#ifndef NO_CURL_IOCTL
|
||||
static curlioerr rpc_ioctl(CURL *handle, int cmd, void *clientp)
|
||||
#ifndef NO_CURL_SEEK
|
||||
static int rpc_seek(void *clientp, curl_off_t offset, int origin)
|
||||
{
|
||||
struct rpc_state *rpc = clientp;
|
||||
|
||||
switch (cmd) {
|
||||
case CURLIOCMD_NOP:
|
||||
return CURLIOE_OK;
|
||||
if (origin != SEEK_SET)
|
||||
BUG("rpc_seek only handles SEEK_SET, not %d", origin);
|
||||
|
||||
case CURLIOCMD_RESTARTREAD:
|
||||
if (rpc->initial_buffer) {
|
||||
rpc->pos = 0;
|
||||
return CURLIOE_OK;
|
||||
if (rpc->initial_buffer) {
|
||||
if (offset < 0 || offset > rpc->len) {
|
||||
error("curl seek would be outside of rpc buffer");
|
||||
return CURL_SEEKFUNC_FAIL;
|
||||
}
|
||||
error(_("unable to rewind rpc post data - try increasing http.postBuffer"));
|
||||
return CURLIOE_FAILRESTART;
|
||||
|
||||
default:
|
||||
return CURLIOE_UNKNOWNCMD;
|
||||
rpc->pos = offset;
|
||||
return CURL_SEEKFUNC_OK;
|
||||
}
|
||||
error(_("unable to rewind rpc post data - try increasing http.postBuffer"));
|
||||
return CURL_SEEKFUNC_FAIL;
|
||||
}
|
||||
#endif
|
||||
|
||||
@ -947,9 +945,9 @@ retry:
|
||||
rpc->initial_buffer = 1;
|
||||
curl_easy_setopt(slot->curl, CURLOPT_READFUNCTION, rpc_out);
|
||||
curl_easy_setopt(slot->curl, CURLOPT_INFILE, rpc);
|
||||
#ifndef NO_CURL_IOCTL
|
||||
curl_easy_setopt(slot->curl, CURLOPT_IOCTLFUNCTION, rpc_ioctl);
|
||||
curl_easy_setopt(slot->curl, CURLOPT_IOCTLDATA, rpc);
|
||||
#ifndef NO_CURL_SEEK
|
||||
curl_easy_setopt(slot->curl, CURLOPT_SEEKFUNCTION, rpc_seek);
|
||||
curl_easy_setopt(slot->curl, CURLOPT_SEEKDATA, rpc);
|
||||
#endif
|
||||
if (options.verbosity > 1) {
|
||||
fprintf(stderr, "POST %s (chunked)\n", rpc->service_name);
|
||||
|
Loading…
Reference in New Issue
Block a user