<?php
/**
* Phinx
*
* (The MIT license)
* Copyright (c) 2015 Rob Morgan
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated * documentation files (the "Software"), to
* deal in the Software without restriction, including without limitation the
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*
* @package Phinx
* @subpackage Phinx\Db
*/
namespace Phinx\Db\Table;
use Phinx\Db\Adapter\AdapterInterface;
/**
*
* This object is based loosely on: http://api.rubyonrails.org/classes/ActiveRecord/ConnectionAdapters/Table.html.
*/
class Column
{
/**
* @var string
*/
protected $name;
/**
* @var string
*/
protected $type;
/**
* @var integer
*/
protected $limit = null;
/**
* @var boolean
*/
protected $null = false;
/**
* @var mixed
*/
protected $default = null;
/**
* @var boolean
*/
protected $identity = false;
/**
* @var integer
*/
protected $precision;
/**
* @var integer
*/
protected $scale;
/**
* @var string
*/
protected $after;
/**
* @var string
*/
protected $update;
/**
* @var string
*/
protected $comment;
/**
* @var boolean
*/
protected $signed = true;
/**
* @var boolean
*/
protected $timezone = false;
/**
* @var array
*/
protected $properties = [];
/**
* @var string
*/
protected $collation;
/**
* @var string
*/
protected $encoding;
/**
* @var array
*/
protected $values;
/**
* Sets the column name.
*
* @param string $name
* @return \Phinx\Db\Table\Column
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* Gets the column name.
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* Sets the column type.
*
* @param string $type
* @return \Phinx\Db\Table\Column
*/
public function setType($type)
{
$this->type = $type;
return $this;
}
/**
* Gets the column type.
*
* @return string
*/
public function getType()
{
return $this->type;
}
/**
* Sets the column limit.
*
* @param int $limit
* @return \Phinx\Db\Table\Column
*/
public function setLimit($limit)
{
$this->limit = $limit;
return $this;
}
/**
* Gets the column limit.
*
* @return int
*/
public function getLimit()
{
return $this->limit;
}
/**
* Sets whether the column allows nulls.
*
* @param bool $null
* @return \Phinx\Db\Table\Column
*/
public function setNull($null)
{
$this->null = (bool)$null;
return $this;
}
/**
* Gets whether the column allows nulls.
*
* @return bool
*/
public function getNull()
{
return $this->null;
}
/**
* Does the column allow nulls?
*
* @return bool
*/
public function isNull()
{
return $this->getNull();
}
/**
* Sets the default column value.
*
* @param mixed $default
* @return \Phinx\Db\Table\Column
*/
public function setDefault($default)
{
$this->default = $default;
return $this;
}
/**
* Gets the default column value.
*
* @return mixed
*/
public function getDefault()
{
return $this->default;
}
/**
* Sets whether or not the column is an identity column.
*
* @param bool $identity
* @return \Phinx\Db\Table\Column
*/
public function setIdentity($identity)
{
$this->identity = $identity;
return $this;
}
/**
* Gets whether or not the column is an identity column.
*
* @return bool
*/
public function getIdentity()
{
return $this->identity;
}
/**
* Is the column an identity column?
*
* @return bool
*/
public function isIdentity()
{
return $this->getIdentity();
}
/**
* Sets the name of the column to add this column after.
*
* @param string $after After
* @return \Phinx\Db\Table\Column
*/
public function setAfter($after)
{
$this->after = $after;
return $this;
}
/**
* Returns the name of the column to add this column after.
*
* @return string
*/
public function getAfter()
{
return $this->after;
}
/**
* Sets the 'ON UPDATE' mysql column function.
*
* @param string $update On Update function
* @return \Phinx\Db\Table\Column
*/
public function setUpdate($update)
{
$this->update = $update;
return $this;
}
/**
* Returns the value of the ON UPDATE column function.
*
* @return string
*/
public function getUpdate()
{
return $this->update;
}
/**
* Sets the column precision for decimal.
*
* @param int $precision
* @return \Phinx\Db\Table\Column
*/
public function setPrecision($precision)
{
$this->precision = $precision;
return $this;
}
/**
* Gets the column precision for decimal.
*
* @return int
*/
public function getPrecision()
{
return $this->precision;
}
/**
* Sets the column scale for decimal.
*
* @param int $scale
* @return \Phinx\Db\Table\Column
*/
public function setScale($scale)
{
$this->scale = $scale;
return $this;
}
/**
* Gets the column scale for decimal.
*
* @return int
*/
public function getScale()
{
return $this->scale;
}
/**
* Sets the column comment.
*
* @param string $comment
* @return \Phinx\Db\Table\Column
*/
public function setComment($comment)
{
$this->comment = $comment;
return $this;
}
/**
* Gets the column comment.
*
* @return string
*/
public function getComment()
{
return $this->comment;
}
/**
* Sets whether field should be signed.
*
* @param bool $signed
* @return \Phinx\Db\Table\Column
*/
public function setSigned($signed)
{
$this->signed = (bool)$signed;
return $this;
}
/**
* Gets whether field should be signed.
*
* @return bool
*/
public function getSigned()
{
return $this->signed;
}
/**
* Should the column be signed?
*
* @return bool
*/
public function isSigned()
{
return $this->getSigned();
}
/**
* Sets whether the field should have a timezone identifier.
* Used for date/time columns only!
*
* @param bool $timezone
* @return \Phinx\Db\Table\Column
*/
public function setTimezone($timezone)
{
$this->timezone = (bool)$timezone;
return $this;
}
/**
* Gets whether field has a timezone identifier.
*
* @return bool
*/
public function getTimezone()
{
return $this->timezone;
}
/**
* Should the column have a timezone?
*
* @return bool
*/
public function isTimezone()
{
return $this->getTimezone();
}
/**
* Sets field properties.
*
* @param array $properties
*
* @return \Phinx\Db\Table\Column
*/
public function setProperties($properties)
{
$this->properties = $properties;
return $this;
}
/**
* Gets field properties
*
* @return array
*/
public function getProperties()
{
return $this->properties;
}
/**
* Sets field values.
*
* @param mixed (array|string) $values
*
* @return \Phinx\Db\Table\Column
*/
public function setValues($values)
{
if (!is_array($values)) {
$values = preg_split('/,\s*/', $values);
}
$this->values = $values;
return $this;
}
/**
* Gets field values
*
* @return array
*/
public function getValues()
{
return $this->values;
}
/**
* Sets the column collation.
*
* @param string $collation
*
* @throws \UnexpectedValueException If collation not allowed for type
* @return $this
*/
public function setCollation($collation)
{
$allowedTypes = [
AdapterInterface::PHINX_TYPE_CHAR,
AdapterInterface::PHINX_TYPE_STRING,
AdapterInterface::PHINX_TYPE_TEXT,
];
if (!in_array($this->getType(), $allowedTypes)) {
throw new \UnexpectedValueException('Collation may be set only for types: ' . implode(', ', $allowedTypes));
}
$this->collation = $collation;
return $this;
}
/**
* Gets the column collation.
*
* @return string
*/
public function getCollation()
{
return $this->collation;
}
/**
* Sets the column character set.
*
* @param string $encoding
*
* @throws \UnexpectedValueException If character set not allowed for type
* @return $this
*/
public function setEncoding($encoding)
{
$allowedTypes = [
AdapterInterface::PHINX_TYPE_CHAR,
AdapterInterface::PHINX_TYPE_STRING,
AdapterInterface::PHINX_TYPE_TEXT,
];
if (!in_array($this->getType(), $allowedTypes)) {
throw new \UnexpectedValueException('Character set may be set only for types: ' . implode(', ', $allowedTypes));
}
$this->encoding = $encoding;
return $this;
}
/**
* Gets the column character set.
*
* @return string
*/
public function getEncoding()
{
return $this->encoding;
}
/**
* Gets all allowed options. Each option must have a corresponding `setFoo` method.
*
* @return array
*/
protected function getValidOptions()
{
return [
'limit',
'default',
'null',
'identity',
'precision',
'scale',
'after',
'update',
'comment',
'signed',
'timezone',
'properties',
'values',
'collation',
'encoding',
];
}
/**
* Gets all aliased options. Each alias must reference a valid option.
*
* @return array
*/
protected function getAliasedOptions()
{
return [
'length' => 'limit',
];
}
/**
* Utility method that maps an array of column options to this objects methods.
*
* @param array $options Options
* @return \Phinx\Db\Table\Column
*/
public function setOptions($options)
{
$validOptions = $this->getValidOptions();
$aliasOptions = $this->getAliasedOptions();
foreach ($options as $option => $value) {
if (isset($aliasOptions[$option])) {
// proxy alias -> option
$option = $aliasOptions[$option];
}
if (!in_array($option, $validOptions, true)) {
throw new \RuntimeException(sprintf('"%s" is not a valid column option.', $option));
}
$method = 'set' . ucfirst($option);
$this->$method($value);
}
return $this;
}
}