X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=mailid.php;h=ffad34755551de02776a3253de1ee5eefebed2c8;hp=b1baa9f2f07978bfcef61f48de1f0107f02b2ed6;hb=a6c65fe3bac46ab95bd9e49908c53cd6e3381ff8;hpb=6c763653e88b9d10627e651ca59c7201d4b7d62b diff --git a/mailid.php b/mailid.php index b1baa9f2f0..ffad347555 100644 --- a/mailid.php +++ b/mailid.php @@ -10,9 +10,14 @@ * -------------------------------------------------------------------- * * Kurzbeschreibung : Bestaetigung von Mails * * -------------------------------------------------------------------- * - * * + * $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 * @@ -31,199 +36,207 @@ * MA 02110-1301 USA * ************************************************************************/ -// Load security stuff here (Oh, I hope this is not unsecure? Am I paranoia??? ;-) ) -require_once("inc/libs/security_functions.php"); +// Load security stuff here +require('inc/libs/security_functions.php'); -// Init "action" and "what" -global $what, $action; -$GLOBALS['what'] = ""; $GLOBALS['action'] = ""; +// Init start time +$GLOBALS['startTime'] = microtime(true); // Tell everyone we are in this module -$GLOBALS['module'] = "mailid"; $CSS = -1; +$GLOBALS['module'] = 'mailid'; +$GLOBALS['output_mode'] = -1; +$errorCode = ''; // Load the required file(s) -require("inc/config.php"); - -if (isBooleanConstantAndTrue('mxchange_installed')) { - // Is the extension active - if (!EXT_IS_ACTIVE("mailid", true)) { - // Is not activated/installed yet! - LOAD_URL("modules.php?module=index&msg=".CODE_EXTENSION_PROBLEM."&ext=mailid"); - } // END - if - - // Init - $url_uid = 0; $url_bid = 0; $url_mid = 0; - - // Secure all data - if (!empty($_GET['uid'])) $url_uid = bigintval($_GET['uid']); - if (!empty($_GET['mailid'])) $url_mid = bigintval($_GET['mailid']); - if (!empty($_GET['bonusid'])) $url_bid = bigintval($_GET['bonusid']); - - //* DEBUG: */ die("*".$url_uid."/".$url_bid."/".$url_mid."*
".print_r($FATAL, true)."
"); - - // 01 1 12 3 32 21 1 2 2 10 - if (($url_uid) > 0 && (($url_mid > 0) || ($url_bid > 0)) && (count($FATAL) == 0)) { - // Maybe he wants to confirm an email? - if ($url_mid > 0) { - // Normal-Mails - $result = SQL_QUERY_ESC("SELECT link_type FROM "._MYSQL_PREFIX."_user_links WHERE stats_id=%s AND userid=%s LIMIT 1", - array($url_mid, $url_uid), __FILE__, __LINE__); - $type = "mailid"; $DATA = $url_mid; - } elseif ($url_bid > 0) { - // Bonus-Mail - $result = SQL_QUERY_ESC("SELECT link_type FROM "._MYSQL_PREFIX."_user_links WHERE bonus_id=%s AND userid=%s LIMIT 1", - array($url_bid, $url_uid), __FILE__, __LINE__); - $type = "bonusid"; $DATA = $url_bid; - } else { - // Problem: No ID entered - LOAD_URL("index.php"); - } +require('inc/config-global.php'); + +// Set content type +setContentType('text/html'); + +// Is the extension active? +redirectOnUninstalledExtension('mailid'); + +// Init +$url_userid = 0; +$url_bid = 0; +$url_mid = 0; + +// Secure all data +if (isGetRequestElementSet('userid')) $url_userid = bigintval(getRequestElement('userid')); +if (isGetRequestElementSet('mailid')) $url_mid = bigintval(getRequestElement('mailid')); +if (isGetRequestElementSet('bonusid')) $url_bid = bigintval(getRequestElement('bonusid')); + +// 01 1 12 2 2 21 1 22 10 +if (($url_userid) > 0 && (($url_mid > 0) || ($url_bid > 0)) && (getTotalFatalErrors() == 0)) { + // Maybe he wants to confirm an email? + if ($url_mid > 0) { + // Normal-Mails + $result = SQL_QUERY_ESC("SELECT `link_type` FROM `{?_MYSQL_PREFIX?}_user_links` WHERE `stats_id`=%s AND `userid`=%s LIMIT 1", + array($url_mid, $url_userid), __FILE__, __LINE__); + $type = 'mailid'; $urlId = $url_mid; + } elseif ($url_bid > 0) { + // Bonus-Mail + $result = SQL_QUERY_ESC("SELECT `link_type` FROM `{?_MYSQL_PREFIX?}_user_links` WHERE `bonus_id`=%s AND `userid`=%s LIMIT 1", + array($url_bid, $url_userid), __FILE__, __LINE__); + $type = 'bonusid'; $urlId = $url_bid; + } else { + // Problem: No ID entered + redirectToUrl('index.php'); + } - if (SQL_NUMROWS($result) == 1) { - // Load the entry - list($ltype) = SQL_FETCHROW($result); + if (SQL_NUMROWS($result) == 1) { + // Load the entry + list($ltype) = SQL_FETCHROW($result); - // Clean result - SQL_FREERESULT($result); + // Clean result + SQL_FREERESULT($result); - switch ($ltype) - { - case "NORMAL": + // @TODO Rewrite this to a filter + switch ($ltype) + { + case 'NORMAL': // Is the stats ID valid? - $result = SQL_QUERY_ESC("SELECT pool_id, url, subject FROM "._MYSQL_PREFIX."_user_stats WHERE id=%s LIMIT 1", - array($url_mid), __FILE__, __LINE__); + $result = SQL_QUERY_ESC("SELECT pool_id, url, subject FROM `{?_MYSQL_PREFIX?}_user_stats` WHERE `id`=%s LIMIT 1", + array($url_mid), __FILE__, __LINE__); break; - case "BONUS": + case 'BONUS': // Is the bonus extension active? - if (!EXT_IS_ACTIVE("bonus")) { - // Abort here - LOAD_URL("modules.php?module=index&msg=".CODE_EXTENSION_PROBLEM."&ext=mailid"); - } // END - if + redirectOnUninstalledExtension('bonus'); // Bonus-Mails - $result = SQL_QUERY_ESC("SELECT id, url, subject FROM "._MYSQL_PREFIX."_bonus WHERE id=%s LIMIT 1", - array($url_bid), __FILE__, __LINE__); + $result = SQL_QUERY_ESC("SELECT id, url, subject FROM `{?_MYSQL_PREFIX?}_bonus` WHERE `id`=%s LIMIT 1", + array($url_bid), __FILE__, __LINE__); break; - } - if (SQL_NUMROWS($result) == 1) { - // Load data - list($pool, $URL, $EXTRA_TITLE) = SQL_FETCHROW($result); + default: // Invalid mail type + debug_report_bug('Invalid mail type ' . $ltype . ' detected.'); + break; + } - // Free result - SQL_FREERESULT($result); + if (SQL_NUMROWS($result) == 1) { + // Load data + list($pool, $URL, $title) = SQL_FETCHROW($result); - // Compile extra title - $EXTRA_TITLE = COMPILE_CODE($EXTRA_TITLE); - - // Is the user's ID unlocked? - $result = SQL_QUERY_ESC("SELECT status, gender, surname, family FROM `"._MYSQL_PREFIX."_user_data` WHERE userid=%s LIMIT 1", - array($url_uid), __FILE__, __LINE__); - if (SQL_NUMROWS($result) == 1) { - list($status, $gender, $sname, $fname) = SQL_FETCHROW($result); - SQL_FREERESULT($result); - if ($status == "CONFIRMED") { - // User has confirmed his account so we can procede... - switch ($ltype) - { - case "NORMAL": - $result = SQL_QUERY_ESC("SELECT payment_id FROM "._MYSQL_PREFIX."_user_stats WHERE pool_id=%s LIMIT 1", - array(bigintval($pool)), __FILE__, __LINE__); - if (SQL_NUMROWS($result) == 1) - { + // Free result + SQL_FREERESULT($result); + + // Set it + setExtraTitle($title); + + // Is the user's ID unlocked? + $result = SQL_QUERY_ESC("SELECT `status`, `gender`, `surname`, `family` FROM `{?_MYSQL_PREFIX?}_user_data` WHERE `userid`=%s LIMIT 1", + array($url_userid), __FILE__, __LINE__); + if (SQL_NUMROWS($result) == 1) { + list($status, $gender, $surname, $family) = SQL_FETCHROW($result); + SQL_FREERESULT($result); + if ($status == 'CONFIRMED') { + // User has confirmed his account so we can procede... + // @TODO Rewrite this to a filter + switch ($ltype) { + case 'NORMAL': + $result = SQL_QUERY_ESC("SELECT payment_id FROM `{?_MYSQL_PREFIX?}_user_stats` WHERE `pool_id`=%s LIMIT 1", + array(bigintval($pool)), __FILE__, __LINE__); + if (SQL_NUMROWS($result) == 1) { list($pay) = SQL_FETCHROW($result); - $time = GET_PAY_POINTS($pay, "time"); - $payment = GET_PAY_POINTS($pay, "payment"); - $VALID = true; - } + $time = getPaymentPoints($pay, 'time'); + $payment = getPaymentPoints($pay, 'payment'); + $isValid = true; + } // END - if // Free memory SQL_FREERESULT($result); break; - case "BONUS": - $result = SQL_QUERY_ESC("SELECT points, time FROM "._MYSQL_PREFIX."_bonus WHERE id=%s LIMIT 1", - array($url_bid), __FILE__, __LINE__); - if (SQL_NUMROWS($result) == 1) - { + case 'BONUS': + $result = SQL_QUERY_ESC("SELECT points, time FROM `{?_MYSQL_PREFIX?}_bonus` WHERE `id`=%s LIMIT 1", + array($url_bid), __FILE__, __LINE__); + if (SQL_NUMROWS($result) == 1) { list($points, $time) = SQL_FETCHROW($result); - $payment = "0.00000"; - $VALID = true; + $payment = '0.00000'; + $isValid = true; } // Free memory SQL_FREERESULT($result); break; - } - // Add header - require_once(PATH."inc/header.php"); - - // Was that mail a valid one? - if ($VALID) { - // If time is zero seconds we have a sponsor mail. 1 Second shall be set to avoid problems - if (($time == "0") && ($payment > 0)) { $URL = URL; $time = "1"; } - if (($time > 0) && (($payment > 0) || ($points > 0))) { - // He can confirm this mail! - // Export data into constants for the template - define('_UID_VALUE' , $url_uid); - define('_TYPE_VALUE', $type); - define('_DATA_VALUE', $DATA); - define('_URL_VALUE' , DEREFERER($URL)); - - // Load template - LOAD_TEMPLATE("mailid_frames"); - } else { - $msg = CODE_DATA_INVALID; - } + default: // Invalid mail type + debug_report_bug('Invalid mail type ' . $ltype . ' detected.'); + break; + } + + // Add header + loadIncludeOnce('inc/header.php'); + + // Was that mail a valid one? + if ($isValid === true) { + // If time is zero seconds we have a sponsor mail. 1 Second shall be set to avoid problems + if (($time == 0) && ($payment > 0)) { $URL = getConfig('URL'); $time = 1; } + if (($time > 0) && (($payment > 0) || ($points > 0))) { + // Export data into constants for the template + $content = array( + 'userid' => $url_userid, + 'type' => $type, + 'data' => $urlId, + 'url' => generateDerefererUrl($URL) + ); + + // Load template + loadTemplate('mailid_frames', false, $content); } else { - $msg = CODE_POSSIBLE_INVALID; + $errorCode = getCode('DATA_INVALID'); } } else { - $msg = CODE_ACCOUNT_LOCKED; + $errorCode = getCode('POSSIBLE_INVALID'); } } else { - SQL_FREERESULT($result); - $msg = CODE_USER_404; + $errorCode = getCode('ACCOUNT_' . $status); } } else { SQL_FREERESULT($result); - $msg = CODE_STATS_404; + $errorCode = getCode('USER_404'); } } else { SQL_FREERESULT($result); - $msg = CODE_ALREADY_CONFIRMED; + $errorCode = getCode('STATS_404'); } } else { - // Nothing entered - $msg = CODE_ERROR_MAILID; + SQL_FREERESULT($result); + $errorCode = getCode('ALREADY_CONFIRMED'); } +} else { + // Nothing entered + $errorCode = getCode('ERROR_MAILID'); +} - // Error code is set? - if (!empty($msg)) { - switch ($_CONFIG['mailid_error_redirect']) { - case "INDEX": // Redirect to index page - LOAD_URL("modules.php?module=index&msg=".$msg."&ext=mailid"); - break; +// Error code is set? +if (!empty($errorCode)) { + // @TODO Rewrite this to a dynamic include or so + switch (getConfig('mailid_error_redirect')) { + case 'INDEX': // Redirect to index page + redirectToUrl('modules.php?module=index&code=' . $errorCode . '&ext=mailid'); + break; + + case 'REJECT': // Redirect to rejection page + if (isExtensionActive('other')) { + // Redirect to configured URL + redirectToConfiguredUrl('reject_url'); + } else { + // Redirect to index + redirectToUrl('index.php'); + } + break; - case "REJECT": // Redirect to rejection page - LOAD_URL($_CONFIG['reject_url']); - break; + default: + logDebugMessage(__FILE__, __LINE__, sprintf("Unknown status %s detected in mailid_error_redirect.", getConfig('mailid_error_redirect'))); + redirectToUrl('modules.php?module=index&code=' . getCode('UNKNOWN_STATUS') . '&ext=mailid'); + break; + } // END - switch +} // END - if - default: - DEBUG_LOG(__FILE__, __LINE__, sprintf("Unknown status %s detected in mailid_error_redirect.", $_CONFIG['mailid_error_redirect'])); - LOAD_URL("modules.php?module=index&msg=".CODE_UNKNOWN_STATUS."&ext=mailid"); - break; - } - } else { - // Include footer - require_once(PATH."inc/footer.php"); - } -} else { - // You have to configure first! - LOAD_URL("install.php"); -} +// Include footer +loadIncludeOnce('inc/footer.php'); -// +// [EOF] ?>