Файл: files/receiver/gifts.php
Строк: 26
<?php
/*
------------------------------------------------
AlphaCMS - универсальный движок для вашего сайта
E-mail администрации проекта: adm@alpha-cms.ru
Официальный сайт поддержки: alpha-cms.ru
Руководитель проекта: adm (ID 1)
------------------------------------------------
*/
require ($_SERVER['DOCUMENT_ROOT'].'/system/connections/core.php');
access('management');
if (isset($_FILES) && ajax() == true) {
//Директория в которую будут загружены файлы
$uploadDir = ROOT."/files/upload/gifts/";
//Останавливаем выгрузку, если нет файлов
if (!isset($_FILES['file']['name'])) { file::error(); }
//Подсчет количества отправляемых файлов
$fileCount = count($_FILES['file']['name']);
//Разрешенные форматы для выгрузки
$ExtList = "jpg,jpeg,png,gif,webp";
//Создание массива из форматов
$AllowFileExt = explode(",", $ExtList);
//Определяем id директории
$id_dir = intval(get('id_dir'));
//Определяем url откуда пришли
$url = url_check_validate(base64_decode(get('url')));
if (db::get_column("SELECT COUNT(*) FROM `GIFTS_DIR` WHERE `ID` = ? LIMIT 1", [$id_dir]) == 0) {
file::error('Неизвестная ошибка');
}
if ($fileCount > config('MAXFILEUPLOAD')) {
file::error(lg('Нельзя загружать более %d файлов за 1 раз', config('MAXFILEUPLOAD')));
}
/*
---------------------
Мультивыгрузка файлов
---------------------
*/
$error = null;
$s = 0;
for ($i = 0; $i < $fileCount; $i++) {
//Размер файла
$FileSize = tabs($_FILES['file']['size'][$i]);
//Оригинальное название файла
$FileNameExt = tabs($_FILES['file']['name'][$i]);
//Оригинальное название файла без расширения
$FileName = tprcs(preg_replace('#.[^.]*$#', null, $FileNameExt));
//Расширение файла без названия
$Ext = strtolower(preg_replace('#^.*.#', null, $FileNameExt));
//Временные файлы
$TempName = $_FILES['file']['tmp_name'][$i];
//Определение ширины и высоты изображения
$xy = getimagesize($TempName);
$width = $xy[0];
$height = $xy[1];
if ($width > 800) {
file::error('<b>'.$FileNameExt.'</b> - '.lg('ширина изображения не может быть больше 800px. Текущая ширина: %dpx', $width));
}elseif ($height > 800) {
file::error('<b>'.$FileNameExt.'</b> - '.lg('высота изображения не может быть больше 800px. Текущая ширина: %dpx', $height));
}elseif ($xy == false) {
file::error('<b>'.$FileNameExt.'</b> - '.lg('это не изображение'));
}elseif (!in_array($Ext, $AllowFileExt)) {
file::error('<b>'.$FileNameExt.'</b> - '.lg('неверный формат изображения. Допустимые форматы: %s', $ExtList));
}elseif (filesize($TempName) > config('MAXFILESIZE')) {
file::error('<b>'.$FileNameExt.'</b> - '.lg('размер превышает установленные ограничения. Размер должен быть не больше %s', size_file(config('MAXFILESIZE'))));
}elseif ($FileSize < 1024) {
file::error('<b>'.$FileNameExt.'</b> - '.lg('слишком маленькое изображение'));
}else{
//Сохраняем файл
if (@copy($TempName, $uploadDir.$FileName.'.'.$Ext)) {
$ID = db::get_add("INSERT INTO `GIFTS` (`ACT`, `ID_DIR`, `EXT`) VALUES (?, ?, ?)", [0, $id_dir, $Ext]);
rename($uploadDir.$FileName.'.'.$Ext, $uploadDir.$ID.'.'.$Ext);
$s++;
}else{
file::error();
}
}
}
/*
--------------------------------
Действия после успешной загрузки
--------------------------------
*/
if ($s > 0) {
file::update($url, '#upload-gifts');
}
}else{
file::error('Не удалось установить соединение с ресивером');
}