<?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ä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 *
+ * Copyright (c) 2003 - 2009 by Roland Haeder *
+ * Copyright (c) 2009, 2010 by Mailer Developer Team *
* For more information visit: http://www.mxchange.org *
* *
* This program is free software; you can redistribute it and/or modify *
************************************************************************/
// 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(getMessage('EXTENSION_PROBLEM_EXT_INACTIVE'), "mailid");
- return;
-}
+if ((!defined('__SECURITY')) || (!isAdmin())) {
+ die();
+} // END - if
// Add description as navigation point
-ADD_DESCR("admin", __FILE__);
+addMenuDescription('admin', __FILE__);
-if (empty($_GET['del'])) $_GET['del'] = "";
+if (!isExtensionActive('mailid')) {
+ loadTemplate('admin_settings_saved', false, generateExtensionInactiveNotInstalledMessage('mailid'));
+ return;
+} // END - if
-if (!empty($_GET['u_id'])) {
+if (isGetRequestParameterSet('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($_GET['u_id'])), __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);
-
+ if (fetchUserData(getRequestParameter('userid'))) {
// 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($_GET['u_id'])), __FILE__, __LINE__);
+ // @TODO Try to rewrite this to a filter
+ if (isExtensionActive('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` ASC",
+ array(bigintval(getRequestParameter('userid'))), __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($_GET['u_id'])), __FILE__, __LINE__);
+ // 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` ASC",
+ array(bigintval(getRequestParameter('userid'))), __FILE__, __LINE__);
}
// Get number of rows from the query
if ($nums > 0) {
// Some unconfirmed mails left
- if ($_GET['del'] == "all") {
+ if (getRequestParameter('del') == "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($_GET['u_id']), $nums), __FILE__, __LINE__);
+ SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM `{?_MYSQL_PREFIX?}_user_links` WHERE `userid`=%s LIMIT %s",
+ array(bigintval(getRequestParameter('userid')), $nums), __FILE__, __LINE__);
// Prepare mail and send it away
- $msg = LOAD_EMAIL_TEMPLATE("admin-del_links", $nums, bigintval($_GET['u_id']));
- SEND_EMAIL($email, getMessage('ADMIN_DEL_LINK_SUBJ'), $msg);
+ $message = loadEmailTemplate('admin-del_links', $nums, bigintval(getRequestParameter('userid')));
+ sendEmail(getUserData('email'), '{--ADMIN_DELETE_LINK_SUBJECT--}', $message);
// Display message
- LOAD_TEMPLATE("admin_settings_saved", false, getMessage('ADMIN_LINKS_DELETED'));
+ loadTemplate('admin_settings_saved', false, '{--ADMIN_LINKS_DELETED--}');
} else {
+ // Init variables
+ $OUT = '';
+
// List all unconfirmed mails
- $SW = 2; $OUT = "";
+ // @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 = GENERAL_MAIL_PROBLEM;
+ $cat = '';
+ $DATA = '';
+ $PROBLEM = '{--ADMIN_GENERAL_MAIL_PROBLEM--}';
$result_data = false; // Closes Bug #58
// 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=".$_GET['u_id']."&mailid=".$id."\" target=\"_blank\">".$id."</a>";
- 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=".$_GET['u_id']."&bonusid=".$id2."\" target=\"_blank\">".$id2."</a>";
- break;
-
- default: // Problem in application detected!
- // Log the error
- DEBUG_LOG(__FILE__, __LINE__, sprintf("Invalid email type %s detected.", $type));
- break;
- }
+ // @TODO Rewrite this to includes/filter
+ switch ($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($id)), __FILE__, __LINE__);
+ $type = 'mailid'; $DATA = $id; $PROBLEM = '{--NORMAL_MAIL_PROBLEM--}';
+ $LINK = '<a href="{%url=mailid.php?userid=' . getRequestParameter('userid') . '&mailid=' . $id . '%}" target="_blank">' . $id . '</a>';
+ 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 = '{--BONUS_MAIL_PROBLEM--}';
+ $LINK = '<a href="{%url=mailid.php?userid=' . getRequestParameter('userid') . '&bonusid=' . $id2 . '%}" target="_blank">' . $id2 . '</a>';
+ break;
+
+ default: // Problem in application detected!
+ // Log the error
+ logDebugMessage(__FILE__, __LINE__, sprintf("Invalid email type %s detected.", $type));
+ break;
+ } // END - switch
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');
+ $content = SQL_FETCHARRAY($result_data);
+
+ // Fix empty subject
+ if (empty($content['subject'])) $content['subject'] = '{--DEFAULT_SUBJECT_LINE--}';
// Prepare data for the row template
$content = array(
- 'sw' => $SW,
- 'link' => $LINK,
- 'subj' => $subject,
- 'stamp' => MAKE_DATETIME($timestamp, "0"),
- 'cat' => GET_CATEGORY($cat),
+ 'link' => $LINK,
+ 'subject' => $content['subject'],
+ 'timestamp' => generateDateTime($content['timestamp'], 0),
+ 'cat_id' => $content['cat_id'],
);
// Load row template
- $OUT .= LOAD_TEMPLATE("admin_list_links_row", true, $content);
+ $OUT .= loadTemplate('admin_list_links_row', true, $content);
} else {
// Load template for error
- $OUT .= LOAD_TEMPLATE("admin_list_links_problem",
+ $OUT .= loadTemplate('admin_list_links_problem', true,
array(
- 'sw' => $SW,
'problem' => $PROBLEM,
'data' => $DATA
)
);
}
- $SW = 3 - $SW;
- }
+
+ // Free result
+ SQL_FREERESULT($result_data);
+ } // END - while
// Free memory
SQL_FREERESULT($result);
// Remember list in constant for the template
- define('__SNAME_VALUE', $sname);
- define('__FNAME_VALUE', $fname);
- define('__EMAIL_VALUE', "<a href=\"".CREATE_EMAIL_LINK($email, "user_data")."\">".$email."</a>");
- define('__EMAIL_LIST' , $OUT);
- define('__NUMS_VALUE' , $nums);
- define('__UID' , bigintval($_GET['u_id']));
+ $content['surname'] = getUserData('surname');
+ $content['family'] = getUserData('family');
+ $content['email'] = '<a href="' . generateEmailLink(getUserData('email'), 'user_data') . '">' . getUserData('email') . '</a>';
+ $content['rows'] = $OUT;
+ $content['nums'] = $nums;
+ $content['userid'] = bigintval(getRequestParameter('userid'));
// 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, ADMIN_MEMBER_LINKS_1.$_GET['u_id'].ADMIN_MEMBER_LINKS_2);
+ loadTemplate('admin_settings_saved', false, getMaskedMessage('ADMIN_MEMBER_LINKS', bigintval(getRequestParameter('userid'))));
}
} else {
// User not found
- LOAD_TEMPLATE("admin_settings_saved", false, ADMIN_MEMBER_404_1.$_GET['u_id'].ADMIN_MEMBER_404_2);
+ loadTemplate('admin_settings_saved', false, getMaskedMessage('ADMIN_MEMBER_404', bigintval(getRequestParameter('userid'))));
}
} else {
// Output selection form with all confirmed user accounts listed
- ADD_MEMBER_SELECTION_BOX();
+ addMemberSelectionBox();
}
-//
+// [EOF]
?>