123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410 |
- <?php
- /**
- * Twitter-API-PHP : Simple PHP wrapper for the v1.1 API
- *
- * PHP version 5.3.10
- *
- * @category Awesomeness
- * @package Twitter-API-PHP
- * @author James Mallison <me@j7mbo.co.uk>
- * @license MIT License
- * @version 1.0.4
- * @link http://github.com/j7mbo/twitter-api-php
- */
- class TwitterAPIExchange
- {
- /**
- * @var string
- */
- private $oauth_access_token;
- /**
- * @var string
- */
- private $oauth_access_token_secret;
- /**
- * @var string
- */
- private $consumer_key;
- /**
- * @var string
- */
- private $consumer_secret;
- /**
- * @var array
- */
- private $postfields;
- /**
- * @var string
- */
- private $getfield;
- /**
- * @var mixed
- */
- protected $oauth;
- /**
- * @var string
- */
- public $url;
- /**
- * @var string
- */
- public $requestMethod;
- /**
- * The HTTP status code from the previous request
- *
- * @var int
- */
- protected $httpStatusCode;
- /**
- * Create the API access object. Requires an array of settings::
- * oauth access token, oauth access token secret, consumer key, consumer secret
- * These are all available by creating your own application on dev.twitter.com
- * Requires the cURL library
- *
- * @throws \RuntimeException When cURL isn't loaded
- * @throws \InvalidArgumentException When incomplete settings parameters are provided
- *
- * @param array $settings
- */
- public function __construct(array $settings)
- {
- if (!function_exists('curl_init'))
- {
- throw new RuntimeException('TwitterAPIExchange requires cURL extension to be loaded, see: http://curl.haxx.se/docs/install.html');
- }
- if (!isset($settings['oauth_access_token'])
- || !isset($settings['oauth_access_token_secret'])
- || !isset($settings['consumer_key'])
- || !isset($settings['consumer_secret']))
- {
- throw new InvalidArgumentException('Incomplete settings passed to TwitterAPIExchange');
- }
- $this->oauth_access_token = $settings['oauth_access_token'];
- $this->oauth_access_token_secret = $settings['oauth_access_token_secret'];
- $this->consumer_key = $settings['consumer_key'];
- $this->consumer_secret = $settings['consumer_secret'];
- }
- /**
- * Set postfields array, example: array('screen_name' => 'J7mbo')
- *
- * @param array $array Array of parameters to send to API
- *
- * @throws \Exception When you are trying to set both get and post fields
- *
- * @return TwitterAPIExchange Instance of self for method chaining
- */
- public function setPostfields(array $array)
- {
- if (!is_null($this->getGetfield()))
- {
- throw new Exception('You can only choose get OR post fields (post fields include put).');
- }
- if (isset($array['status']) && substr($array['status'], 0, 1) === '@')
- {
- $array['status'] = sprintf("\0%s", $array['status']);
- }
- foreach ($array as $key => &$value)
- {
- if (is_bool($value))
- {
- $value = ($value === true) ? 'true' : 'false';
- }
- }
- $this->postfields = $array;
- // rebuild oAuth
- if (isset($this->oauth['oauth_signature']))
- {
- $this->buildOauth($this->url, $this->requestMethod);
- }
- return $this;
- }
- /**
- * Set getfield string, example: '?screen_name=J7mbo'
- *
- * @param string $string Get key and value pairs as string
- *
- * @throws \Exception
- *
- * @return \TwitterAPIExchange Instance of self for method chaining
- */
- public function setGetfield($string)
- {
- if (!is_null($this->getPostfields()))
- {
- throw new Exception('You can only choose get OR post / post fields.');
- }
- $getfields = preg_replace('/^\?/', '', explode('&', $string));
- $params = array();
- foreach ($getfields as $field)
- {
- if ($field !== '')
- {
- list($key, $value) = explode('=', $field);
- $params[$key] = $value;
- }
- }
- $this->getfield = '?' . http_build_query($params, '', '&');
- return $this;
- }
- /**
- * Get getfield string (simple getter)
- *
- * @return string $this->getfields
- */
- public function getGetfield()
- {
- return $this->getfield;
- }
- /**
- * Get postfields array (simple getter)
- *
- * @return array $this->postfields
- */
- public function getPostfields()
- {
- return $this->postfields;
- }
- /**
- * Build the Oauth object using params set in construct and additionals
- * passed to this method. For v1.1, see: https://dev.twitter.com/docs/api/1.1
- *
- * @param string $url The API url to use. Example: https://api.twitter.com/1.1/search/tweets.json
- * @param string $requestMethod Either POST or GET
- *
- * @throws \Exception
- *
- * @return \TwitterAPIExchange Instance of self for method chaining
- */
- public function buildOauth($url, $requestMethod)
- {
- if (!in_array(strtolower($requestMethod), array('post', 'get', 'put', 'delete')))
- {
- throw new Exception('Request method must be either POST, GET or PUT or DELETE');
- }
- $consumer_key = $this->consumer_key;
- $consumer_secret = $this->consumer_secret;
- $oauth_access_token = $this->oauth_access_token;
- $oauth_access_token_secret = $this->oauth_access_token_secret;
- $oauth = array(
- 'oauth_consumer_key' => $consumer_key,
- 'oauth_nonce' => time(),
- 'oauth_signature_method' => 'HMAC-SHA1',
- 'oauth_token' => $oauth_access_token,
- 'oauth_timestamp' => time(),
- 'oauth_version' => '1.0'
- );
- $getfield = $this->getGetfield();
- if (!is_null($getfield))
- {
- $getfields = str_replace('?', '', explode('&', $getfield));
- foreach ($getfields as $g)
- {
- $split = explode('=', $g);
- /** In case a null is passed through **/
- if (isset($split[1]))
- {
- $oauth[$split[0]] = urldecode($split[1]);
- }
- }
- }
- $postfields = $this->getPostfields();
- if (!is_null($postfields)) {
- foreach ($postfields as $key => $value) {
- $oauth[$key] = $value;
- }
- }
- $base_info = $this->buildBaseString($url, $requestMethod, $oauth);
- $composite_key = rawurlencode($consumer_secret) . '&' . rawurlencode($oauth_access_token_secret);
- $oauth_signature = base64_encode(hash_hmac('sha1', $base_info, $composite_key, true));
- $oauth['oauth_signature'] = $oauth_signature;
- $this->url = $url;
- $this->requestMethod = $requestMethod;
- $this->oauth = $oauth;
- return $this;
- }
- /**
- * Perform the actual data retrieval from the API
- *
- * @param boolean $return If true, returns data. This is left in for backward compatibility reasons
- * @param array $curlOptions Additional Curl options for this request
- *
- * @throws \Exception
- *
- * @return string json If $return param is true, returns json data.
- */
- public function performRequest($return = true, $curlOptions = array())
- {
- if (!is_bool($return))
- {
- throw new Exception('performRequest parameter must be true or false');
- }
- $header = array($this->buildAuthorizationHeader($this->oauth), 'Expect:');
- $getfield = $this->getGetfield();
- $postfields = $this->getPostfields();
- if (in_array(strtolower($this->requestMethod), array('put', 'delete')))
- {
- $curlOptions[CURLOPT_CUSTOMREQUEST] = $this->requestMethod;
- }
- $options = $curlOptions + array(
- CURLOPT_HTTPHEADER => $header,
- CURLOPT_HEADER => false,
- CURLOPT_URL => $this->url,
- CURLOPT_RETURNTRANSFER => true,
- CURLOPT_TIMEOUT => 10,
- );
- if (!is_null($postfields))
- {
- $options[CURLOPT_POSTFIELDS] = http_build_query($postfields, '', '&');
- }
- else
- {
- if ($getfield !== '')
- {
- $options[CURLOPT_URL] .= $getfield;
- }
- }
- $feed = curl_init();
- curl_setopt_array($feed, $options);
- $json = curl_exec($feed);
- $this->httpStatusCode = curl_getinfo($feed, CURLINFO_HTTP_CODE);
- if (($error = curl_error($feed)) !== '')
- {
- curl_close($feed);
- throw new \Exception($error);
- }
- curl_close($feed);
- return $json;
- }
- /**
- * Private method to generate the base string used by cURL
- *
- * @param string $baseURI
- * @param string $method
- * @param array $params
- *
- * @return string Built base string
- */
- private function buildBaseString($baseURI, $method, $params)
- {
- $return = array();
- ksort($params);
- foreach($params as $key => $value)
- {
- $return[] = rawurlencode($key) . '=' . rawurlencode($value);
- }
- return $method . "&" . rawurlencode($baseURI) . '&' . rawurlencode(implode('&', $return));
- }
- /**
- * Private method to generate authorization header used by cURL
- *
- * @param array $oauth Array of oauth data generated by buildOauth()
- *
- * @return string $return Header used by cURL for request
- */
- private function buildAuthorizationHeader(array $oauth)
- {
- $return = 'Authorization: OAuth ';
- $values = array();
- foreach($oauth as $key => $value)
- {
- if (in_array($key, array('oauth_consumer_key', 'oauth_nonce', 'oauth_signature',
- 'oauth_signature_method', 'oauth_timestamp', 'oauth_token', 'oauth_version'))) {
- $values[] = "$key=\"" . rawurlencode($value) . "\"";
- }
- }
- $return .= implode(', ', $values);
- return $return;
- }
- /**
- * Helper method to perform our request
- *
- * @param string $url
- * @param string $method
- * @param string $data
- * @param array $curlOptions
- *
- * @throws \Exception
- *
- * @return string The json response from the server
- */
- public function request($url, $method = 'get', $data = null, $curlOptions = array())
- {
- if (strtolower($method) === 'get')
- {
- $this->setGetfield($data);
- }
- else
- {
- $this->setPostfields($data);
- }
- return $this->buildOauth($url, $method)->performRequest(true, $curlOptions);
- }
- /**
- * Get the HTTP status code for the previous request
- *
- * @return integer
- */
- public function getHttpStatusCode()
- {
- return $this->httpStatusCode;
- }
- }
|