You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
88 lines
1.9 KiB
PHP
88 lines
1.9 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Composer.
|
|
*
|
|
* (c) Nils Adermann <naderman@naderman.de>
|
|
* Jordi Boggiano <j.boggiano@seld.be>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Composer\Util\Http;
|
|
|
|
use Composer\Util\Url;
|
|
|
|
/**
|
|
* @internal
|
|
* @author John Stevenson <john-stevenson@blueyonder.co.uk>
|
|
*/
|
|
class RequestProxy
|
|
{
|
|
private $contextOptions;
|
|
private $isSecure;
|
|
private $formattedUrl;
|
|
private $url;
|
|
|
|
/**
|
|
* @param string $url
|
|
* @param array $contextOptions
|
|
* @param string $formattedUrl
|
|
*/
|
|
public function __construct($url, array $contextOptions, $formattedUrl)
|
|
{
|
|
$this->url = $url;
|
|
$this->contextOptions = $contextOptions;
|
|
$this->formattedUrl = $formattedUrl;
|
|
$this->isSecure = 0 === strpos($url, 'https://');
|
|
}
|
|
|
|
/**
|
|
* Returns an array of context options
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getContextOptions()
|
|
{
|
|
return $this->contextOptions;
|
|
}
|
|
|
|
/**
|
|
* Returns the safe proxy url from the last request
|
|
*
|
|
* @param string|null $format Output format specifier
|
|
* @return string Safe proxy, no proxy or empty
|
|
*/
|
|
public function getFormattedUrl($format = '')
|
|
{
|
|
$result = '';
|
|
if ($this->formattedUrl) {
|
|
$format = $format ?: '%s';
|
|
$result = sprintf($format, $this->formattedUrl);
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Returns the proxy url
|
|
*
|
|
* @return string Proxy url or empty
|
|
*/
|
|
public function getUrl()
|
|
{
|
|
return $this->url;
|
|
}
|
|
|
|
/**
|
|
* Returns true if this is a secure-proxy
|
|
*
|
|
* @return bool False if not secure or there is no proxy
|
|
*/
|
|
public function isSecure()
|
|
{
|
|
return $this->isSecure;
|
|
}
|
|
}
|