コード例 #1
0
ファイル: Server.php プロジェクト: slkxmail/App
 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;
 }