/Quản lý website đọc truyện online PHP/forum/includes/files.php
PHP | 181 lines | 147 code | 4 blank | 30 comment | 25 complexity | e811aa48592b0cbe58de212e1bb67e8f MD5 | raw file
- <?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
- */
- defined('_IN_JOHNCMS') or die('Error: restricted access');
- $headmod = 'forumfiles';
- require('../incfiles/head.php');
- $types = array(
- 1 => $lng_forum['files_type_win'],
- 2 => $lng_forum['files_type_java'],
- 3 => $lng_forum['files_type_sis'],
- 4 => $lng_forum['files_type_txt'],
- 5 => $lng_forum['files_type_pic'],
- 6 => $lng_forum['files_type_arc'],
- 7 => $lng_forum['files_type_video'],
- 8 => $lng_forum['files_type_audio'],
- 9 => $lng_forum['files_type_other']
- );
- $new = time() - 86400; // Сколько времени файлы считать новыми?
- /*
- -----------------------------------------------------------------
- Получаем ID раздела и подготавливаем запрос
- -----------------------------------------------------------------
- */
- $c = abs(intval($_GET['c'])); // ID раздела
- $s = abs(intval($_GET['s'])); // ID подраздела
- $t = abs(intval($_GET['t'])); // ID топика
- $do = isset($_GET['do']) && intval($_GET['do']) > 0 && intval($_GET['do']) < 10 ? intval($_GET['do']) : 0;
- if ($c) {
- $id = $c;
- $lnk = '&c=' . $c;
- $sql = " AND `cat` = '" . $c . "'";
- $caption = '<b>' . $lng_forum['files_category'] . '</b>: ';
- $input = '<input type="hidden" name="c" value="' . $c . '"/>';
- } elseif ($s) {
- $id = $s;
- $lnk = '&s=' . $s;
- $sql = " AND `subcat` = '" . $s . "'";
- $caption = '<b>' . $lng_forum['files_section'] . '</b>: ';
- $input = '<input type="hidden" name="s" value="' . $s . '"/>';
- } elseif ($t) {
- $id = $t;
- $lnk = '&t=' . $t;
- $sql = " AND `topic` = '" . $t . "'";
- $caption = '<b>' . $lng_forum['files_topic'] . '</b>: ';
- $input = '<input type="hidden" name="t" value="' . $t . '"/>';
- } else {
- $id = false;
- $sql = '';
- $lnk = '';
- $caption = '<b>' . $lng_forum['files_forum'] . '</b>';
- $input = '';
- }
- if ($c || $s || $t) {
- // Получаем имя нужной категории форума
- $req = mysql_query("SELECT `text` FROM `forum` WHERE `website` = '$website' AND `id` = '$id'");
- if (mysql_num_rows($req) > 0) {
- $res = mysql_fetch_assoc($req);
- $caption .= $res['text'];
- } else {
- echo functions::display_error($lng['error_wrong_data'], '<a href="index.php">' . $lng['to_forum'] . '</a>');
- require('../incfiles/end.php');
- exit;
- }
- }
- if ($do || isset($_GET['new'])) {
- /*
- -----------------------------------------------------------------
- Выводим список файлов нужного раздела
- -----------------------------------------------------------------
- */
- $total = mysql_result(mysql_query("SELECT COUNT(*) FROM `cms_forum_files` WHERE `website` = '$website' AND " . (isset($_GET['new'])
- ? " `time` > '$new'" : " `filetype` = '$do'") . $sql), 0);
- if ($total > 0) {
- // Заголовок раздела
- echo '<div class="phdr">' . $caption . (isset($_GET['new']) ? '<br />' . $lng['new_files']
- : '') . '</div>' . ($do ? '<div class="bmenu">' . $types[$do] . '</div>' : '');
- $req = mysql_query("SELECT `cms_forum_files`.*, `forum`.`user_id`, `forum`.`text`, `topicname`.`text` AS `topicname`
- FROM `cms_forum_files`
- LEFT JOIN `forum` ON `cms_forum_files`.`post` = `forum`.`id`
- LEFT JOIN `forum` AS `topicname` ON `cms_forum_files`.`topic` = `topicname`.`id`
- WHERE `forum`.`website` = '$website' AND " . (isset($_GET['new']) ? " `cms_forum_files`.`time` > '$new'" : " `filetype` = '$do'") . ($rights >= 7
- ? '' : " AND `del` != '1'") . $sql .
- "ORDER BY `time` DESC LIMIT $start,$kmess");
- while ($res = mysql_fetch_assoc($req)) {
- $req_u = mysql_query("SELECT `id`, `name`, `sex`, `rights`, `lastdate`, `status`, `datereg`, `ip`, `browser` FROM `users` WHERE `website` = '$website' AND `id` = '" . $res['user_id'] . "'");
- $res_u = mysql_fetch_assoc($req_u);
- echo $i % 2 ? '<div class="list2">' : '<div class="list1">';
- // Выводим текст поста
- $text = mb_substr($res['text'], 0, 500);
- $text = functions::checkout($text, 1, 0);
- $text = preg_replace('#\[c\](.*?)\[/c\]#si', '', $text);
- $page = ceil(mysql_result(mysql_query("SELECT COUNT(*) FROM `forum` WHERE `website` = '$website' AND `refid` = '" . $res['topic'] . "' AND `id` " . ($set_forum['upfp']
- ? ">=" : "<=") . " '" . $res['post'] . "'"), 0) / $kmess);
- $text = '<b><a href="index.php?id=' . $res['topic'] . '&page=' . $page . '">' . $res['topicname'] . '</a></b><br />' . $text;
- if (mb_strlen($res['text']) > 500)
- $text .= '<br /><a href="index.php?act=post&id=' . $res['post'] . '">' . $lng_forum['read_all'] . ' >></a>';
- // Формируем ссылку на файл
- $fls = @filesize('../files/forum/attach/' . $res['filename']);
- $fls = round($fls / 1024, 0);
- $att_ext = strtolower(functions::format('./files/forum/attach/' . $res['filename']));
- $pic_ext = array(
- 'gif',
- 'jpg',
- 'jpeg',
- 'png'
- );
- if (in_array($att_ext, $pic_ext)) {
- // Если картинка, то выводим предпросмотр
- $file = '<div><a href="index.php?act=file&id=' . $res['id'] . '">';
- $file .= '<img src="thumbinal.php?file=' . (urlencode($res['filename'])) . '" alt="' . $lng_forum['click_to_view'] . '" /></a></div>';
- } else {
- // Если обычный файл, выводим значок и ссылку
- $file = ($res['del'] ? '<img src="http://img.infoviet.net/images/del.png" width="16" height="16" />'
- : '') . '<img src="http://img.infoviet.net/images/system/' . $res['filetype'] . '.png" width="16" height="16" /> ';
- }
- $file .= '<a href="index.php?act=file&id=' . $res['id'] . '">' . htmlspecialchars($res['filename']) . '</a><br />';
- $file .= '<small><span class="gray">' . $lng_forum['size'] . ': ' . $fls . ' kb.<br />' . $lng_forum['downloaded'] . ': ' . $res['dlcount'] . ' ' . $lng_forum['time'] . '</span></small>';
- $arg = array(
- 'iphide' => 1,
- 'sub' => $file,
- 'body' => $text
- );
- echo functions::display_user($res_u, $arg);
- echo '</div>';
- ++$i;
- }
- echo '<div class="phdr">' . $lng['total'] . ': ' . $total . '</div>';
- if ($total > $kmess) {
- // Постраничная навигация
- echo '<p>' . functions::display_pagination('index.php?act=files&' . (isset($_GET['new']) ? 'new'
- : 'do=' . $do) . $lnk . '&', $start, $total, $kmess) . '</p>' .
- '<p><form action="index.php" method="get">' .
- '<input type="hidden" name="act" value="files"/>' .
- '<input type="hidden" name="do" value="' . $do . '"/>' . $input . '<input type="text" name="page" size="2"/>' .
- '<input type="submit" value="' . $lng['to_page'] . ' >>"/></form></p>';
- }
- } else {
- echo '<div class="list1">' . $lng['list_empty'] . '</div>';
- }
- } else {
- /*
- -----------------------------------------------------------------
- Выводим список разделов, в которых есть файлы
- -----------------------------------------------------------------
- */
- $countnew = mysql_result(mysql_query("SELECT COUNT(*) FROM `cms_forum_files` WHERE `website` = '$website' AND `time` > '$new'" . ($rights >= 7
- ? '' : " AND `del` != '1'") . $sql), 0);
- echo '<p>' . ($countnew > 0
- ? '<a href="index.php?act=files&new' . $lnk . '">' . $lng['new_files'] . ' (' . $countnew . ')</a>'
- : $lng_forum['new_files_empty']) . '</p>';
- echo '<div class="phdr">' . $caption . '</div>';
- $link = array();
- $total = 0;
- for ($i = 1; $i < 10; $i++) {
- $count = mysql_result(mysql_query("SELECT COUNT(*) FROM `cms_forum_files` WHERE `website` = '$website' AND `filetype` = '$i'" . ($rights >= 7
- ? '' : " AND `del` != '1'") . $sql), 0);
- if ($count > 0) {
- $link[] = '<img src="http://img.infoviet.net/images/system/' . $i . '.png" width="16" height="16" class="left" /> <a href="index.php?act=files&do=' . $i . $lnk . '">' . $types[$i] . '</a> (' . $count . ')';
- $total = $total + $count;
- }
- }
- foreach ($link as $var) {
- echo ($i % 2 ? '<div class="list2">' : '<div class="list1">') . $var . '</div>';
- ++$i;
- }
- echo '<div class="phdr">' . $lng['total'] . ': ' . $total . '</div>';
- }
- echo '<p>' . (($do || isset($_GET['new']))
- ? '<a href="index.php?act=files' . $lnk . '">' . $lng_forum['section_list'] . '</a><br />'
- : '') . '<a href="index.php' . ($id ? '?id=' . $id : '') . '">' . $lng['forum'] . '</a></p>';
- ?>