-- ------------------------------------------
--- Friendica 2021.06-rc (Siberian Iris)
--- DB_UPDATE_VERSION 1421
+-- Friendica 2021.09-dev (Siberian Iris)
+-- DB_UPDATE_VERSION 1429
-- ------------------------------------------
FOREIGN KEY (`parent-uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='The local users';
+--
+-- TABLE item-uri
+--
+CREATE TABLE IF NOT EXISTS `item-uri` (
+ `id` int unsigned NOT NULL auto_increment,
+ `uri` varbinary(255) NOT NULL COMMENT 'URI of an item',
+ `guid` varbinary(255) COMMENT 'A unique identifier for an item',
+ PRIMARY KEY(`id`),
+ UNIQUE INDEX `uri` (`uri`),
+ INDEX `guid` (`guid`)
+) DEFAULT COLLATE utf8mb4_general_ci COMMENT='URI and GUID for items';
+
--
-- TABLE contact
--
`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)',
+ `header` varchar(255) COMMENT 'Header picture',
`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 '',
+ `uri-id` int unsigned COMMENT 'Id of the item-uri table entry that contains the contact url',
`addr` varchar(255) NOT NULL DEFAULT '' COMMENT '',
`alias` varchar(255) NOT NULL DEFAULT '' COMMENT '',
`pubkey` text COMMENT 'RSA public key 4096 bit',
INDEX `uid_self_contact-type` (`uid`,`self`,`contact-type`),
INDEX `self_network_uid` (`self`,`network`,`uid`),
INDEX `gsid` (`gsid`),
+ INDEX `uri-id` (`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 (`gsid`) REFERENCES `gserver` (`id`) ON UPDATE RESTRICT ON DELETE RESTRICT
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='contact table';
---
--- TABLE item-uri
---
-CREATE TABLE IF NOT EXISTS `item-uri` (
- `id` int unsigned NOT NULL auto_increment,
- `uri` varbinary(255) NOT NULL COMMENT 'URI of an item',
- `guid` varbinary(255) COMMENT 'A unique identifier for an item',
- PRIMARY KEY(`id`),
- UNIQUE INDEX `uri` (`uri`),
- INDEX `guid` (`guid`)
-) DEFAULT COLLATE utf8mb4_general_ci COMMENT='URI and GUID for items';
-
--
-- TABLE tag
--
--
CREATE TABLE IF NOT EXISTS `apcontact` (
`url` varbinary(255) NOT NULL COMMENT 'URL of the contact',
+ `uri-id` int unsigned COMMENT 'Id of the item-uri table entry that contains the apcontact url',
`uuid` varchar(255) COMMENT '',
`type` varchar(20) NOT NULL COMMENT '',
`following` varchar(255) COMMENT '',
`outbox` varchar(255) COMMENT '',
`sharedinbox` varchar(255) COMMENT '',
`manually-approve` boolean COMMENT '',
+ `discoverable` boolean COMMENT 'Mastodon extension: true if profile is published in their directory',
`nick` varchar(255) NOT NULL DEFAULT '' COMMENT '',
`name` varchar(255) COMMENT '',
`about` text COMMENT '',
`photo` varchar(255) COMMENT '',
+ `header` varchar(255) COMMENT 'Header picture',
`addr` varchar(255) COMMENT '',
`alias` varchar(255) COMMENT '',
`pubkey` text COMMENT '',
INDEX `baseurl` (`baseurl`(190)),
INDEX `sharedinbox` (`sharedinbox`(190)),
INDEX `gsid` (`gsid`),
+ UNIQUE INDEX `uri-id` (`uri-id`),
+ FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
FOREIGN KEY (`gsid`) REFERENCES `gserver` (`id`) ON UPDATE RESTRICT ON DELETE RESTRICT
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='ActivityPub compatible contacts - used in the ActivityPub implementation';
`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)',
`uri` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `uri-id` int unsigned COMMENT 'Id of the item-uri table entry that contains the event uri',
`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',
PRIMARY KEY(`id`),
INDEX `uid_start` (`uid`,`start`),
INDEX `cid` (`cid`),
+ INDEX `uri-id` (`uri-id`),
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE,
- FOREIGN KEY (`cid`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
+ FOREIGN KEY (`cid`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
+ FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Events';
--
`id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
`guid` varchar(255) NOT NULL DEFAULT '' COMMENT 'unique id',
`url` varchar(255) NOT NULL DEFAULT '' COMMENT '',
+ `uri-id` int unsigned COMMENT 'Id of the item-uri table entry that contains the fcontact url',
`name` varchar(255) NOT NULL DEFAULT '' COMMENT '',
`photo` varchar(255) NOT NULL DEFAULT '' COMMENT '',
`request` varchar(255) NOT NULL DEFAULT '' 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))
+ UNIQUE INDEX `url` (`url`(190)),
+ UNIQUE INDEX `uri-id` (`uri-id`),
+ FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Diaspora compatible contacts - used in the Diaspora implementation';
--
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Delivery data for items';
+--
+-- TABLE post-link
+--
+CREATE TABLE IF NOT EXISTS `post-link` (
+ `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 'External URL',
+ `mimetype` varchar(60) 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='Post related external links';
+
--
-- TABLE post-media
--
INDEX `post-user-id` (`post-user-id`),
INDEX `commented` (`commented`),
INDEX `uid_received` (`uid`,`received`),
+ INDEX `uid_wall_received` (`uid`,`wall`,`received`),
INDEX `uid_pinned` (`uid`,`pinned`),
INDEX `uid_commented` (`uid`,`commented`),
INDEX `uid_starred` (`uid`,`starred`),
`parent-post`.`author-id` AS `parent-author-id`,
`parent-post-author`.`url` AS `parent-author-link`,
`parent-post-author`.`name` AS `parent-author-name`,
- `parent-post-author`.`network` AS `parent-author-network`
+ `parent-post-author`.`network` AS `parent-author-network`,
+ `parent-post-author`.`blocked` AS `parent-author-blocked`,
+ `parent-post-author`.`hidden` AS `parent-author-hidden`
FROM `post-thread-user`
INNER JOIN `post-user` ON `post-user`.`id` = `post-thread-user`.`post-user-id`
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-thread-user`.`contact-id`
`post-content`.`target-type` AS `target-type`,
`post-content`.`target` AS `target`,
`post-content`.`resource-id` AS `resource-id`,
+ `post`.`author-id` AS `contact-id`,
+ `author`.`url` AS `contact-link`,
+ `author`.`addr` AS `contact-addr`,
+ `author`.`name` AS `contact-name`,
+ `author`.`nick` AS `contact-nick`,
+ `author`.`thumb` AS `contact-avatar`,
+ `author`.`network` AS `contact-network`,
+ `author`.`blocked` AS `contact-blocked`,
+ `author`.`hidden` AS `contact-hidden`,
+ `author`.`readonly` AS `contact-readonly`,
+ `author`.`archive` AS `contact-archive`,
+ `author`.`pending` AS `contact-pending`,
+ `author`.`rel` AS `contact-rel`,
+ `author`.`uid` AS `contact-uid`,
+ `author`.`contact-type` AS `contact-contact-type`,
+ IF (`post`.`network` IN ('apub', 'dfrn', 'dspr', 'stat'), true, `author`.`writable`) AS `writable`,
+ false AS `self`,
+ `author`.`id` AS `cid`,
+ `author`.`alias` AS `alias`,
+ `author`.`photo` AS `photo`,
+ `author`.`name-date` AS `name-date`,
+ `author`.`uri-date` AS `uri-date`,
+ `author`.`avatar-date` AS `avatar-date`,
+ `author`.`thumb` AS `thumb`,
+ `author`.`dfrn-id` AS `dfrn-id`,
`post`.`author-id` AS `author-id`,
`author`.`url` AS `author-link`,
`author`.`addr` AS `author-addr`,
`parent-post`.`author-id` AS `parent-author-id`,
`parent-post-author`.`url` AS `parent-author-link`,
`parent-post-author`.`name` AS `parent-author-name`,
- `parent-post-author`.`network` AS `parent-author-network`
+ `parent-post-author`.`network` AS `parent-author-network`,
+ `parent-post-author`.`blocked` AS `parent-author-blocked`,
+ `parent-post-author`.`hidden` AS `parent-author-hidden`
FROM `post`
STRAIGHT_JOIN `post-thread` ON `post-thread`.`uri-id` = `post`.`parent-uri-id`
STRAIGHT_JOIN `contact` AS `author` ON `author`.`id` = `post`.`author-id`
`post-content`.`target-type` AS `target-type`,
`post-content`.`target` AS `target`,
`post-content`.`resource-id` AS `resource-id`,
+ `post-thread`.`author-id` AS `contact-id`,
+ `author`.`url` AS `contact-link`,
+ `author`.`addr` AS `contact-addr`,
+ `author`.`name` AS `contact-name`,
+ `author`.`nick` AS `contact-nick`,
+ `author`.`thumb` AS `contact-avatar`,
+ `author`.`network` AS `contact-network`,
+ `author`.`blocked` AS `contact-blocked`,
+ `author`.`hidden` AS `contact-hidden`,
+ `author`.`readonly` AS `contact-readonly`,
+ `author`.`archive` AS `contact-archive`,
+ `author`.`pending` AS `contact-pending`,
+ `author`.`rel` AS `contact-rel`,
+ `author`.`uid` AS `contact-uid`,
+ `author`.`contact-type` AS `contact-contact-type`,
+ IF (`post`.`network` IN ('apub', 'dfrn', 'dspr', 'stat'), true, `author`.`writable`) AS `writable`,
+ false AS `self`,
+ `author`.`id` AS `cid`,
+ `author`.`alias` AS `alias`,
+ `author`.`photo` AS `photo`,
+ `author`.`name-date` AS `name-date`,
+ `author`.`uri-date` AS `uri-date`,
+ `author`.`avatar-date` AS `avatar-date`,
+ `author`.`thumb` AS `thumb`,
+ `author`.`dfrn-id` AS `dfrn-id`,
`post-thread`.`author-id` AS `author-id`,
`author`.`url` AS `author-link`,
`author`.`addr` AS `author-addr`,
`parent-post`.`author-id` AS `parent-author-id`,
`parent-post-author`.`url` AS `parent-author-link`,
`parent-post-author`.`name` AS `parent-author-name`,
- `parent-post-author`.`network` AS `parent-author-network`
+ `parent-post-author`.`network` AS `parent-author-network`,
+ `parent-post-author`.`blocked` AS `parent-author-blocked`,
+ `parent-post-author`.`hidden` AS `parent-author-hidden`
FROM `post-thread`
INNER JOIN `post` ON `post`.`uri-id` = `post-thread`.`uri-id`
STRAIGHT_JOIN `contact` AS `author` ON `author`.`id` = `post-thread`.`author-id`
`contact`.`photo` AS `photo`,
`contact`.`thumb` AS `thumb`,
`contact`.`micro` AS `micro`,
+ `contact`.`header` AS `header`,
`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`.`uri-id` AS `uri-id`,
`contact`.`addr` AS `addr`,
`contact`.`alias` AS `alias`,
`contact`.`pubkey` AS `pubkey`,
INNER JOIN `contact` ON `contact`.`uid` = `user`.`uid` AND `contact`.`self`
INNER JOIN `profile` ON `profile`.`uid` = `user`.`uid`;
+--
+-- VIEW account-view
+--
+DROP VIEW IF EXISTS `account-view`;
+CREATE VIEW `account-view` AS SELECT
+ `contact`.`id` AS `id`,
+ `contact`.`url` AS `url`,
+ `contact`.`nurl` AS `nurl`,
+ `contact`.`uri-id` AS `uri-id`,
+ `contact`.`addr` AS `addr`,
+ `contact`.`alias` AS `alias`,
+ `contact`.`name` AS `name`,
+ `contact`.`nick` AS `nick`,
+ `contact`.`about` AS `about`,
+ `contact`.`keywords` AS `keywords`,
+ `contact`.`xmpp` AS `xmpp`,
+ `contact`.`avatar` AS `avatar`,
+ `contact`.`photo` AS `photo`,
+ `contact`.`thumb` AS `thumb`,
+ `contact`.`micro` AS `micro`,
+ `contact`.`header` AS `header`,
+ `contact`.`created` AS `created`,
+ `contact`.`updated` AS `updated`,
+ `contact`.`network` AS `network`,
+ `contact`.`protocol` AS `protocol`,
+ `contact`.`location` AS `location`,
+ `contact`.`attag` AS `attag`,
+ `contact`.`pubkey` AS `pubkey`,
+ `contact`.`prvkey` AS `prvkey`,
+ `contact`.`subscribe` AS `subscribe`,
+ `contact`.`last-update` AS `last-update`,
+ `contact`.`success_update` AS `success_update`,
+ `contact`.`failure_update` AS `failure_update`,
+ `contact`.`failed` AS `failed`,
+ `contact`.`last-item` AS `last-item`,
+ `contact`.`last-discovery` AS `last-discovery`,
+ `contact`.`contact-type` AS `contact-type`,
+ `contact`.`manually-approve` AS `manually-approve`,
+ `contact`.`unsearchable` AS `unsearchable`,
+ `contact`.`sensitive` AS `sensitive`,
+ `contact`.`baseurl` AS `baseurl`,
+ `contact`.`gsid` AS `gsid`,
+ `contact`.`info` AS `info`,
+ `contact`.`bdyear` AS `bdyear`,
+ `contact`.`bd` AS `bd`,
+ `contact`.`poco` AS `poco`,
+ `contact`.`name-date` AS `name-date`,
+ `contact`.`uri-date` AS `uri-date`,
+ `contact`.`avatar-date` AS `avatar-date`,
+ `contact`.`term-date` AS `term-date`,
+ `contact`.`hidden` AS `global-ignored`,
+ `contact`.`blocked` AS `global-blocked`,
+ `contact`.`hidden` AS `hidden`,
+ `contact`.`archive` AS `archive`,
+ `contact`.`deleted` AS `deleted`,
+ `contact`.`blocked` AS `blocked`,
+ `contact`.`request` AS `dfrn-request`,
+ `contact`.`notify` AS `dfrn-notify`,
+ `contact`.`poll` AS `dfrn-poll`,
+ `contact`.`confirm` AS `dfrn-confirm`,
+ `fcontact`.`guid` AS `diaspora-guid`,
+ `fcontact`.`batch` AS `diaspora-batch`,
+ `fcontact`.`notify` AS `diaspora-notify`,
+ `fcontact`.`poll` AS `diaspora-poll`,
+ `fcontact`.`alias` AS `diaspora-alias`,
+ `apcontact`.`uuid` AS `ap-uuid`,
+ `apcontact`.`type` AS `ap-type`,
+ `apcontact`.`following` AS `ap-following`,
+ `apcontact`.`followers` AS `ap-followers`,
+ `apcontact`.`inbox` AS `ap-inbox`,
+ `apcontact`.`outbox` AS `ap-outbox`,
+ `apcontact`.`sharedinbox` AS `ap-sharedinbox`,
+ `apcontact`.`generator` AS `ap-generator`,
+ `apcontact`.`following_count` AS `ap-following_count`,
+ `apcontact`.`followers_count` AS `ap-followers_count`,
+ `apcontact`.`statuses_count` AS `ap-statuses_count`
+ FROM `contact`
+ LEFT JOIN `apcontact` ON `apcontact`.`uri-id` = `contact`.`uri-id`
+ LEFT JOIN `fcontact` ON `fcontact`.`uri-id` = contact.`uri-id`
+ WHERE `contact`.`uid` = 0;
+
+--
+-- VIEW account-user-view
+--
+DROP VIEW IF EXISTS `account-user-view`;
+CREATE VIEW `account-user-view` AS SELECT
+ `ucontact`.`id` AS `id`,
+ `contact`.`id` AS `pid`,
+ `ucontact`.`uid` AS `uid`,
+ `contact`.`url` AS `url`,
+ `contact`.`nurl` AS `nurl`,
+ `contact`.`uri-id` AS `uri-id`,
+ `contact`.`addr` AS `addr`,
+ `contact`.`alias` AS `alias`,
+ `contact`.`name` AS `name`,
+ `contact`.`nick` AS `nick`,
+ `contact`.`about` AS `about`,
+ `contact`.`keywords` AS `keywords`,
+ `contact`.`xmpp` AS `xmpp`,
+ `contact`.`avatar` AS `avatar`,
+ `contact`.`photo` AS `photo`,
+ `contact`.`thumb` AS `thumb`,
+ `contact`.`micro` AS `micro`,
+ `contact`.`header` AS `header`,
+ `contact`.`created` AS `created`,
+ `contact`.`updated` AS `updated`,
+ `ucontact`.`self` AS `self`,
+ `ucontact`.`remote_self` AS `remote_self`,
+ `ucontact`.`rel` AS `rel`,
+ `contact`.`network` AS `network`,
+ `ucontact`.`protocol` AS `protocol`,
+ `contact`.`location` AS `location`,
+ `contact`.`attag` AS `attag`,
+ `contact`.`pubkey` AS `pubkey`,
+ `contact`.`prvkey` AS `prvkey`,
+ `contact`.`subscribe` AS `subscribe`,
+ `contact`.`last-update` AS `last-update`,
+ `contact`.`success_update` AS `success_update`,
+ `contact`.`failure_update` AS `failure_update`,
+ `contact`.`failed` AS `failed`,
+ `contact`.`last-item` AS `last-item`,
+ `contact`.`last-discovery` AS `last-discovery`,
+ `contact`.`contact-type` AS `contact-type`,
+ `contact`.`manually-approve` AS `manually-approve`,
+ `contact`.`unsearchable` AS `unsearchable`,
+ `contact`.`sensitive` AS `sensitive`,
+ `contact`.`baseurl` AS `baseurl`,
+ `contact`.`gsid` AS `gsid`,
+ `contact`.`info` AS `info`,
+ `contact`.`bdyear` AS `bdyear`,
+ `contact`.`bd` AS `bd`,
+ `contact`.`poco` AS `poco`,
+ `contact`.`name-date` AS `name-date`,
+ `contact`.`uri-date` AS `uri-date`,
+ `contact`.`avatar-date` AS `avatar-date`,
+ `contact`.`term-date` AS `term-date`,
+ `contact`.`hidden` AS `global-ignored`,
+ `contact`.`blocked` AS `global-blocked`,
+ `ucontact`.`hidden` AS `hidden`,
+ `ucontact`.`archive` AS `archive`,
+ `ucontact`.`pending` AS `pending`,
+ `ucontact`.`deleted` AS `deleted`,
+ `ucontact`.`notify_new_posts` AS `notify_new_posts`,
+ `ucontact`.`fetch_further_information` AS `fetch_further_information`,
+ `ucontact`.`ffi_keyword_denylist` AS `ffi_keyword_denylist`,
+ `ucontact`.`rating` AS `rating`,
+ `ucontact`.`readonly` AS `readonly`,
+ `ucontact`.`blocked` AS `blocked`,
+ `ucontact`.`block_reason` AS `block_reason`,
+ `ucontact`.`subhub` AS `subhub`,
+ `ucontact`.`hub-verify` AS `hub-verify`,
+ `ucontact`.`reason` AS `reason`,
+ `ucontact`.`duplex` AS `dfrn-duplex`,
+ `ucontact`.`ret-aes` AS `dfrn-ret-aes`,
+ `ucontact`.`site-pubkey` AS `dfrn-site-pubkey`,
+ `ucontact`.`issued-id` AS `dfrn-issued-id`,
+ `ucontact`.`dfrn-id` AS `dfrn-id`,
+ `ucontact`.`aes_allow` AS `dfrn-aes_allow`,
+ `contact`.`request` AS `dfrn-request`,
+ `contact`.`notify` AS `dfrn-notify`,
+ `contact`.`poll` AS `dfrn-poll`,
+ `contact`.`confirm` AS `dfrn-confirm`,
+ `fcontact`.`guid` AS `diaspora-guid`,
+ `fcontact`.`batch` AS `diaspora-batch`,
+ `fcontact`.`notify` AS `diaspora-notify`,
+ `fcontact`.`poll` AS `diaspora-poll`,
+ `fcontact`.`alias` AS `diaspora-alias`,
+ `apcontact`.`uuid` AS `ap-uuid`,
+ `apcontact`.`type` AS `ap-type`,
+ `apcontact`.`following` AS `ap-following`,
+ `apcontact`.`followers` AS `ap-followers`,
+ `apcontact`.`inbox` AS `ap-inbox`,
+ `apcontact`.`outbox` AS `ap-outbox`,
+ `apcontact`.`sharedinbox` AS `ap-sharedinbox`,
+ `apcontact`.`generator` AS `ap-generator`,
+ `apcontact`.`following_count` AS `ap-following_count`,
+ `apcontact`.`followers_count` AS `ap-followers_count`,
+ `apcontact`.`statuses_count` AS `ap-statuses_count`
+ FROM `contact` AS `ucontact`
+ INNER JOIN `contact` ON `contact`.`uri-id` = `ucontact`.`uri-id` AND `contact`.`uid` = 0
+ LEFT JOIN `apcontact` ON `apcontact`.`uri-id` = `ucontact`.`uri-id`
+ LEFT JOIN `fcontact` ON `fcontact`.`uri-id` = `ucontact`.`uri-id` AND `fcontact`.`network` = 'dspr';
+
--
-- VIEW pending-view
--