Server : nginx/1.20.2
System : Linux VM-4-4-centos 3.10.0-1160.66.1.el7.x86_64 #1 SMP Wed May 18 16:02:34 UTC 2022 x86_64
User : www ( 1000)
PHP Version : 5.6.40
Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Directory :  /www/wwwroot/greatapp.cn/vendor/topthink/think-migration/src/db/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : /www/wwwroot/greatapp.cn/vendor/topthink/think-migration/src/db/Column.php
<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: yunwuxin <448901948@qq.com>
// +----------------------------------------------------------------------

namespace think\migration\db;

use Phinx\Db\Adapter\AdapterInterface;
use Phinx\Db\Adapter\MysqlAdapter;

class Column extends \Phinx\Db\Table\Column
{
    protected $unique = false;

    public function setNullable()
    {
        return $this->setNull(true);
    }

    public function setUnsigned()
    {
        return $this->setSigned(false);
    }

    public function setUnique()
    {
        $this->unique = true;
        return $this;
    }

    public function getUnique()
    {
        return $this->unique;
    }

    public function isUnique()
    {
        return $this->getUnique();
    }

    public static function make($name, $type, $options = [])
    {
        $column = new self();
        $column->setName($name);
        $column->setType($type);
        $column->setOptions($options);
        return $column;
    }

    public static function bigInteger($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_BIG_INTEGER);
    }

    public static function binary($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_BLOB);
    }

    public static function boolean($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_BOOLEAN);
    }

    public static function char($name, $length = 255)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_CHAR, compact('length'));
    }

    public static function date($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_DATE);
    }

    public static function dateTime($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_DATETIME);
    }

    public static function decimal($name, $precision = 8, $scale = 2)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_DECIMAL, compact('precision', 'scale'));
    }

    public static function enum($name, array $values)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_ENUM, compact('values'));
    }

    public static function float($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_FLOAT);
    }

    public static function integer($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_INTEGER);
    }

    public static function json($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_JSON);
    }

    public static function jsonb($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_JSONB);
    }

    public static function longText($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_TEXT, ['length' => MysqlAdapter::TEXT_LONG]);
    }

    public static function mediumInteger($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_INTEGER, ['length' => MysqlAdapter::INT_MEDIUM]);
    }

    public static function mediumText($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_TEXT, ['length' => MysqlAdapter::TEXT_MEDIUM]);
    }

    public static function smallInteger($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_INTEGER, ['length' => MysqlAdapter::INT_SMALL]);
    }

    public static function string($name, $length = 255)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_STRING, compact('length'));
    }

    public static function text($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_TEXT);
    }

    public static function time($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_TIME);
    }

    public static function tinyInteger($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_INTEGER, ['length' => MysqlAdapter::INT_TINY]);
    }

    public static function unsignedInteger($name)
    {
        return self::integer($name)->setUnSigned();
    }

    public static function timestamp($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_TIMESTAMP);
    }

    public static function uuid($name)
    {
        return self::make($name, AdapterInterface::PHINX_TYPE_UUID);
    }

}