<?php

use think\migration\Migrator;

class AdminFields extends Migrator {
    /**
     * Change Method.
     *
     * Write your reversible migrations using this method.
     *
     * More information on writing migrations is available here:
     * http://docs.phinx.org/en/latest/migrations.html#the-abstractmigration-class
     *
     * The following commands can be used in this method and Phinx will
     * automatically reverse them when rolling back:
     *
     *    createTable
     *    renameTable
     *    addColumn
     *    renameColumn
     *    addIndex
     *    addForeignKey
     *
     * Remember to call "create()" or "update()" and NOT "save()" when working
     * with the Table class.
     */

    /**
     * CREATE TABLE `admin_fields` (
     *   `id` int(11) unsigned NOT NULL,
     *   `field_name` varchar(50) NOT NULL DEFAULT '' COMMENT '字段名称',
     *   `hash` varchar(50) NOT NULL DEFAULT '' COMMENT '权限所属组的ID',
     *   `data_type` int(2) NOT NULL DEFAULT '0' COMMENT '数据类型,来源于DataType类库',
     *   `default` varchar(500) NOT NULL DEFAULT '' COMMENT '默认值',
     *   `is_must` int(2) NOT NULL DEFAULT '0' COMMENT '是否必须 0为不必须,1为必须',
     *   `range` varchar(500) NOT NULL DEFAULT '' COMMENT '范围,Json字符串,根据数据类型有不一样的含义',
     *   `info` varchar(500) NOT NULL DEFAULT '' COMMENT '字段说明',
     *   `type` int(2) NOT NULL DEFAULT '0' COMMENT '字段用处:0为request,1为response',
     *   `show_name` varchar(50) NOT NULL DEFAULT '' COMMENT 'wiki显示用字段',
     *   PRIMARY KEY (`id`),
     *   KEY `hash` (`hash`)
     * ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用于保存各个API的字段规则';
     */

    public function change() {
        $table = $this->table('admin_fields', [
            'comment' => '用于保存各个API的字段规则'
        ])->setCollation('utf8mb4_general_ci');
        $table->addColumn('field_name', 'string', [
            'limit'   => 50,
            'default' => '',
            'comment' => '字段名称'
        ])->addColumn('hash', 'string', [
            'limit'   => 50,
            'default' => '',
            'comment' => '权限所属组的ID'
        ])->addColumn('data_type', 'integer', [
            'limit'   => 2,
            'default' => 0,
            'comment' => '数据类型,来源于DataType类库'
        ])->addColumn('default', 'string', [
            'limit'   => 500,
            'default' => '',
            'comment' => '默认值'
        ])->addColumn('is_must', 'integer', [
            'limit'   => 2,
            'default' => 0,
            'comment' => '是否必须 0为不必须,1为必须'
        ])->addColumn('range', 'string', [
            'limit'   => 500,
            'default' => '',
            'comment' => '范围,Json字符串,根据数据类型有不一样的含义'
        ])->addColumn('info', 'string', [
            'limit'   => 500,
            'default' => '',
            'comment' => '字段说明'
        ])->addColumn('type', 'integer', [
            'limit'   => 2,
            'default' => 0,
            'comment' => '字段用处:0为request,1为response'
        ])->addColumn('show_name', 'string', [
            'limit'   => 50,
            'default' => '',
            'comment' => 'wiki显示用字段'
        ])->addIndex(['hash'])->create();

        $table->changeColumn('id', 'integer', ['signed' => false]);
    }
}