YamlExporter.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. <?php
  2. /*
  3. * $Id$
  4. *
  5. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  6. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  7. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  8. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  9. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  10. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  11. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  12. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  13. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  14. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  15. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  16. *
  17. * This software consists of voluntary contributions made by many individuals
  18. * and is licensed under the LGPL. For more information, see
  19. * <http://www.doctrine-project.org>.
  20. */
  21. namespace Doctrine\ORM\Tools\Export\Driver;
  22. use Doctrine\ORM\Mapping\ClassMetadataInfo;
  23. /**
  24. * ClassMetadata exporter for Doctrine YAML mapping files
  25. *
  26. * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
  27. * @link www.doctrine-project.org
  28. * @since 2.0
  29. * @version $Revision$
  30. * @author Jonathan Wage <jonwage@gmail.com>
  31. */
  32. class YamlExporter extends AbstractExporter
  33. {
  34. protected $_extension = '.dcm.yml';
  35. /**
  36. * Converts a single ClassMetadata instance to the exported format
  37. * and returns it
  38. *
  39. * TODO: Should this code be pulled out in to a toArray() method in ClassMetadata
  40. *
  41. * @param ClassMetadataInfo $metadata
  42. * @return mixed $exported
  43. */
  44. public function exportClassMetadata(ClassMetadataInfo $metadata)
  45. {
  46. $array = array();
  47. if ($metadata->isMappedSuperclass) {
  48. $array['type'] = 'mappedSuperclass';
  49. } else {
  50. $array['type'] = 'entity';
  51. }
  52. $array['table'] = $metadata->table['name'];
  53. if (isset($metadata->table['schema'])) {
  54. $array['schema'] = $metadata->table['schema'];
  55. }
  56. $inheritanceType = $metadata->inheritanceType;
  57. if ($inheritanceType !== ClassMetadataInfo::INHERITANCE_TYPE_NONE) {
  58. $array['inheritanceType'] = $this->_getInheritanceTypeString($inheritanceType);
  59. }
  60. if ($column = $metadata->discriminatorColumn) {
  61. $array['discriminatorColumn'] = $column;
  62. }
  63. if ($map = $metadata->discriminatorMap) {
  64. $array['discriminatorMap'] = $map;
  65. }
  66. if ($metadata->changeTrackingPolicy !== ClassMetadataInfo::CHANGETRACKING_DEFERRED_IMPLICIT) {
  67. $array['changeTrackingPolicy'] = $this->_getChangeTrackingPolicyString($metadata->changeTrackingPolicy);
  68. }
  69. if (isset($metadata->table['indexes'])) {
  70. $array['indexes'] = $metadata->table['indexes'];
  71. }
  72. if ($metadata->customRepositoryClassName) {
  73. $array['repositoryClass'] = $metadata->customRepositoryClassName;
  74. }
  75. if (isset($metadata->table['uniqueConstraints'])) {
  76. $array['uniqueConstraints'] = $metadata->table['uniqueConstraints'];
  77. }
  78. $fieldMappings = $metadata->fieldMappings;
  79. $ids = array();
  80. foreach ($fieldMappings as $name => $fieldMapping) {
  81. $fieldMapping['column'] = $fieldMapping['columnName'];
  82. unset(
  83. $fieldMapping['columnName'],
  84. $fieldMapping['fieldName']
  85. );
  86. if ($fieldMapping['column'] == $name) {
  87. unset($fieldMapping['column']);
  88. }
  89. if (isset($fieldMapping['id']) && $fieldMapping['id']) {
  90. $ids[$name] = $fieldMapping;
  91. unset($fieldMappings[$name]);
  92. continue;
  93. }
  94. $fieldMappings[$name] = $fieldMapping;
  95. }
  96. if ( ! $metadata->isIdentifierComposite && $idGeneratorType = $this->_getIdGeneratorTypeString($metadata->generatorType)) {
  97. $ids[$metadata->getSingleIdentifierFieldName()]['generator']['strategy'] = $idGeneratorType;
  98. }
  99. if ($ids) {
  100. $array['fields'] = $ids;
  101. }
  102. if ($fieldMappings) {
  103. if ( ! isset($array['fields'])) {
  104. $array['fields'] = array();
  105. }
  106. $array['fields'] = array_merge($array['fields'], $fieldMappings);
  107. }
  108. $associations = array();
  109. foreach ($metadata->associationMappings as $name => $associationMapping) {
  110. $cascade = array();
  111. if ($associationMapping['isCascadeRemove']) {
  112. $cascade[] = 'remove';
  113. }
  114. if ($associationMapping['isCascadePersist']) {
  115. $cascade[] = 'persist';
  116. }
  117. if ($associationMapping['isCascadeRefresh']) {
  118. $cascade[] = 'refresh';
  119. }
  120. if ($associationMapping['isCascadeMerge']) {
  121. $cascade[] = 'merge';
  122. }
  123. if ($associationMapping['isCascadeDetach']) {
  124. $cascade[] = 'detach';
  125. }
  126. if (count($cascade) === 5) {
  127. $cascade = array('all');
  128. }
  129. $associationMappingArray = array(
  130. 'targetEntity' => $associationMapping['targetEntity'],
  131. 'cascade' => $cascade,
  132. );
  133. if ($associationMapping['type'] & ClassMetadataInfo::TO_ONE) {
  134. $joinColumns = $associationMapping['joinColumns'];
  135. $newJoinColumns = array();
  136. foreach ($joinColumns as $joinColumn) {
  137. $newJoinColumns[$joinColumn['name']]['referencedColumnName'] = $joinColumn['referencedColumnName'];
  138. if (isset($joinColumn['onDelete'])) {
  139. $newJoinColumns[$joinColumn['name']]['onDelete'] = $joinColumn['onDelete'];
  140. }
  141. }
  142. $oneToOneMappingArray = array(
  143. 'mappedBy' => $associationMapping['mappedBy'],
  144. 'inversedBy' => $associationMapping['inversedBy'],
  145. 'joinColumns' => $newJoinColumns,
  146. 'orphanRemoval' => $associationMapping['orphanRemoval'],
  147. );
  148. $associationMappingArray = array_merge($associationMappingArray, $oneToOneMappingArray);
  149. if ($associationMapping['type'] & ClassMetadataInfo::ONE_TO_ONE) {
  150. $array['oneToOne'][$name] = $associationMappingArray;
  151. } else {
  152. $array['manyToOne'][$name] = $associationMappingArray;
  153. }
  154. } else if ($associationMapping['type'] == ClassMetadataInfo::ONE_TO_MANY) {
  155. $oneToManyMappingArray = array(
  156. 'mappedBy' => $associationMapping['mappedBy'],
  157. 'inversedBy' => $associationMapping['inversedBy'],
  158. 'orphanRemoval' => $associationMapping['orphanRemoval'],
  159. 'orderBy' => isset($associationMapping['orderBy']) ? $associationMapping['orderBy'] : null
  160. );
  161. $associationMappingArray = array_merge($associationMappingArray, $oneToManyMappingArray);
  162. $array['oneToMany'][$name] = $associationMappingArray;
  163. } else if ($associationMapping['type'] == ClassMetadataInfo::MANY_TO_MANY) {
  164. $manyToManyMappingArray = array(
  165. 'mappedBy' => $associationMapping['mappedBy'],
  166. 'inversedBy' => $associationMapping['inversedBy'],
  167. 'joinTable' => isset($associationMapping['joinTable']) ? $associationMapping['joinTable'] : null,
  168. 'orderBy' => isset($associationMapping['orderBy']) ? $associationMapping['orderBy'] : null
  169. );
  170. $associationMappingArray = array_merge($associationMappingArray, $manyToManyMappingArray);
  171. $array['manyToMany'][$name] = $associationMappingArray;
  172. }
  173. }
  174. if (isset($metadata->lifecycleCallbacks)) {
  175. $array['lifecycleCallbacks'] = $metadata->lifecycleCallbacks;
  176. }
  177. return \Symfony\Component\Yaml\Yaml::dump(array($metadata->name => $array), 10);
  178. }
  179. }