mylittleforum/includes/avatar.inc.php
2010-03-14 11:37:06 +01:00

172 lines
6.1 KiB
PHP

<?php
if(!defined('IN_INDEX'))
{
header('Location: ../index.php');
exit;
}
// upload folder:
$uploaded_images_path = 'images/avatars/';
if($settings['avatars']>0 && isset($_SESSION[$settings['session_prefix'].'user_id']))
{
if(isset($_GET['delete']))
{
if(file_exists($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.jpg'))
{
@chmod($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.jpg', 0777);
@unlink($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.jpg');
}
if(file_exists($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.png'))
{
@chmod($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.png', 0777);
@unlink($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.png');
}
if(file_exists($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.gif'))
{
@chmod($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.gif', 0777);
@unlink($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.gif');
}
header('Location: index.php?mode=avatar&deleted=true');
exit;
}
if(isset($_FILES['probe']) && $_FILES['probe']['size'] != 0 && !$_FILES['probe']['error'])
{
unset($errors);
$image_info = getimagesize($_FILES['probe']['tmp_name']);
if(!is_array($image_info) || $image_info[2] != 1 && $image_info[2] != 2 && $image_info[2] != 3) $errors[] = 'invalid_file_format';
if(empty($errors))
{
if($_FILES['probe']['size'] > $settings['avatar_max_filesize']*1000 || $image_info[0] > $settings['avatar_max_width'] || $image_info[1] > $settings['avatar_max_height'])
{
#$compression = 10;
$width=$image_info[0];
$height=$image_info[1];
// resize if too large:
if($width != $settings['avatar_max_width'] || $height != $settings['avatar_max_height'])
{
if($width >= $height)
{
$new_width = $settings['avatar_max_width'];
$new_height = intval($height*$new_width/$width);
}
else
{
$new_height = $settings['avatar_max_height'];
$new_width = intval($width*$new_height/$height);
}
#$new_width = $settings['avatar_max_width'];
#$new_height = $settings['avatar_max_height'];
}
else
{
$new_width=$width;
$new_height=$height;
}
$img_tmp_name = uniqid(rand()).'.tmp';
for($compression = 100; $compression>1; $compression=$compression-10)
{
if(!resize_image($_FILES['probe']['tmp_name'], $uploaded_images_path.$img_tmp_name, $new_width, $new_height, $compression))
{
$file_size = $_FILES['probe']['size']; // @filesize($_FILES['probe']['tmp_name']);
break;
}
$file_size = @filesize($uploaded_images_path.$img_tmp_name);
if($image_info[2]!=2 && $file_size > $settings['avatar_max_filesize']*1000) break;
if($file_size <= $settings['avatar_max_filesize']*1000) break;
}
if($file_size > $settings['avatar_max_filesize']*1000)
{
$smarty->assign('width',$image_info[0]);
$smarty->assign('height',$image_info[1]);
$smarty->assign('filesize',number_format($_FILES['probe']['size']/1000,0,',',''));
$smarty->assign('max_width',$settings['avatar_max_width']);
$smarty->assign('max_height',$settings['avatar_max_height']);
$smarty->assign('max_filesize',$settings['avatar_max_filesize']);
$errors[] = 'file_too_large';
}
if(isset($errors))
{
if(file_exists($uploaded_images_path.$img_tmp_name))
{
@chmod($uploaded_images_path.$img_tmp_name, 0777);
@unlink($uploaded_images_path.$img_tmp_name);
}
}
}
}
if(empty($errors))
{
$nr = 0;
switch($image_info[2])
{
case 1: $filename = $_SESSION[$settings['session_prefix'].'user_id'].'.gif'; break;
case 2: $filename = $_SESSION[$settings['session_prefix'].'user_id'].'.jpg'; break;
case 3: $filename = $_SESSION[$settings['session_prefix'].'user_id'].'.png'; break;
}
if(isset($img_tmp_name))
{
@rename($uploaded_images_path.$img_tmp_name, $uploaded_images_path.$filename) or $errors[] = 'upload_error';
$smarty->assign('image_downsized',true);
$smarty->assign('new_width',$new_width);
$smarty->assign('new_height',$new_height);
$smarty->assign('new_filesize',number_format($file_size/1000,0,',',''));
}
else
{
@move_uploaded_file($_FILES['probe']['tmp_name'], $uploaded_images_path.$filename) or $errors[] = 'upload_error';
}
}
if(empty($errors))
{
@chmod($uploaded_images_path.$filename, 0644);
$smarty->assign('avatar_uploaded',true);
}
else
{
$smarty->assign('errors',$errors);
$smarty->assign('form',true);
}
}
if(file_exists($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.jpg'))
{
$avatar = $uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.jpg';
}
elseif(file_exists($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.png'))
{
$avatar = $uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.png';
}
elseif(file_exists($uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.gif'))
{
$avatar = $uploaded_images_path.$_SESSION[$settings['session_prefix'].'user_id'].'.gif';
}
if(isset($avatar))
{
$avatar .= '?u='.uniqid();
$smarty->assign('avatar', $avatar);
}
else $smarty->assign('upload', 'true');
if(isset($_GET['deleted'])) $smarty->assign('avatar_deleted', true);
if(empty($errors) && isset($_FILES['probe']['error']))
{
$smarty->assign('server_max_filesize', ini_get('upload_max_filesize'));
$errors[] = 'upload_error_2';
$smarty->assign('errors',$errors);
}
}
$template = 'avatar.tpl';
?>