ColumnSchema.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\db\pgsql;
  8. use yii\db\ArrayExpression;
  9. use yii\db\ExpressionInterface;
  10. use yii\db\JsonExpression;
  11. /**
  12. * Class ColumnSchema for PostgreSQL database.
  13. *
  14. * @author Dmytro Naumenko <d.naumenko.a@gmail.com>
  15. */
  16. class ColumnSchema extends \yii\db\ColumnSchema
  17. {
  18. /**
  19. * @var int the dimension of array. Defaults to 0, means this column is not an array.
  20. */
  21. public $dimension = 0;
  22. /**
  23. * @var bool whether the column schema should OMIT using JSON support feature.
  24. * You can use this property to make upgrade to Yii 2.0.14 easier.
  25. * Default to `false`, meaning JSON support is enabled.
  26. *
  27. * @since 2.0.14.1
  28. * @deprecated Since 2.0.14.1 and will be removed in 2.1.
  29. */
  30. public $disableJsonSupport = false;
  31. /**
  32. * @var bool whether the column schema should OMIT using PgSQL Arrays support feature.
  33. * You can use this property to make upgrade to Yii 2.0.14 easier.
  34. * Default to `false`, meaning Arrays support is enabled.
  35. *
  36. * @since 2.0.14.1
  37. * @deprecated Since 2.0.14.1 and will be removed in 2.1.
  38. */
  39. public $disableArraySupport = false;
  40. /**
  41. * @var bool whether the Array column value should be unserialized to an [[ArrayExpression]] object.
  42. * You can use this property to make upgrade to Yii 2.0.14 easier.
  43. * Default to `true`, meaning arrays are unserialized to [[ArrayExpression]] objects.
  44. *
  45. * @since 2.0.14.1
  46. * @deprecated Since 2.0.14.1 and will be removed in 2.1.
  47. */
  48. public $deserializeArrayColumnToArrayExpression = true;
  49. /**
  50. * @var string name of associated sequence if column is auto-incremental
  51. * @since 2.0.29
  52. */
  53. public $sequenceName;
  54. /**
  55. * {@inheritdoc}
  56. */
  57. public function dbTypecast($value)
  58. {
  59. if ($value === null) {
  60. return $value;
  61. }
  62. if ($value instanceof ExpressionInterface) {
  63. return $value;
  64. }
  65. if ($this->dimension > 0) {
  66. return $this->disableArraySupport
  67. ? (string) $value
  68. : new ArrayExpression($value, $this->dbType, $this->dimension);
  69. }
  70. if (!$this->disableJsonSupport && in_array($this->dbType, [Schema::TYPE_JSON, Schema::TYPE_JSONB], true)) {
  71. return new JsonExpression($value, $this->dbType);
  72. }
  73. return $this->typecast($value);
  74. }
  75. /**
  76. * {@inheritdoc}
  77. */
  78. public function phpTypecast($value)
  79. {
  80. if ($this->dimension > 0) {
  81. if ($this->disableArraySupport) {
  82. return $value;
  83. }
  84. if (!is_array($value)) {
  85. $value = $this->getArrayParser()->parse($value);
  86. }
  87. if (is_array($value)) {
  88. array_walk_recursive($value, function (&$val, $key) {
  89. $val = $this->phpTypecastValue($val);
  90. });
  91. } elseif ($value === null) {
  92. return null;
  93. }
  94. return $this->deserializeArrayColumnToArrayExpression
  95. ? new ArrayExpression($value, $this->dbType, $this->dimension)
  96. : $value;
  97. }
  98. return $this->phpTypecastValue($value);
  99. }
  100. /**
  101. * Casts $value after retrieving from the DBMS to PHP representation.
  102. *
  103. * @param string|null $value
  104. * @return bool|mixed|null
  105. */
  106. protected function phpTypecastValue($value)
  107. {
  108. if ($value === null) {
  109. return null;
  110. }
  111. switch ($this->type) {
  112. case Schema::TYPE_BOOLEAN:
  113. switch (strtolower($value)) {
  114. case 't':
  115. case 'true':
  116. return true;
  117. case 'f':
  118. case 'false':
  119. return false;
  120. }
  121. return (bool) $value;
  122. case Schema::TYPE_JSON:
  123. return $this->disableJsonSupport ? $value : json_decode($value, true);
  124. }
  125. return parent::phpTypecast($value);
  126. }
  127. /**
  128. * Creates instance of ArrayParser
  129. *
  130. * @return ArrayParser
  131. */
  132. protected function getArrayParser()
  133. {
  134. static $parser = null;
  135. if ($parser === null) {
  136. $parser = new ArrayParser();
  137. }
  138. return $parser;
  139. }
  140. }