3 * Zend Framework (http://framework.zend.com/)
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
6 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
7 * @license http://framework.zend.com/license/new-bsd New BSD License
10 namespace Zend\Stdlib\Hydrator
;
12 use Zend\Stdlib\Exception
;
14 class ArraySerializable
extends AbstractHydrator
17 * Extract values from the provided object
19 * Extracts values via the object's getArrayCopy() method.
21 * @param object $object
23 * @throws Exception\BadMethodCallException for an $object not implementing getArrayCopy()
25 public function extract($object)
27 if (!is_callable(array($object, 'getArrayCopy'))) {
28 throw new Exception\
BadMethodCallException(
29 sprintf('%s expects the provided object to implement getArrayCopy()', __METHOD__
)
33 $data = $object->getArrayCopy();
34 $filter = $this->getFilter();
36 foreach ($data as $name => $value) {
37 if (!$filter->filter($name)) {
41 $extractedName = $this->extractName($name, $object);
42 // replace the original key with extracted, if differ
43 if ($extractedName !== $name) {
45 $name = $extractedName;
47 $data[$name] = $this->extractValue($name, $value, $object);
56 * Hydrates an object by passing $data to either its exchangeArray() or
60 * @param object $object
62 * @throws Exception\BadMethodCallException for an $object not implementing exchangeArray() or populate()
64 public function hydrate(array $data, $object)
66 $replacement = array();
67 foreach ($data as $key => $value) {
68 $name = $this->hydrateName($key, $data);
69 $replacement[$name] = $this->hydrateValue($name, $value, $data);
72 if (is_callable(array($object, 'exchangeArray'))) {
73 $object->exchangeArray($replacement);
74 } elseif (is_callable(array($object, 'populate'))) {
75 $object->populate($replacement);
77 throw new Exception\
BadMethodCallException(
78 sprintf('%s expects the provided object to implement exchangeArray() or populate()', __METHOD__
)