From 687381bc53058cdfefa41c533ab8fa20ec68b999 Mon Sep 17 00:00:00 2001 From: oldkid Date: Sun, 28 Apr 2024 08:36:40 +0200 Subject: [PATCH] loma-one addons --- invidious/invidious.php | 6 +- piped/README.md | 4 ++ piped/lang/C/messages.po | 58 +++++++++++++++++++ piped/piped.php | 106 ++++++++++++++++++++++++++++++++++ piped/templates/admin.tpl | 5 ++ piped/templates/settings.tpl | 2 + proxigram/README.md | 4 ++ proxigram/lang/C/messages.po | 39 +++++++++++++ proxigram/proxigram.php | 65 +++++++++++++++++++++ proxigram/templates/admin.tpl | 5 ++ 10 files changed, 292 insertions(+), 2 deletions(-) create mode 100644 piped/README.md create mode 100644 piped/lang/C/messages.po create mode 100644 piped/piped.php create mode 100644 piped/templates/admin.tpl create mode 100644 piped/templates/settings.tpl create mode 100644 proxigram/README.md create mode 100644 proxigram/lang/C/messages.po create mode 100644 proxigram/proxigram.php create mode 100644 proxigram/templates/admin.tpl diff --git a/invidious/invidious.php b/invidious/invidious.php index 7153aab9..35e6df7e 100644 --- a/invidious/invidious.php +++ b/invidious/invidious.php @@ -2,10 +2,10 @@ /* * Name: invidious * Description: Replaces links to youtube.com to an invidious instance in all displays of postings on a node. - * Version: 0.4 + * Version: 0.5 * Author: Matthias Ebers * Author: Michael Vogel - * Status: Unsupported + * Status: * Note: Please use the URL Replace addon instead */ @@ -96,6 +96,8 @@ function invidious_render(array &$b) $b['html'] = preg_replace("~https?://(?:www\.)?youtube\.com/watch\?v=(.*?)~ism", $server . '/watch?v=$1', $b['html']); $b['html'] = preg_replace("~https?://(?:www\.)?youtube\.com/embed/(.*?)~ism", $server . '/embed/$1', $b['html']); $b['html'] = preg_replace("~https?://(?:www\.)?youtube\.com/shorts/(.*?)~ism", $server . '/shorts/$1', $b['html']); + $b['html'] = preg_replace ("/https?:\/\/music.youtube.com\/(.*?)/ism", $server . '/watch?v=$1', $b['html']); + $b['html'] = preg_replace ("/https?:\/\/m.youtube.com\/(.*?)/ism", $server . '/watch?v=$1', $b['html']); $b['html'] = preg_replace("/https?:\/\/youtu.be\/(.*?)/ism", $server . '/watch?v=$1', $b['html']); if ($original != $b['html']) { diff --git a/piped/README.md b/piped/README.md new file mode 100644 index 00000000..cdf599b8 --- /dev/null +++ b/piped/README.md @@ -0,0 +1,4 @@ +piped Addon for Friendica +========================== + +This addon will replace "youtube.com" with the chosen Piped instance diff --git a/piped/lang/C/messages.po b/piped/lang/C/messages.po new file mode 100644 index 00000000..b6cc6988 --- /dev/null +++ b/piped/lang/C/messages.po @@ -0,0 +1,58 @@ +# ADDON piped +# Copyright (C) +# This file is distributed under the same license as the Friendica piped addon package. +# +# +#, fuzzy +msgid "" +msgstr "" +"Project-Id-Version: \n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2024-04-27 08:25+0200\n" +"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" +"Last-Translator: FULL NAME \n" +"Language-Team: LANGUAGE \n" +"Language: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" + +#: piped.php:40 +#, php-format +msgid "" +"Which Piped server shall be used for the replacements in the post bodies? " +"Use the URL with servername and protocol. See %s for a list of available " +"public Piped servers." +msgstr "" + +#: piped.php:41 piped.php:58 +msgid "Piped server" +msgstr "" + +#: piped.php:41 piped.php:58 +#, php-format +msgid "See %s for a list of available Piped servers." +msgstr "" + +#: piped.php:42 +msgid "Save Settings" +msgstr "" + +#: piped.php:57 +msgid "Replace Youtube links with links to an Piped server" +msgstr "" + +#: piped.php:57 +msgid "" +"If enabled, Youtube links are replaced with the links to the specified Piped " +"server." +msgstr "" + +#: piped.php:63 +msgid "Piped Settings" +msgstr "" + +#: piped.php:104 +#, php-format +msgid "(Piped addon enabled: YouTube links via %s)" +msgstr "" diff --git a/piped/piped.php b/piped/piped.php new file mode 100644 index 00000000..81fa95b6 --- /dev/null +++ b/piped/piped.php @@ -0,0 +1,106 @@ + + * Author: Michael Vogel + * Status: + * Note: + */ + +use Friendica\Core\Hook; +use Friendica\Core\Renderer; +use Friendica\DI; + +CONST PIPED_DEFAULT = 'https://piped.video'; + +function piped_install() +{ + Hook::register('prepare_body_final', __FILE__, 'piped_render'); + Hook::register('addon_settings', __FILE__, 'piped_settings'); + Hook::register('addon_settings_post', __FILE__, 'piped_settings_post'); +} + +/* Handle the send data from the admin settings + */ +function piped_addon_admin_post() +{ + DI::config()->set('piped', 'server', trim($_POST['pipedserver'], " \n\r\t\v\x00/")); +} + +/* Hook into the admin settings to let the admin choose an + * piped server to use for the replacement. + */ +function piped_addon_admin(string &$o) +{ + $pipedserver = DI::config()->get('piped', 'server', PIPED_DEFAULT); + $t = Renderer::getMarkupTemplate('admin.tpl', 'addon/piped/'); + $o = Renderer::replaceMacros($t, [ + '$settingdescription' => DI::l10n()->t('Which Piped server shall be used for the replacements in the post bodies? Use the URL with servername and protocol. See %s for a list of available public Piped servers.', 'https://github.com/TeamPiped/Piped/wiki/Instances'), + '$pipedserver' => ['pipedserver', DI::l10n()->t('Piped server'), $pipedserver, DI::l10n()->t('See %s for a list of available Piped servers.', 'https://github.com/TeamPiped/Piped/wiki/Instances/')], + '$submit' => DI::l10n()->t('Save Settings'), + ]); +} + +function piped_settings(array &$data) +{ + if (!DI::userSession()->getLocalUserId()) { + return; + } + + $enabled = DI::pConfig()->get(DI::userSession()->getLocalUserId(), 'piped', 'enabled'); + $server = DI::pConfig()->get(DI::userSession()->getLocalUserId(), 'piped', 'server', DI::config()->get('piped', 'server', PIPED_DEFAULT)); + + $t = Renderer::getMarkupTemplate('settings.tpl', 'addon/piped/'); + $html = Renderer::replaceMacros($t, [ + '$enabled' => ['enabled', DI::l10n()->t('Replace Youtube links with links to an Piped server'), $enabled, DI::l10n()->t('If enabled, Youtube links are replaced with the links to the specified Piped server.')], + '$server' => ['server', DI::l10n()->t('Piped server'), $server, DI::l10n()->t('See %s for a list of available Piped servers.', 'https://github.com/TeamPiped/Piped/wiki/Instances/')], + ]); + + $data = [ + 'addon' => 'piped', + 'title' => DI::l10n()->t('Piped Settings'), + 'html' => $html, + ]; +} + +function piped_settings_post(array &$b) +{ + if (!DI::userSession()->getLocalUserId() || empty($_POST['piped-submit'])) { + return; + } + + DI::pConfig()->set(DI::userSession()->getLocalUserId(), 'piped', 'enabled', (bool)$_POST['enabled']); + + $server = trim($_POST['server'], " \n\r\t\v\x00/"); + if ($server != DI::config()->get('piped', 'server', PIPED_DEFAULT) && !empty($server)) { + DI::pConfig()->set(DI::userSession()->getLocalUserId(), 'piped', 'server', $server); + } else { + DI::pConfig()->delete(DI::userSession()->getLocalUserId(), 'piped', 'server'); + } +} + +/* + * replace "youtube.com" with the chosen Piped instance + */ +function piped_render(array &$b) +{ + if (!DI::userSession()->getLocalUserId() || !DI::pConfig()->get(DI::userSession()->getLocalUserId(), 'piped', 'enabled')) { + return; + } + + $original = $b['html']; + $server = DI::pConfig()->get(DI::userSession()->getLocalUserId(), 'piped', 'server', DI::config()->get('piped', 'server', PIPED_DEFAULT)); + + $b['html'] = preg_replace("~https?://(?:www\.)?youtube\.com/watch\?v=(.*?)~ism", $server . '/watch?v=$1', $b['html']); + $b['html'] = preg_replace("~https?://(?:www\.)?youtube\.com/embed/(.*?)~ism", $server . '/embed/$1', $b['html']); + $b['html'] = preg_replace("~https?://(?:www\.)?youtube\.com/shorts/(.*?)~ism", $server . '/shorts/$1', $b['html']); + $b['html'] = preg_replace ("/https?:\/\/music.youtube.com\/(.*?)/ism", $server . '/watch?v=$1', $b['html']); + $b['html'] = preg_replace ("/https?:\/\/m.youtube.com\/(.*?)/ism", $server . '/watch?v=$1', $b['html']); + $b['html'] = preg_replace("/https?:\/\/youtu.be\/(.*?)/ism", $server . '/watch?v=$1', $b['html']); + + if ($original != $b['html']) { + $b['html'] .= '

' . DI::l10n()->t('(Piped addon enabled: YouTube links via %s)', $server) . '

'; + } +} diff --git a/piped/templates/admin.tpl b/piped/templates/admin.tpl new file mode 100644 index 00000000..600c1aa1 --- /dev/null +++ b/piped/templates/admin.tpl @@ -0,0 +1,5 @@ +

{{$settingdescription}}

+ +{{include file="field_input.tpl" field=$pipedserver}} + +
diff --git a/piped/templates/settings.tpl b/piped/templates/settings.tpl new file mode 100644 index 00000000..387286ef --- /dev/null +++ b/piped/templates/settings.tpl @@ -0,0 +1,2 @@ +{{include file="field_checkbox.tpl" field=$enabled}} +{{include file="field_input.tpl" field=$server}} diff --git a/proxigram/README.md b/proxigram/README.md new file mode 100644 index 00000000..2f3e28db --- /dev/null +++ b/proxigram/README.md @@ -0,0 +1,4 @@ +instagram Addon for Friendica +========================== + +This addon will replace "instagram.com" with the chosen Proxigram instance diff --git a/proxigram/lang/C/messages.po b/proxigram/lang/C/messages.po new file mode 100644 index 00000000..c22bf5f8 --- /dev/null +++ b/proxigram/lang/C/messages.po @@ -0,0 +1,39 @@ +# ADDON invidious +# Copyright (C) +# This file is distributed under the same license as the Friendica invidious addon package. +# +# +#, fuzzy +msgid "" +msgstr "" +"Project-Id-Version: \n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2023-12-03 20:21+0100\n" +"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" +"Last-Translator: FULL NAME \n" +"Language-Team: LANGUAGE \n" +"Language: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" + +#: invidious.php:35 +#, php-format +msgid "" +"Which Invidious server shall be used for the replacements in the post " +"bodies? Use the URL with servername and protocol. See %s for a list of " +"available public Invidious servers." +msgstr "" + +#: invidious.php:36 +msgid "Invidious server" +msgstr "" + +#: invidious.php:37 +msgid "Save Settings" +msgstr "" + +#: invidious.php:64 +#, php-format +msgid "(Invidious addon enabled: YouTube links via %s)" +msgstr "" diff --git a/proxigram/proxigram.php b/proxigram/proxigram.php new file mode 100644 index 00000000..d5caafa3 --- /dev/null +++ b/proxigram/proxigram.php @@ -0,0 +1,65 @@ + + * + */ + +use Friendica\App; +use Friendica\Core\Hook; +use Friendica\Core\Renderer; +use Friendica\DI; + +function proxigram_install() +{ + Hook::register('prepare_body_final', 'addon/proxigram/proxigram.php', 'proxigram_render'); +} + +/* Handle the send data from the admin settings + */ +function proxigram_addon_admin_post() +{ + DI::config()->set('proxigram', 'server', rtrim(trim($_POST['proxigramserver']), '/')); +} + +/* Hook into the admin settings to let the admin choose an + * proxigram server to use for the replacement. + */ +function proxigram_addon_admin(string &$o) +{ + $proxigramserver = DI::config()->get('proxigram', 'server'); + $t = Renderer::getMarkupTemplate('admin.tpl', 'addon/proxigram/'); + $o = Renderer::replaceMacros($t, [ + '$settingdescription' => DI::l10n()->t('Which proxigram server shall be used for the replacements in the post bodies? Use the URL with servername and protocol. See %s for a list of available public proxigram servers.', 'https://codeberg.org/ThePenguinDev/proxigram/wiki/Instances#user-content-public'), + '$proxigramserver' => ['proxigramserver', DI::l10n()->t('proxigram server'), $proxigramserver, 'https://example.com'], + '$submit' => DI::l10n()->t('Save Settings'), + ]); +} + +/* + * replace "instagram" with the chosen proxigram instance + */ +function proxigram_render(array &$b) +{ + // this needs to be a system setting + $replaced = false; + $proxigram = DI::config()->get('proxigram', 'server', 'https://proxigram.lunar.icu'); + + $instagramUrls = [ + 'https://www.instagram.com', + 'https://ig.me', + ]; + + foreach ($instagramUrls as $instagramUrl) { + if (strstr($b['html'], $instagramUrl)) { + $b['html'] = str_replace($instagramUrl, $proxigram, $b['html']); + $replaced = true; + } + } + + if ($replaced) { + $b['html'] .= '

' . DI::l10n()->t('(proxigram addon enabled: Instagram links via %s)', $proxigram) . '

'; + } +} diff --git a/proxigram/templates/admin.tpl b/proxigram/templates/admin.tpl new file mode 100644 index 00000000..9ee5b7b8 --- /dev/null +++ b/proxigram/templates/admin.tpl @@ -0,0 +1,5 @@ +

{{$settingdescription}}

+ +{{include file="field_input.tpl" field=$proxigramserver}} + +