From 2f5fea4f8ce149a807b31d3b2f7dbaf985faaee9 Mon Sep 17 00:00:00 2001 From: Michael Date: Fri, 13 Apr 2018 06:34:16 +0000 Subject: [PATCH 1/5] Catavatar: The profile picture is now stored in a better way --- catavatar/catavatar.php | 44 +++++++++++++++++++---------------------- 1 file changed, 20 insertions(+), 24 deletions(-) diff --git a/catavatar/catavatar.php b/catavatar/catavatar.php index ee5bb567..aaa85972 100644 --- a/catavatar/catavatar.php +++ b/catavatar/catavatar.php @@ -13,6 +13,9 @@ use Friendica\Core\Worker; use Friendica\Core\PConfig; use Friendica\Util\DateTimeFormat; use Friendica\Network\HTTPException\NotFoundException; +use Friendica\Model\Contact; +use Friendica\Model\Photo; +use Friendica\Database\DBM; define("CATAVATAR_SIZE", 256); @@ -92,36 +95,29 @@ function catavatar_addon_settings_post(App $a, &$s) if (!empty($_POST['catavatar-usecat'])) { $url = $a->get_baseurl() . '/catavatar/' . local_user(); - // 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) { + $self = dba::selectFirst('contact', ['id'], ['uid' => local_user(), 'self' => true]); + if (!DBM::is_result($self)) { + notice(L10n::t("The cat hadn't found itself.")); + return; + } + + Photo::importProfilePhoto($url, local_user(), $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.')); 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; - } + dba::update('photo', ['profile' => false], ['profile' => true, 'uid' => local_user()]); - $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.')); - return; - } + $fields = ['profile' => true, 'album' => 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']; From 72b8bc815c0af5bbf0f682b3fffa35ffcc1c602c Mon Sep 17 00:00:00 2001 From: Michael Date: Fri, 13 Apr 2018 08:14:35 +0000 Subject: [PATCH 2/5] And now it really works --- catavatar/catavatar.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/catavatar/catavatar.php b/catavatar/catavatar.php index aaa85972..9c1f2290 100644 --- a/catavatar/catavatar.php +++ b/catavatar/catavatar.php @@ -93,7 +93,7 @@ function catavatar_addon_settings_post(App $a, &$s) if (!empty($_POST['catavatar-usecat'])) { - $url = $a->get_baseurl() . '/catavatar/' . local_user(); + $url = $a->get_baseurl() . '/catavatar/' . local_user() . '?ts=' . time(); $self = dba::selectFirst('contact', ['id'], ['uid' => local_user(), 'self' => true]); if (!DBM::is_result($self)) { @@ -200,7 +200,7 @@ function catavatar_content(App $a) throw new NotFoundException(); } - $seed = PConfig::get(local_user(), "catavatar", "seed", md5(trim(strtolower($user['email'])))); + $seed = PConfig::get($uid, "catavatar", "seed", md5(trim(strtolower($user['email'])))); // from cat-avatar-generator.php $imageurl = $seed . "-" . $size; From ac5db74a8b2379c6156d0227e18556ddea3daa24 Mon Sep 17 00:00:00 2001 From: Michael Date: Fri, 13 Apr 2018 08:31:16 +0000 Subject: [PATCH 3/5] Just some code beautification --- catavatar/catavatar.php | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) diff --git a/catavatar/catavatar.php b/catavatar/catavatar.php index 9c1f2290..10f0093c 100644 --- a/catavatar/catavatar.php +++ b/catavatar/catavatar.php @@ -252,10 +252,12 @@ function catavatar_content(App $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( @@ -273,11 +275,13 @@ function build_cat($seed='', $size=0){ imagefill($cat,0,0,$white); // add parts - foreach($parts as $part => $num){ + 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); imagedestroy($im); @@ -285,10 +289,16 @@ function build_cat($seed='', $size=0){ // 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 = 175; + break; + case 5: + $size = 80; + break; + case 6: + $size = 48; + break; } $dest = imagecreatetruecolor($size, $size); @@ -311,5 +321,3 @@ function build_cat($seed='', $size=0){ imagejpeg($cat, NULL, 90); imagedestroy($cat); } - - From 814edd45411175e03aac12f1faf80bacc9008f85 Mon Sep 17 00:00:00 2001 From: Michael Date: Fri, 13 Apr 2018 09:36:02 +0000 Subject: [PATCH 4/5] Now with changed messages.po --- catavatar/lang/C/messages.po | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/catavatar/lang/C/messages.po b/catavatar/lang/C/messages.po index 17c6a7fa..d22b6a88 100644 --- a/catavatar/lang/C/messages.po +++ b/catavatar/lang/C/messages.po @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: \n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2018-04-06 18:26+0200\n" +"POT-Creation-Date: 2018-04-13 09:35+0000\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" @@ -17,26 +17,34 @@ msgstr "" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: 8bit\n" -#: catavatar.php:57 +#: catavatar.php:60 msgid "Use Cat as Avatar" msgstr "" -#: catavatar.php:58 +#: catavatar.php:61 msgid "More Random Cat!" msgstr "" -#: catavatar.php:59 +#: catavatar.php:62 msgid "Reset to email Cat" msgstr "" -#: catavatar.php:61 +#: catavatar.php:64 msgid "Cat Avatar Settings" msgstr "" -#: catavatar.php:103 catavatar.php:112 catavatar.php:121 +#: catavatar.php:100 +msgid "The cat hadn't found itself." +msgstr "" + +#: catavatar.php:109 msgid "There was an error, the cat ran away." msgstr "" -#: catavatar.php:134 +#: catavatar.php:115 +msgid "Profile Photos" +msgstr "" + +#: catavatar.php:130 msgid "Meow!" msgstr "" From 7f06962bd1595d43d59ee97a0c2b1f25d4619d66 Mon Sep 17 00:00:00 2001 From: Michael Date: Fri, 13 Apr 2018 10:28:25 +0000 Subject: [PATCH 5/5] Standards --- catavatar/catavatar.php | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/catavatar/catavatar.php b/catavatar/catavatar.php index 10f0093c..8b8f780c 100644 --- a/catavatar/catavatar.php +++ b/catavatar/catavatar.php @@ -85,7 +85,7 @@ function catavatar_addon_settings_post(App $a, &$s) ); $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).''; + $imageurl = substr($imageurl, 0, 35) . ''; $cachefile = get_cachefile($imageurl); if ($cachefile != "" && file_exists($cachefile)) { unlink($cachefile); @@ -121,7 +121,7 @@ function catavatar_addon_settings_post(App $a, &$s) // Update global directory in background $url = $a->get_baseurl() . '/profile/' . $a->user['nickname']; - if ($url && strlen(Config::get('system','directory'))) { + if ($url && strlen(Config::get('system', 'directory'))) { Worker::add(PRIORITY_LOW, 'Directory', $url); } @@ -205,7 +205,7 @@ function catavatar_content(App $a) // from cat-avatar-generator.php $imageurl = $seed . "-" . $size; $imageurl = preg_replace('/[^A-Za-z0-9\._-]/', '', $imageurl); - $imageurl = substr($imageurl,0,35) . ''; + $imageurl = substr($imageurl, 0, 35) . ''; $cachefile = get_cachefile($imageurl); $cachetime = 604800; # 1 week (1 day = 86400) @@ -213,7 +213,7 @@ function catavatar_content(App $a) 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('Expires: ' . gmdate('D, d M Y H:i:s \G\M\T', time() + 86400)); header('Content-Type: image/jpg'); readfile($cachefile); exit(); @@ -256,34 +256,34 @@ function build_cat($seed = '', $size = 0) { // init random seed if ($seed) { - srand(hexdec(substr(md5($seed),0,6))); + 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'; + $file = dirname(__FILE__) . '/avatars/' . $part . '_' . $num . '.png'; $im = @imagecreatefrompng($file); if (!$im) { - die('Failed to load '.$file); + 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); } @@ -316,7 +316,7 @@ function build_cat($seed = '', $size = 0) 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);