| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- <?php
- /* $Id: viewnfo.php 2893 2007-04-14 13:20:30Z b4rt $ */
- /*******************************************************************************
- LICENSE
- This program is free software; you can redistribute it and/or
- modify it under the terms of the GNU General Public License (GPL)
- as published by the Free Software Foundation; either version 2
- of the License, or (at your option) any later version.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
- To read the license please visit http://www.gnu.org/copyleft/gpl.html
- *******************************************************************************/
- // prevent direct invocation
- if ((!isset($cfg['user'])) || (isset($_REQUEST['cfg']))) {
- @ob_end_clean();
- @header("location: ../../index.php");
- exit();
- }
- /******************************************************************************/
- // common functions
- require_once('inc/functions/functions.common.php');
- // dir functions
- require_once('inc/functions/functions.dir.php');
- // is enabled ?
- if ($cfg["enable_view_nfo"] != 1) {
- AuditAction($cfg["constants"]["error"], "ILLEGAL ACCESS: ".$cfg["user"]." tried to use nfo-viewer");
- @error("nfo-viewer is disabled. Action has been logged.", "", "");
- }
- // target
- $file = UrlHTMLSlashesDecode(tfb_getRequestVar("path"));
- $path = $cfg["path"].$file;
- // only valid dirs + entries with permission
- if (!((tfb_isValidPath($path, ".nfo") || tfb_isValidPath($path, ".txt") || tfb_isValidPath($path, ".log")) &&
- (isValidEntry($file)) &&
- (hasPermission($file, $cfg["user"], 'r')))) {
- AuditAction($cfg["constants"]["error"], "ILLEGAL NFO-ACCESS: ".$cfg["user"]." tried to view ".$file);
- @error("Illegal access. Action has been logged.", "", "");
- }
- // init template-instance
- tmplInitializeInstance($cfg["theme"], "page.viewnfo.tmpl");
- // set vars
- $tmpl->setvar('file', $file);
- $folder = htmlspecialchars(substr($file, 0, strrpos($file, "/" )));
- $tmpl->setvar('folder', $folder);
- if ($fileHandle = @fopen($path,'r')) {
- $output = "";
- while (!@feof($fileHandle))
- $output .= @fgets($fileHandle, 4096);
- @fclose ($fileHandle);
- } else {
- $output = "Error opening NFO File: ".$file;
- }
- if ((empty($_REQUEST["dos"]) && empty($_REQUEST["win"])) || !empty($_REQUEST["dos"]))
- $tmpl->setvar('output', htmlentities($output, ENT_COMPAT, "cp866"));
- else
- $tmpl->setvar('output', htmlentities($output));
- //
- tmplSetTitleBar($cfg["pagetitle"].' - View NFO');
- tmplSetFoot();
- tmplSetIidVars();
- // parse template
- $tmpl->pparse();
- ?>
|