2 /************************************************************************
3 * MXChange v0.2.1 Start: 06/29/2004 *
4 * ================ Last change: 08/22/2004 *
6 * -------------------------------------------------------------------- *
7 * File : what-add_rallye.php *
8 * -------------------------------------------------------------------- *
9 * Short description : Add new rallye *
10 * -------------------------------------------------------------------- *
11 * Kurzbeschreibung : Neue Ref-Rallye einfuegen *
12 * -------------------------------------------------------------------- *
15 * $Tag:: 0.2.1-FINAL $ *
17 * Needs to be in all Files and every File needs "svn propset *
18 * svn:keywords Date Revision" (autoprobset!) at least!!!!!! *
19 * -------------------------------------------------------------------- *
20 * Copyright (c) 2003 - 2008 by Roland Haeder *
21 * For more information visit: http://www.mxchange.org *
23 * This program is free software; you can redistribute it and/or modify *
24 * it under the terms of the GNU General Public License as published by *
25 * the Free Software Foundation; either version 2 of the License, or *
26 * (at your option) any later version. *
28 * This program is distributed in the hope that it will be useful, *
29 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
30 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
31 * GNU General Public License for more details. *
33 * You should have received a copy of the GNU General Public License *
34 * along with this program; if not, write to the Free Software *
35 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *
37 ************************************************************************/
39 // Some security stuff...
40 if ((!defined('__SECURITY')) || (!IS_ADMIN())) {
41 $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), '/inc') + 4) . '/security.php';
45 // Add description as navigation point
46 ADD_DESCR('admin', __FILE__);
49 // Generate timestamps
50 $START = mktime(REQUEST_POST('start_hour'), REQUEST_POST('start_min'), REQUEST_POST('start_sec'), REQUEST_POST('start_month'), REQUEST_POST('start_day'), REQUEST_POST('start_year'));
51 $END = mktime(REQUEST_POST('end_hour') , REQUEST_POST('end_min') , REQUEST_POST('end_sec') , REQUEST_POST('end_month') , REQUEST_POST('end_day') , REQUEST_POST('end_year') );
53 // Is there already a rallye running?
54 $result = SQL_QUERY_ESC("SELECT id, admin_id FROM `{!_MYSQL_PREFIX!}_rallye_data` WHERE (start_time <= %s AND end_time >= %s) OR (start_time >= %s AND start_time <= %s) LIMIT 1",
55 array($START, $START, $START, $END), __FILE__, __LINE__);
57 if (SQL_NUMROWS($result) == 0) {
58 // Ok, start and end time did not overlap
59 SQL_QUERY_ESC("INSERT INTO `{!_MYSQL_PREFIX!}_rallye_data` (admin_id, title, descr, template, start_time, end_time, auto_add_new_user, is_active, send_notify)
60 VALUES ('%s','%s','%s','%s','%s','%s','%s','%s','%s')",
63 REQUEST_POST('title'),
64 REQUEST_POST('descr'),
65 REQUEST_POST('template'),
68 REQUEST_POST('auto_add'),
69 REQUEST_POST('active'),
70 REQUEST_POST('notify'),
71 ), __FILE__, __LINE__);
74 $result = SQL_QUERY_ESC("SELECT `id` FROM `{!_MYSQL_PREFIX!}_rallye_data` WHERE start_time='%s' AND end_time='%s' AND `title`='%s' LIMIT 1",
75 array($START, $END, REQUEST_POST('title')), __FILE__, __LINE__);
76 list($id) = SQL_FETCHROW($result);
77 SQL_FREERESULT($result);
80 // Reload to prices...
81 redirectToUrl('modules.php?module=admin&what=config_rallye_prices&rallye='.$id);
83 // Problem detected...
84 LOAD_TEMPLATE('admin_settings_saved', false, getMessage('RALLYE_PROBLEM_CREATE'));
88 SQL_FREERESULT($result);
90 // Overlapping detected
91 LOAD_TEMPLATE('admin_settings_saved', false, getMessage('RALLYE_OVERLAP_TIMES'));
95 // Prepare some constants for the template
96 define('_AUTO_ADD_OPTIONS', generateOptionList('/ARRAY/', array('Y','N'), array(YES, NO )));
97 define('_ACTIVE_OPTIONS' , generateOptionList('/ARRAY/', array('N','Y'), array(NO , YES)));
98 define('_NOTIFY_OPTIONS' , generateOptionList('/ARRAY/', array('Y','N'), array(YES, NO )));
101 define('_START_SEC' , ADD_SELECTION('sec' , '0' , 'start'));
102 define('_START_MIN' , ADD_SELECTION('min' , '0' , 'start'));
103 define('_START_HOUR' , ADD_SELECTION('hour' , date('G', time()), 'start'));
104 define('_START_DAY' , ADD_SELECTION('day' , date('d', time()), 'start'));
105 define('_START_MONTH', ADD_SELECTION('month', date('m', time()), 'start'));
106 define('_START_YEAR' , ADD_SELECTION('year' , date('Y', time()), 'start'));
108 // Calcualte ending date
109 $D = date('d', time() + (getConfig('one_day') * 7));
110 $M = date('m', time() + (getConfig('one_day') * 7));
111 $Y = date('Y', time() + (getConfig('one_day') * 7));
114 define('_END_SEC' , ADD_SELECTION('sec' , '0' , 'end'));
115 define('_END_MIN' , ADD_SELECTION('min' , '0' , 'end'));
116 define('_END_HOUR' , ADD_SELECTION('hour' , date('G', time()), 'end'));
117 define('_END_DAY' , ADD_SELECTION('day' , $D , 'end'));
118 define('_END_MONTH', ADD_SELECTION('month', $M , 'end'));
119 define('_END_YEAR' , ADD_SELECTION('year' , $Y , 'end'));
121 // Transfer (maybe found) templates into constant for the template
122 define('_TEMPLATES', RALLYE_TEMPLATE_SELECTION());
125 LOAD_TEMPLATE('admin_add_rallye');