-
Notifications
You must be signed in to change notification settings - Fork 230
/
DocumentsToArrayTransformer.php
97 lines (80 loc) · 2.76 KB
/
DocumentsToArrayTransformer.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Bundle\DoctrineMongoDBBundle\Form\DataTransformer;
use Symfony\Bundle\DoctrineMongoDBBundle\Form\ChoiceList\DocumentChoiceList;
use Symfony\Component\Form\Exception\UnexpectedTypeException;
use Symfony\Component\Form\Exception\TransformationFailedException;
use Symfony\Component\Form\DataTransformerInterface;
use Doctrine\Common\Collections\Collection;
use Doctrine\Common\Collections\ArrayCollection;
/**
* Transforms collections into arrays of ids
*
* @author Thibault Duplessis <thibault.duplessis@gmail.com>
*/
class DocumentsToArrayTransformer implements DataTransformerInterface
{
private $choiceList;
public function __construct(DocumentChoiceList $choiceList)
{
$this->choiceList = $choiceList;
}
/**
* Transforms documents into choice keys
*
* @param Collection|object $collection A collection of documents, a single document or
* NULL
* @return mixed An array of choice keys, a single key or NULL
*/
public function transform($collection)
{
if (null === $collection) {
return array();
}
if (!($collection instanceof Collection)) {
throw new UnexpectedTypeException($collection, 'Doctrine\Common\Collection\Collection');
}
$array = array();
foreach ($collection as $document) {
$array[] = $this->choiceList->getIdentifierValue($document);
}
return $array;
}
/**
* Transforms choice keys into documents
*
* @param mixed $keys An array of keys, a single key or NULL
* @return Collection|object A collection of documents, a single document
* or NULL
*/
public function reverseTransform($keys)
{
$collection = new ArrayCollection();
if ('' === $keys || null === $keys) {
return $collection;
}
if (!is_array($keys)) {
throw new UnexpectedTypeException($keys, 'array');
}
$notFound = array();
// optimize this into a SELECT WHERE IN query
foreach ($keys as $key) {
if ($document = $this->choiceList->getDocument($key)) {
$collection->add($document);
} else {
$notFound[] = $key;
}
}
if (count($notFound) > 0) {
throw new TransformationFailedException(sprintf('The documents with keys "%s" could not be found', implode('", "', $notFound)));
}
return $collection;
}
}