2013-07-16 19:54:44 -04:00
|
|
|
<?php
|
|
|
|
|
2014-12-23 21:28:26 -05:00
|
|
|
namespace PicoFeed\Client;
|
2013-07-16 19:54:44 -04:00
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
use LogicException;
|
2014-12-23 21:28:26 -05:00
|
|
|
use PicoFeed\Logging\Logger;
|
2014-05-20 14:20:27 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Client class
|
|
|
|
*
|
|
|
|
* @author Frederic Guillot
|
|
|
|
* @package client
|
|
|
|
*/
|
2013-07-16 19:54:44 -04:00
|
|
|
abstract class Client
|
|
|
|
{
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Flag that say if the resource have been modified
|
|
|
|
*
|
|
|
|
* @access private
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
private $is_modified = true;
|
|
|
|
|
2014-10-19 14:42:31 -04:00
|
|
|
/**
|
2014-12-23 21:28:26 -05:00
|
|
|
* HTTP Content-Type
|
2014-10-19 14:42:31 -04:00
|
|
|
*
|
|
|
|
* @access private
|
2014-12-23 21:28:26 -05:00
|
|
|
* @var string
|
2014-10-19 14:42:31 -04:00
|
|
|
*/
|
2014-12-23 21:28:26 -05:00
|
|
|
private $content_type = '';
|
2014-10-19 14:42:31 -04:00
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* HTTP encoding
|
|
|
|
*
|
|
|
|
* @access private
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
private $encoding = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* HTTP Etag header
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $etag = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* HTTP Last-Modified header
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $last_modified = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Proxy hostname
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $proxy_hostname = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Proxy port
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var integer
|
|
|
|
*/
|
|
|
|
protected $proxy_port = 3128;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Proxy username
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $proxy_username = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Proxy password
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $proxy_password = '';
|
|
|
|
|
2014-12-24 13:50:20 -05:00
|
|
|
/**
|
|
|
|
* Basic auth username
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $username = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Basic auth password
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $password = '';
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Client connection timeout
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var integer
|
|
|
|
*/
|
|
|
|
protected $timeout = 10;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* User-agent
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $user_agent = 'PicoFeed (https://github.com/fguillot/picoFeed)';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Real URL used (can be changed after a HTTP redirect)
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $url = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Page/Feed content
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $content = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Number maximum of HTTP redirections to avoid infinite loops
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var integer
|
|
|
|
*/
|
|
|
|
protected $max_redirects = 5;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum size of the HTTP body response
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var integer
|
|
|
|
*/
|
|
|
|
protected $max_body_size = 2097152; // 2MB
|
|
|
|
|
2014-12-24 13:50:20 -05:00
|
|
|
/**
|
|
|
|
* HTTP response status code
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var integer
|
|
|
|
*/
|
|
|
|
protected $status_code = 0;
|
|
|
|
|
2015-02-05 21:16:34 -05:00
|
|
|
/**
|
|
|
|
* Enables direct passthrough to requesting client
|
|
|
|
*
|
|
|
|
* @access protected
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $passthrough = false;
|
|
|
|
|
2014-10-22 22:10:17 -04:00
|
|
|
/**
|
|
|
|
* Do the HTTP request
|
|
|
|
*
|
|
|
|
* @abstract
|
|
|
|
* @access public
|
|
|
|
* @return array
|
|
|
|
*/
|
2015-02-01 14:48:05 -05:00
|
|
|
abstract public function doRequest();
|
2014-10-22 22:10:17 -04:00
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Get client instance: curl or stream driver
|
|
|
|
*
|
|
|
|
* @static
|
|
|
|
* @access public
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public static function getInstance()
|
2013-07-16 19:54:44 -04:00
|
|
|
{
|
|
|
|
if (function_exists('curl_init')) {
|
2014-12-23 21:28:26 -05:00
|
|
|
return new Curl;
|
2014-05-20 14:20:27 -04:00
|
|
|
}
|
|
|
|
else if (ini_get('allow_url_fopen')) {
|
2014-12-23 21:28:26 -05:00
|
|
|
return new Stream;
|
2013-07-16 19:54:44 -04:00
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
throw new LogicException('You must have "allow_url_fopen=1" or curl extension installed');
|
2013-07-16 19:54:44 -04:00
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Perform the HTTP request
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $url URL
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function execute($url = '')
|
2013-07-16 19:54:44 -04:00
|
|
|
{
|
2014-05-20 14:20:27 -04:00
|
|
|
if ($url !== '') {
|
|
|
|
$this->url = $url;
|
2013-07-16 19:54:44 -04:00
|
|
|
}
|
|
|
|
|
2014-12-23 21:28:26 -05:00
|
|
|
Logger::setMessage(get_called_class().' Fetch URL: '.$this->url);
|
|
|
|
Logger::setMessage(get_called_class().' Etag provided: '.$this->etag);
|
|
|
|
Logger::setMessage(get_called_class().' Last-Modified provided: '.$this->last_modified);
|
2013-07-16 19:54:44 -04:00
|
|
|
|
|
|
|
$response = $this->doRequest();
|
|
|
|
|
2014-12-24 13:50:20 -05:00
|
|
|
$this->status_code = $response['status'];
|
2014-12-23 21:28:26 -05:00
|
|
|
$this->handleNotModifiedResponse($response);
|
|
|
|
$this->handleNotFoundResponse($response);
|
|
|
|
$this->handleNormalResponse($response);
|
2014-10-19 14:42:31 -04:00
|
|
|
|
2014-12-23 21:28:26 -05:00
|
|
|
return $this;
|
2014-10-19 14:42:31 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle not modified response
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param array $response Client response
|
|
|
|
*/
|
|
|
|
public function handleNotModifiedResponse(array $response)
|
|
|
|
{
|
|
|
|
if ($response['status'] == 304) {
|
|
|
|
$this->is_modified = false;
|
|
|
|
}
|
|
|
|
else if ($response['status'] == 200) {
|
2014-12-23 21:28:26 -05:00
|
|
|
$this->is_modified = $this->hasBeenModified($response, $this->etag, $this->last_modified);
|
|
|
|
$this->etag = $this->getHeader($response, 'ETag');
|
|
|
|
$this->last_modified = $this->getHeader($response, 'Last-Modified');
|
2013-07-16 19:54:44 -04:00
|
|
|
}
|
|
|
|
|
2014-10-19 14:42:31 -04:00
|
|
|
if ($this->is_modified === false) {
|
2014-12-23 21:28:26 -05:00
|
|
|
Logger::setMessage(get_called_class().' Resource not modified');
|
2014-10-19 14:42:31 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle not found response
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param array $response Client response
|
|
|
|
*/
|
|
|
|
public function handleNotFoundResponse(array $response)
|
|
|
|
{
|
|
|
|
if ($response['status'] == 404) {
|
2014-12-23 21:28:26 -05:00
|
|
|
throw new InvalidUrlException('Resource not found');
|
2014-10-19 14:42:31 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle normal response
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param array $response Client response
|
|
|
|
*/
|
|
|
|
public function handleNormalResponse(array $response)
|
|
|
|
{
|
|
|
|
if ($response['status'] == 200) {
|
|
|
|
$this->content = $response['body'];
|
2014-12-23 21:28:26 -05:00
|
|
|
$this->content_type = $this->findContentType($response);
|
|
|
|
$this->encoding = $this->findCharset();
|
2014-10-19 14:42:31 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-12-23 21:28:26 -05:00
|
|
|
* Check if a request has been modified according to the parameters
|
2014-10-19 14:42:31 -04:00
|
|
|
*
|
|
|
|
* @access public
|
2014-12-23 21:28:26 -05:00
|
|
|
* @param array $response
|
|
|
|
* @param string $etag
|
|
|
|
* @param string $lastModified
|
2014-10-19 14:42:31 -04:00
|
|
|
* @return boolean
|
|
|
|
*/
|
2014-12-23 21:28:26 -05:00
|
|
|
private function hasBeenModified($response, $etag, $lastModified)
|
2014-10-19 14:42:31 -04:00
|
|
|
{
|
2014-12-23 21:28:26 -05:00
|
|
|
$headers = array(
|
|
|
|
'Etag' => $etag,
|
|
|
|
'Last-Modified' => $lastModified
|
|
|
|
);
|
|
|
|
|
|
|
|
// Compare the values for each header that is present
|
|
|
|
$presentCacheHeaderCount = 0;
|
|
|
|
foreach ($headers as $key => $value) {
|
|
|
|
if (isset($response['headers'][$key])) {
|
|
|
|
if ($response['headers'][$key] !== $value) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
$presentCacheHeaderCount++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// If at least one header is present and the values match, the response
|
|
|
|
// was not modified
|
|
|
|
if ($presentCacheHeaderCount > 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
2014-10-19 14:42:31 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-12-23 21:28:26 -05:00
|
|
|
* Find content type from response headers
|
2014-10-19 14:42:31 -04:00
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param array $response Client response
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return string
|
2014-10-19 14:42:31 -04:00
|
|
|
*/
|
2014-12-23 21:28:26 -05:00
|
|
|
public function findContentType(array $response)
|
2014-10-19 14:42:31 -04:00
|
|
|
{
|
2014-12-23 21:28:26 -05:00
|
|
|
return strtolower($this->getHeader($response, 'Content-Type'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find charset from response headers
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function findCharset()
|
|
|
|
{
|
|
|
|
$result = explode('charset=', $this->content_type);
|
2014-10-19 14:42:31 -04:00
|
|
|
return isset($result[1]) ? $result[1] : '';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get header value from a client response
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param array $response Client response
|
|
|
|
* @param string $header Header name
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getHeader(array $response, $header)
|
|
|
|
{
|
|
|
|
return isset($response['headers'][$header]) ? $response['headers'][$header] : '';
|
2014-05-20 14:20:27 -04:00
|
|
|
}
|
2013-07-16 19:54:44 -04:00
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Set the Last-Modified HTTP header
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $last_modified Header value
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
2013-07-16 19:54:44 -04:00
|
|
|
public function setLastModified($last_modified)
|
|
|
|
{
|
|
|
|
$this->last_modified = $last_modified;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Get the value of the Last-Modified HTTP header
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-07-16 19:54:44 -04:00
|
|
|
public function getLastModified()
|
|
|
|
{
|
|
|
|
return $this->last_modified;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Set the value of the Etag HTTP header
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $etag Etag HTTP header value
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
2013-07-16 19:54:44 -04:00
|
|
|
public function setEtag($etag)
|
|
|
|
{
|
|
|
|
$this->etag = $etag;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Get the Etag HTTP header value
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-07-16 19:54:44 -04:00
|
|
|
public function getEtag()
|
|
|
|
{
|
|
|
|
return $this->etag;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Get the final url value
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-07-16 19:54:44 -04:00
|
|
|
public function getUrl()
|
|
|
|
{
|
|
|
|
return $this->url;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Set the url
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return string
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setUrl($url)
|
|
|
|
{
|
|
|
|
$this->url = $url;
|
|
|
|
return $this;
|
|
|
|
}
|
2013-07-16 19:54:44 -04:00
|
|
|
|
2014-12-24 13:50:20 -05:00
|
|
|
/**
|
|
|
|
* Get the HTTP response status code
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return integer
|
|
|
|
*/
|
|
|
|
public function getStatusCode()
|
|
|
|
{
|
|
|
|
return $this->status_code;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Get the body of the HTTP response
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-07-16 19:54:44 -04:00
|
|
|
public function getContent()
|
|
|
|
{
|
|
|
|
return $this->content;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
2014-12-23 21:28:26 -05:00
|
|
|
* Get the content type value from HTTP headers
|
2014-05-20 14:20:27 -04:00
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return string
|
|
|
|
*/
|
2014-12-23 21:28:26 -05:00
|
|
|
public function getContentType()
|
2013-10-03 23:14:39 -04:00
|
|
|
{
|
2014-12-23 21:28:26 -05:00
|
|
|
return $this->content_type;
|
2013-10-03 23:14:39 -04:00
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
2014-12-23 21:28:26 -05:00
|
|
|
* Get the encoding value from HTTP headers
|
2014-05-20 14:20:27 -04:00
|
|
|
*
|
|
|
|
* @access public
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return string
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
2014-12-23 21:28:26 -05:00
|
|
|
public function getEncoding()
|
2013-07-16 19:54:44 -04:00
|
|
|
{
|
2014-12-23 21:28:26 -05:00
|
|
|
return $this->encoding;
|
2013-07-16 19:54:44 -04:00
|
|
|
}
|
2014-05-20 14:20:27 -04:00
|
|
|
|
2014-10-19 14:42:31 -04:00
|
|
|
/**
|
2014-12-23 21:28:26 -05:00
|
|
|
* Return true if the remote resource has changed
|
2014-10-19 14:42:31 -04:00
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return bool
|
|
|
|
*/
|
2014-12-23 21:28:26 -05:00
|
|
|
public function isModified()
|
2014-10-19 14:42:31 -04:00
|
|
|
{
|
2014-12-23 21:28:26 -05:00
|
|
|
return $this->is_modified;
|
2014-10-19 14:42:31 -04:00
|
|
|
}
|
|
|
|
|
2015-02-05 21:16:34 -05:00
|
|
|
/**
|
|
|
|
* return true if passthrough mode is enabled
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isPassthroughEnabled()
|
|
|
|
{
|
|
|
|
return $this->passthrough;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Set connection timeout
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param integer $timeout Connection timeout
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setTimeout($timeout)
|
|
|
|
{
|
|
|
|
$this->timeout = $timeout ?: $this->timeout;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a custom user agent
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $user_agent User Agent
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setUserAgent($user_agent)
|
|
|
|
{
|
|
|
|
$this->user_agent = $user_agent ?: $this->user_agent;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the mximum number of HTTP redirections
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param integer $max Maximum
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setMaxRedirections($max)
|
|
|
|
{
|
|
|
|
$this->max_redirects = $max ?: $this->max_redirects;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the maximum size of the HTTP body
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param integer $max Maximum
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setMaxBodySize($max)
|
|
|
|
{
|
|
|
|
$this->max_body_size = $max ?: $this->max_body_size;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the proxy hostname
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $hostname Proxy hostname
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setProxyHostname($hostname)
|
|
|
|
{
|
|
|
|
$this->proxy_hostname = $hostname ?: $this->proxy_hostname;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the proxy port
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param integer $port Proxy port
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setProxyPort($port)
|
|
|
|
{
|
|
|
|
$this->proxy_port = $port ?: $this->proxy_port;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the proxy username
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $username Proxy username
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setProxyUsername($username)
|
|
|
|
{
|
|
|
|
$this->proxy_username = $username ?: $this->proxy_username;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the proxy password
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $password Password
|
2014-12-23 21:28:26 -05:00
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setProxyPassword($password)
|
|
|
|
{
|
|
|
|
$this->proxy_password = $password ?: $this->proxy_password;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-12-24 13:50:20 -05:00
|
|
|
/**
|
|
|
|
* Set the username
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $username Basic Auth username
|
|
|
|
* @return \PicoFeed\Client\Client
|
|
|
|
*/
|
|
|
|
public function setUsername($username)
|
|
|
|
{
|
|
|
|
$this->username = $username ?: $this->username;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the password
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $password Basic Auth Password
|
|
|
|
* @return \PicoFeed\Client\Client
|
|
|
|
*/
|
|
|
|
public function setPassword($password)
|
|
|
|
{
|
|
|
|
$this->password = $password ?: $this->password;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-02-05 21:16:34 -05:00
|
|
|
/**
|
|
|
|
* Enable the passthrough mode
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return \PicoFeed\Client\Client
|
|
|
|
*/
|
|
|
|
public function enablePassthroughMode()
|
|
|
|
{
|
|
|
|
$this->passthrough = true;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Disable the passthrough mode
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return \PicoFeed\Client\Client
|
|
|
|
*/
|
|
|
|
public function disablePassthroughMode()
|
|
|
|
{
|
|
|
|
$this->passthrough = false;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Set config object
|
|
|
|
*
|
|
|
|
* @access public
|
2014-12-23 21:28:26 -05:00
|
|
|
* @param \PicoFeed\Config\Config $config Config instance
|
|
|
|
* @return \PicoFeed\Client\Client
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function setConfig($config)
|
|
|
|
{
|
2014-10-19 14:42:31 -04:00
|
|
|
if ($config !== null) {
|
|
|
|
$this->setTimeout($config->getGrabberTimeout());
|
|
|
|
$this->setUserAgent($config->getGrabberUserAgent());
|
|
|
|
$this->setMaxRedirections($config->getMaxRedirections());
|
|
|
|
$this->setMaxBodySize($config->getMaxBodySize());
|
|
|
|
$this->setProxyHostname($config->getProxyHostname());
|
|
|
|
$this->setProxyPort($config->getProxyPort());
|
|
|
|
$this->setProxyUsername($config->getProxyUsername());
|
|
|
|
$this->setProxyPassword($config->getProxyPassword());
|
|
|
|
}
|
2014-05-20 14:20:27 -04:00
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
}
|