]> git.mxchange.org Git - friendica-addons.git/blobdiff - catavatar/catavatar.php
Move Config::get() to DI::config()->get()
[friendica-addons.git] / catavatar / catavatar.php
index 8f812e9b022adb8940edede6556d916ec5add9ac..aac2c0a063e7e074d5dc96bf4ea9cf3210b1dcea 100644 (file)
@@ -5,12 +5,17 @@
  * Version: 1.1
  * Author: Fabio <https://kirgroup.com/profile/fabrixxm>
  */
-use Friendica\Core\Addon;
+
+use Friendica\App;
 use Friendica\Core\Config;
-use Friendica\Core\L10n;
+use Friendica\Core\Hook;
+use Friendica\Core\Logger;
+use Friendica\Core\Renderer;
 use Friendica\Core\Worker;
-use Friendica\Core\PConfig;
-use Friendica\Util\DateTimeFormat;
+use Friendica\Database\DBA;
+use Friendica\DI;
+use Friendica\Model\Contact;
+use Friendica\Model\Photo;
 use Friendica\Network\HTTPException\NotFoundException;
 
 define("CATAVATAR_SIZE", 256);
@@ -20,11 +25,11 @@ 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', 'addon/catavatar/catavatar.php', 'catavatar_lookup');
+       Hook::register('addon_settings', 'addon/catavatar/catavatar.php', 'catavatar_addon_settings');
+       Hook::register('addon_settings_post', 'addon/catavatar/catavatar.php', 'catavatar_addon_settings_post');
 
-       logger('registered catavatar');
+       Logger::log('registered catavatar');
 }
 
 /**
@@ -32,133 +37,112 @@ function catavatar_install()
  */
 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');
+       Hook::unregister('avatar_lookup', 'addon/catavatar/catavatar.php', 'catavatar_lookup');
+       Hook::unregister('addon_settings', 'addon/catavatar/catavatar.php', 'catavatar_addon_settings');
+       Hook::unregister('addon_settings_post', 'addon/catavatar/catavatar.php', 'catavatar_addon_settings_post');
 
-       logger('unregistered catavatar');
+       Logger::log('unregistered catavatar');
 }
 
 /**
  * Cat avatar user settings page
  */
-function catavatar_addon_settings(&$a, &$s)
+function catavatar_addon_settings(App $a, &$s)
 {
        if (!local_user()) {
                return;
        }
 
-       $t = get_markup_template('settings.tpl', 'addon/catavatar/');
-       $s = replace_macros ($t, [
+       $t = Renderer::getMarkupTemplate('settings.tpl', 'addon/catavatar/');
+       $s .= Renderer::replaceMacros($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'),
+               '$usecat' => DI::l10n()->t('Use Cat as Avatar'),
+               '$morecat' => DI::l10n()->t('More Random Cat!'),
+               '$emailcat' => DI::l10n()->t('Reset to email Cat'),
+               '$seed' => DI::pConfig()->get(local_user(), 'catavatar', 'seed', false),
+               '$header' => DI::l10n()->t('Cat Avatar Settings'),
        ]);
 }
 
 /**
  * Cat avatar user settings POST handle
  */
-function catavatar_addon_settings_post(&$a, &$s)
+function catavatar_addon_settings_post(App $a, &$s)
 {
        if (!local_user()) {
                return;
        }
 
        // delete the current cached cat avatar
-       $user = dba::selectFirst('user', ['email'],
-               [
-                       'uid' => $uid,
-                       'blocked' => 0,
-                       'account_expired' => 0,
-                       'account_removed' => 0,
-               ]
-       );
-       $seed = PConfig::get(local_user(), 'catavatar', 'seed', md5(trim(strtolower($user['email']))));
-       $imageurl = preg_replace('/[^A-Za-z0-9\._-]/', '', $seed);
-       $imageurl = substr($imageurl,0,35).'';
-       $cachefile = get_cachefile($imageurl);
-       if ($cachefile != "" && file_exists($cachefile)) {
-               unlink($cachefile);
-       }
+       $condition = ['uid' => local_user(), 'blocked' => false,
+                       'account_expired' => false, 'account_removed' => false];
+       $user = DBA::selectFirst('user', ['email'], $condition);
 
+       $seed = DI::pConfig()->get(local_user(), 'catavatar', 'seed', md5(trim(strtolower($user['email']))));
 
-       if (!empty($_POST['catavatar-usecat'})) {
-               $url = $a->get_baseurl() . '/catavatar/' . local_user();
+       if (!empty($_POST['catavatar-usecat'])) {
+               $url = DI::baseUrl()->get() . '/catavatar/' . local_user() . '?ts=' . time();
 
-               // set the catavatar url as avatar url in contact and default profile
-               // and set profile to 0 to current photo
-               // I'm not sure it's the correct way to do this...
-               $r = dba::update('contact',
-                       ['photo' => $url . '/4', 'thumb' => $url . '/5', 'micro' => $url . '/6', 'avatar-date' => DateTimeFormat::utcNow()],
-                       ['uid' => local_user(), 'self' => 1]
-               );
-               if ($r===false) {
-                       notice(L10n::t('There was an error, the cat ran away.'));
+               $self = DBA::selectFirst('contact', ['id'], ['uid' => local_user(), 'self' => true]);
+               if (!DBA::isResult($self)) {
+                       notice(DI::l10n()->t("The cat hadn't found itself."));
                        return;
                }
 
-               $r = dba::update('profile',
-                       ['photo' => $url . '/4', 'thumb' => $url . '/5'],
-                       ['uid' => local_user(), 'is-default' => 1]
-               );
-               if ($r===false) {
-                       notice(L10n::t('There was an error, the cat ran away.'));
-                       return;
-               }
+               Photo::importProfilePhoto($url, local_user(), $self['id']);
 
-               $r = dba::update('photo',
-                       ['profile' => 0],
-                       ['uid' => local_user(), 'profile' => 1]
-               );
-               if ($r === false) {
-                       notice(L10n::t('There was an error, the cat ran away.'));
+               $condition = ['uid' => local_user(), 'contact-id' => $self['id']];
+               $photo = DBA::selectFirst('photo', ['resource-id'], $condition);
+               if (!DBA::isResult($photo)) {
+                       notice(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' => 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->get_baseurl() . '/profile/' . $a->user['nickname'];
-               if ($url && strlen(Config::get('system','directory'))) {
+               $url = DI::baseUrl()->get() . '/profile/' . $a->user['nickname'];
+               if ($url && strlen(DI::config()->get('system', 'directory'))) {
                        Worker::add(PRIORITY_LOW, 'Directory', $url);
                }
 
                Worker::add(PRIORITY_LOW, 'ProfileUpdate', local_user());
 
-               info(L10n::t('Meow!'));
+               info(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');
        }
 }
 
-
 /**
  * Returns the URL to the cat avatar
  *
  * @param $a array
  * @param &$b array
  */
-function catavatar_lookup($a, &$b)
+function catavatar_lookup(App $a, &$b)
 {
-       $user = dba::selectFirst('user', ['uid'], ['email' => $b['email']]);
-       $url = $a->get_baseurl() . '/catavatar/' . $user['uid'];
+       $user = DBA::selectFirst('user', ['uid'], ['email' => $b['email']]);
+       $url = DI::baseUrl()->get() . '/catavatar/' . $user['uid'];
 
        switch($b['size']) {
-               case 175: $url .= "/4"; break;
+               case 300: $url .= "/4"; break;
                case 80: $url .= "/5"; break;
                case 47: $url .= "/6"; break;
        }
@@ -167,18 +151,15 @@ function catavatar_lookup($a, &$b)
        $b['success'] = true;
 }
 
-
-function catavatar_module(){}
-
+function catavatar_module() {}
 
 /**
  * Returns image for user id
  *
  * @throws NotFoundException
  *
- * @TODO: support sizes
  */
-function catavatar_content($a)
+function catavatar_content(App $a)
 {
        if ($a->argc < 2 || $a->argc > 3) {
                throw new NotFoundException(); // this should be catched on index and show default "not found" page.
@@ -191,37 +172,15 @@ function catavatar_content($a)
                $size = intval($a->argv[2]);
        }
 
-       $user = dba::selectFirst('user', ['email'],
-               [
-                       'uid' => $uid,
-                       'blocked' => 0,
-                       'account_expired' => 0,
-                       'account_removed' => 0,
-               ]
-       );
+       $condition = ['uid' => $uid,
+                       'account_expired' => false, 'account_removed' => false];
+       $user = DBA::selectFirst('user', ['email'], $condition);
 
        if ($user === false) {
                throw new NotFoundException();
        }
 
-       $seed = PConfig::get(local_user(), "catavatar", "seed", md5(trim(strtolower($user['email']))));
-
-       // from cat-avatar-generator.php
-       $imageurl = $seed . "-" . $size;
-       $imageurl = preg_replace('/[^A-Za-z0-9\._-]/', '', $imageurl);
-       $imageurl = substr($imageurl,0,35) . '';
-       $cachefile = get_cachefile($imageurl);
-       $cachetime = 604800; # 1 week (1 day = 86400)
-
-       // Serve from the cache if it is younger than $cachetime
-       if ($cachefile != "" && file_exists($cachefile) && (time() - $cachetime) < filemtime($cachefile)) {
-               header('Pragma: public');
-               header('Cache-Control: max-age=86400');
-               header('Expires: '. gmdate('D, d M Y H:i:s \G\M\T', time() + 86400));
-               header('Content-Type: image/jpg');
-               readfile($cachefile);
-               killme();
-       }
+       $seed = DI::pConfig()->get($uid, "catavatar", "seed", md5(trim(strtolower($user['email']))));
 
        // ...Or start generation
        ob_start();
@@ -229,17 +188,9 @@ function catavatar_content($a)
        // render the picture:
        build_cat($seed, $size);
 
-       // Save/cache the output to a file
-       if ($cachefile != "") {
-               $savedfile = fopen($cachefile, 'w+'); # w+ to be at start of the file, write mode, and attempt to create if not existing.
-               fwrite($savedfile, ob_get_contents());
-               fclose($savedfile);
-               chmod($cachefile, 0755);
-       }
-
        ob_end_flush();
 
-       killme();
+       exit();
 }
 
 
@@ -256,43 +207,53 @@ function catavatar_content($a)
  *
 **/
 
-function build_cat($seed='', $size=0){
-
+function build_cat($seed = '', $size = 0)
+{
        // init random seed
-       if($seed) srand( hexdec(substr(md5($seed),0,6)) );
+       if ($seed) {
+               srand(hexdec(substr(md5($seed), 0, 6)));
+       }
 
        // throw the dice for body parts
        $parts = array(
-               'body' => rand(1,15),
-               'fur' => rand(1,10),
-               'eyes' => rand(1,15),
-               'mouth' => rand(1,10),
-               'accessorie' => rand(1,20)
+               'body' => rand(1, 15),
+               'fur' => rand(1, 10),
+               'eyes' => rand(1, 15),
+               'mouth' => rand(1, 10),
+               'accessorie' => rand(1, 20)
        );
 
        // create backgound
        $cat = @imagecreatetruecolor(CATAVATAR_SIZE, CATAVATAR_SIZE)
                or die("GD image create failed");
        $white = imagecolorallocate($cat, 255, 255, 255);
-       imagefill($cat,0,0,$white);
+       imagefill($cat, 0, 0, $white);
 
        // add parts
-       foreach($parts as $part => $num){
-               $file = dirname(__FILE__).'/avatars/'.$part.'_'.$num.'.png';
+       foreach ($parts as $part => $num) {
+               $file = dirname(__FILE__) . '/avatars/' . $part . '_' . $num . '.png';
 
                $im = @imagecreatefrompng($file);
-               if(!$im) die('Failed to load '.$file);
+               if (!$im) {
+                       die('Failed to load ' . $file);
+               }
                imageSaveAlpha($im, true);
-               imagecopy($cat,$im,0,0,0,0,CATAVATAR_SIZE,CATAVATAR_SIZE);
+               imagecopy($cat, $im, 0, 0, 0, 0, CATAVATAR_SIZE, CATAVATAR_SIZE);
                imagedestroy($im);
        }
 
        // scale image
        if ($size > 3 && $size < 7) {
-               switch($size) {
-                       case 4: $size = 175; break;
-                       case 5: $size = 80; break;
-                       case 6: $size = 48; break;
+               switch ($size) {
+                       case 4:
+                               $size = 300;
+                               break;
+                       case 5:
+                               $size = 80;
+                               break;
+                       case 6:
+                               $size = 48;
+                               break;
                }
 
                $dest = imagecreatetruecolor($size, $size);
@@ -304,14 +265,14 @@ function build_cat($seed='', $size=0){
        }
 
        // restore random seed
-       if($seed) srand();
+       if ($seed) {
+               srand();
+       }
 
        header('Pragma: public');
        header('Cache-Control: max-age=86400');
-       header('Expires: '. gmdate('D, d M Y H:i:s \G\M\T', time() + 86400));
+       header('Expires: ' . gmdate('D, d M Y H:i:s \G\M\T', time() + 86400));
        header('Content-Type: image/jpg');
        imagejpeg($cat, NULL, 90);
        imagedestroy($cat);
 }
-
-