Added exceptions and fixed CS of the ZipDownloader
parent
99d55792f6
commit
e43060eb72
|
@ -21,21 +21,25 @@ class ZipDownloader
|
|||
{
|
||||
public function download(PackageInterface $package, $path)
|
||||
{
|
||||
if (!class_exists('ZipArchive')) {
|
||||
throw new \UnexpectedValueException('You need the zip extension enabled to use the ZipDownloader');
|
||||
}
|
||||
|
||||
$tmpName = tempnam(sys_get_temp_dir(), '');
|
||||
$this->downloadFile($package->getSourceUrl(), $tmpName);
|
||||
|
||||
if (!file_exists($tmpName)) {
|
||||
throw new \UnexpectedValueException($tmpName.' could not be created.');
|
||||
throw new \UnexpectedValueException($path.' could not be saved into '.$tmpName.', make sure the'
|
||||
.' directory is writable and you have internet connectivity.');
|
||||
}
|
||||
|
||||
$zipArchive = new ZipArchive();
|
||||
|
||||
if($zipArchive->open($tmpName) !== TRUE) {
|
||||
if (true === ($retval = $zipArchive->open($tmpName))) {
|
||||
$zipArchive->extractTo($path.'/'.$package->getName());
|
||||
$zipArchive->close();
|
||||
}
|
||||
else {
|
||||
throw new \UnexpectedValueException($tmpName.'is not a valid zip archive');
|
||||
} else {
|
||||
throw new \UnexpectedValueException($tmpName.' is not a valid zip archive, got error code '.$retval);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue