return $o;
}
+ /**
+ * @param string $profile Profile URL
+ * @return string Server URL
+ * @throws \Friendica\Network\HTTPException\InternalServerErrorException
+ */
+ private static function getServerURLForProfile($profile)
+ {
+ $server_url = '';
+
+ // Fetch the server url from the contact table
+ $contact = DBA::selectFirst('contact', ['baseurl'], ['uid' => 0, 'nurl' => Strings::normaliseLink($profile)]);
+ if (DBA::isResult($contact) && !empty($contact['baseurl'])) {
+ $server_url = Strings::normaliseLink($contact['baseurl']);
+ }
+
+ if (empty($server_url)) {
+ // Fetch the server url from the gcontact table
+ $gcontact = DBA::selectFirst('gcontact', ['server_url'], ['nurl' => Strings::normaliseLink($profile)]);
+ if (!empty($gcontact) && !empty($gcontact['server_url'])) {
+ $server_url = Strings::normaliseLink($gcontact['server_url']);
+ }
+ }
+
+ if (empty($server_url)) {
+ // Create the server url out of the profile url
+ $parts = parse_url($profile);
+ unset($parts['path']);
+ $server_url = Strings::normaliseLink(Network::unparseURL($parts));
+ }
+
+ return $server_url;
+ }
+
/**
* @param string $network network
* @param string $profile optional, default empty
$networkname = str_replace($search, $replace, $network);
if ((in_array($network, Protocol::FEDERATED)) && ($profile != "")) {
- // Create the server url out of the profile url
- $parts = parse_url($profile);
- unset($parts['path']);
- $server_url = [Strings::normaliseLink(Network::unparseURL($parts))];
-
- // Fetch the server url
- $gcontact = DBA::selectFirst('gcontact', ['server_url'], ['nurl' => Strings::normaliseLink($profile)]);
- if (!empty($gcontact) && !empty($gcontact['server_url'])) {
- $server_url[] = Strings::normaliseLink($gcontact['server_url']);
- }
+ $server_url = self::getServerURLForProfile($profile);
// Now query the GServer for the platform name
$gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['nurl' => $server_url]);
return $networkname;
}
+ /**
+ * @param string $network network
+ * @param string $profile optional, default empty
+ * @return string
+ * @throws \Friendica\Network\HTTPException\InternalServerErrorException
+ */
+ public static function networkToIcon($network, $profile = "")
+ {
+ $nets = [
+ Protocol::DFRN => 'friendica',
+ Protocol::OSTATUS => 'gnu-social', // There is no generic OStatus icon
+ Protocol::FEED => 'rss',
+ Protocol::MAIL => 'file-text-o', /// @todo
+ Protocol::DIASPORA => 'diaspora',
+ Protocol::ZOT => 'hubzilla',
+ Protocol::LINKEDIN => 'linkedin',
+ Protocol::XMPP => 'xmpp',
+ Protocol::MYSPACE => 'file-text-o', /// @todo
+ Protocol::GPLUS => 'google-plus',
+ Protocol::PUMPIO => 'file-text-o', /// @todo
+ Protocol::TWITTER => 'twitter',
+ Protocol::DIASPORA2 => 'diaspora',
+ Protocol::STATUSNET => 'gnu-social',
+ Protocol::ACTIVITYPUB => 'activitypub',
+ Protocol::PNUT => 'file-text-o', /// @todo
+ ];
+
+ $platform_icons = ['diaspora' => 'diaspora', 'friendica' => 'friendica', 'friendika' => 'friendica',
+ 'GNU Social' => 'gnu-social', 'gnusocial' => 'gnu-social', 'hubzilla' => 'hubzilla',
+ 'mastodon' => 'mastodon', 'peertube' => 'peertube', 'pixelfed' => 'pixelfed',
+ 'pleroma' => 'pleroma', 'red' => 'hubzilla', 'redmatrix' => 'hubzilla',
+ 'socialhome' => 'social-home', 'wordpress' => 'wordpress'];
+
+ $search = array_keys($nets);
+ $replace = array_values($nets);
+
+ $network_icon = str_replace($search, $replace, $network);
+
+ if ((in_array($network, Protocol::FEDERATED)) && ($profile != "")) {
+ $server_url = self::getServerURLForProfile($profile);
+
+ // Now query the GServer for the platform name
+ $gserver = DBA::selectFirst('gserver', ['platform'], ['nurl' => $server_url]);
+
+ if (DBA::isResult($gserver) && !empty($gserver['platform'])) {
+ $network_icon = $platform_icons[strtolower($gserver['platform'])] ?? $network_icon;
+ }
+ }
+
+ return $network_icon;
+ }
+
/**
* @param string $current optional, default empty
* @param string $suffix optionsl, default empty
/**
* @brief Helper function for "updateFromProbe". Updates personal and public contact
*
- * @param array $contact The personal contact entry
- * @param array $fields The fields that are updated
+ * @param integer $id contact id
+ * @param integer $uid user id
+ * @param string $url The profile URL of the contact
+ * @param array $fields The fields that are updated
+ *
* @throws \Exception
*/
private static function updateContact($id, $uid, $url, array $fields)
{
- DBA::update('contact', $fields, ['id' => $id]);
+ if (!DBA::update('contact', $fields, ['id' => $id])) {
+ Logger::info('Couldn\'t update contact.', ['id' => $id, 'fields' => $fields]);
+ return;
+ }
// Search for duplicated contacts and get rid of them
if (self::handleDuplicates(Strings::normaliseLink($url), $uid, $id) || ($uid != 0)) {
// Archive or unarchive the contact. We only need to do this for the public contact.
// The archive/unarchive function will update the personal contacts by themselves.
$contact = DBA::selectFirst('contact', [], ['id' => $id]);
+ if (!DBA::isResult($contact)) {
+ Logger::info('Couldn\'t select contact for archival.', ['id' => $id]);
+ return;
+ }
+
if (!empty($fields['success_update'])) {
self::unmarkForArchival($contact);
} elseif (!empty($fields['failure_update'])) {