header('Access-Control-Allow-Origin: *');
header('Access-Control-Allow-Headers: Content-Type,Authorization');
header('Access-Control-Allow-Methods: POST,OPTIONS');
header('Access-Control-Max-Age: 1000');
if ($_SERVER['REQUEST_METHOD'] === 'OPTIONS') {
require_once dirname(__FILE__).'/include/func.inc.php';
require_once dirname(__FILE__).'/include/classes/core/CHttpRequest.php';
'application/json-rpc' => 'json-rpc',
'application/json' => 'json-rpc',
'application/jsonrequest' => 'json-rpc'
$http_request = new CHttpRequest();
$content_type = $http_request->header('Content-Type');
$content_type = explode(';', $content_type);
$content_type = $content_type[0];
if (!isset($allowed_content[$content_type])) {
header('HTTP/1.0 412 Precondition Failed');
require_once dirname(__FILE__).'/include/classes/core/APP.php';
header('Content-Type: application/json');
$data = $http_request->body();
APP::getInstance()->run(APP::EXEC_MODE_API);
$apiClient = API::getWrapper()->getClient();
$jsonRpc = new CJsonRpc($apiClient, $data);
echo $jsonRpc->execute($http_request);
$json_data = json_decode($data, true);
if (array_key_exists('id', $json_data)) {
$user_type = CUser::$userData === null ? USER_TYPE_ZABBIX_USER : CUser::$userData['type'];
$data = ($e instanceof DBException && $user_type != USER_TYPE_SUPER_ADMIN && $e->getCode() != DB::INIT_ERROR)
? _('System error occurred. Please contact Zabbix administrator.')
'message' => _('Internal error.'),