3 * @copyright Copyright (C) 2010-2023, the Friendica project
5 * @license GNU AGPL version 3 or any later version
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.
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.
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/>.
22 namespace Friendica\Worker;
24 use Friendica\Core\Logger;
25 use Friendica\Core\Worker;
26 use Friendica\Database\DBA;
27 use Friendica\Model\GServer;
28 use Friendica\Network\HTTPException\InternalServerErrorException;
29 use Friendica\Util\Network;
30 use Friendica\Util\Strings;
31 use GuzzleHttp\Psr7\Uri;
32 use Psr\Http\Message\UriInterface;
37 * Update the given server
39 * @param string $server_url Server URL
40 * @param boolean $only_nodeinfo Only use nodeinfo for server detection
44 public static function execute(string $server_url, bool $only_nodeinfo)
46 if (empty($server_url)) {
50 $filtered = filter_var($server_url, FILTER_SANITIZE_URL);
51 if (substr(Strings::normaliseLink($filtered), 0, 7) != 'http://') {
52 GServer::setFailureByUrl($server_url);
56 // Silently dropping the worker task if the server domain is blocked
57 if (Network::isUrlBlocked($filtered)) {
61 if (($filtered != $server_url) && DBA::exists('gserver', ['nurl' => Strings::normaliseLink($server_url)])) {
62 GServer::setFailureByUrl($server_url);
66 $cleaned = GServer::cleanURL($server_url);
67 if (($cleaned != $server_url) && DBA::exists('gserver', ['nurl' => Strings::normaliseLink($server_url)])) {
68 GServer::setFailureByUrl($server_url);
72 $ret = GServer::check($filtered, '', true, $only_nodeinfo);
73 Logger::info('Updated gserver', ['url' => $filtered, 'result' => $ret]);
77 * @param array|int $run_parameters Priority constant or array of options described in Worker::add
78 * @param string $serverUrl
79 * @param bool $onlyNodeInfo Only use NodeInfo for server detection
81 * @throws InternalServerErrorException
83 public static function add($run_parameters, string $serverUrl, bool $onlyNodeInfo = false): int
85 // Dropping the worker task if the server domain is blocked
86 if (Network::isUrlBlocked($serverUrl)) {
90 // We have to convert the Uri back to string because worker parameters are saved in JSON format which
91 // doesn't allow for structured objects.
92 return Worker::add($run_parameters, 'UpdateGServer', $serverUrl, $onlyNodeInfo);