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-20 00:26:24 +01:00
-- DB_UPDATE_VERSION 1393
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
` fid ` int unsigned COMMENT ' ' ,
2018-02-20 13:59:37 +01:00
` contact - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` knowyou ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` duplex ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` note ` text COMMENT ' ' ,
` hash ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` datetime ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
` blocked ` boolean NOT NULL DEFAULT ' 1 ' COMMENT ' ' ,
` ignore ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
2020-08-24 22:09:03 +02:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` contact - id ` ( ` contact - id ` ) ,
INDEX ` uid ` ( ` uid ` ) ,
2020-08-26 07:32:47 +02:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-08-24 22:09:03 +02:00
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 = ' ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE item
--
CREATE TABLE IF NOT EXISTS ` item ` (
` id ` int unsigned NOT NULL auto_increment ,
2018-05-29 16:11:25 +02:00
` guid ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' A unique identifier for this item ' ,
2018-02-20 13:59:37 +01:00
` uri ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-08-05 13:09:59 +02:00
` uri - id ` int unsigned COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
2018-07-15 20:36:20 +02:00
` uri - hash ` varchar ( 80 ) NOT NULL DEFAULT ' ' COMMENT ' RIPEMD-128 hash from uri ' ,
2020-11-19 07:26:30 +01:00
` parent ` int unsigned COMMENT ' item.id of the parent to this item if it is a reply of some form; otherwise this must be set to the id of this item ' ,
2020-11-15 17:42:46 +01:00
` parent - uri ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' uri of the top-level parent to this item ' ,
` parent - uri - id ` int unsigned COMMENT ' Id of the item-uri table that contains the top-level parent uri ' ,
2018-05-29 16:11:25 +02:00
` thr - parent ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' If the parent of this item is not the top-level item in the conversation, the uri of the immediate parent; otherwise set to parent-uri ' ,
2018-08-05 13:09:59 +02:00
` thr - parent - id ` int unsigned COMMENT ' Id of the item-uri table that contains the thread parent uri ' ,
2018-05-29 16:11:25 +02:00
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Creation timestamp. ' ,
2018-06-02 07:03:23 +02:00
` edited ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date of last edit (default is created) ' ,
2018-05-29 16:11:25 +02:00
` commented ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date of last comment/reply to this item ' ,
` received ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' datetime ' ,
` changed ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date that something in the conversation changed, indicating clients should fetch the conversation again ' ,
2018-07-15 20:36:20 +02:00
` gravity ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` network ` char ( 4 ) NOT NULL DEFAULT ' ' COMMENT ' Network from where the item comes from ' ,
2018-05-29 16:11:25 +02:00
` owner - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Link to the contact table with uid=0 of the owner of this item ' ,
` author - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Link to the contact table with uid=0 of the author of this item ' ,
2020-09-22 07:36:01 +02:00
` causer - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Link to the contact table with uid=0 of the contact that caused the item creation ' ,
2020-11-20 01:17:32 +01:00
` vid ` smallint unsigned COMMENT ' Id of the verb table entry that contains the activity verbs ' ,
2018-07-15 20:36:20 +02:00
` extid ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-07-19 15:52:05 +02:00
` post - type ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' Post type (personal note, bookmark, ...) ' ,
2018-07-15 20:36:20 +02:00
` global ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
2020-03-02 21:48:26 +01:00
` private ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' 0=public, 1=private, 2=unlisted ' ,
2018-07-15 20:36:20 +02:00
` visible ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` moderated ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` deleted ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' item has been deleted ' ,
2018-07-15 20:36:20 +02:00
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' Owner id which owns this copy of the item ' ,
` contact - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' contact.id ' ,
` wall ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' This item was posted to the wall of uid ' ,
2018-05-29 16:11:25 +02:00
` origin ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' item originated at this site ' ,
2018-07-15 20:36:20 +02:00
` pubmail ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` starred ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' item has been favourited ' ,
` unseen ` boolean NOT NULL DEFAULT ' 1 ' COMMENT ' item has not been seen ' ,
2018-05-29 16:11:25 +02:00
` mention ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' The owner of this item was mentioned in it ' ,
2018-07-15 20:36:20 +02:00
` forum_mode ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
2018-07-19 15:52:05 +02:00
` psid ` int unsigned COMMENT ' ID of the permission set of this post ' ,
2018-07-15 20:36:20 +02:00
` resource - id ` varchar ( 32 ) NOT NULL DEFAULT ' ' COMMENT ' Used to link other tables to items, it identifies the linked resource (e.g. photo) and if set must also set resource_type ' ,
2020-11-19 07:26:30 +01:00
` event - id ` int unsigned COMMENT ' Used to link to the event.id ' ,
` iaid ` int unsigned COMMENT ' Deprecated ' ,
2021-01-20 00:26:24 +01:00
` icid ` int unsigned COMMENT ' Deprecated ' ,
2020-11-07 09:22:59 +01:00
` attach ` mediumtext COMMENT ' Deprecated ' ,
2019-10-28 21:59:55 +01:00
` allow_cid ` mediumtext COMMENT ' Deprecated ' ,
` allow_gid ` mediumtext COMMENT ' Deprecated ' ,
` deny_cid ` mediumtext COMMENT ' Deprecated ' ,
` deny_gid ` mediumtext COMMENT ' Deprecated ' ,
2018-07-19 23:56:52 +02:00
` postopts ` text COMMENT ' Deprecated ' ,
` inform ` mediumtext COMMENT ' Deprecated ' ,
2018-07-19 15:52:05 +02:00
` type ` varchar ( 20 ) COMMENT ' Deprecated ' ,
` bookmark ` boolean COMMENT ' Deprecated ' ,
2018-07-15 20:36:20 +02:00
` file ` mediumtext COMMENT ' Deprecated ' ,
` location ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` coord ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` tag ` mediumtext COMMENT ' Deprecated ' ,
` plink ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` title ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` content - warning ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` body ` mediumtext COMMENT ' Deprecated ' ,
` app ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` verb ` varchar ( 100 ) COMMENT ' Deprecated ' ,
` object - type ` varchar ( 100 ) COMMENT ' Deprecated ' ,
` object ` text COMMENT ' Deprecated ' ,
` target - type ` varchar ( 100 ) COMMENT ' Deprecated ' ,
` target ` text COMMENT ' Deprecated ' ,
` author - name ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` author - link ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` author - avatar ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` owner - name ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` owner - link ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` owner - avatar ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` rendered - hash ` varchar ( 32 ) COMMENT ' Deprecated ' ,
` rendered - html ` mediumtext COMMENT ' Deprecated ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` guid ` ( ` guid ` ( 191 ) ) ,
INDEX ` uri ` ( ` uri ` ( 191 ) ) ,
INDEX ` parent ` ( ` parent ` ) ,
INDEX ` parent - uri ` ( ` parent - uri ` ( 191 ) ) ,
INDEX ` extid ` ( ` extid ` ( 191 ) ) ,
INDEX ` uid_id ` ( ` uid ` , ` id ` ) ,
INDEX ` uid_contactid_id ` ( ` uid ` , ` contact - id ` , ` id ` ) ,
2019-07-18 08:11:02 +02:00
INDEX ` uid_received ` ( ` uid ` , ` received ` ) ,
2018-02-26 07:59:32 +01:00
INDEX ` uid_commented ` ( ` uid ` , ` commented ` ) ,
2018-02-20 13:59:37 +01:00
INDEX ` uid_unseen_contactid ` ( ` uid ` , ` unseen ` , ` contact - id ` ) ,
INDEX ` uid_network_received ` ( ` uid ` , ` network ` , ` received ` ) ,
INDEX ` uid_network_commented ` ( ` uid ` , ` network ` , ` commented ` ) ,
INDEX ` uid_thrparent ` ( ` uid ` , ` thr - parent ` ( 190 ) ) ,
INDEX ` uid_parenturi ` ( ` uid ` , ` parent - uri ` ( 190 ) ) ,
2019-07-18 08:11:02 +02:00
INDEX ` uid_contactid_received ` ( ` uid ` , ` contact - id ` , ` received ` ) ,
INDEX ` authorid_received ` ( ` author - id ` , ` received ` ) ,
2018-02-20 13:59:37 +01:00
INDEX ` ownerid ` ( ` owner - id ` ) ,
2019-01-14 07:36:08 +01:00
INDEX ` contact - id ` ( ` contact - id ` ) ,
2018-02-20 13:59:37 +01:00
INDEX ` uid_uri ` ( ` uid ` , ` uri ` ( 190 ) ) ,
INDEX ` resource - id ` ( ` resource - id ` ) ,
INDEX ` deleted_changed ` ( ` deleted ` , ` changed ` ) ,
INDEX ` uid_wall_changed ` ( ` uid ` , ` wall ` , ` changed ` ) ,
2020-08-18 12:50:18 +02:00
INDEX ` uid_unseen_wall ` ( ` uid ` , ` unseen ` , ` wall ` ) ,
2019-12-15 14:14:55 +01:00
INDEX ` mention_uid_id ` ( ` mention ` , ` uid ` , ` id ` ) ,
2018-06-25 22:23:32 +02:00
INDEX ` uid_eventid ` ( ` uid ` , ` event - id ` ) ,
2020-11-19 07:26:30 +01:00
INDEX ` vid ` ( ` vid ` ) ,
2020-05-04 17:23:45 +02:00
INDEX ` psid_wall ` ( ` psid ` , ` wall ` ) ,
2020-05-15 08:50:20 +02:00
INDEX ` uri - id ` ( ` uri - id ` ) ,
INDEX ` parent - uri - id ` ( ` parent - uri - id ` ) ,
INDEX ` thr - parent - id ` ( ` thr - parent - id ` ) ,
2020-09-22 09:19:44 +02:00
INDEX ` causer - id ` ( ` causer - id ` ) ,
2020-05-16 22:59:42 +02:00
FOREIGN KEY ( ` uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` parent - uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` thr - parent - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-11-19 07:26:30 +01:00
FOREIGN KEY ( ` owner - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT ,
FOREIGN KEY ( ` author - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT ,
2020-09-22 09:19:44 +02:00
FOREIGN KEY ( ` causer - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT ,
2020-11-20 00:21:31 +01:00
FOREIGN KEY ( ` vid ` ) REFERENCES ` verb ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT ,
2020-11-17 23:33:44 +01:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-11-19 07:26:30 +01:00
FOREIGN KEY ( ` contact - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-05-16 22:59:42 +02:00
FOREIGN KEY ( ` psid ` ) REFERENCES ` permissionset ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
2018-06-25 06:56:32 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Structure for all posts ' ;
2018-07-06 00:00:38 +02:00
--
-- TABLE item-activity
--
CREATE TABLE IF NOT EXISTS ` item - activity ` (
` id ` int unsigned NOT NULL auto_increment ,
2018-07-15 20:36:20 +02:00
` uri ` varchar ( 255 ) COMMENT ' ' ,
2018-08-05 13:09:59 +02:00
` uri - id ` int unsigned COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
2018-07-15 20:36:20 +02:00
` uri - hash ` varchar ( 80 ) NOT NULL DEFAULT ' ' COMMENT ' RIPEMD-128 hash from uri ' ,
2018-07-06 00:00:38 +02:00
` activity ` smallint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
PRIMARY KEY ( ` id ` ) ,
UNIQUE INDEX ` uri - hash ` ( ` uri - hash ` ) ,
2018-11-16 21:21:33 +01:00
INDEX ` uri ` ( ` uri ` ( 191 ) ) ,
2020-05-15 08:50:20 +02:00
INDEX ` uri - id ` ( ` 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-07-06 00:00:38 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Activities for items ' ;
2018-06-25 06:56:32 +02:00
--
-- TABLE item-content
--
CREATE TABLE IF NOT EXISTS ` item - content ` (
` id ` int unsigned NOT NULL auto_increment ,
2018-07-15 20:36:20 +02:00
` uri ` varchar ( 255 ) COMMENT ' ' ,
2018-08-05 13:09:59 +02:00
` uri - id ` int unsigned COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
2018-07-15 20:36:20 +02:00
` uri - plink - hash ` varchar ( 80 ) NOT NULL DEFAULT ' ' COMMENT ' RIPEMD-128 hash from uri ' ,
2018-06-25 06:56:32 +02:00
` title ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' item title ' ,
` content - warning ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` body ` mediumtext COMMENT ' item body content ' ,
2020-10-29 06:20:26 +01:00
` raw - body ` mediumtext COMMENT ' Body without embedded media links ' ,
2018-06-25 06:56:32 +02:00
` location ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' text location where this item originated ' ,
` coord ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' longitude/latitude pair representing location where this item originated ' ,
2018-06-30 07:18:43 +02:00
` language ` text COMMENT ' Language information about this post ' ,
2018-06-25 06:56:32 +02:00
` app ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' application which generated this item ' ,
` rendered - hash ` varchar ( 32 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` rendered - html ` mediumtext COMMENT ' item.body converted to html ' ,
` object - type ` varchar ( 100 ) NOT NULL DEFAULT ' ' COMMENT ' ActivityStreams object type ' ,
` object ` text COMMENT ' JSON encoded object structure unless it is an implied object (normal post) ' ,
` target - type ` varchar ( 100 ) NOT NULL DEFAULT ' ' COMMENT ' ActivityStreams target type if applicable (URI) ' ,
` target ` text COMMENT ' JSON encoded target structure if used ' ,
` plink ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' permalink or URL to a displayable copy of the message at its source ' ,
2018-06-28 05:51:57 +02:00
` verb ` varchar ( 100 ) NOT NULL DEFAULT ' ' COMMENT ' ActivityStreams verb ' ,
2018-06-25 06:56:32 +02:00
PRIMARY KEY ( ` id ` ) ,
UNIQUE INDEX ` uri - plink - hash ` ( ` uri - plink - hash ` ) ,
2020-09-19 14:53:20 +02:00
FULLTEXT INDEX ` title - content - warning - body ` ( ` title ` , ` content - warning ` , ` body ` ) ,
2018-11-16 21:21:33 +01:00
INDEX ` uri ` ( ` uri ` ( 191 ) ) ,
2019-07-18 08:11:02 +02:00
INDEX ` plink ` ( ` plink ` ( 191 ) ) ,
2020-05-15 08:50:20 +02:00
INDEX ` uri - id ` ( ` 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-06-25 06:56:32 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Content for all posts ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE locks
--
CREATE TABLE IF NOT EXISTS ` locks ` (
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
` name ` varchar ( 128 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` locked ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` pid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Process ID ' ,
2018-07-15 20:36:20 +02:00
` expires ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' datetime of cache expiration ' ,
2018-07-07 17:59:22 +02:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` name_expires ` ( ` name ` , ` expires ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE mail
--
CREATE TABLE IF NOT EXISTS ` mail ` (
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 ' ,
` guid ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' A unique identifier for this private message ' ,
` from - name ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' name of the sender ' ,
` from - photo ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' contact photo link of the sender ' ,
` from - url ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' profile linke of the sender ' ,
2020-11-19 07:26:30 +01:00
` contact - id ` varchar ( 255 ) COMMENT ' contact.id ' ,
` convid ` int unsigned COMMENT ' conv.id ' ,
2018-02-20 13:59:37 +01:00
` title ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` body ` mediumtext COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` seen ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' if message visited it is 1 ' ,
2018-02-20 13:59:37 +01:00
` reply ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` replied ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` unknown ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' if sender not in the contact table this is 1 ' ,
2018-02-20 13:59:37 +01:00
` uri ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` parent - 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 of the private message ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` uid_seen ` ( ` uid ` , ` seen ` ) ,
INDEX ` convid ` ( ` convid ` ) ,
INDEX ` uri ` ( ` uri ` ( 64 ) ) ,
INDEX ` parent - uri ` ( ` parent - uri ` ( 64 ) ) ,
2020-08-24 22:09:03 +02:00
INDEX ` contactid ` ( ` contact - id ` ( 32 ) ) ,
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 mailacct
--
CREATE TABLE IF NOT EXISTS ` mailacct ` (
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 ' ,
` server ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` port ` smallint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` ssltype ` varchar ( 16 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` mailbox ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` user ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` pass ` text COMMENT ' ' ,
` reply_to ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` action ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` movetofolder ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` pubmail ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` last_check ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
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 = ' Mail account data for fetching mails ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE manage
--
CREATE TABLE IF NOT EXISTS ` manage ` (
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 ' ,
` mid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
PRIMARY KEY ( ` id ` ) ,
2020-08-24 22:09:03 +02:00
UNIQUE INDEX ` uid_mid ` ( ` uid ` , ` mid ` ) ,
INDEX ` mid ` ( ` mid ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` mid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' table of accounts that can manage each other ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE notify
--
CREATE TABLE IF NOT EXISTS ` notify ` (
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
` type ` smallint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` name ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` url ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` photo ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` date ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
` msg ` mediumtext COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' Owner User id ' ,
2018-02-20 13:59:37 +01:00
` link ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2020-11-19 07:26:30 +01:00
` iid ` int unsigned COMMENT ' item.id ' ,
` parent ` int unsigned COMMENT ' ' ,
2020-05-05 17:47:35 +02:00
` uri - id ` int unsigned COMMENT ' Item-uri id of the related post ' ,
` parent - uri - id ` int unsigned COMMENT ' Item-uri id of the parent of the related post ' ,
2018-02-20 13:59:37 +01:00
` seen ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` verb ` varchar ( 100 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` otype ` varchar ( 10 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` name_cache ` tinytext COMMENT ' Cached bbcode parsing of name ' ,
` msg_cache ` mediumtext COMMENT ' Cached bbcode parsing of msg ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` seen_uid_date ` ( ` seen ` , ` uid ` , ` date ` ) ,
INDEX ` uid_date ` ( ` uid ` , ` date ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` uid_type_link ` ( ` uid ` , ` type ` , ` link ` ( 190 ) ) ,
2020-11-19 07:26:30 +01:00
INDEX ` uri - id ` ( ` uri - id ` ) ,
INDEX ` parent - uri - id ` ( ` parent - uri - id ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` parent - uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' notifications ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE notify-threads
--
CREATE TABLE IF NOT EXISTS ` notify - threads ` (
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
` notify - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
2020-11-19 07:26:30 +01:00
` master - parent - item ` int unsigned COMMENT ' ' ,
2020-05-05 17:47:35 +02:00
` master - parent - uri - id ` int unsigned COMMENT ' Item-uri id of the parent of the related post ' ,
2018-02-20 13:59:37 +01:00
` parent - item ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` receiver - uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
2020-05-15 08:50:20 +02:00
PRIMARY KEY ( ` id ` ) ,
2020-11-19 07:26:30 +01:00
INDEX ` master - parent - item ` ( ` master - parent - item ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` master - parent - uri - id ` ( ` master - parent - uri - id ` ) ,
INDEX ` receiver - uid ` ( ` receiver - uid ` ) ,
2020-08-26 07:32:47 +02:00
INDEX ` notify - id ` ( ` notify - id ` ) ,
FOREIGN KEY ( ` notify - id ` ) REFERENCES ` notify ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-11-19 07:26:30 +01:00
FOREIGN KEY ( ` master - parent - item ` ) REFERENCES ` item ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` master - parent - uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-08-24 22:09:03 +02:00
FOREIGN KEY ( ` receiver - uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE oembed
--
CREATE TABLE IF NOT EXISTS ` oembed ` (
2018-05-29 16:11:25 +02:00
` url ` varbinary ( 255 ) NOT NULL COMMENT ' page url ' ,
` maxwidth ` mediumint unsigned NOT NULL COMMENT ' Maximum width passed to Oembed ' ,
` content ` mediumtext COMMENT ' OEmbed data of the page ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' datetime of creation ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` url ` , ` maxwidth ` ) ,
INDEX ` created ` ( ` created ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' cache for OEmbed queries ' ;
2018-02-20 13:59:37 +01:00
2018-06-23 06:46:22 +02:00
--
-- TABLE openwebauth-token
--
CREATE TABLE IF NOT EXISTS ` openwebauth - token ` (
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
2020-08-26 07:32:47 +02:00
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id - currently unused ' ,
2018-06-23 06:46:22 +02:00
` type ` varchar ( 32 ) NOT NULL DEFAULT ' ' COMMENT ' Verify type ' ,
` token ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' A generated token ' ,
` meta ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' datetime of creation ' ,
2020-08-24 22:09:03 +02:00
PRIMARY KEY ( ` id ` ) ,
2020-11-17 23:33:44 +01:00
INDEX ` uid ` ( ` uid ` ) ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-23 06:46:22 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Store OpenWebAuth token to verify contacts ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE parsed_url
--
CREATE TABLE IF NOT EXISTS ` parsed_url ` (
2018-05-29 16:11:25 +02:00
` url ` varbinary ( 255 ) NOT NULL COMMENT ' page url ' ,
` guessing ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' is the \ ' guessing \ ' mode active? ' ,
` oembed ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' is the data the result of oembed? ' ,
` content ` mediumtext COMMENT ' page data ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' datetime of creation ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` url ` , ` guessing ` , ` oembed ` ) ,
INDEX ` created ` ( ` created ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' cache for \ ' parse_url \ ' queries ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE participation
--
CREATE TABLE IF NOT EXISTS ` participation ` (
` iid ` int unsigned NOT NULL COMMENT ' ' ,
` server ` varchar ( 60 ) NOT NULL COMMENT ' ' ,
` cid ` int unsigned NOT NULL COMMENT ' ' ,
` fid ` int unsigned NOT NULL COMMENT ' ' ,
2019-01-14 07:36:08 +01:00
PRIMARY KEY ( ` iid ` , ` server ` ) ,
INDEX ` cid ` ( ` cid ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` fid ` ( ` fid ` ) ,
FOREIGN KEY ( ` iid ` ) REFERENCES ` item ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` cid ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` fid ` ) REFERENCES ` fcontact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Storage for participation messages from Diaspora ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE pconfig
--
CREATE TABLE IF NOT EXISTS ` pconfig ` (
2020-11-17 23:33:44 +01:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' Primary key ' ,
2018-02-20 13:59:37 +01:00
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
2020-11-17 23:33:44 +01:00
` cat ` varchar ( 50 ) NOT NULL DEFAULT ' ' COMMENT ' Category ' ,
` k ` varchar ( 100 ) NOT NULL DEFAULT ' ' COMMENT ' Key ' ,
` v ` mediumtext COMMENT ' Value ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
2020-08-24 22:09:03 +02:00
UNIQUE INDEX ` uid_cat_k ` ( ` uid ` , ` cat ` , ` k ` ) ,
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 = ' personal (per user) configuration storage ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE photo
--
CREATE TABLE IF NOT EXISTS ` photo ` (
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 ' ,
` contact - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' contact.id ' ,
` guid ` char ( 16 ) NOT NULL DEFAULT ' ' COMMENT ' A unique identifier for this photo ' ,
2018-02-20 13:59:37 +01:00
` resource - id ` char ( 32 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2020-12-26 19:51:36 +01:00
` hash ` char ( 32 ) COMMENT ' hash value of the photo ' ,
2018-05-29 16:11:25 +02:00
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' creation date ' ,
` edited ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' last edited date ' ,
2018-02-20 13:59:37 +01:00
` title ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` desc ` text COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` album ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' The name of the album to which the photo belongs ' ,
2018-02-20 13:59:37 +01:00
` filename ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` type ` varchar ( 30 ) NOT NULL DEFAULT ' image/jpeg ' ,
` height ` smallint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` width ` smallint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` datasize ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` data ` mediumblob NOT NULL COMMENT ' ' ,
` scale ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` profile ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
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 ' ,
2020-03-08 14:16:59 +01:00
` accessible ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Make photo publicly accessible, ignoring permissions ' ,
2018-11-21 19:13:36 +01:00
` backend - class ` tinytext COMMENT ' Storage backend class ' ,
` backend - ref ` text COMMENT ' Storage backend data reference ' ,
2019-03-25 22:51:32 +01:00
` updated ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` contactid ` ( ` contact - id ` ) ,
INDEX ` uid_contactid ` ( ` uid ` , ` contact - id ` ) ,
INDEX ` uid_profile ` ( ` uid ` , ` profile ` ) ,
INDEX ` uid_album_scale_created ` ( ` uid ` , ` album ` ( 32 ) , ` scale ` , ` created ` ) ,
INDEX ` uid_album_resource - id_created ` ( ` uid ` , ` album ` ( 32 ) , ` resource - id ` , ` created ` ) ,
2020-08-21 20:37:58 +02:00
INDEX ` resource - id ` ( ` resource - id ` ) ,
2020-11-24 07:26:26 +01:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE RESTRICT ,
2020-08-21 20:37:58 +02:00
FOREIGN KEY ( ` contact - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' photo storage ' ;
2018-02-20 13:59:37 +01:00
2020-05-15 14:17:13 +02:00
--
-- TABLE post-category
--
CREATE TABLE IF NOT EXISTS ` post - category ` (
` uri - id ` int unsigned NOT NULL COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
` type ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` tid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
PRIMARY KEY ( ` uri - id ` , ` uid ` , ` type ` , ` tid ` ) ,
INDEX ` uri - id ` ( ` tid ` ) ,
2020-11-17 23:33:44 +01:00
INDEX ` uid ` ( ` uid ` ) ,
2020-05-16 22:59:42 +02:00
FOREIGN KEY ( ` uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-11-17 23:33:44 +01:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-05-16 22:59:42 +02:00
FOREIGN KEY ( ` tid ` ) REFERENCES ` tag ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
2020-05-15 14:17:13 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' post relation to categories ' ;
--
-- TABLE post-delivery-data
--
CREATE TABLE IF NOT EXISTS ` post - delivery - data ` (
` uri - id ` int unsigned NOT NULL COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
` postopts ` text COMMENT ' External post connectors add their network name to this comma-separated string to identify that they should be delivered to these networks during delivery ' ,
` inform ` mediumtext COMMENT ' Additional receivers of the linked item ' ,
` queue_count ` mediumint NOT NULL DEFAULT 0 COMMENT ' Initial number of delivery recipients, used as item.delivery_queue_count ' ,
` queue_done ` mediumint NOT NULL DEFAULT 0 COMMENT ' Number of successful deliveries, used as item.delivery_queue_done ' ,
` queue_failed ` mediumint NOT NULL DEFAULT 0 COMMENT ' Number of unsuccessful deliveries, used as item.delivery_queue_failed ' ,
` activitypub ` mediumint NOT NULL DEFAULT 0 COMMENT ' Number of successful deliveries via ActivityPub ' ,
` dfrn ` mediumint NOT NULL DEFAULT 0 COMMENT ' Number of successful deliveries via DFRN ' ,
` legacy_dfrn ` mediumint NOT NULL DEFAULT 0 COMMENT ' Number of successful deliveries via legacy DFRN ' ,
` diaspora ` mediumint NOT NULL DEFAULT 0 COMMENT ' Number of successful deliveries via Diaspora ' ,
` ostatus ` mediumint NOT NULL DEFAULT 0 COMMENT ' Number of successful deliveries via OStatus ' ,
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
2020-05-15 14:17:13 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Delivery data for items ' ;
2020-10-29 06:20:26 +01:00
--
-- TABLE post-media
--
CREATE TABLE IF NOT EXISTS ` post - media ` (
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
` uri - id ` int unsigned NOT NULL COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
` url ` varbinary ( 511 ) NOT NULL COMMENT ' Media URL ' ,
` type ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' Media type ' ,
` mimetype ` varchar ( 60 ) COMMENT ' ' ,
` height ` smallint unsigned COMMENT ' Height of the media ' ,
` width ` smallint unsigned COMMENT ' Width of the media ' ,
` size ` int unsigned COMMENT ' Media size ' ,
` preview ` varbinary ( 255 ) COMMENT ' Preview URL ' ,
` preview - height ` smallint unsigned COMMENT ' Height of the preview picture ' ,
` preview - width ` smallint unsigned COMMENT ' Width of the preview picture ' ,
` description ` text COMMENT ' ' ,
PRIMARY KEY ( ` id ` ) ,
UNIQUE INDEX ` uri - id - url ` ( ` uri - id ` , ` url ` ) ,
FOREIGN KEY ( ` uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Attached media ' ;
2020-05-15 14:17:13 +02:00
--
-- TABLE post-tag
--
CREATE TABLE IF NOT EXISTS ` post - tag ` (
` uri - id ` int unsigned NOT NULL COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
` type ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` tid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` cid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Contact id of the mentioned public contact ' ,
PRIMARY KEY ( ` uri - id ` , ` type ` , ` tid ` , ` cid ` ) ,
INDEX ` tid ` ( ` tid ` ) ,
INDEX ` cid ` ( ` cid ` ) ,
2020-05-16 22:59:42 +02:00
FOREIGN KEY ( ` uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` tid ` ) REFERENCES ` tag ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT ,
FOREIGN KEY ( ` cid ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
2020-05-15 14:17:13 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' post relation to tags ' ;
2020-11-17 23:33:44 +01:00
--
-- TABLE post-user
--
CREATE TABLE IF NOT EXISTS ` post - user ` (
` uri - id ` int unsigned NOT NULL COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
` uid ` mediumint unsigned NOT NULL COMMENT ' Owner id which owns this copy of the item ' ,
2020-11-29 17:09:51 +01:00
` protocol ` tinyint unsigned COMMENT ' Protocol used to deliver the item for this user ' ,
2020-11-17 23:33:44 +01:00
` contact - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' contact.id ' ,
` unseen ` boolean NOT NULL DEFAULT ' 1 ' COMMENT ' post has not been seen ' ,
` hidden ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Marker to hide the post from the user ' ,
` notification - type ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` origin ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' item originated at this site ' ,
` psid ` int unsigned COMMENT ' ID of the permission set of this post ' ,
PRIMARY KEY ( ` uid ` , ` uri - id ` ) ,
INDEX ` uri - id ` ( ` uri - id ` ) ,
INDEX ` contact - id ` ( ` contact - id ` ) ,
INDEX ` psid ` ( ` psid ` ) ,
FOREIGN KEY ( ` uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` contact - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` psid ` ) REFERENCES ` permissionset ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' User specific post data ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE process
--
CREATE TABLE IF NOT EXISTS ` process ` (
` pid ` int unsigned NOT NULL COMMENT ' ' ,
` command ` varbinary ( 32 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
PRIMARY KEY ( ` pid ` ) ,
INDEX ` command ` ( ` command ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Currently running system processes ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE profile
--
CREATE TABLE IF NOT EXISTS ` profile ` (
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 ' ,
2020-01-19 15:43:15 +01:00
` profile - name ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` is - default ` boolean COMMENT ' Deprecated ' ,
2018-05-29 16:11:25 +02:00
` hide - friends ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Hide friend list from viewers of this profile ' ,
2018-02-20 13:59:37 +01:00
` name ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2020-02-09 08:35:39 +01:00
` pdesc ` varchar ( 255 ) COMMENT ' Deprecated ' ,
2018-05-29 16:11:25 +02:00
` dob ` varchar ( 32 ) NOT NULL DEFAULT ' 0000-00-00 ' COMMENT ' Day of birth ' ,
2018-02-20 13:59:37 +01:00
` address ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` locality ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` region ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` postal - code ` varchar ( 32 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` country - name ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2020-01-19 15:43:15 +01:00
` hometown ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` gender ` varchar ( 32 ) COMMENT ' Deprecated ' ,
` marital ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` with ` text COMMENT ' Deprecated ' ,
` howlong ` datetime COMMENT ' Deprecated ' ,
` sexual ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` politic ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` religion ` varchar ( 255 ) COMMENT ' Deprecated ' ,
2018-02-20 13:59:37 +01:00
` pub_keywords ` text COMMENT ' ' ,
` prv_keywords ` text COMMENT ' ' ,
2020-01-19 15:43:15 +01:00
` likes ` text COMMENT ' Deprecated ' ,
` dislikes ` text COMMENT ' Deprecated ' ,
2020-02-09 08:35:39 +01:00
` about ` text COMMENT ' Profile description ' ,
2020-01-19 15:43:15 +01:00
` summary ` varchar ( 255 ) COMMENT ' Deprecated ' ,
` music ` text COMMENT ' Deprecated ' ,
` book ` text COMMENT ' Deprecated ' ,
` tv ` text COMMENT ' Deprecated ' ,
` film ` text COMMENT ' Deprecated ' ,
` interest ` text COMMENT ' Deprecated ' ,
` romance ` text COMMENT ' Deprecated ' ,
` work ` text COMMENT ' Deprecated ' ,
` education ` text COMMENT ' Deprecated ' ,
` contact ` text COMMENT ' Deprecated ' ,
2018-02-20 13:59:37 +01:00
` homepage ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` xmpp ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` photo ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` thumb ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` publish ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' publish default profile in local directory ' ,
` net - publish ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' publish profile in global directory ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
2019-01-14 07:36:08 +01:00
INDEX ` uid_is - default ` ( ` uid ` , ` is - default ` ) ,
2020-08-24 22:09:03 +02:00
FULLTEXT INDEX ` pub_keywords ` ( ` pub_keywords ` ) ,
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 = ' user profiles data ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE profile_check
--
CREATE TABLE IF NOT EXISTS ` profile_check ` (
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 ' ,
2018-05-29 16:11:25 +02:00
` cid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' contact.id ' ,
2018-02-20 13:59:37 +01:00
` dfrn_id ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` sec ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` expire ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
2020-08-24 22:09:03 +02:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` uid ` ( ` uid ` ) ,
INDEX ` cid ` ( ` cid ` ) ,
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 = ' DFRN remote auth use ' ;
2018-02-20 13:59:37 +01:00
2019-11-08 04:09:19 +01:00
--
-- TABLE profile_field
--
CREATE TABLE IF NOT EXISTS ` profile_field ` (
2020-03-02 21:31:16 +01:00
` id ` int unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' Owner user id ' ,
` order ` mediumint unsigned NOT NULL DEFAULT 1 COMMENT ' Field ordering per user ' ,
` psid ` int unsigned COMMENT ' ID of the permission set of this profile field - 0 = public ' ,
` label ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' Label of the field ' ,
` value ` text COMMENT ' Value of the field ' ,
` 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 ' ,
PRIMARY KEY ( ` id ` ) ,
INDEX ` uid ` ( ` uid ` ) ,
INDEX ` order ` ( ` order ` ) ,
2020-05-15 08:50:20 +02:00
INDEX ` psid ` ( ` psid ` ) ,
2020-08-24 22:09:03 +02:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-05-16 22:59:42 +02:00
FOREIGN KEY ( ` psid ` ) REFERENCES ` permissionset ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
2019-11-08 04:09:19 +01:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Custom profile fields ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE push_subscriber
--
CREATE TABLE IF NOT EXISTS ` push_subscriber ` (
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 ' ,
` callback_url ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` topic ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` nickname ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-05-19 05:56:29 +02:00
` push ` tinyint NOT NULL DEFAULT 0 COMMENT ' Retrial counter ' ,
2018-05-18 01:35:24 +02:00
` last_update ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date of last successful trial ' ,
` next_try ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Next retrial date ' ,
2018-05-18 14:50:57 +02:00
` renewed ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Date of last subscription renewal ' ,
2018-02-20 13:59:37 +01:00
` secret ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-05-18 01:35:24 +02:00
PRIMARY KEY ( ` id ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` next_try ` ( ` next_try ` ) ,
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 = ' Used for OStatus: Contains feed subscribers ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE register
--
CREATE TABLE IF NOT EXISTS ` register ` (
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
` hash ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
` password ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` language ` varchar ( 16 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` note ` text COMMENT ' ' ,
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 = ' registrations requiring admin approval ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE search
--
CREATE TABLE IF NOT EXISTS ` search ` (
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 ' ,
` term ` varchar ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
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 = ' ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE session
--
CREATE TABLE IF NOT EXISTS ` session ` (
2018-05-29 16:11:25 +02:00
` id ` bigint unsigned NOT NULL auto_increment COMMENT ' sequential ID ' ,
2018-02-20 13:59:37 +01:00
` sid ` varbinary ( 255 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` data ` text COMMENT ' ' ,
` expire ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
PRIMARY KEY ( ` id ` ) ,
INDEX ` sid ` ( ` sid ` ( 64 ) ) ,
INDEX ` expire ` ( ` expire ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' web session storage ' ;
2018-02-20 13:59:37 +01:00
2020-04-23 08:19:44 +02:00
--
2020-05-15 14:17:13 +02:00
-- TABLE storage
2020-04-23 08:19:44 +02:00
--
2020-05-15 14:17:13 +02:00
CREATE TABLE IF NOT EXISTS ` storage ` (
` id ` int unsigned NOT NULL auto_increment COMMENT ' Auto incremented image data id ' ,
` data ` longblob NOT NULL COMMENT ' file data ' ,
PRIMARY KEY ( ` id ` )
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Data stored by Database storage backend ' ;
2020-04-23 08:19:44 +02:00
2018-02-20 13:59:37 +01:00
--
-- TABLE thread
--
CREATE TABLE IF NOT EXISTS ` thread ` (
2018-05-29 16:11:25 +02:00
` iid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' sequential ID ' ,
2020-05-29 04:19:58 +02:00
` uri - id ` int unsigned COMMENT ' Id of the item-uri table entry that contains the item uri ' ,
2018-02-20 13:59:37 +01:00
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
` contact - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
2018-05-29 16:11:25 +02:00
` owner - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Item owner ' ,
` author - id ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Item author ' ,
2018-02-20 13:59:37 +01:00
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
` edited ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
` commented ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
` received ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
` changed ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' ' ,
` wall ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
2020-03-02 21:48:26 +01:00
` private ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' 0=public, 1=private, 2=unlisted ' ,
2018-02-20 13:59:37 +01:00
` pubmail ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` moderated ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` visible ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` starred ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` ignored ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
2018-07-19 15:52:05 +02:00
` post - type ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' Post type (personal note, bookmark, ...) ' ,
2018-02-20 13:59:37 +01:00
` unseen ` boolean NOT NULL DEFAULT ' 1 ' COMMENT ' ' ,
` deleted ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` origin ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` forum_mode ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
` mention ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' ' ,
` network ` char ( 4 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
2018-07-19 15:52:05 +02:00
` bookmark ` boolean COMMENT ' ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` iid ` ) ,
INDEX ` uid_network_commented ` ( ` uid ` , ` network ` , ` commented ` ) ,
2019-07-18 08:11:02 +02:00
INDEX ` uid_network_received ` ( ` uid ` , ` network ` , ` received ` ) ,
2018-02-20 13:59:37 +01:00
INDEX ` uid_contactid_commented ` ( ` uid ` , ` contact - id ` , ` commented ` ) ,
2019-07-18 08:11:02 +02:00
INDEX ` uid_contactid_received ` ( ` uid ` , ` contact - id ` , ` received ` ) ,
2018-02-20 13:59:37 +01:00
INDEX ` contactid ` ( ` contact - id ` ) ,
INDEX ` ownerid ` ( ` owner - id ` ) ,
INDEX ` authorid ` ( ` author - id ` ) ,
2019-07-18 08:11:02 +02:00
INDEX ` uid_received ` ( ` uid ` , ` received ` ) ,
2018-02-20 13:59:37 +01:00
INDEX ` uid_commented ` ( ` uid ` , ` commented ` ) ,
2019-07-18 08:11:02 +02:00
INDEX ` uid_wall_received ` ( ` uid ` , ` wall ` , ` received ` ) ,
2020-05-29 04:19:58 +02:00
INDEX ` private_wall_origin_commented ` ( ` private ` , ` wall ` , ` origin ` , ` commented ` ) ,
INDEX ` uri - id ` ( ` uri - id ` ) ,
2020-08-26 07:32:47 +02:00
FOREIGN KEY ( ` iid ` ) REFERENCES ` item ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-11-17 23:33:44 +01:00
FOREIGN KEY ( ` uri - id ` ) REFERENCES ` item - uri ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
2020-11-19 07:26:30 +01:00
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` contact - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` owner - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT ,
FOREIGN KEY ( ` author - id ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE RESTRICT
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Thread related data ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE tokens
--
CREATE TABLE IF NOT EXISTS ` tokens ` (
` id ` varchar ( 40 ) NOT NULL COMMENT ' ' ,
` secret ` text COMMENT ' ' ,
` client_id ` varchar ( 20 ) NOT NULL DEFAULT ' ' ,
` expires ` int NOT NULL DEFAULT 0 COMMENT ' ' ,
` scope ` varchar ( 200 ) NOT NULL DEFAULT ' ' COMMENT ' ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
2020-05-15 08:50:20 +02:00
PRIMARY KEY ( ` id ` ) ,
INDEX ` client_id ` ( ` client_id ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` uid ` ( ` uid ` ) ,
FOREIGN KEY ( ` client_id ` ) REFERENCES ` clients ` ( ` client_id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
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 = ' OAuth usage ' ;
2018-02-20 13:59:37 +01:00
--
-- TABLE userd
--
CREATE TABLE IF NOT EXISTS ` userd ` (
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
` username ` varchar ( 255 ) NOT NULL COMMENT ' ' ,
PRIMARY KEY ( ` id ` ) ,
INDEX ` username ` ( ` username ` ( 32 ) )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Deleted usernames ' ;
2018-02-20 13:59:37 +01:00
2018-08-25 15:48:00 +02:00
--
-- TABLE user-contact
--
CREATE TABLE IF NOT EXISTS ` user - contact ` (
` cid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Contact id of the linked public contact ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
` blocked ` boolean COMMENT ' Contact is completely blocked for this user ' ,
` ignored ` boolean COMMENT ' Posts from this contact are ignored ' ,
` collapsed ` boolean COMMENT ' Posts from this contact are collapsed ' ,
2020-08-24 22:09:03 +02:00
PRIMARY KEY ( ` uid ` , ` cid ` ) ,
INDEX ` cid ` ( ` cid ` ) ,
FOREIGN KEY ( ` cid ` ) REFERENCES ` contact ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
FOREIGN KEY ( ` uid ` ) REFERENCES ` user ` ( ` uid ` ) ON UPDATE RESTRICT ON DELETE CASCADE
2018-08-25 15:48:00 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' User specific public contact data ' ;
2018-05-26 20:07:27 +02:00
--
-- TABLE user-item
--
CREATE TABLE IF NOT EXISTS ` user - item ` (
` iid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Item id ' ,
` uid ` mediumint unsigned NOT NULL DEFAULT 0 COMMENT ' User id ' ,
2018-06-02 07:03:23 +02:00
` hidden ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Marker to hide an item from the user ' ,
2018-08-08 22:32:11 +02:00
` ignored ` boolean COMMENT ' Ignore this thread if set ' ,
2019-11-07 06:39:15 +01:00
` pinned ` boolean COMMENT ' The item is pinned on the profile page ' ,
2020-01-04 13:21:42 +01:00
` notification - type ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' ' ,
2019-11-07 07:53:18 +01:00
PRIMARY KEY ( ` uid ` , ` iid ` ) ,
2020-01-05 13:48:18 +01:00
INDEX ` uid_pinned ` ( ` uid ` , ` pinned ` ) ,
2020-08-24 22:09:03 +02:00
INDEX ` iid_uid ` ( ` iid ` , ` uid ` ) ,
FOREIGN KEY ( ` iid ` ) REFERENCES ` item ` ( ` id ` ) ON UPDATE RESTRICT ON DELETE CASCADE ,
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 = ' User specific item data ' ;
--
-- TABLE worker-ipc
--
CREATE TABLE IF NOT EXISTS ` worker - ipc ` (
` key ` int NOT NULL COMMENT ' ' ,
` jobs ` boolean COMMENT ' Flag for outstanding jobs ' ,
PRIMARY KEY ( ` key ` )
) ENGINE = MEMORY DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Inter process communication between the frontend and the worker ' ;
2018-05-26 20:07:27 +02:00
2018-02-20 13:59:37 +01:00
--
-- TABLE workerqueue
--
CREATE TABLE IF NOT EXISTS ` workerqueue ` (
` id ` int unsigned NOT NULL auto_increment COMMENT ' Auto incremented worker task id ' ,
2020-12-03 16:50:14 +01:00
` command ` varchar ( 100 ) COMMENT ' Task command ' ,
` parameter ` mediumtext COMMENT ' Task parameter ' ,
2018-02-20 13:59:37 +01:00
` priority ` tinyint unsigned NOT NULL DEFAULT 0 COMMENT ' Task priority ' ,
` created ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Creation date ' ,
` pid ` int unsigned NOT NULL DEFAULT 0 COMMENT ' Process id of the worker ' ,
` executed ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Execution date ' ,
2018-10-15 23:42:55 +02:00
` next_try ` datetime NOT NULL DEFAULT ' 0001-01-01 00:00:00 ' COMMENT ' Next retrial date ' ,
` retrial ` tinyint NOT NULL DEFAULT 0 COMMENT ' Retrial counter ' ,
2018-05-29 16:11:25 +02:00
` done ` boolean NOT NULL DEFAULT ' 0 ' COMMENT ' Marked 1 when the task was done - will be deleted later ' ,
2018-02-20 13:59:37 +01:00
PRIMARY KEY ( ` id ` ) ,
2020-12-03 16:50:14 +01:00
INDEX ` command ` ( ` command ` ) ,
INDEX ` done_command_parameter ` ( ` done ` , ` command ` , ` parameter ` ( 64 ) ) ,
2019-03-25 22:51:32 +01:00
INDEX ` done_executed ` ( ` done ` , ` executed ` ) ,
2020-10-29 06:20:26 +01:00
INDEX ` done_priority_retrial_created ` ( ` done ` , ` priority ` , ` retrial ` , ` created ` ) ,
2018-11-16 21:21:33 +01:00
INDEX ` done_priority_next_try ` ( ` done ` , ` priority ` , ` next_try ` ) ,
2019-03-25 22:51:32 +01:00
INDEX ` done_pid_next_try ` ( ` done ` , ` pid ` , ` next_try ` ) ,
2020-08-18 12:50:18 +02:00
INDEX ` done_pid_retrial ` ( ` done ` , ` pid ` , ` retrial ` ) ,
2019-03-25 22:51:32 +01:00
INDEX ` done_pid_priority_created ` ( ` done ` , ` pid ` , ` priority ` , ` created ` )
2018-06-02 07:03:23 +02:00
) DEFAULT COLLATE utf8mb4_general_ci COMMENT = ' Background tasks queue entries ' ;
2015-09-11 21:56:37 +02:00
2021-01-14 23:51:44 +01:00
--
-- VIEW post-view
--
DROP VIEW IF EXISTS ` post - view ` ;
CREATE VIEW ` post - view ` AS SELECT
` item ` . ` id ` AS ` id ` ,
` item ` . ` id ` AS ` item_id ` ,
` item ` . ` uid ` AS ` uid ` ,
` item ` . ` uid ` AS ` internal - uid ` ,
` item ` . ` parent ` AS ` parent ` ,
` item ` . ` uri ` AS ` uri ` ,
` item ` . ` uri - id ` AS ` uri - id ` ,
` item ` . ` uri - id ` AS ` internal - uri - id ` ,
` item ` . ` parent - uri ` AS ` parent - uri ` ,
` item ` . ` parent - uri - id ` AS ` parent - uri - id ` ,
` item ` . ` thr - parent ` AS ` thr - parent ` ,
` item ` . ` thr - parent - id ` AS ` thr - parent - id ` ,
` item ` . ` guid ` AS ` guid ` ,
` item ` . ` type ` AS ` type ` ,
` item ` . ` wall ` AS ` wall ` ,
` item ` . ` gravity ` AS ` gravity ` ,
` item ` . ` extid ` AS ` extid ` ,
` item ` . ` created ` AS ` created ` ,
` item ` . ` edited ` AS ` edited ` ,
` item ` . ` commented ` AS ` commented ` ,
` item ` . ` received ` AS ` received ` ,
` item ` . ` changed ` AS ` changed ` ,
` item ` . ` resource - id ` AS ` resource - id ` ,
` item ` . ` post - type ` AS ` post - type ` ,
` item ` . ` private ` AS ` private ` ,
` item ` . ` pubmail ` AS ` pubmail ` ,
` item ` . ` moderated ` AS ` moderated ` ,
` item ` . ` visible ` AS ` visible ` ,
` item ` . ` starred ` AS ` starred ` ,
` item ` . ` bookmark ` AS ` bookmark ` ,
` item ` . ` unseen ` AS ` unseen ` ,
` item ` . ` deleted ` AS ` deleted ` ,
` item ` . ` origin ` AS ` origin ` ,
` item ` . ` forum_mode ` AS ` forum_mode ` ,
` item ` . ` mention ` AS ` mention ` ,
` item ` . ` global ` AS ` global ` ,
` item ` . ` network ` AS ` network ` ,
` item ` . ` vid ` AS ` vid ` ,
` item ` . ` psid ` AS ` psid ` ,
` item ` . ` attach ` AS ` attach ` ,
( SELECT COUNT ( * ) FROM ` post - category ` WHERE ` post - category ` . ` uri - id ` = ` item ` . ` uri - id ` ) AS ` internal - file - count ` ,
NULL AS ` file ` ,
IF ( ` item ` . ` vid ` IS NULL , ' ' , ` verb ` . ` name ` ) AS ` verb ` ,
` item - content ` . ` title ` AS ` title ` ,
` item - content ` . ` content - warning ` AS ` content - warning ` ,
` item - content ` . ` raw - body ` AS ` raw - body ` ,
` item - content ` . ` body ` AS ` body ` ,
` item - content ` . ` rendered - hash ` AS ` rendered - hash ` ,
` item - content ` . ` rendered - html ` AS ` rendered - html ` ,
` item - content ` . ` language ` AS ` language ` ,
` item - content ` . ` plink ` AS ` plink ` ,
` item - content ` . ` location ` AS ` location ` ,
` item - content ` . ` coord ` AS ` coord ` ,
` item - content ` . ` app ` AS ` app ` ,
` item - content ` . ` object - type ` AS ` object - type ` ,
` item - content ` . ` object ` AS ` object ` ,
` item - content ` . ` target - type ` AS ` target - type ` ,
` item - content ` . ` target ` AS ` target ` ,
` item ` . ` contact - id ` AS ` contact - id ` ,
` contact ` . ` url ` AS ` contact - link ` ,
` contact ` . ` addr ` AS ` contact - addr ` ,
` contact ` . ` name ` AS ` contact - name ` ,
` contact ` . ` nick ` AS ` contact - nick ` ,
` contact ` . ` thumb ` AS ` contact - avatar ` ,
` contact ` . ` network ` AS ` contact - network ` ,
2021-01-15 12:31:24 +01:00
` contact ` . ` blocked ` AS ` contact - blocked ` ,
2021-01-17 21:32:13 +01:00
` contact ` . ` hidden ` AS ` contact - hidden ` ,
2021-01-15 12:46:57 +01:00
` contact ` . ` readonly ` AS ` contact - readonly ` ,
2021-01-17 21:32:13 +01:00
` contact ` . ` archive ` AS ` contact - archive ` ,
2021-01-15 12:46:57 +01:00
` contact ` . ` pending ` AS ` contact - pending ` ,
` contact ` . ` rel ` AS ` contact - rel ` ,
2021-01-14 23:51:44 +01:00
` contact ` . ` uid ` AS ` contact - uid ` ,
2021-01-17 21:32:13 +01:00
` contact ` . ` contact - type ` AS ` contact - contact - type ` ,
2021-01-14 23:51:44 +01:00
IF ( ` item ` . ` network ` IN ( ' apub ' , ' dfrn ' , ' dspr ' , ' stat ' ) , true , ` contact ` . ` writable ` ) AS ` writable ` ,
` contact ` . ` self ` AS ` self ` ,
` contact ` . ` id ` AS ` cid ` ,
` contact ` . ` alias ` AS ` alias ` ,
` contact ` . ` photo ` AS ` photo ` ,
` contact ` . ` name - date ` AS ` name - date ` ,
` contact ` . ` uri - date ` AS ` uri - date ` ,
` contact ` . ` avatar - date ` AS ` avatar - date ` ,
` contact ` . ` thumb ` AS ` thumb ` ,
` contact ` . ` dfrn - id ` AS ` dfrn - id ` ,
` item ` . ` author - id ` AS ` author - id ` ,
` author ` . ` url ` AS ` author - link ` ,
` author ` . ` addr ` AS ` author - addr ` ,
2021-01-19 08:23:01 +01:00
IF ( ` contact ` . ` url ` = ` author ` . ` url ` AND ` contact ` . ` name ` ! = ' ' , ` contact ` . ` name ` , ` author ` . ` name ` ) AS ` author - name ` ,
2021-01-14 23:51:44 +01:00
` author ` . ` nick ` AS ` author - nick ` ,
2021-01-19 08:23:01 +01:00
IF ( ` contact ` . ` url ` = ` author ` . ` url ` AND ` contact ` . ` thumb ` ! = ' ' , ` contact ` . ` thumb ` , ` author ` . ` thumb ` ) AS ` author - avatar ` ,
2021-01-14 23:51:44 +01:00
` author ` . ` network ` AS ` author - network ` ,
2021-01-15 12:31:24 +01:00
` author ` . ` blocked ` AS ` author - blocked ` ,
2021-01-16 23:37:27 +01:00
` author ` . ` hidden ` AS ` author - hidden ` ,
2021-01-14 23:51:44 +01:00
` item ` . ` owner - id ` AS ` owner - id ` ,
` owner ` . ` url ` AS ` owner - link ` ,
` owner ` . ` addr ` AS ` owner - addr ` ,
2021-01-19 08:23:01 +01:00
IF ( ` contact ` . ` url ` = ` owner ` . ` url ` AND ` contact ` . ` name ` ! = ' ' , ` contact ` . ` name ` , ` owner ` . ` name ` ) AS ` owner - name ` ,
2021-01-14 23:51:44 +01:00
` owner ` . ` nick ` AS ` owner - nick ` ,
2021-01-19 08:23:01 +01:00
IF ( ` contact ` . ` url ` = ` owner ` . ` url ` AND ` contact ` . ` thumb ` ! = ' ' , ` contact ` . ` thumb ` , ` owner ` . ` thumb ` ) AS ` owner - avatar ` ,
2021-01-14 23:51:44 +01:00
` owner ` . ` network ` AS ` owner - network ` ,
2021-01-15 12:31:24 +01:00
` owner ` . ` blocked ` AS ` owner - blocked ` ,
2021-01-16 23:37:27 +01:00
` owner ` . ` hidden ` AS ` owner - hidden ` ,
2021-01-14 23:51:44 +01:00
` item ` . ` causer - id ` AS ` causer - id ` ,
` causer ` . ` url ` AS ` causer - link ` ,
` causer ` . ` addr ` AS ` causer - addr ` ,
` causer ` . ` name ` AS ` causer - name ` ,
` causer ` . ` nick ` AS ` causer - nick ` ,
` causer ` . ` thumb ` AS ` causer - avatar ` ,
` causer ` . ` network ` AS ` causer - network ` ,
2021-01-15 12:31:24 +01:00
` causer ` . ` blocked ` AS ` causer - blocked ` ,
2021-01-16 23:37:27 +01:00
` causer ` . ` hidden ` AS ` causer - hidden ` ,
2021-01-14 23:51:44 +01:00
` causer ` . ` contact - type ` AS ` causer - contact - type ` ,
` post - delivery - data ` . ` postopts ` AS ` postopts ` ,
` post - delivery - data ` . ` inform ` AS ` inform ` ,
` post - delivery - data ` . ` queue_count ` AS ` delivery_queue_count ` ,
` post - delivery - data ` . ` queue_done ` AS ` delivery_queue_done ` ,
` post - delivery - data ` . ` queue_failed ` AS ` delivery_queue_failed ` ,
IF ( ` item ` . ` psid ` IS NULL , ' ' , ` permissionset ` . ` allow_cid ` ) AS ` allow_cid ` ,
IF ( ` item ` . ` psid ` IS NULL , ' ' , ` permissionset ` . ` allow_gid ` ) AS ` allow_gid ` ,
IF ( ` item ` . ` psid ` IS NULL , ' ' , ` permissionset ` . ` deny_cid ` ) AS ` deny_cid ` ,
IF ( ` item ` . ` psid ` IS NULL , ' ' , ` permissionset ` . ` deny_gid ` ) AS ` deny_gid ` ,
` item ` . ` event - id ` AS ` event - id ` ,
` event ` . ` created ` AS ` event - created ` ,
` event ` . ` edited ` AS ` event - edited ` ,
` event ` . ` start ` AS ` event - start ` ,
` event ` . ` finish ` AS ` event - finish ` ,
` event ` . ` summary ` AS ` event - summary ` ,
` event ` . ` desc ` AS ` event - desc ` ,
` event ` . ` location ` AS ` event - location ` ,
` event ` . ` type ` AS ` event - type ` ,
` event ` . ` nofinish ` AS ` event - nofinish ` ,
` event ` . ` adjust ` AS ` event - adjust ` ,
` event ` . ` ignore ` AS ` event - ignore ` ,
` diaspora - interaction ` . ` interaction ` AS ` signed_text ` ,
` parent - item ` . ` guid ` AS ` parent - guid ` ,
` parent - item ` . ` network ` AS ` parent - network ` ,
` parent - item ` . ` author - id ` AS ` parent - author - id ` ,
` parent - item - author ` . ` url ` AS ` parent - author - link ` ,
` parent - item - author ` . ` name ` AS ` parent - author - name ` ,
` parent - item - author ` . ` network ` AS ` parent - author - network `
FROM ` item `
STRAIGHT_JOIN ` contact ` ON ` contact ` . ` id ` = ` item ` . ` contact - id `
STRAIGHT_JOIN ` contact ` AS ` author ` ON ` author ` . ` id ` = ` item ` . ` author - id `
STRAIGHT_JOIN ` contact ` AS ` owner ` ON ` owner ` . ` id ` = ` item ` . ` owner - id `
STRAIGHT_JOIN ` contact ` AS ` causer ` ON ` causer ` . ` id ` = ` item ` . ` causer - id `
LEFT JOIN ` verb ` ON ` verb ` . ` id ` = ` item ` . ` vid `
LEFT JOIN ` event ` ON ` event ` . ` id ` = ` item ` . ` event - id `
LEFT JOIN ` diaspora - interaction ` ON ` diaspora - interaction ` . ` uri - id ` = ` item ` . ` uri - id `
LEFT JOIN ` item - content ` ON ` item - content ` . ` uri - id ` = ` item ` . ` uri - id `
LEFT JOIN ` post - delivery - data ` ON ` post - delivery - data ` . ` uri - id ` = ` item ` . ` uri - id ` AND ` item ` . ` origin `
LEFT JOIN ` permissionset ` ON ` permissionset ` . ` id ` = ` item ` . ` psid `
2021-01-18 08:10:04 +01:00
STRAIGHT_JOIN ` item ` AS ` parent - item ` ON ` parent - item ` . ` uri - id ` = ` item ` . ` parent - uri - id ` AND ` parent - item ` . ` uid ` = ` item ` . ` uid `
STRAIGHT_JOIN ` contact ` AS ` parent - item - author ` ON ` parent - item - author ` . ` id ` = ` parent - item ` . ` author - id ` ;
--
-- VIEW post-thread-view
--
DROP VIEW IF EXISTS ` post - thread - view ` ;
CREATE VIEW ` post - thread - view ` AS SELECT
` item ` . ` id ` AS ` id ` ,
` thread ` . ` iid ` AS ` iid ` ,
` item ` . ` id ` AS ` item_id ` ,
` thread ` . ` uid ` AS ` uid ` ,
` item ` . ` uid ` AS ` internal - uid ` ,
` item ` . ` parent ` AS ` parent ` ,
` item ` . ` uri ` AS ` uri ` ,
` item ` . ` uri - id ` AS ` uri - id ` ,
` item ` . ` uri - id ` AS ` internal - uri - id ` ,
` item ` . ` parent - uri ` AS ` parent - uri ` ,
` item ` . ` parent - uri - id ` AS ` parent - uri - id ` ,
` item ` . ` thr - parent ` AS ` thr - parent ` ,
` item ` . ` thr - parent - id ` AS ` thr - parent - id ` ,
` item ` . ` guid ` AS ` guid ` ,
` item ` . ` type ` AS ` type ` ,
` thread ` . ` wall ` AS ` wall ` ,
` item ` . ` gravity ` AS ` gravity ` ,
` item ` . ` extid ` AS ` extid ` ,
` thread ` . ` created ` AS ` created ` ,
2021-01-19 08:23:01 +01:00
` item ` . ` edited ` AS ` edited ` ,
2021-01-18 08:10:04 +01:00
` thread ` . ` commented ` AS ` commented ` ,
` thread ` . ` received ` AS ` received ` ,
` thread ` . ` changed ` AS ` changed ` ,
` item ` . ` resource - id ` AS ` resource - id ` ,
` thread ` . ` post - type ` AS ` post - type ` ,
` thread ` . ` private ` AS ` private ` ,
` thread ` . ` pubmail ` AS ` pubmail ` ,
` thread ` . ` moderated ` AS ` moderated ` ,
` thread ` . ` ignored ` AS ` ignored ` ,
` thread ` . ` visible ` AS ` visible ` ,
` thread ` . ` starred ` AS ` starred ` ,
` item ` . ` bookmark ` AS ` bookmark ` ,
` item ` . ` unseen ` AS ` unseen ` ,
` thread ` . ` deleted ` AS ` deleted ` ,
` thread ` . ` origin ` AS ` origin ` ,
` thread ` . ` forum_mode ` AS ` forum_mode ` ,
` thread ` . ` mention ` AS ` mention ` ,
` item ` . ` global ` AS ` global ` ,
` thread ` . ` network ` AS ` network ` ,
` item ` . ` vid ` AS ` vid ` ,
` item ` . ` psid ` AS ` psid ` ,
` item ` . ` attach ` AS ` attach ` ,
( SELECT COUNT ( * ) FROM ` post - category ` WHERE ` post - category ` . ` uri - id ` = ` item ` . ` uri - id ` ) AS ` internal - file - count ` ,
NULL AS ` file ` ,
IF ( ` item ` . ` vid ` IS NULL , ' ' , ` verb ` . ` name ` ) AS ` verb ` ,
` item - content ` . ` title ` AS ` title ` ,
` item - content ` . ` content - warning ` AS ` content - warning ` ,
` item - content ` . ` raw - body ` AS ` raw - body ` ,
` item - content ` . ` body ` AS ` body ` ,
` item - content ` . ` rendered - hash ` AS ` rendered - hash ` ,
` item - content ` . ` rendered - html ` AS ` rendered - html ` ,
` item - content ` . ` language ` AS ` language ` ,
` item - content ` . ` plink ` AS ` plink ` ,
` item - content ` . ` location ` AS ` location ` ,
` item - content ` . ` coord ` AS ` coord ` ,
` item - content ` . ` app ` AS ` app ` ,
` item - content ` . ` object - type ` AS ` object - type ` ,
` item - content ` . ` object ` AS ` object ` ,
` item - content ` . ` target - type ` AS ` target - type ` ,
` item - content ` . ` target ` AS ` target ` ,
` thread ` . ` contact - id ` AS ` contact - id ` ,
` contact ` . ` url ` AS ` contact - link ` ,
` contact ` . ` addr ` AS ` contact - addr ` ,
` contact ` . ` name ` AS ` contact - name ` ,
` contact ` . ` nick ` AS ` contact - nick ` ,
` contact ` . ` thumb ` AS ` contact - avatar ` ,
` contact ` . ` network ` AS ` contact - network ` ,
` contact ` . ` blocked ` AS ` contact - blocked ` ,
` contact ` . ` hidden ` AS ` contact - hidden ` ,
` contact ` . ` readonly ` AS ` contact - readonly ` ,
` contact ` . ` archive ` AS ` contact - archive ` ,
` contact ` . ` pending ` AS ` contact - pending ` ,
` contact ` . ` rel ` AS ` contact - rel ` ,
` contact ` . ` uid ` AS ` contact - uid ` ,
` contact ` . ` contact - type ` AS ` contact - contact - type ` ,
IF ( ` item ` . ` network ` IN ( ' apub ' , ' dfrn ' , ' dspr ' , ' stat ' ) , true , ` contact ` . ` writable ` ) AS ` writable ` ,
` contact ` . ` self ` AS ` self ` ,
` contact ` . ` id ` AS ` cid ` ,
` contact ` . ` alias ` AS ` alias ` ,
` contact ` . ` photo ` AS ` photo ` ,
` contact ` . ` name - date ` AS ` name - date ` ,
` contact ` . ` uri - date ` AS ` uri - date ` ,
` contact ` . ` avatar - date ` AS ` avatar - date ` ,
` contact ` . ` thumb ` AS ` thumb ` ,
` contact ` . ` dfrn - id ` AS ` dfrn - id ` ,
` thread ` . ` author - id ` AS ` author - id ` ,
` author ` . ` url ` AS ` author - link ` ,
` author ` . ` addr ` AS ` author - addr ` ,
2021-01-19 08:23:01 +01:00
IF ( ` contact ` . ` url ` = ` author ` . ` url ` AND ` contact ` . ` name ` ! = ' ' , ` contact ` . ` name ` , ` author ` . ` name ` ) AS ` author - name ` ,
2021-01-18 08:10:04 +01:00
` author ` . ` nick ` AS ` author - nick ` ,
2021-01-19 08:23:01 +01:00
IF ( ` contact ` . ` url ` = ` author ` . ` url ` AND ` contact ` . ` thumb ` ! = ' ' , ` contact ` . ` thumb ` , ` author ` . ` thumb ` ) AS ` author - avatar ` ,
2021-01-18 08:10:04 +01:00
` author ` . ` network ` AS ` author - network ` ,
` author ` . ` blocked ` AS ` author - blocked ` ,
` author ` . ` hidden ` AS ` author - hidden ` ,
` thread ` . ` owner - id ` AS ` owner - id ` ,
` owner ` . ` url ` AS ` owner - link ` ,
` owner ` . ` addr ` AS ` owner - addr ` ,
2021-01-19 08:23:01 +01:00
IF ( ` contact ` . ` url ` = ` owner ` . ` url ` AND ` contact ` . ` name ` ! = ' ' , ` contact ` . ` name ` , ` owner ` . ` name ` ) AS ` owner - name ` ,
2021-01-18 08:10:04 +01:00
` owner ` . ` nick ` AS ` owner - nick ` ,
2021-01-19 08:23:01 +01:00
IF ( ` contact ` . ` url ` = ` owner ` . ` url ` AND ` contact ` . ` thumb ` ! = ' ' , ` contact ` . ` thumb ` , ` owner ` . ` thumb ` ) AS ` owner - avatar ` ,
2021-01-18 08:10:04 +01:00
` owner ` . ` network ` AS ` owner - network ` ,
` owner ` . ` blocked ` AS ` owner - blocked ` ,
` owner ` . ` hidden ` AS ` owner - hidden ` ,
` item ` . ` causer - id ` AS ` causer - id ` ,
` causer ` . ` url ` AS ` causer - link ` ,
` causer ` . ` addr ` AS ` causer - addr ` ,
` causer ` . ` name ` AS ` causer - name ` ,
` causer ` . ` nick ` AS ` causer - nick ` ,
` causer ` . ` thumb ` AS ` causer - avatar ` ,
` causer ` . ` network ` AS ` causer - network ` ,
` causer ` . ` blocked ` AS ` causer - blocked ` ,
` causer ` . ` hidden ` AS ` causer - hidden ` ,
` causer ` . ` contact - type ` AS ` causer - contact - type ` ,
` post - delivery - data ` . ` postopts ` AS ` postopts ` ,
` post - delivery - data ` . ` inform ` AS ` inform ` ,
` post - delivery - data ` . ` queue_count ` AS ` delivery_queue_count ` ,
` post - delivery - data ` . ` queue_done ` AS ` delivery_queue_done ` ,
` post - delivery - data ` . ` queue_failed ` AS ` delivery_queue_failed ` ,
IF ( ` item ` . ` psid ` IS NULL , ' ' , ` permissionset ` . ` allow_cid ` ) AS ` allow_cid ` ,
IF ( ` item ` . ` psid ` IS NULL , ' ' , ` permissionset ` . ` allow_gid ` ) AS ` allow_gid ` ,
IF ( ` item ` . ` psid ` IS NULL , ' ' , ` permissionset ` . ` deny_cid ` ) AS ` deny_cid ` ,
IF ( ` item ` . ` psid ` IS NULL , ' ' , ` permissionset ` . ` deny_gid ` ) AS ` deny_gid ` ,
` item ` . ` event - id ` AS ` event - id ` ,
` event ` . ` created ` AS ` event - created ` ,
` event ` . ` edited ` AS ` event - edited ` ,
` event ` . ` start ` AS ` event - start ` ,
` event ` . ` finish ` AS ` event - finish ` ,
` event ` . ` summary ` AS ` event - summary ` ,
` event ` . ` desc ` AS ` event - desc ` ,
` event ` . ` location ` AS ` event - location ` ,
` event ` . ` type ` AS ` event - type ` ,
` event ` . ` nofinish ` AS ` event - nofinish ` ,
` event ` . ` adjust ` AS ` event - adjust ` ,
` event ` . ` ignore ` AS ` event - ignore ` ,
` diaspora - interaction ` . ` interaction ` AS ` signed_text ` ,
` parent - item ` . ` guid ` AS ` parent - guid ` ,
` parent - item ` . ` network ` AS ` parent - network ` ,
` parent - item ` . ` author - id ` AS ` parent - author - id ` ,
` parent - item - author ` . ` url ` AS ` parent - author - link ` ,
` parent - item - author ` . ` name ` AS ` parent - author - name ` ,
` parent - item - author ` . ` network ` AS ` parent - author - network `
FROM ` thread `
STRAIGHT_JOIN ` item ` ON ` item ` . ` id ` = ` thread ` . ` iid `
STRAIGHT_JOIN ` contact ` ON ` contact ` . ` id ` = ` thread ` . ` contact - id `
STRAIGHT_JOIN ` contact ` AS ` author ` ON ` author ` . ` id ` = ` thread ` . ` author - id `
STRAIGHT_JOIN ` contact ` AS ` owner ` ON ` owner ` . ` id ` = ` thread ` . ` owner - id `
STRAIGHT_JOIN ` contact ` AS ` causer ` ON ` causer ` . ` id ` = ` item ` . ` causer - id `
LEFT JOIN ` verb ` ON ` verb ` . ` id ` = ` item ` . ` vid `
LEFT JOIN ` event ` ON ` event ` . ` id ` = ` item ` . ` event - id `
LEFT JOIN ` diaspora - interaction ` ON ` diaspora - interaction ` . ` uri - id ` = ` thread ` . ` uri - id `
LEFT JOIN ` item - content ` ON ` item - content ` . ` uri - id ` = ` thread ` . ` uri - id `
LEFT JOIN ` post - delivery - data ` ON ` post - delivery - data ` . ` uri - id ` = ` thread ` . ` uri - id ` AND ` thread ` . ` origin `
LEFT JOIN ` permissionset ` ON ` permissionset ` . ` id ` = ` item ` . ` psid `
2021-01-19 08:23:01 +01:00
STRAIGHT_JOIN ` item ` AS ` parent - item ` ON ` parent - item ` . ` id ` = ` item ` . ` parent `
2021-01-14 23:51:44 +01:00
STRAIGHT_JOIN ` contact ` AS ` parent - item - author ` ON ` parent - item - author ` . ` id ` = ` parent - item ` . ` author - id ` ;
2020-05-04 17:23:45 +02:00
--
-- VIEW category-view
--
2020-12-02 09:50:45 +01:00
DROP VIEW IF EXISTS ` category - view ` ;
2020-05-04 17:23:45 +02:00
CREATE VIEW ` category - view ` AS SELECT
` post - category ` . ` uri - id ` AS ` uri - id ` ,
` post - category ` . ` uid ` AS ` uid ` ,
` item - uri ` . ` uri ` AS ` uri ` ,
` item - uri ` . ` guid ` AS ` guid ` ,
` post - category ` . ` type ` AS ` type ` ,
` post - category ` . ` tid ` AS ` tid ` ,
` tag ` . ` name ` AS ` name ` ,
` tag ` . ` url ` AS ` url `
FROM ` post - category `
INNER JOIN ` item - uri ` ON ` item - uri ` . id = ` post - category ` . ` uri - id `
LEFT JOIN ` tag ` ON ` post - category ` . ` tid ` = ` tag ` . ` id ` ;
2020-04-23 08:19:44 +02:00
--
-- VIEW tag-view
--
2020-12-02 09:50:45 +01:00
DROP VIEW IF EXISTS ` tag - view ` ;
2020-04-23 08:19:44 +02:00
CREATE VIEW ` tag - view ` AS SELECT
` post - tag ` . ` uri - id ` AS ` uri - id ` ,
` item - uri ` . ` uri ` AS ` uri ` ,
` item - uri ` . ` guid ` AS ` guid ` ,
` post - tag ` . ` type ` AS ` type ` ,
` post - tag ` . ` tid ` AS ` tid ` ,
` post - tag ` . ` cid ` AS ` cid ` ,
CASE ` cid ` WHEN 0 THEN ` tag ` . ` name ` ELSE ` contact ` . ` name ` END AS ` name ` ,
CASE ` cid ` WHEN 0 THEN ` tag ` . ` url ` ELSE ` contact ` . ` url ` END AS ` url `
FROM ` post - tag `
INNER JOIN ` item - uri ` ON ` item - uri ` . id = ` post - tag ` . ` uri - id `
LEFT JOIN ` tag ` ON ` post - tag ` . ` tid ` = ` tag ` . ` id `
LEFT JOIN ` contact ` ON ` post - tag ` . ` cid ` = ` contact ` . ` id ` ;
2020-08-15 13:31:34 +02:00
--
-- VIEW network-item-view
--
2020-12-02 09:50:45 +01:00
DROP VIEW IF EXISTS ` network - item - view ` ;
2020-08-15 13:31:34 +02:00
CREATE VIEW ` network - item - view ` AS SELECT
` item ` . ` parent - uri - id ` AS ` uri - id ` ,
` item ` . ` parent - uri ` AS ` uri ` ,
` item ` . ` parent ` AS ` parent ` ,
` item ` . ` received ` AS ` received ` ,
` item ` . ` commented ` AS ` commented ` ,
` item ` . ` created ` AS ` created ` ,
` item ` . ` uid ` AS ` uid ` ,
` item ` . ` starred ` AS ` starred ` ,
` item ` . ` mention ` AS ` mention ` ,
` item ` . ` network ` AS ` network ` ,
` item ` . ` unseen ` AS ` unseen ` ,
` item ` . ` gravity ` AS ` gravity ` ,
2020-10-05 18:50:38 +02:00
` item ` . ` contact - id ` AS ` contact - id ` ,
` ownercontact ` . ` contact - type ` AS ` contact - type `
2020-08-15 13:31:34 +02:00
FROM ` item `
INNER JOIN ` thread ` ON ` thread ` . ` iid ` = ` item ` . ` parent `
2020-08-19 21:10:30 +02:00
STRAIGHT_JOIN ` contact ` ON ` contact ` . ` id ` = ` thread ` . ` contact - id `
2020-08-15 13:31:34 +02:00
LEFT JOIN ` user - item ` ON ` user - item ` . ` iid ` = ` item ` . ` id ` AND ` user - item ` . ` uid ` = ` thread ` . ` uid `
LEFT JOIN ` user - contact ` AS ` author ` ON ` author ` . ` uid ` = ` thread ` . ` uid ` AND ` author ` . ` cid ` = ` thread ` . ` author - id `
LEFT JOIN ` user - contact ` AS ` owner ` ON ` owner ` . ` uid ` = ` thread ` . ` uid ` AND ` owner ` . ` cid ` = ` thread ` . ` owner - id `
2020-10-05 18:50:38 +02:00
LEFT JOIN ` contact ` AS ` ownercontact ` ON ` ownercontact ` . ` id ` = ` thread ` . ` owner - id `
2020-08-15 13:31:34 +02:00
WHERE ` thread ` . ` visible ` AND NOT ` thread ` . ` deleted ` AND NOT ` thread ` . ` moderated `
2020-08-19 21:10:30 +02:00
AND ( NOT ` contact ` . ` readonly ` AND NOT ` contact ` . ` blocked ` AND NOT ` contact ` . ` pending ` )
2020-08-15 13:31:34 +02:00
AND ( ` user - item ` . ` hidden ` IS NULL OR NOT ` user - item ` . ` hidden ` )
AND ( ` author ` . ` blocked ` IS NULL OR NOT ` author ` . ` blocked ` )
AND ( ` owner ` . ` blocked ` IS NULL OR NOT ` owner ` . ` blocked ` ) ;
2020-08-15 14:06:18 +02:00
--
-- VIEW network-thread-view
--
2020-12-02 09:50:45 +01:00
DROP VIEW IF EXISTS ` network - thread - view ` ;
2020-08-15 14:06:18 +02:00
CREATE VIEW ` network - thread - view ` AS SELECT
` item ` . ` uri - id ` AS ` uri - id ` ,
` item ` . ` uri ` AS ` uri ` ,
` item ` . ` parent - uri - id ` AS ` parent - uri - id ` ,
` thread ` . ` iid ` AS ` parent ` ,
` thread ` . ` received ` AS ` received ` ,
` thread ` . ` commented ` AS ` commented ` ,
` thread ` . ` created ` AS ` created ` ,
` thread ` . ` uid ` AS ` uid ` ,
` thread ` . ` starred ` AS ` starred ` ,
` thread ` . ` mention ` AS ` mention ` ,
` thread ` . ` network ` AS ` network ` ,
2020-10-05 18:50:38 +02:00
` thread ` . ` contact - id ` AS ` contact - id ` ,
` ownercontact ` . ` contact - type ` AS ` contact - type `
2020-08-15 14:06:18 +02:00
FROM ` thread `
2020-08-19 21:10:30 +02:00
STRAIGHT_JOIN ` contact ` ON ` contact ` . ` id ` = ` thread ` . ` contact - id `
2020-08-15 14:06:18 +02:00
STRAIGHT_JOIN ` item ` ON ` item ` . ` id ` = ` thread ` . ` iid `
LEFT JOIN ` user - item ` ON ` user - item ` . ` iid ` = ` item ` . ` id ` AND ` user - item ` . ` uid ` = ` thread ` . ` uid `
LEFT JOIN ` user - contact ` AS ` author ` ON ` author ` . ` uid ` = ` thread ` . ` uid ` AND ` author ` . ` cid ` = ` thread ` . ` author - id `
LEFT JOIN ` user - contact ` AS ` owner ` ON ` owner ` . ` uid ` = ` thread ` . ` uid ` AND ` owner ` . ` cid ` = ` thread ` . ` owner - id `
2020-10-05 18:50:38 +02:00
LEFT JOIN ` contact ` AS ` ownercontact ` ON ` ownercontact ` . ` id ` = ` thread ` . ` owner - id `
2020-08-15 14:06:18 +02:00
WHERE ` thread ` . ` visible ` AND NOT ` thread ` . ` deleted ` AND NOT ` thread ` . ` moderated `
2020-08-19 21:10:30 +02:00
AND ( NOT ` contact ` . ` readonly ` AND NOT ` contact ` . ` blocked ` AND NOT ` contact ` . ` pending ` )
2020-08-15 14:06:18 +02:00
AND ( ` user - item ` . ` hidden ` IS NULL OR NOT ` user - item ` . ` hidden ` )
AND ( ` author ` . ` blocked ` IS NULL OR NOT ` author ` . ` blocked ` )
AND ( ` owner ` . ` blocked ` IS NULL OR NOT ` owner ` . ` blocked ` ) ;
2020-04-24 15:43:07 +02:00
--
-- VIEW owner-view
--
2020-12-02 09:50:45 +01:00
DROP VIEW IF EXISTS ` owner - view ` ;
2020-04-24 15:43:07 +02:00
CREATE VIEW ` owner - view ` AS SELECT
` contact ` . ` id ` AS ` id ` ,
` contact ` . ` uid ` AS ` uid ` ,
` contact ` . ` created ` AS ` created ` ,
` contact ` . ` updated ` AS ` updated ` ,
` contact ` . ` self ` AS ` self ` ,
` contact ` . ` remote_self ` AS ` remote_self ` ,
` contact ` . ` rel ` AS ` rel ` ,
` contact ` . ` duplex ` AS ` duplex ` ,
` contact ` . ` network ` AS ` network ` ,
` contact ` . ` protocol ` AS ` protocol ` ,
` contact ` . ` name ` AS ` name ` ,
` contact ` . ` nick ` AS ` nick ` ,
` contact ` . ` location ` AS ` location ` ,
` contact ` . ` about ` AS ` about ` ,
` contact ` . ` keywords ` AS ` keywords ` ,
` contact ` . ` gender ` AS ` gender ` ,
2020-04-28 21:46:59 +02:00
` contact ` . ` xmpp ` AS ` xmpp ` ,
2020-04-24 15:43:07 +02:00
` contact ` . ` attag ` AS ` attag ` ,
` contact ` . ` avatar ` AS ` avatar ` ,
` contact ` . ` photo ` AS ` photo ` ,
` contact ` . ` thumb ` AS ` thumb ` ,
` contact ` . ` micro ` AS ` micro ` ,
` contact ` . ` site - pubkey ` AS ` site - pubkey ` ,
` contact ` . ` issued - id ` AS ` issued - id ` ,
` contact ` . ` dfrn - id ` AS ` dfrn - id ` ,
` contact ` . ` url ` AS ` url ` ,
` contact ` . ` nurl ` AS ` nurl ` ,
` contact ` . ` addr ` AS ` addr ` ,
` contact ` . ` alias ` AS ` alias ` ,
` contact ` . ` pubkey ` AS ` pubkey ` ,
` contact ` . ` prvkey ` AS ` prvkey ` ,
` contact ` . ` batch ` AS ` batch ` ,
` contact ` . ` request ` AS ` request ` ,
` contact ` . ` notify ` AS ` notify ` ,
` contact ` . ` poll ` AS ` poll ` ,
` contact ` . ` confirm ` AS ` confirm ` ,
` contact ` . ` poco ` AS ` poco ` ,
` contact ` . ` aes_allow ` AS ` aes_allow ` ,
` contact ` . ` ret - aes ` AS ` ret - aes ` ,
` contact ` . ` usehub ` AS ` usehub ` ,
` contact ` . ` subhub ` AS ` subhub ` ,
` contact ` . ` hub - verify ` AS ` hub - verify ` ,
` contact ` . ` last - update ` AS ` last - update ` ,
` contact ` . ` success_update ` AS ` success_update ` ,
` contact ` . ` failure_update ` AS ` failure_update ` ,
` contact ` . ` name - date ` AS ` name - date ` ,
` contact ` . ` uri - date ` AS ` uri - date ` ,
` contact ` . ` avatar - date ` AS ` avatar - date ` ,
` contact ` . ` avatar - date ` AS ` picdate ` ,
` contact ` . ` term - date ` AS ` term - date ` ,
` contact ` . ` last - item ` AS ` last - item ` ,
` contact ` . ` priority ` AS ` priority ` ,
2020-11-08 08:23:28 +01:00
` user ` . ` blocked ` AS ` blocked ` ,
2020-04-24 15:43:07 +02:00
` contact ` . ` block_reason ` AS ` block_reason ` ,
` contact ` . ` readonly ` AS ` readonly ` ,
` contact ` . ` writable ` AS ` writable ` ,
` contact ` . ` forum ` AS ` forum ` ,
` contact ` . ` prv ` AS ` prv ` ,
` contact ` . ` contact - type ` AS ` contact - type ` ,
2020-09-02 05:18:04 +02:00
` contact ` . ` manually - approve ` AS ` manually - approve ` ,
2020-04-24 15:43:07 +02:00
` contact ` . ` hidden ` AS ` hidden ` ,
` contact ` . ` archive ` AS ` archive ` ,
` contact ` . ` pending ` AS ` pending ` ,
` contact ` . ` deleted ` AS ` deleted ` ,
` contact ` . ` unsearchable ` AS ` unsearchable ` ,
` contact ` . ` sensitive ` AS ` sensitive ` ,
` contact ` . ` baseurl ` AS ` baseurl ` ,
` contact ` . ` reason ` AS ` reason ` ,
` contact ` . ` closeness ` AS ` closeness ` ,
` contact ` . ` info ` AS ` info ` ,
` contact ` . ` profile - id ` AS ` profile - id ` ,
` contact ` . ` bdyear ` AS ` bdyear ` ,
` contact ` . ` bd ` AS ` bd ` ,
2020-04-28 21:46:59 +02:00
` contact ` . ` notify_new_posts ` AS ` notify_new_posts ` ,
` contact ` . ` fetch_further_information ` AS ` fetch_further_information ` ,
2020-06-06 22:43:23 +02:00
` contact ` . ` ffi_keyword_denylist ` AS ` ffi_keyword_denylist ` ,
2020-04-28 21:46:59 +02:00
` user ` . ` parent - uid ` AS ` parent - uid ` ,
2020-04-24 15:43:07 +02:00
` user ` . ` guid ` AS ` guid ` ,
2020-04-28 21:46:59 +02:00
` user ` . ` nickname ` AS ` nickname ` ,
2020-04-24 15:43:07 +02:00
` user ` . ` email ` AS ` email ` ,
2020-04-28 21:46:59 +02:00
` user ` . ` openid ` AS ` openid ` ,
2020-04-24 15:43:07 +02:00
` user ` . ` timezone ` AS ` timezone ` ,
2020-04-28 21:46:59 +02:00
` user ` . ` language ` AS ` language ` ,
` user ` . ` register_date ` AS ` register_date ` ,
` user ` . ` login_date ` AS ` login_date ` ,
` user ` . ` default - location ` AS ` default - location ` ,
` user ` . ` allow_location ` AS ` allow_location ` ,
` user ` . ` theme ` AS ` theme ` ,
` user ` . ` pubkey ` AS ` upubkey ` ,
` user ` . ` prvkey ` AS ` uprvkey ` ,
2020-04-24 15:43:07 +02:00
` user ` . ` sprvkey ` AS ` sprvkey ` ,
` user ` . ` spubkey ` AS ` spubkey ` ,
2020-04-28 21:46:59 +02:00
` user ` . ` verified ` AS ` verified ` ,
` user ` . ` blockwall ` AS ` blockwall ` ,
` user ` . ` hidewall ` AS ` hidewall ` ,
` user ` . ` blocktags ` AS ` blocktags ` ,
` user ` . ` unkmail ` AS ` unkmail ` ,
` user ` . ` cntunkmail ` AS ` cntunkmail ` ,
` user ` . ` notify - flags ` AS ` notify - flags ` ,
2020-04-24 15:43:07 +02:00
` user ` . ` page - flags ` AS ` page - flags ` ,
` user ` . ` account - type ` AS ` account - type ` ,
` user ` . ` prvnets ` AS ` prvnets ` ,
2020-04-28 21:46:59 +02:00
` user ` . ` maxreq ` AS ` maxreq ` ,
2020-04-24 15:43:07 +02:00
` user ` . ` expire ` AS ` expire ` ,
2020-04-28 21:46:59 +02:00
` user ` . ` account_removed ` AS ` account_removed ` ,
2020-04-24 15:43:07 +02:00
` user ` . ` account_expired ` AS ` account_expired ` ,
` user ` . ` account_expires_on ` AS ` account_expires_on ` ,
2020-04-28 21:46:59 +02:00
` user ` . ` expire_notification_sent ` AS ` expire_notification_sent ` ,
` user ` . ` def_gid ` AS ` def_gid ` ,
` user ` . ` allow_cid ` AS ` allow_cid ` ,
` user ` . ` allow_gid ` AS ` allow_gid ` ,
` user ` . ` deny_cid ` AS ` deny_cid ` ,
` user ` . ` deny_gid ` AS ` deny_gid ` ,
` user ` . ` openidserver ` AS ` openidserver ` ,
2020-04-24 15:43:07 +02:00
` profile ` . ` publish ` AS ` publish ` ,
` profile ` . ` net - publish ` AS ` net - publish ` ,
` profile ` . ` hide - friends ` AS ` hide - friends ` ,
` profile ` . ` prv_keywords ` AS ` prv_keywords ` ,
` profile ` . ` pub_keywords ` AS ` pub_keywords ` ,
` profile ` . ` address ` AS ` address ` ,
` profile ` . ` locality ` AS ` locality ` ,
` profile ` . ` region ` AS ` region ` ,
` profile ` . ` postal - code ` AS ` postal - code ` ,
` profile ` . ` country - name ` AS ` country - name ` ,
` profile ` . ` homepage ` AS ` homepage ` ,
` profile ` . ` dob ` AS ` dob `
FROM ` user `
INNER JOIN ` contact ` ON ` contact ` . ` uid ` = ` user ` . ` uid ` AND ` contact ` . ` self `
INNER JOIN ` profile ` ON ` profile ` . ` uid ` = ` user ` . ` uid ` ;
2020-04-24 17:44:41 +02:00
--
-- VIEW pending-view
--
2020-12-02 09:50:45 +01:00
DROP VIEW IF EXISTS ` pending - view ` ;
2020-04-24 17:44:41 +02:00
CREATE VIEW ` pending - view ` AS SELECT
` register ` . ` id ` AS ` id ` ,
` register ` . ` hash ` AS ` hash ` ,
` register ` . ` created ` AS ` created ` ,
` register ` . ` uid ` AS ` uid ` ,
` register ` . ` password ` AS ` password ` ,
` register ` . ` language ` AS ` language ` ,
` register ` . ` note ` AS ` note ` ,
` contact ` . ` self ` AS ` self ` ,
` contact ` . ` name ` AS ` name ` ,
` contact ` . ` url ` AS ` url ` ,
` contact ` . ` micro ` AS ` micro ` ,
` user ` . ` email ` AS ` email ` ,
` contact ` . ` nick ` AS ` nick `
FROM ` register `
INNER JOIN ` contact ` ON ` register ` . ` uid ` = ` contact ` . ` uid `
INNER JOIN ` user ` ON ` register ` . ` uid ` = ` user ` . ` uid ` ;
2020-05-04 17:23:45 +02:00
--
-- VIEW tag-search-view
--
2020-12-02 09:50:45 +01:00
DROP VIEW IF EXISTS ` tag - search - view ` ;
2020-05-04 17:23:45 +02:00
CREATE VIEW ` tag - search - view ` AS SELECT
` post - tag ` . ` uri - id ` AS ` uri - id ` ,
` item ` . ` id ` AS ` iid ` ,
` item ` . ` uri ` AS ` uri ` ,
` item ` . ` guid ` AS ` guid ` ,
` item ` . ` uid ` AS ` uid ` ,
` item ` . ` private ` AS ` private ` ,
` item ` . ` wall ` AS ` wall ` ,
` item ` . ` origin ` AS ` origin ` ,
` item ` . ` gravity ` AS ` gravity ` ,
` item ` . ` received ` AS ` received ` ,
` tag ` . ` name ` AS ` name `
FROM ` post - tag `
INNER JOIN ` tag ` ON ` tag ` . ` id ` = ` post - tag ` . ` tid `
INNER JOIN ` item ` ON ` item ` . ` uri - id ` = ` post - tag ` . ` uri - id `
WHERE ` post - tag ` . ` type ` = 1 ;
2020-04-28 21:46:59 +02:00
--
-- VIEW workerqueue-view
--
2020-12-02 09:50:45 +01:00
DROP VIEW IF EXISTS ` workerqueue - view ` ;
2020-04-28 21:46:59 +02:00
CREATE VIEW ` workerqueue - view ` AS SELECT
` process ` . ` pid ` AS ` pid ` ,
` workerqueue ` . ` priority ` AS ` priority `
FROM ` process `
INNER JOIN ` workerqueue ` ON ` workerqueue ` . ` pid ` = ` process ` . ` pid `
WHERE NOT ` workerqueue ` . ` done ` ;