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() | |
| )); | |
| } | |
| } |