*/
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\DI;
use Friendica\Model\Contact;
use Friendica\Model\Photo;
+use Friendica\Model\Profile;
use Friendica\Network\HTTPException\NotFoundException;
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(App $a, array &$data)
{
if (!local_user()) {
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' => local_user(),
+ '$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(local_user(), 'catavatar', 'seed', false) ? DI::l10n()->t('Reset to email Cat') : null,
+ ],
+ ];
}
/**
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->getBaseURL() . '/catavatar/' . local_user() . '?ts=' . time();
+ $url = DI::baseUrl()->get() . '/catavatar/' . local_user() . '?ts=' . time();
$self = DBA::selectFirst('contact', ['id'], ['uid' => local_user(), 'self' => true]);
if (!DBA::isResult($self)) {
- notice(L10n::t("The cat hadn't found itself."));
+ DI::sysmsg()->addNotice(DI::l10n()->t("The cat hadn't found itself."));
return;
}
$condition = ['uid' => local_user(), 'contact-id' => $self['id']];
$photo = DBA::selectFirst('photo', ['resource-id'], $condition);
if (!DBA::isResult($photo)) {
- notice(L10n::t('There was an error, the cat ran away.'));
+ 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()]);
- $fields = ['profile' => true, 'album' => L10n::t('Profile Photos'), 'contact-id' => 0];
+ $fields = ['profile' => true, 'album' => DI::l10n()->t('Profile Photos'), 'contact-id' => 0];
DBA::update('photo', $fields, ['uid' => local_user(), 'resource-id' => $photo['resource-id']]);
Photo::importProfilePhoto($url, local_user(), $self['id']);
Contact::updateSelfFromUserID(local_user(), true);
// Update global directory in background
- $url = $a->getBaseURL() . '/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(local_user());
- 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(local_user(), 'catavatar', 'seed', time());
}
if (!empty($_POST['catavatar-emailcat'])) {
- PConfig::delete(local_user(), 'catavatar', 'seed');
+ DI::pConfig()->delete(local_user(), 'catavatar', 'seed');
}
}
* @param $a array
* @param &$b array
*/
-function catavatar_lookup(App $a, &$b)
+function catavatar_lookup(App $a, array &$b)
{
$user = DBA::selectFirst('user', ['uid'], ['email' => $b['email']]);
- $url = $a->getBaseURL() . '/catavatar/' . $user['uid'];
+ 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() {}
/**
*/
function catavatar_content(App $a)
{
- 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,
- '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();
exit();
}
-
-
/**
* ====================
* CAT-AVATAR-GENERATOR
if ($size > 3 && $size < 7) {
switch ($size) {
case 4:
- $size = 175;
+ $size = 300;
break;
case 5:
$size = 80;