Issue 3309: Avatar update should work now
This commit is contained in:
parent
48e3f4f47f
commit
80103f8ad9
|
@ -778,8 +778,7 @@ function guess_image_type($filename, $fromcurl=false) {
|
||||||
* @return array Returns array of the different avatar sizes
|
* @return array Returns array of the different avatar sizes
|
||||||
*/
|
*/
|
||||||
function update_contact_avatar($avatar, $uid, $cid, $force = false) {
|
function update_contact_avatar($avatar, $uid, $cid, $force = false) {
|
||||||
|
$r = q("SELECT `avatar`, `photo`, `thumb`, `micro`, `nurl` FROM `contact` WHERE `id` = %d LIMIT 1", intval($cid));
|
||||||
$r = q("SELECT `avatar`, `photo`, `thumb`, `micro` FROM `contact` WHERE `id` = %d LIMIT 1", intval($cid));
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!dbm::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
|
@ -793,6 +792,15 @@ function update_contact_avatar($avatar, $uid, $cid, $force = false) {
|
||||||
q("UPDATE `contact` SET `avatar` = '%s', `photo` = '%s', `thumb` = '%s', `micro` = '%s', `avatar-date` = '%s' WHERE `id` = %d",
|
q("UPDATE `contact` SET `avatar` = '%s', `photo` = '%s', `thumb` = '%s', `micro` = '%s', `avatar-date` = '%s' WHERE `id` = %d",
|
||||||
dbesc($avatar), dbesc($photos[0]), dbesc($photos[1]), dbesc($photos[2]),
|
dbesc($avatar), dbesc($photos[0]), dbesc($photos[1]), dbesc($photos[2]),
|
||||||
dbesc(datetime_convert()), intval($cid));
|
dbesc(datetime_convert()), intval($cid));
|
||||||
|
|
||||||
|
// Update the public contact (contact id = 0)
|
||||||
|
if ($uid != 0) {
|
||||||
|
$pcontact = dba::select('contact', array('id'), array('nurl' => $r[0]['nurl']), array('limit' => 1));
|
||||||
|
if (dbm::is_result($pcontact)) {
|
||||||
|
update_contact_avatar($avatar, 0, $pcontact['id'], $force);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return $photos;
|
return $photos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -847,9 +855,30 @@ function import_profile_photo($photo, $uid, $cid, $quit_on_error = false) {
|
||||||
$photo_failure = true;
|
$photo_failure = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
$photo = App::get_baseurl() . '/photo/' . $hash . '-4.' . $img->getExt();
|
$suffix = '?ts='.time();
|
||||||
$thumb = App::get_baseurl() . '/photo/' . $hash . '-5.' . $img->getExt();
|
|
||||||
$micro = App::get_baseurl() . '/photo/' . $hash . '-6.' . $img->getExt();
|
$photo = App::get_baseurl() . '/photo/' . $hash . '-4.' . $img->getExt() . $suffix;
|
||||||
|
$thumb = App::get_baseurl() . '/photo/' . $hash . '-5.' . $img->getExt() . $suffix;
|
||||||
|
$micro = App::get_baseurl() . '/photo/' . $hash . '-6.' . $img->getExt() . $suffix;
|
||||||
|
|
||||||
|
// Remove the cached photo
|
||||||
|
$a = get_app();
|
||||||
|
$basepath = $a->get_basepath();
|
||||||
|
|
||||||
|
if (is_dir($basepath."/photo")) {
|
||||||
|
$filename = $basepath.'/photo/'.$hash.'-4.'.$img->getExt();
|
||||||
|
if (file_exists($filename)) {
|
||||||
|
unlink($filename);
|
||||||
|
}
|
||||||
|
$filename = $basepath.'/photo/'.$hash.'-5.'.$img->getExt();
|
||||||
|
if (file_exists($filename)) {
|
||||||
|
unlink($filename);
|
||||||
|
}
|
||||||
|
$filename = $basepath.'/photo/'.$hash.'-6.'.$img->getExt();
|
||||||
|
if (file_exists($filename)) {
|
||||||
|
unlink($filename);
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
$photo_failure = true;
|
$photo_failure = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -307,7 +307,7 @@ function _contact_update_profile($contact_id) {
|
||||||
);
|
);
|
||||||
|
|
||||||
// Update the entry in the contact table
|
// Update the entry in the contact table
|
||||||
update_contact_avatar($data['photo'], local_user(), $contact_id);
|
update_contact_avatar($data['photo'], local_user(), $contact_id, true);
|
||||||
|
|
||||||
// Update the entry in the gcontact table
|
// Update the entry in the gcontact table
|
||||||
update_gcontact_from_probe($data["url"]);
|
update_gcontact_from_probe($data["url"]);
|
||||||
|
|
Loading…
Reference in a new issue