View file pages/pictures.php

File size: 6.89Kb
<?php
#-----------------------------------------------------#
#          ********* ROTORCMS *********               #
#              Made by  :  VANTUZ                     #
#               E-mail  :  [email protected]         #
#                 Site  :  http://pizdec.ru           #
#             WAP-Site  :  http://visavi.net          #
#                  ICQ  :  36-44-66                   #
#  Вы не имеете право вносить изменения в код скрипта #
#        для его дальнейшего распространения          #
#-----------------------------------------------------#
require_once ('../includes/start.php');
require_once ('../includes/functions.php');
require_once ('../includes/header.php');
include_once ('../themes/header.php');

if (isset($_GET['act'])) {
	$act = check($_GET['act']);
} else {
	$act = 'index';
} 

show_title('site.png', 'Загрузка фотографии');
$config['newtitle'] = 'Загрузка фотографии';

if (is_user()) {
	switch ($act):
	############################################################################################
	##                                    Главная страница                                    ##
	############################################################################################
		case 'index':

			echo '<div class="form">';
			echo '<form action="pictures.php?act=upload&amp;uid='.$_SESSION['token'].'&amp;'.SID.'" method="post" enctype="multipart/form-data">';
			echo 'Прикрепить фото:<br />';
			echo '<input type="file" name="photo" /><br />';
			echo '<input type="submit" value="Загрузить" /></form></div><br />';

			echo 'Разрешается добавлять фотки с расширением jpg, jpeg, gif и png<br />';
			echo 'Весом не более '.formatsize($config['filesize']).' и размером от 100 до '.(int)$config['fileupfoto'].' px<br /><br />';

			echo '<img src="../images/img/back.gif" alt="image" /> <a href="profile.php?'.SID.'">Вернуться</a><br />';
		break;

		############################################################################################
		##                                    Загрузка аватара                                    ##
		############################################################################################
		case 'upload':

			$uid = check($_GET['uid']);

			if ($uid == $_SESSION['token']) {
				if (is_uploaded_file($_FILES['photo']['tmp_name'])) {
					$photoname = check(strtolower($_FILES['photo']['name']));
					$photosize = getimagesize($_FILES['photo']['tmp_name']);
					$ext = strtolower(substr(strrchr($photoname, '.'), 1));

					if ($ext == 'jpg' || $ext == 'jpeg' || $ext == 'gif' || $ext == 'png') {
						if ($_FILES['photo']['size'] > 0 && $_FILES['photo']['size'] <= $config['filesize']) {
							if ($photosize[0] <= $config['fileupfoto'] && $photosize[1] <= $config['fileupfoto'] && $photosize[0] >= 100 && $photosize[1] >= 100) {
								if (is_quarantine($log)) {
									if (is_flood($log)) {

										// ------------------------------------------------------//
										$handle = upload_image($_FILES['photo'], $log);
										if ($handle) {

											//-------- Удаляем старую фотку ----------//
											$userpic = DB::run() -> querySingle("SELECT `users_picture` FROM `users` WHERE `users_login`=? LIMIT 1;", array($log));

											if (!empty($userpic)){
												unlink_image('upload/photos/', $userpic);
												DB::run() -> query("UPDATE `users` SET `users_picture`=? WHERE `users_login`=?;", array('', $log));
											}
											//-------- Удаляем старую фотку ----------//

											$handle -> process(BASEDIR.'upload/photos/');

											if ($handle -> processed) {
												DB::run() -> query("UPDATE `users` SET `users_picture`=? WHERE `users_login`=?;", array($handle -> file_dst_name, $log));

												$handle -> clean();

												$_SESSION['note'] = 'Фотография успешно загружена!';
												redirect("profile.php?".SID);

											} else {
												show_error('Ошибка! '.$handle -> error);
											} 
										} else {
											show_error('Ошибка! Не удалось загрузить изображение!');
										} 
									} else {
										show_error('Антифлуд! Вы слишком часто добавляете фотографии!');
									} 
								} else {
									show_error('Карантин! Вы не можете добавлять фото в течении '.round($config['karantin'] / 3600).' часов!');
								} 
							} else {
								show_error('Ошибка! Размер изображение должен быть от 100 до '.$config['fileupfoto'].'px');
							} 
						} else {
							show_error('Ошибка! Вес изображения должен быть не более '.formatsize($config['filesize']));
						} 
					} else {
						show_error('Ошибка! Недопустимое расширение (Разрешено jpg, jpeg, gif и png)!');
					} 
				} else {
					show_error('Ошибка! Не удалось загрузить фотографию!');
				} 
			} else {
				show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
			} 

			echo '<img src="../images/img/back.gif" alt="image" /> <a href="pictures.php?'.SID.'">Вернуться</a><br />';
		break;

		############################################################################################
		##                                  Удаление фотографии                                   ##
		############################################################################################
		case 'del':

			$uid = check($_GET['uid']);

			if ($uid == $_SESSION['token']) {
				$userpic = DB::run() -> querySingle("SELECT `users_picture` FROM `users` WHERE `users_login`=? LIMIT 1;", array($log));

				if (!empty($userpic)){

					unlink_image('upload/photos/', $userpic);
					DB::run() -> query("UPDATE `users` SET `users_picture`=? WHERE `users_login`=?", array('', $log));

					$_SESSION['note'] = 'Фотография успешно удалена!';
					redirect("profile.php?".SID);
	
				} else {
					show_error('Ошибка! Фотографии для удаления не существует!');
				} 
			} else {
				show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
			} 

			echo '<img src="../images/img/back.gif" alt="image" /> <a href="profile.php?'.SID.'">Вернуться</a><br />';
		break;

	default:
		redirect("pictures.php?".SID);
	endswitch;

} else {
	show_login('Вы не авторизованы, чтобы загружать фотографии, необходимо');
} 

include_once ('../themes/footer.php');
?>