2018-02-20 13:59:37 +01:00
-- ------------------------------------------
2021-01-09 20:18:22 +01:00
-- Friendica 2021.03-dev (Red Hot Poker)
2021-01-21 08:16:41 +01:00
-- DB_UPDATE_VERSION 1394
2018-02-20 13:59:37 +01:00
-- ------------------------------------------
2020-05-22 07:06:55 +02:00
--
-- 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 ' ' ,
2021-01-09 20:18:22 +01:00
` protocol ` tinyint unsigned COMMENT ' The protocol of the server ' ,
2020-05-22 07:06:55 +02:00
` 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 ' ' ,
2020-12-03 16:50:14 +01:00
` last_contact ` datetime DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Last successful connection request ' ,
` last_failure ` datetime DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Last failed connection request ' ,
2020-07-19 12:04:50 +02:00
` failed ` boolean COMMENT ' Connection failed ' ,
2020-12-03 16:50:14 +01:00
` next_contact ` datetime DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Next connection request ' ,
2020-05-22 07:06:55 +02:00
PRIMARY KEY ( ` id ` ) ,
2020-12-03 16:50:14 +01:00
UNIQUE INDEX ` nurl ` ( ` nurl ` ( 190 ) ) ,
INDEX ` next_contact ` ( ` next_contact ` )
2020-05-22 07:06:55 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Global servers ' ;
2020-11-17 23:49:55 +01:00
--
-- TABLE user
--
CREATE TABLE IF NOT EXISTS ` user ` (
` uid ` mediumint unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
2020-11-18 01:31:05 +01:00
` parent - uid ` mediumint unsigned COMMENT ' The parent user that has full control about this user ' ,
2020-11-17 23:49:55 +01:00
` guid ` varchar ( 64 ) NOT NULL DEFAULT ' ' COMMENT ' A unique identifier for this user ' ,
` username ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' Name that this user is known by ' ,
` password ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' encrypted password ' ,
` legacy_password ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Is the password hash double-hashed? ' ,
` nickname ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' nick- and user name ' ,
` email ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' the users email address ' ,
` openid ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` timezone ` varchar ( 128 ) NOT NULL DEFAULT ' ' COMMENT ' PHP-legal timezone ' ,
` language ` varchar ( 32 ) NOT NULL DEFAULT ' en ' COMMENT ' default language ' ,
` register_date ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' timestamp of registration ' ,
` login_date ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' timestamp of last login ' ,
` default - location ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' Default for item.location ' ,
` allow_location ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' 1 allows to display the location ' ,
` theme ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' user theme preference ' ,
` pubkey ` text COMMENT ' RSA public key 4096 bit ' ,
` prvkey ` text COMMENT ' RSA private key 4096 bit ' ,
` spubkey ` text COMMENT ' ' ,
` sprvkey ` text COMMENT ' ' ,
` verified ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' user is verified through email ' ,
` blocked ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' 1 for user is blocked ' ,
` blockwall ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Prohibit contacts to post to the profile page of the user ' ,
` hidewall ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Hide profile details from unkown viewers ' ,
` blocktags ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Prohibit contacts to tag the post of this user ' ,
` unkmail ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Permit unknown people to send private mails to this user ' ,
` cntunkmail ` int unsigned NOT NULL DEFAULT 10 COMMENT ' ' ,
` notify - flags ` smallint unsigned NOT NULL DEFAULT 65535 COMMENT ' email notification options ' ,
` page - flags ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' page/profile type ' ,
` account - type ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` prvnets ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` pwdreset ` varchar ( 255 ) COMMENT ' Password reset request token ' ,
` pwdreset_time ` datetime COMMENT ' Timestamp of the last password reset request ' ,
` maxreq ` int unsigned NOT NULL DEFAULT 10 COMMENT ' ' ,
` expire ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` account_removed ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' if 1 the account is removed ' ,
` account_expired ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` account_expires_on ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' timestamp when account expires and will be deleted ' ,
` expire_notification_sent ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' timestamp of last warning of account expiration ' ,
` def_gid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` allow_cid ` mediumtext COMMENT ' default permission for this user ' ,
` allow_gid ` mediumtext COMMENT ' default permission for this user ' ,
` deny_cid ` mediumtext COMMENT ' default permission for this user ' ,
` deny_gid ` mediumtext COMMENT ' default permission for this user ' ,
` openidserver ` text COMMENT ' ' ,
PRIMARY KEY ( ` uid ` ) ,
INDEX ` nickname ` ( ` nickname ` ( 32 ) ) ,
INDEX ` parent - uid ` ( ` parent - uid ` ) ,
FOREIGN KEY ( ` parent - uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' The local users ' ;
2020-05-15 14:17:13 +02:00
--
-- 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 ' ' ,
2020-06-04 23:55:14 +02:00
` subscribe ` varchar ( 255 ) COMMENT ' ' ,
2020-05-15 14:17:13 +02:00
` 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 ' ,
2020-07-19 12:04:50 +02:00
` failed ` boolean COMMENT ' Connection failed ' ,
2020-05-15 14:17:13 +02:00
` 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 ' ,
2020-07-26 09:34:33 +02:00
` last - discovery ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' date of the last follower discovery ' ,
2020-05-15 14:17:13 +02:00
` 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 ' ' ,
2020-09-02 05:06:44 +02:00
` manually - approve ` boolean COMMENT ' ' ,
2020-05-15 14:17:13 +02:00
` 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 ' ,
2020-05-22 07:00:55 +02:00
` gsid ` int unsigned COMMENT ' Global Server ID ' ,
2020-05-15 14:17:13 +02:00
` 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 ' ' ,
2020-06-06 22:43:23 +02:00
` ffi_keyword_denylist ` text COMMENT ' ' ,
2020-05-15 14:17:13 +02:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` uid_name ` ( ` uid ` , ` name ` ( 190 ) ) ,
INDEX ` self_uid ` ( ` self ` , ` uid ` ) ,
2020-11-19 10:47:59 +01:00
INDEX ` alias_uid ` ( ` alias ` ( 128 ) , ` uid ` ) ,
2020-05-15 14:17:13 +02:00
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 ) ) ,
2020-11-19 10:47:59 +01:00
INDEX ` addr_uid ` ( ` addr ` ( 128 ) , ` uid ` ) ,
INDEX ` nurl_uid ` ( ` nurl ` ( 128 ) , ` uid ` ) ,
INDEX ` nick_uid ` ( ` nick ` ( 128 ) , ` uid ` ) ,
2020-08-18 12:50:18 +02:00
INDEX ` attag_uid ` ( ` attag ` ( 96 ) , ` uid ` ) ,
2020-05-15 14:17:13 +02:00
INDEX ` dfrn - id ` ( ` dfrn - id ` ( 64 ) ) ,
2020-05-22 07:00:55 +02:00
INDEX ` issued - id ` ( ` issued - id ` ( 64 ) ) ,
2020-07-19 12:04:50 +02:00
INDEX ` network_uid_lastupdate ` ( ` network ` , ` uid ` , ` last - update ` ) ,
2020-08-18 12:50:18 +02:00
INDEX ` uid_network_self_lastupdate ` ( ` uid ` , ` network ` , ` self ` , ` last - update ` ) ,
2020-07-31 19:58:25 +02:00
INDEX ` uid_lastitem ` ( ` uid ` , ` last - item ` ) ,
2020-05-22 07:00:55 +02:00
INDEX ` gsid ` ( ` gsid ` ) ,
2020-11-17 23:33:44 +01:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-05-22 07:00:55 +02:00
FOREIGN KEY ( ` gsid ` ) REFERENCES ` gserver ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
2020-05-15 14:17:13 +02:00
) 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 ' ;
2020-08-24 22:09:03 +02:00
--
-- 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 ' ;
--
-- 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 ` ) ,
INDEX ` uid ` ( ` uid ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' OAuth usage ' ;
2020-05-15 14:17:13 +02:00
--
-- 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 ` ) ,
2020-11-17 23:33:44 +01:00
INDEX ` uid_allow_cid_allow_gid_deny_cid_deny_gid ` ( ` uid ` , ` allow_cid ` ( 50 ) , ` allow_gid ` ( 30 ) , ` deny_cid ` ( 50 ) , ` deny_gid ` ( 30 ) ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2020-05-15 14:17:13 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' ' ;
2020-11-20 01:17:32 +01:00
--
-- TABLE verb
--
CREATE TABLE IF NOT EXISTS ` verb ` (
` id ` smallint unsigned NOT NULL auto_increment ,
` name ` varchar ( 100 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
PRIMARY KEY ( ` id ` )
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Activity Verbs ' ;
2019-08-20 09:39:13 +02:00
--
-- TABLE 2fa_app_specific_password
--
CREATE TABLE IF NOT EXISTS ` 2 fa_app_specific_password ` (
` id ` mediumint unsigned NOT NULL auto_increment COMMENT ' Password ID for revocation ' ,
` uid ` mediumint unsigned NOT NULL COMMENT ' User ID ' ,
` description ` varchar ( 255 ) COMMENT ' Description of the usage of the password ' ,
` hashed_password ` varchar ( 255 ) NOT NULL COMMENT ' Hashed password ' ,
` generated ` datetime NOT NULL COMMENT ' Datetime the password was generated ' ,
` last_used ` datetime COMMENT ' Datetime the password was last used ' ,
PRIMARY KEY ( ` id ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` uid_description ` ( ` uid ` , ` description ` ( 190 ) ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2019-08-20 09:39:13 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Two-factor app-specific _password ' ;
2019-06-28 11:03:58 +02:00
--
-- TABLE 2fa_recovery_codes
--
CREATE TABLE IF NOT EXISTS ` 2 fa_recovery_codes ` (
` uid ` mediumint unsigned NOT NULL COMMENT ' User ID ' ,
` code ` varchar ( 50 ) NOT NULL COMMENT ' Recovery code string ' ,
` generated ` datetime NOT NULL COMMENT ' Datetime the code was generated ' ,
` used ` datetime COMMENT ' Datetime the code was used ' ,
2020-08-24 22:09:03 +02:00
PRIMARY KEY ( ` uid ` , ` code ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2019-06-28 11:03:58 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Two-factor authentication recovery codes ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE addon
--
CREATE TABLE IF NOT EXISTS ` addon ` (
` id ` int unsigned NOT NULL auto_increment COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` name ` varchar ( 50 ) NOT NULL DEFAULT ' ' COMMENT ' addon base (file)name ' ,
` version ` varchar ( 50 ) NOT NULL DEFAULT ' ' COMMENT ' currently unused ' ,
` installed ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' currently always 1 ' ,
` hidden ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' currently unused ' ,
` timestamp ` int unsigned NOT NULL DEFAULT 0 COMMENT ' file timestamp to check for reloads ' ,
` plugin_admin ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' 1 = has admin config, 0 = has no admin config ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
UNIQUE INDEX ` name ` ( ` name ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' registered addons ' ;
2018-02-20 13:59:37 +01:00
2018-10-07 22:36:15 +02:00
--
-- TABLE apcontact
--
CREATE TABLE IF NOT EXISTS ` apcontact ` (
` url ` varbinary ( 255 ) NOT NULL COMMENT ' URL of the contact ' ,
` uuid ` varchar ( 255 ) COMMENT ' ' ,
` type ` varchar ( 20 ) NOT NULL COMMENT ' ' ,
` following ` varchar ( 255 ) COMMENT ' ' ,
` followers ` varchar ( 255 ) COMMENT ' ' ,
` inbox ` varchar ( 255 ) NOT NULL COMMENT ' ' ,
` outbox ` varchar ( 255 ) COMMENT ' ' ,
` sharedinbox ` varchar ( 255 ) COMMENT ' ' ,
2019-01-14 07:36:08 +01:00
` manually - approve ` boolean COMMENT ' ' ,
2018-10-07 22:36:15 +02:00
` nick ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` name ` varchar ( 255 ) COMMENT ' ' ,
` about ` text COMMENT ' ' ,
` photo ` varchar ( 255 ) COMMENT ' ' ,
` addr ` varchar ( 255 ) COMMENT ' ' ,
` alias ` varchar ( 255 ) COMMENT ' ' ,
` pubkey ` text COMMENT ' ' ,
2020-06-04 23:55:14 +02:00
` subscribe ` varchar ( 255 ) COMMENT ' ' ,
2018-10-07 22:36:15 +02:00
` baseurl ` varchar ( 255 ) COMMENT ' baseurl of the ap contact ' ,
2020-05-22 07:00:55 +02:00
` gsid ` int unsigned COMMENT ' Global Server ID ' ,
2019-05-02 15:05:31 +02:00
` generator ` varchar ( 255 ) COMMENT ' Name of the contact\ ' s system ' ,
2019-12-11 01:05:50 +01:00
` following_count ` int unsigned DEFAULT 0 COMMENT ' Number of following contacts ' ,
` followers_count ` int unsigned DEFAULT 0 COMMENT ' Number of followers ' ,
` statuses_count ` int unsigned DEFAULT 0 COMMENT ' Number of posts ' ,
2018-10-07 22:36:15 +02:00
` updated ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
PRIMARY KEY ( ` url ` ) ,
INDEX ` addr ` ( ` addr ` ( 32 ) ) ,
2018-11-16 21:21:33 +01:00
INDEX ` alias ` ( ` alias ` ( 190 ) ) ,
2020-05-22 07:00:55 +02:00
INDEX ` followers ` ( ` followers ` ( 190 ) ) ,
2020-07-19 12:04:50 +02:00
INDEX ` baseurl ` ( ` baseurl ` ( 190 ) ) ,
2020-11-24 07:26:26 +01:00
INDEX ` sharedinbox ` ( ` sharedinbox ` ( 190 ) ) ,
2020-05-22 07:00:55 +02:00
INDEX ` gsid ` ( ` gsid ` ) ,
FOREIGN KEY ( ` gsid ` ) REFERENCES ` gserver ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
2018-10-07 22:36:15 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' ActivityPub compatible contacts - used in the ActivityPub implementation ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE attach
--
CREATE TABLE IF NOT EXISTS ` attach ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' generated index ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' Owner User id ' ,
` hash ` varchar ( 64 ) NOT NULL DEFAULT ' ' COMMENT ' hash ' ,
` filename ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' filename of original ' ,
` filetype ` varchar ( 64 ) NOT NULL DEFAULT ' ' COMMENT ' mimetype ' ,
` filesize ` int unsigned NOT NULL DEFAULT 0 COMMENT ' size in bytes ' ,
` data ` longblob NOT NULL COMMENT ' file data ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' creation time ' ,
` edited ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' last edit time ' ,
2019-10-28 21:59:55 +01:00
` 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 ' ,
2019-01-03 22:51:36 +01:00
` backend - class ` tinytext COMMENT ' Storage backend class ' ,
` backend - ref ` text COMMENT ' Storage backend data reference ' ,
2020-08-24 22:09:03 +02:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` uid ` ( ` uid ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' file attachments ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE auth_codes
--
CREATE TABLE IF NOT EXISTS ` auth_codes ` (
` id ` varchar ( 40 ) NOT NULL COMMENT ' ' ,
` client_id ` varchar ( 20 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` redirect_uri ` varchar ( 200 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` expires ` int NOT NULL DEFAULT 0 COMMENT ' ' ,
` scope ` varchar ( 250 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2020-05-15 08:50:20 +02:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` client_id ` ( ` client_id ` ) ,
2020-05-16 22:59:42 +02:00
FOREIGN KEY ( ` client_id ` ) REFERENCES ` clients ` ( ` client_id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' OAuth usage ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE cache
--
CREATE TABLE IF NOT EXISTS ` cache ` (
2018-03-01 05:48:28 +01:00
` k ` varbinary ( 255 ) NOT NULL COMMENT ' cache key ' ,
` v ` mediumtext COMMENT ' cached serialized value ' ,
` expires ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' datetime of cache expiration ' ,
` updated ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' datetime of cache insertion ' ,
2018-03-05 05:41:14 +01:00
PRIMARY KEY ( ` k ` ) ,
INDEX ` k_expires ` ( ` k ` , ` expires ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Stores temporary data ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE challenge
--
CREATE TABLE IF NOT EXISTS ` challenge ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
2018-02-20 13:59:37 +01:00
` challenge ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` dfrn - id ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` expire ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` type ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` last_update ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
PRIMARY KEY ( ` id ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE config
--
CREATE TABLE IF NOT EXISTS ` config ` (
` id ` int unsigned NOT NULL auto_increment COMMENT ' ' ,
` cat ` varbinary ( 50 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` k ` varbinary ( 50 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` v ` mediumtext COMMENT ' ' ,
PRIMARY KEY ( ` id ` ) ,
UNIQUE INDEX ` cat_k ` ( ` cat ` , ` k ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' main configuration storage ' ;
2018-02-20 13:59:37 +01:00
2020-03-10 23:04:03 +01:00
--
-- TABLE contact-relation
--
CREATE TABLE IF NOT EXISTS ` contact - relation ` (
` cid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' contact the related contact had interacted with ' ,
` relation - cid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' related contact who had interacted with the contact ' ,
` last - interaction ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date of the last interaction ' ,
2020-07-26 09:34:33 +02:00
` follow - updated ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date of the last update of the contact relationship ' ,
` follows ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
2020-03-10 23:04:03 +01:00
PRIMARY KEY ( ` cid ` , ` relation - cid ` ) ,
2020-07-26 09:34:33 +02:00
INDEX ` relation - cid ` ( ` relation - cid ` ) ,
FOREIGN KEY ( ` cid ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` relation - cid ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2020-03-10 23:04:03 +01:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Contact relations ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE conv
--
CREATE TABLE IF NOT EXISTS ` conv ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
` guid ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' A unique identifier for this conversation ' ,
` recips ` text COMMENT ' sender_handle;recipient_handle ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' Owner User id ' ,
` creator ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' handle of creator ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' creation timestamp ' ,
` updated ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' edited timestamp ' ,
` subject ` text COMMENT ' subject of initial message ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` uid ` ( ` uid ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' private messages ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE conversation
--
CREATE TABLE IF NOT EXISTS ` conversation ` (
2018-08-05 13:09:59 +02:00
` item - uri ` varbinary ( 255 ) NOT NULL COMMENT ' Original URI of the item - unrelated to the table with the same name ' ,
2018-05-29 16:11:25 +02:00
` reply - to - uri ` varbinary ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' URI to which this item is a reply ' ,
` conversation - uri ` varbinary ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' GNU Social conversation URI ' ,
` conversation - href ` varbinary ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' GNU Social conversation link ' ,
2018-10-07 22:36:15 +02:00
` protocol ` tinyint unsigned NOT NULL DEFAULT 255 COMMENT ' The protocol of the item ' ,
2020-03-03 09:01:04 +01:00
` direction ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' How the message arrived here: 1=push, 2=pull ' ,
2018-05-29 16:11:25 +02:00
` source ` mediumtext COMMENT ' Original source ' ,
` received ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Receiving date ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` item - uri ` ) ,
INDEX ` conversation - uri ` ( ` conversation - uri ` ) ,
INDEX ` received ` ( ` received ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Raw data and structure information for messages ' ;
2018-02-20 13:59:37 +01:00
2020-12-01 23:21:44 +01:00
--
-- TABLE delayed-post
--
CREATE TABLE IF NOT EXISTS ` delayed - post ` (
` id ` int unsigned NOT NULL auto_increment ,
2020-12-02 15:55:57 +01:00
` uri ` varchar ( 255 ) COMMENT ' URI of the post that will be distributed later ' ,
2020-12-01 23:21:44 +01:00
` uid ` mediumint unsigned COMMENT ' Owner User id ' ,
` delayed ` datetime COMMENT ' delay time ' ,
PRIMARY KEY ( ` id ` ) ,
2020-12-02 01:34:10 +01:00
UNIQUE INDEX ` uid_uri ` ( ` uid ` , ` uri ` ( 190 ) ) ,
2020-12-01 23:21:44 +01:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2020-12-02 15:55:57 +01:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Posts that are about to be distributed at a later time ' ;
2020-12-01 23:21:44 +01:00
2018-10-15 23:42:55 +02:00
--
-- TABLE diaspora-interaction
--
CREATE TABLE IF NOT EXISTS ` diaspora - interaction ` (
` uri - id ` int unsigned NOT NULL COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
` interaction ` mediumtext COMMENT ' The Diaspora interaction ' ,
2020-05-15 08:50:20 +02:00
PRIMARY KEY ( ` uri - id ` ) ,
2020-05-16 22:59:42 +02:00
FOREIGN KEY ( ` uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-10-15 23:42:55 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Signed Diaspora Interaction ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE event
--
CREATE TABLE IF NOT EXISTS ` event ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
2018-02-20 13:59:37 +01:00
` guid ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' Owner User id ' ,
` cid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' contact_id (ID of the contact in contact table) ' ,
2018-02-20 13:59:37 +01:00
` uri ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' creation time ' ,
` edited ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' last edit time ' ,
` start ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' event start time ' ,
` finish ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' event end time ' ,
` summary ` text COMMENT ' short description or title of the event ' ,
` desc ` text COMMENT ' event description ' ,
` location ` text COMMENT ' event location ' ,
` type ` varchar ( 20 ) NOT NULL DEFAULT ' ' COMMENT ' event or birthday ' ,
` nofinish ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' if event does have no end this is 1 ' ,
` adjust ` boolean NOT NULL DEFAULT ' 1 ' COMMENT ' adjust to timezone of the recipient (0 or 1) ' ,
` ignore ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' 0 or 1 ' ,
2019-10-28 21:59:55 +01:00
` 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 ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` uid_start ` ( ` uid ` , ` start ` ) ,
INDEX ` cid ` ( ` cid ` ) ,
2020-11-17 23:33:44 +01:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-08-24 22:09:03 +02:00
FOREIGN KEY ( ` cid ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Events ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE fcontact
--
CREATE TABLE IF NOT EXISTS ` fcontact ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
` guid ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' unique id ' ,
2018-02-20 13:59:37 +01:00
` url ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` name ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` photo ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` request ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` nick ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` addr ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` batch ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` notify ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` poll ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` confirm ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` priority ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` network ` char ( 4 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` alias ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` pubkey ` text COMMENT ' ' ,
` updated ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
PRIMARY KEY ( ` id ` ) ,
INDEX ` addr ` ( ` addr ` ( 32 ) ) ,
UNIQUE INDEX ` url ` ( ` url ` ( 190 ) )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Diaspora compatible contacts - used in the Diaspora implementation ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE fsuggest
--
CREATE TABLE IF NOT EXISTS ` fsuggest ` (
` id ` int unsigned NOT NULL auto_increment COMMENT ' ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
` cid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` name ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` url ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` request ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` photo ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` note ` text COMMENT ' ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
2020-08-24 22:09:03 +02:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` cid ` ( ` cid ` ) ,
INDEX ` uid ` ( ` uid ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` cid ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' friend suggestion stuff ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE group
--
CREATE TABLE IF NOT EXISTS ` group ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' Owner User id ' ,
` visible ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' 1 indicates the member list is not private ' ,
` deleted ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' 1 indicates the group has been deleted ' ,
` name ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' human readable name of group ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` uid ` ( ` uid ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' privacy groups, group info ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE group_member
--
CREATE TABLE IF NOT EXISTS ` group_member ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
` gid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' groups.id of the associated group ' ,
2018-06-18 23:05:44 +02:00
` contact - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' contact.id of the member assigned to the associated group ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` contactid ` ( ` contact - id ` ) ,
2020-08-24 22:09:03 +02:00
UNIQUE INDEX ` gid_contactid ` ( ` gid ` , ` contact - id ` ) ,
FOREIGN KEY ( ` gid ` ) REFERENCES ` group ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` contact - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' privacy groups, member info ' ;
2018-02-20 13:59:37 +01:00
2018-03-26 07:44:53 +02:00
--
-- TABLE gserver-tag
--
CREATE TABLE IF NOT EXISTS ` gserver - tag ` (
` gserver - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' The id of the gserver ' ,
` tag ` varchar ( 100 ) NOT NULL DEFAULT ' ' COMMENT ' Tag that the server has subscribed ' ,
PRIMARY KEY ( ` gserver - id ` , ` tag ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` tag ` ( ` tag ` ) ,
FOREIGN KEY ( ` gserver - id ` ) REFERENCES ` gserver ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Tags that the server has subscribed ' ;
2018-03-26 07:44:53 +02:00
2018-02-20 13:59:37 +01:00
--
-- TABLE hook
--
CREATE TABLE IF NOT EXISTS ` hook ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
` hook ` varbinary ( 100 ) NOT NULL DEFAULT ' ' COMMENT ' name of hook ' ,
` file ` varbinary ( 200 ) NOT NULL DEFAULT ' ' COMMENT ' relative filename of hook handler ' ,
` function ` varbinary ( 200 ) NOT NULL DEFAULT ' ' COMMENT ' function name of hook handler ' ,
` priority ` smallint unsigned NOT NULL DEFAULT 0 COMMENT ' not yet implemented - can be used to sort conflicts in hook handling by calling handlers in priority order ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
UNIQUE INDEX ` hook_file_function ` ( ` hook ` , ` file ` , ` function ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' addon hook registry ' ;
2018-02-20 13:59:37 +01:00
2020-09-02 21:19:00 +02:00
--
-- TABLE host
--
CREATE TABLE IF NOT EXISTS ` host ` (
` id ` tinyint unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
` name ` varchar ( 128 ) NOT NULL DEFAULT ' ' COMMENT ' The hostname ' ,
PRIMARY KEY ( ` id ` ) ,
UNIQUE INDEX ` name ` ( ` name ` )
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Hostname ' ;
2019-03-25 22:51:32 +01:00
--
-- TABLE inbox-status
--
CREATE TABLE IF NOT EXISTS ` inbox - status ` (
` url ` varbinary ( 255 ) NOT NULL COMMENT ' URL of the inbox ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Creation date of this entry ' ,
` success ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date of the last successful delivery ' ,
` failure ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date of the last failed delivery ' ,
` previous ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Previous delivery date ' ,
` archive ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Is the inbox archived? ' ,
2019-03-26 22:38:15 +01:00
` shared ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Is it a shared inbox? ' ,
2019-03-25 22:51:32 +01:00
PRIMARY KEY ( ` url ` )
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Status of ActivityPub inboxes ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE intro
--
CREATE TABLE IF NOT EXISTS ` intro ` (
2018-05-29 16:11:25 +02:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
2018-02-20 13:59:37 +01:00
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
2020-11-19 07:26:30 +01:00