public function run() { /* $data = array( 'project_id' => 'WRHS', 'service' => 'cargoitem', 'method' => 'import', 'request' => '' ); $logAddResult = \Model\LogXmlrpcServerModel::getInstance()->add($data); print_r($logAddResult->getErrors()); die; */ $logAddResult = null; $method = null; ob_start(); $request = $this->getRequest(); try { $xmlRequest = $request->getRawBody(); if (empty($xmlRequest)) { $xmlRequest = '<?xml version="1.0" encoding="UTF-8"?>' . "\n" . '<methodCall><methodName>cargoitem.import</methodName><params><param><value><struct><member><name>item_fid</name><value><string>EBTD_P654326</string></value></member><member><name>source_id</name><value><string>EBTD</string></value></member><member><name>warehouse_code</name><value><string>usa</string></value></member><member><name>country_code</name><value><string>RU</string></value></member><member><name>delivery_type</name><value><string>SPSR</string></value></member><member><name>weight</name><value><int>11386</int></value></member><member><name>_cargo_item_declaration</name><value><array><data><value><struct><member><name>name</name><value><string>Test t-short</string></value></member><member><name>article</name><value><string>123312a</string></value></member><member><name>color</name><value><string>white</string></value></member><member><name>size</name><value><string>xxx-large</string></value></member><member><name>count</name><value><int>2</int></value></member><member><name>weight</name><value><int>11386</int></value></member><member><name>shop</name><value><string>amazon.com</string></value></member><member><name>url</name><value><string>http://amazon.com/goods/1?id2</string></value></member><member><name>price</name><value><double>123.40000000000001</double></value></member><member><name>commission</name><value><double>12.4</double></value></member><member><name>means_of_payment</name><value><string>visa*342</string></value></member><member><name>category</name><value><string>cloting</string></value></member><member><name>descr</name><value><string>Simple t-short</string></value></member></struct></value><value><struct><member><name>name</name><value><string>Test t-short 2</string></value></member><member><name>article</name><value><string>123313b</string></value></member><member><name>color</name><value><string>white</string></value></member><member><name>size</name><value><string>xxx-large</string></value></member><member><name>count</name><value><int>2</int></value></member><member><name>weight</name><value><int>11386</int></value></member><member><name>shop</name><value><string>amazon.com</string></value></member><member><name>url</name><value><string>http://amazon.com/goods/1?id2</string></value></member><member><name>price</name><value><double>123.40000000000001</double></value></member><member><name>commission</name><value><double>12.4</double></value></member><member><name>means_of_payment</name><value><string>visa*342</string></value></member><member><name>category</name><value><string>cloting</string></value></member><member><name>descr</name><value><string>Simple t-short</string></value></member></struct></value></data></array></value></member></struct></value></param></params></methodCall>'; } $parts = null; if (preg_match("#\\<methodName\\>\\s*([a-z0-9_]+)\\.([a-z0-9_]+)\\s*\\<\\/methodName\\>#is", $xmlRequest, $parts)) { $method = @$parts[1] . '.' . @$parts[2]; } if (strtolower($method) == 'system.fake') { // don't execute fake request throw new \Exception('Fake request'); } $key = $this->getRequest()->getQuery('key'); $project = \Model\ProjectModel::getInstance()->getByKey($key); if ($project->exists()) { BaseService::setProject($project); } $logRequest = !in_array(strtolower($method), self::$_notLoggingMethods); if ($logRequest && $method) { $data = array('project_id' => $project->getId(), 'service' => $parts[1], 'method' => $parts[2], 'request' => !in_array(strtolower($method), self::$_notLoggingRequestMethods) ? $xmlRequest : self::$_emptyXmlRequest); $logAddResult = \Model\LogXmlrpcServerModel::getInstance()->add($data); //$a = $logAddResult instanceof \Model\Result\Result; } $response = $this->server->handle(); } catch (\Exception $ex) { $response = (string) $this->server->fault('Server error', 1500); echo "\n\nEXCEPTION: " . $ex->getMessage() . "\n"; echo $ex->getTraceAsString() . "\n\n"; } $output = ob_get_contents(); ob_end_clean(); ob_start(); try { if ($logAddResult instanceof \Model\Result\Result && $logAddResult->getResult()) { $logId = $logAddResult->getResult(); $methparts = explode('.', $method); $msec = round((microtime(true) - $this->getTimeStart()) * 1000); $updateCond = \Model\LogXmlrpcServerModel::getInstance()->getCond()->where(array('id' => $logId)); $logXmlrpcServerArray = array('response' => $response, 'output' => $output, 'work_msec' => $msec); if ($msec > 1000) { //\Model\LogXmlrpcServerModel::getInstance()->reconnect(); нужен реконект } $logUpdResult = \Model\LogXmlrpcServerModel::getInstance()->update($logXmlrpcServerArray, $updateCond); if ($logUpdResult->isError()) { echo "\n\nLogXmlrpcServer update failed\n"; echo $logUpdResult->getErrors(true)->toString() . "\n\n"; echo "Output:\n" . $output; } } else { echo "\n\nLogXmlrpcServer add failed\n"; print_r($logAddResult, true); //echo $logAddResult->getErrors(true)->toString() . "\n\n"; echo "Output:\n" . $output; } } catch (\Exception $e) { echo "\n\n" . $e->getMessage() . "\n" . $e->getTraceAsString() . "\n\n"; } $output2 = ob_get_contents(); /* if ($output2) { $file = Zend_Registry::get('dir')->tmp . '/front_services_exception.txt'; @file_put_contents($file, $output2); @chmod($file, 0664); //App_Logger_Db::log($output2, Zend_Log::ERR); } */ ob_end_clean(); // Пишем в логи для xml-rpc сервера echo $response; }