Пример #1
0
 /**
  * Returns gateway response data object
  *
  * @param array $gatewayTransactionResponse
  * @return Object
  */
 public function getResponseObject($gatewayTransactionResponse)
 {
     $response = new DataObject();
     $response = $this->transparent->mapGatewayResponse($gatewayTransactionResponse, $response);
     $this->logger->debug($gatewayTransactionResponse, (array) $this->transparent->getDebugReplacePrivateDataKeys(), (bool) $this->transparent->getDebugFlag());
     return $response;
 }
Пример #2
0
 /**
  * {inheritdoc}
  */
 public function placeRequest(TransferInterface $transferObject)
 {
     $log = ['request' => $transferObject->getBody(), 'request_uri' => $transferObject->getUri()];
     $result = [];
     /** @var ZendClient $client */
     $client = $this->clientFactory->create();
     $client->setConfig($transferObject->getClientConfig());
     $client->setMethod($transferObject->getMethod());
     switch ($transferObject->getMethod()) {
         case \Zend_Http_Client::GET:
             $client->setParameterGet($transferObject->getBody());
             break;
         case \Zend_Http_Client::POST:
             $client->setParameterPost($transferObject->getBody());
             break;
         default:
             throw new \LogicException(sprintf('Unsupported HTTP method %s', $transferObject->getMethod()));
     }
     $client->setHeaders($transferObject->getHeaders());
     $client->setUrlEncodeBody($transferObject->shouldEncode());
     $client->setUri($transferObject->getUri());
     try {
         $response = $client->request();
         $result = $this->converter ? $this->converter->convert($response->getBody()) : [$response->getBody()];
         $log['response'] = $result;
     } catch (\Zend_Http_Client_Exception $e) {
         throw new \Magento\Payment\Gateway\Http\ClientException(__($e->getMessage()));
     } catch (\Magento\Payment\Gateway\Http\ConverterException $e) {
         throw $e;
     } finally {
         $this->logger->debug($log);
     }
     return $result;
 }
Пример #3
0
 /**
  * Post request into gateway
  *
  * @param DataObject $request
  * @param ConfigInterface $config
  *
  * @return DataObject
  * @throws \Zend_Http_Client_Exception
  */
 public function postRequest(DataObject $request, ConfigInterface $config)
 {
     $result = new DataObject();
     $clientConfig = ['maxredirects' => 5, 'timeout' => 30, 'verifypeer' => $config->getValue('verify_peer')];
     if ($config->getValue('use_proxy')) {
         $clientConfig['proxy'] = $config->getValue('proxy_host') . ':' . $config->getValue('proxy_port');
         $clientConfig['httpproxytunnel'] = true;
         $clientConfig['proxytype'] = CURLPROXY_HTTP;
     }
     /** @var ZendClient $client */
     $client = $this->httpClientFactory->create();
     $client->setUri((bool) $config->getValue('sandbox_flag') ? $config->getValue('transaction_url_test_mode') : $config->getValue('transaction_url'));
     $client->setConfig($clientConfig);
     $client->setMethod(\Zend_Http_Client::POST);
     $client->setParameterPost($request->getData());
     $client->setHeaders(['X-VPS-VIT-CLIENT-CERTIFICATION-ID' => '33baf5893fc2123d8b191d2d011b7fdc', 'X-VPS-Request-ID' => $this->mathRandom->getUniqueHash(), 'X-VPS-CLIENT-TIMEOUT' => 45]);
     $client->setUrlEncodeBody(false);
     try {
         $response = $client->request();
         $responseArray = [];
         parse_str(strstr($response->getBody(), 'RESULT'), $responseArray);
         $result->setData(array_change_key_case($responseArray, CASE_LOWER));
         $result->setData('result_code', $result->getData('result'));
     } catch (\Zend_Http_Client_Exception $e) {
         $result->addData(['response_code' => -1, 'response_reason_code' => $e->getCode(), 'response_reason_text' => $e->getMessage()]);
         throw $e;
     } finally {
         $this->logger->debug(['request' => $request->getData(), 'result' => $result->getData()], (array) $config->getValue('getDebugReplacePrivateDataKeys'), (bool) $config->getValue('debug'));
     }
     return $result;
 }
Пример #4
0
 /**
  * Places request to gateway. Returns result as ENV array
  *
  * @param TransferInterface $transferObject
  * @return array
  * @throws \Magento\Payment\Gateway\Http\ClientException
  * @throws \Magento\Payment\Gateway\Http\ConverterException
  * @throws \Exception
  */
 public function placeRequest(TransferInterface $transferObject)
 {
     $this->logger->debug(['request' => $transferObject->getBody()]);
     $client = $this->clientFactory->create($transferObject->getClientConfig()['wsdl'], ['trace' => true]);
     try {
         $client->__setSoapHeaders($transferObject->getHeaders());
         $response = $client->__soapCall($transferObject->getMethod(), [$transferObject->getBody()]);
         $result = $this->converter ? $this->converter->convert($response) : [$response];
         $this->logger->debug(['response' => $result]);
     } catch (\Exception $e) {
         $this->logger->debug(['trace' => $client->__getLastRequest()]);
         throw $e;
     }
     return $result;
 }
Пример #5
0
 /**
  * @inheritdoc
  */
 public function placeRequest(TransferInterface $transferObject)
 {
     $data = $transferObject->getBody();
     $log = ['request' => $data, 'client' => static::class];
     $response['object'] = [];
     try {
         $response['object'] = $this->process($data);
     } catch (\Exception $e) {
         $message = __($e->getMessage() ?: 'Sorry, but something went wrong');
         $this->logger->critical($message);
         throw new ClientException($message);
     } finally {
         $log['response'] = (array) $response['object'];
         $this->customLogger->debug($log);
     }
     return $response;
 }
Пример #6
0
 /**
  * Log debug data to file
  *
  * @param array $debugData
  * @return void
  */
 protected function _debug($debugData)
 {
     $this->logger->debug($debugData, $this->getDebugReplacePrivateDataKeys(), $this->getDebugFlag());
 }
Пример #7
0
 /**
  * Log debug data to file
  *
  * @param mixed $debugData
  * @return void
  */
 protected function _debug($debugData)
 {
     $this->customLogger->debug($debugData, (array) $this->getDebugReplacePrivateDataKeys(), (bool) $this->getDebugFlag());
 }
 /**
  * Places request to gateway. Returns result as ENV array
  *
  * @param TransferInterface $transferObject
  * @return array
  */
 public function placeRequest(TransferInterface $transferObject)
 {
     $response = $this->generateResponseForCode($this->getResultCode($transferObject));
     $this->logger->debug(['request' => $transferObject->getBody(), 'response' => $response]);
     return $response;
 }