"- disabling accept_holiday.php by default, as it's only used on www.egroupware.org

- only allow 2-char locale's"
This commit is contained in:
Ralf Becker 2009-09-21 07:56:45 +00:00
parent ff0f2dcbbe
commit b0a29726f1

View File

@ -1,73 +1,72 @@
<?php <?php
/**************************************************************************\ /**
* eGroupWare * * Calendar - Accepting holiday files on egroupware.org
* http://www.egroupware.org * *
* Written by Mark Peters <skeeter@phpgroupware.org> * * @link http://www.egroupware.org
* -------------------------------------------- * * @author Mark Peters <skeeter@phpgroupware.org>
* This program is free software; you can redistribute it and/or modify it * * @package calendar
* under the terms of the GNU General Public License as published by the * * @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* Free Software Foundation; either version 2 of the License, or (at your * * @version $Id$
* option) any later version. * */
\**************************************************************************/
/* $Id$ */
$send_back_to = str_replace('submit','admin',$_SERVER['HTTP_REFERER']); die('This file is only used on http://www.egroupware.org/ and therefore disabled on local installations!');
if(!$_POST['locale'])
if(empty($_POST['locale']) || !preg_match('/^[A-Z]{2}$/',$_POST['locale']))
{
die('Missing or wrong value for required _POST[local]!');
}
$send_back_to = str_replace('submit','admin',$_SERVER['HTTP_REFERER']);
function _holiday_cmp($a,$b)
{
if (($year_diff = ($a['occurence'] <= 0 ? 0 : $a['occurence']) - ($b['occurence'] <= 0 ? 0 : $b['occurence'])))
{ {
Header('Location: '.$send_back_to); return $year_diff;
} }
return $a['month'] - $b['month'] ? $a['month'] - $b['month'] : $a['day'] - $b['day'];
}
function _holiday_cmp($a,$b) $send_back_to = str_replace('&locale='.$_POST['locale'],'',$send_back_to);
$file = './holidays.'.$_POST['locale'].'.csv';
if(!file_exists($file) || filesize($file) < 300) // treat very small files as not existent
{
if (count($_POST['name']))
{ {
if (($year_diff = ($a['occurence'] <= 0 ? 0 : $a['occurence']) - ($b['occurence'] <= 0 ? 0 : $b['occurence']))) $fp = fopen($file,'w');
if ($_POST['charset']) fwrite($fp,"charset\t".$_POST['charset']."\n");
$holidays = array();
foreach($_POST['name'] as $i => $name)
{ {
return $year_diff; $holidays[] = array(
'locale' => $_POST['locale'],
'name' => str_replace('\\','',$name),
'day' => $_POST['day'][$i],
'month' => $_POST['month'][$i],
'occurence' => $_POST['occurence'][$i],
'dow' => $_POST['dow'][$i],
'observance_rule' => $_POST['observance'][$i],
);
} }
return $a['month'] - $b['month'] ? $a['month'] - $b['month'] : $a['day'] - $b['day']; // sort holidays by year / occurence:
} usort($holidays,'_holiday_cmp');
$send_back_to = str_replace('&locale='.$_POST['locale'],'',$send_back_to); $last_year = -1;
$file = './holidays.'.$_POST['locale'].'.csv'; foreach($holidays as $holiday)
if(!file_exists($file) || filesize($file) < 300) // treat very small files as not existent
{
if (count($_POST['name']))
{ {
$fp = fopen($file,'w'); $year = $holiday['occurence'] <= 0 ? 0 : $holiday['occurence'];
if ($_POST['charset']) fwrite($fp,"charset\t".$_POST['charset']."\n"); if ($year != $last_year)
$holidays = array();
foreach($_POST['name'] as $i => $name)
{ {
$holidays[] = array( fwrite($fp,"\n".($year ? $year : 'regular (year=0)').":\n");
'locale' => $_POST['locale'], $last_year = $year;
'name' => str_replace('\\','',$name),
'day' => $_POST['day'][$i],
'month' => $_POST['month'][$i],
'occurence' => $_POST['occurence'][$i],
'dow' => $_POST['dow'][$i],
'observance_rule' => $_POST['observance'][$i],
);
} }
// sort holidays by year / occurence: fwrite($fp,"$holiday[locale]\t$holiday[name]\t$holiday[day]\t$holiday[month]\t$holiday[occurence]\t$holiday[dow]\t$holiday[observance_rule]\n");
usort($holidays,'_holiday_cmp');
$last_year = -1;
foreach($holidays as $holiday)
{
$year = $holiday['occurence'] <= 0 ? 0 : $holiday['occurence'];
if ($year != $last_year)
{
fwrite($fp,"\n".($year ? $year : 'regular (year=0)').":\n");
$last_year = $year;
}
fwrite($fp,"$holiday[locale]\t$holiday[name]\t$holiday[day]\t$holiday[month]\t$holiday[occurence]\t$holiday[dow]\t$holiday[observance_rule]\n");
}
fclose($fp);
} }
Header('Location: '.$send_back_to); fclose($fp);
} }
else Header('Location: '.$send_back_to);
{ exit;
}
?> ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html> <html>
@ -84,6 +83,3 @@
<p>To get back to your own eGroupWare-install <a href="<?php echo $send_back_to; ?>">click here</a>.</p> <p>To get back to your own eGroupWare-install <a href="<?php echo $send_back_to; ?>">click here</a>.</p>
</body> </body>
</html> </html>
<?php
}
?>