255 lines
6.0 KiB
PHP
255 lines
6.0 KiB
PHP
<?php
|
|
/**
|
|
* The MIT License
|
|
* Copyright (c) 2007 Andy Smith
|
|
*/
|
|
namespace Abraham\TwitterOAuth;
|
|
|
|
class Request
|
|
{
|
|
protected $parameters;
|
|
protected $httpMethod;
|
|
protected $httpUrl;
|
|
public static $version = '1.0';
|
|
|
|
/**
|
|
* Constructor
|
|
*
|
|
* @param string $httpMethod
|
|
* @param string $httpUrl
|
|
* @param array|null $parameters
|
|
*/
|
|
public function __construct($httpMethod, $httpUrl, array $parameters = [])
|
|
{
|
|
$parameters = array_merge(Util::parseParameters(parse_url($httpUrl, PHP_URL_QUERY)), $parameters);
|
|
$this->parameters = $parameters;
|
|
$this->httpMethod = $httpMethod;
|
|
$this->httpUrl = $httpUrl;
|
|
}
|
|
|
|
/**
|
|
* pretty much a helper function to set up the request
|
|
*
|
|
* @param Consumer $consumer
|
|
* @param Token $token
|
|
* @param string $httpMethod
|
|
* @param string $httpUrl
|
|
* @param array $parameters
|
|
*
|
|
* @return Request
|
|
*/
|
|
public static function fromConsumerAndToken(
|
|
Consumer $consumer,
|
|
Token $token = null,
|
|
$httpMethod,
|
|
$httpUrl,
|
|
array $parameters = []
|
|
) {
|
|
$defaults = [
|
|
"oauth_version" => Request::$version,
|
|
"oauth_nonce" => Request::generateNonce(),
|
|
"oauth_timestamp" => time(),
|
|
"oauth_consumer_key" => $consumer->key
|
|
];
|
|
if (null !== $token) {
|
|
$defaults['oauth_token'] = $token->key;
|
|
}
|
|
|
|
$parameters = array_merge($defaults, $parameters);
|
|
|
|
return new Request($httpMethod, $httpUrl, $parameters);
|
|
}
|
|
|
|
/**
|
|
* @param string $name
|
|
* @param string $value
|
|
*/
|
|
public function setParameter($name, $value)
|
|
{
|
|
$this->parameters[$name] = $value;
|
|
}
|
|
|
|
/**
|
|
* @param $name
|
|
*
|
|
* @return string|null
|
|
*/
|
|
public function getParameter($name)
|
|
{
|
|
return isset($this->parameters[$name]) ? $this->parameters[$name] : null;
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getParameters()
|
|
{
|
|
return $this->parameters;
|
|
}
|
|
|
|
/**
|
|
* @param $name
|
|
*/
|
|
public function removeParameter($name)
|
|
{
|
|
unset($this->parameters[$name]);
|
|
}
|
|
|
|
/**
|
|
* The request parameters, sorted and concatenated into a normalized string.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getSignableParameters()
|
|
{
|
|
// Grab all parameters
|
|
$params = $this->parameters;
|
|
|
|
// Remove oauth_signature if present
|
|
// Ref: Spec: 9.1.1 ("The oauth_signature parameter MUST be excluded.")
|
|
if (isset($params['oauth_signature'])) {
|
|
unset($params['oauth_signature']);
|
|
}
|
|
|
|
return Util::buildHttpQuery($params);
|
|
}
|
|
|
|
/**
|
|
* Returns the base string of this request
|
|
*
|
|
* The base string defined as the method, the url
|
|
* and the parameters (normalized), each urlencoded
|
|
* and the concated with &.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getSignatureBaseString()
|
|
{
|
|
$parts = [
|
|
$this->getNormalizedHttpMethod(),
|
|
$this->getNormalizedHttpUrl(),
|
|
$this->getSignableParameters()
|
|
];
|
|
|
|
$parts = Util::urlencodeRfc3986($parts);
|
|
|
|
return implode('&', $parts);
|
|
}
|
|
|
|
/**
|
|
* Returns the HTTP Method in uppercase
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getNormalizedHttpMethod()
|
|
{
|
|
return strtoupper($this->httpMethod);
|
|
}
|
|
|
|
/**
|
|
* parses the url and rebuilds it to be
|
|
* scheme://host/path
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getNormalizedHttpUrl()
|
|
{
|
|
$parts = parse_url($this->httpUrl);
|
|
|
|
$scheme = $parts['scheme'];
|
|
$host = strtolower($parts['host']);
|
|
$path = $parts['path'];
|
|
|
|
return "$scheme://$host$path";
|
|
}
|
|
|
|
/**
|
|
* Builds a url usable for a GET request
|
|
*
|
|
* @return string
|
|
*/
|
|
public function toUrl()
|
|
{
|
|
$postData = $this->toPostdata();
|
|
$out = $this->getNormalizedHttpUrl();
|
|
if ($postData) {
|
|
$out .= '?' . $postData;
|
|
}
|
|
return $out;
|
|
}
|
|
|
|
/**
|
|
* Builds the data one would send in a POST request
|
|
*
|
|
* @return string
|
|
*/
|
|
public function toPostdata()
|
|
{
|
|
return Util::buildHttpQuery($this->parameters);
|
|
}
|
|
|
|
/**
|
|
* Builds the Authorization: header
|
|
*
|
|
* @return string
|
|
* @throws TwitterOAuthException
|
|
*/
|
|
public function toHeader()
|
|
{
|
|
$first = true;
|
|
$out = 'Authorization: OAuth';
|
|
foreach ($this->parameters as $k => $v) {
|
|
if (substr($k, 0, 5) != "oauth") {
|
|
continue;
|
|
}
|
|
if (is_array($v)) {
|
|
throw new TwitterOAuthException('Arrays not supported in headers');
|
|
}
|
|
$out .= ($first) ? ' ' : ', ';
|
|
$out .= Util::urlencodeRfc3986($k) . '="' . Util::urlencodeRfc3986($v) . '"';
|
|
$first = false;
|
|
}
|
|
return $out;
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function __toString()
|
|
{
|
|
return $this->toUrl();
|
|
}
|
|
|
|
/**
|
|
* @param SignatureMethod $signatureMethod
|
|
* @param Consumer $consumer
|
|
* @param Token $token
|
|
*/
|
|
public function signRequest(SignatureMethod $signatureMethod, Consumer $consumer, Token $token = null)
|
|
{
|
|
$this->setParameter("oauth_signature_method", $signatureMethod->getName());
|
|
$signature = $this->buildSignature($signatureMethod, $consumer, $token);
|
|
$this->setParameter("oauth_signature", $signature);
|
|
}
|
|
|
|
/**
|
|
* @param SignatureMethod $signatureMethod
|
|
* @param Consumer $consumer
|
|
* @param Token $token
|
|
*
|
|
* @return string
|
|
*/
|
|
public function buildSignature(SignatureMethod $signatureMethod, Consumer $consumer, Token $token = null)
|
|
{
|
|
return $signatureMethod->buildSignature($this, $consumer, $token);
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public static function generateNonce()
|
|
{
|
|
return md5(microtime() . mt_rand());
|
|
}
|
|
}
|