%PDF- %PDF-
| Direktori : /home1/lightco1/www/ilfanale.com.au/administrator/components/com_jmap/framework/http/ |
| Current File : //home1/lightco1/www/ilfanale.com.au/administrator/components/com_jmap/framework/http/http.php |
<?php
// namespace administrator\components\com_jmap\framework\http;
/**
* @package JMAP::FRAMEWORK::administrator::components::com_jmap
* @subpackage framework
* @subpackage http
* @author Joomla! Extensions Store
* @copyright (C) 2015 - Joomla! Extensions Store
* @license GNU/GPLv2 http://www.gnu.org/licenses/gpl-2.0.html
*/
defined('_JEXEC') or die('Restricted access');
/**
* HTTP connector client object interface
*
* @package JMAP::FRAMEWORK::administrator::components::com_jmap
* @subpackage framework
* @subpackage http
* @since 1.0
*/
interface IJMapHttp {
/**
* Method to send the GET command to the server.
*
* @param string $url Path to the resource.
* @param array $headers An array of name-value pairs to include in the header of the request.
*
* @return JMapHttpResponse
*
* @since 2.0
*/
public function get($url, array $headers = null);
/**
* Method to send the POST command to the server.
*
* @param string $url Path to the resource.
* @param mixed $data Either an associative array or a string to be sent with the request.
* @param array $headers An array of name-value pairs to include in the header of the request.
* @param int $timeout
* @param string $useragent
*
* @return JMapHttpResponse
*
* @since 1.0
*/
public function post($url, $data, array $headers = null, $timeout = null, $userAgent = null);
}
/**
* HTTP client class.
*
* @package JMAP::FRAMEWORK::administrator::components::com_jmap
* @subpackage framework
* @subpackage http
* @since 1.0
*/
class JMapHttp implements IJMapHttp {
/**
* Number of requests placed
* @var Int
* @access protected
*/
protected $numRequests;
/**
* @var JRegistry Options for the HTTP client
* @access protected
*/
protected $options;
/**
* @var JMapHttpTransport The HTTP transport object to use in sending HTTP requests.
* @access protected
*/
protected $transport;
/**
* Component params
* @var Object&
* @access protected
*/
protected $cParams;
/**
* Application object
* @var Object&
* @access protected
*/
protected $app;
/**
* Constructor.
*
* @param JMapHttpTransport $transport The HTTP transport object.
* @param $cParams Object& Component configuration
*
* @since 1.0
*/
public function __construct(JMapHttpTransport $transport = null, &$cParams = null) {
$this->numRequests = 0;
$this->cParams = $cParams;
$this->app = JFactory::getApplication();
$this->transport = isset($transport) ? $transport : new JMapHttpTransportSocket($this->options);
}
/**
* Method to send the OPTIONS command to the server.
*
* @param string $url Path to the resource.
* @param array $headers An array of name-value pairs to include in the header of the request.
*
* @return JMapHttpResponse
*
* @since 1.0
*/
public function options($url, array $headers = null) {
$this->numRequests++;
return $this->transport->request('OPTIONS', new JUri($url), null, $headers);
}
/**
* Method to send the HEAD command to the server.
*
* @param string $url Path to the resource.
* @param array $headers An array of name-value pairs to include in the header of the request.
*
* @return JMapHttpResponse
*
* @since 1.0
*/
public function head($url, array $headers = null) {
$this->numRequests++;
return $this->transport->request('HEAD', new JUri($url), null, $headers);
}
/**
* Method to send the GET command to the server.
*
* @param string $url Path to the resource.
* @param array $headers An array of name-value pairs to include in the header of the request.
*
* @return JMapHttpResponse
*
* @since 1.0
*/
public function get($url, array $headers = null) {
$this->numRequests++;
return $this->transport->request('GET', new JUri($url), null, $headers);
}
/**
* Method to send the POST command to the server.
*
* @param string $url Path to the resource.
* @param mixed $data Either an associative array or a string to be sent with the request.
* @param array $headers An array of name-value pairs to include in the header of the request.
*
* @return JMapHttpResponse
*
* @since 1.0
*/
public function post($url, $data, array $headers = null, $timeout = null, $userAgent = null) {
$this->numRequests++;
return $this->transport->request('POST', new JUri($url), $data, $headers, $timeout, $userAgent);
}
/**
* Method to send the PUT command to the server.
*
* @param string $url Path to the resource.
* @param mixed $data Either an associative array or a string to be sent with the request.
* @param array $headers An array of name-value pairs to include in the header of the request.
*
* @return JMapHttpResponse
*
* @since 1.0
*/
public function put($url, $data, array $headers = null) {
$this->numRequests++;
return $this->transport->request('PUT', new JUri($url), $data, $headers);
}
/**
* Method to send the DELETE command to the server.
*
* @param string $url Path to the resource.
* @param array $headers An array of name-value pairs to include in the header of the request.
*
* @return JMapHttpResponse
*
* @since 1.0
*/
public function delete($url, array $headers = null) {
$this->numRequests++;
return $this->transport->request('DELETE', new JUri($url), null, $headers);
}
/**
* Method to send the TRACE command to the server.
*
* @param string $url Path to the resource.
* @param array $headers An array of name-value pairs to include in the header of the request.
*
* @return JMapHttpResponse
*
* @since 1.0
*/
public function trace($url, array $headers = null) {
$this->numRequests++;
return $this->transport->request('TRACE', new JUri($url), null, $headers);
}
/**
* Check for remaining requests
*
* @access public
* @return boolean
*/
public function isValidRequest() {
// If unlimited requests, return always true
if ($this->cParams->get('max_images_requests', 0) == 0) {
return true;
}
// If limited check if remains count
$limitRequests = $this->cParams->get('max_images_requests');
if ($this->numRequests < $limitRequests) {
return true;
}
return false;
}
}