]> git.mxchange.org Git - friendica.git/blob - src/Worker/UpdateGServers.php
Merge remote-tracking branch 'upstream/develop' into mod-item
[friendica.git] / src / Worker / UpdateGServers.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2010-2023, the Friendica project
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\Core\Worker;
26 use Friendica\Database\DBA;
27 use Friendica\DI;
28 use Friendica\Util\DateTimeFormat;
29 use Friendica\Util\Strings;
30 use GuzzleHttp\Psr7\Uri;
31
32 class UpdateGServers
33 {
34         /**
35          * Updates a defined number of servers
36          */
37         public static function execute()
38         {
39                 $update_limit = DI::config()->get('system', 'gserver_update_limit');
40                 if (empty($update_limit)) {
41                         return;
42                 }
43
44                 $updating = Worker::countWorkersByCommand('UpdateGServer');
45                 $limit = $update_limit - $updating;
46                 if ($limit <= 0) {
47                         Logger::info('The number of currently running jobs exceed the limit');
48                         return;
49                 }
50
51                 $total = DBA::count('gserver');
52                 $condition = ["`next_contact` < ? AND (`nurl` != ? OR `url` != ?)",  DateTimeFormat::utcNow(), '', ''];
53                 $outdated = DBA::count('gserver', $condition);
54                 Logger::info('Server status', ['total' => $total, 'outdated' => $outdated, 'updating' => $limit]);
55
56                 $gservers = DBA::select('gserver', ['url', 'nurl'], $condition, ['limit' => $limit]);
57                 if (!DBA::isResult($gservers)) {
58                         return;
59                 }
60
61                 $count = 0;
62                 while ($gserver = DBA::fetch($gservers)) {
63                         // Sometimes the "nurl" and "url" doesn't seem to fit, see https://forum.friendi.ca/display/ec054ce7-155f-c94d-6159-f50372664245
64                         // There are duplicated "url" but not "nurl". So we check both addresses instead of just overwriting them,
65                         // since that would mean loosing data.
66                         if (!empty($gserver['url'])) {
67                                 if (UpdateGServer::add(Worker::PRIORITY_LOW, $gserver['url'])) {
68                                         $count++;
69                                 }
70                         }
71                         if (!empty($gserver['nurl']) && ($gserver['nurl'] != Strings::normaliseLink($gserver['url']))) {
72                                 if (UpdateGServer::add(Worker::PRIORITY_LOW, $gserver['nurl'])) {
73                                         $count++;
74                                 }
75                         }
76                         Worker::coolDown();
77                 }
78                 DBA::close($gservers);
79                 Logger::info('Updated servers', ['count' => $count]);
80         }
81 }