Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
100.00% |
1 / 1 |
|
100.00% |
6 / 6 |
CRAP | |
100.00% |
34 / 34 |
Encoder | |
100.00% |
1 / 1 |
|
100.00% |
6 / 6 |
8 | |
100.00% |
34 / 34 |
__construct(LoggerInterface $logger) | |
100.00% |
1 / 1 |
1 | |
100.00% |
3 / 3 |
|||
encode($data, AlgorithmInterface $algorithm) | |
100.00% |
1 / 1 |
3 | |
100.00% |
9 / 9 |
|||
addStrategy(EncoderStrategyInterface $strategy) | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
logEncoderResult( EncoderStrategyInterface $encoderStrategy, AlgorithmInterface $algorithm, $inputData, $encoderResult ) | |
100.00% |
1 / 1 |
1 | |
100.00% |
8 / 8 |
|||
buildException(AlgorithmInterface $algorithm) | |
100.00% |
1 / 1 |
1 | |
100.00% |
4 / 4 |
|||
logException(\Exception $exception) | |
100.00% |
1 / 1 |
1 | |
100.00% |
8 / 8 |
<?php | |
/** | |
* @author Krzysztof Gzocha <krzysztof.gzocha@xsolve.pl> | |
*/ | |
namespace Team3\PayU\SignatureCalculator\Encoder; | |
use Psr\Log\LoggerInterface; | |
use Team3\PayU\SignatureCalculator\Encoder\Algorithms\AlgorithmInterface; | |
use Team3\PayU\SignatureCalculator\Encoder\Strategy\EncoderStrategyInterface; | |
/** | |
* {@inheritdoc} | |
* | |
* Class Encoder | |
* @package Team3\PayU\SignatureCalculator\Encoder | |
*/ | |
class Encoder implements EncoderInterface | |
{ | |
/** | |
* @var EncoderStrategyInterface[] | |
*/ | |
private $strategies; | |
/** | |
* @var LoggerInterface | |
*/ | |
private $logger; | |
/** | |
* @param LoggerInterface $logger | |
*/ | |
public function __construct(LoggerInterface $logger) | |
{ | |
$this->strategies = []; | |
$this->logger = $logger; | |
} | |
/** | |
* Will encode single string with given algorithm. | |
* If could not find strategy for this algorithm will throw exception. | |
* | |
* @param string $data | |
* @param AlgorithmInterface $algorithm | |
* | |
* @return string | |
* @throws EncoderException | |
*/ | |
public function encode($data, AlgorithmInterface $algorithm) | |
{ | |
foreach ($this->strategies as $strategy) { | |
if ($strategy->supports($algorithm)) { | |
$result = $strategy->encode($data); | |
$this->logEncoderResult($strategy, $algorithm, $data, $result); | |
return $result; | |
} | |
} | |
$exception = $this->buildException($algorithm); | |
$this->logException($exception); | |
throw $exception; | |
} | |
/** | |
* @param EncoderStrategyInterface $strategy | |
* | |
* @return $this | |
*/ | |
public function addStrategy(EncoderStrategyInterface $strategy) | |
{ | |
$this->strategies[] = $strategy; | |
return $this; | |
} | |
/** | |
* @param EncoderStrategyInterface $encoderStrategy | |
* @param AlgorithmInterface $algorithm | |
* @param string $inputData | |
* @param string $encoderResult | |
*/ | |
private function logEncoderResult( | |
EncoderStrategyInterface $encoderStrategy, | |
AlgorithmInterface $algorithm, | |
$inputData, | |
$encoderResult | |
) { | |
$this | |
->logger | |
->debug(sprintf( | |
'Encoder\'s strategy %s (algorithm: %s) successfully encode data "%s" into "%s"', | |
get_class($encoderStrategy), | |
get_class($algorithm), | |
$inputData, | |
$encoderResult | |
)); | |
} | |
/** | |
* @param AlgorithmInterface $algorithm | |
* | |
* @return EncoderException | |
*/ | |
private function buildException(AlgorithmInterface $algorithm) | |
{ | |
return new EncoderException(sprintf( | |
'None of encoder strategies supports algorithm "%s"', | |
get_class($algorithm) | |
)); | |
} | |
/** | |
* @param \Exception $exception | |
*/ | |
private function logException(\Exception $exception) | |
{ | |
$this | |
->logger | |
->error(sprintf( | |
'%s thrown %s with message "%s"', | |
get_class($this), | |
get_class($exception), | |
$exception->getMessage() | |
)); | |
} | |
} |