1
0
Fork 0

Add composer mirror class

pull/2993/merge
Jordi Boggiano 2013-10-17 20:29:25 +02:00
parent 9cbfe31983
commit ba776c06ee
3 changed files with 40 additions and 8 deletions

View File

@ -88,8 +88,7 @@ class FileDownloader implements DownloaderInterface
$urls = $package->getDistUrls();
while ($url = array_shift($urls)) {
try {
$this->doDownload($package, $path, $url);
break;
return $this->doDownload($package, $path, $url);
} catch (\Exception $e) {
if ($this->io->isDebug()) {
$this->io->write('');

View File

@ -13,6 +13,7 @@
namespace Composer\Package;
use Composer\Package\Version\VersionParser;
use Composer\Util\ComposerMirror;
/**
* Core package definitions that are needed to resolve dependencies and install packages
@ -581,14 +582,13 @@ class Package extends BasePackage
protected function getUrls($url, $mirrors, $ref, $type)
{
$urls = array($url);
$urls = array();
if ($url) {
$urls[] = $url;
}
if ($mirrors) {
foreach ($mirrors as $mirror) {
$mirrorUrl = str_replace(
array('%package%', '%version%', '%reference%', '%type%'),
array($this->name, $this->version, $ref, $type),
$mirror['url']
);
$mirrorUrl = ComposerMirror::processUrl($mirror['url'], $this->name, $this->version, $ref, $type);
$func = $mirror['preferred'] ? 'array_unshift' : 'array_push';
$func($urls, $mirrorUrl);
}

View File

@ -0,0 +1,33 @@
<?php
namespace Composer\Util;
class ComposerMirror
{
public static function processUrl($mirrorUrl, $packageName, $version, $reference, $type)
{
$reference = preg_match('{^([a-f0-9]*|%reference%)$}', $reference) ? $reference : md5($reference);
$version = strpos($version, '/') === false ? $version : md5($version);
return str_replace(
array('%package%', '%version%', '%reference%', '%type%'),
array($packageName, $version, $reference, $type),
$mirrorUrl
);
}
}