forked from umami-software/umami
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Unify database changes. Closes umami-software#1264
- Loading branch information
Showing
3 changed files
with
225 additions
and
145 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,80 +1,102 @@ | ||
drop table if exists event; | ||
drop table if exists pageview; | ||
drop table if exists session; | ||
drop table if exists website; | ||
drop table if exists account; | ||
|
||
create table account ( | ||
user_id int unsigned not null auto_increment primary key, | ||
username varchar(255) unique not null, | ||
password varchar(60) not null, | ||
is_admin bool not null default false, | ||
created_at timestamp default current_timestamp, | ||
updated_at timestamp default current_timestamp | ||
) ENGINE=InnoDB COLLATE=utf8_general_ci; | ||
|
||
create table website ( | ||
website_id int unsigned not null auto_increment primary key, | ||
website_uuid varchar(36) unique not null, | ||
user_id int unsigned not null, | ||
name varchar(100) not null, | ||
domain varchar(500), | ||
share_id varchar(64) unique, | ||
created_at timestamp default current_timestamp, | ||
foreign key (user_id) references account(user_id) on delete cascade | ||
) ENGINE=InnoDB COLLATE=utf8_general_ci; | ||
|
||
create table session ( | ||
session_id int unsigned not null auto_increment primary key, | ||
session_uuid varchar(36) unique not null, | ||
website_id int unsigned not null references website(website_id) on delete cascade, | ||
created_at timestamp default current_timestamp, | ||
hostname varchar(100), | ||
browser varchar(20), | ||
os varchar(20), | ||
device varchar(20), | ||
screen varchar(11), | ||
language varchar(35), | ||
country char(2), | ||
foreign key (website_id) references website(website_id) on delete cascade | ||
) ENGINE=InnoDB COLLATE=utf8_general_ci; | ||
|
||
create table pageview ( | ||
view_id int unsigned not null auto_increment primary key, | ||
website_id int unsigned not null, | ||
session_id int unsigned not null, | ||
created_at timestamp default current_timestamp, | ||
url varchar(500) not null, | ||
referrer varchar(500), | ||
foreign key (website_id) references website(website_id) on delete cascade, | ||
foreign key (session_id) references session(session_id) on delete cascade | ||
) ENGINE=InnoDB COLLATE=utf8_general_ci; | ||
|
||
create table event ( | ||
event_id int unsigned not null auto_increment primary key, | ||
website_id int unsigned not null, | ||
session_id int unsigned not null, | ||
created_at timestamp default current_timestamp, | ||
url varchar(500) not null, | ||
event_type varchar(50) not null, | ||
event_value varchar(50) not null, | ||
foreign key (website_id) references website(website_id) on delete cascade, | ||
foreign key (session_id) references session(session_id) on delete cascade | ||
) ENGINE=InnoDB COLLATE=utf8_general_ci; | ||
|
||
create index website_user_id_idx on website(user_id); | ||
|
||
create index session_created_at_idx on session(created_at); | ||
create index session_website_id_idx on session(website_id); | ||
|
||
create index pageview_created_at_idx on pageview(created_at); | ||
create index pageview_website_id_idx on pageview(website_id); | ||
create index pageview_session_id_idx on pageview(session_id); | ||
create index pageview_website_id_created_at_idx on pageview(website_id, created_at); | ||
create index pageview_website_id_session_id_created_at_idx on pageview(website_id, session_id, created_at); | ||
|
||
create index event_created_at_idx on event(created_at); | ||
create index event_website_id_idx on event(website_id); | ||
create index event_session_id_idx on event(session_id); | ||
|
||
insert into account (username, password, is_admin) values ('admin', '$2b$10$BUli0c.muyCW1ErNJc3jL.vFRFtFJWrT8/GcR4A.sUdCznaXiqFXa', true); | ||
-- CreateTable | ||
CREATE TABLE `account` ( | ||
`user_id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, | ||
`username` VARCHAR(255) NOT NULL, | ||
`password` VARCHAR(60) NOT NULL, | ||
`is_admin` BOOLEAN NOT NULL DEFAULT false, | ||
`created_at` TIMESTAMP(0) NULL DEFAULT CURRENT_TIMESTAMP(0), | ||
`updated_at` TIMESTAMP(0) NULL DEFAULT CURRENT_TIMESTAMP(0), | ||
|
||
UNIQUE INDEX `username`(`username`), | ||
PRIMARY KEY (`user_id`) | ||
) ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; | ||
|
||
-- CreateTable | ||
CREATE TABLE `event` ( | ||
`event_id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, | ||
`website_id` INTEGER UNSIGNED NOT NULL, | ||
`session_id` INTEGER UNSIGNED NOT NULL, | ||
`created_at` TIMESTAMP(0) NULL DEFAULT CURRENT_TIMESTAMP(0), | ||
`url` VARCHAR(500) NOT NULL, | ||
`event_type` VARCHAR(50) NOT NULL, | ||
`event_value` VARCHAR(50) NOT NULL, | ||
|
||
INDEX `event_created_at_idx`(`created_at`), | ||
INDEX `event_session_id_idx`(`session_id`), | ||
INDEX `event_website_id_idx`(`website_id`), | ||
PRIMARY KEY (`event_id`) | ||
) ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; | ||
|
||
-- CreateTable | ||
CREATE TABLE `pageview` ( | ||
`view_id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, | ||
`website_id` INTEGER UNSIGNED NOT NULL, | ||
`session_id` INTEGER UNSIGNED NOT NULL, | ||
`created_at` TIMESTAMP(0) NULL DEFAULT CURRENT_TIMESTAMP(0), | ||
`url` VARCHAR(500) NOT NULL, | ||
`referrer` VARCHAR(500) NULL, | ||
|
||
INDEX `pageview_created_at_idx`(`created_at`), | ||
INDEX `pageview_session_id_idx`(`session_id`), | ||
INDEX `pageview_website_id_created_at_idx`(`website_id`, `created_at`), | ||
INDEX `pageview_website_id_idx`(`website_id`), | ||
INDEX `pageview_website_id_session_id_created_at_idx`(`website_id`, `session_id`, `created_at`), | ||
PRIMARY KEY (`view_id`) | ||
) ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; | ||
|
||
-- CreateTable | ||
CREATE TABLE `session` ( | ||
`session_id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, | ||
`session_uuid` VARCHAR(36) NOT NULL, | ||
`website_id` INTEGER UNSIGNED NOT NULL, | ||
`created_at` TIMESTAMP(0) NULL DEFAULT CURRENT_TIMESTAMP(0), | ||
`hostname` VARCHAR(100) NULL, | ||
`browser` VARCHAR(20) NULL, | ||
`os` VARCHAR(20) NULL, | ||
`device` VARCHAR(20) NULL, | ||
`screen` VARCHAR(11) NULL, | ||
`language` VARCHAR(35) NULL, | ||
`country` CHAR(2) NULL, | ||
|
||
UNIQUE INDEX `session_uuid`(`session_uuid`), | ||
INDEX `session_created_at_idx`(`created_at`), | ||
INDEX `session_website_id_idx`(`website_id`), | ||
PRIMARY KEY (`session_id`) | ||
) ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; | ||
|
||
-- CreateTable | ||
CREATE TABLE `website` ( | ||
`website_id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, | ||
`website_uuid` VARCHAR(36) NOT NULL, | ||
`user_id` INTEGER UNSIGNED NOT NULL, | ||
`name` VARCHAR(100) NOT NULL, | ||
`domain` VARCHAR(500) NULL, | ||
`share_id` VARCHAR(64) NULL, | ||
`created_at` TIMESTAMP(0) NULL DEFAULT CURRENT_TIMESTAMP(0), | ||
|
||
UNIQUE INDEX `website_uuid`(`website_uuid`), | ||
UNIQUE INDEX `share_id`(`share_id`), | ||
INDEX `website_user_id_idx`(`user_id`), | ||
PRIMARY KEY (`website_id`) | ||
) ENGINE=InnoDB DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; | ||
|
||
-- AddForeignKey | ||
ALTER TABLE `event` ADD CONSTRAINT `event_ibfk_2` FOREIGN KEY (`session_id`) REFERENCES `session`(`session_id`) ON DELETE CASCADE ON UPDATE NO ACTION; | ||
|
||
-- AddForeignKey | ||
ALTER TABLE `event` ADD CONSTRAINT `event_ibfk_1` FOREIGN KEY (`website_id`) REFERENCES `website`(`website_id`) ON DELETE CASCADE ON UPDATE NO ACTION; | ||
|
||
-- AddForeignKey | ||
ALTER TABLE `pageview` ADD CONSTRAINT `pageview_ibfk_2` FOREIGN KEY (`session_id`) REFERENCES `session`(`session_id`) ON DELETE CASCADE ON UPDATE NO ACTION; | ||
|
||
-- AddForeignKey | ||
ALTER TABLE `pageview` ADD CONSTRAINT `pageview_ibfk_1` FOREIGN KEY (`website_id`) REFERENCES `website`(`website_id`) ON DELETE CASCADE ON UPDATE NO ACTION; | ||
|
||
-- AddForeignKey | ||
ALTER TABLE `session` ADD CONSTRAINT `session_ibfk_1` FOREIGN KEY (`website_id`) REFERENCES `website`(`website_id`) ON DELETE CASCADE ON UPDATE NO ACTION; | ||
|
||
-- AddForeignKey | ||
ALTER TABLE `website` ADD CONSTRAINT `website_ibfk_1` FOREIGN KEY (`user_id`) REFERENCES `account`(`user_id`) ON DELETE CASCADE ON UPDATE NO ACTION; | ||
|
||
-- CreateAdminUser | ||
INSERT INTO account (username, password, is_admin) values ('admin', '$2b$10$BUli0c.muyCW1ErNJc3jL.vFRFtFJWrT8/GcR4A.sUdCznaXiqFXa', true); |
Oops, something went wrong.