mirror of
https://github.com/friendica/friendica
synced 2025-01-21 23:39:47 +00:00
Merge pull request #9815 from annando/post-again
"item" is replaced by "post-view" / postupdate check added
This commit is contained in:
commit
fe373a10aa
33 changed files with 152 additions and 826 deletions
2
boot.php
2
boot.php
|
@ -40,7 +40,7 @@ define('FRIENDICA_PLATFORM', 'Friendica');
|
||||||
define('FRIENDICA_CODENAME', 'Red Hot Poker');
|
define('FRIENDICA_CODENAME', 'Red Hot Poker');
|
||||||
define('FRIENDICA_VERSION', '2021.03-dev');
|
define('FRIENDICA_VERSION', '2021.03-dev');
|
||||||
define('DFRN_PROTOCOL_VERSION', '2.23');
|
define('DFRN_PROTOCOL_VERSION', '2.23');
|
||||||
define('NEW_UPDATE_ROUTINE_VERSION', 1170);
|
define('NEW_TABLE_STRUCTURE_VERSION', 1288);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constant with a HTML line break.
|
* Constant with a HTML line break.
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
-- ------------------------------------------
|
-- ------------------------------------------
|
||||||
-- Friendica 2021.03-dev (Red Hot Poker)
|
-- Friendica 2021.03-dev (Red Hot Poker)
|
||||||
-- DB_UPDATE_VERSION 1388
|
-- DB_UPDATE_VERSION 1389
|
||||||
-- ------------------------------------------
|
-- ------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
@ -1560,10 +1560,13 @@ CREATE VIEW `post-view` AS SELECT
|
||||||
`contact`.`thumb` AS `contact-avatar`,
|
`contact`.`thumb` AS `contact-avatar`,
|
||||||
`contact`.`network` AS `contact-network`,
|
`contact`.`network` AS `contact-network`,
|
||||||
`contact`.`blocked` AS `contact-blocked`,
|
`contact`.`blocked` AS `contact-blocked`,
|
||||||
|
`contact`.`hidden` AS `contact-hidden`,
|
||||||
`contact`.`readonly` AS `contact-readonly`,
|
`contact`.`readonly` AS `contact-readonly`,
|
||||||
|
`contact`.`archive` AS `contact-archive`,
|
||||||
`contact`.`pending` AS `contact-pending`,
|
`contact`.`pending` AS `contact-pending`,
|
||||||
`contact`.`rel` AS `contact-rel`,
|
`contact`.`rel` AS `contact-rel`,
|
||||||
`contact`.`uid` AS `contact-uid`,
|
`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`,
|
IF (`item`.`network` IN ('apub', 'dfrn', 'dspr', 'stat'), true, `contact`.`writable`) AS `writable`,
|
||||||
`contact`.`self` AS `self`,
|
`contact`.`self` AS `self`,
|
||||||
`contact`.`id` AS `cid`,
|
`contact`.`id` AS `cid`,
|
||||||
|
|
|
@ -2041,9 +2041,9 @@ function api_statuses_repeat($type)
|
||||||
Logger::log('API: api_statuses_repeat: '.$id);
|
Logger::log('API: api_statuses_repeat: '.$id);
|
||||||
|
|
||||||
$fields = ['uri-id', 'network', 'body', 'title', 'author-name', 'author-link', 'author-avatar', 'guid', 'created', 'plink'];
|
$fields = ['uri-id', 'network', 'body', 'title', 'author-name', 'author-link', 'author-avatar', 'guid', 'created', 'plink'];
|
||||||
$item = Item::selectFirst($fields, ['id' => $id, 'private' => [Item::PUBLIC, Item::UNLISTED]]);
|
$item = Post::selectFirst($fields, ['id' => $id, 'private' => [Item::PUBLIC, Item::UNLISTED]]);
|
||||||
|
|
||||||
if (DBA::isResult($item) && $item['body'] != "") {
|
if (DBA::isResult($item) && !empty($item['body'])) {
|
||||||
if (in_array($item['network'], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::TWITTER])) {
|
if (in_array($item['network'], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::TWITTER])) {
|
||||||
if (!Item::performActivity($id, 'announce', local_user())) {
|
if (!Item::performActivity($id, 'announce', local_user())) {
|
||||||
throw new InternalServerErrorException();
|
throw new InternalServerErrorException();
|
||||||
|
@ -6007,7 +6007,7 @@ function bindComments(&$data)
|
||||||
}
|
}
|
||||||
|
|
||||||
$idStr = DBA::escape(implode(', ', $ids));
|
$idStr = DBA::escape(implode(', ', $ids));
|
||||||
$sql = "SELECT `parent`, COUNT(*) as comments FROM `item` WHERE `parent` IN ($idStr) AND `deleted` = ? AND `gravity`= ? GROUP BY `parent`";
|
$sql = "SELECT `parent`, COUNT(*) as comments FROM `post-view` WHERE `parent` IN ($idStr) AND `deleted` = ? AND `gravity`= ? GROUP BY `parent`";
|
||||||
$items = DBA::p($sql, 0, GRAVITY_COMMENT);
|
$items = DBA::p($sql, 0, GRAVITY_COMMENT);
|
||||||
$itemsData = DBA::toArray($items);
|
$itemsData = DBA::toArray($items);
|
||||||
|
|
||||||
|
|
|
@ -1266,7 +1266,7 @@ function photos_content(App $a)
|
||||||
// as a "post" but displaying instead the photo it is linked to
|
// as a "post" but displaying instead the photo it is linked to
|
||||||
|
|
||||||
/// @todo Rewrite this query. To do so, $sql_extra must be changed
|
/// @todo Rewrite this query. To do so, $sql_extra must be changed
|
||||||
$linked_items = q("SELECT `id` FROM `item` WHERE `resource-id` = '%s' $sql_extra LIMIT 1",
|
$linked_items = q("SELECT `id` FROM `post-view` WHERE `resource-id` = '%s' $sql_extra LIMIT 1",
|
||||||
DBA::escape($datum)
|
DBA::escape($datum)
|
||||||
);
|
);
|
||||||
if (DBA::isResult($linked_items)) {
|
if (DBA::isResult($linked_items)) {
|
||||||
|
|
|
@ -412,8 +412,8 @@ function ping_get_notifications($uid)
|
||||||
|
|
||||||
do {
|
do {
|
||||||
$r = q(
|
$r = q(
|
||||||
"SELECT `notify`.*, `item`.`visible`, `item`.`deleted`
|
"SELECT `notify`.*, `post-view`.`visible`, `post-view`.`deleted`
|
||||||
FROM `notify` LEFT JOIN `item` ON `item`.`id` = `notify`.`iid`
|
FROM `notify` LEFT JOIN `post-view` ON `post-view`.`id` = `notify`.`iid`
|
||||||
WHERE `notify`.`uid` = %d AND `notify`.`msg` != ''
|
WHERE `notify`.`uid` = %d AND `notify`.`msg` != ''
|
||||||
AND NOT (`notify`.`type` IN (%d, %d))
|
AND NOT (`notify`.`type` IN (%d, %d))
|
||||||
AND $seensql `notify`.`seen` ORDER BY `notify`.`date` $order LIMIT %d, 50",
|
AND $seensql `notify`.`seen` ORDER BY `notify`.`date` $order LIMIT %d, 50",
|
||||||
|
|
|
@ -209,14 +209,14 @@ class ForumManager
|
||||||
public static function countUnseenItems()
|
public static function countUnseenItems()
|
||||||
{
|
{
|
||||||
$stmtContacts = DBA::p(
|
$stmtContacts = DBA::p(
|
||||||
"SELECT `contact`.`id`, `contact`.`name`, COUNT(*) AS `count` FROM `item`
|
"SELECT `contact`.`id`, `contact`.`name`, COUNT(*) AS `count` FROM `post-view`
|
||||||
INNER JOIN `contact` ON `item`.`contact-id` = `contact`.`id`
|
INNER JOIN `contact` ON `post-view`.`contact-id` = `contact`.`id`
|
||||||
WHERE `item`.`uid` = ? AND `item`.`visible` AND NOT `item`.`deleted` AND `item`.`unseen`
|
WHERE `post-view`.`uid` = ? AND `post-view`.`visible` AND NOT `post-view`.`deleted` AND `post-view`.`unseen`
|
||||||
AND `contact`.`network`= 'dfrn' AND (`contact`.`forum` OR `contact`.`prv`)
|
AND `contact`.`network` IN (?, ?) AND `contact`.`contact-type` = ?
|
||||||
AND NOT `contact`.`blocked` AND NOT `contact`.`hidden`
|
AND NOT `contact`.`blocked` AND NOT `contact`.`hidden`
|
||||||
AND NOT `contact`.`pending` AND NOT `contact`.`archive`
|
AND NOT `contact`.`pending` AND NOT `contact`.`archive`
|
||||||
GROUP BY `contact`.`id` ",
|
GROUP BY `contact`.`id`",
|
||||||
local_user()
|
local_user(), Protocol::DFRN, Protocol::ACTIVITYPUB, Contact::TYPE_COMMUNITY
|
||||||
);
|
);
|
||||||
|
|
||||||
return DBA::toArray($stmtContacts);
|
return DBA::toArray($stmtContacts);
|
||||||
|
|
|
@ -92,19 +92,19 @@ class TagCloud
|
||||||
|
|
||||||
if ($flags) {
|
if ($flags) {
|
||||||
if ($flags === 'wall') {
|
if ($flags === 'wall') {
|
||||||
$sql_options .= ' AND `item`.`wall` ';
|
$sql_options .= ' AND `post-view`.`wall` ';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($owner_id) {
|
if ($owner_id) {
|
||||||
$sql_options .= ' AND `item`.`owner-id` = ' . intval($owner_id) . ' ';
|
$sql_options .= ' AND `post-view`.`owner-id` = ' . intval($owner_id) . ' ';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch tags
|
// Fetch tags
|
||||||
$tag_stmt = DBA::p("SELECT `name`, COUNT(`name`) AS `total` FROM `tag-search-view`
|
$tag_stmt = DBA::p("SELECT `name`, COUNT(`name`) AS `total` FROM `tag-search-view`
|
||||||
LEFT JOIN `item` ON `tag-search-view`.`uri-id` = `item`.`uri-id`
|
LEFT JOIN `post-view` ON `tag-search-view`.`uri-id` = `post-view`.`uri-id`
|
||||||
WHERE `tag-search-view`.`uid` = ?
|
WHERE `tag-search-view`.`uid` = ?
|
||||||
AND `item`.`visible` AND NOT `item`.`deleted` AND NOT `item`.`moderated`
|
AND `post-view`.`visible` AND NOT `post-view`.`deleted` AND NOT `post-view`.`moderated`
|
||||||
$sql_options
|
$sql_options
|
||||||
GROUP BY `name` ORDER BY `total` DESC $limit",
|
GROUP BY `name` ORDER BY `total` DESC $limit",
|
||||||
$uid
|
$uid
|
||||||
|
|
|
@ -22,9 +22,11 @@
|
||||||
namespace Friendica\Core;
|
namespace Friendica\Core;
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\App\Mode;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\Database\DBStructure;
|
use Friendica\Database\DBStructure;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
|
use Friendica\Network\HTTPException\InternalServerErrorException;
|
||||||
use Friendica\Util\Strings;
|
use Friendica\Util\Strings;
|
||||||
|
|
||||||
class Update
|
class Update
|
||||||
|
@ -60,8 +62,24 @@ class Update
|
||||||
}
|
}
|
||||||
|
|
||||||
// We don't support upgrading from very old versions anymore
|
// We don't support upgrading from very old versions anymore
|
||||||
if ($build < NEW_UPDATE_ROUTINE_VERSION) {
|
if ($build < NEW_TABLE_STRUCTURE_VERSION) {
|
||||||
die('You try to update from a version prior to database version 1170. The direct upgrade path is not supported. Please update to version 3.5.4 before updating to this version.');
|
$error = DI::l10n('Updates from version %s are not supported. Please update at least to version 2021,01 and wait until the postupdate finished version 1383.', $build);
|
||||||
|
if (DI::mode()->getExecutor() == Mode::INDEX) {
|
||||||
|
die($error);
|
||||||
|
} else {
|
||||||
|
throw new InternalServerErrorException($error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// The postupdate has to completed version 1281 for the new post views to take over
|
||||||
|
$postupdate = DI::config()->get("system", "post_update_version");
|
||||||
|
if ($postupdate < NEW_TABLE_STRUCTURE_VERSION) {
|
||||||
|
$error = DI::l10n('Updates from postupdate version %s are not supported. Please update at least to version 2021,01 and wait until the postupdate finished version 1383.', $postupdate);
|
||||||
|
if (DI::mode()->getExecutor() == Mode::INDEX) {
|
||||||
|
die($error);
|
||||||
|
} else {
|
||||||
|
throw new InternalServerErrorException($error);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($build < DB_UPDATE_VERSION) {
|
if ($build < DB_UPDATE_VERSION) {
|
||||||
|
|
|
@ -183,7 +183,7 @@ class DBA
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes a prepared statement that returns data
|
* Executes a prepared statement that returns data
|
||||||
* Example: $r = p("SELECT * FROM `item` WHERE `guid` = ?", $guid);
|
* Example: $r = p("SELECT * FROM `post` WHERE `guid` = ?", $guid);
|
||||||
*
|
*
|
||||||
* Please only use it with complicated queries.
|
* Please only use it with complicated queries.
|
||||||
* For all regular queries please use DBA::select or DBA::exists
|
* For all regular queries please use DBA::select or DBA::exists
|
||||||
|
|
|
@ -455,7 +455,7 @@ class Database
|
||||||
/**
|
/**
|
||||||
* Executes a prepared statement that returns data
|
* Executes a prepared statement that returns data
|
||||||
*
|
*
|
||||||
* @usage Example: $r = p("SELECT * FROM `item` WHERE `guid` = ?", $guid);
|
* @usage Example: $r = p("SELECT * FROM `post` WHERE `guid` = ?", $guid);
|
||||||
*
|
*
|
||||||
* Please only use it with complicated queries.
|
* Please only use it with complicated queries.
|
||||||
* For all regular queries please use DBA::select or DBA::exists
|
* For all regular queries please use DBA::select or DBA::exists
|
||||||
|
|
|
@ -27,9 +27,8 @@ use Friendica\DI;
|
||||||
use Friendica\Model\Contact;
|
use Friendica\Model\Contact;
|
||||||
use Friendica\Model\GServer;
|
use Friendica\Model\GServer;
|
||||||
use Friendica\Model\Item;
|
use Friendica\Model\Item;
|
||||||
use Friendica\Model\ItemURI;
|
|
||||||
use Friendica\Model\PermissionSet;
|
|
||||||
use Friendica\Model\Photo;
|
use Friendica\Model\Photo;
|
||||||
|
use Friendica\Model\Post;
|
||||||
use Friendica\Model\Post\Category;
|
use Friendica\Model\Post\Category;
|
||||||
use Friendica\Model\Tag;
|
use Friendica\Model\Tag;
|
||||||
use Friendica\Model\UserItem;
|
use Friendica\Model\UserItem;
|
||||||
|
@ -53,18 +52,6 @@ class PostUpdate
|
||||||
*/
|
*/
|
||||||
public static function update()
|
public static function update()
|
||||||
{
|
{
|
||||||
if (!self::update1194()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!self::update1206()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!self::update1279()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!self::update1281()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!self::update1297()) {
|
if (!self::update1297()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -105,352 +92,6 @@ class PostUpdate
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Updates the "global" field in the item table
|
|
||||||
*
|
|
||||||
* @return bool "true" when the job is done
|
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
|
||||||
*/
|
|
||||||
private static function update1194()
|
|
||||||
{
|
|
||||||
// Was the script completed?
|
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1194) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
Logger::info("Start");
|
|
||||||
|
|
||||||
$end_id = DI::config()->get("system", "post_update_1194_end");
|
|
||||||
if (!$end_id) {
|
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uid` != 0 ORDER BY `id` DESC LIMIT 1");
|
|
||||||
if ($r) {
|
|
||||||
DI::config()->set("system", "post_update_1194_end", $r[0]["id"]);
|
|
||||||
$end_id = DI::config()->get("system", "post_update_1194_end");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Logger::info("End ID: ".$end_id);
|
|
||||||
|
|
||||||
$start_id = DI::config()->get("system", "post_update_1194_start");
|
|
||||||
|
|
||||||
$query1 = "SELECT `item`.`id` FROM `item` ";
|
|
||||||
|
|
||||||
$query2 = "INNER JOIN `item` AS `shadow` ON `item`.`uri` = `shadow`.`uri` AND `shadow`.`uid` = 0 ";
|
|
||||||
|
|
||||||
$query3 = "WHERE `item`.`uid` != 0 AND `item`.`id` >= %d AND `item`.`id` <= %d
|
|
||||||
AND `item`.`visible` AND NOT `item`.`private`
|
|
||||||
AND NOT `item`.`deleted` AND NOT `item`.`moderated`
|
|
||||||
AND `item`.`network` IN ('%s', '%s', '%s', '')
|
|
||||||
AND NOT `item`.`global`";
|
|
||||||
|
|
||||||
$r = q($query1.$query2.$query3." ORDER BY `item`.`id` LIMIT 1",
|
|
||||||
intval($start_id), intval($end_id),
|
|
||||||
DBA::escape(Protocol::DFRN), DBA::escape(Protocol::DIASPORA), DBA::escape(Protocol::OSTATUS));
|
|
||||||
if (!$r) {
|
|
||||||
DI::config()->set("system", "post_update_version", 1194);
|
|
||||||
Logger::info("Update is done");
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
DI::config()->set("system", "post_update_1194_start", $r[0]["id"]);
|
|
||||||
$start_id = DI::config()->get("system", "post_update_1194_start");
|
|
||||||
}
|
|
||||||
|
|
||||||
Logger::info("Start ID: ".$start_id);
|
|
||||||
|
|
||||||
$r = q($query1.$query2.$query3." ORDER BY `item`.`id` LIMIT 1000,1",
|
|
||||||
intval($start_id), intval($end_id),
|
|
||||||
DBA::escape(Protocol::DFRN), DBA::escape(Protocol::DIASPORA), DBA::escape(Protocol::OSTATUS));
|
|
||||||
if ($r) {
|
|
||||||
$pos_id = $r[0]["id"];
|
|
||||||
} else {
|
|
||||||
$pos_id = $end_id;
|
|
||||||
}
|
|
||||||
Logger::info("Progress: Start: ".$start_id." position: ".$pos_id." end: ".$end_id);
|
|
||||||
|
|
||||||
q("UPDATE `item` ".$query2." SET `item`.`global` = 1 ".$query3,
|
|
||||||
intval($start_id), intval($pos_id),
|
|
||||||
DBA::escape(Protocol::DFRN), DBA::escape(Protocol::DIASPORA), DBA::escape(Protocol::OSTATUS));
|
|
||||||
|
|
||||||
Logger::info("Done");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* update the "last-item" field in the "self" contact
|
|
||||||
*
|
|
||||||
* This field avoids cost intensive calls in the admin panel and in "nodeinfo"
|
|
||||||
*
|
|
||||||
* @return bool "true" when the job is done
|
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
|
||||||
*/
|
|
||||||
private static function update1206()
|
|
||||||
{
|
|
||||||
// Was the script completed?
|
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1206) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
Logger::info("Start");
|
|
||||||
$r = q("SELECT `contact`.`id`, `contact`.`last-item`,
|
|
||||||
(SELECT MAX(`changed`) FROM `item` USE INDEX (`uid_wall_changed`) WHERE `wall` AND `uid` = `user`.`uid`) AS `lastitem_date`
|
|
||||||
FROM `user`
|
|
||||||
INNER JOIN `contact` ON `contact`.`uid` = `user`.`uid` AND `contact`.`self`");
|
|
||||||
|
|
||||||
if (!DBA::isResult($r)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
foreach ($r as $user) {
|
|
||||||
if (!empty($user["lastitem_date"]) && ($user["lastitem_date"] > $user["last-item"])) {
|
|
||||||
DBA::update('contact', ['last-item' => $user['lastitem_date']], ['id' => $user['id']]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version", 1206);
|
|
||||||
Logger::info("Done");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* update the item related tables
|
|
||||||
*
|
|
||||||
* @return bool "true" when the job is done
|
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
|
||||||
* @throws \ImagickException
|
|
||||||
*/
|
|
||||||
private static function update1279()
|
|
||||||
{
|
|
||||||
// Was the script completed?
|
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1279) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$id = DI::config()->get("system", "post_update_version_1279_id", 0);
|
|
||||||
|
|
||||||
Logger::info("Start from item " . $id);
|
|
||||||
|
|
||||||
$fields = array_merge(Item::MIXED_CONTENT_FIELDLIST, ['network', 'author-id', 'owner-id', 'tag', 'file',
|
|
||||||
'author-name', 'author-avatar', 'author-link', 'owner-name', 'owner-avatar', 'owner-link', 'id',
|
|
||||||
'uid', 'allow_cid', 'allow_gid', 'deny_cid', 'deny_gid', 'psid', 'post-type', 'bookmark', 'type',
|
|
||||||
'inform', 'postopts', 'icid']);
|
|
||||||
|
|
||||||
$start_id = $id;
|
|
||||||
$rows = 0;
|
|
||||||
$condition = ["`id` > ?", $id];
|
|
||||||
$params = ['order' => ['id'], 'limit' => 10000];
|
|
||||||
$items = Item::select($fields, $condition, $params);
|
|
||||||
|
|
||||||
if (DBA::errorNo() != 0) {
|
|
||||||
Logger::info('Database error ' . DBA::errorNo() . ':' . DBA::errorMessage());
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ($item = Item::fetch($items)) {
|
|
||||||
$id = $item['id'];
|
|
||||||
|
|
||||||
if (empty($item['author-id'])) {
|
|
||||||
$default = ['url' => $item['author-link'], 'name' => $item['author-name'],
|
|
||||||
'photo' => $item['author-avatar'], 'network' => $item['network']];
|
|
||||||
|
|
||||||
$item['author-id'] = Contact::getIdForURL($item["author-link"], 0, null, $default);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($item['owner-id'])) {
|
|
||||||
$default = ['url' => $item['owner-link'], 'name' => $item['owner-name'],
|
|
||||||
'photo' => $item['owner-avatar'], 'network' => $item['network']];
|
|
||||||
|
|
||||||
$item['owner-id'] = Contact::getIdForURL($item["owner-link"], 0, null, $default);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($item['psid'])) {
|
|
||||||
$item['psid'] = PermissionSet::getIdFromACL(
|
|
||||||
$item['uid'],
|
|
||||||
$item['allow_cid'],
|
|
||||||
$item['allow_gid'],
|
|
||||||
$item['deny_cid'],
|
|
||||||
$item['deny_gid']
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$item['allow_cid'] = null;
|
|
||||||
$item['allow_gid'] = null;
|
|
||||||
$item['deny_cid'] = null;
|
|
||||||
$item['deny_gid'] = null;
|
|
||||||
|
|
||||||
if ($item['post-type'] == 0) {
|
|
||||||
if (!empty($item['type']) && ($item['type'] == 'note')) {
|
|
||||||
$item['post-type'] = Item::PT_PERSONAL_NOTE;
|
|
||||||
} elseif (!empty($item['type']) && ($item['type'] == 'photo')) {
|
|
||||||
$item['post-type'] = Item::PT_IMAGE;
|
|
||||||
} elseif (!empty($item['bookmark']) && $item['bookmark']) {
|
|
||||||
$item['post-type'] = Item::PT_PAGE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
self::createLanguage($item);
|
|
||||||
|
|
||||||
if (!empty($item['icid']) && !empty($item['language'])) {
|
|
||||||
DBA::update('item-content', ['language' => $item['language']], ['id' => $item['icid']]);
|
|
||||||
}
|
|
||||||
unset($item['language']);
|
|
||||||
|
|
||||||
Item::update($item, ['id' => $id]);
|
|
||||||
|
|
||||||
++$rows;
|
|
||||||
}
|
|
||||||
DBA::close($items);
|
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version_1279_id", $id);
|
|
||||||
|
|
||||||
Logger::info("Processed rows: " . $rows . " - last processed item: " . $id);
|
|
||||||
|
|
||||||
if ($start_id == $id) {
|
|
||||||
// Set all deprecated fields to "null" if they contain an empty string
|
|
||||||
$nullfields = ['allow_cid', 'allow_gid', 'deny_cid', 'deny_gid', 'postopts', 'inform', 'type',
|
|
||||||
'bookmark', 'file', 'location', 'coord', 'tag', 'plink', 'title', 'content-warning',
|
|
||||||
'body', 'app', 'verb', 'object-type', 'object', 'target-type', 'target',
|
|
||||||
'author-name', 'author-link', 'author-avatar', 'owner-name', 'owner-link', 'owner-avatar',
|
|
||||||
'rendered-hash', 'rendered-html'];
|
|
||||||
foreach ($nullfields as $field) {
|
|
||||||
$fields = [$field => null];
|
|
||||||
$condition = [$field => ''];
|
|
||||||
Logger::info("Setting '" . $field . "' to null if empty.");
|
|
||||||
// Important: This has to be a "DBA::update", not a "Item::update"
|
|
||||||
DBA::update('item', $fields, $condition);
|
|
||||||
}
|
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version", 1279);
|
|
||||||
Logger::info("Done");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static function createLanguage(&$item)
|
|
||||||
{
|
|
||||||
if (empty($item['postopts'])) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$opts = explode(',', $item['postopts']);
|
|
||||||
|
|
||||||
$postopts = [];
|
|
||||||
|
|
||||||
foreach ($opts as $opt) {
|
|
||||||
if (strstr($opt, 'lang=')) {
|
|
||||||
$language = substr($opt, 5);
|
|
||||||
} else {
|
|
||||||
$postopts[] = $opt;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($language)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($postopts)) {
|
|
||||||
$item['postopts'] = implode(',', $postopts);
|
|
||||||
} else {
|
|
||||||
$item['postopts'] = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
$lang_pairs = explode(':', $language);
|
|
||||||
|
|
||||||
$lang_arr = [];
|
|
||||||
|
|
||||||
foreach ($lang_pairs as $pair) {
|
|
||||||
$lang_pair_arr = explode(';', $pair);
|
|
||||||
if (count($lang_pair_arr) == 2) {
|
|
||||||
$lang_arr[$lang_pair_arr[0]] = $lang_pair_arr[1];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$item['language'] = json_encode($lang_arr);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* update item-uri data. Prerequisite for the next item structure update.
|
|
||||||
*
|
|
||||||
* @return bool "true" when the job is done
|
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
|
||||||
*/
|
|
||||||
private static function update1281()
|
|
||||||
{
|
|
||||||
// Was the script completed?
|
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1281) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$id = DI::config()->get("system", "post_update_version_1281_id", 0);
|
|
||||||
|
|
||||||
Logger::info("Start from item " . $id);
|
|
||||||
|
|
||||||
$fields = ['id', 'guid', 'uri', 'uri-id', 'parent-uri', 'parent-uri-id', 'thr-parent', 'thr-parent-id'];
|
|
||||||
|
|
||||||
$start_id = $id;
|
|
||||||
$rows = 0;
|
|
||||||
$condition = ["`id` > ?", $id];
|
|
||||||
$params = ['order' => ['id'], 'limit' => 10000];
|
|
||||||
$items = DBA::select('item', $fields, $condition, $params);
|
|
||||||
|
|
||||||
if (DBA::errorNo() != 0) {
|
|
||||||
Logger::info('Database error ' . DBA::errorNo() . ':' . DBA::errorMessage());
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ($item = DBA::fetch($items)) {
|
|
||||||
$id = $item['id'];
|
|
||||||
|
|
||||||
if (empty($item['uri'])) {
|
|
||||||
// Should not happen
|
|
||||||
continue;
|
|
||||||
} elseif (empty($item['uri-id'])) {
|
|
||||||
$item['uri-id'] = ItemURI::insert(['uri' => $item['uri'], 'guid' => $item['guid']]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($item['parent-uri'])) {
|
|
||||||
$item['parent-uri-id'] = $item['uri-id'];
|
|
||||||
} elseif (empty($item['parent-uri-id'])) {
|
|
||||||
$item['parent-uri-id'] = ItemURI::getIdByURI($item['parent-uri']);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Very old items don't have this field
|
|
||||||
if (empty($item['thr-parent'])) {
|
|
||||||
$item['thr-parent-id'] = $item['parent-uri-id'];
|
|
||||||
} elseif (empty($item['thr-parent-id'])) {
|
|
||||||
$item['thr-parent-id'] = ItemURI::getIdByURI($item['thr-parent']);
|
|
||||||
}
|
|
||||||
|
|
||||||
unset($item['id']);
|
|
||||||
unset($item['guid']);
|
|
||||||
unset($item['uri']);
|
|
||||||
unset($item['parent-uri']);
|
|
||||||
unset($item['thr-parent']);
|
|
||||||
|
|
||||||
DBA::update('item', $item, ['id' => $id]);
|
|
||||||
|
|
||||||
++$rows;
|
|
||||||
}
|
|
||||||
DBA::close($items);
|
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version_1281_id", $id);
|
|
||||||
|
|
||||||
Logger::info("Processed rows: " . $rows . " - last processed item: " . $id);
|
|
||||||
|
|
||||||
if ($start_id == $id) {
|
|
||||||
Logger::info("Updating item-uri in item-activity");
|
|
||||||
DBA::e("UPDATE `item-activity` INNER JOIN `item-uri` ON `item-uri`.`uri` = `item-activity`.`uri` SET `item-activity`.`uri-id` = `item-uri`.`id` WHERE `item-activity`.`uri-id` IS NULL");
|
|
||||||
|
|
||||||
Logger::info("Updating item-uri in item-content");
|
|
||||||
DBA::e("UPDATE `item-content` INNER JOIN `item-uri` ON `item-uri`.`uri` = `item-content`.`uri` SET `item-content`.`uri-id` = `item-uri`.`id` WHERE `item-content`.`uri-id` IS NULL");
|
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version", 1281);
|
|
||||||
Logger::info("Done");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the delivery queue count to a negative value for all items preceding the feature.
|
* Set the delivery queue count to a negative value for all items preceding the feature.
|
||||||
*
|
*
|
||||||
|
@ -822,7 +463,7 @@ class PostUpdate
|
||||||
}
|
}
|
||||||
|
|
||||||
while ($term = DBA::fetch($terms)) {
|
while ($term = DBA::fetch($terms)) {
|
||||||
$item = Item::selectFirst(['uri-id', 'uid'], ['id' => $term['oid']]);
|
$item = Post::selectFirst(['uri-id', 'uid'], ['id' => $term['oid']]);
|
||||||
if (!DBA::isResult($item)) {
|
if (!DBA::isResult($item)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -302,11 +302,7 @@ class Notification extends BaseFactory
|
||||||
*/
|
*/
|
||||||
public function getPersonalList(bool $seen = false, int $start = 0, int $limit = BaseNotifications::DEFAULT_PAGE_LIMIT)
|
public function getPersonalList(bool $seen = false, int $start = 0, int $limit = BaseNotifications::DEFAULT_PAGE_LIMIT)
|
||||||
{
|
{
|
||||||
$myUrl = str_replace('http://', '', $this->nurl);
|
$condition = ["NOT `wall` AND `uid` = ? AND `author-id` = ?", local_user(), public_contact()];
|
||||||
$diaspUrl = str_replace('/profile/', '/u/', $myUrl);
|
|
||||||
|
|
||||||
$condition = ["NOT `wall` AND `uid` = ? AND (`item`.`author-id` = ? OR `item`.`tag` REGEXP ? OR `item`.`tag` REGEXP ?)",
|
|
||||||
local_user(), public_contact(), $myUrl . '\\]', $diaspUrl . '\\]'];
|
|
||||||
|
|
||||||
if (!$seen) {
|
if (!$seen) {
|
||||||
$condition[0] .= " AND `unseen`";
|
$condition[0] .= " AND `unseen`";
|
||||||
|
|
|
@ -513,15 +513,13 @@ class Event
|
||||||
}
|
}
|
||||||
|
|
||||||
// Query for the event by event id
|
// Query for the event by event id
|
||||||
$r = q("SELECT `event`.*, `item`.`id` AS `itemid` FROM `event`
|
$events = DBA::toArray(DBA::p("SELECT `event`.*, `post-view`.`id` AS `itemid` FROM `event`
|
||||||
LEFT JOIN `item` ON `item`.`event-id` = `event`.`id` AND `item`.`uid` = `event`.`uid`
|
LEFT JOIN `post-view` ON `post-view`.`event-id` = `event`.`id` AND `post-view`.`uid` = `event`.`uid`
|
||||||
WHERE `event`.`uid` = %d AND `event`.`id` = %d $sql_extra",
|
WHERE `event`.`uid` = %d AND `event`.`id` = %d $sql_extra",
|
||||||
intval($owner_uid),
|
$owner_uid, $event_id));
|
||||||
intval($event_id)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (DBA::isResult($r)) {
|
if (DBA::isResult($events)) {
|
||||||
$return = self::removeDuplicates($r);
|
$return = self::removeDuplicates($events);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $return;
|
return $return;
|
||||||
|
@ -554,24 +552,17 @@ class Event
|
||||||
|
|
||||||
// Query for the event by date.
|
// Query for the event by date.
|
||||||
// @todo Slow query (518 seconds to run), to be optimzed
|
// @todo Slow query (518 seconds to run), to be optimzed
|
||||||
$r = q("SELECT `event`.*, `item`.`id` AS `itemid` FROM `event`
|
$events = DBA::toArray(DBA::p("SELECT `event`.*, `post-view`.`id` AS `itemid` FROM `event`
|
||||||
LEFT JOIN `item` ON `item`.`event-id` = `event`.`id` AND `item`.`uid` = `event`.`uid`
|
LEFT JOIN `post-view` ON `post-view`.`event-id` = `event`.`id` AND `post-view`.`uid` = `event`.`uid`
|
||||||
WHERE `event`.`uid` = %d AND event.ignore = %d
|
WHERE `event`.`uid` = ? AND `event`.`ignore` = ?
|
||||||
AND ((`adjust` = 0 AND (`finish` >= '%s' OR (nofinish AND start >= '%s')) AND `start` <= '%s')
|
AND ((NOT `adjust` AND (`finish` >= ? OR (`nofinish` AND `start` >= ?)) AND `start` <= ?)
|
||||||
OR (`adjust` = 1 AND (`finish` >= '%s' OR (nofinish AND start >= '%s')) AND `start` <= '%s'))
|
OR (`adjust` AND (`finish` >= ? OR (`nofinish` AND `start` >= ?)) AND `start` <= ?))" . $sql_extra,
|
||||||
$sql_extra ",
|
$owner_uid, $event_params["ignore"],
|
||||||
intval($owner_uid),
|
$event_params["start"], $event_params["start"], $event_params["finish"],
|
||||||
intval($event_params["ignore"]),
|
$event_params["adjust_start"], $event_params["adjust_start"], $event_params["adjust_finish"]));
|
||||||
DBA::escape($event_params["start"]),
|
|
||||||
DBA::escape($event_params["start"]),
|
|
||||||
DBA::escape($event_params["finish"]),
|
|
||||||
DBA::escape($event_params["adjust_start"]),
|
|
||||||
DBA::escape($event_params["adjust_start"]),
|
|
||||||
DBA::escape($event_params["adjust_finish"])
|
|
||||||
);
|
|
||||||
|
|
||||||
if (DBA::isResult($r)) {
|
if (DBA::isResult($events)) {
|
||||||
$return = self::removeDuplicates($r);
|
$return = self::removeDuplicates($events);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $return;
|
return $return;
|
||||||
|
|
|
@ -160,7 +160,7 @@ class Group
|
||||||
public static function countUnseen()
|
public static function countUnseen()
|
||||||
{
|
{
|
||||||
$stmt = DBA::p("SELECT `group`.`id`, `group`.`name`,
|
$stmt = DBA::p("SELECT `group`.`id`, `group`.`name`,
|
||||||
(SELECT COUNT(*) FROM `item` FORCE INDEX (`uid_unseen_contactid`)
|
(SELECT COUNT(*) FROM `post-view`
|
||||||
WHERE `uid` = ?
|
WHERE `uid` = ?
|
||||||
AND `unseen`
|
AND `unseen`
|
||||||
AND `contact-id` IN
|
AND `contact-id` IN
|
||||||
|
|
|
@ -148,15 +148,6 @@ class Item
|
||||||
return $postfields;
|
return $postfields;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function isLegacyMode()
|
|
||||||
{
|
|
||||||
if (is_null(self::$legacy_mode)) {
|
|
||||||
self::$legacy_mode = (DI::config()->get("system", "post_update_version") < 1279);
|
|
||||||
}
|
|
||||||
|
|
||||||
return self::$legacy_mode;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the pinned state of an item
|
* Set the pinned state of an item
|
||||||
*
|
*
|
||||||
|
@ -226,7 +217,7 @@ class Item
|
||||||
* @return array|false current row or false
|
* @return array|false current row or false
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function fetch($stmt)
|
private static function fetch($stmt)
|
||||||
{
|
{
|
||||||
$row = DBA::fetch($stmt);
|
$row = DBA::fetch($stmt);
|
||||||
|
|
||||||
|
@ -267,17 +258,6 @@ class Item
|
||||||
|
|
||||||
// ---------------------- Transform item content data ----------------------
|
// ---------------------- Transform item content data ----------------------
|
||||||
|
|
||||||
// Fetch data from the item-content table whenever there is content there
|
|
||||||
if (self::isLegacyMode()) {
|
|
||||||
$legacy_fields = array_merge(Post\DeliveryData::LEGACY_FIELD_LIST, self::MIXED_CONTENT_FIELDLIST);
|
|
||||||
foreach ($legacy_fields as $field) {
|
|
||||||
if (empty($row[$field]) && !empty($row['internal-item-' . $field])) {
|
|
||||||
$row[$field] = $row['internal-item-' . $field];
|
|
||||||
}
|
|
||||||
unset($row['internal-item-' . $field]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (array_key_exists('verb', $row)) {
|
if (array_key_exists('verb', $row)) {
|
||||||
if (!is_null($row['internal-verb'])) {
|
if (!is_null($row['internal-verb'])) {
|
||||||
$row['verb'] = $row['internal-verb'];
|
$row['verb'] = $row['internal-verb'];
|
||||||
|
@ -390,53 +370,6 @@ class Item
|
||||||
return $retval;
|
return $retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Select rows from the item table for a given user
|
|
||||||
*
|
|
||||||
* @param integer $uid User ID
|
|
||||||
* @param array $selected Array of selected fields, empty for all
|
|
||||||
* @param array $condition Array of fields for condition
|
|
||||||
* @param array $params Array of several parameters
|
|
||||||
*
|
|
||||||
* @return boolean|object
|
|
||||||
* @throws \Exception
|
|
||||||
*/
|
|
||||||
public static function selectForUser($uid, array $selected = [], array $condition = [], $params = [])
|
|
||||||
{
|
|
||||||
$params['uid'] = $uid;
|
|
||||||
|
|
||||||
if (empty($selected)) {
|
|
||||||
$selected = self::DISPLAY_FIELDLIST;
|
|
||||||
}
|
|
||||||
|
|
||||||
return self::select($selected, $condition, $params);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Retrieve a single record from the item table and returns it in an associative array
|
|
||||||
*
|
|
||||||
* @param array $fields
|
|
||||||
* @param array $condition
|
|
||||||
* @param array $params
|
|
||||||
* @return bool|array
|
|
||||||
* @throws \Exception
|
|
||||||
* @see DBA::select
|
|
||||||
*/
|
|
||||||
public static function selectFirst(array $fields = [], array $condition = [], $params = [])
|
|
||||||
{
|
|
||||||
$params['limit'] = 1;
|
|
||||||
|
|
||||||
$result = self::select($fields, $condition, $params);
|
|
||||||
|
|
||||||
if (is_bool($result)) {
|
|
||||||
return $result;
|
|
||||||
} else {
|
|
||||||
$row = self::fetch($result);
|
|
||||||
DBA::close($result);
|
|
||||||
return $row;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Select rows from the item table and returns them as an array
|
* Select rows from the item table and returns them as an array
|
||||||
*
|
*
|
||||||
|
@ -830,9 +763,6 @@ class Item
|
||||||
foreach ($fields as $table => $table_fields) {
|
foreach ($fields as $table => $table_fields) {
|
||||||
foreach ($table_fields as $field => $select) {
|
foreach ($table_fields as $field => $select) {
|
||||||
if (empty($selected) || in_array($select, $selected)) {
|
if (empty($selected) || in_array($select, $selected)) {
|
||||||
if (self::isLegacyMode() && in_array($select, $legacy_fields)) {
|
|
||||||
$selection[] = "`item`.`".$select."` AS `internal-item-" . $select . "`";
|
|
||||||
}
|
|
||||||
if (is_int($field)) {
|
if (is_int($field)) {
|
||||||
$selection[] = "`" . $table . "`.`" . $select . "`";
|
$selection[] = "`" . $table . "`.`" . $select . "`";
|
||||||
} else {
|
} else {
|
||||||
|
@ -904,7 +834,7 @@ class Item
|
||||||
foreach (array_merge(self::CONTENT_FIELDLIST, self::MIXED_CONTENT_FIELDLIST) as $field) {
|
foreach (array_merge(self::CONTENT_FIELDLIST, self::MIXED_CONTENT_FIELDLIST) as $field) {
|
||||||
if (isset($fields[$field])) {
|
if (isset($fields[$field])) {
|
||||||
$content_fields[$field] = $fields[$field];
|
$content_fields[$field] = $fields[$field];
|
||||||
if (in_array($field, self::CONTENT_FIELDLIST) || !self::isLegacyMode()) {
|
if (in_array($field, self::CONTENT_FIELDLIST)) {
|
||||||
unset($fields[$field]);
|
unset($fields[$field]);
|
||||||
} else {
|
} else {
|
||||||
$fields[$field] = null;
|
$fields[$field] = null;
|
||||||
|
@ -965,14 +895,6 @@ class Item
|
||||||
$item_content = DBA::selectFirst('item-content', [], ['uri-id' => $item['uri-id']]);
|
$item_content = DBA::selectFirst('item-content', [], ['uri-id' => $item['uri-id']]);
|
||||||
if (DBA::isResult($item_content)) {
|
if (DBA::isResult($item_content)) {
|
||||||
$item_fields = ['icid' => $item_content['id']];
|
$item_fields = ['icid' => $item_content['id']];
|
||||||
// Clear all fields in the item table that have a content in the item-content table
|
|
||||||
if (self::isLegacyMode()) {
|
|
||||||
foreach ($item_content as $field => $content) {
|
|
||||||
if (in_array($field, self::MIXED_CONTENT_FIELDLIST) && !empty($content)) {
|
|
||||||
$item_fields[$field] = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
DBA::update('item', $item_fields, ['id' => $item['id']]);
|
DBA::update('item', $item_fields, ['id' => $item['id']]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ class ItemContent
|
||||||
{
|
{
|
||||||
$condition = ["`uri-id` IN (SELECT `uri-id` FROM `item-content` WHERE MATCH (`title`, `content-warning`, `body`) AGAINST (? IN BOOLEAN MODE))
|
$condition = ["`uri-id` IN (SELECT `uri-id` FROM `item-content` WHERE MATCH (`title`, `content-warning`, `body`) AGAINST (? IN BOOLEAN MODE))
|
||||||
AND (NOT `private` OR (`private` AND `uid` = ?))
|
AND (NOT `private` OR (`private` AND `uid` = ?))
|
||||||
AND `uri-id` IN (SELECT `uri-id` FROM `item` WHERE `network` IN (?, ?, ?, ?))",
|
AND `uri-id` IN (SELECT `uri-id` FROM `post-view` WHERE `network` IN (?, ?, ?, ?))",
|
||||||
$search, $uid, Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
|
$search, $uid, Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
|
||||||
|
|
||||||
if (!empty($last_uriid)) {
|
if (!empty($last_uriid)) {
|
||||||
|
@ -71,7 +71,7 @@ class ItemContent
|
||||||
{
|
{
|
||||||
$condition = ["`uri-id` IN (SELECT `uri-id` FROM `item-content` WHERE MATCH (`title`, `content-warning`, `body`) AGAINST (? IN BOOLEAN MODE))
|
$condition = ["`uri-id` IN (SELECT `uri-id` FROM `item-content` WHERE MATCH (`title`, `content-warning`, `body`) AGAINST (? IN BOOLEAN MODE))
|
||||||
AND (NOT `private` OR (`private` AND `uid` = ?))
|
AND (NOT `private` OR (`private` AND `uid` = ?))
|
||||||
AND `uri-id` IN (SELECT `uri-id` FROM `item` WHERE `network` IN (?, ?, ?, ?))",
|
AND `uri-id` IN (SELECT `uri-id` FROM `post-view` WHERE `network` IN (?, ?, ?, ?))",
|
||||||
$search, $uid, Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
|
$search, $uid, Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
|
||||||
return Post::count($condition);
|
return Post::count($condition);
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,7 +60,7 @@ class Nodeinfo
|
||||||
|
|
||||||
$logger->debug('user statistics', $userStats);
|
$logger->debug('user statistics', $userStats);
|
||||||
|
|
||||||
$items = DBA::p("SELECT COUNT(*) AS `total`, `gravity` FROM `item` WHERE `origin` AND NOT `deleted` AND `uid` != 0 AND `gravity` IN (?, ?) GROUP BY `gravity`",
|
$items = DBA::p("SELECT COUNT(*) AS `total`, `gravity` FROM `post-view` WHERE `origin` AND NOT `deleted` AND `uid` != 0 AND `gravity` IN (?, ?) GROUP BY `gravity`",
|
||||||
GRAVITY_PARENT, GRAVITY_COMMENT);
|
GRAVITY_PARENT, GRAVITY_COMMENT);
|
||||||
while ($item = DBA::fetch($items)) {
|
while ($item = DBA::fetch($items)) {
|
||||||
if ($item['gravity'] == GRAVITY_PARENT) {
|
if ($item['gravity'] == GRAVITY_PARENT) {
|
||||||
|
|
|
@ -43,7 +43,7 @@ use Psr\Log\LoggerInterface;
|
||||||
* @property integer parent Parent Item Id
|
* @property integer parent Parent Item Id
|
||||||
* @property boolean seen Whether the notification was read or not.
|
* @property boolean seen Whether the notification was read or not.
|
||||||
* @property string verb Verb URL (@see http://activitystrea.ms)
|
* @property string verb Verb URL (@see http://activitystrea.ms)
|
||||||
* @property string otype Subject type (`item`, `intro` or `mail`)
|
* @property string otype Subject type ('item', 'intro' or 'mail')
|
||||||
*
|
*
|
||||||
* @property-read string name_cache Full name of the contact subject
|
* @property-read string name_cache Full name of the contact subject
|
||||||
* @property-read string msg_cache Plaintext version of the notification text with a placeholder (`{0}`) for the subject contact's name.
|
* @property-read string msg_cache Plaintext version of the notification text with a placeholder (`{0}`) for the subject contact's name.
|
||||||
|
|
|
@ -452,7 +452,7 @@ class Tag
|
||||||
public static function countByTag(string $search, int $uid = 0)
|
public static function countByTag(string $search, int $uid = 0)
|
||||||
{
|
{
|
||||||
$condition = ["`name` = ? AND (NOT `private` OR (`private` AND `uid` = ?))
|
$condition = ["`name` = ? AND (NOT `private` OR (`private` AND `uid` = ?))
|
||||||
AND `uri-id` IN (SELECT `uri-id` FROM `item` WHERE `network` IN (?, ?, ?, ?))",
|
AND `uri-id` IN (SELECT `uri-id` FROM `post-view` WHERE `network` IN (?, ?, ?, ?))",
|
||||||
$search, $uid, Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
|
$search, $uid, Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
|
||||||
$params = ['group_by' => ['uri-id']];
|
$params = ['group_by' => ['uri-id']];
|
||||||
|
|
||||||
|
@ -472,7 +472,7 @@ class Tag
|
||||||
public static function getURIIdListByTag(string $search, int $uid = 0, int $start = 0, int $limit = 100, int $last_uriid = 0)
|
public static function getURIIdListByTag(string $search, int $uid = 0, int $start = 0, int $limit = 100, int $last_uriid = 0)
|
||||||
{
|
{
|
||||||
$condition = ["`name` = ? AND (NOT `private` OR (`private` AND `uid` = ?))
|
$condition = ["`name` = ? AND (NOT `private` OR (`private` AND `uid` = ?))
|
||||||
AND `uri-id` IN (SELECT `uri-id` FROM `item` WHERE `network` IN (?, ?, ?, ?))",
|
AND `uri-id` IN (SELECT `uri-id` FROM `post-view` WHERE `network` IN (?, ?, ?, ?))",
|
||||||
$search, $uid, Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
|
$search, $uid, Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
|
||||||
|
|
||||||
if (!empty($last_uriid)) {
|
if (!empty($last_uriid)) {
|
||||||
|
|
|
@ -72,9 +72,8 @@ class UserItem
|
||||||
|
|
||||||
// Add every user who participated so far in this thread
|
// Add every user who participated so far in this thread
|
||||||
// This can only happen with participations on global items. (means: uid = 0)
|
// This can only happen with participations on global items. (means: uid = 0)
|
||||||
$users = DBA::p("SELECT DISTINCT(`contact`.`uid`) FROM `item`
|
$users = DBA::p("SELECT DISTINCT(`contact-uid`) AS `uid` FROM `post-view`
|
||||||
INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id` AND `contact`.`uid` != 0
|
WHERE `contact-uid` != 0 AND `parent` IN (SELECT `parent` FROM `post-view` WHERE `id` = ?)", $iid);
|
||||||
WHERE `parent` IN (SELECT `parent` FROM `item` WHERE `id`=?)", $iid);
|
|
||||||
while ($user = DBA::fetch($users)) {
|
while ($user = DBA::fetch($users)) {
|
||||||
$uids[] = $user['uid'];
|
$uids[] = $user['uid'];
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,11 +62,11 @@ class PublicTimeline extends BaseApi
|
||||||
'uid' => 0, 'network' => Protocol::FEDERATED];
|
'uid' => 0, 'network' => Protocol::FEDERATED];
|
||||||
|
|
||||||
if ($local) {
|
if ($local) {
|
||||||
$condition = DBA::mergeConditions($condition, ["`uri-id` IN (SELECT `uri-id` FROM `item` WHERE `origin`)"]);
|
$condition = DBA::mergeConditions($condition, ["`uri-id` IN (SELECT `uri-id` FROM `post-view` WHERE `origin`)"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($remote) {
|
if ($remote) {
|
||||||
$condition = DBA::mergeConditions($condition, ["NOT `uri-id` IN (SELECT `uri-id` FROM `item` WHERE `origin`)"]);
|
$condition = DBA::mergeConditions($condition, ["NOT `uri-id` IN (SELECT `uri-id` FROM `post-view` WHERE `origin`)"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($max_id)) {
|
if (!empty($max_id)) {
|
||||||
|
|
|
@ -181,7 +181,7 @@ class Status extends BaseProfile
|
||||||
|
|
||||||
$condition = DBA::mergeConditions($condition, ["((`gravity` = ? AND `wall`) OR
|
$condition = DBA::mergeConditions($condition, ["((`gravity` = ? AND `wall`) OR
|
||||||
(`gravity` = ? AND `vid` = ? AND `origin` AND `thr-parent-id` IN
|
(`gravity` = ? AND `vid` = ? AND `origin` AND `thr-parent-id` IN
|
||||||
(SELECT `uri-id` FROM `item` AS `i`
|
(SELECT `uri-id` FROM `post-view` AS `i`
|
||||||
WHERE `gravity` = ? AND `network` IN (?, ?, ?, ?) AND `uid` IN (?, ?)
|
WHERE `gravity` = ? AND `network` IN (?, ?, ?, ?) AND `uid` IN (?, ?)
|
||||||
AND `i`.`uri-id` = `thr-parent-id`)))",
|
AND `i`.`uri-id` = `thr-parent-id`)))",
|
||||||
GRAVITY_PARENT, GRAVITY_ACTIVITY, Verb::getID(Activity::ANNOUNCE), GRAVITY_PARENT,
|
GRAVITY_PARENT, GRAVITY_ACTIVITY, Verb::getID(Activity::ANNOUNCE), GRAVITY_PARENT,
|
||||||
|
|
|
@ -71,27 +71,18 @@ class Profile extends BaseModule
|
||||||
// If the page user is the owner of the page we should query for unseen
|
// If the page user is the owner of the page we should query for unseen
|
||||||
// items. Otherwise use a timestamp of the last succesful update request.
|
// items. Otherwise use a timestamp of the last succesful update request.
|
||||||
if ($is_owner || !$last_updated) {
|
if ($is_owner || !$last_updated) {
|
||||||
$sql_extra4 = " AND `item`.`unseen`";
|
$sql_extra4 = " AND `unseen`";
|
||||||
} else {
|
} else {
|
||||||
$gmupdate = gmdate(DateTimeFormat::MYSQL, $last_updated);
|
$gmupdate = gmdate(DateTimeFormat::MYSQL, $last_updated);
|
||||||
$sql_extra4 = " AND `item`.`received` > '" . $gmupdate . "'";
|
$sql_extra4 = " AND `received` > '" . $gmupdate . "'";
|
||||||
}
|
}
|
||||||
|
|
||||||
$items_stmt = DBA::p(
|
$items_stmt = DBA::p(
|
||||||
"SELECT DISTINCT(`parent-uri`) AS `uri`, `item`.`created`
|
"SELECT DISTINCT(`parent-uri`) AS `uri`, `created` FROM `post-view`
|
||||||
FROM `item`
|
WHERE `uid` = ? AND NOT `contact-blocked` AND NOT `contact-pending`
|
||||||
INNER JOIN `contact`
|
AND `visible` AND (NOT `deleted` OR `gravity` = ?)
|
||||||
ON `contact`.`id` = `item`.`contact-id`
|
AND NOT `moderated` AND `wall` $sql_extra4 $sql_extra
|
||||||
AND NOT `contact`.`blocked`
|
ORDER BY `received` DESC",
|
||||||
AND NOT `contact`.`pending`
|
|
||||||
WHERE `item`.`uid` = ?
|
|
||||||
AND `item`.`visible`
|
|
||||||
AND (NOT `item`.`deleted` OR `item`.`gravity` = ?)
|
|
||||||
AND NOT `item`.`moderated`
|
|
||||||
AND `item`.`wall`
|
|
||||||
$sql_extra4
|
|
||||||
$sql_extra
|
|
||||||
ORDER BY `item`.`received` DESC",
|
|
||||||
$a->profile['uid'],
|
$a->profile['uid'],
|
||||||
GRAVITY_ACTIVITY
|
GRAVITY_ACTIVITY
|
||||||
);
|
);
|
||||||
|
|
|
@ -63,7 +63,7 @@ class Notification extends BaseEntity
|
||||||
protected $seen;
|
protected $seen;
|
||||||
/** @var string Verb URL @see http://activitystrea.ms */
|
/** @var string Verb URL @see http://activitystrea.ms */
|
||||||
protected $verb;
|
protected $verb;
|
||||||
/** @var string Subject type (`item`, `intro` or `mail`) */
|
/** @var string Subject type ('item', 'intro' or 'mail') */
|
||||||
protected $otype;
|
protected $otype;
|
||||||
/** @var string Full name of the contact subject (HTML) */
|
/** @var string Full name of the contact subject (HTML) */
|
||||||
protected $name_cache;
|
protected $name_cache;
|
||||||
|
|
|
@ -184,7 +184,7 @@ class DFRN
|
||||||
|
|
||||||
// default permissions - anonymous user
|
// default permissions - anonymous user
|
||||||
|
|
||||||
$sql_extra = sprintf(" AND `item`.`private` != %s ", Item::PRIVATE);
|
$sql_extra = sprintf(" AND `private` != %s ", Item::PRIVATE);
|
||||||
|
|
||||||
$owner = DBA::selectFirst('owner-view', [], ['nickname' => $owner_nick]);
|
$owner = DBA::selectFirst('owner-view', [], ['nickname' => $owner_nick]);
|
||||||
if (!DBA::isResult($owner)) {
|
if (!DBA::isResult($owner)) {
|
||||||
|
@ -194,9 +194,7 @@ class DFRN
|
||||||
|
|
||||||
$owner_id = $owner['uid'];
|
$owner_id = $owner['uid'];
|
||||||
|
|
||||||
$sql_post_table = "";
|
if (!$public_feed) {
|
||||||
|
|
||||||
if (! $public_feed) {
|
|
||||||
switch ($direction) {
|
switch ($direction) {
|
||||||
case (-1):
|
case (-1):
|
||||||
$sql_extra = sprintf(" AND `issued-id` = '%s' ", DBA::escape($dfrn_id));
|
$sql_extra = sprintf(" AND `issued-id` = '%s' ", DBA::escape($dfrn_id));
|
||||||
|
@ -212,71 +210,41 @@ class DFRN
|
||||||
break; // NOTREACHED
|
break; // NOTREACHED
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = q(
|
$contact = DBA::selectFirst('contact', [], ["NOT `blocked` AND `contact`.`uid` = ?" . $sql_extra, $owner_id]);
|
||||||
"SELECT * FROM `contact` WHERE NOT `blocked` AND `contact`.`uid` = %d $sql_extra LIMIT 1",
|
if (!DBA::isResult($contact)) {
|
||||||
intval($owner_id)
|
Logger::notice('No contact found', ['uid' => $owner_id]);
|
||||||
);
|
|
||||||
|
|
||||||
if (! DBA::isResult($r)) {
|
|
||||||
Logger::log(sprintf('No contact found for uid=%d', $owner_id), Logger::WARNING);
|
|
||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
$contact = $r[0];
|
|
||||||
|
|
||||||
$set = PermissionSet::get($owner_id, $contact['id']);
|
$set = PermissionSet::get($owner_id, $contact['id']);
|
||||||
|
|
||||||
if (!empty($set)) {
|
if (!empty($set)) {
|
||||||
$sql_extra = " AND `item`.`psid` IN (" . implode(',', $set) .")";
|
$sql_extra = " AND `psid` IN (" . implode(',', $set) .")";
|
||||||
} else {
|
} else {
|
||||||
$sql_extra = sprintf(" AND `item`.`private` != %s", Item::PRIVATE);
|
$sql_extra = sprintf(" AND `private` != %s", Item::PRIVATE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($public_feed) {
|
if (!strlen($last_update)) {
|
||||||
$sort = 'DESC';
|
|
||||||
} else {
|
|
||||||
$sort = 'ASC';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (! strlen($last_update)) {
|
|
||||||
$last_update = 'now -30 days';
|
$last_update = 'now -30 days';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($category)) {
|
if (isset($category)) {
|
||||||
$sql_post_table = sprintf("INNER JOIN (SELECT `uri-id` FROM `category-view` WHERE `name` = '%s' AND `type` = %d AND `uid` = %d ORDER BY `uri-id` DESC) AS `category` ON `item`.`uri-id` = `category`.`uri-id` ",
|
$sql_extra .= sprintf(" AND `uri-id` IN (SELECT `uri-id` FROM `category-view` WHERE `name` = '%s' AND `type` = %d AND `uid` = %d)",
|
||||||
DBA::escape(Strings::protectSprintf($category)), intval(Category::CATEGORY), intval($owner_id));
|
DBA::escape(Strings::protectSprintf($category)), intval(Category::CATEGORY), intval($owner_id));
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($public_feed && ! $converse) {
|
if ($public_feed && ! $converse) {
|
||||||
$sql_extra .= " AND `contact`.`self` = 1 ";
|
$sql_extra .= " AND `self` ";
|
||||||
}
|
}
|
||||||
|
|
||||||
$check_date = DateTimeFormat::utc($last_update);
|
$check_date = DateTimeFormat::utc($last_update);
|
||||||
|
|
||||||
$r = q(
|
$condition = ["`uid` = ? AND `wall` AND `changed` > ? AND `vid` != ? AND `visible`" . $sql_extra,
|
||||||
"SELECT `item`.`id`
|
$owner_id, $check_date, Verb::getID(Activity::ANNOUNCE)];
|
||||||
FROM `item` USE INDEX (`uid_wall_changed`) $sql_post_table
|
|
||||||
STRAIGHT_JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
|
|
||||||
WHERE `item`.`uid` = %d AND `item`.`wall` AND `item`.`changed` > '%s'
|
|
||||||
AND `vid` != %d AND `item`.`visible` $sql_extra
|
|
||||||
ORDER BY `item`.`parent` ".$sort.", `item`.`received` ASC LIMIT 0, 300",
|
|
||||||
intval($owner_id),
|
|
||||||
DBA::escape($check_date),
|
|
||||||
Verb::getID(Activity::ANNOUNCE),
|
|
||||||
DBA::escape($sort)
|
|
||||||
);
|
|
||||||
|
|
||||||
$ids = [];
|
$params = ['sort' => ['parent' => $public_feed, 'received']];
|
||||||
foreach ($r as $item) {
|
$items = Post::selectToArray(Item::DELIVER_FIELDLIST, $condition, $params, ['limit' => 300]);
|
||||||
$ids[] = $item['id'];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($ids)) {
|
|
||||||
$items = Post::selectToArray(Item::DELIVER_FIELDLIST, ['id' => $ids]);
|
|
||||||
} else {
|
|
||||||
$items = [];
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Will check further below if this actually returned results.
|
* Will check further below if this actually returned results.
|
||||||
|
@ -1924,32 +1892,15 @@ class DFRN
|
||||||
$community = true;
|
$community = true;
|
||||||
Logger::log("possible community action");
|
Logger::log("possible community action");
|
||||||
} else {
|
} else {
|
||||||
$sql_extra = " AND `contact`.`self` AND `item`.`wall` ";
|
$sql_extra = " AND `self` AND `wall`";
|
||||||
}
|
}
|
||||||
|
|
||||||
// was the top-level post for this action written by somebody on this site?
|
// was the top-level post for this action written by somebody on this site?
|
||||||
// Specifically, the recipient?
|
// Specifically, the recipient?
|
||||||
|
$parent = Post::selectFirst(['forum_mode', 'wall'],
|
||||||
|
["`uri` = ? AND `uid` = ?" . $sql_extra, $item["thr-parent"], $importer["importer_uid"]]);
|
||||||
|
|
||||||
$is_a_remote_action = false;
|
$is_a_remote_action = DBA::isResult($parent);
|
||||||
|
|
||||||
$parent = Post::selectFirst(['thr-parent'], ['uri' => $item["thr-parent"]]);
|
|
||||||
if (DBA::isResult($parent)) {
|
|
||||||
$r = q(
|
|
||||||
"SELECT `item`.`forum_mode`, `item`.`wall` FROM `item`
|
|
||||||
INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
|
|
||||||
WHERE `item`.`uri` = '%s' AND (`item`.`thr-parent` = '%s' OR `item`.`thr-parent` = '%s')
|
|
||||||
AND `item`.`uid` = %d
|
|
||||||
$sql_extra
|
|
||||||
LIMIT 1",
|
|
||||||
DBA::escape($parent["thr-parent"]),
|
|
||||||
DBA::escape($parent["thr-parent"]),
|
|
||||||
DBA::escape($parent["thr-parent"]),
|
|
||||||
intval($importer["importer_uid"])
|
|
||||||
);
|
|
||||||
if (DBA::isResult($r)) {
|
|
||||||
$is_a_remote_action = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Does this have the characteristics of a community or private group action?
|
* Does this have the characteristics of a community or private group action?
|
||||||
|
@ -1957,7 +1908,7 @@ class DFRN
|
||||||
* valid community action. Also forum_mode makes it valid for sure.
|
* valid community action. Also forum_mode makes it valid for sure.
|
||||||
* If neither, it's not.
|
* If neither, it's not.
|
||||||
*/
|
*/
|
||||||
if ($is_a_remote_action && $community && (!$r[0]["forum_mode"]) && (!$r[0]["wall"])) {
|
if ($is_a_remote_action && $community && (!$parent["forum_mode"]) && (!$parent["wall"])) {
|
||||||
$is_a_remote_action = false;
|
$is_a_remote_action = false;
|
||||||
Logger::log("not a community action");
|
Logger::log("not a community action");
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,7 +55,7 @@
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
|
|
||||||
if (!defined('DB_UPDATE_VERSION')) {
|
if (!defined('DB_UPDATE_VERSION')) {
|
||||||
define('DB_UPDATE_VERSION', 1388);
|
define('DB_UPDATE_VERSION', 1389);
|
||||||
}
|
}
|
||||||
|
|
||||||
return [
|
return [
|
||||||
|
|
|
@ -106,10 +106,13 @@
|
||||||
"contact-avatar" => ["contact", "thumb"],
|
"contact-avatar" => ["contact", "thumb"],
|
||||||
"contact-network" => ["contact", "network"],
|
"contact-network" => ["contact", "network"],
|
||||||
"contact-blocked" => ["contact", "blocked"],
|
"contact-blocked" => ["contact", "blocked"],
|
||||||
|
"contact-hidden" => ["contact", "hidden"],
|
||||||
"contact-readonly" => ["contact", "readonly"],
|
"contact-readonly" => ["contact", "readonly"],
|
||||||
|
"contact-archive" => ["contact", "archive"],
|
||||||
"contact-pending" => ["contact", "pending"],
|
"contact-pending" => ["contact", "pending"],
|
||||||
"contact-rel" => ["contact", "rel"],
|
"contact-rel" => ["contact", "rel"],
|
||||||
"contact-uid" => ["contact", "uid"],
|
"contact-uid" => ["contact", "uid"],
|
||||||
|
"contact-contact-type" => ["contact", "contact-type"],
|
||||||
"writable" => "IF (`item`.`network` IN ('apub', 'dfrn', 'dspr', 'stat'), true, `contact`.`writable`)",
|
"writable" => "IF (`item`.`network` IN ('apub', 'dfrn', 'dspr', 'stat'), true, `contact`.`writable`)",
|
||||||
"self" => ["contact", "self"],
|
"self" => ["contact", "self"],
|
||||||
"cid" => ["contact", "id"],
|
"cid" => ["contact", "id"],
|
||||||
|
|
|
@ -58,7 +58,6 @@ class StaticDatabase extends Database
|
||||||
$this->connection = self::$staticConnection;
|
$this->connection = self::$staticConnection;
|
||||||
$this->connected = true;
|
$this->connected = true;
|
||||||
$this->emulate_prepares = false;
|
$this->emulate_prepares = false;
|
||||||
$this->pdo_emulate_prepares = false;
|
|
||||||
|
|
||||||
return $this->connected;
|
return $this->connected;
|
||||||
}
|
}
|
||||||
|
|
|
@ -179,6 +179,50 @@ return [
|
||||||
'guid' => '6',
|
'guid' => '6',
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
|
'item-content' => [
|
||||||
|
[
|
||||||
|
'id' => 1,
|
||||||
|
'uri-id' => 1,
|
||||||
|
'uri-plink-hash' => '1',
|
||||||
|
'body' => 'Parent status',
|
||||||
|
'plink' => 'http://localhost/display/1',
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'id' => 2,
|
||||||
|
'uri-id' => 2,
|
||||||
|
'uri-plink-hash' => '2',
|
||||||
|
'body' => 'Reply',
|
||||||
|
'plink' => 'http://localhost/display/2',
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'id' => 3,
|
||||||
|
'uri-id' => 3,
|
||||||
|
'uri-plink-hash' => '3',
|
||||||
|
'body' => 'Other user status',
|
||||||
|
'plink' => 'http://localhost/display/3',
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'id' => 4,
|
||||||
|
'uri-id' => 4,
|
||||||
|
'uri-plink-hash' => '4',
|
||||||
|
'body' => 'Friend user reply',
|
||||||
|
'plink' => 'http://localhost/display/4',
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'id' => 5,
|
||||||
|
'uri-id' => 5,
|
||||||
|
'uri-plink-hash' => '5',
|
||||||
|
'body' => '[share]Shared status[/share]',
|
||||||
|
'plink' => 'http://localhost/display/5',
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'id' => 6,
|
||||||
|
'uri-id' => 6,
|
||||||
|
'uri-plink-hash' => '6',
|
||||||
|
'body' => 'Friend user status',
|
||||||
|
'plink' => 'http://localhost/display/6',
|
||||||
|
],
|
||||||
|
],
|
||||||
'item' => [
|
'item' => [
|
||||||
[
|
[
|
||||||
'id' => 1,
|
'id' => 1,
|
||||||
|
@ -191,7 +235,6 @@ return [
|
||||||
'uid' => 42,
|
'uid' => 42,
|
||||||
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
||||||
'unseen' => 1,
|
'unseen' => 1,
|
||||||
'body' => 'Parent status',
|
|
||||||
'parent' => 1,
|
'parent' => 1,
|
||||||
'parent-uri-id' => 1,
|
'parent-uri-id' => 1,
|
||||||
'thr-parent-id' => 1,
|
'thr-parent-id' => 1,
|
||||||
|
@ -205,7 +248,6 @@ return [
|
||||||
'deny_cid' => '',
|
'deny_cid' => '',
|
||||||
'deny_gid' => '',
|
'deny_gid' => '',
|
||||||
'guid' => '1',
|
'guid' => '1',
|
||||||
'plink' => 'http://localhost/display/1',
|
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'id' => 2,
|
'id' => 2,
|
||||||
|
@ -218,7 +260,6 @@ return [
|
||||||
'uid' => 42,
|
'uid' => 42,
|
||||||
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
||||||
'unseen' => 0,
|
'unseen' => 0,
|
||||||
'body' => 'Reply',
|
|
||||||
'parent' => 1,
|
'parent' => 1,
|
||||||
'parent-uri-id' => 1,
|
'parent-uri-id' => 1,
|
||||||
'thr-parent-id' => 1,
|
'thr-parent-id' => 1,
|
||||||
|
@ -228,10 +269,8 @@ return [
|
||||||
'starred' => 0,
|
'starred' => 0,
|
||||||
'origin' => 1,
|
'origin' => 1,
|
||||||
'guid' => '2',
|
'guid' => '2',
|
||||||
'plink' => 'http://localhost/display/2',
|
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
|
|
||||||
'id' => 3,
|
'id' => 3,
|
||||||
'uri-id' => 3,
|
'uri-id' => 3,
|
||||||
'visible' => 1,
|
'visible' => 1,
|
||||||
|
@ -242,7 +281,6 @@ return [
|
||||||
'uid' => 42,
|
'uid' => 42,
|
||||||
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
||||||
'unseen' => 0,
|
'unseen' => 0,
|
||||||
'body' => 'Other user status',
|
|
||||||
'parent' => 3,
|
'parent' => 3,
|
||||||
'parent-uri-id' => 3,
|
'parent-uri-id' => 3,
|
||||||
'thr-parent-id' => 3,
|
'thr-parent-id' => 3,
|
||||||
|
@ -252,7 +290,6 @@ return [
|
||||||
'starred' => 0,
|
'starred' => 0,
|
||||||
'origin' => 1,
|
'origin' => 1,
|
||||||
'guid' => '3',
|
'guid' => '3',
|
||||||
'plink' => 'http://localhost/display/3',
|
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'id' => 4,
|
'id' => 4,
|
||||||
|
@ -275,7 +312,6 @@ return [
|
||||||
'starred' => 0,
|
'starred' => 0,
|
||||||
'origin' => 1,
|
'origin' => 1,
|
||||||
'guid' => '4',
|
'guid' => '4',
|
||||||
'plink' => 'http://localhost/display/4',
|
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
|
|
||||||
|
@ -289,7 +325,6 @@ return [
|
||||||
'uid' => 42,
|
'uid' => 42,
|
||||||
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
||||||
'unseen' => 0,
|
'unseen' => 0,
|
||||||
'body' => '[share]Shared status[/share]',
|
|
||||||
'parent' => 1,
|
'parent' => 1,
|
||||||
'parent-uri-id' => 1,
|
'parent-uri-id' => 1,
|
||||||
'thr-parent-id' => 1,
|
'thr-parent-id' => 1,
|
||||||
|
@ -303,7 +338,6 @@ return [
|
||||||
'deny_cid' => '',
|
'deny_cid' => '',
|
||||||
'deny_gid' => '',
|
'deny_gid' => '',
|
||||||
'guid' => '5',
|
'guid' => '5',
|
||||||
'plink' => 'http://localhost/display/5',
|
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'id' => 6,
|
'id' => 6,
|
||||||
|
@ -316,7 +350,6 @@ return [
|
||||||
'uid' => 42,
|
'uid' => 42,
|
||||||
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
'verb' => 'http://activitystrea.ms/schema/1.0/post',
|
||||||
'unseen' => 0,
|
'unseen' => 0,
|
||||||
'body' => 'Friend user status',
|
|
||||||
'parent' => 6,
|
'parent' => 6,
|
||||||
'parent-uri-id' => 6,
|
'parent-uri-id' => 6,
|
||||||
'thr-parent-id' => 6,
|
'thr-parent-id' => 6,
|
||||||
|
@ -326,7 +359,6 @@ return [
|
||||||
'starred' => 0,
|
'starred' => 0,
|
||||||
'origin' => 1,
|
'origin' => 1,
|
||||||
'guid' => '6',
|
'guid' => '6',
|
||||||
'plink' => 'http://localhost/display/6',
|
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
'notify' => [
|
'notify' => [
|
||||||
|
|
|
@ -12,7 +12,6 @@ return [
|
||||||
'password' => 'testpw',
|
'password' => 'testpw',
|
||||||
'database' => 'testdb',
|
'database' => 'testdb',
|
||||||
'charset' => 'utf8mb4',
|
'charset' => 'utf8mb4',
|
||||||
'pdo_emulate_prepares' => true,
|
|
||||||
],
|
],
|
||||||
|
|
||||||
'config' => [
|
'config' => [
|
||||||
|
|
|
@ -12,7 +12,6 @@ return [
|
||||||
'password' => 'testpw',
|
'password' => 'testpw',
|
||||||
'database' => 'testdb',
|
'database' => 'testdb',
|
||||||
'charset' => 'utf8mb4',
|
'charset' => 'utf8mb4',
|
||||||
'pdo_emulate_prepares' => true,
|
|
||||||
],
|
],
|
||||||
|
|
||||||
'config' => [
|
'config' => [
|
||||||
|
|
|
@ -447,7 +447,7 @@ return [
|
||||||
'password' => '{$conf('database', 'password')}',
|
'password' => '{$conf('database', 'password')}',
|
||||||
'database' => '{$conf('database', 'database')}',
|
'database' => '{$conf('database', 'database')}',
|
||||||
'charset' => 'utf8mb4',
|
'charset' => 'utf8mb4',
|
||||||
'pdo_emulate_prepares' => true,
|
'pdo_emulate_prepares' => false,
|
||||||
],
|
],
|
||||||
|
|
||||||
// ****************************************************************
|
// ****************************************************************
|
||||||
|
|
218
update.php
218
update.php
|
@ -53,227 +53,9 @@ use Friendica\Model\Item;
|
||||||
use Friendica\Model\Notify;
|
use Friendica\Model\Notify;
|
||||||
use Friendica\Model\Photo;
|
use Friendica\Model\Photo;
|
||||||
use Friendica\Model\Post;
|
use Friendica\Model\Post;
|
||||||
use Friendica\Model\User;
|
|
||||||
use Friendica\Model\Storage;
|
use Friendica\Model\Storage;
|
||||||
use Friendica\Util\DateTimeFormat;
|
|
||||||
use Friendica\Worker\Delivery;
|
use Friendica\Worker\Delivery;
|
||||||
|
|
||||||
function update_1179()
|
|
||||||
{
|
|
||||||
if (DI::config()->get('system', 'no_community_page')) {
|
|
||||||
DI::config()->set('system', 'community_page_style', CP_NO_COMMUNITY_PAGE);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update the central item storage with uid=0
|
|
||||||
Worker::add(PRIORITY_LOW, "threadupdate");
|
|
||||||
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1181()
|
|
||||||
{
|
|
||||||
|
|
||||||
// Fill the new fields in the term table.
|
|
||||||
// deactivated, the "term" table is deprecated
|
|
||||||
// Worker::add(PRIORITY_LOW, "TagUpdate");
|
|
||||||
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1189()
|
|
||||||
{
|
|
||||||
|
|
||||||
if (strlen(DI::config()->get('system', 'directory_submit_url')) &&
|
|
||||||
!strlen(DI::config()->get('system', 'directory'))) {
|
|
||||||
DI::config()->set('system', 'directory', dirname(DI::config()->get('system', 'directory_submit_url')));
|
|
||||||
DI::config()->delete('system', 'directory_submit_url');
|
|
||||||
}
|
|
||||||
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1191()
|
|
||||||
{
|
|
||||||
DI::config()->set('system', 'maintenance', 1);
|
|
||||||
|
|
||||||
if (Addon::isEnabled('forumlist')) {
|
|
||||||
Addon::uninstall('forumlist');
|
|
||||||
}
|
|
||||||
|
|
||||||
// select old formlist addon entries
|
|
||||||
$r = q("SELECT `uid`, `cat`, `k`, `v` FROM `pconfig` WHERE `cat` = '%s' ",
|
|
||||||
DBA::escape('forumlist')
|
|
||||||
);
|
|
||||||
|
|
||||||
// convert old forumlist addon entries in new config entries
|
|
||||||
if (DBA::isResult($r)) {
|
|
||||||
foreach ($r as $rr) {
|
|
||||||
$uid = $rr['uid'];
|
|
||||||
$family = $rr['cat'];
|
|
||||||
$key = $rr['k'];
|
|
||||||
$value = $rr['v'];
|
|
||||||
|
|
||||||
if ($key === 'randomise') {
|
|
||||||
DI::pConfig()->delete($uid, $family, $key);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($key === 'show_on_profile') {
|
|
||||||
if ($value) {
|
|
||||||
DI::pConfig()->set($uid, 'feature', 'forumlist_profile', $value);
|
|
||||||
}
|
|
||||||
|
|
||||||
DI::pConfig()->delete($uid, $family, $key);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($key === 'show_on_network') {
|
|
||||||
if ($value) {
|
|
||||||
DI::pConfig()->set($uid, 'feature', 'forumlist_widget', $value);
|
|
||||||
}
|
|
||||||
|
|
||||||
DI::pConfig()->delete($uid, $family, $key);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
DI::config()->set('system', 'maintenance', 0);
|
|
||||||
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1203()
|
|
||||||
{
|
|
||||||
$r = q("UPDATE `user` SET `account-type` = %d WHERE `page-flags` IN (%d, %d)",
|
|
||||||
DBA::escape(User::ACCOUNT_TYPE_COMMUNITY),
|
|
||||||
DBA::escape(User::PAGE_FLAGS_COMMUNITY),
|
|
||||||
DBA::escape(User::PAGE_FLAGS_PRVGROUP)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1244()
|
|
||||||
{
|
|
||||||
// Sets legacy_password for all legacy hashes
|
|
||||||
DBA::update('user', ['legacy_password' => true], ['SUBSTR(password, 1, 4) != "$2y$"']);
|
|
||||||
|
|
||||||
// All legacy hashes are re-hashed using the new secure hashing function
|
|
||||||
$stmt = DBA::select('user', ['uid', 'password'], ['legacy_password' => true]);
|
|
||||||
while ($user = DBA::fetch($stmt)) {
|
|
||||||
DBA::update('user', ['password' => User::hashPassword($user['password'])], ['uid' => $user['uid']]);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Logged in users are forcibly logged out
|
|
||||||
DBA::delete('session', ['1 = 1']);
|
|
||||||
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1245()
|
|
||||||
{
|
|
||||||
$rino = DI::config()->get('system', 'rino_encrypt');
|
|
||||||
|
|
||||||
if (!$rino) {
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
DI::config()->set('system', 'rino_encrypt', 1);
|
|
||||||
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1247()
|
|
||||||
{
|
|
||||||
// Removing hooks with the old name
|
|
||||||
DBA::e("DELETE FROM `hook`
|
|
||||||
WHERE `hook` LIKE 'plugin_%'");
|
|
||||||
|
|
||||||
// Make sure we install the new renamed ones
|
|
||||||
Addon::reload();
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1260()
|
|
||||||
{
|
|
||||||
DI::config()->set('system', 'maintenance', 1);
|
|
||||||
DI::config()->set(
|
|
||||||
'system',
|
|
||||||
'maintenance_reason',
|
|
||||||
DI::l10n()->t(
|
|
||||||
'%s: Updating author-id and owner-id in item and thread table. ',
|
|
||||||
DateTimeFormat::utcNow().' '.date('e')
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
$items = DBA::p("SELECT `id`, `owner-link`, `owner-name`, `owner-avatar`, `network` FROM `item`
|
|
||||||
WHERE `owner-id` = 0 AND `owner-link` != ''");
|
|
||||||
while ($item = DBA::fetch($items)) {
|
|
||||||
$contact = ['url' => $item['owner-link'], 'name' => $item['owner-name'],
|
|
||||||
'photo' => $item['owner-avatar'], 'network' => $item['network']];
|
|
||||||
$cid = Contact::getIdForURL($item['owner-link'], 0, null, $contact);
|
|
||||||
if (empty($cid)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
Item::update(['owner-id' => $cid], ['id' => $item['id']]);
|
|
||||||
}
|
|
||||||
DBA::close($items);
|
|
||||||
|
|
||||||
DBA::e("UPDATE `thread` INNER JOIN `item` ON `thread`.`iid` = `item`.`id`
|
|
||||||
SET `thread`.`owner-id` = `item`.`owner-id` WHERE `thread`.`owner-id` = 0");
|
|
||||||
|
|
||||||
$items = DBA::p("SELECT `id`, `author-link`, `author-name`, `author-avatar`, `network` FROM `item`
|
|
||||||
WHERE `author-id` = 0 AND `author-link` != ''");
|
|
||||||
while ($item = DBA::fetch($items)) {
|
|
||||||
$contact = ['url' => $item['author-link'], 'name' => $item['author-name'],
|
|
||||||
'photo' => $item['author-avatar'], 'network' => $item['network']];
|
|
||||||
$cid = Contact::getIdForURL($item['author-link'], 0, null, $contact);
|
|
||||||
if (empty($cid)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
Item::update(['author-id' => $cid], ['id' => $item['id']]);
|
|
||||||
}
|
|
||||||
DBA::close($items);
|
|
||||||
|
|
||||||
DBA::e("UPDATE `thread` INNER JOIN `item` ON `thread`.`iid` = `item`.`id`
|
|
||||||
SET `thread`.`author-id` = `item`.`author-id` WHERE `thread`.`author-id` = 0");
|
|
||||||
|
|
||||||
DI::config()->set('system', 'maintenance', 0);
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1261()
|
|
||||||
{
|
|
||||||
// This fixes the results of an issue in the develop branch of 2018-05.
|
|
||||||
DBA::update('contact', ['blocked' => false, 'pending' => false], ['uid' => 0, 'blocked' => true, 'pending' => true]);
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1278()
|
|
||||||
{
|
|
||||||
DI::config()->set('system', 'maintenance', 1);
|
|
||||||
DI::config()->set(
|
|
||||||
'system',
|
|
||||||
'maintenance_reason',
|
|
||||||
DI::l10n()->t(
|
|
||||||
'%s: Updating post-type.',
|
|
||||||
DateTimeFormat::utcNow().' '.date('e')
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
Item::update(['post-type' => Item::PT_PAGE], ['bookmark' => true]);
|
|
||||||
Item::update(['post-type' => Item::PT_PERSONAL_NOTE], ['type' => 'note']);
|
|
||||||
|
|
||||||
DI::config()->set('system', 'maintenance', 0);
|
|
||||||
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
function update_1288()
|
|
||||||
{
|
|
||||||
// Updates missing `uri-id` values
|
|
||||||
|
|
||||||
DBA::e("UPDATE `item-activity` INNER JOIN `item` ON `item`.`iaid` = `item-activity`.`id` SET `item-activity`.`uri-id` = `item`.`uri-id` WHERE `item-activity`.`uri-id` IS NULL OR `item-activity`.`uri-id` = 0");
|
|
||||||
DBA::e("UPDATE `item-content` INNER JOIN `item` ON `item`.`icid` = `item-content`.`id` SET `item-content`.`uri-id` = `item`.`uri-id` WHERE `item-content`.`uri-id` IS NULL OR `item-content`.`uri-id` = 0");
|
|
||||||
|
|
||||||
return Update::SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Post-update script of PR 5751
|
// Post-update script of PR 5751
|
||||||
function update_1298()
|
function update_1298()
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Reference in a new issue