Added remote class, requires CURL

This commit is contained in:
Woody Gilk 2008-12-09 19:10:02 -06:00
parent aa4aa93395
commit ac9ba6de45

68
system/classes/remote.php Normal file
View file

@ -0,0 +1,68 @@
<?php
/**
* Provides remote server communications options using [curl][ref-curl].
*
* [ref-curl]: http://php.net/curl
*
* @package Core
* @author Kohana Team
* @copyright (c) 2008-2009 Kohana Team
* @license http://kohanaphp.com/license.html
*/
class remote_Core {
// Default curl options
public $default_options = array
(
CURLOPT_USERAGENT => 'Mozilla/5.0 (compatible; Kohana v'.KOHANA_VERSION.' +http://kohanaphp.com/)',
CURLOPT_CONNECTTIMEOUT => 5,
CURLOPT_TIMEOUT => 5,
);
/**
* Returns the output of a remote URL. Output will be returned as an
* array with a boolean "status" and a string "response":
*
* $page = remote::get('http://www.google.com');
*
* echo $page['status'] ? $page['response'] : 'Error: '.$page['response'];
*
* @param string remote URL
* @param array curl options
* @return array
*/
public static function get($url, $options = NULL)
{
// Add default options
$options = array_merge(remote::$default_options, (array) $options);
// The transfer must always be returned
$options[CURLOPT_RETURNTRANSFER] = TRUE;
// Open a new remote connection
$remote = curl_init($url);
// Set connection options
curl_setopt_array($remote, $options);
if (($response = curl_exec($remote)) === FALSE)
{
// An error has occurred
$status = FALSE;
// Return the error message instead of the response
$response = curl_error($remote);
}
else
{
// The response is valid
$status = TRUE;
}
// Close the connection
curl_close($remote);
return array('status' => $status, 'response' => $response);
}
} // End remote