Fix for 'Problem with number found. ret=0, num='
[mailer.git] / inc / modules / member / what-order.php
index 9bbe6a58f80923476f0780deca018533378001dd..9a6e74c712be87f998a5e4d66b63182a0b7e5dda 100644 (file)
@@ -1,7 +1,7 @@
 <?php
 /************************************************************************
- * MXChange v0.2.1                                    Start: 10/19/2003 *
- * ===============                              Last change: 08/26/2004 *
+ * Mailer v0.2.1-FINAL                                Start: 10/19/2003 *
+ * ===================                          Last change: 08/26/2004 *
  *                                                                      *
  * -------------------------------------------------------------------- *
  * File              : what-order.php                                   *
  * -------------------------------------------------------------------- *
  * Kurzbeschreibung  : Hier koennen Ihre Mitglieder Mails buchen        *
  * -------------------------------------------------------------------- *
- *                                                                      *
+ * $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 (ereg(basename(__FILE__), $_SERVER['PHP_SELF']))
-{
-       $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";
-       require($INC);
-}
- elseif (!IS_LOGGED_IN())
-{
-       LOAD_URL("modules.php?module=index");
-}
- elseif ((!EXT_IS_ACTIVE("order")) && (!IS_ADMIN()))
-{
-       ADD_FATAL(EXTENSION_PROBLEM_EXT_INACTIVE, "order");
-       return;
+if (!defined('__SECURITY')) {
+       die();
+} elseif (!isMember()) {
+       redirectToIndexMemberOnlyModule();
 }
 
 // Add description as navigation point
-ADD_DESCR("member", basename(__FILE__));
+addMenuDescription('member', __FILE__);
 
-$URL = ""; $id = 0;
-$whereStatement = " WHERE visible='Y'";
+if ((!isExtensionActive('order')) && (!isAdmin())) {
+       loadTemplate('admin_settings_saved', false, generateExtensionInactiveNotInstalledMessage('order'));
+       return;
+} // END - if
 
-// Set undefined array elements
-if (empty($_GET['msg']))       $_GET['msg']       = "";
-if (empty($_POST['zip']))      $_POST['zip']      = "";
-if (empty($_POST['html']))     $_POST['html']     = "";
-if (empty($_POST['receiver'])) $_POST['receiver'] = "";
-if (is_admin()) $whereStatement = "";
-
-// Add slashes to every value
-foreach($_POST as $key=>$value)
-{
-       // Skip submit buttons
-       if (($key != "data") && ($key != "frametester")) $_POST[$key] = addslashes($value);
-}
+$URL = ''; $id = '0';
+$whereStatement = " WHERE `visible`='Y'";
 
-// Minimum mails / order
-define('__MIN_VALUE', $_CONFIG['order_min']);
+// Set undefined array elements
+if (isAdmin()) $whereStatement = '';
 
 // Count unconfirmed mails
-$result_links = SQL_QUERY_ESC("SELECT id FROM "._MYSQL_PREFIX."_user_links WHERE userid=%s",
- array($GLOBALS['userid']), __FILE__, __LINE__);
-$links = SQL_NUMROWS($result_links);
-SQL_FREERESULT($result_links);
-
-// Does the user has more than 0 mails per day set?
-$HOLIDAY="userid";
-if (GET_EXT_VERSION("holiday") >= "0.1.3")
-{
-       // Fetch also holiday activation data
-       $HOLIDAY = "holiday_active";
-}
+$links = countSumTotalData(getMemberId(), 'user_links', 'id', 'userid', true);
 
-$result_mmails = SQL_QUERY_ESC("SELECT userid, receive_mails, mail_orders, ".$HOLIDAY."
-FROM "._MYSQL_PREFIX."_user_data
-WHERE userid=%s AND max_mails > 0 LIMIT 1",
- array($GLOBALS['userid']), __FILE__, __LINE__);
+// Do we have ext-holiday installed?
+// @TODO Rewrite this to a filter
+$extraColumn = 'userid';
+if ((isExtensionActive('holiday')) && (getExtensionVersion('holiday') >= '0.1.3')) {
+       // Fetch also holiday activation data
+       $extraColumn = 'holiday_active';
+} // END - if
+
+$result_mmails = SQL_QUERY_ESC("SELECT
+       `userid`, `receive_mails`, `mail_orders`, `".$extraColumn."`
+FROM
+       `{?_MYSQL_PREFIX?}_user_data`
+WHERE
+       `userid`=%s AND
+       `max_mails` > 0
+LIMIT 1",
+       array(getMemberId()), __FILE__, __LINE__);
 
 $mmails = SQL_NUMROWS($result_mmails);
 list($DMY, $MAXI, $ORDERS, $HOLIDAY) = SQL_FETCHROW($result_mmails);
+
+// Free result
 SQL_FREERESULT($result_mmails);
-if ($HOLIDAY == $DMY) $HOLIDAY='N';
 
-$ALLOWED = $MAXI - $ORDERS;
-if ($_CONFIG['order_max_full'] == "MAX") $ALLOWED = $MAXI;
+// Fix non-existent ext-holidy
+if ($HOLIDAY == $DMY) $HOLIDAY = 'N';
 
-// Check HTML extension
-$HTML_EXT = EXT_IS_ACTIVE("html_mail");
+$ALLOWED = $MAXI - $ORDERS;
+if (getConfig('order_max_full') == 'MAX') $ALLOWED = $MAXI;
 
 // Now check his points amount
-$result_p = SQL_QUERY_ESC("SELECT SUM(points) FROM "._MYSQL_PREFIX."_user_points WHERE userid=%s",
- array($GLOBALS['userid']), __FILE__, __LINE__);
-
-$TOTAL = "0";
-if (SQL_NUMROWS($result_p) > 0)
-{
-       // Load points
-       list($TOTAL) = SQL_FETCHROW($result_p);
-       SQL_FREERESULT($result_p);
-
-       // And subtract his used points...
-       $result_p = SQL_QUERY_ESC("SELECT used_points FROM "._MYSQL_PREFIX."_user_data WHERE userid=%s LIMIT 1",
-        array($GLOBALS['userid']), __FILE__, __LINE__);
-
-       list($p) = SQL_FETCHROW($result_p);
-       SQL_FREERESULT($result_p);
-       $TOTAL -= $p;
-
-       // Add (maybe) missing three zeros
-       if (!ereg(".", $TOTAL)) $TOTAL .= ".00000";
-}
+$total = countSumTotalData(getMemberId(), 'user_points', 'points') - countSumTotalData(getMemberId(), 'user_data', 'used_points');;
 
-if (($HOLIDAY == "Y") && (GET_EXT_VERSION("holiday") >= "0.1.3"))
-{
+if (($HOLIDAY == 'Y') && (getExtensionVersion('holiday') >= '0.1.3')) {
        // Holiday is active!
-       SQL_FREERESULT($result_p);
-       LOAD_TEMPLATE("admin_settings_saved", false, HOLIDAY_ORDER_NOT_POSSIBLE);
-}
- elseif ((!empty($_POST['frametester'])) && ($ALLOWED > 0) && ($_POST['receiver'] > 0))
-{
+       loadTemplate('admin_settings_saved', false, getMessage('HOLIDAY_ORDER_NOT_POSSIBLE'));
+} elseif ((isPostRequestParameterSet('frametester')) && ($ALLOWED > 0) && (postRequestParameter('receiver') > 0)) {
        // Continue with the frametester, we first need to store the data temporary in the pool
        //
        // First we would like to store the data and get it's pool position back...
-       $result = SQL_QUERY_ESC("SELECT id, data_type FROM "._MYSQL_PREFIX."_pool WHERE sender=%s AND url='%s' AND timestamp > %s LIMIT 1",
-        array($GLOBALS['userid'], $_POST['url'], bigintval(time() - $_CONFIG['url_tlock'])), __FILE__, __LINE__);
-
-       $type = "TEMP"; $id = "0";
-       if (SQL_NUMROWS($result) == 1)
-       {
+       $result = SQL_QUERY_ESC("SELECT `id`, `data_type`
+FROM
+       `{?_MYSQL_PREFIX?}_pool`
+WHERE
+       `sender`=%s AND
+       `url`='%s' AND
+       `timestamp` > (UNIX_TIMESTAMP() - %s)
+LIMIT 1",
+               array(
+                       getMemberId(),
+                       postRequestParameter('url'),
+                       getConfig('url_tlock')
+               ), __FILE__, __LINE__);
+
+       $type = 'TEMP'; $id = '0';
+       if (SQL_NUMROWS($result) == 1) {
+               // Load id and mail type
                list($id, $type) = SQL_FETCHROW($result);
-               SQL_FREERESULT($result);
-       }
-       if ($type == "TEMP")
-       {
+       } // END - if
+
+       // Free result
+       SQL_FREERESULT($result);
+
+       if ($type == 'TEMP') {
                // No entry found, so we need to check out the stats table as well... :)
                // We have to add that suff here, now we continue WITHOUT checking and check the text and subject against some filters
-               $URL = "";
-               if ($_CONFIG['test_text'] == "Y")
-               {
+               $URL = '';
+               if (getConfig('allow_url_in_text') == 'Y') {
                        // Test submitted text against some filters (length, URLs in text etc.)
-                       if ((strpos(strtolower($_POST['text']), "https://") > -1) || (strpos(strtolower($_POST['text']), "http://") > -1) || (strpos(strtolower($_POST['text']), "www") > -1))
-                       {
+                       if ((strpos(strtolower(postRequestParameter('text')), 'https://') > -1) || (strpos(strtolower(postRequestParameter('text')), 'http://') > -1) || (strpos(strtolower(postRequestParameter('text')), "www") > -1)) {
                                // URL found!
-                               $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_URL_FOUND;
-                       }
-                       $TEST = str_replace("\n", "", str_replace("\r", "", addslashes($_POST['text'])));
-                       if (strlen($TEST) > $_CONFIG['max_tlength'])
-                       {
+                               $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('URL_FOUND');
+                       } // END - if
+
+                       // Remove new-line and carriage-return characters
+                       $TEST = str_replace("\n", '', str_replace("\r", '', postRequestParameter('text')));
+
+                       // Text length within allowed length?
+                       if (strlen($TEST) > getConfig('max_tlength')) {
                                // Text is too long!
-                               $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_OVERLENGTH;
-                       }
-               }
+                               $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('OVERLENGTH');
+                       } // END - if
+               } // END - if
+
                // Shall I test the subject line against URLs?
-               if ($_CONFIG['test_subj'] == "Y")
-               {
+               if (getConfig('allow_url_in_subject') == 'Y') {
                        // Check the subject line for issues
-                       $_POST['subject'] = str_replace("\\", "[nl]", substr($_POST['subject'], 0, 200));
-                       if ((strpos(strtolower($_POST['subject']), "http://") > -1) || (strpos(strtolower($_POST['subject']), "www") > -1))
-                       {
+                       setPostRequestParameter('subject', str_replace("\\", '[nl]', substr(postRequestParameter('subject'), 0, 200)));
+                       if ((strpos(strtolower(postRequestParameter('subject')), 'http://') > -1) || (strpos(strtolower(postRequestParameter('subject')), "www") > -1)) {
                                // URL in subject found
-                               $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_SUBJ_URL;
-                       }
-               }
+                               $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('SUBJ_URL');
+                       } // END - if
+               } // END - if
+
                // And shall I check that his URL is not in the black list?
-               if ($_CONFIG['url_blacklist'] == "Y")
-               {
+               if (getConfig('url_blacklist') == 'Y') {
                        // Ok, I do that for you know...
-                       $result = SQL_QUERY_ESC("SELECT timestamp FROM "._MYSQL_PREFIX."_url_blist WHERE url='%s' LIMIT 1",
-                        array($_POST['url']), __FILE__, __LINE__);
+                       $result = SQL_QUERY_ESC("SELECT UNIX_TIMESTAMP(`timestamp`) AS tstamp FROM `{?_MYSQL_PREFIX?}_url_blacklist` WHERE `url`='%s' LIMIT 1",
+                               array(postRequestParameter('url')), __FILE__, __LINE__);
 
-                       if (SQL_NUMROWS($result) == 1)
-                       {
+                       if (SQL_NUMROWS($result) == 1) {
                                // Jupp, we got one listed
                                list($blist) = SQL_FETCHROW($result);
-                               SQL_FREERESULT($result);
-                               $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_BLIST_URL."&blist=".$blist;
-                       }
-               }
-               if (($_POST['receiver'] < $_CONFIG['order_min']) && (!IS_ADMIN()))
-               {
+
+                               // Create redirect-URL
+                               $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('BLIST_URL') . '&amp;blist=' . $blist;
+                       } // END - if
+
+                       // Free result
+                       SQL_FREERESULT($result);
+               } // END - if
+
+               // Enougth receivers entered?
+               if ((postRequestParameter('receiver') < getConfig('order_min')) && (!isAdmin())) {
                        // Less than allowed receivers entered!
-                       $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_MORE_RECEIVERS3;
-               }
+                       $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('MORE_RECEIVERS3');
+               } // END - if
 
                // Validate URL
-               if (!VALIDATE_URL($_POST['url']))
-               {
+               if (!isUrlValid(postRequestParameter('url'))) {
                        // URL is invalid!
-                       $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_INVALID_URL;
-               }
+                       $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('INVALID_URL');
+               } // END - if
 
                // Probe for HTML extension
-               if ($HTML_EXT)
-               {
-                       if ($_POST['html'] == "Y")
-                       {
+               if (isExtensionActive('html_mail')) {
+                       // HTML or regular text mail?
+                       if (postRequestParameter('html') == 'Y') {
                                // Chek for valid HTML tags
-                               $_POST['text'] = HTML_CHECK_TAGS($_POST['text']);
+                               setPostRequestParameter('text', checkHtmlTags(postRequestParameter('text')));
 
                                // Maybe invalid tags found?
-                               if (empty($_POST['text'])) $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_INVALID_TAGS."&id=".$id;
-                       }
-                        else
-                       {
+                               if (!isPostRequestParameterSet('text')) $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('INVALID_TAGS')."&amp;id=".$id;
+                       } else {
                                // Remove any HTML code
-                               $_POST['text'] = str_replace("<", "{OPEN_HTML}", str_replace(">", "{CLOSE_HTML}", $_POST['text']));
+                               setPostRequestParameter('text', str_replace('<', '{OPEN_HTML}', str_replace('>', '{CLOSE_HTML}', postRequestParameter('text'))));
                        }
-               }
-       }
-        elseif (!IS_ADMIN())
-       {
+               } // END - if
+
+               // Is mail type set?
+               if ((!isPostRequestParameterSet('mail_type')) || (postRequestParameter('mail_type') < 1)) {
+                       // Not correctly set
+                       $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('NO_MAIL_TYPE');
+               } // END - if
+       } elseif (!isAdmin()) {
                // He has already sent a mail within a specific time
-               $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_URL_TLOCK."&id=".$id;
+               $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('URL_TLOCK') . '&amp;id=' . $id;
        }
-       if (empty($URL))
-       {
+
+       // Still no error?
+       if (empty($URL)) {
                // Check if category and number of receivers is okay
-               $ADD = "";
-               if (($_CONFIG['order_multi_page'] == "Y") && (!empty($_POST['zip']))) $ADD = "AND d.zip LIKE '".bigintval($_POST['zip'])."{PER}'";
+               $add = '';
+               if ((getConfig('order_multi_page') == 'Y') && (isPostRequestParameterSet('zip')) && (postRequestParameter('zip') != '')) {
+                       // Choose recipients by ZIP code
+                       $add = " AND d.zip LIKE '".bigintval(postRequestParameter('zip'))."{PER}'";
+               } // END - if
 
                // Check for userids
-               $result = SQL_QUERY_ESC("SELECT DISTINCT c.userid FROM "._MYSQL_PREFIX."_user_cats AS c
-LEFT JOIN "._MYSQL_PREFIX."_user_data AS d
-ON c.userid=d.userid
-WHERE c.cat_id=%s AND c.userid != '%s' AND d.status='CONFIRMED' AND d.receive_mails > 0
-".$ADD."
-ORDER BY d.%s %s",
- array(
-       bigintval($_POST['cat']),
-       $GLOBALS['userid'],
-       $_CONFIG['order_select'],
-       $_CONFIG['order_mode'],
- ), __FILE__, __LINE__);
+               $result = SQL_QUERY_ESC("SELECT
+       c.userid
+FROM
+       `{?_MYSQL_PREFIX?}_user_cats` AS c
+LEFT JOIN
+       `{?_MYSQL_PREFIX?}_user_data` AS d
+ON
+       c.userid=d.userid
+WHERE
+       c.cat_id=%s AND
+       c.userid != '%s' AND
+       d.`status`='CONFIRMED' AND
+       d.receive_mails > 0
+       ".$add."
+ORDER BY
+       d.%s %s",
+                       array(
+                               bigintval(postRequestParameter('cat')),
+                               getMemberId(),
+                               getConfig('order_select'),
+                               getConfig('order_mode'),
+                       ), __FILE__, __LINE__);
 
                // Do we enougth receivers left?
-               if (SQL_NUMROWS($result) >= $_POST['receiver'])
-               {
-                       // Check for holiday extensions
-                       $HOLIDAY = false;
-                       if (GET_EXT_VERSION("holiday") >= "0.1.3")
-                       {
-                               // Include checking for users in holiday
-                               $HOLIDAY = true;
-                       }
-
+               if (SQL_NUMROWS($result) >= postRequestParameter('receiver')) {
                        // Load receivers from database
-                       $TEST = array(); $cnt = 0;
-                       while (list($REC) = SQL_FETCHROW($result))
-                       {
-                               if ($HOLIDAY)
-                               {
+                       $TEST = array(); $cnt = '0';
+                       while ($holidayContent = SQL_FETCHARRAY($result)) {
+                               if (getExtensionVersion('holiday') >= '0.1.3') {
                                        // Check for his holiday status
-                                       $result_holiday = SQL_QUERY_ESC("SELECT id FROM "._MYSQL_PREFIX."_user_holidays
-WHERE userid=%s AND holiday_start < ".time()." AND holiday_end > ".time()." LIMIT 1",
- array(bigintval($REC)), __FILE__, __LINE__);
-                                       if (SQL_NUMROWS($result_holiday) == 1) $REC = 0; // Exclude user who are in holiday
+                                       $result_holiday = SQL_QUERY_ESC("SELECT
+       `id`
+FROM
+       `{?_MYSQL_PREFIX?}_user_holidays`
+WHERE
+       `userid`=%s AND `holiday_start` < UNIX_TIMESTAMP() AND `holiday_end` > UNIX_TIMESTAMP()
+LIMIT 1",
+                                               array($holidayContent['userid']), __FILE__, __LINE__);
+                                       if (SQL_NUMROWS($result_holiday) == 1) $holidayContent['userid'] = '0'; // Exclude user who are in holiday
 
                                        // Free memory
                                        SQL_FREERESULT($result_holiday);
-                               }
+                               } // END - if
 
-                               if ($REC > 0)
-                               {
+                               if ($holidayContent['userid'] > 0) {
                                        // Add receiver
-                                       $TEST[] = $REC;
+                                       $TEST[] = $holidayContent['userid'];
                                        $cnt++;
-                               }
-                       }
+                               } // END - if
+                       } // END - while
 
                        // Free memory
                        SQL_FREERESULT($result);
 
                        // Implode array into string for the sending pool
-                       $RECEIVER = implode($TEST, ";");
+                       $receiver = implode($TEST, ';');
 
                        // Count array for maximum sent
-                       $MAX_SEND = count($TEST);
+                       $content['target_send'] = count($TEST);
 
                        // Update receiver list
-                       $result = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_user_data SET receive_mails=receive_mails-1 WHERE userid IN (%s) LIMIT %s",
-                        array(str_replace(";", ", ", $RECEIVER), $MAX_SEND), __FILE__, __LINE__);
+                       SQL_QUERY_ESC("UPDATE `{?_MYSQL_PREFIX?}_user_data` SET `receive_mails`=`receive_mails`-1 WHERE `userid` IN (%s) LIMIT %s",
+                               array(convertReceivers($receiver), $content['target_send']), __FILE__, __LINE__);
 
                        // Is calculated max receivers larger than wanted receivers then reset it
-                       if ($MAX_SEND > $_POST['receiver']) $MAX_SEND = $_POST['receiver'];
+                       if ($content['target_send'] > postRequestParameter('receiver')) $content['target_send'] = bigintval(postRequestParameter('receiver'));
 
                        // Calculate used points
-                       $USED = $MAX_SEND * GET_PAY_POINTS(bigintval($_POST['type']));
+                       $USED = $content['target_send'] * getPaymentPoints(bigintval(postRequestParameter('mail_type')));
+
+                       // Fix empty zip code
+                       if (!isPostRequestParameterSet('zip')) setPostRequestParameter('zip', 0);
 
                        // Check if he has enougth points for this order and selected more than 0 receivers
-                       if (($USED > 0) && ($USED <= $TOTAL) && ($MAX_SEND > 0))
-                       {
+                       if (($USED > 0) && ($USED <= $total) && ($content['target_send'] > 0)) {
                                // Gettings points is okay, so we can add $USED later from
-                               $TIME = time();
-                               if (($id == "0") || ($type != "TEMP"))
-                               {
+                               if (($id == '0') || ($type != 'TEMP')) {
                                        // New order
-                                       $id = 0;
-                                       if ($HTML_EXT)
-                                       {
+                                       $id = '0';
+                                       if (isExtensionActive('html_mail')) {
                                                // HTML extension is active
-                                               $result = SQL_QUERY_ESC("INSERT INTO "._MYSQL_PREFIX."_pool (sender, subject, text, receivers, payment_id, data_type, timestamp, url, cat_id, target_send, zip, html_msg)
- VALUES ('%s', '%s', '%s', '%s', '%s', 'TEMP', '%s', '%s', '%s', '%s', '%s', '%s')",
-array(
-       $GLOBALS['userid'],
-       addslashes($_POST['subject']),
-       addslashes($_POST['text']),
-       $RECEIVER,
-       bigintval($_POST['type']),
-       $TIME,
-       $_POST['url'],
-       bigintval($_POST['cat']),
-       $MAX_SEND,
-       bigintval($_POST['zip']),
-       $_POST['html']
-), __FILE__, __LINE__);
-                                       }
-                                        else
-                                       {
+                                               SQL_QUERY_ESC("INSERT INTO `{?_MYSQL_PREFIX?}_pool` (`sender`, `subject`, `text`, `receivers`, `payment_id`, `data_type`, `timestamp`, `url`, `cat_id`, `target_send`, `zip`, `html_msg`)
+VALUES (%s,'%s','%s','%s','%s','TEMP',UNIX_TIMESTAMP(),'%s',%s,%s,%s,'%s')",
+                                                       array(
+                                                               getMemberId(),
+                                                               postRequestParameter('subject'),
+                                                               postRequestParameter('text'),
+                                                               $receiver,
+                                                               bigintval(postRequestParameter('mail_type')),
+                                                               postRequestParameter('url'),
+                                                               bigintval(postRequestParameter('cat')),
+                                                               $content['target_send'],
+                                                               bigintval(postRequestParameter('zip'), true false),
+                                                               postRequestParameter('html')
+                                                       ), __FILE__, __LINE__);
+                                       } else {
                                                // No HTML extension is active
-                                               $result = SQL_QUERY_ESC("INSERT INTO "._MYSQL_PREFIX."_pool (sender, subject, text, receivers, payment_id, data_type, timestamp, url, cat_id, target_send, zip)
- VALUES ('%s', '%s', '%s', '%s', '%s', 'TEMP', '%s', '%s', '%s', '%s', '%s')",
-array(
-       $GLOBALS['userid'],
-       addslashes($_POST['subject']),
-       addslashes($_POST['text']),
-       $RECEIVER,
-       bigintval($_POST['type']),
-       $TIME,
-       $_POST['url'],
-       bigintval($_POST['cat']),
-       $MAX_SEND,
-       bigintval($_POST['zip']),
-), __FILE__, __LINE__);
+                                               SQL_QUERY_ESC("INSERT INTO `{?_MYSQL_PREFIX?}_pool` (`sender`, `subject`, `text`, `receivers`, `payment_id`, `data_type`, `timestamp`, `url`, `cat_id`, `target_send`, `zip`)
+VALUES (%s,'%s','%s','%s','%s','TEMP',UNIX_TIMESTAMP(),'%s',%s,%s,%s)",
+                                                       array(
+                                                               getMemberId(),
+                                                               postRequestParameter('subject'),
+                                                               postRequestParameter('text'),
+                                                               $receiver,
+                                                               bigintval(postRequestParameter('mail_type')),
+                                                               postRequestParameter('url'),
+                                                               bigintval(postRequestParameter('cat')),
+                                                               $content['target_send'],
+                                                               bigintval(postRequestParameter('zip'), true false),
+                                                       ), __FILE__, __LINE__);
                                        }
-                               }
-                                else
-                               {
+                               } else {
                                        // Change current order
-                                       if ($HTML_EXT)
-                                       {
+                                       if (isExtensionActive('html_mail')) {
                                                // HTML extension is active
-                                               $result = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_pool SET
-subject='%s',
-text='%s',
-receivers='%s',
-payment_id=%s,
-timestamp=UNIX_TIMESTAMP(),
-url='%s',
-cat_id=%s,
-target_send=%s,
-zip=%s,
-html_msg='%s'
-WHERE id=%s LIMIT 1",
-array(
-       $_POST['subject'],
-       $_POST['text'],
-       $RECEIVER,
-       bigintval($_POST['type']),
-       $_POST['url'],
-       bigintval($_POST['cat']),
-       $MAX_SEND,
-       bigintval($_POST['zip']),
-       $_POST['html'],
-       bigintval($id)
-), __FILE__, __LINE__);
-                                       }
-                                        else
-                                       {
+                                               SQL_QUERY_ESC("UPDATE
+       `{?_MYSQL_PREFIX?}_pool`
+SET
+       `subject`='%s',
+       `text`='%s',
+       `receivers`='%s',
+       `payment_id`=%s,
+       `timestamp`=UNIX_TIMESTAMP(),
+       `url`='%s',
+       `cat_id`=%s,
+       `target_send`=%s,
+       `zip`=%s,
+       `html_msg`='%s'
+WHERE
+       `id`=%s
+LIMIT 1",
+                                                       array(
+                                                               postRequestParameter('subject'),
+                                                               postRequestParameter('text'),
+                                                               $receiver,
+                                                               bigintval(postRequestParameter('mail_type')),
+                                                               postRequestParameter('url'),
+                                                               bigintval(postRequestParameter('cat')),
+                                                               $content['target_send'],
+                                                               bigintval(postRequestParameter('zip')),
+                                                               postRequestParameter('html'),
+                                                               bigintval($id)
+                                                       ), __FILE__, __LINE__);
+                                       } else {
                                                // No HTML extension is active
-                                               $result = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_pool SET
-subject='%s',
-text='%s',
-receivers='%s',
-payment_id=%s,
-timestamp=UNIX_TIMESTAMP(),
-url='%s',
-cat_id=%s,
-target_send=%s,
-zip=%s
-WHERE id=%s LIMIT 1",
-array(
-       $_POST['subject'],
-       $_POST['text'],
-       $RECEIVER,
-       bigintval($_POST['type']),
-       $_POST['url'],
-       bigintval($_POST['cat']),
-       $MAX_SEND,
-       bigintval($_POST['zip']),
-       bigintval($id)
-), __FILE__, __LINE__);
+                                               SQL_QUERY_ESC("UPDATE
+       `{?_MYSQL_PREFIX?}_pool`
+SET
+       `subject`='%s',
+       `text`='%s',
+       `receivers`='%s',
+       `payment_id`=%s,
+       `timestamp`=UNIX_TIMESTAMP(),
+       `url`='%s',
+       `cat_id`=%s,
+       `target_send`=%s,
+       `zip`=%s
+WHERE
+       `id`=%s
+LIMIT 1",
+                                                       array(
+                                                               postRequestParameter('subject'),
+                                                               postRequestParameter('text'),
+                                                               $receiver,
+                                                               bigintval(postRequestParameter('mail_type')),
+                                                               postRequestParameter('url'),
+                                                               bigintval(postRequestParameter('cat')),
+                                                               $content['target_send'],
+                                                               bigintval(postRequestParameter('zip')),
+                                                               bigintval($id)
+                                                       ), __FILE__, __LINE__);
                                        }
                                }
 
-                               // Do we need to get the ID number?
-                               if ($id == 0) {
+                               // Do we need to get the id number?
+                               if ($id == '0') {
                                        // Order is placed as temporary. We need to get it's id for the frametester
-                                       $result = SQL_QUERY_ESC("SELECT id FROM "._MYSQL_PREFIX."_pool WHERE sender=%s AND subject='%s' AND payment_id=%s AND data_type='TEMP' AND timestamp=%s LIMIT 1",
-                                       array(
-                                               $GLOBALS['userid'],
-                                               $_POST['subject'],
-                                               bigintval($_POST['type']),
-                                               $TIME
-                                       ), __FILE__, __LINE__);
-
+                                       $result = SQL_QUERY_ESC("SELECT `id` FROM `{?_MYSQL_PREFIX?}_pool` WHERE `sender`=%s AND `subject`='%s' AND `payment_id`=%s AND `data_type`='TEMP' AND `timestamp`=UNIX_TIMESTAMP() LIMIT 1",
+                                               array(
+                                                       getMemberId(),
+                                                       postRequestParameter('subject'),
+                                                       bigintval(postRequestParameter('mail_type'))
+                                               ), __FILE__, __LINE__);
+
+                                       // Get pool id
                                        list($id) = SQL_FETCHROW($result);
+
+                                       // Free result
                                        SQL_FREERESULT($result);
-                               }
+                               } // END - if
 
-                               // ID is received so we can redirect the user, used points will be added when he send's out the mail
-                               $URL = URL."/modules.php?module=frametester&amp;order=".$id."";
-                       }
-                        elseif ($MAX_SEND == 0)
-                       {
+                               // id is received so we can redirect the user, used points will be added when he send's out the mail
+                               $URL = 'modules.php?module=frametester&amp;order=' . $id;
+                       } elseif ($content['target_send'] == '0') {
                                // Not enougth receivers found which can receive mails
-                               $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_MORE_RECEIVERS2;
-                       }
-                        else
-                       {
+                               $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('MORE_RECEIVERS2');
+                       } else {
                                // No enougth points left!
-                               $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_MORE_POINTS;
+                               $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('MORE_POINTS');
                        }
-               }
-                else
-               {
+               } else  {
                        // Ordered more mails than he can send in this category
-                       $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_NO_RECS_LEFT;
+                       $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('NO_RECS_LEFT');
                }
        }
-}
- elseif ($_POST['receiver'] == "0")
-{
+} elseif (postRequestParameter('receiver') == '0') {
        // Not enougth receivers selected
-       $URL = URL."/modules.php?module=login&amp;what=order&amp;msg=".CODE_MORE_RECEIVERS1;
-}
- elseif (($ALLOWED == 0) && ($_CONFIG['order_max_full'] == "ORDER"))
-{
+       $URL = 'modules.php?module=login&amp;what=order&amp;code=' . getCode('MORE_RECEIVERS1');
+} elseif (($ALLOWED == '0') && (getConfig('order_max_full') == 'ORDER')) {
        // No more mail orders allowed
-       LOAD_TEMPLATE("admin_settings_saved", false, MEMBER_ORDER_ALLOWED_EXHAUSTED);
-}
- elseif (($links < $_CONFIG['unconfirmed']) && ($mmails == "1"))
-{
+       loadTemplate('admin_settings_saved', false, getMessage('MEMBER_ORDER_ALLOWED_EXHAUSTED'));
+} elseif (($links < getConfig('unconfirmed')) && ($mmails == 1)) {
        // Display order form
-       $result_cats = SQL_QUERY("SELECT id, cat FROM "._MYSQL_PREFIX."_cats".$whereStatement." ORDER BY sort", __FILE__, __LINE__);
-       if (SQL_NUMROWS($result_cats) > 0)
-       {
-               if ($TOTAL > 0)
-               {
+       $result_cats = SQL_QUERY("SELECT
+       `id`, `cat`
+FROM
+       `{?_MYSQL_PREFIX?}_cats`
+".$whereStatement."
+ORDER BY
+       `sort` ASC", __FILE__, __LINE__);
+       if (SQL_NUMROWS($result_cats) > 0) {
+               if ($total > 0) {
                        // Initialize array...
-                       $CATS = array(
-                               'id'   => array(),
-                               'name' => array(),
-                               'uids' => array()
+                       $categories = array(
+                               'id'      => array(),
+                               'name'    => array(),
+                               'userids' => array()
                        );
 
                        // Enable HTML checking
-                       $HTML = ""; $HOLIDAY = false; $HOL_STRING = "";
-                       if (($HTML_EXT) && ($_POST['html'] == "Y")) $HTML = " AND html='Y'";
-                       if (GET_EXT_VERSION("holiday") >= "0.1.3")
-                       {
+                       // @TODO Rewrite this to a filter
+                       $HTML = ''; $HOL_STRING = '';
+                       if ((isExtensionActive('html_mail')) && (postRequestParameter('html') == 'Y')) $HTML = " AND `html`='Y'";
+                       if (isExtensionInstalledAndNewer('holiday', '0.1.3')) {
                                // Extension's version is fine
-                               $HOLIDAY = true; $HOL_STRING = " AND holiday_active='N'";
-                       }
+                               $HOL_STRING = " AND `holiday_active`='N'";
+                       } // END - if
 
                        // ... and begin loading stuff
-                       while (list($id, $cat) = SQL_FETCHROW($result_cats))
-                       {
-                               $CATS['id'][]   = bigintval($id);
-                               $CATS['name'][] = $cat;
+                       while ($categoriesContent = SQL_FETCHARRAY($result_cats)) {
+                               $categories['id'][]   = bigintval($categoriesContent['id']);
+                               $categories['name'][] = $categoriesContent['cat'];
 
                                // Select users in current category
-                               $result_uids = SQL_QUERY_ESC("SELECT userid FROM "._MYSQL_PREFIX."_user_cats WHERE cat_id=%s AND userid != '%s' ORDER BY userid",
-                                array(bigintval($id), $GLOBALS['userid']), __FILE__, __LINE__);
+                               $result_userids = SQL_QUERY_ESC("SELECT `userid` FROM `{?_MYSQL_PREFIX?}_user_cats` WHERE `cat_id`=%s AND `userid` != '%s' ORDER BY `userid` ASC",
+                                       array(bigintval($categoriesContent['id']), getMemberId()), __FILE__, __LINE__);
 
-                               $uid_cnt = "0";
-                               while (list($ucat) = SQL_FETCHROW($result_uids))
-                               {
+                               $userid_cnt = '0';
+                               while (list($ucat) = SQL_FETCHROW($result_userids)) {
                                        // Check for holiday system
                                        $HOL_ACTIVE = false;
-                                       if ($HOLIDAY)
-                                       {
+                                       if (getExtensionVersion('holiday') >= '0.1.3') {
                                                // Check user's holiday status
-                                               $result_holiday = SQL_QUERY_ESC("SELECT DISTINCT d.userid FROM "._MYSQL_PREFIX."_user_data AS d
-LEFT JOIN "._MYSQL_PREFIX."_user_holidays AS h
-ON d.userid=h.userid
-WHERE d.userid=%s AND d.receive_mails > 0 AND d.status='CONFIRMED' AND d.holiday_active='Y'
-AND h.holiday_start < ".time()." AND h.holiday_end > ".time()."
-LIMIT 1", array(bigintval($ucat)), __FILE__, __LINE__);
-                                               if (SQL_NUMROWS($result_holiday) == 1)
-                                               {
-                                                       // Holiday is active!
-                                                       $HOL_ACTIVE = true;
-                                               }
+                                               $result_holiday = SQL_QUERY_ESC("SELECT
+       d.userid FROM `{?_MYSQL_PREFIX?}_user_data` AS d
+LEFT JOIN
+       `{?_MYSQL_PREFIX?}_user_holidays` AS h
+ON
+       d.userid=h.userid
+WHERE
+       d.userid=%s AND
+       d.receive_mails > 0 AND
+       d.`status`='CONFIRMED' AND
+       d.`holiday_active`='Y' AND
+       h.holiday_start < UNIX_TIMESTAMP() AND
+       h.holiday_end > UNIX_TIMESTAMP()
+LIMIT 1",
+                                                       array(bigintval($ucat)), __FILE__, __LINE__);
+
+                                               // Is holiday is active?
+                                               $HOL_ACTIVE = (SQL_NUMROWS($result_holiday) == 1);
 
                                                // Free memory
                                                SQL_FREERESULT($result_holiday);
-                                       }
+                                       } // END - if
 
-                                       if (!$HOL_ACTIVE)
-                                       {
+                                       if ($HOL_ACTIVE === false) {
                                                // Check if the user want's to receive mails?
-                                               $result_ver = SQL_QUERY_ESC("SELECT zip FROM "._MYSQL_PREFIX."_user_data WHERE userid=%s".$HTML." AND receive_mails > 0 AND status='CONFIRMED' LIMIT 1",
-                                                array(bigintval($ucat)), __FILE__, __LINE__);
+                                               $result_ver = SQL_QUERY_ESC("SELECT `zip` FROM `{?_MYSQL_PREFIX?}_user_data` WHERE `userid`=%s".$HTML." AND `receive_mails` > 0 AND `status`='CONFIRMED' LIMIT 1",
+                                                       array(bigintval($ucat)), __FILE__, __LINE__);
 
-                                               if ((SQL_NUMROWS($result_ver) == 1) && (!empty($_POST['zip'])) && ($_CONFIG['order_multi_page'] == "Y"))
-                                               {
+                                               if ((SQL_NUMROWS($result_ver) == 1) && (isPostRequestParameterSet('zip')) && (getConfig('order_multi_page') == 'Y')) {
+                                                       // Get zip code
                                                        list($zip) = SQL_FETCHROW($result_ver);
-                                                       SQL_FREERESULT($result_ver);
-                                                       if (substr($zip, 0, strlen($_POST['zip'])) == $_POST['zip'])
-                                                       {
+                                                       if (substr($zip, 0, strlen(postRequestParameter('zip'))) == postRequestParameter('zip')) {
                                                                // Ok, ZIP part is found
-                                                               $uid_cnt++;
-                                                       }
-                                               }
-                                                else
-                                               {
+                                                               $userid_cnt++;
+                                                       } // END - if
+                                               } else {
                                                        // Count numbers up!
-                                                       $uid_cnt += SQL_NUMROWS($result_ver);
+                                                       $userid_cnt += SQL_NUMROWS($result_ver);
                                                }
-                                       }
-                               }
+
+                                               // Free result
+                                               SQL_FREERESULT($result_ver);
+                                       } // END - if
+                               } // END - while
 
                                // Free memory
-                               SQL_FREERESULT($result_uids);
-                               $CATS['uids'][] = $uid_cnt;
-                       }
+                               SQL_FREERESULT($result_userids);
+                               $categories['userids'][] = $userid_cnt;
+                       } // END - while
 
                        // Free memory
                        SQL_FREERESULT($result_cats);
 
                        // Now we need to load the mail types...
-                       $result = SQL_QUERY("SELECT id, price, payment, mail_title FROM "._MYSQL_PREFIX."_payments ORDER BY payment", __FILE__, __LINE__);
-
-                       $typeS = array();
-                       if (SQL_NUMROWS($result) > 0)
-                       {
-                               // Check for message ID in URL
-                               $MSG = "";
-                               switch ($_GET['msg'])
-                               {
-                               case CODE_URL_TLOCK:
-                                       $result = SQL_QUERY_ESC("SELECT timestamp FROM "._MYSQL_PREFIX."_pool WHERE id=%s LIMIT 1",
-                                        array(bigintval($_GET['id'])), __FILE__, __LINE__);
-
-                                       // Load timestamp from last order
-                                       list($LORDER) = SQL_FETCHROW($result);
-                                       $LORDER = MAKE_DATETIME($LORDER, "1");
-
-                                       // Free memory
-                                       SQL_FREERESULT($result);
-
-                                       // Calculate hours...
-                                       $STD = round($_CONFIG['url_tlock'] / 60 / 60);
-
-                                       // Minutes...
-                                       $MIN = round(($_CONFIG['url_tlock'] - $STD * 60 * 60) / 60);
-
-                                       // And seconds
-                                       $SEC = $_CONFIG['url_tlock'] - $STD * 60 * 60 - $MIN * 60;
+                       $result = SQL_QUERY("SELECT `id`, `price`, `payment`, `mail_title` FROM `{?_MYSQL_PREFIX?}_payments` ORDER BY `payment` ASC", __FILE__, __LINE__);
 
-                                       // Finally contruct the message
-                                       $MSG = MEMBER_URL_TIME_LOCK."<br />".CONFIG_URL_TLOCK." ".$STD." ".
-                                               HOURS.", ".$MIN." ".MINS." "._AND." ".$SEC." ".SECS."<br />".
-                                               MEMBER_LAST_TLOCK.": ".$LORDER;
-                                       break;
+                       $types = array();
+                       if (SQL_NUMROWS($result) > 0) {
+                               // Check for message id in URL
+                               $message = getMessageFromErrorCode(getRequestParameter('code'));
 
-                               case CODE_OVERLENGTH:
-                                       $MSG = MEMBER_TEXT_OVERLENGTH;
-                                       break;
-
-                               case CODE_URL_FOUND:
-                                       $MSG = MEMBER_TEXT_CONTAINS_URL;
-                                       break;
-
-                               case CODE_SUBJ_URL:
-                                       $MSG = MEMBER_SUBJ_CONTAINS_URL;
-                                       break;
-
-                               case CODE_BLIST_URL:
-                                       $MSG = MEMBER_URL_BLACK_LISTED."<br />
-".MEMBER_BLIST_TIME.": ".MAKE_DATETIME($_GET['blist'], "0");
-                                       break;
-
-                               case CODE_NO_RECS_LEFT:
-                                       $MSG = MEMBER_SELECTED_MORE_RECS;
-                                       break;
-
-                               case CODE_INVALID_TAGS:
-                                       $MSG = MEMBER_HTML_INVALID_TAGS;
-                                       break;
-
-                               case CODE_MORE_POINTS:
-                                       $MSG = MEMBER_MORE_POINTS_NEEDED;
-                                       break;
-
-                               case CODE_MORE_RECEIVERS1:
-                                       $MSG = MEMBER_ENTER_MORE_RECEIVERS;
-                                       break;
-
-                               case CODE_MORE_RECEIVERS2:
-                                       $MSG = MEMBER_NO_MORE_RECEIVERS_FOUND;
-                                       break;
-
-                               case CODE_MORE_RECEIVERS3:
-                                       $MSG = MEMBER_ENTER_MORE_MIN_RECEIVERS_1.$_CONFIG['order_min'].MEMBER_ENTER_MORE_MIN_RECEIVERS_2;
-                                       break;
-
-                               case CODE_INVALID_URL:
-                                       $MSG = MEMBER_ENTER_INVALID_URL;
-                                       break;
-
-                               case "": // When no error code is included in the URL we do not need to output an error message as well...
-                                       break;
-
-                               default:
-                                       $MSG = UNKNOWN_CODE_1.$_GET['msg'].UNKNOWN_CODE_2;
-                                       break;
-                               }
-                               if (!empty($MSG))
-                               {
+                               if (!empty($message)) {
                                        // We got system message so we drop it out to the user
-                                       LOAD_TEMPLATE("admin_settings_saved", false, $MSG);
-                               }
+                                       loadTemplate('admin_settings_saved', false, $message);
+                               } // END - if
 
                                // Load all email types...
-                               while ($typeS[] = SQL_FETCHROW($result))
-                               {
+                               while ($types[] = SQL_FETCHROW($result)) {
                                        // Nothing to do here... ;-)
-                               }
+                               } // END - while
 
                                // Free memory
                                SQL_FREERESULT($result);
 
                                // Output user's points
-                               $TOTAL = TRANSLATE_COMMA($TOTAL);
+                               $content['total'] = translateComma($total);
 
                                // Check how many mail orders he has placed today and how many he's allowed to send
-                               switch ($_CONFIG['order_max_full'])
-                               {
-                               case "MAX": // He is allowed to send as much as possible
-                                       define('ORDER_MAX_VALUE', ORDER_ALLOED_MAX);
-                                       break;
-
-                               case "ORDER": // He is allowed to send as much as he setup the receiving value
-                                       define('ORDER_MAX_VALUE', ORDER_ALLOWED_RECEIVE_1.$ALLOWED.ORDER_ALLOWED_RECEIVE_2.$MAXI.ORDER_ALLOWED_RECEIVE_3);
-                                       break;
-                               }
+                               switch (getConfig('order_max_full')) {
+                                       case 'MAX': // He is allowed to send as much as possible
+                                               $content['order_max_full'] = getMessage('MEMBER_ORDER_ALLOWED_MAX');
+                                               break;
+
+                                       case 'ORDER': // He is allowed to send as much as he setup the receiving value
+                                               $content['order_max_full'] = sprintf(getMessage('MEMBER_ORDER_ALLOWED_RECEIVE'), $ALLOWED, $MAXI);
+                                               break;
+
+                                       default: // Unknown/invalid
+                                               logDebugMessage(__FILE__, __LINE__, sprintf("Unknown order_mas_full config detected.", getConfig('order_max_full')));
+                                               $content['order_max_full'] = getMessage('MEMBER_ORDER_ALLOWED_UNKNOWN');
+                                               break;
+                               } // END - switch
 
                                // Load final template
-                               LOAD_TEMPLATE("member_order_points", false, $TOTAL);
+                               loadTemplate('member_order_points', false, $content);
 
                                // Reset variables
-                               $OLD_ORDER = false; $subject = ""; $text = ""; $target = "";
+                               $OLD_ORDER = false;
+                               $subject = '';
+                               $text = '';
+                               $target = '';
 
                                // Check if we already have an order placed and make it editable
-                               $result = SQL_QUERY_ESC("SELECT subject, text, payment_id, timestamp, url, target_send, cat_id, zip FROM "._MYSQL_PREFIX."_pool WHERE sender=%s AND data_type='TEMP' LIMIT 1",
-                                array($GLOBALS['userid']), __FILE__, __LINE__);
-
-                               if (SQL_NUMROWS($result) == 1)
-                               {
+                               $result = SQL_QUERY_ESC("SELECT
+       `subject`, `text`, `payment_id`, `timestamp`, `url`, `target_send`, `cat_id`, `zip`
+FROM
+       `{?_MYSQL_PREFIX?}_pool`
+WHERE
+       `sender`=%s AND
+       `data_type`='TEMP'
+LIMIT 1",
+                                       array(getMemberId()), __FILE__, __LINE__);
+
+                               if (SQL_NUMROWS($result) == 1) {
                                        // Old order found
-                                       list($subject, $text, $payment, $tstamp, $url, $target, $cat, $zip) = SQL_FETCHROW($result);
-                                       SQL_FREERESULT($result);
+                                       $content = merge_array($content, SQL_FETCHARRAY($result));
 
                                        // Fix max receivers when it is too much
-                                       if ($target > $CATS['uids'][$cat]) $target = $CATS['uids'][$cat];
+                                       if ((isset($categories['userids'][$content['cat_id']])) && ($content['target_send'] > $categories['userids'][$content['cat_id']])) {
+                                               // Fix it
+                                               $content['target_send'] = $categories['userids'][$content['cat_id']];
+                                       } // END - if
 
                                        // Old order is grabbed
                                        $OLD_ORDER = true;
-                               }
-                                else
-                               {
+                               } else {
                                        // Default output for that your members don't forget it...
-                                       $url = "http://";
+                                       $content['url']         = 'http://';
+                                       $content['target_send'] = getConfig('order_min');
+                                       $content['subject']     = '{--ORDER_DEFAULT_SUBJECT--}';
+                                       $content['text']        = '{--ORDER_DEFAULT_TEXT--}';
                                }
 
-                               // 01      2                       21    12                             2    23         443    3          3210
-                               if ((!empty($_POST['data'])) || (($_CONFIG['order_multi_page'] == "N") && ((!IS_ADMIN()) && (!$HTML_EXT))))
-                               {
+                               // Free result
+                               SQL_FREERESULT($result);
+
+                               if ((isPostRequestParameterSet('data')) || ((getConfig('order_multi_page') != 'Y') && ((!isAdmin()) && (!isExtensionActive('html_mail'))))) {
                                        // Pre-output categories
-                                       $CAT = "";
-                                       foreach ($CATS['id'] as $key=>$value)
-                                       {
-                                               $CAT .= "      <OPTION value=\"".$value."\"";
-                                               if (($OLD_ORDER) && ($cat == $value)) $CAT .= " selected=\"selected\"";
-                                               $CAT .= ">".$CATS['name'][$key]." (".$CATS['uids'][$key]." ".USER_IN_CAT.")</OPTION>\n";
-                                       }
+                                       $content['category_selection'] = '';
+                                       foreach ($categories['id'] as $key => $value) {
+                                               $content['category_selection'] .= "      <option value=\"".$value."\"";
+                                               if (($OLD_ORDER) && ($content['cat_id'] == $value)) $content['category_selection'] .= ' selected="selected"';
+                                               $content['category_selection'] .= ">".$categories['name'][$key]." (".$categories['userids'][$key]." {--USER_IN_CAT--})</option>\n";
+                                       } // END - foreach
+
                                        // Mail type
-                                       $type = "";
-                                       foreach ($typeS as $key=>$value)
-                                       {
-                                               $P = TRANSLATE_COMMA($typeS[$key][1]);
-                                               if (is_array($value))
-                                               {
+                                       $content['type_selection'] = '';
+                                       foreach ($types as $key => $value) {
+                                               $P = translateComma($types[$key][1]);
+                                               if (is_array($value)) {
                                                        // Output option line
-                                                       $type .= "      <OPTION value=\"".$typeS[$key][0]."\"";
-                                                       if (($OLD_ORDER) && ($payment == $typeS[$key][0])) $type .= " selected=\"selected\"";
-                                                       $type .= ">".$P." ".PER_MAIL." - ".$typeS[$key][3]." - ".round($typeS[$key][2])." ".PAYMENT."</OPTION>\n";
-                                               }
-                                       }
+                                                       $content['type_selection'] .= "      <option value=\"".$types[$key][0]."\"";
+                                                       if (($OLD_ORDER) && ($content['payment_id'] == $types[$key][0])) $content['type_selection'] .= ' selected="selected"';
+                                                       $content['type_selection'] .= ">".$P." {--PER_MAIL--} - ".$types[$key][3]." - ".round($types[$key][2])." {--PAYMENT--}</option>\n";
+                                               } // END - if
+                                       } // END - foreach
 
-                                       // Put all in constants for the template
-                                       define('CATEGORY_SELECTION', $CAT);
-                                       define('TYPE_SELECTION', $type);
-                                       define('TARGET', $target);
-                                       define('SUBJECT', $subject);
-                                       define('TEXT', COMPILE_CODE($text));
-                                       define('T_URL', $url);
+                                       // No content is default
+                                       $content['zip_content'] = '';
 
-                                       if (!empty($_POST['zip']))
-                                       {
+                                       if (isPostRequestParameterSet('zip')) {
                                                // Output entered ZIP code
-                                               define('ZIP_OUTPUT', LOAD_TEMPLATE("member_order-zip2", true, $_POST['zip']));
-                                       }
-                                        else
-                                       {
-                                               define('ZIP_OUTPUT', "<TR><TD colspan=\"5\" height=\"5\" class=\"seperator\">&nbsp;</TD></TR>");
-                                       }
+                                               $content['zip_content'] = loadTemplate('member_order-zip2', true, postRequestParameter('zip'));
+                                       } // END - if
+
                                        // HTML extension
-                                       if (($HTML_EXT) && ($_POST['html'] == "Y"))
-                                       {
+                                       if ((isExtensionActive('html_mail')) && (postRequestParameter('html') == 'Y')) {
                                                // Extension is active so output valid HTML tags
-                                               define('MEMBER_HTML_EXTENSION', LOAD_TEMPLATE("member_order-html_ext", true, HTML_ADD_VALID_TAGS()));
-                                       }
-                                        else
-                                       {
+                                               $content['html_extension'] = loadTemplate('member_order-html_ext', true, addValidHtmlTags());
+                                       } else {
                                                // Extension not active and/or class not uploaded
-                                               define('MEMBER_HTML_EXTENSION', "<TR><TD colspan=\"5\"><INPUT type=\"hidden\" name=\"html\" value=\"N\"></TD></TR>");
+                                               $content['html_extension'] = '<tr><td colspan="3"><input type="hidden" name="html" value="N" /></td></tr>';
                                        }
 
                                        // Output form for page 2
-                                       LOAD_TEMPLATE("member_order_page2");
-                               }
-                                else
-                               {
+                                       loadTemplate('member_order_page2', false, $content);
+                               } else {
                                        // Remember maybe entered ZIP code in constant
-                                       $ADD = "";
-                                       if ($HTML_EXT)
-                                       {
+                                       if (isExtensionActive('html_mail')) {
                                                // Add some content when html extension is active
-                                               if (($_CONFIG['order_multi_page'] == "Y") || (IS_ADMIN())) $ADD = "<TR><TD colspan=\"2\" class=\"seperator bottom2\" height=\"5\">&nbsp;</TD></TR>\n";
-                                               define('MEMBER_HTML_EXTENSION', LOAD_TEMPLATE("member_order-html_intro", true));
-                                       }
-                                        else
-                                       {
+                                               $content['html_extension'] = loadTemplate('member_order-html_intro', true);
+                                       } else {
                                                // No HTML extension installed
-                                               define('MEMBER_HTML_EXTENSION', "<TR><TD colspan=\"2\"><INPUT type=\"hidden\" name=\"html\" value=\"N\"></TD></TR>");
+                                               $content['html_extension'] = '<tr><td colspan="3"><input type="hidden" name="html" value="N" /></td></tr>';
                                        }
+
+                                       // Default is no ZIP code
+                                       $content['zip_content'] = '';
+
                                        // Do we want ZIP code or not?
-                                       if (($_CONFIG['order_multi_page'] == "Y") || (IS_ADMIN()))
-                                       {
+                                       if ((getConfig('order_multi_page') == 'Y') || (isAdmin())) {
                                                // Yes
-                                               $content = array(
-                                                       'zip' => $_POST['zip'],
-                                                       'add' => $ADD
-                                               );
-                                               define('MEMBER_ZIP_CONTENT', LOAD_TEMPLATE("member_order-zip1", true, $content));
-                                       }
-                                        else
-                                       {
-                                               // No
-                                               define('MEMBER_ZIP_CONTENT', "");
-                                       }
+                                               if (postRequestParameter('zip') > 0) {
+                                                       $data = array(
+                                                               'zip' => bigintval(postRequestParameter('zip'))
+                                                       );
+                                               } else {
+                                                       $data = array(
+                                                               'zip' => ''
+                                                       );
+                                               }
+                                               $content['zip_content'] = loadTemplate('member_order-zip1', true, $data);
+                                       } // END - if
 
                                        // Output form for page 1 (ZIP code or HTML)
-                                       LOAD_TEMPLATE("member_order_page1");
+                                       loadTemplate('member_order_page1', false, $content);
                                }
-                       }
-                        else
-                       {
+                       } else {
                                // No mail types defined
-                               OUTPUT_HTML("<STRONG><SPAN class=\"member_failed\">".MEMBER_NO_PAYMENTS."</SPAN></STRONG>");
+                               loadTemplate('admin_settings_saved', false, '<span class="member_failed">{--MEMBER_NO_PAYMENTS--}</span>');
                        }
+               } else {
+                       // No points left
+                       loadTemplate('admin_settings_saved', false, '<span class="member_failed">{--MEMBER_NO_POINTS--}</span>');
                }
-                else
-               {
-                       // No points left!
-                       OUTPUT_HTML("<STRONG><SPAN class=\"member_failed\">".MEMBER_NO_POINTS."</SPAN></STRONG>");
-               }
-       }
-        else
-       {
+       } else {
                // No cateogries are defined yet
-               OUTPUT_HTML("<STRONG><SPAN class=\"member_failed\">".MEMBER_NO_CATS."</SPAN></STRONG>");
+               loadTemplate('admin_settings_saved', false, '<span class="member_failed">{--MEMBER_NO_CATS--}</span>');
        }
-}
- elseif ($mmails == "0")
-{
-       // Please set more than 0 mails per day!
-       LOAD_TEMPLATE("admin_settings_saved", false, MEMBER_HAS_ZERO_MMAILS);
-}
- else
-{
-       // Please confirm some mails first!
-       LOAD_TEMPLATE("admin_settings_saved", false, MEMBER_LINKS_LEFT_1.$links.MEMBER_LINKS_LEFT_2.$_CONFIG['unconfirmed'].MEMBER_LINKS_LEFT_3);
+} elseif ($mmails == '0') {
+       // Please set more than 0 mails per day
+       loadTemplate('admin_settings_saved', false, getMessage('MEMBER_HAS_ZERO_MMAILS'));
+} else {
+       // Please confirm some mails first
+       loadTemplate('admin_settings_saved', false, getMaskedMessage('MEMBER_LINKS_LEFT'), $links);
 }
 
-if (!empty($URL))
-{
+if (!empty($URL)) {
        // Redirect to requested URL
-       LOAD_URL($URL);
-}
+       redirectToUrl($URL);
+} // END - if
 
-//
+// [EOF]
 ?>