2 /************************************************************************
3 * Mailer v0.2.1-FINAL Start: 04/24/2005 *
4 * =================== Last change: 05/12/2005 *
6 * -------------------------------------------------------------------- *
7 * File : what-edit_sponsor.php *
8 * -------------------------------------------------------------------- *
9 * Short description : Edit sponsor account *
10 * -------------------------------------------------------------------- *
11 * Kurzbeschreibung : Sponsorenaccount aendern *
12 * -------------------------------------------------------------------- *
15 * $Tag:: 0.2.1-FINAL $ *
17 * -------------------------------------------------------------------- *
18 * Copyright (c) 2003 - 2009 by Roland Haeder *
19 * Copyright (c) 2009 - 2011 by Mailer Developer Team *
20 * For more information visit: http://www.mxchange.org *
22 * This program is free software; you can redistribute it and/or modify *
23 * it under the terms of the GNU General Public License as published by *
24 * the Free Software Foundation; either version 2 of the License, or *
25 * (at your option) any later version. *
27 * This program is distributed in the hope that it will be useful, *
28 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
29 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
30 * GNU General Public License for more details. *
32 * You should have received a copy of the GNU General Public License *
33 * along with this program; if not, write to the Free Software *
34 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *
36 ************************************************************************/
38 // Some security stuff...
39 if ((!defined('__SECURITY')) || (!isAdmin())) {
43 // Add description as navigation point
44 addYouAreHereLink('admin', __FILE__);
46 if ((isGetRequestParameterSet('id')) && (isGetRequestParameterSet('mode'))) {
47 // Check for selected sponsor
48 $result_main = SQL_QUERY_ESC("SELECT
49 `id`, `company`, `position`, `gender`, `surname`, `family`,
50 `street_nr1`, `street_nr2`, `zip`, `city`, `country`,
51 `phone`, `fax`, `cell`, `email`, `url`, `tax_ident`,
52 `receive_warnings`, `warning_interval`
54 `{?_MYSQL_PREFIX?}_sponsor_data`
58 array(bigintval(getRequestParameter('id'))), __FILE__, __LINE__);
59 if (SQL_NUMROWS($result_main) == 1) {
60 // Load sponsor details
61 $content = SQL_FETCHARRAY($result_main);
63 // Warning because low points
64 $content['receive_warnings'] = addSelectionBox('yn', $content['receive_warnings'], 'receive_warning');
65 $content['warning_interval'] = createTimeSelections($content['warning_interval'], 'warning_interval', 'MWDh');
67 // Init variables here
68 $TPL = sprintf("admin_edit_sponsor_%s", getRequestParameter('mode'));
72 if ((isFormSent()) || (isFormSent('edit'))) {
73 // Perform action on mode
74 switch (getRequestParameter('mode')) {
75 case 'add_points': // Add points
76 if (bigintval(postRequestParameter('points')) > 0) {
77 // Replace german decimal comma with computer's decimal dot
78 $points = bigintval(convertCommaToDot(postRequestParameter('points')));
80 // Add points to account
81 SQL_QUERY_ESC("UPDATE `{?_MYSQL_PREFIX?}_sponsor_data` SET `points_amount`=`points_amount`+%s WHERE `id`=%s LIMIT 1",
82 array($points, bigintval(getRequestParameter('id'))), __FILE__, __LINE__);
84 // Remember points /reason for the template
85 $content['points'] = $points;
86 $content['reason'] = postRequestParameter('reason');
89 $message = loadEmailTemplate('sponsor_add_points', $content);
90 sendEmail($content['email'], '{--ADMIN_SPONSOR_ADD_POINTS_SUBJECT--}', $message);
91 $message = '{--ADMIN_SPONSOR_POINTS_ADDED--}';
93 // No points entered to add!
94 $message = '{--ADMIN_SPONSOR_NO_POINTS_TO_ADD--}';
98 case 'sub_points': // Subtract points
99 if (bigintval(postRequestParameter('points')) > 0) {
100 // Replace german decimal comma with computer's decimal dot
101 $points = bigintval(convertCommaToDot(postRequestParameter('points')));
103 // Add points to account
104 SQL_QUERY_ESC("UPDATE `{?_MYSQL_PREFIX?}_sponsor_data` SET `points_used`=`points_used`+%s WHERE `id`=%s LIMIT 1",
105 array($points, bigintval(getRequestParameter('id'))), __FILE__, __LINE__);
107 // Remember points /reason for the template
108 $content['points'] = $points;
109 $content['reason'] = postRequestParameter('reason');
112 $message = loadEmailTemplate('sponsor_sub_points', $content);
113 sendEmail($content['email'], '{--ADMIN_SPONSOR_SUB_POINTS_SUBJECT--}', $message);
114 $message = '{--ADMIN_SPONSOR_POINTS_SUBTRACTED--}';
116 // No points entered to add!
117 $message = '{--ADMIN_SPONSOR_NO_POINTS_TO_SUBTRACT--}';
121 case 'edit': // Edit sponsor account
123 if ((postRequestParameter('pass1') != postRequestParameter('pass2')) || ((!isPostRequestParameterSet('pass1')) && (!isPostRequestParameterSet('pass1')))) {
125 unsetPostRequestParameter('pass1');
126 unsetPostRequestParameter('pass2');
130 // Convert time selection
131 $DATA = array(); $id = 'warning_interval_ye'; $skip = false;
132 convertSelectionsToEpocheTime(postRequestArray(), $DATA, $id, $skip);
135 handleSponsorRequest(postRequestArray());
137 // Convert some data for the email template
138 postRequestParameter('gender' , '{%pipe,translateComma=' . postRequestParameter('gender') . '%}');
139 postRequestParameter('warning_interval', '{%pipe,createFancyTime=' . postRequestParameter('warning_interval') . '%}');
141 if ($PASS === false) setPostRequestParameter('pass1', '{--SPONSOR_PASS_UNCHANGED--}');
143 // Load email template and send the mail away
144 $message = loadEmailTemplate('admin_sponsor_edit', postRequestArray(), false);
145 sendEmail(postRequestParameter('email'), '{--ADMIN_SPONSOR_EDIT_SUBJECT--}', $message);
148 default: // Unknown mode
149 logDebugMessage(__FILE__, __LINE__, sprintf("Unknown mode %s detected.", getRequestParameter('mode')));
150 $message = '{%message,ADMIN_SPONSOR_INVALID_MODE=' . getRequestParameter('mode') . '%}';
154 if (!empty($message)) {
156 displayMessage($message);
158 } elseif (isFileReadable(sprintf("%stemplates/%s/html/admin/%s.tpl", getPath(), getLanguage(), $TPL))) {
159 // Create mailto link
160 $content['contact'] = '<a href="' . generateSponsorEmailLink($content['email'], 'sponsor_data') . '">' . $content['surname'] . ' ' . $content['family'] . '</a>';
162 // Load mode template
163 loadTemplate($TPL, false, $content);
165 // Template not found
166 displayMessage('{%message,ADMIN_SPONSOR_MODUS_TPL_404', getRequestParameter('mode') . '%}');
170 displayMessage('{%message,ADMIN_SPONSOR_404=' . bigintval(getRequestParameter('id')) . '%}');
174 SQL_FREERESULT($result_main);
176 // Not called by what-list_sponsor.php
177 displayMessage('{--ADMIN_CALL_NOT_DIRECTLY--}');