/**
 * Database schema required by \yii\rbac\DbManager.
 *
 * @author Qiang Xue <qiang.xue@gmail.com>
 * @author Alexander Kochetov <creocoder@gmail.com>
 * @link http://www.yiiframework.com/
 * @copyright 2008 Yii Software LLC
 * @license http://www.yiiframework.com/license/
 * @since 2.0
 */

drop table if exists [tbl_auth_assignment];
drop table if exists [tbl_auth_item_child];
drop table if exists [tbl_auth_item];

create table [tbl_auth_item]
(
   [name]                 varchar(64) not null,
   [type]                 integer not null,
   [description]          text,
   [biz_rule]              text,
   [data]                 text,
   primary key ([name]),
   key [type] ([type])
);

create table [tbl_auth_item_child]
(
   [parent]               varchar(64) not null,
   [child]                varchar(64) not null,
   primary key ([parent],[child]),
   foreign key ([parent]) references [tbl_auth_item] ([name]) on delete cascade on update cascade,
   foreign key ([child]) references [tbl_auth_item] ([name]) on delete cascade on update cascade
);

create table [tbl_auth_assignment]
(
   [item_name]            varchar(64) not null,
   [user_id]              varchar(64) not null,
   [biz_rule]              text,
   [data]                 text,
   primary key ([item_name],[user_id]),
   foreign key ([item_name]) references [tbl_auth_item] ([name]) on delete cascade on update cascade
);