Merge pull request #12908 from annando/server-detection

Takahē and Wildebeest added, Nomad detection improved
This commit is contained in:
Hypolite Petovan 2023-03-18 08:04:03 -04:00 committed by GitHub
commit aae9ba18d2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 25 additions and 3 deletions

View file

@ -1503,6 +1503,10 @@ class GServer
$generator = explode(' ', JsonLD::fetchElement($actor['as:generator'], 'as:name', '@value')); $generator = explode(' ', JsonLD::fetchElement($actor['as:generator'], 'as:name', '@value'));
$serverdata['platform'] = strtolower(array_shift($generator)); $serverdata['platform'] = strtolower(array_shift($generator));
$serverdata['detection-method'] = self::DETECT_SYSTEM_ACTOR; $serverdata['detection-method'] = self::DETECT_SYSTEM_ACTOR;
if (self::isNomad($actor['@id'])) {
$serverdata['version'] = $serverdata['platform'];
$serverdata['platform'] = 'nomad';
}
} else { } else {
$serverdata['detection-method'] = self::DETECT_AP_ACTOR; $serverdata['detection-method'] = self::DETECT_AP_ACTOR;
} }
@ -1525,6 +1529,22 @@ class GServer
return ['server' => $serverdata, 'actor' => '']; return ['server' => $serverdata, 'actor' => ''];
} }
/**
* Detect if the given url belongs to a nomad account
*
* @param string $url
* @return boolean
*/
private static function isNomad(string $url): bool
{
foreach (Probe::lrdd($url) as $attribute) {
if ((($attribute['@attributes']['rel'] ?? '') == 'http://purl.org/nomad') && (($attribute['@attributes']['type'] ?? '') == 'application/x-nomad+json')) {
return true;
}
}
return false;
}
/** /**
* Checks if the server contains a valid host meta file * Checks if the server contains a valid host meta file
* *

View file

@ -59,7 +59,7 @@ class Federation extends BaseAdmin
'misskey' => ['name' => 'Misskey', 'color' => '#ccfefd'], // Font color of the homepage 'misskey' => ['name' => 'Misskey', 'color' => '#ccfefd'], // Font color of the homepage
'mobilizon' => ['name' => 'Mobilizon', 'color' => '#ffd599'], // Background color of parts of the homepage 'mobilizon' => ['name' => 'Mobilizon', 'color' => '#ffd599'], // Background color of parts of the homepage
'nextcloud' => ['name' => 'Nextcloud', 'color' => '#1cafff'], // Logo color 'nextcloud' => ['name' => 'Nextcloud', 'color' => '#1cafff'], // Logo color
'mistpark' => ['name' => 'Nomad projects (Mistpark, Osada, Roadhouse, Zap)', 'color' => '#348a4a'], // Green like the Mistpark green 'nomad' => ['name' => 'Nomad projects (Mistpark, Osada, Roadhouse, Streams. Zap)', 'color' => '#348a4a'], // Green like the Mistpark green
'owncast' => ['name' => 'Owncast', 'color' => '#007bff'], // Font color of the homepage 'owncast' => ['name' => 'Owncast', 'color' => '#007bff'], // Font color of the homepage
'peertube' => ['name' => 'Peertube', 'color' => '#ffad5c'], // One of the logo colors 'peertube' => ['name' => 'Peertube', 'color' => '#ffad5c'], // One of the logo colors
'pixelfed' => ['name' => 'Pixelfed', 'color' => '#11da47'], // One of the logo colors 'pixelfed' => ['name' => 'Pixelfed', 'color' => '#11da47'], // One of the logo colors
@ -67,6 +67,8 @@ class Federation extends BaseAdmin
'plume' => ['name' => 'Plume', 'color' => '#7765e3'], // From the homepage 'plume' => ['name' => 'Plume', 'color' => '#7765e3'], // From the homepage
'relay' => ['name' => 'ActivityPub Relay', 'color' => '#888888'], // Grey like the second color of the ActivityPub logo 'relay' => ['name' => 'ActivityPub Relay', 'color' => '#888888'], // Grey like the second color of the ActivityPub logo
'socialhome' => ['name' => 'SocialHome', 'color' => '#52056b'], // lilac from the Django Image used at the Socialhome homepage 'socialhome' => ['name' => 'SocialHome', 'color' => '#52056b'], // lilac from the Django Image used at the Socialhome homepage
'takahe' => ['name' => 'Takahē', 'color' => '#26323c'], // Background color of the homepage
'wildebeest' => ['name' => 'Wildebeest', 'color' => '#0055dc'], // Color of the mascot
'wordpress' => ['name' => 'WordPress', 'color' => '#016087'], // Background color of the homepage 'wordpress' => ['name' => 'WordPress', 'color' => '#016087'], // Background color of the homepage
'write.as' => ['name' => 'Write.as', 'color' => '#00ace3'], // Border color of the homepage 'write.as' => ['name' => 'Write.as', 'color' => '#00ace3'], // Border color of the homepage
'writefreely' => ['name' => 'WriteFreely', 'color' => '#292929'], // Font color of the homepage 'writefreely' => ['name' => 'WriteFreely', 'color' => '#292929'], // Font color of the homepage
@ -125,8 +127,8 @@ class Federation extends BaseAdmin
$platform = 'friendica'; $platform = 'friendica';
} elseif (in_array($platform, ['red matrix', 'redmatrix', 'red'])) { } elseif (in_array($platform, ['red matrix', 'redmatrix', 'red'])) {
$platform = 'hubzilla'; $platform = 'hubzilla';
} elseif (in_array($platform, ['osada', 'mistpark', 'roadhouse', 'zap', 'macgirvin', 'mkultra'])) { } elseif (in_array($platform, ['nomad', 'osada', 'mistpark', 'roadhouse', 'zap', 'macgirvin', 'mkultra'])) {
$platform = 'mistpark'; $platform = 'nomad';
} elseif(stristr($platform, 'pleroma')) { } elseif(stristr($platform, 'pleroma')) {
$platform = 'pleroma'; $platform = 'pleroma';
} elseif(stristr($platform, 'statusnet')) { } elseif(stristr($platform, 'statusnet')) {