Nost test code is removed
This commit is contained in:
parent
ae55029028
commit
3eb24d1b5c
1 changed files with 31 additions and 88 deletions
|
@ -18,34 +18,25 @@ use Friendica\Util\Strings;
|
||||||
use Friendica\Util\XML;
|
use Friendica\Util\XML;
|
||||||
use Friendica\Core\Logger;
|
use Friendica\Core\Logger;
|
||||||
|
|
||||||
/*
|
|
||||||
use Exception;
|
|
||||||
use Friendica\Core\System;
|
|
||||||
use Friendica\Core\Worker;
|
|
||||||
use Friendica\Network\Probe;
|
|
||||||
use Friendica\Protocol\PortableContact;
|
|
||||||
*/
|
|
||||||
/**
|
/**
|
||||||
* @brief This class handles GServer related functions
|
* @brief This class handles GServer related functions
|
||||||
*/
|
*/
|
||||||
class GServer
|
class GServer
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Detect server type
|
* Detect server data (type, protocol, version number, ...)
|
||||||
|
* The detected data is then updated or inserted in the gserver table.
|
||||||
*
|
*
|
||||||
* @param string $url Server url
|
* @param string $url Server url
|
||||||
* @param boolean $force Force update
|
|
||||||
*
|
*
|
||||||
* @return boolean 'true' if server could be detected
|
* @return boolean 'true' if server could be detected
|
||||||
*/
|
*/
|
||||||
public static function detect($url, $force = false)
|
public static function detect($url)
|
||||||
{
|
{
|
||||||
/// @Todo:
|
/// @Todo:
|
||||||
// - Update Check
|
|
||||||
// - poco endpoint
|
// - poco endpoint
|
||||||
// - Pleroma version number
|
// - Pleroma version number
|
||||||
|
|
||||||
// $gserver = DBA::selectFirst('gserver', [], ['nurl' => Strings::normaliseLink($url)]);
|
|
||||||
$serverdata = [];
|
$serverdata = [];
|
||||||
|
|
||||||
// When a nodeinfo is present, we don't need to dig further
|
// When a nodeinfo is present, we don't need to dig further
|
||||||
|
@ -58,10 +49,12 @@ class GServer
|
||||||
|
|
||||||
$nodeinfo = self::fetchNodeinfo($url, $curlResult);
|
$nodeinfo = self::fetchNodeinfo($url, $curlResult);
|
||||||
|
|
||||||
|
// When nodeinfo isn't present, we use the older 'statistics.json' endpoint
|
||||||
if (empty($nodeinfo)) {
|
if (empty($nodeinfo)) {
|
||||||
$nodeinfo = self::fetchStatistics($url);
|
$nodeinfo = self::fetchStatistics($url);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If that didn't work out well, we use some protocol specific endpoints
|
||||||
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]);
|
||||||
|
@ -88,6 +81,7 @@ class GServer
|
||||||
$serverdata = self::fetchSiteinfo($url, $serverdata);
|
$serverdata = self::fetchSiteinfo($url, $serverdata);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// The 'siteinfo.json' doesn't seem to be present on older Hubzilla installations
|
||||||
if (empty($serverdata['network'])) {
|
if (empty($serverdata['network'])) {
|
||||||
$serverdata = self::detectHubzilla($url, $serverdata);
|
$serverdata = self::detectHubzilla($url, $serverdata);
|
||||||
}
|
}
|
||||||
|
@ -119,18 +113,18 @@ class GServer
|
||||||
$serverdata['registered-users'] = max($gcontacts, $apcontacts, $contacts);
|
$serverdata['registered-users'] = max($gcontacts, $apcontacts, $contacts);
|
||||||
}
|
}
|
||||||
|
|
||||||
$fields = array_keys($serverdata);
|
$serverdata['last_contact'] = DateTimeFormat::utcNow();
|
||||||
$old_data = DBA::selectFirst('gserver', $fields, ['nurl' => Strings::normaliseLink($url)]);
|
|
||||||
if (!DBA::isResult($old_data)) {
|
if (!DBA::exists('gserver', ['nurl' => Strings::normaliseLink($url)])) {
|
||||||
die('Möööp');
|
|
||||||
$serverdata['created'] = DateTimeFormat::utcNow();
|
$serverdata['created'] = DateTimeFormat::utcNow();
|
||||||
DBA::insert('gserver', $serverdata);
|
$ret = DBA::insert('gserver', $serverdata);
|
||||||
} else {
|
} else {
|
||||||
$serverdata['last_contact'] = DateTimeFormat::utcNow();
|
$ret = DBA::update('gserver', $serverdata, ['nurl' => $serverdata['nurl']]);
|
||||||
DBA::update('gserver', $serverdata, ['nurl' => $serverdata['nurl']], $old_data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $serverdata;
|
print_r($serverdata);
|
||||||
|
|
||||||
|
return $ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function fetchStatistics($url)
|
private static function fetchStatistics($url)
|
||||||
|
@ -165,11 +159,10 @@ die('Möööp');
|
||||||
$serverdata['network'] = Protocol::DIASPORA;
|
$serverdata['network'] = Protocol::DIASPORA;
|
||||||
} elseif ($serverdata['platform'] == 'Friendica') {
|
} elseif ($serverdata['platform'] == 'Friendica') {
|
||||||
$serverdata['network'] = Protocol::DFRN;
|
$serverdata['network'] = Protocol::DFRN;
|
||||||
|
} elseif ($serverdata['platform'] == 'hubzilla') {
|
||||||
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
} elseif ($serverdata['platform'] == 'redmatrix') {
|
} elseif ($serverdata['platform'] == 'redmatrix') {
|
||||||
$serverdata['network'] = Protocol::ZOT;
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
} else {
|
|
||||||
print_r($serverdata);
|
|
||||||
die('aaa');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -194,7 +187,7 @@ die('Möööp');
|
||||||
{
|
{
|
||||||
$nodeinfo = json_decode($curlResult->getBody(), true);
|
$nodeinfo = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (!is_array($nodeinfo) || !isset($nodeinfo['links'])) {
|
if (!is_array($nodeinfo) || empty($nodeinfo['links'])) {
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -262,11 +255,11 @@ die('Möööp');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_array($nodeinfo['software'])) {
|
if (is_array($nodeinfo['software'])) {
|
||||||
if (isset($nodeinfo['software']['name'])) {
|
if (!empty($nodeinfo['software']['name'])) {
|
||||||
$server['platform'] = $nodeinfo['software']['name'];
|
$server['platform'] = $nodeinfo['software']['name'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($nodeinfo['software']['version'])) {
|
if (!empty($nodeinfo['software']['version'])) {
|
||||||
$server['version'] = $nodeinfo['software']['version'];
|
$server['version'] = $nodeinfo['software']['version'];
|
||||||
// Version numbers on Nodeinfo are presented with additional info, e.g.:
|
// Version numbers on Nodeinfo are presented with additional info, e.g.:
|
||||||
// 0.6.3.0-p1702cc1c, 0.6.99.0-p1b9ab160 or 3.4.3-2-1191.
|
// 0.6.3.0-p1702cc1c, 0.6.99.0-p1b9ab160 or 3.4.3-2-1191.
|
||||||
|
@ -274,7 +267,7 @@ die('Möööp');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($nodeinfo['metadata']['nodeName'])) {
|
if (!empty($nodeinfo['metadata']['nodeName'])) {
|
||||||
$server['site_name'] = $nodeinfo['metadata']['nodeName'];
|
$server['site_name'] = $nodeinfo['metadata']['nodeName'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -300,9 +293,6 @@ die('Möööp');
|
||||||
$server['network'] = Protocol::OSTATUS;
|
$server['network'] = Protocol::OSTATUS;
|
||||||
} elseif (!empty($protocols['zot'])) {
|
} elseif (!empty($protocols['zot'])) {
|
||||||
$server['network'] = Protocol::ZOT;
|
$server['network'] = Protocol::ZOT;
|
||||||
} else {
|
|
||||||
print_r($protocols);
|
|
||||||
die('Protocol 1');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -342,11 +332,11 @@ die('Möööp');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_array($nodeinfo['software'])) {
|
if (is_array($nodeinfo['software'])) {
|
||||||
if (isset($nodeinfo['software']['name'])) {
|
if (!empty($nodeinfo['software']['name'])) {
|
||||||
$server['platform'] = $nodeinfo['software']['name'];
|
$server['platform'] = $nodeinfo['software']['name'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($nodeinfo['software']['version'])) {
|
if (!empty($nodeinfo['software']['version'])) {
|
||||||
$server['version'] = $nodeinfo['software']['version'];
|
$server['version'] = $nodeinfo['software']['version'];
|
||||||
// Version numbers on Nodeinfo are presented with additional info, e.g.:
|
// Version numbers on Nodeinfo are presented with additional info, e.g.:
|
||||||
// 0.6.3.0-p1702cc1c, 0.6.99.0-p1b9ab160 or 3.4.3-2-1191.
|
// 0.6.3.0-p1702cc1c, 0.6.99.0-p1b9ab160 or 3.4.3-2-1191.
|
||||||
|
@ -354,7 +344,7 @@ die('Möööp');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($nodeinfo['metadata']['nodeName'])) {
|
if (!empty($nodeinfo['metadata']['nodeName'])) {
|
||||||
$server['site_name'] = $nodeinfo['metadata']['nodeName'];
|
$server['site_name'] = $nodeinfo['metadata']['nodeName'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -380,9 +370,6 @@ die('Möööp');
|
||||||
$server['network'] = Protocol::OSTATUS;
|
$server['network'] = Protocol::OSTATUS;
|
||||||
} elseif (!empty($protocols['zot'])) {
|
} elseif (!empty($protocols['zot'])) {
|
||||||
$server['network'] = Protocol::ZOT;
|
$server['network'] = Protocol::ZOT;
|
||||||
} else {
|
|
||||||
print_r($protocols);
|
|
||||||
die('Protocol 2');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -405,7 +392,7 @@ die('Möööp');
|
||||||
return $serverdata;
|
return $serverdata;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($data['url'])) {
|
if (!empty($data['url'])) {
|
||||||
$serverdata['platform'] = $data['platform'];
|
$serverdata['platform'] = $data['platform'];
|
||||||
$serverdata['version'] = $data['version'];
|
$serverdata['version'] = $data['version'];
|
||||||
}
|
}
|
||||||
|
@ -508,13 +495,6 @@ die('Möööp');
|
||||||
$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 (!empty($serverdata['version']) && strstr($serverdata['version'], 'Pixelfed')) {
|
|
||||||
print_r($serverdata);
|
|
||||||
die();
|
|
||||||
// $serverdata['platform'] = 'pixelfed';
|
|
||||||
// $serverdata['version'] = trim(str_replace('Pixelfed', '', $serverdata['version'])); // 2.7.2 (compatible; Pixelfed 0.10.5)
|
|
||||||
}
|
|
||||||
|
|
||||||
return $serverdata;
|
return $serverdata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -535,33 +515,21 @@ die('Möööp');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($data['site']['platform'])) {
|
if (!empty($data['site']['platform'])) {
|
||||||
print_r($data);
|
|
||||||
die('1');
|
|
||||||
$serverdata['platform'] = $data['site']['platform']['PLATFORM_NAME'];
|
$serverdata['platform'] = $data['site']['platform']['PLATFORM_NAME'];
|
||||||
$serverdata['version'] = $data['site']['platform']['STD_VERSION'];
|
$serverdata['version'] = $data['site']['platform']['STD_VERSION'];
|
||||||
$serverdata['network'] = Protocol::ZOT;
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($data['site']['BlaBlaNet'])) {
|
if (!empty($data['site']['hubzilla'])) {
|
||||||
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['platform'] = $data['site']['hubzilla']['PLATFORM_NAME'];
|
||||||
$serverdata['version'] = $data['site']['hubzilla']['RED_VERSION'];
|
$serverdata['version'] = $data['site']['hubzilla']['RED_VERSION'];
|
||||||
$serverdata['network'] = Protocol::ZOT;
|
$serverdata['network'] = Protocol::ZOT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($data['site']['redmatrix'])) {
|
if (!empty($data['site']['redmatrix'])) {
|
||||||
if (isset($data['site']['redmatrix']['PLATFORM_NAME'])) {
|
if (!empty($data['site']['redmatrix']['PLATFORM_NAME'])) {
|
||||||
$serverdata['platform'] = $data['site']['redmatrix']['PLATFORM_NAME'];
|
$serverdata['platform'] = $data['site']['redmatrix']['PLATFORM_NAME'];
|
||||||
} elseif (isset($data['site']['redmatrix']['RED_PLATFORM'])) {
|
} elseif (!empty($data['site']['redmatrix']['RED_PLATFORM'])) {
|
||||||
$serverdata['platform'] = $data['site']['redmatrix']['RED_PLATFORM'];
|
$serverdata['platform'] = $data['site']['redmatrix']['RED_PLATFORM'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -569,15 +537,6 @@ die('3');
|
||||||
$serverdata['network'] = Protocol::ZOT;
|
$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;
|
$private = false;
|
||||||
$inviteonly = false;
|
$inviteonly = false;
|
||||||
$closed = false;
|
$closed = false;
|
||||||
|
@ -740,23 +699,13 @@ die('5');
|
||||||
$serverdata['network'] = Protocol::ACTIVITYPUB;
|
$serverdata['network'] = Protocol::ACTIVITYPUB;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//
|
|
||||||
if (($attr['name'] == 'generator') && in_array($attr['content'], ['Write.as'])) {
|
if ($attr['name'] == 'generator') {
|
||||||
die('as');
|
|
||||||
// $serverdata['platform'] = $attr['content'];
|
|
||||||
// $serverdata['network'] = Protocol::ACTIVITYPUB;
|
|
||||||
} elseif ($attr['name'] == 'generator') {
|
|
||||||
$serverdata['platform'] = $attr['content'];
|
$serverdata['platform'] = $attr['content'];
|
||||||
|
|
||||||
$version_part = explode(' ', $attr['content']);
|
$version_part = explode(' ', $attr['content']);
|
||||||
|
|
||||||
if (count($version_part) == 3) {
|
if (count($version_part) == 2) {
|
||||||
if (($version_part[0] == 'Red') && ($version_part[1] == 'Matrix')) {
|
|
||||||
// $serverdata['platform'] = $version_part[0] . ' ' . $version_part[1];
|
|
||||||
// $serverdata['version'] = $version_part[2];
|
|
||||||
// $serverdata['network'] = Protocol::DIASPORA;
|
|
||||||
}
|
|
||||||
} elseif (count($version_part) == 2) {
|
|
||||||
if (in_array($version_part[0], ['WordPress'])) {
|
if (in_array($version_part[0], ['WordPress'])) {
|
||||||
$serverdata['platform'] = $version_part[0];
|
$serverdata['platform'] = $version_part[0];
|
||||||
$serverdata['version'] = $version_part[1];
|
$serverdata['version'] = $version_part[1];
|
||||||
|
@ -799,12 +748,6 @@ die('as');
|
||||||
$serverdata['info'] = $attr['content'];
|
$serverdata['info'] = $attr['content'];
|
||||||
}
|
}
|
||||||
|
|
||||||
// if (($attr['property'] == 'og:title') && in_array($attr['content'], ['pixelfed', 'Socialhome'])) {
|
|
||||||
// if (($attr['property'] == 'og:title') && in_array($attr['content'], ['Nextcloud'])) {
|
|
||||||
// $serverdata['platform'] = $attr['content'];
|
|
||||||
// $serverdata['network'] = Protocol::ACTIVITYPUB;
|
|
||||||
// }
|
|
||||||
|
|
||||||
if ($attr['property'] == 'og:platform') {
|
if ($attr['property'] == 'og:platform') {
|
||||||
$serverdata['platform'] = $attr['content'];
|
$serverdata['platform'] = $attr['content'];
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue