You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
60 lines
2.6 KiB
60 lines
2.6 KiB
11 years ago
|
<?php
|
||
|
|
||
|
use yii\db\Schema;
|
||
|
|
||
|
class m140506_102106_rbac_init extends \yii\db\Migration
|
||
|
{
|
||
|
public function up()
|
||
|
{
|
||
|
$tableOptions = null;
|
||
|
if ($this->db->driverName === 'mysql') {
|
||
|
$tableOptions = 'CHARACTER SET utf8 COLLATE utf8_general_ci ENGINE=InnoDB';
|
||
|
}
|
||
|
|
||
|
$this->createTable('{{%auth_rule}}', [
|
||
|
'name' => Schema::TYPE_STRING . '(64) NOT NULL',
|
||
|
'data' => Schema::TYPE_TEXT,
|
||
|
'created_at' => Schema::TYPE_INTEGER,
|
||
|
'updated_at' => Schema::TYPE_INTEGER,
|
||
|
], $tableOptions);
|
||
|
$this->addPrimaryKey('pk-auth_rule', '{{%auth_rule}}', 'name');
|
||
|
|
||
|
$this->createTable('{{%auth_item}}', [
|
||
|
'name' => Schema::TYPE_STRING . '(64) NOT NULL',
|
||
|
'type' => Schema::TYPE_INTEGER . ' NOT NULL',
|
||
|
'description' => Schema::TYPE_TEXT,
|
||
|
'rule_name' => Schema::TYPE_STRING . '(64)',
|
||
|
'data' => Schema::TYPE_TEXT,
|
||
|
'created_at' => Schema::TYPE_INTEGER,
|
||
|
'updated_at' => Schema::TYPE_INTEGER,
|
||
|
], $tableOptions);
|
||
|
$this->addPrimaryKey('pk-auth_item', '{{%auth_item}}', 'name');
|
||
|
$this->addForeignKey('fk-auth_item-rule_name', '{{%auth_item}}', 'rule_name', '{{%auth_rule}}', 'name', 'SET NULL', 'CASCADE');
|
||
|
$this->createIndex('idx-auth_item-type', '{{%auth_item}}', 'type');
|
||
|
|
||
|
$this->createTable('{{%auth_item_child}}', [
|
||
|
'parent' => Schema::TYPE_STRING . '(64) NOT NULL',
|
||
|
'child' => Schema::TYPE_STRING . '(64) NOT NULL',
|
||
|
], $tableOptions);
|
||
|
$this->addPrimaryKey('pk-auth_item_child', '{{%auth_item_child}}', ['parent', 'child']);
|
||
|
$this->addForeignKey('fk-auth_item_child-parent', '{{%auth_item_child}}', 'parent', '{{%auth_item}}', 'name', 'CASCADE', 'CASCADE');
|
||
|
$this->addForeignKey('fk-auth_item_child-child', '{{%auth_item_child}}', 'child', '{{%auth_item}}', 'name', 'CASCADE', 'CASCADE');
|
||
|
|
||
|
$this->createTable('{{%auth_assignment}}', [
|
||
|
'item_name' => Schema::TYPE_STRING . '(64) NOT NULL',
|
||
|
'user_id' => Schema::TYPE_STRING . '(64) NOT NULL',
|
||
|
'created_at' => Schema::TYPE_INTEGER,
|
||
|
], $tableOptions);
|
||
|
$this->addPrimaryKey('pk-auth_assignment', '{{%auth_assignment}}', ['item_name', 'user_id']);
|
||
|
$this->addForeignKey('fk-auth_assignment-item_name', '{{%auth_assignment}}', 'item_name', '{{%auth_item}}', 'name', 'CASCADE', 'CASCADE');
|
||
|
}
|
||
|
|
||
|
public function down()
|
||
|
{
|
||
|
$this->dropTable('{{%auth_assignment}}');
|
||
|
$this->dropTable('{{%auth_item_child}}');
|
||
|
$this->dropTable('{{%auth_item}}');
|
||
|
$this->dropTable('{{%auth_rule}}');
|
||
|
}
|
||
|
}
|