1
0
mirror of https://github.com/e107inc/e107.git synced 2025-01-17 12:48:24 +01:00
php-e107/e107_admin/banlist_export.php

146 lines
3.7 KiB
PHP
Raw Normal View History

2007-12-11 22:48:42 +00:00
<?php
/*
2009-11-12 14:30:07 +00:00
* e107 website system
*
2012-01-02 22:23:43 +00:00
* Copyright (C) 2008-2012 e107 Inc (e107.org)
2009-11-12 14:30:07 +00:00
* Released under the terms and conditions of the
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
*
* Banlist export
*
2012-01-02 22:23:43 +00:00
*/
require_once(__DIR__.'/../class2.php');
2012-01-02 22:23:43 +00:00
if (!getperms('4'))
2007-12-11 22:48:42 +00:00
{
e107::redirect('admin');
2012-01-02 22:23:43 +00:00
exit;
2007-12-11 22:48:42 +00:00
}
/*
Output a selection of data from the banlist table arequire_once(__DIR__.'/../class2.php');s a CSV
2007-12-11 22:48:42 +00:00
Selection data:
$_POST['ban_types'] - array of 0..9
$_POST['ban_separator'] - 1 or 2
$_POST['ban_quote'] - 1,2,3
*/
2012-01-02 22:23:43 +00:00
require_once(e_HANDLER.'iphandler_class.php'); // This is probably already loaded in class2.php
2007-12-11 22:48:42 +00:00
2012-01-02 22:23:43 +00:00
// Uncomment what's going on to get debug data
2007-12-11 22:48:42 +00:00
//define('CSV_DEBUG',TRUE);
$separator_char = array(1 => ',', 2 => '|');
$quote_char = array(1 => '', 2 => "'", 3 => '"');
$format_array = array(
'banlist_ip' => 1,
'banlist_datestamp' => "%Y%m%d_%H%M%S",
'banlist_banexpires' => "%Y%m%d_%H%M%S",
'banlist_bantype' => 1,
'banlist_reason' => 1,
'banlist_notes' => 1
);
$banSep = (int) varset($_POST['ban_separator']);
$banQuote = (int) varset($_POST['ban_quote']);
$use_separator = varset($separator_char[$banSep],$separator_char[1]);
$use_quote = varset($quote_char[$banQuote],$quote_char[2]);
2007-12-11 22:48:42 +00:00
$type_list = '';
if (!empty($_POST['ban_types']))
2007-12-11 22:48:42 +00:00
{
2012-01-02 22:23:43 +00:00
$validBanTypes = banlistManager::getValidReasonList();
$spacer = '';
foreach($_POST['ban_types'] as $b)
2007-12-11 22:48:42 +00:00
{
2012-01-02 22:23:43 +00:00
$b = trim($b);
if (is_numeric($b) && in_array($b, $validBanTypes))
{
$type_list .= $spacer.($b);
$spacer = ',';
}
2007-12-11 22:48:42 +00:00
}
}
2021-11-25 10:18:53 -08:00
$filename = 'banlist_'.e107::getParser()->toDate(time(), "%Y%m%d_%H%M%S").'.csv';
2007-12-11 22:48:42 +00:00
if ($error_string = do_export($filename, $type_list, $format_array, $use_separator, $use_quote))
{
// Need to report an error here
2012-01-02 22:23:43 +00:00
echo "Error report: {$error_string}<br />";
2007-12-11 22:48:42 +00:00
}
2012-01-02 22:23:43 +00:00
banlist_adminlog('06','File: '.$filename.'<br />'.$error_string);
2007-12-23 21:15:54 +00:00
2007-12-11 22:48:42 +00:00
2020-12-08 12:21:12 -08:00
function do_export($filename, $type_list='',$format_array=array(), $sep = ',', $quot = '"')
2007-12-11 22:48:42 +00:00
{
2012-01-02 22:23:43 +00:00
$sql = e107::getDb();
2021-11-25 10:18:53 -08:00
$tp = e107::getParser();
2012-01-02 22:23:43 +00:00
$export_text = '';
$qry = "SELECT * FROM `#banlist` ";
if ($type_list != '') $qry .= " WHERE`banlist_bantype` IN ({$type_list})";
2016-02-15 00:14:45 -08:00
if (!$sql->gen($qry)) return 'No data: '.$qry;
2020-12-14 16:21:48 -08:00
while ($row = $sql->fetch())
2012-01-02 22:23:43 +00:00
{
$line = '';
$spacer = '';
foreach ($format_array as $f => $v)
{
switch ($f)
{
case 'banlist_ip' :
case 'banlist_bantype' :
case 'banlist_reason' :
case 'banlist_notes' :
$line .= $spacer.$quot.$row[$f].$quot;
break;
case 'banlist_datestamp' :
case 'banlist_banexpires' :
2021-11-25 10:18:53 -08:00
if ($row[$f]) $line .= $spacer.$quot.$tp->toDate($row[$f], $v).$quot; else $line .= $spacer.$quot.'0'.$quot;
2012-01-02 22:23:43 +00:00
break;
}
$spacer = $sep;
}
$export_text .= $line."\n";
}
if (defined('CSV_DEBUG'))
2007-12-11 22:48:42 +00:00
{
2012-01-02 22:23:43 +00:00
$export_text .= 'Summary data: <br />';
$export_text .= 'File: '.$filename.'<br />';
$export_text .= 'Types: '.$type_list.'<br />';
$export_text .= 'Query: '.$qry.'<br />';
echo str_replace("\n","<br />",$export_text);
2007-12-11 22:48:42 +00:00
}
2012-01-02 22:23:43 +00:00
else
2007-12-11 22:48:42 +00:00
{
2012-01-02 22:23:43 +00:00
if(headers_sent())
{
return "Cannot output file - some data already sent<br /><br />";
}
//Secure https check
if (isset($_SERVER['HTTP_USER_AGENT']) && $_SERVER['HTTP_USER_AGENT']=='contype') header('Pragma: public');
if (isset($_SERVER['HTTP_USER_AGENT']) && strpos($_SERVER['HTTP_USER_AGENT'],'MSIE'))
header('Content-Type: application/force-download');
else
header('Content-Type: application/octet-stream');
header('Content-Length: '.strlen($export_text));
header('Content-disposition: attachment; filename="'.$filename.'"');
echo $export_text;
2007-12-11 22:48:42 +00:00
}
2012-01-02 22:23:43 +00:00
}
2007-12-11 22:48:42 +00:00
2007-12-23 21:15:54 +00:00
// Log event to admin log
2008-01-16 22:18:27 +00:00
function banlist_adminlog($msg_num='00', $woffle='')
2007-12-23 21:15:54 +00:00
{
e107::getLog()->add('BANLIST_'.$msg_num, $woffle, E_LOG_INFORMATIVE, '');
2007-12-23 21:15:54 +00:00
}
2007-12-11 22:48:42 +00:00
?>