mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-24 15:17:02 +01:00
dirmngr: Improve error codes returned from http fetching.
* dirmngr/ks-engine-http.c (ks_http_fetch): Return better error codes. * dirmngr/ks-engine-hkp.c (send_request): Ditto. * dirmngr/t-http.c (main): New option --try-proxy.
This commit is contained in:
parent
63acf06efb
commit
9fe73df21a
@ -1294,18 +1294,17 @@ send_request (ctrl_t ctrl, const char *request, const char *hostportstr,
|
|||||||
}
|
}
|
||||||
goto once_more;
|
goto once_more;
|
||||||
|
|
||||||
case 501:
|
|
||||||
err = gpg_error (GPG_ERR_NOT_IMPLEMENTED);
|
|
||||||
goto leave;
|
|
||||||
|
|
||||||
case 413: /* Payload too large */
|
|
||||||
err = gpg_error (GPG_ERR_TOO_LARGE);
|
|
||||||
goto leave;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
log_error (_("error accessing '%s': http status %u\n"),
|
log_error (_("error accessing '%s': http status %u\n"),
|
||||||
request, http_get_status_code (http));
|
request, http_get_status_code (http));
|
||||||
err = gpg_error (GPG_ERR_NO_DATA);
|
switch (http_get_status_code (http))
|
||||||
|
{
|
||||||
|
case 401: err = gpg_error (GPG_ERR_NO_AUTH); break;
|
||||||
|
case 407: err = gpg_error (GPG_ERR_BAD_AUTH); break;
|
||||||
|
case 413: err = gpg_error (GPG_ERR_TOO_LARGE); break;
|
||||||
|
case 501: err = gpg_error (GPG_ERR_NOT_IMPLEMENTED); break;
|
||||||
|
default: err = gpg_error (GPG_ERR_NO_DATA); break;
|
||||||
|
}
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -192,14 +192,16 @@ ks_http_fetch (ctrl_t ctrl, const char *url, unsigned int flags,
|
|||||||
}
|
}
|
||||||
goto once_more;
|
goto once_more;
|
||||||
|
|
||||||
case 413: /* Payload too large */
|
|
||||||
err = gpg_error (GPG_ERR_TOO_LARGE);
|
|
||||||
goto leave;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
log_error (_("error accessing '%s': http status %u\n"),
|
log_error (_("error accessing '%s': http status %u\n"),
|
||||||
url, http_get_status_code (http));
|
url, http_get_status_code (http));
|
||||||
err = gpg_error (GPG_ERR_NO_DATA);
|
switch (http_get_status_code (http))
|
||||||
|
{
|
||||||
|
case 401: err = gpg_error (GPG_ERR_NO_AUTH); break;
|
||||||
|
case 407: err = gpg_error (GPG_ERR_BAD_AUTH); break;
|
||||||
|
case 413: err = gpg_error (GPG_ERR_TOO_LARGE); break;
|
||||||
|
default: err = gpg_error (GPG_ERR_NO_DATA); break;
|
||||||
|
}
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -288,6 +288,11 @@ main (int argc, char **argv)
|
|||||||
my_http_flags |= HTTP_FLAG_FORCE_TOR;
|
my_http_flags |= HTTP_FLAG_FORCE_TOR;
|
||||||
argc--; argv++;
|
argc--; argv++;
|
||||||
}
|
}
|
||||||
|
else if (!strcmp (*argv, "--try-proxy"))
|
||||||
|
{
|
||||||
|
my_http_flags |= HTTP_FLAG_TRY_PROXY;
|
||||||
|
argc--; argv++;
|
||||||
|
}
|
||||||
else if (!strcmp (*argv, "--no-out"))
|
else if (!strcmp (*argv, "--no-out"))
|
||||||
{
|
{
|
||||||
no_out = 1;
|
no_out = 1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user