]> git.mxchange.org Git - friendica-addons.git/blobdiff - catavatar/catavatar.php
[various] Remove App dependency from hook functions
[friendica-addons.git] / catavatar / catavatar.php
index 20291b5b65226ad0a26a11b96aadf6bc8f4dae0b..69f71ef60e012528da38ba621974ac265674ba1b 100644 (file)
@@ -7,15 +7,15 @@
  */
 
 use Friendica\App;
-use Friendica\Core\Addon;
-use Friendica\Core\Config;
-use Friendica\Core\L10n;
-use Friendica\Core\PConfig;
+use Friendica\Core\Hook;
+use Friendica\Core\Logger;
+use Friendica\Core\Renderer;
 use Friendica\Core\Worker;
-use Friendica\Database\dba;
-use Friendica\Database\DBM;
+use Friendica\Database\DBA;
+use Friendica\DI;
 use Friendica\Model\Contact;
 use Friendica\Model\Photo;
+use Friendica\Model\Profile;
 use Friendica\Network\HTTPException\NotFoundException;
 
 define("CATAVATAR_SIZE", 256);
@@ -25,132 +25,122 @@ define("CATAVATAR_SIZE", 256);
  */
 function catavatar_install()
 {
-       Addon::registerHook('avatar_lookup', 'addon/catavatar/catavatar.php', 'catavatar_lookup');
-       Addon::registerHook('addon_settings', 'addon/catavatar/catavatar.php', 'catavatar_addon_settings');
-       Addon::registerHook('addon_settings_post', 'addon/catavatar/catavatar.php', 'catavatar_addon_settings_post');
+       Hook::register('avatar_lookup', __FILE__, 'catavatar_lookup');
+       Hook::register('addon_settings', __FILE__, 'catavatar_addon_settings');
+       Hook::register('addon_settings_post', __FILE__, 'catavatar_addon_settings_post');
 
-       logger('registered catavatar');
-}
-
-/**
- * Removes the addon hook
- */
-function catavatar_uninstall()
-{
-       Addon::unregisterHook('avatar_lookup', 'addon/catavatar/catavatar.php', 'catavatar_lookup');
-       Addon::unregisterHook('addon_settings', 'addon/catavatar/catavatar.php', 'catavatar_addon_settings');
-       Addon::unregisterHook('addon_settings_post', 'addon/catavatar/catavatar.php', 'catavatar_addon_settings_post');
-
-       logger('unregistered catavatar');
+       Logger::notice('registered catavatar');
 }
 
 /**
  * Cat avatar user settings page
  */
-function catavatar_addon_settings(App $a, &$s)
+function catavatar_addon_settings(array &$data)
 {
-       if (!local_user()) {
+       if (!DI::userSession()->getLocalUserId()) {
                return;
        }
 
-       $t = get_markup_template('settings.tpl', 'addon/catavatar/');
-       $s .= replace_macros ($t, [
-               '$postpost' => !empty($_POST['catavatar-morecat']) || !empty($_POST['catavatar-emailcat']),
-               '$uncache' => time(),
-               '$uid' => local_user(),
-               '$usecat' => L10n::t('Use Cat as Avatar'),
-               '$morecat' => L10n::t('More Random Cat!'),
-               '$emailcat' => L10n::t('Reset to email Cat'),
-               '$seed' => PConfig::get(local_user(), 'catavatar', 'seed', false),
-               '$header' => L10n::t('Cat Avatar Settings'),
+       $t    = Renderer::getMarkupTemplate('settings.tpl', 'addon/catavatar/');
+       $html = Renderer::replaceMacros($t, [
+               '$uncache'      => time(),
+               '$uid'          => DI::userSession()->getLocalUserId(),
+               '$setrandomize' => DI::l10n()->t('Set default profile avatar or randomize the cat.'),
        ]);
+
+       $data = [
+               'addon'  => 'catavar',
+               'title'  => DI::l10n()->t('Cat Avatar Settings'),
+               'html'   => $html,
+               'submit' => [
+                       'catavatar-usecat'   => DI::l10n()->t('Use Cat as Avatar'),
+                       'catavatar-morecat'  => DI::l10n()->t('Another random Cat!'),
+                       'catavatar-emailcat' => DI::pConfig()->get(DI::userSession()->getLocalUserId(), 'catavatar', 'seed', false) ? DI::l10n()->t('Reset to email Cat') : null,
+               ],
+       ];
 }
 
 /**
  * Cat avatar user settings POST handle
  */
-function catavatar_addon_settings_post(App $a, &$s)
+function catavatar_addon_settings_post(&$s)
 {
-       if (!local_user()) {
+       if (!DI::userSession()->getLocalUserId()) {
                return;
        }
 
-       // delete the current cached cat avatar
-       $condition = ['uid' => local_user(), 'blocked' => false,
-                       'account_expired' => false, 'account_removed' => false];
-       $user = dba::selectFirst('user', ['email'], $condition);
-
-       $seed = PConfig::get(local_user(), 'catavatar', 'seed', md5(trim(strtolower($user['email']))));
-
        if (!empty($_POST['catavatar-usecat'])) {
-               $url = $a->get_baseurl() . '/catavatar/' . local_user() . '?ts=' . time();
+               $url = DI::baseUrl()->get() . '/catavatar/' . DI::userSession()->getLocalUserId() . '?ts=' . time();
 
-               $self = dba::selectFirst('contact', ['id'], ['uid' => local_user(), 'self' => true]);
-               if (!DBM::is_result($self)) {
-                       notice(L10n::t("The cat hadn't found itself."));
+               $self = DBA::selectFirst('contact', ['id'], ['uid' => DI::userSession()->getLocalUserId(), 'self' => true]);
+               if (!DBA::isResult($self)) {
+                       DI::sysmsg()->addNotice(DI::l10n()->t("The cat hadn't found itself."));
                        return;
                }
 
-               Photo::importProfilePhoto($url, local_user(), $self['id']);
+               Photo::importProfilePhoto($url, DI::userSession()->getLocalUserId(), $self['id']);
 
-               $condition = ['uid' => local_user(), 'contact-id' => $self['id']];
-               $photo = dba::selectFirst('photo', ['resource-id'], $condition);
-               if (!DBM::is_result($photo)) {
-                       notice(L10n::t('There was an error, the cat ran away.'));
+               $condition = ['uid' => DI::userSession()->getLocalUserId(), 'contact-id' => $self['id']];
+               $photo = DBA::selectFirst('photo', ['resource-id'], $condition);
+               if (!DBA::isResult($photo)) {
+                       DI::sysmsg()->addNotice(DI::l10n()->t('There was an error, the cat ran away.'));
                        return;
                }
 
-               dba::update('photo', ['profile' => false], ['profile' => true, 'uid' => local_user()]);
+               DBA::update('photo', ['profile' => false], ['profile' => true, 'uid' => DI::userSession()->getLocalUserId()]);
 
-               $fields = ['profile' => true, 'album' => L10n::t('Profile Photos'), 'contact-id' => 0];
-               dba::update('photo', $fields, ['uid' => local_user(), 'resource-id' => $photo['resource-id']]);
+               $fields = ['profile' => true, 'album' => DI::l10n()->t('Profile Photos'), 'contact-id' => 0];
+               DBA::update('photo', $fields, ['uid' => DI::userSession()->getLocalUserId(), 'resource-id' => $photo['resource-id']]);
 
-               Photo::importProfilePhoto($url, local_user(), $self['id']);
+               Photo::importProfilePhoto($url, DI::userSession()->getLocalUserId(), $self['id']);
 
-               Contact::updateSelfFromUserID(local_user(), true);
+               Contact::updateSelfFromUserID(DI::userSession()->getLocalUserId(), true);
 
                // Update global directory in background
-               $url = $a->get_baseurl() . '/profile/' . $a->user['nickname'];
-               if ($url && strlen(Config::get('system', 'directory'))) {
-                       Worker::add(PRIORITY_LOW, 'Directory', $url);
-               }
-
-               Worker::add(PRIORITY_LOW, 'ProfileUpdate', local_user());
+               Profile::publishUpdate(DI::userSession()->getLocalUserId());
 
-               info(L10n::t('Meow!'));
+               DI::sysmsg()->addInfo(DI::l10n()->t('Meow!'));
                return;
        }
 
        if (!empty($_POST['catavatar-morecat'])) {
-               PConfig::set(local_user(), 'catavatar', 'seed', time());
+               DI::pConfig()->set(DI::userSession()->getLocalUserId(), 'catavatar', 'seed', time());
        }
 
        if (!empty($_POST['catavatar-emailcat'])) {
-               PConfig::delete(local_user(), 'catavatar', 'seed');
+               DI::pConfig()->delete(DI::userSession()->getLocalUserId(), 'catavatar', 'seed');
        }
 }
 
 /**
  * Returns the URL to the cat avatar
  *
- * @param $a array
  * @param &$b array
  */
-function catavatar_lookup(App $a, &$b)
+function catavatar_lookup(array &$b)
 {
-       $user = dba::selectFirst('user', ['uid'], ['email' => $b['email']]);
-       $url = $a->get_baseurl() . '/catavatar/' . $user['uid'];
+       $user = DBA::selectFirst('user', ['uid'], ['email' => $b['email']]);
+       if (DBA::isResult($user)) {
+               $url = DI::baseUrl()->get() . '/catavatar/' . $user['uid'];
+       } else {
+               $url = DI::baseUrl()->get() . '/catavatar/' . md5(trim(strtolower($b['email'])));
+       }
 
        switch($b['size']) {
-               case 175: $url .= "/4"; break;
+               case 300: $url .= "/4"; break;
                case 80: $url .= "/5"; break;
-               case 47: $url .= "/6"; break;
+               case 48: $url .= "/6"; break;
        }
 
        $b['url'] = $url;
        $b['success'] = true;
 }
 
+/**
+ * This is a statement rather than an actual function definition. The simple
+ * existence of this method is checked to figure out if the addon offers a
+ * module.
+ */
 function catavatar_module() {}
 
 /**
@@ -159,28 +149,33 @@ function catavatar_module() {}
  * @throws NotFoundException
  *
  */
-function catavatar_content(App $a)
+function catavatar_content()
 {
-       if ($a->argc < 2 || $a->argc > 3) {
+       if (DI::args()->getArgc() < 2 || DI::args()->getArgc() > 3) {
                throw new NotFoundException(); // this should be catched on index and show default "not found" page.
        }
 
-       $uid = intval($a->argv[1]);
-
-       $size = 0;
-       if ($a->argc == 3) {
-               $size = intval($a->argv[2]);
-       }
+       if (is_numeric(DI::args()->getArgv()[1])) {
+               $uid = intval(DI::args()->getArgv()[1]);
+               $condition = ['uid' => $uid,
+                               'account_expired' => false, 'account_removed' => false];
+               $user = DBA::selectFirst('user', ['email'], $condition);
 
-       $condition = ['uid' => $uid, 'blocked' => false,
-                       'account_expired' => false, 'account_removed' => false];
-       $user = dba::selectFirst('user', ['email'], $condition);
+               if ($user === false) {
+                       throw new NotFoundException();
+               }
 
-       if ($user === false) {
+               $seed = DI::pConfig()->get($uid, "catavatar", "seed", md5(trim(strtolower($user['email']))));
+       } elseif (!empty(DI::args()->getArgv()[1])) {
+               $seed = DI::args()->getArgv()[1];
+       } else {
                throw new NotFoundException();
        }
 
-       $seed = PConfig::get($uid, "catavatar", "seed", md5(trim(strtolower($user['email']))));
+       $size = 0;
+       if (DI::args()->getArgc() == 3) {
+               $size = intval(DI::args()->getArgv()[2]);
+       }
 
        // ...Or start generation
        ob_start();
@@ -193,8 +188,6 @@ function catavatar_content(App $a)
        exit();
 }
 
-
-
 /**
  * ====================
  * CAT-AVATAR-GENERATOR
@@ -246,7 +239,7 @@ function build_cat($seed = '', $size = 0)
        if ($size > 3 && $size < 7) {
                switch ($size) {
                        case 4:
-                               $size = 175;
+                               $size = 300;
                                break;
                        case 5:
                                $size = 80;