1
0
Fork 0

Merge pull request #9594 from wissem/add-response-info-transport-exception

Add response info for 3xx/4xx/5xx HTTP responses
pull/9601/head
Jordi Boggiano 2021-01-08 16:38:36 +01:00 committed by GitHub
commit f82a888704
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 13 additions and 9 deletions

View File

@ -337,7 +337,7 @@ class CurlDownloader
HttpDownloader::outputWarnings($this->io, $job['origin'], json_decode($response->getBody(), true));
}
$result = $this->isAuthenticatedRetryNeeded($job, $response);
$result = $this->isAuthenticatedRetryNeeded($job, $response, $progress);
if ($result['retry']) {
$this->restartJob($job, $job['url'], array('storeAuth' => $result['storeAuth']));
continue;
@ -345,7 +345,7 @@ class CurlDownloader
// handle 3xx redirects, 304 Not Modified is excluded
if ($statusCode >= 300 && $statusCode <= 399 && $statusCode !== 304 && $job['attributes']['redirects'] < $this->maxRedirects) {
$location = $this->handleRedirect($job, $response);
$location = $this->handleRedirect($job, $response, $progress);
if ($location) {
$this->restartJob($job, $location, array('redirects' => $job['attributes']['redirects'] + 1));
continue;
@ -354,7 +354,7 @@ class CurlDownloader
// fail 4xx and 5xx responses and capture the response
if ($statusCode >= 400 && $statusCode <= 599) {
throw $this->failResponse($job, $response, $response->getStatusMessage());
throw $this->failResponse($job, $response, $response->getStatusMessage(), $progress);
}
if ($job['attributes']['storeAuth']) {
@ -417,7 +417,7 @@ class CurlDownloader
}
}
private function handleRedirect(array $job, Response $response)
private function handleRedirect(array $job, Response $response, array $responseInfo)
{
if ($locationHeader = $response->getHeader('location')) {
if (parse_url($locationHeader, PHP_URL_SCHEME)) {
@ -445,10 +445,12 @@ class CurlDownloader
return $targetUrl;
}
throw new TransportException('The "'.$job['url'].'" file could not be downloaded, got redirect without Location ('.$response->getStatusMessage().')');
$exception = new TransportException('The "'.$job['url'].'" file could not be downloaded, got redirect without Location ('.$response->getStatusMessage().')');
$exception->setResponseInfo($responseInfo);
throw $exception;
}
private function isAuthenticatedRetryNeeded(array $job, Response $response)
private function isAuthenticatedRetryNeeded(array $job, Response $response, array $responseInfo)
{
if (in_array($response->getStatusCode(), array(401, 403)) && $job['attributes']['retryAuthFailure']) {
$result = $this->authHelper->promptAuthIfNeeded($job['url'], $job['origin'], $response->getStatusCode(), $response->getStatusMessage(), $response->getHeaders());
@ -489,7 +491,7 @@ class CurlDownloader
}
}
throw $this->failResponse($job, $response, $needsAuthRetry);
throw $this->failResponse($job, $response, $needsAuthRetry, $responseInfo);
}
return array('retry' => false, 'storeAuth' => false);
@ -507,13 +509,15 @@ class CurlDownloader
$this->initDownload($job['resolve'], $job['reject'], $origin, $url, $job['options'], $job['filename'], $attributes);
}
private function failResponse(array $job, Response $response, $errorMessage)
private function failResponse(array $job, Response $response, $errorMessage, array $responseInfo)
{
if ($job['filename']) {
@unlink($job['filename'].'~');
}
return new TransportException('The "'.$job['url'].'" file could not be downloaded ('.$errorMessage.')', $response->getStatusCode());
$exception = new TransportException('The "'.$job['url'].'" file could not be downloaded ('.$errorMessage.')', $response->getStatusCode());
$exception->setResponseInfo($responseInfo);
return $exception;
}
private function checkCurlResult($code)