Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
100.00% |
1 / 1 |
|
100.00% |
6 / 6 |
CRAP | |
100.00% |
46 / 46 |
| Serializer | |
100.00% |
1 / 1 |
|
100.00% |
6 / 6 |
9 | |
100.00% |
46 / 46 |
| __construct( JMSSerializerInterface $serializer, GroupsSpecifierInterface $groupsSpecifier, LoggerInterface $logger ) | |
100.00% |
1 / 1 |
1 | |
100.00% |
4 / 4 |
|||
| toJson( SerializableInterface $serializable, SerializationContext $serializationContext = null ) | |
100.00% |
1 / 1 |
2 | |
100.00% |
11 / 11 |
|||
| fromJson($data, $type) | |
100.00% |
1 / 1 |
2 | |
100.00% |
13 / 13 |
|||
| getSerializationContext( SerializableInterface $serializable, SerializationContext $serializationContext ) | |
100.00% |
1 / 1 |
2 | |
100.00% |
6 / 6 |
|||
| logSerializationResult( SerializableInterface $serializable, $result ) | |
100.00% |
1 / 1 |
1 | |
100.00% |
6 / 6 |
|||
| logException(\Exception $exception) | |
100.00% |
1 / 1 |
1 | |
100.00% |
6 / 6 |
|||
| <?php | |
| /** | |
| * @author Krzysztof Gzocha <krzysztof.gzocha@xsolve.pl> | |
| */ | |
| namespace Team3\PayU\Serializer; | |
| use JMS\Serializer\SerializationContext; | |
| use JMS\Serializer\SerializerInterface as JMSSerializerInterface; | |
| use Psr\Log\LoggerInterface; | |
| use Team3\PayU\Order\Model\OrderInterface; | |
| use Team3\PayU\Serializer\SerializerInterface as PayUSerializerInterface; | |
| /** | |
| * {@inheritdoc} | |
| * | |
| * Class Serializer | |
| * @package Team3\PayU\Serializer | |
| */ | |
| class Serializer implements PayUSerializerInterface | |
| { | |
| /** | |
| * @var JMSSerializerInterface | |
| */ | |
| protected $serializer; | |
| /** | |
| * @var GroupsSpecifierInterface | |
| */ | |
| protected $groupsSpecifier; | |
| /** | |
| * @var LoggerInterface | |
| */ | |
| protected $logger; | |
| /** | |
| * @param JMSSerializerInterface $serializer | |
| * @param GroupsSpecifierInterface $groupsSpecifier | |
| * @param LoggerInterface $logger | |
| */ | |
| public function __construct( | |
| JMSSerializerInterface $serializer, | |
| GroupsSpecifierInterface $groupsSpecifier, | |
| LoggerInterface $logger | |
| ) { | |
| $this->serializer = $serializer; | |
| $this->groupsSpecifier = $groupsSpecifier; | |
| $this->logger = $logger; | |
| } | |
| /** | |
| * @param SerializableInterface $serializable | |
| * @param SerializationContext $serializationContext | |
| * | |
| * @return string | |
| */ | |
| public function toJson( | |
| SerializableInterface $serializable, | |
| SerializationContext $serializationContext = null | |
| ) { | |
| if (null == $serializationContext) { | |
| $serializationContext = new SerializationContext(); | |
| } | |
| $serializationResult = $this | |
| ->serializer | |
| ->serialize( | |
| $serializable, | |
| 'json', | |
| $this->getSerializationContext($serializable, $serializationContext) | |
| ); | |
| $this->logSerializationResult($serializable, $serializationResult); | |
| return $serializationResult; | |
| } | |
| /** | |
| * @param string $data | |
| * @param string $type | |
| * | |
| * @return array|object | |
| * @throws SerializerException | |
| */ | |
| public function fromJson($data, $type) | |
| { | |
| try { | |
| $result = $this | |
| ->serializer | |
| ->deserialize( | |
| $data, | |
| $type, | |
| 'json' | |
| ); | |
| } catch (\Exception $exception) { | |
| $adaptedException = new SerializerException( | |
| $exception->getMessage(), | |
| $exception->getCode(), | |
| $exception | |
| ); | |
| $this->logException($adaptedException); | |
| throw $adaptedException; | |
| } | |
| return $result; | |
| } | |
| /** | |
| * @param SerializableInterface $serializable | |
| * @param SerializationContext $serializationContext | |
| * | |
| * @return SerializationContext | |
| */ | |
| private function getSerializationContext( | |
| SerializableInterface $serializable, | |
| SerializationContext $serializationContext | |
| ) { | |
| if ($serializable instanceof OrderInterface) { | |
| $serializationContext->setGroups( | |
| $this->groupsSpecifier->specifyGroups($serializable) | |
| ); | |
| } | |
| return $serializationContext; | |
| } | |
| /** | |
| * @param SerializableInterface $serializable | |
| * @param string $result | |
| */ | |
| private function logSerializationResult( | |
| SerializableInterface $serializable, | |
| $result | |
| ) { | |
| $this | |
| ->logger | |
| ->debug(sprintf( | |
| 'Serializable object %s was serialized to "%s"', | |
| get_class($serializable), | |
| $result | |
| )); | |
| } | |
| /** | |
| * @param \Exception $exception | |
| */ | |
| private function logException(\Exception $exception) | |
| { | |
| $this->logger->error(sprintf( | |
| '%s exception occurred on deserialization with message "%s"', | |
| get_class($exception), | |
| $exception->getMessage() | |
| )); | |
| } | |
| } |