X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FContent%2FContactSelector.php;h=64a2b5be9e4f4b92182a1f277a5408c88f27e6b2;hb=8e2910976f126ee7c728ba4716f317ac496f377b;hp=c3db2406e303589d67973502cbc623c83154cd7e;hpb=300b1b6af84e8ce4223b173dd36ac9963da4ca51;p=friendica.git diff --git a/src/Content/ContactSelector.php b/src/Content/ContactSelector.php index c3db2406e3..64a2b5be9e 100644 --- a/src/Content/ContactSelector.php +++ b/src/Content/ContactSelector.php @@ -4,116 +4,289 @@ */ namespace Friendica\Content; -use Friendica\Database\DBM; -use Friendica\Protocol\Diaspora; +use Friendica\Core\Hook; +use Friendica\Core\Protocol; +use Friendica\Database\DBA; +use Friendica\DI; +use Friendica\Util\Network; +use Friendica\Util\Strings; +/** + * ContactSelector class + */ class ContactSelector { - function contact_profile_assign($current,$foreign_net) { - - $o = ''; - - $disabled = (($foreign_net) ? ' disabled="true" ' : ''); - - $o .= "\r\n"; - return $o; - } - - function contact_reputation($current) { - - $o = ''; - $o .= "\r\n"; - return $o; - } - - function contact_poll_interval($current, $disabled = false) { - - $dis = (($disabled) ? ' disabled="disabled" ' : ''); - $o = ''; - $o .= "\r\n"; - return $o; - } - - function network_to_name($s, $profile = "") { - - $nets = array( - NETWORK_DFRN => t('Friendica'), - NETWORK_OSTATUS => t('OStatus'), - NETWORK_FEED => t('RSS/Atom'), - NETWORK_MAIL => t('Email'), - NETWORK_DIASPORA => t('Diaspora'), - NETWORK_FACEBOOK => t('Facebook'), - NETWORK_ZOT => t('Zot!'), - NETWORK_LINKEDIN => t('LinkedIn'), - NETWORK_XMPP => t('XMPP/IM'), - NETWORK_MYSPACE => t('MySpace'), - NETWORK_GPLUS => t('Google+'), - NETWORK_PUMPIO => t('pump.io'), - NETWORK_TWITTER => t('Twitter'), - NETWORK_DIASPORA2 => t('Diaspora Connector'), - NETWORK_STATUSNET => t('GNU Social Connector'), - NETWORK_PNUT => t('pnut'), - NETWORK_APPNET => t('App.net') - ); - - call_hooks('network_to_name', $nets); - - $search = array_keys($nets); - $replace = array_values($nets); - - $networkname = str_replace($search, $replace, $s); - - if ((in_array($s, array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS))) && ($profile != "")) { - $r = dba::fetch_first("SELECT `gserver`.`platform` FROM `gcontact` - INNER JOIN `gserver` ON `gserver`.`nurl` = `gcontact`.`server_url` - WHERE `gcontact`.`nurl` = ? AND `platform` != ''", normalise_link($profile)); - - if (DBM::is_result($r)) { - $networkname = $r['platform']; - } - } - - return $networkname; - } + /** + * @param string $current current + * @param boolean $disabled optional, default false + * @return object + */ + public static function pollInterval($current, $disabled = false) + { + $dis = (($disabled) ? ' disabled="disabled" ' : ''); + $o = ''; + $o .= "\r\n"; + 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 of the contact + * @param string $profile optional, default empty + * @param string $protocol (Optional) Protocol that is used for the transmission + * @return string + * @throws \Friendica\Network\HTTPException\InternalServerErrorException + */ + public static function networkToName($network, $profile = '', $protocol = '') + { + $nets = [ + Protocol::DFRN => DI::l10n()->t('DFRN'), + Protocol::OSTATUS => DI::l10n()->t('OStatus'), + Protocol::FEED => DI::l10n()->t('RSS/Atom'), + Protocol::MAIL => DI::l10n()->t('Email'), + Protocol::DIASPORA => DI::l10n()->t('Diaspora'), + Protocol::ZOT => DI::l10n()->t('Zot!'), + Protocol::LINKEDIN => DI::l10n()->t('LinkedIn'), + Protocol::XMPP => DI::l10n()->t('XMPP/IM'), + Protocol::MYSPACE => DI::l10n()->t('MySpace'), + Protocol::GPLUS => DI::l10n()->t('Google+'), + Protocol::PUMPIO => DI::l10n()->t('pump.io'), + Protocol::TWITTER => DI::l10n()->t('Twitter'), + Protocol::DISCOURSE => DI::l10n()->t('Discourse'), + Protocol::DIASPORA2 => DI::l10n()->t('Diaspora Connector'), + Protocol::STATUSNET => DI::l10n()->t('GNU Social Connector'), + Protocol::ACTIVITYPUB => DI::l10n()->t('ActivityPub'), + Protocol::PNUT => DI::l10n()->t('pnut'), + ]; + + Hook::callAll('network_to_name', $nets); + + $search = array_keys($nets); + $replace = array_values($nets); + + $networkname = 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', 'network'], ['nurl' => $server_url]); + + if (DBA::isResult($gserver)) { + if (!empty($gserver['platform'])) { + $platform = $gserver['platform']; + } elseif (!empty($gserver['network']) && ($gserver['network'] != Protocol::ACTIVITYPUB)) { + $platform = self::networkToName($gserver['network']); + } + + if (!empty($platform)) { + $networkname = $platform; + + if ($network == Protocol::ACTIVITYPUB) { + $networkname .= ' (AP)'; + } + } + } + } + + if (!empty($protocol) && ($protocol != $network)) { + $networkname = DI::l10n()->t('%s (via %s)', $networkname, self::networkToName($protocol)); + } + + 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 => 'inbox', + 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::DISCOURSE => 'dot-circle-o', /// @todo + 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 + * @return string + * @throws \Friendica\Network\HTTPException\InternalServerErrorException + */ + public static function sexualPreference($current = "", $suffix = "") + { + $o = ''; + $select = [ + '' => DI::l10n()->t('No answer'), + 'Males' => DI::l10n()->t('Males'), + 'Females' => DI::l10n()->t('Females'), + 'Gay' => DI::l10n()->t('Gay'), + 'Lesbian' => DI::l10n()->t('Lesbian'), + 'No Preference' => DI::l10n()->t('No Preference'), + 'Bisexual' => DI::l10n()->t('Bisexual'), + 'Autosexual' => DI::l10n()->t('Autosexual'), + 'Abstinent' => DI::l10n()->t('Abstinent'), + 'Virgin' => DI::l10n()->t('Virgin'), + 'Deviant' => DI::l10n()->t('Deviant'), + 'Fetish' => DI::l10n()->t('Fetish'), + 'Oodles' => DI::l10n()->t('Oodles'), + 'Nonsexual' => DI::l10n()->t('Nonsexual'), + ]; + + Hook::callAll('sexpref_selector', $select); + + $o .= "'; + return $o; + } + + /** + * @param string $current optional, default empty + * @return string + * @throws \Friendica\Network\HTTPException\InternalServerErrorException + */ + public static function maritalStatus($current = "") + { + $o = ''; + $select = [ + '' => DI::l10n()->t('No answer'), + 'Single' => DI::l10n()->t('Single'), + 'Lonely' => DI::l10n()->t('Lonely'), + 'In a relation' => DI::l10n()->t('In a relation'), + 'Has crush' => DI::l10n()->t('Has crush'), + 'Infatuated' => DI::l10n()->t('Infatuated'), + 'Dating' => DI::l10n()->t('Dating'), + 'Unfaithful' => DI::l10n()->t('Unfaithful'), + 'Sex Addict' => DI::l10n()->t('Sex Addict'), + 'Friends' => DI::l10n()->t('Friends'), + 'Friends/Benefits' => DI::l10n()->t('Friends/Benefits'), + 'Casual' => DI::l10n()->t('Casual'), + 'Engaged' => DI::l10n()->t('Engaged'), + 'Married' => DI::l10n()->t('Married'), + 'Imaginarily married' => DI::l10n()->t('Imaginarily married'), + 'Partners' => DI::l10n()->t('Partners'), + 'Cohabiting' => DI::l10n()->t('Cohabiting'), + 'Common law' => DI::l10n()->t('Common law'), + 'Happy' => DI::l10n()->t('Happy'), + 'Not looking' => DI::l10n()->t('Not looking'), + 'Swinger' => DI::l10n()->t('Swinger'), + 'Betrayed' => DI::l10n()->t('Betrayed'), + 'Separated' => DI::l10n()->t('Separated'), + 'Unstable' => DI::l10n()->t('Unstable'), + 'Divorced' => DI::l10n()->t('Divorced'), + 'Imaginarily divorced' => DI::l10n()->t('Imaginarily divorced'), + 'Widowed' => DI::l10n()->t('Widowed'), + 'Uncertain' => DI::l10n()->t('Uncertain'), + 'It\'s complicated' => DI::l10n()->t('It\'s complicated'), + 'Don\'t care' => DI::l10n()->t('Don\'t care'), + 'Ask me' => DI::l10n()->t('Ask me'), + ]; + + Hook::callAll('marital_selector', $select); + + $o .= ''; + return $o; + } }