2016-12-02 07:38:54 +00:00
CREATE TABLE ` users ` (
` uid ` int not null AUTO_INCREMENT ,
` name ` varchar ( 100 ) not null ,
` password ` varchar ( 100 ) not null ,
2017-01-12 02:55:08 +00:00
` salt ` varchar ( 80 ) default ' ' not null ,
2016-12-02 07:38:54 +00:00
` group ` int not null ,
2017-01-12 02:55:08 +00:00
` active ` tinyint default 0 not null ,
2016-12-02 07:38:54 +00:00
` is_super_admin ` tinyint ( 1 ) not null ,
` createdAt ` datetime not null ,
` lastActiveAt ` datetime not null ,
2017-01-12 02:55:08 +00:00
` session ` varchar ( 200 ) default ' ' not null ,
` last_ip ` varchar ( 200 ) default ' 0.0.0.0.0 ' not null ,
` email ` varchar ( 200 ) default ' ' not null ,
` avatar ` varchar ( 20 ) default ' ' not null ,
2016-12-09 13:46:29 +00:00
` message ` text not null ,
2017-01-12 02:55:08 +00:00
` url_prefix ` varchar ( 20 ) default ' ' not null ,
` url_name ` varchar ( 100 ) default ' ' not null ,
` level ` tinyint default 0 not null ,
` score ` int default 0 not null ,
` posts ` int default 0 not null ,
` bigposts ` int default 0 not null ,
` megaposts ` int default 0 not null ,
` topics ` int default 0 not null ,
2016-12-09 13:46:29 +00:00
primary key ( ` uid ` ) ,
unique ( ` name ` )
2016-12-08 14:11:18 +00:00
) CHARSET = utf8mb4 COLLATE utf8mb4_general_ci ;
2016-12-02 07:38:54 +00:00
CREATE TABLE ` users_groups ` (
` gid ` int not null AUTO_INCREMENT ,
` name ` varchar ( 100 ) not null ,
` permissions ` text not null ,
2016-12-07 13:46:14 +00:00
` is_mod ` tinyint DEFAULT 0 not null ,
2016-12-02 07:38:54 +00:00
` is_admin ` tinyint DEFAULT 0 not null ,
2016-12-03 10:25:39 +00:00
` is_banned ` tinyint DEFAULT 0 not null ,
2016-12-07 09:34:09 +00:00
` tag ` varchar ( 50 ) DEFAULT ' ' not null ,
2016-12-02 07:38:54 +00:00
primary key ( ` gid ` )
2016-12-08 14:11:18 +00:00
) CHARSET = utf8mb4 COLLATE utf8mb4_general_ci ;
2016-12-02 07:38:54 +00:00
2017-01-03 07:47:31 +00:00
CREATE TABLE ` emails ` (
` email ` varchar ( 200 ) not null ,
` uid ` int not null ,
` validated ` tinyint DEFAULT 0 not null ,
` token ` varchar ( 200 ) DEFAULT ' ' not null
) ;
2016-12-03 13:45:08 +00:00
CREATE TABLE ` forums ` (
` fid ` int not null AUTO_INCREMENT ,
` name ` varchar ( 100 ) not null ,
2016-12-07 09:34:09 +00:00
` active ` tinyint DEFAULT 1 not null ,
2017-01-26 13:37:50 +00:00
` topicCount ` int DEFAULT 0 not null ,
2017-02-04 15:49:24 +00:00
` preset ` varchar ( 100 ) DEFAULT ' ' not null ,
2016-12-03 13:45:08 +00:00
` lastTopic ` varchar ( 100 ) DEFAULT ' ' not null ,
` lastTopicID ` int DEFAULT 0 not null ,
` lastReplyer ` varchar ( 100 ) DEFAULT ' ' not null ,
` lastReplyerID ` int DEFAULT 0 not null ,
` lastTopicTime ` datetime not null ,
primary key ( ` fid ` )
2016-12-08 14:11:18 +00:00
) CHARSET = utf8mb4 COLLATE utf8mb4_general_ci ;
2016-12-03 13:45:08 +00:00
2017-01-31 05:13:38 +00:00
CREATE TABLE ` forums_permissions ` (
` fid ` int not null ,
` gid ` int not null ,
2017-02-04 06:19:55 +00:00
` preset ` varchar ( 100 ) DEFAULT ' ' not null ,
2017-01-31 05:13:38 +00:00
` permissions ` text not null
) ;
2016-12-02 07:38:54 +00:00
CREATE TABLE ` topics ` (
` tid ` int not null AUTO_INCREMENT ,
` title ` varchar ( 100 ) not null ,
` content ` text not null ,
2016-12-03 05:00:21 +00:00
` parsed_content ` text not null ,
2016-12-02 07:38:54 +00:00
` createdAt ` datetime not null ,
` lastReplyAt ` datetime not null ,
` createdBy ` int not null ,
` is_closed ` tinyint DEFAULT 0 not null ,
` sticky ` tinyint DEFAULT 0 not null ,
2017-02-05 14:41:53 +00:00
` parentID ` int DEFAULT 2 not null ,
2016-12-18 12:56:06 +00:00
` ipaddress ` varchar ( 200 ) DEFAULT ' 0.0.0.0.0 ' not null ,
2017-01-21 18:16:27 +00:00
` postCount ` int DEFAULT 1 not null ,
2017-02-10 13:39:13 +00:00
` likeCount ` int DEFAULT 0 not null ,
` words ` int DEFAULT 0 not null ,
2016-12-11 16:06:17 +00:00
` data ` varchar ( 200 ) DEFAULT ' ' not null ,
2016-12-02 07:38:54 +00:00
primary key ( ` tid ` )
2016-12-08 14:11:18 +00:00
) CHARSET = utf8mb4 COLLATE utf8mb4_general_ci ;
2016-12-02 07:38:54 +00:00
CREATE TABLE ` replies ` (
` rid ` int not null AUTO_INCREMENT ,
` tid ` int not null ,
` content ` text not null ,
2016-12-03 05:00:21 +00:00
` parsed_content ` text not null ,
2016-12-02 07:38:54 +00:00
` createdAt ` datetime not null ,
` createdBy ` int not null ,
` lastEdit ` int not null ,
` lastEditBy ` int not null ,
2016-12-18 12:56:06 +00:00
` ipaddress ` varchar ( 200 ) DEFAULT ' 0.0.0.0.0 ' not null ,
2017-02-10 13:39:13 +00:00
` likeCount ` int DEFAULT 0 not null ,
` words ` int DEFAULT 1 not null ,
2017-04-02 13:00:40 +00:00
` actionType ` varchar ( 20 ) DEFAULT ' ' not null ,
2016-12-02 07:38:54 +00:00
primary key ( ` rid ` )
2016-12-08 14:11:18 +00:00
) CHARSET = utf8mb4 COLLATE utf8mb4_general_ci ;
2016-12-02 07:38:54 +00:00
2017-03-15 08:34:14 +00:00
CREATE TABLE ` revisions ` (
` index ` int not null ,
` content ` text not null ,
` contentID ` int not null ,
` contentType ` varchar ( 100 ) DEFAULT ' replies ' not null
) CHARSET = utf8mb4 COLLATE utf8mb4_general_ci ;
2016-12-07 09:34:09 +00:00
CREATE TABLE ` users_replies ` (
` rid ` int not null AUTO_INCREMENT ,
` uid ` int not null ,
` content ` text not null ,
` parsed_content ` text not null ,
` createdAt ` datetime not null ,
` createdBy ` int not null ,
` lastEdit ` int not null ,
` lastEditBy ` int not null ,
primary key ( ` rid ` )
2016-12-08 14:11:18 +00:00
) CHARSET = utf8mb4 COLLATE utf8mb4_general_ci ;
2016-12-07 09:34:09 +00:00
2017-01-10 06:51:28 +00:00
CREATE TABLE ` likes ` (
2017-01-12 02:55:08 +00:00
` weight ` tinyint DEFAULT 1 not null ,
2017-02-28 09:27:28 +00:00
/* `type` tinyint not null, /* Regular Post: 1, Big Post: 2, Mega Post: 3, etc. */
2017-01-10 06:51:28 +00:00
` targetItem ` int not null ,
2017-02-10 13:39:13 +00:00
` targetType ` varchar ( 50 ) DEFAULT ' replies ' not null ,
2017-01-10 06:51:28 +00:00
` sentBy ` int not null ,
` recalc ` tinyint DEFAULT 0 not null
) ;
2017-02-28 09:27:28 +00:00
CREATE TABLE ` activity_stream_matches ` (
` watcher ` int not null ,
` asid ` int not null
) ;
CREATE TABLE ` activity_stream ` (
` asid ` int not null AUTO_INCREMENT ,
` actor ` int not null , /* the one doing the act */
` targetUser ` int not null , /* the user who created the item the actor is acting on, some items like forums may lack a targetUser field */
` event ` varchar ( 50 ) not null , /* mention, like, reply (as in the act of replying to an item, not the reply item type, you can "reply" to a forum by making a topic in it), friend_invite */
` elementType ` varchar ( 50 ) not null , /* topic, post (calling it post here to differentiate it from the 'reply' event), forum, user */
` elementID ` int not null , /* the ID of the element being acted upon */
primary key ( ` asid ` )
) ;
CREATE TABLE ` activity_subscriptions ` (
` user ` int not null ,
2017-03-03 16:28:49 +00:00
` targetID ` int not null , /* the ID of the element being acted upon */
` targetType ` varchar ( 50 ) not null , /* topic, post (calling it post here to differentiate it from the 'reply' event), forum, user */
2017-03-05 07:53:41 +00:00
` level ` tinyint DEFAULT 0 not null /* 0: Mentions (aka the global default for any post), 1: Replies To You, 2: All Replies */
2017-02-28 09:27:28 +00:00
) ;
2016-12-09 13:46:29 +00:00
CREATE TABLE ` settings ` (
` name ` varchar ( 200 ) not null ,
` content ` varchar ( 250 ) not null ,
` type ` varchar ( 50 ) not null ,
2016-12-16 10:37:42 +00:00
` constraints ` varchar ( 200 ) DEFAULT ' ' not null ,
2016-12-09 13:46:29 +00:00
unique ( ` name ` )
) ;
2016-12-11 16:06:17 +00:00
CREATE TABLE ` plugins ` (
` uname ` varchar ( 200 ) not null ,
` active ` tinyint DEFAULT 0 not null ,
unique ( ` uname ` )
) ;
2017-01-01 15:45:43 +00:00
CREATE TABLE ` themes ` (
` uname ` varchar ( 200 ) not null ,
` default ` tinyint DEFAULT 0 not null ,
unique ( ` uname ` )
) ;
2017-04-05 14:05:37 +00:00
CREATE TABLE ` moderation_logs ` (
` action ` varchar ( 100 ) not null ,
` elementID ` int not null ,
` elementType ` varchar ( 100 ) not null ,
` ipaddress ` varchar ( 200 ) not null ,
2017-04-06 17:37:32 +00:00
` actorID ` int not null ,
` doneAt ` datetime not null
2017-04-05 14:05:37 +00:00
) ;
CREATE TABLE ` administration_logs ` (
` action ` varchar ( 100 ) not null ,
` elementID ` int not null ,
` elementType ` varchar ( 100 ) not null ,
` ipaddress ` varchar ( 200 ) not null ,
2017-04-06 17:37:32 +00:00
` actorID ` int not null ,
` doneAt ` datetime not null
2017-04-05 14:05:37 +00:00
) ;
2016-12-09 13:46:29 +00:00
INSERT INTO settings ( ` name ` , ` content ` , ` type ` ) VALUES ( ' url_tags ' , ' 1 ' , ' bool ' ) ;
2017-01-10 06:51:28 +00:00
INSERT INTO settings ( ` name ` , ` content ` , ` type ` , ` constraints ` ) VALUES ( ' activation_type ' , ' 1 ' , ' list ' , ' 1-3 ' ) ;
2017-01-12 02:55:08 +00:00
INSERT INTO settings ( ` name ` , ` content ` , ` type ` ) VALUES ( ' bigpost_min_chars ' , ' 250 ' , ' int ' ) ;
INSERT INTO settings ( ` name ` , ` content ` , ` type ` ) VALUES ( ' megapost_min_chars ' , ' 1000 ' , ' int ' ) ;
2017-01-01 15:45:43 +00:00
INSERT INTO themes ( ` uname ` , ` default ` ) VALUES ( ' tempra-simple ' , 1 ) ;
2016-12-04 10:44:28 +00:00
2017-01-17 07:55:46 +00:00
INSERT INTO users ( ` name ` , ` password ` , ` email ` , ` group ` , ` is_super_admin ` , ` createdAt ` , ` lastActiveAt ` , ` message ` , ` last_ip ` )
VALUES ( ' Admin ' , ' password ' , ' admin@localhost ' , 1 , 1 , NOW ( ) , NOW ( ) , ' ' , ' 127.0.0.1 ' ) ;
2017-01-03 07:47:31 +00:00
INSERT INTO emails ( ` email ` , ` uid ` , ` validated ` ) VALUES ( ' admin@localhost ' , 1 , 1 ) ;
2016-12-08 14:11:18 +00:00
2016-12-21 02:30:32 +00:00
/*
The Permissions :
BanUsers
ActivateUsers
2016-12-23 12:35:22 +00:00
EditUser
EditUserEmail
EditUserPassword
EditUserGroup
EditUserGroupSuperMod
EditUserGroupAdmin
2017-03-18 07:23:02 +00:00
EditGroup
EditGroupLocalPerms
EditGroupGlobalPerms
EditGroupSuperMod
EditGroupAdmin
2016-12-21 02:30:32 +00:00
ManageForums
EditSettings
2017-01-01 15:45:43 +00:00
ManageThemes
2016-12-21 02:30:32 +00:00
ManagePlugins
2017-04-12 10:10:36 +00:00
ViewAdminLogs
2016-12-21 02:30:32 +00:00
ViewIPs
ViewTopic
2017-02-10 13:39:13 +00:00
LikeItem
2016-12-21 02:30:32 +00:00
CreateTopic
EditTopic
DeleteTopic
CreateReply
EditReply
DeleteReply
PinTopic
CloseTopic
* /
2017-04-12 10:10:36 +00:00
INSERT INTO users_groups ( ` name ` , ` permissions ` , ` is_mod ` , ` is_admin ` , ` tag ` ) VALUES ( ' Administrator ' , ' {"BanUsers":true,"ActivateUsers":true,"EditUser":true,"EditUserEmail":true,"EditUserPassword":true,"EditUserGroup":true,"EditUserGroupSuperMod":true,"EditUserGroupAdmin":false,"EditGroup":true,"EditGroupLocalPerms":true,"EditGroupGlobalPerms":true,"EditGroupSuperMod":true,"EditGroupAdmin":false,"ManageForums":true,"EditSettings":true,"ManageThemes":true,"ManagePlugins":true,"ViewAdminLogs":true,"ViewIPs":true,"ViewTopic":true,"LikeItem":true,"CreateTopic":true,"EditTopic":true,"DeleteTopic":true,"CreateReply":true,"EditReply":true,"DeleteReply":true,"PinTopic":true,"CloseTopic":true} ' , 1 , 1 , " Admin " ) ;
2017-03-18 07:23:02 +00:00
INSERT INTO users_groups ( ` name ` , ` permissions ` , ` is_mod ` , ` tag ` ) VALUES ( ' Moderator ' , ' {"BanUsers":true,"ActivateUsers":false,"EditUser":true,"EditUserEmail":false,"EditUserGroup":true,"ViewIPs":true,"ViewTopic":true,"LikeItem":true,"CreateTopic":true,"EditTopic":true,"DeleteTopic":true,"CreateReply":true,"EditReply":true,"DeleteReply":true,"PinTopic":true,"CloseTopic":true} ' , 1 , " Mod " ) ;
2017-02-10 13:39:13 +00:00
INSERT INTO users_groups ( ` name ` , ` permissions ` ) VALUES ( ' Member ' , ' {"ViewTopic":true,"LikeItem":true,"CreateTopic":true,"CreateReply":true} ' ) ;
INSERT INTO users_groups ( ` name ` , ` permissions ` , ` is_banned ` ) VALUES ( ' Banned ' , ' {"ViewTopic":true} ' , 1 ) ;
INSERT INTO users_groups ( ` name ` , ` permissions ` ) VALUES ( ' Awaiting Activation ' , ' {"ViewTopic":true} ' ) ;
2017-01-31 05:13:38 +00:00
INSERT INTO users_groups ( ` name ` , ` permissions ` , ` tag ` ) VALUES ( ' Not Loggedin ' , ' {"ViewTopic":true} ' , ' Guest ' ) ;
2016-12-08 14:11:18 +00:00
2017-01-26 13:37:50 +00:00
INSERT INTO forums ( ` name ` , ` active ` ) VALUES ( ' Reports ' , 0 ) ;
2016-12-03 13:45:08 +00:00
INSERT INTO forums ( ` name ` , ` lastTopicTime ` ) VALUES ( ' General ' , NOW ( ) ) ;
2017-01-31 05:13:38 +00:00
INSERT INTO forums_permissions ( ` gid ` , ` fid ` , ` permissions ` ) VALUES ( 1 , 1 , ' {"ViewTopic":true,"CreateReply":true,"CreateTopic":true,"PinTopic":true,"CloseTopic":true} ' ) ;
INSERT INTO forums_permissions ( ` gid ` , ` fid ` , ` permissions ` ) VALUES ( 2 , 1 , ' {"ViewTopic":true,"CreateReply":true,"CloseTopic":true} ' ) ;
INSERT INTO forums_permissions ( ` gid ` , ` fid ` , ` permissions ` ) VALUES ( 3 , 1 , ' {} ' ) ;
INSERT INTO forums_permissions ( ` gid ` , ` fid ` , ` permissions ` ) VALUES ( 4 , 1 , ' {} ' ) ;
INSERT INTO forums_permissions ( ` gid ` , ` fid ` , ` permissions ` ) VALUES ( 5 , 1 , ' {} ' ) ;
INSERT INTO forums_permissions ( ` gid ` , ` fid ` , ` permissions ` ) VALUES ( 6 , 1 , ' {} ' ) ;
2016-12-02 07:38:54 +00:00
INSERT INTO topics ( ` title ` , ` content ` , ` createdAt ` , ` lastReplyAt ` , ` createdBy ` , ` parentID ` )
2017-03-15 09:34:07 +00:00
VALUES ( ' Test Topic ' , ' A topic automatically generated by the software. ' , NOW ( ) , NOW ( ) , 1 , 2 ) ;
2016-12-02 07:38:54 +00:00
INSERT INTO replies ( ` tid ` , ` content ` , ` createdAt ` , ` createdBy ` , ` lastEdit ` , ` lastEditBy ` )
VALUES ( 1 , ' Reply 1 ' , NOW ( ) , 1 , 0 , 0 ) ;