Вход Регистрация
Файл: localhost/modules/reference/edit_reference.php
Строк: 54
<?php

/**
 * @package   Zcore
 * @author     Artem Sokolovsky
 * @url           http://vk.com/x_s_s
 */


// Инклудим ядро

include_once ($_SERVER['DOCUMENT_ROOT']."/lite/core.php"); 


// Только для зарегистрированых

    
$profile->access(true);    

// Выводим шапку

    
$title 'Редактирование';

// Инклудим шапку

include_once (ROOT.'template/head.php');

// Проверяем права

    
if ($user['access'] > && $user['access'] < 3) {    
    
// Ищим статью в базе

    
$queryguest DB :: $dbh -> query("SELECT * FROM `reference` WHERE `id`=? LIMIT 1;", array($id));
    
$act $queryguest -> fetch();    
    
// Только если данная статья существует
    
    
if (!empty($act)) {    

// Антифлуд
    
    
$antiflood DB :: $dbh -> querySingle("SELECT count(*) FROM `reference` WHERE `edit_time`>? AND `id`=?;", array(time()-$config['antiflood_edit'], $act['id']));

// Только если не было изменений в течении $config['antiflood_edit'] секунд
    
    
if (empty($antiflood)) {        
    
// Только если отправлен POST запрос    
    
    
if (isset($_POST['save'])) {    
    
// Проверяем sid    
    
    
if (isset($_POST['sid']) && $system->check($_POST['sid']) == $user['sid']) {

// Обработка названия
    
    
$name $system->check($_POST['name']);        
    
// Обработка описания
    
    
$description $system->check($_POST['description']);    

// Обработка количества символов названия
    
    
if ($system->utf_strlen($name) >= && $system->utf_strlen($name) < 100) {        
    
// Обработка количества символов описания
    
    
if ($system->utf_strlen($description) >= && $system->utf_strlen($description) < 20000) {    

// Выполняем запрос в базу
    
    
DB :: $dbh -> query("UPDATE `reference` SET `name`=?, `description`=?, `edit`=?, `edit_time`=? WHERE `id`=? LIMIT 1;", array($name$description$user['id'], time(), $act['id']));    
    
// Уведомляем

    
$system->redirect("Статья успешно отредактирована""/modules/reference/".$act['id']."");

// Выводим ошибки

    
} else { $system->show("Слишком длинное или короткое описание"); } 
    } else { 
$system->show("Слишком длинное или короткое название"); } 
    } else { 
$system->show("Замечена подозрительная активность, повторите действие"); }     
    } else if (isset(
$_POST['back'])) {
    
header ("Location: /modules/reference/$act[id]");  
    }        
    
// Выводим форму

    
echo '
    <div class="block">
    <form method="post">
    <input type="hidden" name="sid" value="'
.$user['sid'].'" />
    Название: (100 символов) <br />
    <input type="text" name="name" value="'
.$act['name'].'"/> <br />
    Описание: (10000 символов) <br />
    <textarea name="description" class="textarea" />'
.$act['description'].'</textarea> <br />
    </div>
    '
.($act['edit'] > '
    <div class="hide">
    <img class="middle" src="/icons/edit.png">
    Последний раз редактировалось: '
.$system->system_time($act['edit_time']).'
    '
.$profile->login($act['edit']).'
    </div>
    ' 
'').'    
    <div class="block">
    <input type="submit" name="save" value="Сохранить" />
    <input type="submit" name="back" value="Отмена" />
    </form>
    </div>
    '
;
    
// Выводим ошибки

    
} else { $system->show("Не так быстро, подождите немного"); }     
    } else { 
$system->show("Выбранная вами статья не существует"); }     
    } else { 
$system->show("Отказано в доступе"); }     

// Инклудим ноги    
    
include_once (ROOT.'template/foot.php');

?>
Онлайн: 0
Реклама