]> git.mxchange.org Git - friendica-addons.git/blobdiff - curweather/curweather.php
Move Config::get() to DI::config()->get()
[friendica-addons.git] / curweather / curweather.php
index 044f5a154d53dbec72ce6ef9d9e7a49c304ceb53..4507fadb70955f420009f76281898d874180516c 100644 (file)
@@ -2,47 +2,46 @@
 /**
  * Name: Current Weather
  * Description: Shows current weather conditions for user's location on their network page.
- * Version: 1.1
+ * Version: 1.2
  * Author: Tony Baldwin <http://friendica.tonybaldwin.info/u/t0ny>
  * Author: Fabio Comuni <http://kirkgroup.com/u/fabrixxm>
  * Author: Tobias Diekershoff <https://f.diekershoff.de/u/tobias>
  *
  */
 
-require_once 'include/text.php';
-
 use Friendica\App;
-use Friendica\Core\Addon;
-use Friendica\Core\Cache;
+use Friendica\Core\Cache\Duration;
 use Friendica\Core\Config;
-use Friendica\Core\L10n;
-use Friendica\Core\PConfig;
+use Friendica\Core\Hook;
+use Friendica\Core\Renderer;
+use Friendica\Core\Session;
+use Friendica\DI;
 use Friendica\Util\Network;
 use Friendica\Util\Proxy as ProxyUtils;
 
 function curweather_install()
 {
-       Addon::registerHook('network_mod_init'   , 'addon/curweather/curweather.php', 'curweather_network_mod_init');
-       Addon::registerHook('addon_settings'     , 'addon/curweather/curweather.php', 'curweather_addon_settings');
-       Addon::registerHook('addon_settings_post', 'addon/curweather/curweather.php', 'curweather_addon_settings_post');
+       Hook::register('network_mod_init'   , 'addon/curweather/curweather.php', 'curweather_network_mod_init');
+       Hook::register('addon_settings'     , 'addon/curweather/curweather.php', 'curweather_addon_settings');
+       Hook::register('addon_settings_post', 'addon/curweather/curweather.php', 'curweather_addon_settings_post');
 }
 
 function curweather_uninstall()
 {
-       Addon::unregisterHook('network_mod_init'   , 'addon/curweather/curweather.php', 'curweather_network_mod_init');
-       Addon::unregisterHook('addon_settings'     , 'addon/curweather/curweather.php', 'curweather_addon_settings');
-       Addon::unregisterHook('addon_settings_post', 'addon/curweather/curweather.php', 'curweather_addon_settings_post');
+       Hook::unregister('network_mod_init'   , 'addon/curweather/curweather.php', 'curweather_network_mod_init');
+       Hook::unregister('addon_settings'     , 'addon/curweather/curweather.php', 'curweather_addon_settings');
+       Hook::unregister('addon_settings_post', 'addon/curweather/curweather.php', 'curweather_addon_settings_post');
 }
 
 //  get the weather data from OpenWeatherMap
 function getWeather($loc, $units = 'metric', $lang = 'en', $appid = '', $cachetime = 0)
 {
        $url = "http://api.openweathermap.org/data/2.5/weather?q=" . $loc . "&appid=" . $appid . "&lang=" . $lang . "&units=" . $units . "&mode=xml";
-       $cached = Cache::get('curweather'.md5($url));
+       $cached = DI::cache()->get('curweather'.md5($url));
        $now = new DateTime();
 
        if (!is_null($cached)) {
-               $cdate = PConfig::get(local_user(), 'curweather', 'last');
+               $cdate = DI::pConfig()->get(local_user(), 'curweather', 'last');
                $cached = unserialize($cached);
 
                if ($cdate + $cachetime > $now->getTimestamp()) {
@@ -54,7 +53,7 @@ function getWeather($loc, $units = 'metric', $lang = 'en', $appid = '', $cacheti
                $res = new SimpleXMLElement(Network::fetchUrl($url));
        } catch (Exception $e) {
                if (empty($_SESSION['curweather_notice_shown'])) {
-                       info(L10n::t('Error fetching weather data. Error was: '.$e->getMessage()));
+                       info(DI::l10n()->t('Error fetching weather data. Error was: '.$e->getMessage()));
                        $_SESSION['curweather_notice_shown'] = true;
                }
 
@@ -63,7 +62,7 @@ function getWeather($loc, $units = 'metric', $lang = 'en', $appid = '', $cacheti
 
        unset($_SESSION['curweather_notice_shown']);
 
-       if ((string) $res->temperature['unit'] === 'metric') {
+       if (in_array((string) $res->temperature['unit'], ['celsius', 'metric'])) {
                $tunit = '°C';
                $wunit = 'm/s';
        } else {
@@ -91,19 +90,19 @@ function getWeather($loc, $units = 'metric', $lang = 'en', $appid = '', $cacheti
                'icon'        => (string) $res->weather['icon'],
        ];
 
-       PConfig::set(local_user(), 'curweather', 'last', $now->getTimestamp());
-       Cache::set('curweather'.md5($url), serialize($r), CACHE_HOUR);
+       DI::pConfig()->set(local_user(), 'curweather', 'last', $now->getTimestamp());
+       DI::cache()->set('curweather'.md5($url), serialize($r), Duration::HOUR);
 
        return $r;
 }
 
 function curweather_network_mod_init(App $a, &$b)
 {
-       if (!intval(PConfig::get(local_user(), 'curweather', 'curweather_enable'))) {
+       if (!intval(DI::pConfig()->get(local_user(), 'curweather', 'curweather_enable'))) {
                return;
        }
 
-       $a->page['htmlhead'] .= '<link rel="stylesheet"  type="text/css" href="' . $a->get_baseurl() . '/addon/curweather/curweather.css' . '" media="all" />' . "\r\n";
+       DI::page()['htmlhead'] .= '<link rel="stylesheet"  type="text/css" href="' . DI::baseUrl()->get() . '/addon/curweather/curweather.css' . '" media="all" />' . "\r\n";
 
        // $rpt value is needed for location
        // $lang will be taken from the browser session to honour user settings
@@ -114,13 +113,13 @@ function curweather_network_mod_init(App $a, &$b)
        // those parameters will be used to get: cloud status, temperature, preassure
        // and relative humidity for display, also the relevent area of the map is
        // linked from lat/log of the reply of OWMp
-       $rpt = PConfig::get(local_user(), 'curweather', 'curweather_loc');
+       $rpt = DI::pConfig()->get(local_user(), 'curweather', 'curweather_loc');
 
        // Set the language to the browsers language or default and use metric units
-       $lang = (!empty($_SESSION['language']) ? $_SESSION['language'] : Config::get('system', 'language'));
-       $units = PConfig::get( local_user(), 'curweather', 'curweather_units');
-       $appid = Config::get('curweather', 'appid');
-       $cachetime = intval(Config::get('curweather', 'cachetime'));
+       $lang = Session::get('language', DI::config()->get('system', 'language'));
+       $units = DI::pConfig()->get( local_user(), 'curweather', 'curweather_units');
+       $appid = DI::config()->get('curweather', 'appid');
+       $cachetime = intval(DI::config()->get('curweather', 'cachetime'));
 
        if ($units === "") {
                $units = 'metric';
@@ -135,32 +134,32 @@ function curweather_network_mod_init(App $a, &$b)
        }
 
        if ($ok) {
-               $t = get_markup_template("widget.tpl", "addon/curweather/" );
-               $curweather = replace_macros ($t, [
-                       '$title' => L10n::t("Current Weather"),
+               $t = Renderer::getMarkupTemplate("widget.tpl", "addon/curweather/" );
+               $curweather = Renderer::replaceMacros($t, [
+                       '$title' => DI::l10n()->t("Current Weather"),
                        '$icon' => ProxyUtils::proxifyUrl('http://openweathermap.org/img/w/'.$res['icon'].'.png'),
                        '$city' => $res['city'],
                        '$lon' => $res['lon'],
                        '$lat' => $res['lat'],
                        '$description' => $res['descripion'],
                        '$temp' => $res['temperature'],
-                       '$relhumidity' => ['caption'=>L10n::t('Relative Humidity'), 'val'=>$res['humidity']],
-                       '$pressure' => ['caption'=>L10n::t('Pressure'), 'val'=>$res['pressure']],
-                       '$wind' => ['caption'=>L10n::t('Wind'), 'val'=> $res['wind']],
-                       '$lastupdate' => L10n::t('Last Updated').': '.$res['update'].'UTC',
-                       '$databy' =>  L10n::t('Data by'),
-                       '$showonmap' => L10n::t('Show on map')
+                       '$relhumidity' => ['caption'=>DI::l10n()->t('Relative Humidity'), 'val'=>$res['humidity']],
+                       '$pressure' => ['caption'=>DI::l10n()->t('Pressure'), 'val'=>$res['pressure']],
+                       '$wind' => ['caption'=>DI::l10n()->t('Wind'), 'val'=> $res['wind']],
+                       '$lastupdate' => DI::l10n()->t('Last Updated').': '.$res['update'].'UTC',
+                       '$databy' =>  DI::l10n()->t('Data by'),
+                       '$showonmap' => DI::l10n()->t('Show on map')
                ]);
        } else {
-               $t = get_markup_template('widget-error.tpl', 'addon/curweather/');
-               $curweather = replace_macros( $t, [
-                       '$problem' => L10n::t('There was a problem accessing the weather data. But have a look'),
+               $t = Renderer::getMarkupTemplate('widget-error.tpl', 'addon/curweather/');
+               $curweather = Renderer::replaceMacros( $t, [
+                       '$problem' => DI::l10n()->t('There was a problem accessing the weather data. But have a look'),
                        '$rpt' => $rpt,
-                       '$atOWM' => L10n::t('at OpenWeatherMap')
+                       '$atOWM' => DI::l10n()->t('at OpenWeatherMap')
                ]);
        }
 
-       $a->page['aside'] = $curweather . $a->page['aside'];
+       DI::page()['aside'] = $curweather . DI::page()['aside'];
 }
 
 function curweather_addon_settings_post(App $a, $post)
@@ -169,11 +168,11 @@ function curweather_addon_settings_post(App $a, $post)
                return;
        }
 
-       PConfig::set(local_user(), 'curweather', 'curweather_loc'   , trim($_POST['curweather_loc']));
-       PConfig::set(local_user(), 'curweather', 'curweather_enable', intval($_POST['curweather_enable']));
-       PConfig::set(local_user(), 'curweather', 'curweather_units' , trim($_POST['curweather_units']));
+       DI::pConfig()->set(local_user(), 'curweather', 'curweather_loc'   , trim($_POST['curweather_loc']));
+       DI::pConfig()->set(local_user(), 'curweather', 'curweather_enable', intval($_POST['curweather_enable']));
+       DI::pConfig()->set(local_user(), 'curweather', 'curweather_units' , trim($_POST['curweather_units']));
 
-       info(L10n::t('Current Weather settings updated.') . EOL);
+       info(DI::l10n()->t('Current Weather settings updated.') . EOL);
 }
 
 function curweather_addon_settings(App $a, &$s)
@@ -183,30 +182,30 @@ function curweather_addon_settings(App $a, &$s)
        }
 
        /* Get the current state of our config variable */
-       $curweather_loc = PConfig::get(local_user(), 'curweather', 'curweather_loc');
-       $curweather_units = PConfig::get(local_user(), 'curweather', 'curweather_units');
-       $appid = Config::get('curweather', 'appid');
+       $curweather_loc = DI::pConfig()->get(local_user(), 'curweather', 'curweather_loc');
+       $curweather_units = DI::pConfig()->get(local_user(), 'curweather', 'curweather_units');
+       $appid = DI::config()->get('curweather', 'appid');
 
        if ($appid == "") {
-               $noappidtext = L10n::t('No APPID found, please contact your admin to obtain one.');
+               $noappidtext = DI::l10n()->t('No APPID found, please contact your admin to obtain one.');
        } else {
                $noappidtext = '';
        }
 
-       $enable = intval(PConfig::get(local_user(), 'curweather', 'curweather_enable'));
+       $enable = intval(DI::pConfig()->get(local_user(), 'curweather', 'curweather_enable'));
        $enable_checked = (($enable) ? ' checked="checked" ' : '');
        
        // load template and replace the macros
-       $t = get_markup_template("settings.tpl", "addon/curweather/" );
+       $t = Renderer::getMarkupTemplate("settings.tpl", "addon/curweather/" );
 
-       $s = replace_macros ($t, [
-               '$submit' => L10n::t('Save Settings'),
-               '$header' => L10n::t('Current Weather').' '.L10n::t('Settings'),
+       $s = Renderer::replaceMacros($t, [
+               '$submit' => DI::l10n()->t('Save Settings'),
+               '$header' => DI::l10n()->t('Current Weather').' '.DI::l10n()->t('Settings'),
                '$noappidtext' => $noappidtext,
-               '$info' => L10n::t('Enter either the name of your location or the zip code.'),
-               '$curweather_loc' => [ 'curweather_loc', L10n::t('Your Location'), $curweather_loc, L10n::t('Identifier of your location (name or zip code), e.g. <em>Berlin,DE</em> or <em>14476,DE</em>.') ],
-               '$curweather_units' => [ 'curweather_units', L10n::t('Units'), $curweather_units, L10n::t('select if the temperature should be displayed in &deg;C or &deg;F'), ['metric'=>'°C', 'imperial'=>'°F']],
-               '$enabled' => [ 'curweather_enable', L10n::t('Show weather data'), $enable, '']
+               '$info' => DI::l10n()->t('Enter either the name of your location or the zip code.'),
+               '$curweather_loc' => [ 'curweather_loc', DI::l10n()->t('Your Location'), $curweather_loc, DI::l10n()->t('Identifier of your location (name or zip code), e.g. <em>Berlin,DE</em> or <em>14476,DE</em>.') ],
+               '$curweather_units' => [ 'curweather_units', DI::l10n()->t('Units'), $curweather_units, DI::l10n()->t('select if the temperature should be displayed in &deg;C or &deg;F'), ['metric'=>'°C', 'imperial'=>'°F']],
+               '$enabled' => [ 'curweather_enable', DI::l10n()->t('Show weather data'), $enable, '']
        ]);
 
        return;
@@ -224,7 +223,7 @@ function curweather_addon_admin_post(App $a)
                Config::set('curweather', 'appid',     trim($_POST['appid']));
                Config::set('curweather', 'cachetime', trim($_POST['cachetime']));
 
-               info(L10n::t('Curweather settings saved.' . PHP_EOL));
+               info(DI::l10n()->t('Curweather settings saved.' . PHP_EOL));
        }
 }
 
@@ -234,25 +233,25 @@ function curweather_addon_admin(App $a, &$o)
                return;
        }
 
-       $appid = Config::get('curweather', 'appid');
-       $cachetime = Config::get('curweather', 'cachetime');
+       $appid = DI::config()->get('curweather', 'appid');
+       $cachetime = DI::config()->get('curweather', 'cachetime');
 
-       $t = get_markup_template("admin.tpl", "addon/curweather/" );
+       $t = Renderer::getMarkupTemplate("admin.tpl", "addon/curweather/" );
 
-       $o = replace_macros ($t, [
-               '$submit' => L10n::t('Save Settings'),
+       $o = Renderer::replaceMacros($t, [
+               '$submit' => DI::l10n()->t('Save Settings'),
                '$cachetime' => [
                        'cachetime',
-                       L10n::t('Caching Interval'),
+                       DI::l10n()->t('Caching Interval'),
                        $cachetime,
-                       L10n::t('For how long should the weather data be cached? Choose according your OpenWeatherMap account type.'), [
-                               '0'    => L10n::t('no cache'),
-                               '300'  => '5 '  . L10n::t('minutes'),
-                               '900'  => '15 ' . L10n::t('minutes'),
-                               '1800' => '30 ' . L10n::t('minutes'),
-                               '3600' => '60 ' . L10n::t('minutes')
+                       DI::l10n()->t('For how long should the weather data be cached? Choose according your OpenWeatherMap account type.'), [
+                               '0'    => DI::l10n()->t('no cache'),
+                               '300'  => '5 '  . DI::l10n()->t('minutes'),
+                               '900'  => '15 ' . DI::l10n()->t('minutes'),
+                               '1800' => '30 ' . DI::l10n()->t('minutes'),
+                               '3600' => '60 ' . DI::l10n()->t('minutes')
                        ]
                ],
-               '$appid' => ['appid', L10n::t('Your APPID'), $appid, L10n::t('Your API key provided by OpenWeatherMap')]
+               '$appid' => ['appid', DI::l10n()->t('Your APPID'), $appid, DI::l10n()->t('Your API key provided by OpenWeatherMap')]
        ]);
 }