+--
+-- TABLE gserver
+--
+CREATE TABLE IF NOT EXISTS `gserver` (
+ `id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
+ `url` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `nurl` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `version` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `site_name` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `info` text COMMENT '',
+ `register_policy` tinyint NOT NULL DEFAULT 0 COMMENT '',
+ `registered-users` int unsigned NOT NULL DEFAULT 0 COMMENT 'Number of registered users',
+ `directory-type` tinyint DEFAULT 0 COMMENT 'Type of directory service (Poco, Mastodon)',
+ `poco` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `noscrape` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `network` char(4) NOT NULL DEFAULT '' COMMENT '',
+ `platform` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `relay-subscribe` boolean NOT NULL DEFAULT '0' COMMENT 'Has the server subscribed to the relay system',
+ `relay-scope` varchar(10) NOT NULL DEFAULT '' COMMENT 'The scope of messages that the server wants to get',
+ `detection-method` tinyint unsigned COMMENT 'Method that had been used to detect that server',
+ `created` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ `last_poco_query` datetime DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ `last_contact` datetime DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ `last_failure` datetime DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ PRIMARY KEY(`id`),
+ UNIQUE INDEX `nurl` (`nurl`(190))
+) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Global servers';
+
+--
+-- TABLE clients
+--
+CREATE TABLE IF NOT EXISTS `clients` (
+ `client_id` varchar(20) NOT NULL COMMENT '',
+ `pw` varchar(20) NOT NULL DEFAULT '' COMMENT '',
+ `redirect_uri` varchar(200) NOT NULL DEFAULT '' COMMENT '',
+ `name` text COMMENT '',
+ `icon` text COMMENT '',
+ `uid` mediumint unsigned NOT NULL DEFAULT 0 COMMENT 'User id',
+ PRIMARY KEY(`client_id`)
+) DEFAULT COLLATE utf8mb4_general_ci COMMENT='OAuth usage';
+
+--
+-- TABLE contact
+--
+CREATE TABLE IF NOT EXISTS `contact` (
+ `id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
+ `uid` mediumint unsigned NOT NULL DEFAULT 0 COMMENT 'Owner User id',
+ `created` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ `updated` datetime DEFAULT '0001-01-01 00:00:00' COMMENT 'Date of last contact update',
+ `self` boolean NOT NULL DEFAULT '0' COMMENT '1 if the contact is the user him/her self',
+ `remote_self` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `rel` tinyint unsigned NOT NULL DEFAULT 0 COMMENT 'The kind of the relation between the user and the contact',
+ `duplex` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `network` char(4) NOT NULL DEFAULT '' COMMENT 'Network of the contact',
+ `protocol` char(4) NOT NULL DEFAULT '' COMMENT 'Protocol of the contact',
+ `name` varchar(255) NOT NULL DEFAULT '' COMMENT 'Name that this contact is known by',
+ `nick` varchar(255) NOT NULL DEFAULT '' COMMENT 'Nick- and user name of the contact',
+ `location` varchar(255) DEFAULT '' COMMENT '',
+ `about` text COMMENT '',
+ `keywords` text COMMENT 'public keywords (interests) of the contact',
+ `gender` varchar(32) NOT NULL DEFAULT '' COMMENT 'Deprecated',
+ `xmpp` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `attag` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `avatar` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `photo` varchar(255) DEFAULT '' COMMENT 'Link to the profile photo of the contact',
+ `thumb` varchar(255) DEFAULT '' COMMENT 'Link to the profile photo (thumb size)',
+ `micro` varchar(255) DEFAULT '' COMMENT 'Link to the profile photo (micro size)',
+ `site-pubkey` text COMMENT '',
+ `issued-id` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `dfrn-id` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `url` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `nurl` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `addr` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `alias` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `pubkey` text COMMENT 'RSA public key 4096 bit',
+ `prvkey` text COMMENT 'RSA private key 4096 bit',
+ `batch` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `request` varchar(255) COMMENT '',
+ `notify` varchar(255) COMMENT '',
+ `poll` varchar(255) COMMENT '',
+ `confirm` varchar(255) COMMENT '',
+ `subscribe` varchar(255) COMMENT '',
+ `poco` varchar(255) COMMENT '',
+ `aes_allow` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `ret-aes` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `usehub` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `subhub` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `hub-verify` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `last-update` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'Date of the last try to update the contact info',
+ `success_update` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'Date of the last successful contact update',
+ `failure_update` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'Date of the last failed update',
+ `name-date` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ `uri-date` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ `avatar-date` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ `term-date` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT '',
+ `last-item` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'date of the last post',
+ `priority` tinyint unsigned NOT NULL DEFAULT 0 COMMENT '',
+ `blocked` boolean NOT NULL DEFAULT '1' COMMENT 'Node-wide block status',
+ `block_reason` text COMMENT 'Node-wide block reason',
+ `readonly` boolean NOT NULL DEFAULT '0' COMMENT 'posts of the contact are readonly',
+ `writable` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `forum` boolean NOT NULL DEFAULT '0' COMMENT 'contact is a forum',
+ `prv` boolean NOT NULL DEFAULT '0' COMMENT 'contact is a private group',
+ `contact-type` tinyint NOT NULL DEFAULT 0 COMMENT '',
+ `hidden` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `archive` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `pending` boolean NOT NULL DEFAULT '1' COMMENT '',
+ `deleted` boolean NOT NULL DEFAULT '0' COMMENT 'Contact has been deleted',
+ `rating` tinyint NOT NULL DEFAULT 0 COMMENT '',
+ `unsearchable` boolean NOT NULL DEFAULT '0' COMMENT 'Contact prefers to not be searchable',
+ `sensitive` boolean NOT NULL DEFAULT '0' COMMENT 'Contact posts sensitive content',
+ `baseurl` varchar(255) DEFAULT '' COMMENT 'baseurl of the contact',
+ `gsid` int unsigned COMMENT 'Global Server ID',
+ `reason` text COMMENT '',
+ `closeness` tinyint unsigned NOT NULL DEFAULT 99 COMMENT '',
+ `info` mediumtext COMMENT '',
+ `profile-id` int unsigned COMMENT 'Deprecated',
+ `bdyear` varchar(4) NOT NULL DEFAULT '' COMMENT '',
+ `bd` date NOT NULL DEFAULT '0001-01-01' COMMENT '',
+ `notify_new_posts` boolean NOT NULL DEFAULT '0' COMMENT '',
+ `fetch_further_information` tinyint unsigned NOT NULL DEFAULT 0 COMMENT '',
+ `ffi_keyword_denylist` text COMMENT '',
+ PRIMARY KEY(`id`),
+ INDEX `uid_name` (`uid`,`name`(190)),
+ INDEX `self_uid` (`self`,`uid`),
+ INDEX `alias_uid` (`alias`(32),`uid`),
+ INDEX `pending_uid` (`pending`,`uid`),
+ INDEX `blocked_uid` (`blocked`,`uid`),
+ INDEX `uid_rel_network_poll` (`uid`,`rel`,`network`,`poll`(64),`archive`),
+ INDEX `uid_network_batch` (`uid`,`network`,`batch`(64)),
+ INDEX `addr_uid` (`addr`(32),`uid`),
+ INDEX `nurl_uid` (`nurl`(32),`uid`),
+ INDEX `nick_uid` (`nick`(32),`uid`),
+ INDEX `dfrn-id` (`dfrn-id`(64)),
+ INDEX `issued-id` (`issued-id`(64)),
+ INDEX `gsid` (`gsid`),
+ FOREIGN KEY (`gsid`) REFERENCES `gserver` (`id`) ON UPDATE RESTRICT ON DELETE RESTRICT
+) DEFAULT COLLATE utf8mb4_general_ci COMMENT='contact table';
+
+--
+-- TABLE item-uri
+--
+CREATE TABLE IF NOT EXISTS `item-uri` (
+ `id` int unsigned NOT NULL auto_increment,
+ `uri` varbinary(255) NOT NULL COMMENT 'URI of an item',
+ `guid` varbinary(255) COMMENT 'A unique identifier for an item',
+ PRIMARY KEY(`id`),
+ UNIQUE INDEX `uri` (`uri`),
+ INDEX `guid` (`guid`)
+) DEFAULT COLLATE utf8mb4_general_ci COMMENT='URI and GUID for items';
+
+--
+-- TABLE permissionset
+--
+CREATE TABLE IF NOT EXISTS `permissionset` (
+ `id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
+ `uid` mediumint unsigned NOT NULL DEFAULT 0 COMMENT 'Owner id of this permission set',
+ `allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>\'',
+ `allow_gid` mediumtext COMMENT 'Access Control - list of allowed groups',
+ `deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
+ `deny_gid` mediumtext COMMENT 'Access Control - list of denied groups',
+ PRIMARY KEY(`id`),
+ INDEX `uid_allow_cid_allow_gid_deny_cid_deny_gid` (`allow_cid`(50),`allow_gid`(30),`deny_cid`(50),`deny_gid`(30))
+) DEFAULT COLLATE utf8mb4_general_ci COMMENT='';
+
+--
+-- TABLE tag
+--
+CREATE TABLE IF NOT EXISTS `tag` (
+ `id` int unsigned NOT NULL auto_increment COMMENT '',
+ `name` varchar(96) NOT NULL DEFAULT '' COMMENT '',
+ `url` varbinary(255) NOT NULL DEFAULT '' COMMENT '',
+ PRIMARY KEY(`id`),
+ UNIQUE INDEX `type_name_url` (`name`,`url`),
+ INDEX `url` (`url`)
+) DEFAULT COLLATE utf8mb4_general_ci COMMENT='tags and mentions';
+