Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
4 / 4
CRAP
100.00% covered (success)
100.00%
27 / 27
ClientAdapter
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
4 / 4
4
100.00% covered (success)
100.00%
27 / 27
 __construct( SenderInterface $sender, CurlRequestBuilderInterface $requestBuilder, LoggerInterface $logger )
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
4 / 4
 sendRequest( ConfigurationInterface $configuration, PayURequestInterface $request )
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
5 / 5
 logRequest(RequestInterface $request)
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
8 / 8
 logResponse( RequestInterface $request, Response $response )
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
10 / 10
<?php
/**
 * @author Krzysztof Gzocha <krzysztof.gzocha@xsolve.pl>
 */
namespace Team3\PayU\Communication;
use Buzz\Client\ClientInterface;
use Buzz\Message\RequestInterface;
use Team3\PayU\Communication\ClientInterface as PayUClientInterface;
use Buzz\Exception\ClientException;
use Buzz\Message\Response;
use Psr\Log\LoggerInterface;
use Team3\PayU\Communication\CurlRequestBuilder\CurlRequestBuilderInterface;
use Team3\PayU\Communication\Request\PayURequestInterface;
use Team3\PayU\Communication\Sender\Sender;
use Team3\PayU\Communication\Sender\SenderInterface;
use Team3\PayU\Configuration\ConfigurationInterface;
/**
 * {@inheritdoc}
 *
 * Class ClientAdapter
 * @package Team3\PayU\Communication
 */
class ClientAdapter implements PayUClientInterface
{
    /**
     * @var SenderInterface
     */
    private $sender;
    /**
     * @var CurlRequestBuilderInterface
     */
    private $requestBuilder;
    /**
     * @var LoggerInterface
     */
    private $logger;
    /**
     * @param SenderInterface             $sender
     * @param CurlRequestBuilderInterface $requestBuilder
     * @param LoggerInterface             $logger
     */
    public function __construct(
        SenderInterface $sender,
        CurlRequestBuilderInterface $requestBuilder,
        LoggerInterface $logger
    ) {
        $this->sender = $sender;
        $this->requestBuilder = $requestBuilder;
        $this->logger = $logger;
    }
    /**
     * @param ConfigurationInterface $configuration
     * @param PayURequestInterface   $request
     *
     * @return Response
     * @throws ClientException
     */
    public function sendRequest(
        ConfigurationInterface $configuration,
        PayURequestInterface $request
    ) {
        $curlRequest = $this->requestBuilder->build($configuration, $request);
        $this->logRequest($curlRequest);
        $response = $this->sender->send($curlRequest, $configuration->getCredentials());
        $this->logResponse($curlRequest, $response);
        return $response;
    }
    /**
     * @param RequestInterface $request
     */
    private function logRequest(RequestInterface $request)
    {
        $this
            ->logger
            ->debug(sprintf(
                'Sending request to host:%s resource:%s with content "%s"',
                $request->getHost(),
                $request->getResource(),
                $request->getContent()
            ));
    }
    /**
     * @param RequestInterface $request
     * @param Response         $response
     */
    private function logResponse(
        RequestInterface $request,
        Response $response
    ) {
        $this
            ->logger
            ->debug(sprintf(
                'Request to %s%s with content "%s" was send and response with content "%s" and status %d received',
                $request->getHost(),
                $request->getResource(),
                $request->getContent(),
                $response->getContent(),
                $response->getStatusCode()
            ));
    }
}