friendica/src/Worker/UpdateGServer.php

97 lines
3.1 KiB
PHP
Raw Normal View History

2019-12-20 22:46:30 +01:00
<?php
/**
2023-01-01 15:36:24 +01:00
* @copyright Copyright (C) 2010-2023, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
2019-12-20 22:46:30 +01:00
*/
2019-12-20 22:46:30 +01:00
namespace Friendica\Worker;
use Friendica\Core\Logger;
use Friendica\Core\Worker;
2020-12-03 23:32:51 +01:00
use Friendica\Database\DBA;
2019-12-20 22:46:30 +01:00
use Friendica\Model\GServer;
use Friendica\Network\HTTPException\InternalServerErrorException;
use Friendica\Util\Network;
2019-12-20 22:46:30 +01:00
use Friendica\Util\Strings;
use GuzzleHttp\Psr7\Uri;
use Psr\Http\Message\UriInterface;
2019-12-20 22:46:30 +01:00
2019-12-21 19:11:51 +01:00
class UpdateGServer
2019-12-20 22:46:30 +01:00
{
2019-12-21 21:18:44 +01:00
/**
* Update the given server
*
* @param string $server_url Server URL
* @param boolean $only_nodeinfo Only use nodeinfo for server detection
* @return void
* @throws \Exception
2019-12-21 21:18:44 +01:00
*/
public static function execute(string $server_url, bool $only_nodeinfo)
2019-12-20 22:46:30 +01:00
{
if (empty($server_url)) {
return;
}
2020-12-03 16:47:50 +01:00
$filtered = filter_var($server_url, FILTER_SANITIZE_URL);
if (substr(Strings::normaliseLink($filtered), 0, 7) != 'http://') {
2022-12-31 17:20:18 +01:00
GServer::setFailureByUrl($server_url);
2019-12-20 22:46:30 +01:00
return;
}
// Silently dropping the worker task if the server domain is blocked
if (Network::isUrlBlocked($filtered)) {
GServer::setBlockedByUrl($filtered);
return;
}
2020-12-03 23:32:51 +01:00
if (($filtered != $server_url) && DBA::exists('gserver', ['nurl' => Strings::normaliseLink($server_url)])) {
2022-12-31 17:20:18 +01:00
GServer::setFailureByUrl($server_url);
2020-12-03 23:32:51 +01:00
return;
}
$cleaned = GServer::cleanURL($server_url);
if (($cleaned != $server_url) && DBA::exists('gserver', ['nurl' => Strings::normaliseLink($server_url)])) {
2022-12-31 17:20:18 +01:00
GServer::setFailureByUrl($server_url);
2020-12-03 23:32:51 +01:00
return;
}
$ret = GServer::check($filtered, '', true, $only_nodeinfo);
2020-12-03 16:47:50 +01:00
Logger::info('Updated gserver', ['url' => $filtered, 'result' => $ret]);
2019-12-20 22:46:30 +01:00
}
/**
* @param array|int $run_parameters Priority constant or array of options described in Worker::add
* @param string $serverUrl
* @param bool $onlyNodeInfo Only use NodeInfo for server detection
* @return int
* @throws InternalServerErrorException
*/
public static function add($run_parameters, string $serverUrl, bool $onlyNodeInfo = false): int
{
// Dropping the worker task if the server domain is blocked
if (Network::isUrlBlocked($serverUrl)) {
GServer::setBlockedByUrl($serverUrl);
return 0;
}
// We have to convert the Uri back to string because worker parameters are saved in JSON format which
// doesn't allow for structured objects.
return Worker::add($run_parameters, 'UpdateGServer', $serverUrl, $onlyNodeInfo);
}
2019-12-20 22:46:30 +01:00
}