X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Fmodules%2Fmember%2Fwhat-order.php;h=1b1dd1984c29df084f31ad63e4dd97a93faa967c;hp=4c1055a2404e53e5552895b0e100d6143d178908;hb=6c0abc9f643c69610fe87be0ddb1a5dab95c6d39;hpb=116747e4dba29e9e2e4daa82c45d8bbb302e9378 diff --git a/inc/modules/member/what-order.php b/inc/modules/member/what-order.php index 4c1055a240..1b1dd1984c 100644 --- a/inc/modules/member/what-order.php +++ b/inc/modules/member/what-order.php @@ -1,7 +1,7 @@ = '0.1.3') { - // Fetch also holiday activation data - $HOLIDAY = "holiday_active"; +if ((!isExtensionActive('order')) && (!isAdmin())) { + loadTemplate('admin_settings_saved', false, generateExtensionInactiveNotInstalledMessage('order')); + return; } // END - if -$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(getUserId()), __FILE__, __LINE__); +$url = ''; $id = '0'; -$mmails = SQL_NUMROWS($result_mmails); -list($DMY, $MAXI, $ORDERS, $HOLIDAY) = SQL_FETCHROW($result_mmails); -SQL_FREERESULT($result_mmails); -if ($HOLIDAY == $DMY) $HOLIDAY='N'; +// Count unconfirmed mails +$links = countSumTotalData(getMemberId(), 'user_links', 'id', 'userid', true); -$ALLOWED = $MAXI - $ORDERS; -if (getConfig('order_max_full') == 'MAX') $ALLOWED = $MAXI; +$ALLOWED = getUserData('receive_mails') - getUserData('mail_orders'); +if (getConfig('order_max_full') == 'MAX') $ALLOWED = getUserData('receive_mails'); // Now check his points amount -$total = GET_TOTAL_DATA(getUserId(), "user_points", "points") - GET_TOTAL_DATA(getUserId(), "user_data", "used_points");; +$total = getTotalPoints(getMemberId()); -if (($HOLIDAY == 'Y') && (GET_EXT_VERSION('holiday') >= '0.1.3')) { +if ((isExtensionInstalledAndNewer('holiday', '0.1.3')) && (getUserData('holiday_active') == 'Y')) { // Holiday is active! - LOAD_TEMPLATE('admin_settings_saved', false, getMessage('HOLIDAY_ORDER_NOT_POSSIBLE')); -} elseif ((REQUEST_ISSET_POST(('frametester'))) && ($ALLOWED > 0) && (REQUEST_POST('receiver') > 0)) { + loadTemplate('admin_settings_saved', false, '{--MEMBER_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 > (UNIX_TIMESTAMP() - %s) LIMIT 1", - array(getUserId(), REQUEST_POST('url'), getConfig('url_tlock')), __FILE__, __LINE__); - - $type = "TEMP"; $id = 0; + $result = SQL_QUERY_ESC("SELECT `id`, `data_type` +FROM + `{?_MYSQL_PREFIX?}_pool` +WHERE + `sender`=%s AND + `url`='%s' AND + `timestamp` > (UNIX_TIMESTAMP() - {?url_tlock?}) +LIMIT 1", + array( + getMemberId(), + postRequestParameter('url') + ), __FILE__, __LINE__); + + $type = 'TEMP'; $id = '0'; if (SQL_NUMROWS($result) == 1) { // Load id and mail type list($id, $type) = SQL_FETCHROW($result); @@ -110,49 +90,49 @@ WHERE sender=%s AND url='%s' AND timestamp > (UNIX_TIMESTAMP() - %s) LIMIT 1", // Free result SQL_FREERESULT($result); - if ($type == "TEMP") { + 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 (getConfig('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(REQUEST_POST('text')), "https://") > -1) || (strpos(strtolower(REQUEST_POST('text')), "http://") > -1) || (strpos(strtolower(REQUEST_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 = 'modules.php?module=login&what=order&msg=' . getCode('URL_FOUND'); + $url = 'modules.php?module=login&what=order&code=' . getCode('URL_FOUND'); } // END - if // Remove new-line and carriage-return characters - $TEST = str_replace("\n", '', str_replace("\r", '', REQUEST_POST('text'))); + $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 = 'modules.php?module=login&what=order&msg=' . getCode('OVERLENGTH'); + $url = 'modules.php?module=login&what=order&code=' . getCode('OVERLENGTH'); } // END - if } // END - if // Shall I test the subject line against URLs? - if (getConfig('test_subj') == 'Y') { + if (getConfig('allow_url_in_subject') == 'Y') { // Check the subject line for issues - REQUEST_SET_POST('subject', str_replace("\\", "[nl]", substr(REQUEST_POST('subject'), 0, 200))); - if ((strpos(strtolower(REQUEST_POST('subject')), "http://") > -1) || (strpos(strtolower(REQUEST_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 = 'modules.php?module=login&what=order&msg=' . getCode('SUBJ_URL'); + $url = 'modules.php?module=login&what=order&code=' . getCode('SUBJECT_URL'); } // END - if } // END - if // And shall I check that his URL is not in the black list? if (getConfig('url_blacklist') == 'Y') { // Ok, I do that for you know... - $result = SQL_QUERY_ESC("SELECT UNIX_TIMESTAMP(`timestamp`) AS tstamp FROM `{!_MYSQL_PREFIX!}_url_blacklist` WHERE `url`='%s' LIMIT 1", - array(REQUEST_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) { // Jupp, we got one listed list($blist) = SQL_FETCHROW($result); // Create redirect-URL - $URL = 'modules.php?module=login&what=order&msg=' . getCode('BLIST_URL')."&blist=".$blist; + $url = 'modules.php?module=login&what=order&code=' . getCode('BLIST_URL') . '&blist=' . $blist; } // END - if // Free result @@ -160,84 +140,101 @@ WHERE sender=%s AND url='%s' AND timestamp > (UNIX_TIMESTAMP() - %s) LIMIT 1", } // END - if // Enougth receivers entered? - if ((REQUEST_POST('receiver') < getConfig('order_min')) && (!IS_ADMIN())) { + if ((postRequestParameter('receiver') < getConfig('order_min')) && (!isAdmin())) { // Less than allowed receivers entered! - $URL = 'modules.php?module=login&what=order&msg=' . getCode('MORE_RECEIVERS3'); + $url = 'modules.php?module=login&what=order&code=' . getCode('MORE_RECEIVERS3'); } // END - if // Validate URL - if (!VALIDATE_URL(REQUEST_POST('url'))) { + if (!isUrlValid(postRequestParameter('url'))) { // URL is invalid! - $URL = 'modules.php?module=login&what=order&msg=' . getCode('INVALID_URL'); + $url = 'modules.php?module=login&what=order&code=' . getCode('INVALID_URL'); } // END - if // Probe for HTML extension - if (EXT_IS_ACTIVE('html_mail')) { + if (isExtensionActive('html_mail')) { // HTML or regular text mail? - if (REQUEST_POST('html') == 'Y') { + if (postRequestParameter('html') == 'Y') { // Chek for valid HTML tags - REQUEST_SET_POST('text', HTML_CHECK_TAGS(REQUEST_POST('text'))); + setPostRequestParameter('text', checkHtmlTags(postRequestParameter('text'))); // Maybe invalid tags found? - if (!REQUEST_ISSET_POST(('text'))) $URL = 'modules.php?module=login&what=order&msg=' . getCode('INVALID_TAGS')."&id=".$id; + if (!isPostRequestParameterSet('text')) $url = 'modules.php?module=login&what=order&code=' . getCode('INVALID_TAGS')."&id=".$id; } else { // Remove any HTML code - REQUEST_SET_POST('text', str_replace("<", "{OPEN_HTML}", str_replace(">", "{CLOSE_HTML}", REQUEST_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&what=order&code=' . getCode('NO_MAIL_TYPE'); + } // END - if + } elseif (!isAdmin()) { // He has already sent a mail within a specific time - $URL = 'modules.php?module=login&what=order&msg=' . getCode('URL_TLOCK')."&id=".$id; + $url = 'modules.php?module=login&what=order&code=' . getCode('URL_TLOCK') . '&id=' . $id; } // Still no error? - if (empty($URL)) { + if (empty($url)) { // Check if category and number of receivers is okay $add = ''; - if ((getConfig('order_multi_page') == 'Y') && (REQUEST_ISSET_POST('zip'))) { + if ((getConfig('order_multi_page') == 'Y') && (isPostRequestParameterSet('zip')) && (postRequestParameter('zip') != '')) { // Choose recipients by ZIP code - $add = " AND d.zip LIKE '".bigintval(REQUEST_POST('zip'))."{PER}'"; + $add = sprintf(" AND d.zip LIKE '%s%%'", + bigintval(postRequestParameter('zip')) + ); } // 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(REQUEST_POST('cat')), - getUserId(), - getConfig('order_select'), - getConfig('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) >= REQUEST_POST('receiver')) { - // Check for holiday extensions - $HOLIDAY = false; - if (GET_EXT_VERSION('holiday') >= '0.1.3') { - // Include checking for users in holiday - $HOLIDAY = true; - } // END - if - + if (SQL_NUMROWS($result) >= postRequestParameter('receiver')) { // Load receivers from database - $TEST = array(); $cnt = 0; - while ($content = SQL_FETCHARRAY($result)) { - if ($HOLIDAY) { + $TEST = array(); $cnt = '0'; + while ($holidayContent = SQL_FETCHARRAY($result)) { + if (isExtensionInstalledAndNewer('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 < UNIX_TIMESTAMP() AND holiday_end > UNIX_TIMESTAMP() LIMIT 1", - array(bigintval($content['userid'])), __FILE__, __LINE__); - if (SQL_NUMROWS($result_holiday) == 1) $content['userid'] = 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 ($content['userid'] > 0) { + if ($holidayContent['userid'] > 0) { // Add receiver - $TEST[] = $content['userid']; + $TEST[] = $holidayContent['userid']; $cnt++; } // END - if } // END - while @@ -246,328 +243,283 @@ WHERE userid=%s AND holiday_start < UNIX_TIMESTAMP() AND holiday_end > UNIX_TIME 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 - 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 > REQUEST_POST('receiver')) $MAX_SEND = REQUEST_POST('receiver'); + if ($content['target_send'] > postRequestParameter('receiver')) $content['target_send'] = bigintval(postRequestParameter('receiver')); // Calculate used points - $USED = $MAX_SEND * GET_PAY_POINTS(bigintval(REQUEST_POST('type'))); + $USED = $content['target_send'] * getPaymentPoints(bigintval(postRequestParameter('mail_type'))); // Fix empty zip code - if (!REQUEST_ISSET_POST('zip')) REQUEST_SET_POST('zip', "0"); + 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 (EXT_IS_ACTIVE('html_mail')) { + $id = '0'; + if (isExtensionActive('html_mail')) { // HTML extension is active - 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( - getUserId(), - REQUEST_POST('subject'), - REQUEST_POST('text'), - $RECEIVER, - bigintval(REQUEST_POST('type')), - $TIME, - REQUEST_POST('url'), - bigintval(REQUEST_POST('cat')), - $MAX_SEND, - bigintval(REQUEST_POST('zip')), - REQUEST_POST('html') -), __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`, `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 - 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( - getUserId(), - REQUEST_POST('subject'), - REQUEST_POST('text'), - $RECEIVER, - bigintval(REQUEST_POST('type')), - $TIME, - REQUEST_POST('url'), - bigintval(REQUEST_POST('cat')), - $MAX_SEND, - bigintval(REQUEST_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 { // Change current order - if (EXT_IS_ACTIVE('html_mail')) { + if (isExtensionActive('html_mail')) { // HTML extension is active - 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( - REQUEST_POST('subject'), - REQUEST_POST('text'), - $RECEIVER, - bigintval(REQUEST_POST('type')), - REQUEST_POST('url'), - bigintval(REQUEST_POST('cat')), - $MAX_SEND, - bigintval(REQUEST_POST('zip')), - REQUEST_POST('html'), - 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, + `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 - 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( - REQUEST_POST('subject'), - REQUEST_POST('text'), - $RECEIVER, - bigintval(REQUEST_POST('type')), - REQUEST_POST('url'), - bigintval(REQUEST_POST('cat')), - $MAX_SEND, - bigintval(REQUEST_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( - getUserId(), - REQUEST_POST('subject'), - bigintval(REQUEST_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 = "modules.php?module=frametester&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&order=' . $id; + } elseif ($content['target_send'] == '0') { // Not enougth receivers found which can receive mails - $URL = 'modules.php?module=login&what=order&msg=' . getCode('MORE_RECEIVERS2'); + $url = 'modules.php?module=login&what=order&code=' . getCode('MORE_RECEIVERS2'); } else { // No enougth points left! - $URL = 'modules.php?module=login&what=order&msg=' . getCode('MORE_POINTS'); + $url = 'modules.php?module=login&what=order&code=' . getCode('MORE_POINTS'); } } else { // Ordered more mails than he can send in this category - $URL = 'modules.php?module=login&what=order&msg=' . getCode('NO_RECS_LEFT'); + $url = 'modules.php?module=login&what=order&code=' . getCode('NO_RECS_LEFT'); } } -} elseif (REQUEST_POST('receiver') == "0") { +} elseif (postRequestParameter('receiver') == '0') { // Not enougth receivers selected - $URL = 'modules.php?module=login&what=order&msg=' . getCode('MORE_RECEIVERS1'); -} elseif (($ALLOWED == 0) && (getConfig('order_max_full') == 'ORDER')) { + $url = 'modules.php?module=login&what=order&code=' . getCode('MORE_RECEIVERS1'); +} elseif (($ALLOWED == '0') && (getConfig('order_max_full') == 'ORDER')) { // No more mail orders allowed - LOAD_TEMPLATE('admin_settings_saved', false, getMessage('MEMBER_ORDER_ALLOWED_EXHAUSTED')); -} elseif (($links < getConfig('unconfirmed')) && ($mmails == "1")) { + loadTemplate('admin_settings_saved', false, '{--MEMBER_ORDER_ALLOWED_EXHAUSTED--}'); +} elseif ($links < getConfig('unconfirmed')) { + // Show only enabled categories to the user ... + $whereStatement = " WHERE `visible`='Y'"; + + // ... but all to the admin + if (isAdmin()) $whereStatement = ''; + // 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) { + $result_cats = SQL_QUERY("SELECT + `id`, `cat` +FROM + `{?_MYSQL_PREFIX?}_cats` +".$whereStatement." +ORDER BY + `sort` ASC", __FILE__, __LINE__); + if (!SQL_HASZERONUMS($result_cats)) { 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 ((EXT_IS_ACTIVE('html_mail')) && (REQUEST_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 ($content = SQL_FETCHARRAY($result_cats)) { - $CATS['id'][] = bigintval($content['id']); - $CATS['name'][] = $content['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($content['id']), getUserId()), __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) { + $isHolidayActive = false; + if (isExtensionInstalledAndNewer('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 < UNIX_TIMESTAMP() AND h.holiday_end > UNIX_TIMESTAMP() -LIMIT 1", array(bigintval($ucat)), __FILE__, __LINE__); - if (SQL_NUMROWS($result_holiday) == 1) { - // Holiday is active! - $HOL_ACTIVE = true; - } // END - if + $result_holiday = SQL_QUERY_ESC("SELECT + COUNT(d.userid) AS `cnt` +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__); + + // Fetch entry + list($cnt) = SQL_FETCHROW($result); // Free memory SQL_FREERESULT($result_holiday); + + // Is holiday is active? + $isHolidayActive = ($cont == 1); } // END - if - if (!$HOL_ACTIVE) { + if ($isHolidayActive === 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", + $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) && (REQUEST_ISSET_POST('zip')) && (getConfig('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(REQUEST_POST('zip'))) == REQUEST_POST('zip')) { + if (substr($zip, 0, strlen(postRequestParameter('zip'))) == postRequestParameter('zip')) { // Ok, ZIP part is found - $uid_cnt++; + $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 - $message = ''; - switch (REQUEST_GET('msg')) - { - case getCode('URL_TLOCK'): - $result = SQL_QUERY_ESC("SELECT timestamp FROM `{!_MYSQL_PREFIX!}_pool` WHERE id=%s LIMIT 1", - array(bigintval(REQUEST_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(getConfig('url_tlock') / 60 / 60); - - // Minutes... - $MIN = round((getConfig('url_tlock') - $STD * 60 * 60) / 60); - - // And seconds - $SEC = getConfig('url_tlock') - $STD * 60 * 60 - $MIN * 60; - - // Finally contruct the message - // @TODO Rewrite this old lost code to a template - $message = "{--MEMBER_URL_TIME_LOCK--}
{--CONFIG_URL_TLOCK--} ".$STD." - {--_HOURS--}, ".$MIN." {--_MINUTES--} {--_AND--} ".$SEC." {--_SECONDS--}
- {--MEMBER_LAST_TLOCK--}: ".$LORDER; - break; - - case getCode('OVERLENGTH'): - $message = getMessage('MEMBER_TEXT_OVERLENGTH'); - break; - - case getCode('URL_FOUND'): - $message = getMessage('MEMBER_TEXT_CONTAINS_URL'); - break; - - case getCode('SUBJ_URL'): - $message = getMessage('MEMBER_SUBJ_CONTAINS_URL'); - break; - - case getCode('BLIST_URL'): - $message = "{--MEMBER_URL_BLACK_LISTED--}
\n{--MEMBER_BLIST_TIME--}: ".MAKE_DATETIME(REQUEST_GET('blist'), "0"); - break; - - case getCode('NO_RECS_LEFT'): - $message = getMessage('MEMBER_SELECTED_MORE_RECS'); - break; - - case getCode('INVALID_TAGS'): - $message = getMessage('MEMBER_HTML_INVALID_TAGS'); - break; - - case getCode('MORE_POINTS'): - $message = getMessage('MEMBER_MORE_POINTS_NEEDED'); - break; - - case getCode('MORE_RECEIVERS1'): - $message = getMessage('MEMBER_ENTER_MORE_RECEIVERS'); - break; - - case getCode('MORE_RECEIVERS2'): - $message = getMessage('MEMBER_NO_MORE_RECEIVERS_FOUND'); - break; - - case getCode('MORE_RECEIVERS3'): - $message = sprintf(getMessage('MEMBER_ENTER_MORE_MIN_RECEIVERS'), getConfig('order_min')); - break; + $result = SQL_QUERY("SELECT `id`, `price`, `payment`, `mail_title` FROM `{?_MYSQL_PREFIX?}_payments` ORDER BY `payment` ASC", __FILE__, __LINE__); - case getCode('INVALID_URL'): - $message = getMessage('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: - DEBUG_LOG(__FILE__, __LINE__, sprintf("Unknown error code %s detected.", REQUEST_GET('msg'))); - $message = sprintf(getMessage('UNKNOWN_CODE'), REQUEST_GET('msg')); - break; - } + $types = array(); + if (!SQL_HASZERONUMS($result)) { + // Check for message id in URL + $message = getMessageFromErrorCode(getRequestParameter('code')); if (!empty($message)) { // We got system message so we drop it out to the user - LOAD_TEMPLATE('admin_settings_saved', false, $message); + 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 @@ -575,159 +527,159 @@ LIMIT 1", array(bigintval($ucat)), __FILE__, __LINE__); 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 (getConfig('order_max_full')) - { - case 'MAX': // He is allowed to send as much as possible - define('ORDER_MAX_VALUE', getMessage('ORDER_ALLOWED_MAX')); - break; - - case 'ORDER': // He is allowed to send as much as he setup the receiving value - define('ORDER_MAX_VALUE', sprintf(getMessage('ORDER_ALLOWED_RECEIVE'), $ALLOWED, $MAXI)); - break; - - default: // Unknown/invalid - DEBUG_LOG(__FILE__, __LINE__, sprintf("Unknown order_mas_full config detected.", getConfig('order_max_full'))); - define('ORDER_MAX_VALUE', getMessage('ORDER_ALLOWED_UNKNOWN')); - break; - } + switch (getConfig('order_max_full')) { + case 'MAX': // He is allowed to send as much as possible + $content['order_max_full'] = '{--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, getUserData('receive_mails')); + break; + + default: // Unknown/invalid + logDebugMessage(__FILE__, __LINE__, sprintf("Unknown order_mas_full config detected.", getConfig('order_max_full'))); + $content['order_max_full'] = '{--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(getUserId()), __FILE__, __LINE__); + $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, $content['cat'], $zip) = SQL_FETCHROW($result); + $content = merge_array($content, SQL_FETCHARRAY($result)); // Fix max receivers when it is too much - if ((isset($CATS['uids'][$content['cat']])) && ($target > $CATS['uids'][$content['cat']])) $target = $CATS['uids'][$content['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 { // 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--}'; } // Free result SQL_FREERESULT($result); - // 01 2 21 12 2 23 443 3 3210 - if ((REQUEST_ISSET_POST(('data'))) || ((getConfig('order_multi_page') != 'Y') && ((!IS_ADMIN()) && (!EXT_IS_ACTIVE('html_mail'))))) { + if ((isPostRequestParameterSet('data')) || ((getConfig('order_multi_page') != 'Y') && ((!isAdmin()) && (!isExtensionActive('html_mail'))))) { // Pre-output categories - $CAT = ''; - foreach ($CATS['id'] as $key => $value) { - $CAT .= "