59 lines
1.7 KiB
PHP
Raw Normal View History

2016-01-29 18:04:48 +03:00
<?php
/**
* Class RequestProxy
* @package RetailCrm\Component
*/
class RetailcrmProxy
{
private $api;
private $log;
2017-09-15 15:47:38 +03:00
public function __construct($url, $key, $log, $version = null)
{
switch ($version) {
case 'v5':
2017-09-15 15:47:38 +03:00
$this->api = new RetailcrmApiClient5($url, $key, $version);
break;
case 'v4':
2017-09-15 15:47:38 +03:00
$this->api = new RetailcrmApiClient4($url, $key, $version);
break;
case 'v3':
2017-09-15 15:47:38 +03:00
$this->api = new RetailcrmApiClient3($url, $key, $version);
break;
case null:
$this->api = new RetailcrmApiClient3($url, $key, $version);
break;
}
2016-01-29 18:04:48 +03:00
$this->log = $log;
}
public function __call($method, $arguments)
{
$date = date('[Y-m-d H:i:s]');
2016-01-29 18:04:48 +03:00
try {
$response = call_user_func_array(array($this->api, $method), $arguments);
if (!$response->isSuccessful()) {
error_log($date . " [$method] " . $response->getErrorMsg() . "\n", 3, $this->log);
2016-01-29 18:04:48 +03:00
if (isset($response['errors'])) {
$error = implode("\n", $response['errors']);
error_log($date .' '. $error . "\n", 3, $this->log);
2016-01-29 18:04:48 +03:00
}
}
return $response;
} catch (CurlException $e) {
error_log($date . " [$method] " . $e->getMessage() . "\n", 3, $this->log);
2016-01-29 18:04:48 +03:00
return false;
} catch (InvalidJsonException $e) {
error_log($date . " [$method] " . $e->getMessage() . "\n", 3, $this->log);
2016-01-29 18:04:48 +03:00
return false;
}
}
}