]> git.mxchange.org Git - friendica-addons.git/blobdiff - libravatar/libravatar.php
Tumblr: Improved error handling whe fetching blog information
[friendica-addons.git] / libravatar / libravatar.php
index 9a0c9db6fb2e8eaef4a34ac95c79ceae0e8260f7..54594b8899a950c25379829f700de9e816b4457c 100644 (file)
@@ -7,14 +7,12 @@
  */
 
 use Friendica\App;
-use Friendica\BaseModule;
+use Friendica\Core\Addon;
 use Friendica\Core\Hook;
 use Friendica\Core\Logger;
 use Friendica\Core\Renderer;
-use Friendica\Database\DBA;
 use Friendica\DI;
-use Friendica\Util\ConfigFileLoader;
-use Friendica\Util\Strings;
+use Friendica\Core\Config\Util\ConfigFileManager;
 
 /**
  * Installs the addon hook
@@ -23,34 +21,29 @@ function libravatar_install()
 {
        Hook::register('load_config',   'addon/libravatar/libravatar.php', 'libravatar_load_config');
        Hook::register('avatar_lookup', 'addon/libravatar/libravatar.php', 'libravatar_lookup');
-       Logger::log("registered libravatar in avatar_lookup hook");
+       Logger::notice("registered libravatar in avatar_lookup hook");
 }
 
-function libravatar_load_config(App $a, ConfigFileLoader $loader)
+function libravatar_load_config(ConfigFileManager $loader)
 {
-       $a->getConfigCache()->load($loader->loadAddonConfig('libravatar'));
+       DI::app()->getConfigCache()->load($loader->loadAddonConfig('libravatar'), \Friendica\Core\Config\ValueObject\Cache::SOURCE_STATIC);
 }
 
 /**
  * Looks up the avatar at Libravatar and returns the URL.
  *
- * @param $a array
  * @param &$b array
  */
-function libravatar_lookup($a, &$b)
+function libravatar_lookup(array &$b)
 {
        $default_avatar = DI::config()->get('libravatar', 'default_avatar');
-
-       if (! $default_avatar) {
+       if (empty($default_avatar)) {
                // if not set, look up if there was one from the gravatar addon
-               $default_avatar = DI::config()->get('gravatar', 'default_avatar');
-               // setting default avatar if nothing configured
-               if (!$default_avatar) {
-                       $default_avatar = 'identicon'; // default image will be a random pattern
-               }
+               $default_avatar = DI::config()->get('gravatar', 'default_avatar', 'identicon');
        }
 
        require_once 'Services/Libravatar.php';
+
        $libravatar = new Services_Libravatar();
        $libravatar->setSize($b['size']);
        $libravatar->setDefault($default_avatar);
@@ -63,16 +56,11 @@ function libravatar_lookup($a, &$b)
 /**
  * Display admin settings for this addon
  */
-function libravatar_addon_admin(&$a, &$o)
+function libravatar_addon_admin(string &$o)
 {
-       $t = Renderer::getMarkupTemplate("admin.tpl", "addon/libravatar");
-
-       $default_avatar = DI::config()->get('libravatar', 'default_avatar');
+       $t = Renderer::getMarkupTemplate('admin.tpl', 'addon/libravatar');
 
-       // set default values for first configuration
-       if (!$default_avatar) {
-               $default_avatar = 'identicon'; // pseudo-random geometric pattern based on email hash
-       }
+       $default_avatar = DI::config()->get('libravatar', 'default_avatar', 'identicon');
 
        // Available options for the select boxes
        $default_avatars = [
@@ -81,26 +69,15 @@ function libravatar_addon_admin(&$a, &$o)
                'monsterid' => DI::l10n()->t('monster face'),
                'wavatar' => DI::l10n()->t('computer generated face'),
                'retro' => DI::l10n()->t('retro arcade style face'),
+               'robohash' => DI::l10n()->t('roboter face'),
+               'pagan' => DI::l10n()->t('retro adventure game character'),
        ];
 
-       // Show warning if PHP version is too old
-       if (! version_compare(PHP_VERSION, '5.3.0', '>=')) {
-               $o = '<h5>' .DI::l10n()->t('Warning') .'</h5><p>';
-               $o .= DI::l10n()->t('Your PHP version %s is lower than the required PHP >= 5.3.', PHP_VERSION);
-               $o .= '<br>' .DI::l10n()->t('This addon is not functional on your server.') .'<p><br>';
-               return;
-       }
-
-       // Libravatar falls back to gravatar, so show warning about gravatar addon if enabled
-       $r = q("SELECT * FROM `addon` WHERE `name` = '%s' and `installed` = 1",
-               DBA::escape('gravatar')
-       );
-       if (count($r)) {
+       if (Addon::isEnabled('gravatar')) {
                $o = '<h5>' .DI::l10n()->t('Information') .'</h5><p>' .DI::l10n()->t('Gravatar addon is installed. Please disable the Gravatar addon.<br>The Libravatar addon will fall back to Gravatar if nothing was found at Libravatar.') .'</p><br><br>';
        }
 
        // output Libravatar settings
-       $o .= '<input type="hidden" name="form_security_token" value="' . BaseModule::getFormSecurityToken("libravatarsave") .'">';
        $o .= Renderer::replaceMacros( $t, [
                '$submit' => DI::l10n()->t('Save Settings'),
                '$default_avatar' => ['avatar', DI::l10n()->t('Default avatar image'), $default_avatar, DI::l10n()->t('Select default avatar image if none was found. See README'), $default_avatars],
@@ -110,10 +87,7 @@ function libravatar_addon_admin(&$a, &$o)
 /**
  * Save admin settings
  */
-function libravatar_addon_admin_post(&$a)
+function libravatar_addon_admin_post()
 {
-       BaseModule::checkFormSecurityToken('libravatarrsave');
-
-       $default_avatar = (!empty($_POST['avatar']) ? Strings::escapeTags(trim($_POST['avatar'])) : 'identicon');
-       DI::config()->set('libravatar', 'default_avatar', $default_avatar);
+       DI::config()->set('libravatar', 'default_avatar', trim($_POST['avatar'] ?? 'identicon'));
 }