Rewrote 'we' word a little, rewrote mail order to use SQL_INSERTID() instead of anoth...
[mailer.git] / inc / modules / admin / what-list_links.php
index 79b0ab48131f4a96d4d6fcfa86c4bd982542f1c8..1b024ace196fc6e2c152c9256ffeaba00bd40c5c 100644 (file)
@@ -1,24 +1,23 @@
 <?php
 /************************************************************************
- * MXChange v0.2.1                                    Start: 01/28/2004 *
- * ================                             Last change: 12/13/2004 *
+ * Mailer v0.2.1-FINAL                                Start: 01/28/2004 *
+ * ===================                          Last change: 12/13/2004 *
  *                                                                      *
  * -------------------------------------------------------------------- *
  * File              : what-list_links.php                              *
  * -------------------------------------------------------------------- *
  * Short description : List unconfirmed mails of a member               *
  * -------------------------------------------------------------------- *
- * Kurzbeschreibung  : Unbestaetigte Mails eines Mitgliedes auflisten   *
+ * Kurzbeschreibung  : Unbest&auml;tigte Mails eines Mitgliedes auflisten   *
  * -------------------------------------------------------------------- *
  * $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                           *
- * For more information visit: http://www.mxchange.org                  *
+ * Copyright (c) 2003 - 2009 by Roland Haeder                           *
+ * Copyright (c) 2009 - 2012 by Mailer Developer Team                   *
+ * For more information visit: http://mxchange.org                      *
  *                                                                      *
  * 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 *
  ************************************************************************/
 
 // Some security stuff...
-if ((!defined('__SECURITY')) || (!IS_ADMIN())) {
-       $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), '/inc') + 4) . '/security.php';
-       require($INC);
-} elseif (!EXT_IS_ACTIVE('mailid')) {
-       addFatalMessage(__FILE__, __LINE__, generateExtensionInactiveMessage('mailid'));
-       return;
-}
+if ((!defined('__SECURITY')) || (!isAdmin())) {
+       die();
+} // END - if
 
 // Add description as navigation point
-ADD_DESCR('admin', __FILE__);
+addYouAreHereLink('admin', __FILE__);
 
-if (!REQUEST_ISSET_GET('del')) REQUEST_SET_GET('del', '');
+if (!isExtensionActive('mailid')) {
+       displayMessage('{%pipe,generateExtensionInactiveNotInstalledMessage=mailid%}');
+       return;
+} // END - if
 
-if (REQUEST_ISSET_GET('uid')) {
+if (isGetRequestElementSet('userid')) {
        // Check if the user already exists
-       $result = SQL_QUERY_ESC("SELECT surname, family, email FROM `{!_MYSQL_PREFIX!}_user_data` WHERE userid=%s LIMIT 1",
-       array(bigintval(REQUEST_GET('uid'))), __FILE__, __LINE__);
-
-       // Is there an entry?
-       if (SQL_NUMROWS($result) == 1) {
-               // Loads surname, family's name and the email address
-               list($sname, $fname, $email) = SQL_FETCHROW($result);
-               SQL_FREERESULT($result);
-
-               // Grab user's all unconfirmed mails
-               if (EXT_IS_ACTIVE('bonus')) {
-                       // Load bonus ID
-                       $result = SQL_QUERY_ESC("SELECT stats_id, bonus_id, link_type FROM `{!_MYSQL_PREFIX!}_user_links` WHERE userid=%s ORDER BY `id`",
-                       array(bigintval(REQUEST_GET('uid'))), __FILE__, __LINE__);
-               } else {
-                       // Load stats ID (2nd will be ignored later! But it is needed for the same fetchrow command)
-                       $result = SQL_QUERY_ESC("SELECT stats_id, stats_id, link_type FROM `{!_MYSQL_PREFIX!}_user_links` WHERE userid=%s ORDER BY `id`",
-                       array(bigintval(REQUEST_GET('uid'))), __FILE__, __LINE__);
-               }
-
-               // Get number of rows from the query
-               $nums = SQL_NUMROWS($result);
-
-               if ($nums > 0) {
+       if (fetchUserData(getRequestElement('userid'))) {
+               // Default is ext-bonus is not installed
+               $rowName = 'stats_id';
+
+               // Is ext-bonus installed?
+               if (isExtensionActive('bonus')) {
+                       // Use bonus_id
+                       $linkDataName = 'bonus_id';
+               } // END - if
+
+               // Load user links data
+               $result = SQL_QUERY_ESC("SELECT `userid`, `stats_id`, `%s`, `link_type` FROM `{?_MYSQL_PREFIX?}_user_links` WHERE `userid`=%s ORDER BY `id` ASC",
+                       array(
+                               $linkDataName,
+                               bigintval(getRequestElement('userid'))
+                       ), __FILE__, __LINE__);
+
+               // Are there some entries?
+               if (!SQL_HASZERONUMS($result)) {
                        // Some unconfirmed mails left
-                       if (REQUEST_GET('del') == "all") {
+                       if (getRequestElement('delete') == 'all') {
                                // Delete all unconfirmed mails by this user
-                               SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM `{!_MYSQL_PREFIX!}_user_links` WHERE userid=%s LIMIT %s",
-                               array(bigintval(REQUEST_GET('uid')), $nums), __FILE__, __LINE__);
+                               SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM `{?_MYSQL_PREFIX?}_user_links` WHERE `userid`=%s LIMIT %s",
+                                       array(bigintval(getRequestElement('userid')), SQL_NUMROWS($result)), __FILE__, __LINE__);
 
                                // Prepare mail and send it away
-                               $msg = LOAD_EMAIL_TEMPLATE("admin-del_links", $nums, bigintval(REQUEST_GET('uid')));
-                               sendEmail($email, getMessage('ADMIN_DEL_LINK_SUBJ'), $msg);
+                               $message = loadEmailTemplate('member_delete_links', SQL_NUMROWS($result), bigintval(getRequestElement('userid')));
+                               sendEmail(getUserData('userid'), '{--ADMIN_DELETE_LINK_SUBJECT--}', $message);
 
                                // Display message
-                               LOAD_TEMPLATE('admin_settings_saved', false, getMessage('ADMIN_LINKS_DELETED'));
+                               displayMessage('{--ADMIN_LINKS_DELETED--}');
                        } else {
                                // Init variables
-                               $OUT = ''; $SW = 2;
+                               $OUT = '';
 
                                // List all unconfirmed mails
-                               // @TODO Find a way to rewrite this. See some lines above for different queries
-                               while (list($id, $id2, $type) = SQL_FETCHROW($result)) {
-                                       // Initializes some variables
-                                       $cat = '';
-                                       $DATA = '';
-                                       $PROBLEM = getMessage('GENERAL_MAIL_PROBLEM');
-                                       $result_data = false; // Closes Bug #58
+                               while ($linkData = SQL_FETCHARRAY($result)) {
+                                       // Initializes all other elements
+                                       $linkData['mail_id'] = '';
+                                       $linkData['problem'] = '{--ADMIN_GENERAL_MAIL_PROBLEM--}';
+                                       $result_data = false;
 
                                        // Load data from stats table...
-                                       switch ($type)
-                                       {
-                                               case "NORMAL":
-                                                       $result_data = SQL_QUERY_ESC("SELECT subject, timestamp_ordered, cat_id FROM `{!_MYSQL_PREFIX!}_user_stats` WHERE `id`=%s LIMIT 1",
-                                                       array(bigintval($id)), __FILE__, __LINE__);
-                                                       $type = 'mailid'; $DATA = $id; $PROBLEM = getMessage('NORMAL_MAIL_PROBLEM');
-                                                       $LINK = "<a href=\"{!URL!}/mailid.php?uid=".REQUEST_GET('uid')."&amp;mailid=".$id."\" target=\"_blank\">".$id."</a>";
+                                       // @TODO Rewrite this to includes/filter
+                                       switch ($linkData['link_type']) {
+                                               case 'NORMAL':
+                                                       $result_data = SQL_QUERY_ESC("SELECT `subject`, `timestamp_ordered` AS `timestamp`, `cat_id` FROM `{?_MYSQL_PREFIX?}_user_stats` WHERE `id`=%s LIMIT 1",
+                                                               array(bigintval($linkData['stats_id'])), __FILE__, __LINE__);
+                                                       $linkData['link_type'] = 'mailid';
+                                                       $linkData['mail_id']   = $linkData['stats_id'];
+                                                       $linkData['problem']   = '{--NORMAL_MAIL_PROBLEM--}';
                                                        break;
 
-                                               case "BONUS":
-                                                       $result_data = SQL_QUERY_ESC("SELECT subject, timestamp, cat_id FROM `{!_MYSQL_PREFIX!}_bonus` WHERE `id`=%s LIMIT 1",
-                                                       array(bigintval($id2)), __FILE__, __LINE__);
-                                                       $type = 'bonusid'; $DATA = $id2; $PROBLEM = getMessage('BONUS_MAIL_PROBLEM');
-                                                       $LINK = "<a href=\"{!URL!}/mailid.php?uid=".REQUEST_GET('uid')."&amp;bonusid=".$id2."\" target=\"_blank\">".$id2."</a>";
+                                               case 'BONUS':
+                                                       $result_data = SQL_QUERY_ESC("SELECT `subject`, `timestamp`, `cat_id` FROM `{?_MYSQL_PREFIX?}_bonus` WHERE `id`=%s LIMIT 1",
+                                                               array(bigintval($linkData['bonus_id'])), __FILE__, __LINE__);
+                                                       $linkData['link_type'] = 'bonusid';
+                                                       $linkData['mail_id']   = $linkData['bonus_id'];
+                                                       $linkData['problem']   = '{--BONUS_MAIL_PROBLEM--}';
                                                        break;
 
                                                default: // Problem in application detected!
-                                                       // Log the error
-                                                       DEBUG_LOG(__FILE__, __LINE__, sprintf("Invalid email type %s detected.", $type));
+                                                       reportBug(__FILE__, __LINE__, sprintf("Invalid email type %s detected.", $linkData['link_type']));
                                                        break;
-                                       }
+                                       } // END - switch
 
+                                       // Is there an entry?
                                        if (SQL_NUMROWS($result_data) == 1) {
-                                               // Mail was found!
-                                               list($subject, $timestamp, $cat) = SQL_FETCHROW($result_data);
-                                               SQL_FREERESULT($result_data);
-                                               if (empty($subject)) $subject = getMessage('DEFAULT_SUBJECT_LINE');
+                                               // Mail was found
+                                               $mailData = merge_array($linkData, SQL_FETCHARRAY($result_data));
+
+                                               // Fix empty subject
+                                               if (empty($mailData['subject'])) {
+                                                       // The subject line is empty so we use the default
+                                                       $mailData['subject'] = '{--DEFAULT_SUBJECT_LINE--}';
+                                               } // END - if
 
                                                // Prepare data for the row template
-                                               $content = array(
-                                                       'sw'    => $SW,
-                                                       'link'  => $LINK,
-                                                       'subj'  => $subject,
-                                                       'stamp' => generateDateTime($timestamp, '0'),
-                                                       'cat'   => getCategory($cat),
-                                               );
+                                               $mailData['timestamp'] = generateDateTime($mailData['timestamp'], 0);
 
                                                // Load row template
-                                               $OUT .= LOAD_TEMPLATE("admin_list_links_row", true, $content);
+                                               $OUT .= loadTemplate('admin_list_links_row', true, $mailData);
                                        } else {
                                                // Load template for error
-                                               $OUT .= LOAD_TEMPLATE("admin_list_links_problem",
-                                               array(
-                                                               'sw'            => $SW,
-                                                               'problem'       => $PROBLEM,
-                                                               'data'          => $DATA
-                                               )
-                                               );
+                                               $OUT .= loadTemplate('admin_list_links_problem', true, $linkData);
                                        }
-                                       $SW = 3 - $SW;
-                               }
 
-                               // Free memory
-                               SQL_FREERESULT($result);
+                                       // Free result
+                                       SQL_FREERESULT($result_data);
+                               } // END - while
 
                                // Remember list in constant for the template
-                               define('__SNAME_VALUE', $sname);
-                               define('__FNAME_VALUE', $fname);
-                               define('__EMAIL_VALUE', "<a href=\"".generateMemberEmailLink($email, "user_data")."\">".$email."</a>");
-                               define('__EMAIL_LIST' , $OUT);
-                               define('__NUMS_VALUE' , $nums);
-                               define('__UID'        , bigintval(REQUEST_GET('uid')));
+                               $content = array(
+                                       'email'   => '<a href="' . generateEmailLink(getUserData('email'), 'user_data') . '">' . getUserData('email') . '</a>',
+                                       'rows'    => $OUT,
+                                       'nums'    => SQL_NUMROWS($result),
+                                       'userid'  => bigintval(getRequestElement('userid')),
+                               );
+
+                               // Free memory
+                               SQL_FREERESULT($result);
 
                                // Load final template
-                               LOAD_TEMPLATE("admin_list_links");
+                               loadTemplate('admin_list_links', false, $content);
                        }
                } else {
                        // No mails left to confirm
-                       LOAD_TEMPLATE('admin_settings_saved', false, sprintf(getMessage('ADMIN_MEMBER_LINKS'), REQUEST_GET('uid')));
+                       displayMessage('{%message,ADMIN_NO_UNCONFIRMED_MAILS_LEFT=' . bigintval(getRequestElement('userid')) . '%}');
                }
        } else {
                // User not found
-               LOAD_TEMPLATE('admin_settings_saved', false, sprintf(getMessage('ADMIN_MEMBER_404'), REQUEST_GET('uid')));
+               displayMessage('{%message,ADMIN_MEMBER_404=' . bigintval(getRequestElement('userid')) . '%}');
        }
 } else {
        // Output selection form with all confirmed user accounts listed
-       ADD_MEMBER_SELECTION_BOX();
+       addMemberSelectionBox();
 }
 
-//
+// [EOF]
 ?>