12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Braintree\Gateway\Http\Client;
- use Magento\Braintree\Model\Adapter\BraintreeAdapterFactory;
- use Magento\Payment\Gateway\Http\ClientException;
- use Magento\Payment\Gateway\Http\ClientInterface;
- use Magento\Payment\Gateway\Http\TransferInterface;
- use Magento\Payment\Model\Method\Logger;
- use Psr\Log\LoggerInterface;
- /**
- * Class AbstractTransaction
- */
- abstract class AbstractTransaction implements ClientInterface
- {
- /**
- * @var LoggerInterface
- */
- protected $logger;
- /**
- * @var Logger
- */
- protected $customLogger;
- /**
- * @var BraintreeAdapterFactory
- */
- protected $adapterFactory;
- /**
- * Constructor
- *
- * @param LoggerInterface $logger
- * @param Logger $customLogger
- * @param BraintreeAdapterFactory $adapterFactory
- */
- public function __construct(LoggerInterface $logger, Logger $customLogger, BraintreeAdapterFactory $adapterFactory)
- {
- $this->logger = $logger;
- $this->customLogger = $customLogger;
- $this->adapterFactory = $adapterFactory;
- }
- /**
- * @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;
- }
- /**
- * Process http request
- * @param array $data
- * @return \Braintree\Result\Error|\Braintree\Result\Successful
- */
- abstract protected function process(array $data);
- }
|