Additional endpoints added
This commit is contained in:
parent
25f93cb03a
commit
ae55029028
|
@ -42,7 +42,7 @@ class GServer
|
||||||
{
|
{
|
||||||
/// @Todo:
|
/// @Todo:
|
||||||
// - Update Check
|
// - Update Check
|
||||||
// - poco
|
// - poco endpoint
|
||||||
// - Pleroma version number
|
// - Pleroma version number
|
||||||
|
|
||||||
// $gserver = DBA::selectFirst('gserver', [], ['nurl' => Strings::normaliseLink($url)]);
|
// $gserver = DBA::selectFirst('gserver', [], ['nurl' => Strings::normaliseLink($url)]);
|
||||||
|
@ -58,6 +58,10 @@ class GServer
|
||||||
|
|
||||||
$nodeinfo = self::fetchNodeinfo($url, $curlResult);
|
$nodeinfo = self::fetchNodeinfo($url, $curlResult);
|
||||||
|
|
||||||
|
if (empty($nodeinfo)) {
|
||||||
|
$nodeinfo = self::fetchStatistics($url);
|
||||||
|
}
|
||||||
|
|
||||||
if (empty($nodeinfo) || ($nodeinfo['network'] == Protocol::DFRN)) {
|
if (empty($nodeinfo) || ($nodeinfo['network'] == Protocol::DFRN)) {
|
||||||
// Fetch the landing page, possibly it reveals some data
|
// Fetch the landing page, possibly it reveals some data
|
||||||
$curlResult = Network::curl($url, false, ['timeout' => $xrd_timeout]);
|
$curlResult = Network::curl($url, false, ['timeout' => $xrd_timeout]);
|
||||||
|
@ -79,11 +83,15 @@ class GServer
|
||||||
$serverdata = self::detectMastodonAlikes($url, $serverdata);
|
$serverdata = self::detectMastodonAlikes($url, $serverdata);
|
||||||
}
|
}
|
||||||
|
|
||||||
// the "siteinfo.json" is some specific endpoint of Hubzilla and Red
|
// the 'siteinfo.json' is some specific endpoint of Hubzilla and Red
|
||||||
if (empty($serverdata['network']) || ($serverdata['network'] == Protocol::ZOT)) {
|
if (empty($serverdata['network']) || ($serverdata['network'] == Protocol::ZOT)) {
|
||||||
$serverdata = self::fetchSiteinfo($url, $serverdata);
|
$serverdata = self::fetchSiteinfo($url, $serverdata);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (empty($serverdata['network'])) {
|
||||||
|
$serverdata = self::detectHubzilla($url, $serverdata);
|
||||||
|
}
|
||||||
|
|
||||||
if (empty($serverdata['network'])) {
|
if (empty($serverdata['network'])) {
|
||||||
$serverdata = self::detectNextcloud($url, $serverdata);
|
$serverdata = self::detectNextcloud($url, $serverdata);
|
||||||
}
|
}
|
||||||
|
@ -125,6 +133,56 @@ die('Möööp');
|
||||||
return $serverdata;
|
return $serverdata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static function fetchStatistics($url)
|
||||||
|
{
|
||||||
|
$curlResult = Network::curl($url . '/statistics.json');
|
||||||
|
if (!$curlResult->isSuccess()) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
if (empty($data)) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
$serverdata = [];
|
||||||
|
|
||||||
|
if (!empty($data['version'])) {
|
||||||
|
$serverdata['version'] = $data['version'];
|
||||||
|
// Version numbers on statistics.json are presented with additional info, e.g.:
|
||||||
|
// 0.6.3.0-p1702cc1c, 0.6.99.0-p1b9ab160 or 3.4.3-2-1191.
|
||||||
|
$serverdata['version'] = preg_replace('=(.+)-(.{4,})=ism', '$1', $serverdata['version']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($data['name'])) {
|
||||||
|
$serverdata['site_name'] = $data['name'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($data['network'])) {
|
||||||
|
$serverdata['platform'] = $data['network'];
|
||||||
|
|
||||||
|
if ($serverdata['platform'] == 'Diaspora') {
|
||||||
|
$serverdata['network'] = Protocol::DIASPORA;
|
||||||
|
} elseif ($serverdata['platform'] == 'Friendica') {
|
||||||
|
$serverdata['network'] = Protocol::DFRN;
|
||||||
|
} elseif ($serverdata['platform'] == 'redmatrix') {
|
||||||
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
|
} else {
|
||||||
|
print_r($serverdata);
|
||||||
|
die('aaa');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (!empty($data['registrations_open'])) {
|
||||||
|
$serverdata['register_policy'] = Register::OPEN;
|
||||||
|
} else {
|
||||||
|
$serverdata['register_policy'] = Register::CLOSED;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $serverdata;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Detect server type by using the nodeinfo data
|
* @brief Detect server type by using the nodeinfo data
|
||||||
*
|
*
|
||||||
|
@ -240,6 +298,8 @@ die('Möööp');
|
||||||
$server['network'] = Protocol::OSTATUS;
|
$server['network'] = Protocol::OSTATUS;
|
||||||
} elseif (!empty($protocols['gnusocial'])) {
|
} elseif (!empty($protocols['gnusocial'])) {
|
||||||
$server['network'] = Protocol::OSTATUS;
|
$server['network'] = Protocol::OSTATUS;
|
||||||
|
} elseif (!empty($protocols['zot'])) {
|
||||||
|
$server['network'] = Protocol::ZOT;
|
||||||
} else {
|
} else {
|
||||||
print_r($protocols);
|
print_r($protocols);
|
||||||
die('Protocol 1');
|
die('Protocol 1');
|
||||||
|
@ -318,6 +378,8 @@ die('Möööp');
|
||||||
$server['network'] = Protocol::OSTATUS;
|
$server['network'] = Protocol::OSTATUS;
|
||||||
} elseif (!empty($protocols['gnusocial'])) {
|
} elseif (!empty($protocols['gnusocial'])) {
|
||||||
$server['network'] = Protocol::OSTATUS;
|
$server['network'] = Protocol::OSTATUS;
|
||||||
|
} elseif (!empty($protocols['zot'])) {
|
||||||
|
$server['network'] = Protocol::ZOT;
|
||||||
} else {
|
} else {
|
||||||
print_r($protocols);
|
print_r($protocols);
|
||||||
die('Protocol 2');
|
die('Protocol 2');
|
||||||
|
@ -370,15 +432,15 @@ die('Möööp');
|
||||||
|
|
||||||
if (!empty($data['register_policy'])) {
|
if (!empty($data['register_policy'])) {
|
||||||
switch ($data['register_policy']) {
|
switch ($data['register_policy']) {
|
||||||
case "REGISTER_OPEN":
|
case 'REGISTER_OPEN':
|
||||||
$serverdata['register_policy'] = Register::OPEN;
|
$serverdata['register_policy'] = Register::OPEN;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "REGISTER_APPROVE":
|
case 'REGISTER_APPROVE':
|
||||||
$serverdata['register_policy'] = Register::APPROVE;
|
$serverdata['register_policy'] = Register::APPROVE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "REGISTER_CLOSED":
|
case 'REGISTER_CLOSED':
|
||||||
default:
|
default:
|
||||||
$serverdata['register_policy'] = Register::CLOSED;
|
$serverdata['register_policy'] = Register::CLOSED;
|
||||||
break;
|
break;
|
||||||
|
@ -423,28 +485,30 @@ die('Möööp');
|
||||||
return $serverdata;
|
return $serverdata;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($data['version'])) {
|
if (!empty($data['version'])) {
|
||||||
$serverdata['platform'] = 'mastodon';
|
$serverdata['platform'] = 'mastodon';
|
||||||
$serverdata['version'] = defaults($data, 'version', '');
|
$serverdata['version'] = defaults($data, 'version', '');
|
||||||
|
$serverdata['network'] = Protocol::ACTIVITYPUB;
|
||||||
|
}
|
||||||
|
|
||||||
if (!empty($data['title'])) {
|
if (!empty($data['title'])) {
|
||||||
$serverdata['site_name'] = $data['title'];
|
$serverdata['site_name'] = $data['title'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($data['description'])) {
|
if (!empty($data['description'])) {
|
||||||
$serverdata['info'] = trim($data['description']);
|
$serverdata['info'] = trim($data['description']);
|
||||||
}
|
}
|
||||||
$serverdata['network'] = Protocol::ACTIVITYPUB;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($data['stats']['user_count'])) {
|
if (!empty($data['stats']['user_count'])) {
|
||||||
$serverdata['registered-users'] = $data['stats']['user_count'];
|
$serverdata['registered-users'] = $data['stats']['user_count'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strstr($serverdata['version'], 'Pleroma')) {
|
if (!empty($serverdata['version']) && strstr($serverdata['version'], 'Pleroma')) {
|
||||||
$serverdata['platform'] = 'pleroma';
|
$serverdata['platform'] = 'pleroma';
|
||||||
$serverdata['version'] = trim(str_replace('Pleroma', '', $serverdata['version'])); // 2.7.2 (compatible; Pleroma 1.0.0-1225-gf31ad554-develop)
|
$serverdata['version'] = trim(str_replace('Pleroma', '', $serverdata['version'])); // 2.7.2 (compatible; Pleroma 1.0.0-1225-gf31ad554-develop)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strstr($serverdata['version'], 'Pixelfed')) {
|
if (!empty($serverdata['version']) && strstr($serverdata['version'], 'Pixelfed')) {
|
||||||
print_r($serverdata);
|
print_r($serverdata);
|
||||||
die();
|
die();
|
||||||
// $serverdata['platform'] = 'pixelfed';
|
// $serverdata['platform'] = 'pixelfed';
|
||||||
|
@ -454,6 +518,104 @@ die('Möööp');
|
||||||
return $serverdata;
|
return $serverdata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static function detectHubzilla($url, $serverdata)
|
||||||
|
{
|
||||||
|
$curlResult = Network::curl($url . '/api/statusnet/config.json');
|
||||||
|
if (!$curlResult->isSuccess() || ($curlResult->getBody() == '')) {
|
||||||
|
return $serverdata;
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
if (empty($data)) {
|
||||||
|
return $serverdata;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($data['site']['name'])) {
|
||||||
|
$serverdata['site_name'] = $data['site']['name'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($data['site']['platform'])) {
|
||||||
|
print_r($data);
|
||||||
|
die('1');
|
||||||
|
$serverdata['platform'] = $data['site']['platform']['PLATFORM_NAME'];
|
||||||
|
$serverdata['version'] = $data['site']['platform']['STD_VERSION'];
|
||||||
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($data['site']['BlaBlaNet'])) {
|
||||||
|
print_r($data);
|
||||||
|
die('2');
|
||||||
|
$serverdata['platform'] = $data['site']['BlaBlaNet']['PLATFORM_NAME'];
|
||||||
|
$serverdata['version'] = $data['site']['BlaBlaNet']['STD_VERSION'];
|
||||||
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($data['site']['hubzilla'])) {
|
||||||
|
print_r($data);
|
||||||
|
die('3');
|
||||||
|
$serverdata['platform'] = $data['site']['hubzilla']['PLATFORM_NAME'];
|
||||||
|
$serverdata['version'] = $data['site']['hubzilla']['RED_VERSION'];
|
||||||
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($data['site']['redmatrix'])) {
|
||||||
|
if (isset($data['site']['redmatrix']['PLATFORM_NAME'])) {
|
||||||
|
$serverdata['platform'] = $data['site']['redmatrix']['PLATFORM_NAME'];
|
||||||
|
} elseif (isset($data['site']['redmatrix']['RED_PLATFORM'])) {
|
||||||
|
$serverdata['platform'] = $data['site']['redmatrix']['RED_PLATFORM'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$serverdata['version'] = $data['site']['redmatrix']['RED_VERSION'];
|
||||||
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($data['site']['friendica'])) {
|
||||||
|
print_r($data);
|
||||||
|
print_r($serverdata);
|
||||||
|
die('5');
|
||||||
|
$serverdata['platform'] = $data['site']['friendica']['FRIENDICA_PLATFORM'];
|
||||||
|
$serverdata['version'] = $data['site']['friendica']['FRIENDICA_VERSION'];
|
||||||
|
$serverdata['network'] = Protocol::DFRN;
|
||||||
|
}
|
||||||
|
|
||||||
|
$private = false;
|
||||||
|
$inviteonly = false;
|
||||||
|
$closed = false;
|
||||||
|
|
||||||
|
if (!empty($data['site']['closed'])) {
|
||||||
|
$closed = self::toBoolean($data['site']['closed']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($data['site']['private'])) {
|
||||||
|
$private = self::toBoolean($data['site']['private']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($data['site']['inviteonly'])) {
|
||||||
|
$inviteonly = self::toBoolean($data['site']['inviteonly']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$closed && !$private and $inviteonly) {
|
||||||
|
$register_policy = Register::APPROVE;
|
||||||
|
} elseif (!$closed && !$private) {
|
||||||
|
$register_policy = Register::OPEN;
|
||||||
|
} else {
|
||||||
|
$register_policy = Register::CLOSED;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $serverdata;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function toBoolean($val)
|
||||||
|
{
|
||||||
|
if (($val == 'true') || ($val == 1)) {
|
||||||
|
return true;
|
||||||
|
} elseif (($val == 'false') || ($val == 0)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $val;
|
||||||
|
}
|
||||||
|
|
||||||
private static function detectGNUSocial($url, $serverdata)
|
private static function detectGNUSocial($url, $serverdata)
|
||||||
{
|
{
|
||||||
$curlResult = Network::curl($url . '/api/statusnet/version.json');
|
$curlResult = Network::curl($url . '/api/statusnet/version.json');
|
||||||
|
|
Loading…
Reference in New Issue
Block a user