X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=catavatar%2Fcatavatar.php;h=69f71ef60e012528da38ba621974ac265674ba1b;hb=39c654da00e63a58b6a930e7d0e555bfb248b44b;hp=20291b5b65226ad0a26a11b96aadf6bc8f4dae0b;hpb=18e43c0138c3ce6776557de385c4e0191831dcc2;p=friendica-addons.git diff --git a/catavatar/catavatar.php b/catavatar/catavatar.php index 20291b5b..69f71ef6 100644 --- a/catavatar/catavatar.php +++ b/catavatar/catavatar.php @@ -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;