Merge branch 'develop' of https://github.com/friendica/friendica-addons into develop
[friendica-addons.git/.git] / mastodoncustomemojis / mastodoncustomemojis.php
1 <?php
2
3 /*
4  * Name: Mastodon Custom Emojis
5  * Description: Replace emojis shortcodes in Mastodon posts with their originating server custom emojis images.
6  * Version: 1.0
7  * Author: Hypolite Petovan
8  * Author: Roland Haeder
9  * Status: Unsupported
10  */
11
12 use Friendica\App;
13 use Friendica\Content\Smilies;
14 use Friendica\Core\Cache\Enum\Duration;
15 use Friendica\Core\Hook;
16 use Friendica\Core\Protocol;
17 use Friendica\DI;
18 use Friendica\Util\Proxy as ProxyUtils;
19
20 function mastodoncustomemojis_install()
21 {
22         Hook::register('put_item_in_cache',  __FILE__, 'mastodoncustomemojis_put_item_in_cache');
23         Hook::register('network_mod_init',   __FILE__, 'mastodoncustomemojis_css_hook');
24         Hook::register('display_mod_init',   __FILE__, 'mastodoncustomemojis_css_hook');
25         Hook::register('search_mod_init',    __FILE__, 'mastodoncustomemojis_css_hook');
26         Hook::register('community_mod_init', __FILE__, 'mastodoncustomemojis_css_hook');
27         Hook::register('contacts_mod_init',  __FILE__, 'mastodoncustomemojis_css_hook');
28 }
29
30 function mastodoncustomemojis_css_hook()
31 {
32         DI::page()['htmlhead'] .= <<<HTML
33 <!-- Style added by mastodoncustomemojis -->
34 <style type="text/css">
35         .emoji.mastodon {
36                 height: 1.2em;
37                 vertical-align: middle;
38         }
39 </style>
40
41
42 HTML;
43 }
44
45 function mastodoncustomemojis_put_item_in_cache(array &$hook_data)
46 {
47         // Mastodon uses OStatus and ActivityPub, skipping other network protocols
48         if (empty($hook_data['item']['author-link']) || !in_array($hook_data['item']['network'], [Protocol::OSTATUS, Protocol::ACTIVITYPUB])) {
49                 return;
50         }
51
52         $emojis = mastodoncustomemojis_get_custom_emojis_for_author($hook_data['item']['author-link']);
53
54         $hook_data["rendered-html"] = Smilies::replaceFromArray($hook_data["rendered-html"], $emojis);
55 }
56
57 function mastodoncustomemojis_get_custom_emojis_for_author($author_link)
58 {
59         $url_parts = parse_url($author_link);
60
61         $api_base_url = $url_parts['scheme'] . '://' . $url_parts['host'] . (isset($url_parts['port']) ? ':' . $url_parts['port'] : '');
62
63         $cache_key = 'mastodoncustomemojis:' . $api_base_url;
64
65         $return = DI::cache()->get($cache_key);
66
67         if (empty($return) || DI::config()->get('system', 'ignore_cache')) {
68                 $return = mastodoncustomemojis_fetch_custom_emojis_for_url($api_base_url);
69
70                 DI::cache()->set($cache_key, $return, empty($return['texts']) ? Duration::QUARTER_HOUR : Duration::HOUR);
71         }
72
73         return $return;
74 }
75
76 function mastodoncustomemojis_fetch_custom_emojis_for_url($api_base_url)
77 {
78         $return = ['texts' => [], 'icons' => []];
79
80         $api_url = $api_base_url . '/api/v1/custom_emojis';
81
82         $fetchResult = DI::httpClient()->fetchFull($api_url);
83
84         if ($fetchResult->isSuccess()) {
85                 $emojis_array = json_decode($fetchResult->getBodyString(), true);
86
87                 if (is_array($emojis_array) && count($emojis_array)) {
88                         foreach ($emojis_array as $emoji) {
89                                 if (!empty($emoji['shortcode']) && !empty($emoji['static_url'])) {
90                                         $return['texts'][] = ':' . $emoji['shortcode'] . ':';
91                                         $return['icons'][] = '<img class="emoji mastodon" src="' . ProxyUtils::proxifyUrl($emoji['static_url']) . '" alt=":' . $emoji['shortcode'] . ':" title=":' . $emoji['shortcode'] . ':"/>';
92                                 }
93                         }
94                 }
95         }
96
97         return $return;
98 }