schema-pgsql.sql 1.72 KB
Newer Older
Alexander Kochetov committed
1 2 3 4 5 6 7 8 9 10 11
/**
 * 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
 */

12 13 14
drop table if exists "auth_assignment";
drop table if exists "auth_item_child";
drop table if exists "auth_item";
15 16 17 18 19 20
drop table if exists "auth_rule";

create table "auth_rule"
(
    "name"  varchar(64) not null,
    "data"  text,
21 22
    "created_at"           integer,
    "updated_at"           integer,
23 24
    primary key ("name")
);
Alexander Kochetov committed
25

26
create table "auth_item"
Alexander Kochetov committed
27 28 29 30
(
   "name"                 varchar(64) not null,
   "type"                 integer not null,
   "description"          text,
31
   "rule_name"            varchar(64),
Alexander Kochetov committed
32
   "data"                 text,
33 34
   "created_at"           integer,
   "updated_at"           integer,
35 36
   primary key ("name"),
   foreign key ("rule_name") references "auth_rule" ("name") on delete set null on update cascade
Alexander Kochetov committed
37 38
);

39
create index auth_item_type_idx on "auth_item" ("type");
40

41
create table "auth_item_child"
Alexander Kochetov committed
42 43 44 45
(
   "parent"               varchar(64) not null,
   "child"                varchar(64) not null,
   primary key ("parent","child"),
46 47
   foreign key ("parent") references "auth_item" ("name") on delete cascade on update cascade,
   foreign key ("child") references "auth_item" ("name") on delete cascade on update cascade
Alexander Kochetov committed
48 49
);

50
create table "auth_assignment"
Alexander Kochetov committed
51
(
52 53
   "item_name"            varchar(64) not null,
   "user_id"              varchar(64) not null,
54
   "created_at"           integer,
Alexander Kochetov committed
55
   primary key ("item_name","user_id"),
56
   foreign key ("item_name") references "auth_item" ("name") on delete cascade on update cascade
Alexander Kochetov committed
57
);