mirror of
https://github.com/friendica/friendica
synced 2025-01-25 12:12:32 +01:00
PoCo endpoint added
This commit is contained in:
parent
3eb24d1b5c
commit
59b464ade3
1 changed files with 37 additions and 8 deletions
|
@ -27,14 +27,13 @@ class GServer
|
||||||
* Detect server data (type, protocol, version number, ...)
|
* Detect server data (type, protocol, version number, ...)
|
||||||
* The detected data is then updated or inserted in the gserver table.
|
* The detected data is then updated or inserted in the gserver table.
|
||||||
*
|
*
|
||||||
* @param string $url Server url
|
* @param string $url Server url
|
||||||
*
|
*
|
||||||
* @return boolean 'true' if server could be detected
|
* @return boolean 'true' if server could be detected
|
||||||
*/
|
*/
|
||||||
public static function detect($url)
|
public static function detect($url)
|
||||||
{
|
{
|
||||||
/// @Todo:
|
/// @Todo:
|
||||||
// - poco endpoint
|
|
||||||
// - Pleroma version number
|
// - Pleroma version number
|
||||||
|
|
||||||
$serverdata = [];
|
$serverdata = [];
|
||||||
|
@ -97,6 +96,8 @@ class GServer
|
||||||
$serverdata = $nodeinfo;
|
$serverdata = $nodeinfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$serverdata = self::checkPoCo($url, $serverdata);
|
||||||
|
|
||||||
// We can't detect the network type. Possibly it is some system that we don't know yet
|
// We can't detect the network type. Possibly it is some system that we don't know yet
|
||||||
if (empty($serverdata['network'])) {
|
if (empty($serverdata['network'])) {
|
||||||
$serverdata['network'] = Protocol::PHANTOM;
|
$serverdata['network'] = Protocol::PHANTOM;
|
||||||
|
@ -105,14 +106,19 @@ class GServer
|
||||||
$serverdata['url'] = $url;
|
$serverdata['url'] = $url;
|
||||||
$serverdata['nurl'] = Strings::normaliseLink($url);
|
$serverdata['nurl'] = Strings::normaliseLink($url);
|
||||||
|
|
||||||
// When we don't have the registered users, we simply count what we know
|
// We take the highest number that we do find
|
||||||
if (empty($serverdata['registered-users'])) {
|
$registeredUsers = $serverdata['registered-users'] ?? 0;
|
||||||
$gcontacts = DBA::count('gcontact', ['server_url' => [$url, $serverdata['nurl']]]);
|
|
||||||
$apcontacts = DBA::count('apcontact', ['baseurl' => [$url, $serverdata['nurl']]]);
|
// On an active server there has to be at least a single user
|
||||||
$contacts = DBA::count('contact', ['uid' => 0, 'baseurl' => [$url, $serverdata['nurl']]]);
|
if (($serverdata['network'] != Protocol::PHANTOM) && ($registeredUsers == 0)) {
|
||||||
$serverdata['registered-users'] = max($gcontacts, $apcontacts, $contacts);
|
$registeredUsers = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$gcontacts = DBA::count('gcontact', ['server_url' => [$url, $serverdata['nurl']]]);
|
||||||
|
$apcontacts = DBA::count('apcontact', ['baseurl' => [$url, $serverdata['nurl']]]);
|
||||||
|
$contacts = DBA::count('contact', ['uid' => 0, 'baseurl' => [$url, $serverdata['nurl']]]);
|
||||||
|
$serverdata['registered-users'] = max($gcontacts, $apcontacts, $contacts, $registeredUsers);
|
||||||
|
|
||||||
$serverdata['last_contact'] = DateTimeFormat::utcNow();
|
$serverdata['last_contact'] = DateTimeFormat::utcNow();
|
||||||
|
|
||||||
if (!DBA::exists('gserver', ['nurl' => Strings::normaliseLink($url)])) {
|
if (!DBA::exists('gserver', ['nurl' => Strings::normaliseLink($url)])) {
|
||||||
|
@ -437,6 +443,29 @@ class GServer
|
||||||
return $serverdata;
|
return $serverdata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static function checkPoCo($url, $serverdata)
|
||||||
|
{
|
||||||
|
$curlResult = Network::curl($url. '/poco');
|
||||||
|
if (!$curlResult->isSuccess()) {
|
||||||
|
return $serverdata;
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
if (empty($data)) {
|
||||||
|
return $serverdata;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($data['totalResults'])) {
|
||||||
|
$registeredUsers = $serverdata['registered-users'] ?? 0;
|
||||||
|
$serverdata['registered-users'] = max($data['totalResults'], $registeredUsers);
|
||||||
|
$serverdata['poco'] = $url . '/poco';
|
||||||
|
} else {
|
||||||
|
$serverdata['poco'] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $serverdata;
|
||||||
|
}
|
||||||
|
|
||||||
private static function detectNextcloud($url, $serverdata)
|
private static function detectNextcloud($url, $serverdata)
|
||||||
{
|
{
|
||||||
$curlResult = Network::curl($url . '/status.php');
|
$curlResult = Network::curl($url . '/status.php');
|
||||||
|
|
Loading…
Reference in a new issue