Drop UpdateGServer worker task if domain is blocked
This commit is contained in:
@@ -22,9 +22,14 @@
|
||||
namespace Friendica\Worker;
|
||||
|
||||
use Friendica\Core\Logger;
|
||||
use Friendica\Core\Worker;
|
||||
use Friendica\Database\DBA;
|
||||
use Friendica\Model\GServer;
|
||||
use Friendica\Network\HTTPException\InternalServerErrorException;
|
||||
use Friendica\Util\Network;
|
||||
use Friendica\Util\Strings;
|
||||
use GuzzleHttp\Psr7\Uri;
|
||||
use Psr\Http\Message\UriInterface;
|
||||
|
||||
class UpdateGServer
|
||||
{
|
||||
@@ -34,8 +39,9 @@ class UpdateGServer
|
||||
* @param string $server_url Server URL
|
||||
* @param boolean $only_nodeinfo Only use nodeinfo for server detection
|
||||
* @return void
|
||||
* @throws \Exception
|
||||
*/
|
||||
public static function execute(string $server_url, bool $only_nodeinfo = false)
|
||||
public static function execute(string $server_url, bool $only_nodeinfo)
|
||||
{
|
||||
if (empty($server_url)) {
|
||||
return;
|
||||
@@ -47,6 +53,11 @@ class UpdateGServer
|
||||
return;
|
||||
}
|
||||
|
||||
// Silently dropping the worker task if the server domain is blocked
|
||||
if (Network::isUrlBlocked($filtered)) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (($filtered != $server_url) && DBA::exists('gserver', ['nurl' => Strings::normaliseLink($server_url)])) {
|
||||
GServer::setFailureByUrl($server_url);
|
||||
return;
|
||||
@@ -61,4 +72,23 @@ class UpdateGServer
|
||||
$ret = GServer::check($filtered, '', true, $only_nodeinfo);
|
||||
Logger::info('Updated gserver', ['url' => $filtered, 'result' => $ret]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @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)) {
|
||||
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);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user