A lightweight forum engine written in PHP. Repository is now obsolete and read-only. http://www.pioder.pl/uforum.html
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

212 lines
6.7 KiB

<?php
/**
* @package uForum
* @file admin/censorlist.php
* @version $Id$
* @copyright 2007-2010 (c) PioDer <[email protected]>
* @link http://www.pioder.pl/
* @license see LICENSE.txt
**/
define('IN_uF', true);
//include files
require('./../config.php');
require('./../includes/constants.php');
require('./../includes/db.php');
require('./../includes/errors.php');
require('./../includes/classes/class_pms.php');
//connect to database
DataBase::db_connect();
require('./../includes/sessions.php');
require('./../includes/classes/class_user.php');
require('./../common.php');
require('./../includes/admin/class_main.php');
require('./../includes/classes/class_forum.php');
require('./../includes/admin/class_forum.php');
require('./../includes/classes/secure.php');
require('./../lngs/'.Admin_Over::DefaultLang().'/admin.php');
SessDelInvalid();
SessRegister();
SessDeleteOld();
if (User::UserInformation($_SESSION['uid'],'rank')!=2)
{
admin_message_forum($lng['yournotadmin'],'../index.php');
}
if (!isset($_GET['mode']))
{
header('Location: censorlist.php?mode=main');
}
switch($_GET['mode'])
{
case 'addfile':
{
if (isset($_FILES['file']))
{
$catalog = '../tmp/';
if(!move_uploaded_file($_FILES['file']['tmp_name'], $catalog.$_FILES['file']['name']))
{
message_die(GENERAL,'Could not upload file.','');
}
$open = fopen($catalog.$_FILES['file']['name'],'r');
$file = fread($open, filesize($catalog.$_FILES['file']['name']));
$item = @explode(',',$file);
$sql = "SELECT `w_id` FROM ".CENSORLIST_TABLE." ORDER BY `w_id` DESC";
$last = DataBase::fetch(DataBase::sql_query($sql,GENERAL,'Could not obtain last word id'));
$last = $last['w_id'];
$last= $last +1;
for($i=0;$i<count($item);$i++)
{
$word = $item[$i];
DataBase::sql_query("INSERT INTO ".CENSORLIST_TABLE." VALUES ('$last','$word','[censored]')",GENERAL,'Could not add censored word.');
$last = $last +1;
}
admin_message_forum($lng['words_added'],'censorlist.php');
}
else
{
$skin = array(
'L.main_beam'=>$lng['add_from_file'],
'L.file_name'=>$lng['file_name'],
'L.save'=>$lng['submit'],
'L.reset'=>$lng['reset'],
'L.censorlist'=>$lng['admin_censorlist']
);
Admin_Over::GenerateHeader();
require('./template/censorlist_upload_body.tpl');
require('./template/overall_footer.tpl');
}
break;
}
case 'delete':
{
$wid = intval($_GET['w']);
$sql = "DELETE FROM ".CENSORLIST_TABLE." WHERE `w_id`='$wid'";
DataBase::sql_query($sql,GENERAL,'Could not delete word.');
admin_message_forum($lng['word_deleted'],'censorlist.php?mode=view');
break;
}
case 'addword':
{
if (isset($_POST['word']))
{
$word = strip_tags($_POST['word']);
$replace = (strlen($_POST['replace']) > 0) ? $_POST['replace'] : '[censored]';
$sql = "SELECT `w_id` FROM ".CENSORLIST_TABLE." ORDER BY `w_id` DESC";
$last = DataBase::fetch(DataBase::sql_query($sql,GENERAL,'Could not obtain last word id'));
$last = $last['w_id'];
$last= $last +1;
DataBase::sql_query("INSERT INTO ".CENSORLIST_TABLE." VALUES ('$last','$word','$replace')",GENERAL,'Could not add censored word.');
admin_message_forum($lng['word_added'],'censorlist.php');
}
else
{
$_POST['word']='';
$_POST['replace']='';
$skin = array(
'action'=>'censorlist.php?mode=addword',
'L.main_beam'=>$lng['add_word'],
'L.word_name'=>$lng['word_name'],
'L.replace_to'=>$lng['replace_to'],
'L.save'=>$lng['submit'],
'L.reset'=>$lng['reset'],
'L.censorlist'=>$lng['admin_censorlist']
);
Admin_Over::GenerateHeader();
require('./template/censorlist_add_edit_body.tpl');
require('./template/overall_footer.tpl');
}
break;
}
case 'edit':
{
if (isset($_POST['word'],$_GET['w']))
{
$word = strip_tags(trim($_POST['word']));
$wid = intval($_GET['w']);
$replace = $_POST['replace'];
DataBase::sql_query("UPDATE ".CENSORLIST_TABLE." SET `word`='$word', `replace`='$replace' WHERE `w_id`='$wid'",GENERAL,'Could not update censored word.');
admin_message_forum($lng['word_edited'],'censorlist.php?mode=view');
}
else
{
$wid = intval($_GET['w']);
$sql = "SELECT * FROM ".CENSORLIST_TABLE." WHERE `w_id`='$wid'";
$query = DataBase::sql_query($sql,CRITICAL,'Could not obtain censorlist words');
$result = DataBase::fetch($query);
$_POST['word']=$result['word'];
$_POST['replace']=$result['replace'];
$skin = array(
'action'=>'censorlist.php?mode=edit&w='.$wid,
'L.main_beam'=>$lng['edit_word'],
'L.word_name'=>$lng['word_name'],
'L.replace_to'=>$lng['replace_to'],
'L.save'=>$lng['submit'],
'L.reset'=>$lng['reset'],
'L.censorlist'=>$lng['admin_censorlist']
);
Admin_Over::GenerateHeader();
require('./template/censorlist_add_edit_body.tpl');
require('./template/overall_footer.tpl');
}
break;
}
case 'deleteall':
{
DataBase::sql_query("TRUNCATE TABLE ".CENSORLIST_TABLE,GENERAL,'Could not empty censorlist table.');
admin_message_forum($lng['table_cleanout'],'censorlist.php');
break;
}
case 'view':
{
$sql = "SELECT * FROM ".CENSORLIST_TABLE." ORDER BY `word`";
$query = DataBase::sql_query($sql,CRITICAL,'Could not obtain censorlist words');
$skin = array(
'L.censorlist'=>$lng['admin_censorlist'],
'L.view_all_words'=>$lng['view_all_words']
);
Admin_Over::GenerateHeader();
require('./template/censorlist_view_body.tpl');
if (DataBase::num_rows($query)<1)
{
echo '<table class="maintable"><tr><td width="'.TABLES_WIDTH.'" colspan="8" height="19"
class="fitem"><p class="fstandard" align="center">'.$lng['no_words'].'!</p></td></tr></table>';
}
else
{
while($item = DataBase::fetch($query))
{
$skin = array(
'L.word_name'=>$item['word'],
'L.word_replacement'=>$item['replace'],
'w_id'=>$item['w_id'],
'L.delete'=>$lng['delete'],
'L.edit'=>$lng['edit'],
);
require('./template/censorlist_list_word.tpl');
}
}
require('./template/overall_footer.tpl');
break;
}
case 'main':
{
$skin = array(
'L.show_all_words' => $lng['show_all_words'],
'L.what_do_you_want'=> $lng['what_do_you_want'],
'L.delete_all_words' => $lng['delete_all_words'],
'L.add_from_file' => $lng['add_from_file'],
'L.add_word' => $lng['add_word'],
'L.censorlist'=>$lng['admin_censorlist']
);
Admin_Over::GenerateHeader();
require('./template/censorlist_main_body.tpl');
require('./template/overall_footer.tpl');
break;
}
default:
{
header('Location: censorlist.php?mode=main');
break;
}
}
?>