View file forum/forum.php

File size: 11.31Kb
<?php

require_once('../includes/start.php');
require_once('../includes/functions.php');
require_once('../includes/header.php');
include_once ("../themes/".$config['themes']."/verh.dat");
$act = (isset($_GET['act'])) ? check($_GET['act']) : 'index';
$start = (isset($_GET['start'])) ? abs(intval($_GET['start'])) : 0;
$fid = (isset($_GET['fid'])) ? abs(intval($_GET['fid'])) : 0;

switch ($act):
    ############################################################################################
    ##                             Вывод перечня тем в категории                              ##
    ############################################################################################
    case "index":
        $forum = search_string(DATADIR . "dataforum/mainforum.dat", $fid, 0);
        if ($forum) {
            $config['newtitle'] = $forum[1];
            $total = counter_string(DATADIR . "dataforum/topic$fid.dat");
			echo'Все записи безвременно актуальны.<br>';
            echo'<a href="index.php">Дневник</a>';
            if (is_admin()) {
				echo' / <a href="forum.php?act=new&amp;fid=' . $fid . '">Новая тема</a>';
                echo' / <a href="' . ADMINDIR . 'forum.php?act=forum&amp;fid=' . $fid . '&amp;start=' . $start . '">Управление</a>';
            }
            echo'<br><br><h1>' . $forum[1] . '</h1> (' . $total . ' тем.)<hr>';
            if ($total > 0) {
                $files = file(DATADIR . "dataforum/topic$fid.dat");
                $files = array_reverse($files);
                // Выводим сперва закрепленные темы
                $fixed = [];
                foreach ($files as $key => $value) {
                    $data = explode("|", $value);
                    if (! empty($data[5])) {
                        unset($files[$key]);
                        $fixed[] = $value;
                    }
                }
                $files = array_merge($fixed, $files);
                //-------------------------------//
                if ($start < 0 || $start >= $total) {
                    $start = 0;
                }
                if ($total < $start + $config['forumtem']) {
                    $end = $total;
                } else {
                    $end = $start + $config['forumtem'];
                }
                for ($i = $start; $i < $end; $i++) {
                    $data = explode("|", $files[$i]);
                    if ($data[5] == 1) {
                    } elseif ($data[6] == 1) {
                    } else {
                    }
                    $totalpost = counter_string(DATADIR . 'dataforum/' . $fid . '-' . $data[0] . '.dat');
                    echo'<div class="b">';
                    echo'<a href="topic.php?fid=' . $fid . '&amp;id=' . $data[0] . '">' . $data[3] . '</a> (' . $totalpost . ')</div>';
                    if ($totalpost > 0) {
                        $filepost = file(DATADIR . 'dataforum/' . $fid . '-' . $data[0] . '.dat');
                        $datapost = explode("|", end($filepost));
                        $lastpage = ceil($totalpost / $config['forumpost']) * $config['forumpost'] - $config['forumpost'];
                        echo'<div>';
                        //forum_navigation('topic.php?fid=' . $datapost[1] . '&amp;id=' . $datapost[0] . '&amp;', $config['forumpost'], $totalpost);
                        echo'<small>(' . date_fixed($datapost[5]) . ') </small>';
						echo'</div>';
                    } else {
                        echo'Тема пустая! Сообщений еще нет!';
                    }
                }
                page_strnavigation('forum.php?fid=' . $fid . '&amp;', $config['forumtem'], $start, $total);
            } else {
                show_error('Раздел пустой! Темы еще не созданы!');
            }
        } else {
            show_error('Ошибка! Данного раздела не существует!');
        }
        echo'<a href="index.php">Вернуться</a><br>';
        break;


    ############################################################################################
    ##                           Подготовка к созданию новой темы                             ##
    ############################################################################################
    case 'new':
        $config['newtitle'] = 'Создание новой темы';
        if (is_user()) {
            $forums = file(DATADIR . "dataforum/mainforum.dat");
            if (count($forums) > 0) {
                echo'<div class="form">';
                echo'<form action="forum.php?act=create&amp;fid=' . $fid . '&amp;uid=' . $_SESSION['token'] . '" method="post">';
                echo'Раздел:<br>';
                echo'<select name="fid">';
                foreach ($forums as $data) {
                    $data = explode("|", $data);
                    $selected = ($fid == $data[0]) ? ' selected="selected"' : '';
                    echo'<option value="' . $data[0] . '"' . $selected . '>' . $data[1] . '</option>';
                }
                echo'</select><br>';
                echo'Заголовок:<br>';
                echo'<input type="text" name="title" size="50" maxlength="50"><br>';
                echo'Сообщение:<br>';
                echo'<textarea cols="15" rows="10" name="msg" id="msg"></textarea><br>';
                echo'<input value="Создать тему" type="submit"></form></div><br>';
            } else {
                show_error('Разделы Дневника еще не созданы!');
            }
        } else {
            show_login('');
        }
        echo'<a href="forum.php?fid=' . $fid . '">Вернуться</a><br>';
        break;

    ############################################################################################
    ##                                  Создание новой темы                                   ##
    ############################################################################################
    case 'create':
        $config['newtitle'] = 'Создание новой темы';
        $uid = check($_GET['uid']);
        $fid = abs(intval($_POST['fid']));
        $forum = search_string(DATADIR . "dataforum/mainforum.dat", $fid, 0);
        if ($forum) {
            if (is_user()) {
                if ($uid == $_SESSION['token']) {
                    $title = check($_POST['title']);
                    $msg = check($_POST['msg']);
                    if (is_flood($log)) {
                        if (is_quarantine($log)) {
                            if (utf_strlen(trim($title)) >= 5 && utf_strlen($title) <= 50) {
                                if (utf_strlen(trim($msg)) >= 5 && utf_strlen($msg) <= 3000) {
                                    statistics(1);
                                    statistics(2);
                                    $title = no_br($title);
                                    $title = antimat($title);
                                    $msg = no_br($msg, '<br>');
                                    $msg = antimat($msg);
                                    $msg = smiles($msg);
                                    $id = unifile(DATADIR . "dataforum/topic$fid.dat", 0);
                                    // Создание темы в списке тем
                                    $text = $id . '|' . $fid . '|' . $log . '|' . $title . '|' . SITETIME . '|0|0|';
                                    write_files(DATADIR . "dataforum/topic$fid.dat", "$text\r\n", 0, 0666);
                                    // Создание файла темы и запись сообщения
                                    $topictext = $id . '|' . $fid . '|' . $log . '|' . $msg . '|' . $brow . ', ' . $ip . '|' . SITETIME . '|';
                                    write_files(DATADIR . 'dataforum/' . $fid . '-' . $id . '.dat', "$topictext\r\n", 1, 0666);
                                    // Обновление mainforum
                                    $maintext = $forum[0] . '|' . $forum[1] . '|' . ($forum[2] + 1) . '|' . ($forum[3] + 1) . '|';
                                    replace_lines(DATADIR . "dataforum/mainforum.dat", $forum['line'], $maintext);
                                    //Удаление старых тем
                                    $file = file(DATADIR . "dataforum/topic$fid.dat");
                                    if (count($file) > $config['topforum']) {
                                        foreach ($file as $key => $value) {
                                            $data = explode("|", $value);
                                            if (empty($data[5])) { // если тема не закреплена
                                                if (file_exists(DATADIR . 'dataforum/' . $fid . '-' . $data[0] . '.dat')) {
                                                    unlink(DATADIR . 'dataforum/' . $fid . '-' . $data[0] . '.dat');
                                                }
                                                unset($file[$key]);
                                                file_put_contents(DATADIR . "dataforum/topic$fid.dat", $file, LOCK_EX);
                                                break;
                                            }
                                        }
                                    }
                                    change_profil($log, [8 => $udata[8] + 1, 14 => $ip, 36 => $udata[36] + 1, 41 => $udata[41] + 1]);
                                    $_SESSION['note'] = 'Тема успешно создана!';
                                    redirect("topic.php?fid=$fid&id=$id");
                                } else {
                                    show_error('Слишком длинный или короткий текст сообщения (Необходимо от 5 до 3000 символов)');
                                }
                            } else {
                                show_error('Слишком длинный или короткий заголовок (Необходимо от 5 до 50 символов)');
                            }
                        } else {
                            show_error('Карантин! Вы не можете писать в течении ' . round($config['karantin'] / 3600) . ' часов!');
                        }
                    } else {
                        show_error('Антифлуд! Разрешается отправлять сообщения раз в ' . flood_period() . ' секунд!');
                    }
                } else {
                    show_error('Ошибка! Неверный идентификатор сессии, повторите действие!');
                }
            } else {
                show_login('');
            }
        } else {
            show_error('Ошибка! Даннго раздела для создании темы не существует!');
        }
        echo' <a href="forum.php?act=new&amp;fid=' . $fid . '">Вернуться</a><br>';
        break;
    default:
        redirect('index.php');
endswitch;
echo'<a href="search.php">Поиск</a><br>';
echo'<a href="/index.php"></a><br>';

include_once ("../themes/".$config['themes']."/niz.dat");

?>