friendica/src/Worker/DiscoverPoCo.php

69 lines
1.8 KiB
PHP
Raw Normal View History

2017-11-18 12:02:46 +01:00
<?php
/**
* @file src/Worker/DiscoverPoCo.php
*/
namespace Friendica\Worker;
use Friendica\Core\Config;
2018-10-29 22:20:46 +01:00
use Friendica\Core\Logger;
use Friendica\Core\Protocol;
2017-11-18 12:02:46 +01:00
use Friendica\Core\Worker;
use Friendica\Database\DBA;
use Friendica\Model\GContact;
use Friendica\Model\Contact;
use Friendica\Model\GServer;
2017-11-18 12:02:46 +01:00
use Friendica\Protocol\PortableContact;
use Friendica\Util\Strings;
2017-11-18 12:02:46 +01:00
class DiscoverPoCo
{
2017-11-18 12:02:46 +01:00
/// @todo Clean up this mess of a parameter hell and split it in several classes
2017-11-19 01:14:20 +01:00
public static function execute($command = '', $param1 = '', $param2 = '', $param3 = '', $param4 = '')
2017-11-18 12:02:46 +01:00
{
/*
This function can be called in these ways:
- server <poco url>: Searches for the poco server list. "poco url" is base64 encoded.
*/
$search = "";
$mode = 0;
2019-12-20 22:04:38 +01:00
if ($command == "server") {
2017-11-18 12:02:46 +01:00
$server_url = $param1;
if ($server_url == "") {
return;
}
$server_url = filter_var($server_url, FILTER_SANITIZE_URL);
if (substr(Strings::normaliseLink($server_url), 0, 7) != "http://") {
2017-11-18 12:02:46 +01:00
return;
}
$result = "Checking server ".$server_url." - ";
$ret = GServer::check($server_url);
2017-11-18 12:02:46 +01:00
if ($ret) {
$result .= "success";
} else {
$result .= "failed";
}
Logger::log($result, Logger::DEBUG);
} elseif ($command !== "") {
Logger::log("Unknown or missing parameter ".$command."\n");
return;
}
Logger::log('start '.$search);
if (($mode == 0) && ($search == "") && (Config::get('system', 'poco_discovery') != PortableContact::DISABLED)) {
2017-11-18 12:02:46 +01:00
// Query Friendica and Hubzilla servers for their users
PortableContact::discover();
// Query GNU Social servers for their users ("statistics" addon has to be enabled on the GS server)
if (!Config::get('system', 'ostatus_disabled')) {
GContact::discoverGsUsers();
2017-11-18 12:02:46 +01:00
}
}
2018-10-29 22:20:46 +01:00
Logger::log('end '.$search);
2017-11-18 12:02:46 +01:00
return;
}
}