]> git.mxchange.org Git - friendica-addons.git/blobdiff - mastodoncustomemojis/mastodoncustomemojis.php
Fix GIT email/name
[friendica-addons.git] / mastodoncustomemojis / mastodoncustomemojis.php
index da9bbf7f71d6351ee72ea3c3386d23802da221e3..40dac01f016c9576c4d658b030e1565a4c230ae4 100644 (file)
@@ -6,38 +6,30 @@
  * Version: 1.0
  * Author: Hypolite Petovan
  * Author: Roland Haeder
+ * Status: Unsupported
  */
 
 use Friendica\App;
 use Friendica\Content\Smilies;
-use Friendica\Core\Addon;
-use Friendica\Core\Cache;
+use Friendica\Core\Cache\Enum\Duration;
+use Friendica\Core\Hook;
 use Friendica\Core\Protocol;
-use Friendica\Util\Network;
+use Friendica\DI;
+use Friendica\Util\Proxy as ProxyUtils;
 
 function mastodoncustomemojis_install()
 {
-       Addon::registerHook('put_item_in_cache',  __FILE__, 'mastodoncustomemojis_put_item_in_cache');
-       Addon::registerHook('network_mod_init',   __FILE__, 'mastodoncustomemojis_css_hook');
-       Addon::registerHook('display_mod_init',   __FILE__, 'mastodoncustomemojis_css_hook');
-       Addon::registerHook('search_mod_init',    __FILE__, 'mastodoncustomemojis_css_hook');
-       Addon::registerHook('community_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
-       Addon::registerHook('contacts_mod_init',  __FILE__, 'mastodoncustomemojis_css_hook');
-}
-
-function mastodoncustomemojis_uninstall()
-{
-       Addon::unregisterHook('put_item_in_cache',  __FILE__, 'mastodoncustomemojis_put_item_in_cache');
-       Addon::unregisterHook('network_mod_init',   __FILE__, 'mastodoncustomemojis_css_hook');
-       Addon::unregisterHook('display_mod_init',   __FILE__, 'mastodoncustomemojis_css_hook');
-       Addon::unregisterHook('search_mod_init',    __FILE__, 'mastodoncustomemojis_css_hook');
-       Addon::unregisterHook('community_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
-       Addon::unregisterHook('contacts_mod_init',  __FILE__, 'mastodoncustomemojis_css_hook');
+       Hook::register('put_item_in_cache',  __FILE__, 'mastodoncustomemojis_put_item_in_cache');
+       Hook::register('network_mod_init',   __FILE__, 'mastodoncustomemojis_css_hook');
+       Hook::register('display_mod_init',   __FILE__, 'mastodoncustomemojis_css_hook');
+       Hook::register('search_mod_init',    __FILE__, 'mastodoncustomemojis_css_hook');
+       Hook::register('community_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
+       Hook::register('contacts_mod_init',  __FILE__, 'mastodoncustomemojis_css_hook');
 }
 
 function mastodoncustomemojis_css_hook(App $a)
 {
-       $a->page['htmlhead'] .= <<<HTML
+       DI::page()['htmlhead'] .= <<<HTML
 <!-- Style added by mastodoncustomemojis -->
 <style type="text/css">
        .emoji.mastodon {
@@ -52,8 +44,8 @@ HTML;
 
 function mastodoncustomemojis_put_item_in_cache(App $a, array &$hook_data)
 {
-       // Mastodon uses OStatus, skipping other network protocols
-       if ($hook_data['item']['network'] != Protocol::OSTATUS) {
+       // Mastodon uses OStatus and ActivityPub, skipping other network protocols
+       if (empty($hook_data['item']['author-link']) || !in_array($hook_data['item']['network'], [Protocol::OSTATUS, Protocol::ACTIVITYPUB])) {
                return;
        }
 
@@ -64,37 +56,42 @@ function mastodoncustomemojis_put_item_in_cache(App $a, array &$hook_data)
 
 function mastodoncustomemojis_get_custom_emojis_for_author($author_link)
 {
-       $return = ['texts' => [], 'icons' => []];
-
        $url_parts = parse_url($author_link);
 
        $api_base_url = $url_parts['scheme'] . '://' . $url_parts['host'] . (isset($url_parts['port']) ? ':' . $url_parts['port'] : '');
 
        $cache_key = 'mastodoncustomemojis:' . $api_base_url;
 
-       $emojis = Cache::get($cache_key);
-       if (empty($emojis)) {
-               // Reset the emojis array
-               $emojis = $return;
+       $return = DI::cache()->get($cache_key);
+
+       if (empty($return) || DI::config()->get('system', 'ignore_cache')) {
+               $return = mastodoncustomemojis_fetch_custom_emojis_for_url($api_base_url);
+
+               DI::cache()->set($cache_key, $return, empty($return['texts']) ? Duration::QUARTER_HOUR : Duration::HOUR);
+       }
+
+       return $return;
+}
+
+function mastodoncustomemojis_fetch_custom_emojis_for_url($api_base_url)
+{
+       $return = ['texts' => [], 'icons' => []];
 
-               $api_url = $api_base_url . '/api/v1/custom_emojis';
+       $api_url = $api_base_url . '/api/v1/custom_emojis';
 
-               $ret = Network::fetchUrlFull($api_url);
+       $fetchResult = DI::httpClient()->fetchFull($api_url);
 
-               if ($ret['success']) {
-                       $emojis_array = json_decode($ret['body'], true);
+       if ($fetchResult->isSuccess()) {
+               $emojis_array = json_decode($fetchResult->getBody(), true);
 
-                       if (is_array($emojis_array)) {
-                               foreach ($emojis_array as $emoji) {
-                                       $emojis['texts'][] = ':' . $emoji['shortcode'] . ':';
-                                       $emojis['icons'][] = '<img class="emoji mastodon" src="' . proxy_url($emoji['static_url']) . '" alt=":' . $emoji['shortcode'] . ':" title=":' . $emoji['shortcode'] . ':"/>';
+               if (is_array($emojis_array) && count($emojis_array)) {
+                       foreach ($emojis_array as $emoji) {
+                               if (!empty($emoji['shortcode']) && !empty($emoji['static_url'])) {
+                                       $return['texts'][] = ':' . $emoji['shortcode'] . ':';
+                                       $return['icons'][] = '<img class="emoji mastodon" src="' . ProxyUtils::proxifyUrl($emoji['static_url']) . '" alt=":' . $emoji['shortcode'] . ':" title=":' . $emoji['shortcode'] . ':"/>';
                                }
                        }
                }
-
-               Cache::set($cache_key, $emojis, Cache::WEEK);
-
-               $return = $emojis;
        }
 
        return $return;