2018-01-09 21:56:05 -05:00
|
|
|
<?php
|
|
|
|
/**
|
2023-01-01 09:36:24 -05:00
|
|
|
* @copyright Copyright (C) 2010-2023, the Friendica project
|
2020-02-09 09:45:36 -05:00
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
2018-01-09 21:56:05 -05:00
|
|
|
*/
|
2020-02-09 09:45:36 -05:00
|
|
|
|
2018-01-09 21:56:05 -05:00
|
|
|
namespace Friendica\Content;
|
|
|
|
|
2018-12-26 01:06:24 -05:00
|
|
|
use Friendica\Core\Hook;
|
2018-08-11 16:40:44 -04:00
|
|
|
use Friendica\Core\Protocol;
|
2018-07-20 08:19:26 -04:00
|
|
|
use Friendica\Database\DBA;
|
2020-01-18 17:00:53 -05:00
|
|
|
use Friendica\DI;
|
2018-10-05 15:26:20 -04:00
|
|
|
use Friendica\Util\Network;
|
2018-11-08 11:28:29 -05:00
|
|
|
use Friendica\Util\Strings;
|
2018-01-09 21:56:05 -05:00
|
|
|
|
2018-01-09 22:42:04 -05:00
|
|
|
/**
|
2020-01-19 01:05:23 -05:00
|
|
|
* ContactSelector class
|
2018-01-09 22:42:04 -05:00
|
|
|
*/
|
2018-01-09 21:56:05 -05:00
|
|
|
class ContactSelector
|
|
|
|
{
|
2021-02-17 13:59:19 -05:00
|
|
|
static $serverdata = [];
|
|
|
|
static $server_url = [];
|
|
|
|
|
2018-01-10 07:14:45 -05:00
|
|
|
/**
|
|
|
|
* @param string $current current
|
|
|
|
* @param boolean $disabled optional, default false
|
2020-01-27 23:05:57 -05:00
|
|
|
* @return string
|
2018-01-10 07:14:45 -05:00
|
|
|
*/
|
2022-06-16 12:28:38 -04:00
|
|
|
public static function pollInterval(string $current, bool $disabled = false): string
|
2018-01-09 22:42:04 -05:00
|
|
|
{
|
|
|
|
$dis = (($disabled) ? ' disabled="disabled" ' : '');
|
|
|
|
$o = '';
|
|
|
|
$o .= "<select id=\"contact-poll-interval\" name=\"poll\" $dis />" . "\r\n";
|
|
|
|
|
2018-01-15 08:05:12 -05:00
|
|
|
$rep = [
|
2020-01-18 14:52:34 -05:00
|
|
|
0 => DI::l10n()->t('Frequently'),
|
|
|
|
1 => DI::l10n()->t('Hourly'),
|
|
|
|
2 => DI::l10n()->t('Twice daily'),
|
|
|
|
3 => DI::l10n()->t('Daily'),
|
|
|
|
4 => DI::l10n()->t('Weekly'),
|
|
|
|
5 => DI::l10n()->t('Monthly')
|
2018-01-15 08:05:12 -05:00
|
|
|
];
|
2018-01-09 22:42:04 -05:00
|
|
|
|
|
|
|
foreach ($rep as $k => $v) {
|
|
|
|
$selected = (($k == $current) ? " selected=\"selected\" " : "");
|
|
|
|
$o .= "<option value=\"$k\" $selected >$v</option>\r\n";
|
|
|
|
}
|
|
|
|
$o .= "</select>\r\n";
|
|
|
|
return $o;
|
|
|
|
}
|
|
|
|
|
2021-02-17 13:59:19 -05:00
|
|
|
private static function getServerForProfile(string $profile)
|
|
|
|
{
|
|
|
|
$server_url = self::getServerURLForProfile($profile);
|
|
|
|
|
|
|
|
if (!empty(self::$serverdata[$server_url])) {
|
|
|
|
return self::$serverdata[$server_url];
|
|
|
|
}
|
|
|
|
|
|
|
|
// Now query the GServer for the platform name
|
|
|
|
$gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['nurl' => $server_url]);
|
|
|
|
|
|
|
|
self::$serverdata[$server_url] = $gserver;
|
|
|
|
return $gserver;
|
|
|
|
}
|
|
|
|
|
2019-08-28 02:38:35 -04:00
|
|
|
/**
|
|
|
|
* @param string $profile Profile URL
|
|
|
|
* @return string Server URL
|
2020-01-27 23:05:57 -05:00
|
|
|
* @throws \Exception
|
2019-08-28 02:38:35 -04:00
|
|
|
*/
|
2022-06-16 12:28:38 -04:00
|
|
|
private static function getServerURLForProfile(string $profile): string
|
2019-08-28 02:38:35 -04:00
|
|
|
{
|
2021-02-17 13:59:19 -05:00
|
|
|
if (!empty(self::$server_url[$profile])) {
|
|
|
|
return self::$server_url[$profile];
|
|
|
|
}
|
|
|
|
|
2019-08-28 02:38:35 -04:00
|
|
|
$server_url = '';
|
|
|
|
|
|
|
|
// Fetch the server url from the contact table
|
2019-08-28 05:10:25 -04:00
|
|
|
$contact = DBA::selectFirst('contact', ['baseurl'], ['uid' => 0, 'nurl' => Strings::normaliseLink($profile)]);
|
2019-08-28 02:38:35 -04:00
|
|
|
if (DBA::isResult($contact) && !empty($contact['baseurl'])) {
|
|
|
|
$server_url = Strings::normaliseLink($contact['baseurl']);
|
|
|
|
}
|
|
|
|
|
|
|
|
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));
|
|
|
|
}
|
|
|
|
|
2021-02-17 13:59:19 -05:00
|
|
|
self::$server_url[$profile] = $server_url;
|
|
|
|
|
2019-08-28 02:38:35 -04:00
|
|
|
return $server_url;
|
|
|
|
}
|
|
|
|
|
2018-01-10 07:14:45 -05:00
|
|
|
/**
|
2022-06-16 14:42:40 -04:00
|
|
|
* Determines network name
|
|
|
|
*
|
2019-12-27 14:00:54 -05:00
|
|
|
* @param string $network network of the contact
|
2019-12-27 12:24:29 -05:00
|
|
|
* @param string $profile optional, default empty
|
2019-12-27 14:00:54 -05:00
|
|
|
* @param string $protocol (Optional) Protocol that is used for the transmission
|
2022-06-16 14:42:40 -04:00
|
|
|
* @param int $gsid Server id
|
2018-01-10 07:14:45 -05:00
|
|
|
* @return string
|
2019-01-06 16:06:53 -05:00
|
|
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
2018-01-10 07:14:45 -05:00
|
|
|
*/
|
2022-06-16 14:42:40 -04:00
|
|
|
public static function networkToName(string $network, string $profile = '', string $protocol = '', int $gsid = null): string
|
2018-01-09 22:42:04 -05:00
|
|
|
{
|
2018-01-15 08:05:12 -05:00
|
|
|
$nets = [
|
2020-01-18 14:52:34 -05:00
|
|
|
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'),
|
2023-04-18 15:30:28 -04:00
|
|
|
Protocol::TUMBLR => DI::l10n()->t('Tumblr'),
|
2023-05-21 13:19:39 -04:00
|
|
|
Protocol::BLUESKY => DI::l10n()->t('Bluesky'),
|
2018-01-15 08:05:12 -05:00
|
|
|
];
|
2018-01-09 22:42:04 -05:00
|
|
|
|
2018-12-26 01:06:24 -05:00
|
|
|
Hook::callAll('network_to_name', $nets);
|
2018-01-09 22:42:04 -05:00
|
|
|
|
|
|
|
$search = array_keys($nets);
|
|
|
|
$replace = array_values($nets);
|
|
|
|
|
2018-10-05 15:26:20 -04:00
|
|
|
$networkname = str_replace($search, $replace, $network);
|
2018-01-09 22:42:04 -05:00
|
|
|
|
2019-07-01 14:00:55 -04:00
|
|
|
if ((in_array($network, Protocol::FEDERATED)) && ($profile != "")) {
|
2021-03-07 15:15:25 -05:00
|
|
|
if (!empty($gsid) && !empty(self::$serverdata[$gsid])) {
|
|
|
|
$gserver = self::$serverdata[$gsid];
|
|
|
|
} elseif (!empty($gsid)) {
|
|
|
|
$gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['id' => $gsid]);
|
|
|
|
self::$serverdata[$gsid] = $gserver;
|
|
|
|
} else {
|
|
|
|
$gserver = self::getServerForProfile($profile);
|
|
|
|
}
|
2018-10-05 15:26:20 -04:00
|
|
|
|
2021-02-17 13:59:19 -05:00
|
|
|
if (!empty($gserver['platform'])) {
|
|
|
|
$platform = $gserver['platform'];
|
|
|
|
} elseif (!empty($gserver['network']) && ($gserver['network'] != Protocol::ACTIVITYPUB)) {
|
|
|
|
$platform = self::networkToName($gserver['network']);
|
|
|
|
}
|
2018-10-05 15:26:20 -04:00
|
|
|
|
2021-02-17 13:59:19 -05:00
|
|
|
if (!empty($platform)) {
|
|
|
|
$networkname = $platform;
|
2018-09-15 06:13:41 -04:00
|
|
|
|
2021-02-17 13:59:19 -05:00
|
|
|
if ($network == Protocol::ACTIVITYPUB) {
|
|
|
|
$networkname .= ' (AP)';
|
2018-09-15 06:13:41 -04:00
|
|
|
}
|
2018-01-09 22:42:04 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-27 12:24:29 -05:00
|
|
|
if (!empty($protocol) && ($protocol != $network)) {
|
2020-01-18 14:52:34 -05:00
|
|
|
$networkname = DI::l10n()->t('%s (via %s)', $networkname, self::networkToName($protocol));
|
2019-12-27 12:24:29 -05:00
|
|
|
}
|
|
|
|
|
2018-01-09 22:42:04 -05:00
|
|
|
return $networkname;
|
|
|
|
}
|
2018-01-15 10:08:47 -05:00
|
|
|
|
2019-08-28 02:38:35 -04:00
|
|
|
/**
|
2022-06-16 14:42:40 -04:00
|
|
|
* Determines network's icon name
|
|
|
|
*
|
2019-08-28 02:38:35 -04:00
|
|
|
* @param string $network network
|
|
|
|
* @param string $profile optional, default empty
|
2022-06-16 14:42:40 -04:00
|
|
|
* @param int $gsid Server id
|
|
|
|
* @return string Name for network icon
|
2020-01-27 23:05:57 -05:00
|
|
|
* @throws \Exception
|
2019-08-28 02:38:35 -04:00
|
|
|
*/
|
2022-06-16 14:42:40 -04:00
|
|
|
public static function networkToIcon(string $network, string $profile = "", int $gsid = null): string
|
2019-08-28 02:38:35 -04:00
|
|
|
{
|
|
|
|
$nets = [
|
|
|
|
Protocol::DFRN => 'friendica',
|
2019-08-28 05:10:25 -04:00
|
|
|
Protocol::OSTATUS => 'gnu-social', // There is no generic OStatus icon
|
2019-08-28 02:38:35 -04:00
|
|
|
Protocol::FEED => 'rss',
|
2020-01-14 23:09:58 -05:00
|
|
|
Protocol::MAIL => 'inbox',
|
2019-08-28 02:38:35 -04:00
|
|
|
Protocol::DIASPORA => 'diaspora',
|
|
|
|
Protocol::ZOT => 'hubzilla',
|
|
|
|
Protocol::LINKEDIN => 'linkedin',
|
|
|
|
Protocol::XMPP => 'xmpp',
|
2019-08-28 05:10:25 -04:00
|
|
|
Protocol::MYSPACE => 'file-text-o', /// @todo
|
2019-08-28 02:38:35 -04:00
|
|
|
Protocol::GPLUS => 'google-plus',
|
2019-08-28 05:10:25 -04:00
|
|
|
Protocol::PUMPIO => 'file-text-o', /// @todo
|
2019-08-28 02:38:35 -04:00
|
|
|
Protocol::TWITTER => 'twitter',
|
2019-11-24 15:06:47 -05:00
|
|
|
Protocol::DISCOURSE => 'dot-circle-o', /// @todo
|
2019-08-28 02:38:35 -04:00
|
|
|
Protocol::DIASPORA2 => 'diaspora',
|
|
|
|
Protocol::STATUSNET => 'gnu-social',
|
|
|
|
Protocol::ACTIVITYPUB => 'activitypub',
|
2019-08-28 05:10:25 -04:00
|
|
|
Protocol::PNUT => 'file-text-o', /// @todo
|
2023-04-18 15:30:28 -04:00
|
|
|
Protocol::TUMBLR => 'tumblr',
|
2023-05-21 13:19:39 -04:00
|
|
|
Protocol::BLUESKY => 'circle', /// @todo
|
2019-08-28 02:38:35 -04:00
|
|
|
];
|
|
|
|
|
2019-08-28 10:07:21 -04:00
|
|
|
$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',
|
2023-08-09 16:29:45 -04:00
|
|
|
'socialhome' => 'social-home', 'wordpress' => 'wordpress', 'lemmy' => 'users',
|
|
|
|
'firefish' => 'fire', 'calckey' => 'calculator', 'kbin' => 'check'];
|
2019-08-28 10:07:21 -04:00
|
|
|
|
2019-08-28 02:38:35 -04:00
|
|
|
$search = array_keys($nets);
|
|
|
|
$replace = array_values($nets);
|
|
|
|
|
2019-08-28 10:07:21 -04:00
|
|
|
$network_icon = str_replace($search, $replace, $network);
|
2019-08-28 02:38:35 -04:00
|
|
|
|
|
|
|
if ((in_array($network, Protocol::FEDERATED)) && ($profile != "")) {
|
2022-04-29 03:47:24 -04:00
|
|
|
if (!empty($gsid) && !empty(self::$serverdata[$gsid])) {
|
|
|
|
$gserver = self::$serverdata[$gsid];
|
|
|
|
} elseif (!empty($gsid)) {
|
|
|
|
$gserver = DBA::selectFirst('gserver', ['platform', 'network'], ['id' => $gsid]);
|
|
|
|
self::$serverdata[$gsid] = $gserver;
|
|
|
|
} else {
|
|
|
|
$gserver = self::getServerForProfile($profile);
|
|
|
|
}
|
2021-02-17 13:59:19 -05:00
|
|
|
if (!empty($gserver['platform'])) {
|
2019-08-28 10:07:21 -04:00
|
|
|
$network_icon = $platform_icons[strtolower($gserver['platform'])] ?? $network_icon;
|
2019-08-28 02:38:35 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-28 10:07:21 -04:00
|
|
|
return $network_icon;
|
2019-08-28 02:38:35 -04:00
|
|
|
}
|
2018-01-09 21:56:05 -05:00
|
|
|
}
|