4 * Name: Mastodon Custom Emojis
5 * Description: Replace emojis shortcodes in Mastodon posts with their originating server custom emojis images.
7 * Author: Hypolite Petovan
10 use Friendica\Core\Addon;
12 function mastodoncustomemojis_install()
14 Addon::registerHook('put_item_in_cache', __FILE__, 'mastodoncustomemojis_put_item_in_cache');
15 Addon::registerHook('network_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
16 Addon::registerHook('display_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
17 Addon::registerHook('search_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
18 Addon::registerHook('community_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
19 Addon::registerHook('contacts_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
22 function mastodoncustomemojis_uninstall()
24 Addon::unregisterHook('put_item_in_cache', __FILE__, 'mastodoncustomemojis_put_item_in_cache');
25 Addon::unregisterHook('network_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
26 Addon::unregisterHook('display_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
27 Addon::unregisterHook('search_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
28 Addon::unregisterHook('community_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
29 Addon::unregisterHook('contacts_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
32 function mastodoncustomemojis_css_hook(Friendica\App $a)
34 $a->page['htmlhead'] .= <<<HTML
35 <!-- Style added by mastodoncustomemojis -->
36 <style type="text/css">
39 vertical-align: middle;
47 function mastodoncustomemojis_put_item_in_cache(Friendica\App $a, &$hook_data)
49 // Mastodon uses OStatus, skipping other network protocols
50 if ($hook_data['item']['network'] != Friendica\Core\Protocol::OSTATUS) {
54 $emojis = mastodoncustomemojis_get_custom_emojis_for_author($hook_data['item']['author-link']);
56 $hook_data["rendered-html"] = Friendica\Content\Smilies::replaceFromArray($hook_data["rendered-html"], $emojis);
59 function mastodoncustomemojis_get_custom_emojis_for_author($author_link)
61 $return = ['texts' => [], 'icons' => []];
63 $url_parts = parse_url($author_link);
65 $api_base_url = $url_parts['scheme'] . '://' . $url_parts['host'] . ($url_parts['port'] ? ':' . $url_parts['port'] : '');
67 $cache_key = 'mastodoncustomemojis:' . $api_base_url;
69 $emojis = Friendica\Core\Cache::get($cache_key);
71 // Reset the emojis array
74 $api_url = $api_base_url . '/api/v1/custom_emojis';
76 $ret = Friendica\Util\Network::fetchUrlFull($api_url);
78 if ($ret['success']) {
79 $emojis_array = json_decode($ret['body'], true);
81 if (is_array($emojis_array)) {
82 foreach ($emojis_array as $emoji) {
83 $emojis['texts'][] = ':' . $emoji['shortcode'] . ':';
84 $emojis['icons'][] = '<img class="emoji mastodon" src="' . proxy_url($emoji['static_url']) . '" alt=":' . $emoji['shortcode'] . ':" title=":' . $emoji['shortcode'] . ':"/>';
89 Friendica\Core\Cache::set($cache_key, $emojis, Friendica\Core\Cache::WEEK);