Chris@0
|
1 <?php
|
Chris@0
|
2
|
Chris@0
|
3 /*
|
Chris@0
|
4 * This file is part of the Symfony package.
|
Chris@0
|
5 *
|
Chris@0
|
6 * (c) Fabien Potencier <fabien@symfony.com>
|
Chris@0
|
7 *
|
Chris@0
|
8 * For the full copyright and license information, please view the LICENSE
|
Chris@0
|
9 * file that was distributed with this source code.
|
Chris@0
|
10 */
|
Chris@0
|
11
|
Chris@0
|
12 namespace Symfony\Component\Serializer\Normalizer;
|
Chris@0
|
13
|
Chris@0
|
14 use Symfony\Component\Serializer\SerializerAwareInterface;
|
Chris@0
|
15 use Symfony\Component\Serializer\SerializerAwareTrait;
|
Chris@0
|
16
|
Chris@0
|
17 /**
|
Chris@0
|
18 * @author Jordi Boggiano <j.boggiano@seld.be>
|
Chris@0
|
19 */
|
Chris@0
|
20 class CustomNormalizer implements NormalizerInterface, DenormalizerInterface, SerializerAwareInterface
|
Chris@0
|
21 {
|
Chris@0
|
22 use SerializerAwareTrait;
|
Chris@0
|
23
|
Chris@0
|
24 /**
|
Chris@0
|
25 * {@inheritdoc}
|
Chris@0
|
26 */
|
Chris@0
|
27 public function normalize($object, $format = null, array $context = array())
|
Chris@0
|
28 {
|
Chris@0
|
29 return $object->normalize($this->serializer, $format, $context);
|
Chris@0
|
30 }
|
Chris@0
|
31
|
Chris@0
|
32 /**
|
Chris@0
|
33 * {@inheritdoc}
|
Chris@0
|
34 */
|
Chris@0
|
35 public function denormalize($data, $class, $format = null, array $context = array())
|
Chris@0
|
36 {
|
Chris@0
|
37 $object = new $class();
|
Chris@0
|
38 $object->denormalize($this->serializer, $data, $format, $context);
|
Chris@0
|
39
|
Chris@0
|
40 return $object;
|
Chris@0
|
41 }
|
Chris@0
|
42
|
Chris@0
|
43 /**
|
Chris@0
|
44 * Checks if the given class implements the NormalizableInterface.
|
Chris@0
|
45 *
|
Chris@0
|
46 * @param mixed $data Data to normalize
|
Chris@0
|
47 * @param string $format The format being (de-)serialized from or into
|
Chris@0
|
48 *
|
Chris@0
|
49 * @return bool
|
Chris@0
|
50 */
|
Chris@0
|
51 public function supportsNormalization($data, $format = null)
|
Chris@0
|
52 {
|
Chris@0
|
53 return $data instanceof NormalizableInterface;
|
Chris@0
|
54 }
|
Chris@0
|
55
|
Chris@0
|
56 /**
|
Chris@0
|
57 * Checks if the given class implements the NormalizableInterface.
|
Chris@0
|
58 *
|
Chris@0
|
59 * @param mixed $data Data to denormalize from
|
Chris@0
|
60 * @param string $type The class to which the data should be denormalized
|
Chris@0
|
61 * @param string $format The format being deserialized from
|
Chris@0
|
62 *
|
Chris@0
|
63 * @return bool
|
Chris@0
|
64 */
|
Chris@0
|
65 public function supportsDenormalization($data, $type, $format = null)
|
Chris@0
|
66 {
|
Chris@0
|
67 if (!class_exists($type)) {
|
Chris@0
|
68 return false;
|
Chris@0
|
69 }
|
Chris@0
|
70
|
Chris@0
|
71 return is_subclass_of($type, 'Symfony\Component\Serializer\Normalizer\DenormalizableInterface');
|
Chris@0
|
72 }
|
Chris@0
|
73 }
|