use Friendica\Util\Strings;
use Friendica\Util\XML;
use Friendica\Network\HTTPException;
+use Friendica\Worker\UpdateGServer;
use GuzzleHttp\Psr7\Uri;
use Psr\Http\Message\UriInterface;
*/
public static function add(string $url, bool $only_nodeinfo = false)
{
- if (self::getID($url, false)) {
+ if (self::getID($url)) {
return;
}
- Worker::add(Worker::PRIORITY_LOW, 'UpdateGServer', $url, $only_nodeinfo);
+ UpdateGServer::add(Worker::PRIORITY_LOW, $url, $only_nodeinfo);
}
/**
return false;
} else {
if (strtotime($gserver['next_contact']) < time()) {
- Worker::add(Worker::PRIORITY_LOW, 'UpdateGServer', $gserver['url'], false);
+ UpdateGServer::add(Worker::PRIORITY_LOW, $gserver['url']);
}
+
return self::isDefunct($gserver);
}
}
return true;
} else {
if (strtotime($gserver['next_contact']) < time()) {
- Worker::add(Worker::PRIORITY_LOW, 'UpdateGServer', $gserver['url'], false);
+ UpdateGServer::add(Worker::PRIORITY_LOW, $gserver['url']);
}
+
return !$gserver['failed'] && in_array($gserver['network'], Protocol::FEDERATED);
}
}
}
if (!empty($server) && (empty($gserver) || strtotime($gserver['next_contact']) < time())) {
- Worker::add(Worker::PRIORITY_LOW, 'UpdateGServer', $server, false);
+ UpdateGServer::add(Worker::PRIORITY_LOW, $server);
}
return $reachable;
Logger::info('Reset failed status for server', ['url' => $gserver['url']]);
if (strtotime($gserver['next_contact']) < time()) {
- Worker::add(Worker::PRIORITY_LOW, 'UpdateGServer', $gserver['url'], false);
+ UpdateGServer::add(Worker::PRIORITY_LOW, $gserver['url']);
}
}
}
Logger::info('Set failed status for server', ['url' => $gserver['url']]);
if (strtotime($gserver['next_contact']) < time()) {
- Worker::add(Worker::PRIORITY_LOW, 'UpdateGServer', $gserver['url'], false);
+ UpdateGServer::add(Worker::PRIORITY_LOW, $gserver['url']);
}
}
}
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
{
* @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;
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;
$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);
+ }
}
use Friendica\DI;
use Friendica\Util\DateTimeFormat;
use Friendica\Util\Strings;
+use GuzzleHttp\Psr7\Uri;
class UpdateGServers
{
// There are duplicated "url" but not "nurl". So we check both addresses instead of just overwriting them,
// since that would mean loosing data.
if (!empty($gserver['url'])) {
- if (Worker::add(Worker::PRIORITY_LOW, 'UpdateGServer', $gserver['url'])) {
+ if (UpdateGServer::add(Worker::PRIORITY_LOW, $gserver['url'])) {
$count++;
}
}
if (!empty($gserver['nurl']) && ($gserver['nurl'] != Strings::normaliseLink($gserver['url']))) {
- if (Worker::add(Worker::PRIORITY_LOW, 'UpdateGServer', $gserver['nurl'])) {
+ if (UpdateGServer::add(Worker::PRIORITY_LOW, $gserver['nurl'])) {
$count++;
}
}