Вход Регистрация
Файл: download/add_file.php
Строк: 164
<?php
/**
 * @package     JohnCMS
 * @link        http://johncms.com
 * @copyright   Copyright (C) 2008-2011 JohnCMS Community
 * @license     LICENSE.txt (see attached file)
 * @version     VERSION.txt (see attached file)
 * @author      http://johncms.com/about
 *
 * @var $lng_dl
 */


define('_IN_JOHNCMS'1);
$headmod 'load';
$textl $lng_dl['add_file'];
require_once 
'../incfiles/core.php';
require_once 
'../incfiles/head.php';
require_once 
'functions.php';
$cat intval($_GET['cat']);
$dost db::query("select * from `downpath` where id = '" $cat "';");
$dost mysqli_fetch_array($dost);
echo
'<div class="phdr">'.$lng_dl['add_file'].'</div>';
if(
$dost['dost'] && $user_id 0){
    
    if(!empty(
$ban))
    {
        echo
'<div class="rmenu">'.$lng_dl['you_banned'].'</div>';
        include_once 
'../incfiles/end.php';
    exit; 
    }
    
    

    if (isset(
$_POST['submit'])){
    
///////////////////////////////////////////////
    ////// Обработка отправленного файла //////////
    ///////////////////////////////////////////////
    
    
$error false;
    
    
$fname $_FILES['fail']['name'];
    
$fsize $_FILES['fail']['size'];
    
$scrname $_FILES['screen']['name'];
    
$scrsize $_FILES['screen']['size'];
    
$opis db::escape(trim($_POST['desc']));
    
$name functions::check($_POST['name']);
    
$linkname functions::check($_POST['linkname']);
    
$loaddir $loadroot.'/'.$dost['way'];
    
$scrf pathinfo($scrnamePATHINFO_EXTENSION);
    
//// ^получаем всё что нужно^ //////
    
    //////////// Транслитируем имя файла в пригодное для сохранения в фс ///////
    
$ftp name_replace($name);
    
/////// Определяем тип файла ///////
    
$typ pathinfo($fnamePATHINFO_EXTENSION);
    
//////// Конечное имя файла для сохранения /////////
    
$ftp $ftp.'.'.$typ;
    
    if(
is_file($loaddir.$ftp)) // Если файл существует, дописываем время в имя.
       
$ftp time().$ftp;

    
$ftypes explode(',',$dost['types']);
    
    if(isset(
$opis) && $opis != '')
        
$opis '[b]'.$lng_dl['description'].':[/b] '.$opis;

    if(empty(
$name))
        
$error[] = $lng_dl['empty_filename_to_view'];

    if (!
in_array('all'$ftypes) && !in_array($typ$ftypes))
           
$error[] = str_replace('#FILE_TYPE#'$typ$lng_dl['file_type_not_allowed']);

    
$ftypes = array('jpg''gif''png''jpeg'); // Типы скриншотов. Если нужны другие, пропишите через запятую.
    
    
if ($scrf && !in_array($scrf$ftypes))
           
$error[] = str_replace('#SCREEN_TYPE#'$scrf$lng_dl['screen_type_not_allowed']);

    
$filesize 1024$down_setting['filesize'];
    
////// Проверяем размер файла ///////
    
if ($fsize $filesize)
    {
        
$str_size_error str_replace('#CURRENT_SIZE#'size_convert($fsize), $lng_dl['big_file_size']);
        
$error[] = str_replace('#MAX_SIZE#'size_convert($filesize), $str_size_error);
    }

    
///// Проверяем размер скриншота /////
    
if ($scrsize $filesize)
    {
        
$str_size_error str_replace('#CURRENT_SIZE#'size_convert($scrsize), $lng_dl['big_file_size']);
        
$error[] = str_replace('#MAX_SIZE#'size_convert($filesize), $str_size_error);
    }

    
////// На всякий случай проверяем название файла если не справился фильтр ///////
    
if (preg_match("/[^a-z0-9.()+_-]/i"$ftp))
    {
        
$error[] = str_replace('#FILE_NAME#'$ftp$lng_dl['incorrect_name']);
    }


    if(!
$error){
    
// Сохраняем всё если нет ошибок.
    
if ((move_uploaded_file($_FILES["screen"]["tmp_name"], $filesroot.'/screens/'.$ftp.'.'.$scrf)) == true){
            @
chmod("screens/$ftp.$scrf"0777);
            echo 
'<div class="gmenu">'.$lng_dl['screen_loaded'].'</div>';
        }
    if ((
move_uploaded_file($_FILES["fail"]["tmp_name"], $loaddir.$ftp)) == true){
            @
chmod("$save"0777);
            echo 
"<div class='gmenu'>".$lng_dl['file_loaded']."</div>";
            echo 
"<div class='rmenu'>".$lng_dl['file_to_moderation']."</div>";
            
$name $name.'||||'.$linkname;
            
db::query("INSERT INTO `downfiles` SET
            `pathid` = '" 
$cat "',
            `way` = '"
.$dost['way'].$ftp."',
            `name` = '"
.$name."',
            `desc` = '"
.$opis."',
            `time` = '" 
time() . "',
            `gol` = '',
            `login` = '"
.$login."',
            `user_id` = '"
.$user_id."',
            `status` = 0;"
);
            
$rid mysqli_insert_id();
    if(
$scrf){
    
db::query("INSERT INTO `downscreen` SET
    `fileid` = '"
.$rid."',
    `way` = '"
.$ftp.".".$scrf."';");
    }
    }else{
    echo 
"<div class='rmenu'>".$lng_dl['load_error']."</div>";
    }
    
    }else{
    
// Найдены ошибки. Уведомляем юзера о них.
    
echo functions::display_error($error);
    echo 
'<div class="menu"><a href="add_file.php?cat='.$cat.'">'.$lng_dl['repeat'].'</a></div>';
    include_once 
'../incfiles/end.php';
    exit;    
    }    
    }else{
    
///////////////////////////////////////////////
    ////////////// Форма выбора файла /////////////
    ///////////////////////////////////////////////
    
$set_download unserialize($datauser['set_forum']);
    echo 
'<div class="rmenu">'.$lng_dl['required_fields'].'</div>';
    echo 
'<form name="add_file" action="add_file.php?cat='.$cat.'" method="post" enctype="multipart/form-data">';
    echo
'<div class="menu"><b>*</b> '.$lng_dl['select_file'].':<br/><input type="file" name="fail"/><br/>
    <small>'
.$lng_dl['allowed_types'].' <b>'.$dost['types'].'</b></small></div><div class="menu">
    '
.$lng_dl['select_screen'].' <br/>
    <input type="file" name="screen"/><br/>
    <small>'
.$lng_dl['allowed_types'].' <b>jpg,gif,png</b></small></div><div class="menu">
    <b>*</b> '
.$lng_dl['name_to_view'].'<br/>
    <input type="text" name="name" value=""/></div>
    <div class="menu">
    '
.$lng_dl['link_name'].'<br/>
    <input type="text" name="linkname" value=""/>
    </div>
    <div class="menu"><b>*</b> '
.$lng_dl['description'].':<br />';
    if(!
$is_mobile)
    echo 
bbcode::auto_bb('add_file''desc');
    echo 
'<textarea cols="' $set_user['field_w'] . '" rows="' $set_user['field_h'] . '" name="desc"></textarea>
    </div>'
;
    echo
'<div class="menu"><input type="submit" name="submit" value="'.$lng['save'].'"/></div></form>';
    }
    echo
'<div class="gmenu"><a href="dir_' $cat '.html">'.$lng['back'].'</a></div>';

}else{
    echo
'<div class="rmenu">'.$lng_dl['download_not_available'].'</div>';
}

require_once 
'../incfiles/end.php';
Онлайн: 1
Реклама