Typo 'referral'->'referal' fixed, more 'empty version' fixed
[mailer.git] / inc / modules / admin / what-unlock_sponsor.php
index 130f511cf97a8569334ca83f422fbae2921be5f9..bd1f77f5060c45d90c026fa18ea49201a11fbeb9 100644 (file)
  * -------------------------------------------------------------------- *
  * Kurzbeschreibung  : Sponsorenaccounts freigeben                      *
  * -------------------------------------------------------------------- *
- *                                                                      *
+ * $Revision::                                                        $ *
+ * $Date::                                                            $ *
+ * $Tag:: 0.2.1-FINAL                                                 $ *
+ * $Author::                                                          $ *
+ * Needs to be in all Files and every File needs "svn propset           *
+ * svn:keywords Date Revision" (autoprobset!) at least!!!!!!            *
  * -------------------------------------------------------------------- *
- * Copyright (c) 2003 - 2008 by Roland Haeder                           *
+ * Copyright (c) 2003 - 2009 by Roland Haeder                           *
  * For more information visit: http://www.mxchange.org                  *
  *                                                                      *
- * This program is free software. You can redistribute it and/or modify *
+ * This program is free software; you can redistribute it and/or modify *
  * it under the terms of the GNU General Public License as published by *
- * the Free Software Foundation; either version 2 of the License.       *
+ * the Free Software Foundation; either version 2 of the License, or    *
+ * (at your option) any later version.                                  *
+ *                                                                      *
+ * This program is distributed in the hope that it will be useful,      *
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of       *
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the        *
+ * GNU General Public License for more details.                         *
+ *                                                                      *
+ * You should have received a copy of the GNU General Public License    *
+ * along with this program; if not, write to the Free Software          *
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,               *
+ * MA  02110-1301  USA                                                  *
  ************************************************************************/
 
 // Some security stuff...
-if ((ereg(basename(__FILE__), $_SERVER['PHP_SELF'])) || (!is_admin())) {
-       $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4)."/security.php";
-       require($INC);
+if ((!defined('__SECURITY')) || (!isAdmin())) {
+       die();
 }
 
 // Add description as navigation point
-ADD_DESCR("admin", basename(__FILE__));
+addMenuDescription('admin', __FILE__);
 
 // Check if admin has submitted form
-if (isset($_POST['ok'])) {
+if (isFormSent()) {
        // Does he have selected at least one sponsor?
-       if (SELECTION_COUNT($_POST['id']) > 0) {
+       if (countSelection(postRequestElement('id')) > 0) {
                // At least one entry selected
-               foreach ($_POST['id'] as $id=>$sel) {
-                       // Secure ID number
-                       $id = bigintval($id);
+               foreach (postRequestElement('id') as $id => $selected) {
+                       // Secure id number and init $content
+                       $content = array(
+                               'id'    => bigintval($id),
+                               'refid' => 0
+                       );
 
                        // Load his personal data
-                       $result_main = SQL_QUERY_ESC("SELECT salut, surname, family, email, remote_addr, sponsor_created, points_amount, refid
-FROM "._MYSQL_PREFIX."_sponsor_data
-WHERE status='PENDING' AND id='%s' LIMIT 1",
array($id), __FILE__, __LINE__);
-                       $refid = 0;
+                       $result_main = SQL_QUERY_ESC("SELECT gender, surname, family, email, remote_addr, sponsor_created, points_amount, refid
+FROM `{?_MYSQL_PREFIX?}_sponsor_data`
+WHERE `status`='PENDING' AND id='%s' LIMIT 1",
                      array($content['id']), __FILE__, __LINE__);
+
                        if (SQL_NUMROWS($result_main) == 1) {
-                               // Load data and free memory
-                               list($salut, $sname, $fname, $email, $ip, $created, $points, $refid) = SQL_FETCHROW($result_main);
+                               // Load data
+                               $content = SQL_FETCHARRAY($result_main);
 
                                // Check for open payments and close them
-                               $result = SQL_QUERY_ESC("SELECT DISTINCT so.aid, so.pay_count, so.pay_ordered, so.pay_status,
+                               $result = SQL_QUERY_ESC("SELECT so.admin_id, so.pay_count, so.pay_ordered, so.pay_status,
 sp.pay_name, sp.pay_rate, sp.pay_currency
-FROM "._MYSQL_PREFIX."_sponsor_orders AS so
-LEFT JOIN "._MYSQL_PREFIX."_sponsor_paytypes AS sp
+FROM `{?_MYSQL_PREFIX?}_sponsor_orders` AS so
+LEFT JOIN `{?_MYSQL_PREFIX?}_sponsor_paytypes` AS sp
 ON sp.id=so.payid
 WHERE so.sponsorid='%s'
 ORDER BY sp.pay_name",
array($id), __FILE__, __LINE__);
                              array($content['id']), __FILE__, __LINE__);
                                if (SQL_NUMROWS($result) > 0) {
                                        // Payment does exist
-                                       while(list($aid, $count, $ordered, $status, $pname, $prate, $pcurr) = SQL_FETCHROW($result))
-                                       {
-                                               if ($aid == "0") {
-                                                       // No admin assigned!
-                                                       $aid = SPONSOR_NO_ADMIN;
-                                               } else {
-                                                       // Load admin's email address for contact
-                                                       $result_aid = SQL_QUERY_ESC("SELECT email FROM "._MYSQL_PREFIX."_admins WHERE id='%s' LIMIT 1",
-                                                        array(bigintval($aid)), __FILE__, __LINE__);
-                                                       list($aid) = SQL_FETCHROW($result_aid);
-                                                       SQL_FREERESULT($result_aid);
+                                       while ($content2 = SQL_FETCHARRAY($result)) {
+                                               // Merge both arrays
+                                               $content = merge_array($content, $content2);
 
-                                                       // Check if admin login is still in db
-                                                       if (empty($aid)) $aid = ADMIN_NOT_FOUND;
-                                               }
+                                               // Set default email
+                                               $content['email'] = getMessage('SPONSOR_NO_ADMIN');
+                                               if ($content['admin_id'] > 0) {
+                                                       // Load admin's email address for contact
+                                                       $content['email'] = getAdminEmail($content['admin_id']);
+                                               } // END - if
 
                                                // Transfer data to array
-                                               $content = array(
-                                                       'aid'   => $aid,
-                                                       'order' => ($count * $prate)." ".$pcurr,
-                                                       'stamp' => MAKE_DATETIME($ordered, "2"),
-                                                       'pname' => $pname,
+                                               $data = array(
+                                                       'admin_id'   => $content['email'],
+                                                       'order' => ($content['pay_count'] * $content['pay_rate'])." ".$content['pay_currency'],
+                                                       'stamp' => generateDateTime($content['pay_ordered'], 2),
+                                                       'pname' => $content['pay_name'],
                                                );
-       
+
                                                // Load email template
-                                               $content['msg'] = LOAD_EMAIL_TEMPLATE("sponsor_unlock_sponsor_pay", $content, $id);
+                                               $content['message'] = loadEmailTemplate('sponsor_unlock_sponsor_pay', $data, $content['id']);
                                        }
                                } else {
                                        // No payments found
-                                       $content['msg'] = SPONSOR_NO_PAYMENTS_FOUND;
+                                       $content['message'] = getMessage('SPONSOR_NO_PAYMENTS_FOUND');
                                }
 
                                // Free memory
@@ -99,38 +112,42 @@ ORDER BY sp.pay_name",
                        SQL_FREERESULT($result_main);
 
                        // Unlock sponsor account
-                       $result = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_sponsor_data SET status='CONFIRMED'
-WHERE id='%s' AND status='PENDING' LIMIT 1",
- array($id), __FILE__, __LINE__);
-
-                       // Update, if applyable, referral count and points
-                       if (($refid > 0) && ($refid != $id)) {
-                               // Update referral account
-                               $result = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_sponsor_data
-SET points_amount=points_amount+%s, ref_count=ref_count+1
-WHERE id='%s' LIMIT 1",
- array($CONFIG['sponsor_ref_points'], bigintval($refid)), __FILE__, __LINE__);
+                       SQL_QUERY_ESC("UPDATE `{?_MYSQL_PREFIX?}_sponsor_data` SET `status`='CONFIRMED'
+WHERE `id`='%s' AND `status`='PENDING' LIMIT 1",
+                       array($content['id']), __FILE__, __LINE__);
+
+                       // Update, if applyable, referal count and points
+                       if (($content['refid'] > 0) && ($content['refid'] != $content['id'])) {
+                               // Update referal account
+                               SQL_QUERY_ESC("UPDATE
+       `{?_MYSQL_PREFIX?}_sponsor_data`
+SET
+       `points_amount`=`points_amount`+{?sponsor_ref_points?}, `ref_count`=`ref_count`+1
+WHERE
+       `id`='%s'
+LIMIT 1",
+                                       array(bigintval($content['refid'])), __FILE__, __LINE__);
 
                                // Whas that update fine?
-                               if (SQL_AFFECTED_ROWS($link) == 1) {
-                                       // Load referral's data
-                                       $result = SQL_QUERY_ESC("SELECT id, salut, surname, family, email,
+                               if (SQL_AFFECTEDROWS() == 1) {
+                                       // Load referal's data
+                                       $result = SQL_QUERY_ESC("SELECT id, gender, surname, family, email,
 (points_amount - points_used) AS points, receive_warnings, ref_count AS refs
-FROM "._MYSQL_PREFIX."_sponsor_data
-WHERE id='%s' LIMIT 1",
array(bigintval($refid)), __FILE__, __LINE__);
-                                       $REFERRAL = SQL_FETCHARRAY($result);
+FROM `{?_MYSQL_PREFIX?}_sponsor_data`
+WHERE `id`='%s' LIMIT 1",
                                      array(bigintval($content['refid'])), __FILE__, __LINE__);
+                                       $REFERAL = SQL_FETCHARRAY($result);
 
                                        // Send warnings out?
-                                       if ($REFERRAL['receive_warnings'] == "Y") {
+                                       if ($REFERAL['receive_warnings'] == 'Y') {
                                                // Translate some data
-                                               $REFERRAL['points']     = TRANSLATE_COMMA($REFERRAL['points']);
-                                               $REFERRAL['ref_points'] = TRANSLATE_COMMA($CONFIG['sponsor_ref_points']);
-                                               $REFERRAL['salut']      = TRANSLATE_SEX($REFERRAL['salut']);
+                                               $REFERAL['points']     = translateComma($REFERAL['points']);
+                                               $REFERAL['ref_points'] = translateComma(getConfig('sponsor_ref_points'));
+                                               $REFERAL['gender']     = translateGender($REFERAL['gender']);
 
-                                               // Send notification to referral
-                                               $REF_MSG = LOAD_EMAIL_TEMPLATE("sponsor_ref_notify", $REFERRAL);
-                                               SEND_EMAIL($REFERRAL['email'], SPONSOR_REF_NOTIFY_SUBJ, $REF_MSG);
+                                               // Send notification to referal
+                                               $REF_MSG = loadEmailTemplate('sponsor_ref_notify', $REFERAL);
+                                               sendEmail($REFERAL['email'], getMessage('SPONSOR_REF_NOTIFY_SUBJ'), $REF_MSG);
                                        }
 
                                        // Free memory
@@ -139,61 +156,64 @@ WHERE id='%s' LIMIT 1",
                        }
 
                        // Transfer data to array
-                       $content['salut']   = TRANSLATE_SEX($salut);
-                       $content['surname'] = $sname;
-                       $content['family']  = $fname;
-                       $content['sponsor'] = $id;
-                       $content['points']  = TRANSLATE_COMMA($points);
+                       $content['gender']   = translateGender($content['gender']);
+                       $content['sponsor']  = $content['id'];
+                       $content['points']   = translateComma($content['points_amount']);
 
                        // So let's send the email away
-                       $msg = LOAD_EMAIL_TEMPLATE("sponsor_unlocked", $content);
-                       SEND_EMAIL($email, SPONSOR_UNLOCKED_SUBJ, $msg);
+                       $message = loadEmailTemplate('sponsor_unlocked', $content);
+                       sendEmail($content['email'], getMessage('SPONSOR_UNLOCKED_SUBJ'), $message);
                }
        } else {
                // Nothing selected
-               LOAD_TEMPLATE("admin_settings_saved", false, ADMIN_SPONSOR_NONE_SELECTED_UNLOCK);
+               loadTemplate('admin_settings_saved', false, getMessage('ADMIN_SPONSOR_NONE_SELECTED_UNLOCK'));
        }
 
        // Add seperator
-       OUTPUT_HTML("<BR>");
+       outputHtml('<br />');
 }
 
 // Begin listing of all pending sponsor accounts
-$result = SQL_QUERY("SELECT id, salut, surname, family, email, remote_addr, sponsor_created
-FROM "._MYSQL_PREFIX."_sponsor_data
-WHERE status='PENDING' ORDER BY id", __FILE__, __LINE__);
+$result = SQL_QUERY("SELECT
+       `id`, `gender`, `surname`, `family`, `email`, `remote_addr`, `sponsor_created`
+FROM
+       `{?_MYSQL_PREFIX?}_sponsor_data`
+WHERE
+       `status`='PENDING'
+ORDER BY
+       `id`", __FILE__, __LINE__);
 
 if (SQL_NUMROWS($result) > 0) {
        // Entries found so let's list them!
-       $OUT = ""; $SW = 2;
-       while(list($id, $salut, $sname, $fname, $email, $ip, $created) = SQL_FETCHROW($result)) {
+       $OUT = ''; $SW = 2;
+       while ($content = SQL_FETCHARRAY($result)) {
                // Transfer data to array
+               // @TODO Rewritings: remote->remote_addr, created->sponsor_created in template
                $content = array(
                        'sw'      => $SW,
-                       'id'      => $id,
-                       'salut'   => TRANSLATE_SEX($salut),
-                       'surname' => $sname,
-                       'family'  => $fname,
-                       'email'   => "mailto:".$email,
-                       'remote'  => $ip,
-                       'created' => MAKE_DATETIME($created, "2"),
+                       'id'      => $content['id'],
+                       'gender'   => translateGender($content['gender']),
+                       'surname' => $content['surname'],
+                       'family'  => $content['family'],
+                       'email'   => generateEmailLink($content['email'], 'sponsor_data'),
+                       'remote'  => $content['remote_addr'],
+                       'created' => generateDateTime($content['sponsor_created'], 2),
                );
 
                // Load row template and switch colors
-               $OUT .= LOAD_TEMPLATE("admin_unlock_sponsor_row", true, $content);
+               $OUT .= loadTemplate('admin_unlock_sponsor_row', true, $content);
                $SW = 3 - $SW;
        }
-       define('__SPONSOR_ROWS', $OUT);
 
        // Load template
-       LOAD_TEMPLATE("admin_unlock_sponsor");
+       loadTemplate('admin_unlock_sponsor', false, $OUT);
 } else {
        // No pending accounts found
-       LOAD_TEMPLATE("admin_settings_saved", false, ADMIN_SPONSOR_NONE_PENDING);
+       loadTemplate('admin_settings_saved', false, getMessage('ADMIN_SPONSOR_NONE_PENDING'));
 }
 
 // Free memory
 SQL_FREERESULT($result);
 
-//
+// [EOF]
 ?>