index 54f98096ca7a8ed6d86a71b410b1802f883a41b5..d9084f61c0913dba6c4bbcefb8668f69ddc754dd 100644 (file)
class jsonRPC {
private $curlHandler = NULL;
- private $debug;
- private $url;
+ private $config;
private $id;
+ private $lastStats = array();
+ private $lastAction = "none";
- public function __construct($url,$debug = false) {
+ public function __construct($config)
+ {
+ $this->config = $config;
+ $this->id = 0;
+ $this->__login();
+ }
+
+ private function __login()
+ {
+ // Get connection data
+ $url = $this->config->get_cfg_value('core','gosaRpcServer');
+ $user = $this->config->get_cfg_value('core','gosaRpcUser');
+ $passwd = $this->config->get_cfg_value('core','gosaRpcPassword');
- $this->url = $url;
- $this->dbug = $debug;
- $this->id = 1;
+ DEBUG (DEBUG_RPC, __LINE__, __FUNCTION__, __FILE__,bold($url), "Initiated RPC ");
+ DEBUG (DEBUG_RPC, __LINE__, __FUNCTION__, __FILE__,bold($user), "RPC user: ");
+ DEBUG (DEBUG_RPC, __LINE__, __FUNCTION__, __FILE__,bold($passwd),"RPC password: ");
// Init Curl handler
- $this->curlHandler = curl_init($this->url);
- curl_setopt($this->curlHandler, CURLOPT_URL , $this->url);
+ $this->curlHandler = curl_init($url);
+
+ // Set curl options
+ curl_setopt($this->curlHandler, CURLOPT_URL , $url);
curl_setopt($this->curlHandler, CURLOPT_COOKIESESSION , TRUE);
curl_setopt($this->curlHandler, CURLOPT_COOKIEFILE, 'cookiefile.txt');
curl_setopt($this->curlHandler, CURLOPT_POST , TRUE);
curl_setopt($this->curlHandler, CURLOPT_RETURNTRANSFER , TRUE);
+ curl_setopt($this->curlHandler, CURLOPT_SSL_VERIFYPEER, TRUE);
curl_setopt($this->curlHandler, CURLOPT_HTTPHEADER , array('Content-Type: application/json'));
+
+ // Try to login
+ $this->login($user, $passwd);
+
}
+
- public function __call($method,$params) {
+ public function getHTTPstatusCode()
+ {
+ return((isset($this->lastStats['http_code']))? $this->lastStats['http_code'] : -1 );
+ }
- if (!is_scalar($method)) trigger_error('jsonRPC::__call requires a scalar value as first parameter!');
+ public function get_error()
+ {
+ if($this->lastStats['http_code'] != 200){
+ return($this->getHttpStatusCodeMessage($this->lastStats['http_code']));
+ }else{
+ return(curl_error($this->curlHandler));
+ }
+ }
+
+ public function success()
+ {
+ return(curl_errno($this->curlHandler) == 0 && $this->lastStats['http_code'] == 200);
+ }
+
+ public function __destruct()
+ {
+ if($this->curlHandler){
+ curl_close($this->curlHandler);
+ }
+ }
+
+ public function __call($method,$params)
+ {
+ // Check if handle is still valid!
+ if(!$this->curlHandler && $this->lastAction != 'login'){
+ $this->__login();
+ }
+ // Start request
+ DEBUG (DEBUG_RPC, __LINE__, __FUNCTION__, __FILE__,"{$method}", "Calling: ");
+ $response = $this->request($method,$params);
+ if($this->success()){
+ DEBUG (DEBUG_RPC, __LINE__, __FUNCTION__, __FILE__,
+ (is_array($response['result']))?$response['result']:bold($response['result']), "Result: ");
+ }else{
+ DEBUG (DEBUG_RPC, __LINE__, __FUNCTION__, __FILE__,bold($this->get_error())."<br>".$response, "Result (FAILED): ");
+ }
+
+ return($response['result']);
+ }
+
+
+ private function request($method, $params)
+ {
+ // Set last action
+ $this->lastAction = $method;
+
+ // Reset stats of last request.
+ $this->lastStats = array();
+
+ // Validate input values
+ if (!is_scalar($method)) trigger_error('jsonRPC::__call requires a scalar value as first parameter!');
if (is_array($params)) {
$params = array_values($params);
} else {
$response = curl_exec($this->curlHandler);
$response = json_decode($response,true);
- // Check responce id
- if ($response['id'] != $this->id){
- trigger_error('jsonPRC returned incorrect response id (request id: '.$this->id.', response id: '.$response['id'].')');
- }
+ // Set current result stats.
+ $this->lastStats = curl_getinfo($this->curlHandler);
+
+ return($response);
+ }
+
- return($response['result']);
+ public static function getHttpStatusCodeMessage($code)
+ {
+ $codes = array(
+ '100' => 'Continue',
+ '101' => 'Switching Protocols',
+ '102' => 'Processing',
+ '200' => 'OK',
+ '201' => 'Created',
+ '202' => 'Accepted',
+ '203' => 'Non-Authoritative Information',
+ '204' => 'No Content',
+ '205' => 'Reset Content',
+ '206' => 'Partial Content',
+ '207' => 'Multi-Status',
+ '300' => 'Multiple Choice',
+ '301' => 'Moved Permanently',
+ '302' => 'Found',
+ '303' => 'See Other',
+ '304' => 'Not Modified',
+ '305' => 'Use Proxy',
+ '306' => 'reserved',
+ '307' => 'Temporary Redirect',
+ '400' => 'Bad Request',
+ '401' => 'Unauthorized',
+ '402' => 'Payment Required',
+ '403' => 'Forbidden',
+ '404' => 'Not Found',
+ '405' => 'Method Not Allowed',
+ '406' => 'Not Acceptable',
+ '407' => 'Proxy Authentication Required',
+ '408' => 'Request Time-out',
+ '409' => 'Conflict',
+ '410' => 'Gone',
+ '411' => 'Length Required',
+ '412' => 'Precondition Failed',
+ '413' => 'Request Entity Too Large',
+ '414' => 'Request-URI Too Long',
+ '415' => 'Unsupported Media Type',
+ '416' => 'Requested range not satisfiable',
+ '417' => 'Expectation Failed',
+ '421' => 'There are too many connections from your internet address',
+ '422' => 'Unprocessable Entity',
+ '423' => 'Locked',
+ '424' => 'Failed Dependency',
+ '425' => 'Unordered Collection',
+ '426' => 'Upgrade Required',
+ '500' => 'Internal Server Error',
+ '501' => 'Not Implemented',
+ '502' => 'Bad Gateway',
+ '503' => 'Service Unavailable',
+ '504' => 'Gateway Time-out',
+ '505' => 'HTTP Version not supported',
+ '506' => 'Variant Also Negotiates',
+ '507' => 'Insufficient Storage',
+ '509' => 'Bandwidth Limit Exceeded',
+ '510' => 'Not Extended');
+ return((isset($codes[$code]))? $codes[$code] : sprintf(_("Unknown HTTP status code '%s'!"), $code));
}
}
?>