]> git.mxchange.org Git - friendica.git/blob - src/Worker/TagUpdate.php
Merge remote-tracking branch 'upstream/develop' into post-delivery-data
[friendica.git] / src / Worker / TagUpdate.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2020, Friendica
4  *
5  * @license GNU AGPL version 3 or any later version
6  *
7  * This program is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU Affero General Public License as
9  * published by the Free Software Foundation, either version 3 of the
10  * License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU Affero General Public License for more details.
16  *
17  * You should have received a copy of the GNU Affero General Public License
18  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
19  *
20  */
21
22 namespace Friendica\Worker;
23
24 use Friendica\Core\Logger;
25 use Friendica\Database\DBA;
26 use Friendica\Model\Term;
27
28 class TagUpdate
29 {
30         public static function execute()
31         {
32                 $messages = DBA::p("SELECT `oid`,`item`.`guid`, `item`.`created`, `item`.`received` FROM `term` INNER JOIN `item` ON `item`.`id`=`term`.`oid` WHERE `term`.`otype` = 1 AND `term`.`guid` = ''");
33
34                 Logger::log('fetched messages: ' . DBA::numRows($messages));
35                 while ($message = DBA::fetch($messages)) {
36                         if ($message['uid'] == 0) {
37                                 $global = true;
38
39                                 DBA::update('term', ['global' => true], ['otype' => Term::OBJECT_TYPE_POST, 'guid' => $message['guid']]);
40                         } else {
41                                 $global = (DBA::count('term', ['uid' => 0, 'otype' => Term::OBJECT_TYPE_POST, 'guid' => $message['guid']]) > 0);
42                         }
43
44                         $fields = ['guid' => $message['guid'], 'created' => $message['created'],
45                                 'received' => $message['received'], 'global' => $global];
46                         DBA::update('term', $fields, ['otype' => Term::OBJECT_TYPE_POST, 'oid' => $message['oid']]);
47                 }
48
49                 DBA::close($messages);
50
51                 $messages = DBA::select('item', ['guid'], ['uid' => 0]);
52
53                 Logger::log('fetched messages: ' . DBA::numRows($messages));
54                 while ($message = DBA::fetch($messages)) {
55                         DBA::update('item', ['global' => true], ['guid' => $message['guid']]);
56                 }
57
58                 DBA::close($messages);
59         }
60 }