/** * 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; }
/** * {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; }
/** * 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; }
/** * 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; }
/** * @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; }
/** * Log debug data to file * * @param array $debugData * @return void */ protected function _debug($debugData) { $this->logger->debug($debugData, $this->getDebugReplacePrivateDataKeys(), $this->getDebugFlag()); }
/** * 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; }