X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Fmodules%2Fmember%2Fwhat-order.php;h=f891d0609fa8f7d36799e234691f702d188df50f;hb=1c62a6c2a4ed2bb170e0f1888899625e67a27947;hp=54c841fe089437da886e28d5956e6543cec2b95a;hpb=414570c5081d337bb6c28dcf521bd8bca02f69e7;p=mailer.git
diff --git a/inc/modules/member/what-order.php b/inc/modules/member/what-order.php
index 54c841fe08..f891d0609f 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($GLOBALS['userid']), __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($GLOBALS['userid'], "user_points", "points") - GET_TOTAL_DATA($GLOBALS['userid'], "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($GLOBALS['userid'], 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 +88,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=".constant('CODE_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=".constant('CODE_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=".constant('CODE_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") {
+ if (isUrlBlaskEnabled()) {
// 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=".constant('CODE_BLIST_URL')."&blist=".$blist;
+ $url = 'modules.php?module=login&what=order&code=' . getCode('BLIST_URL') . '&blist=' . $blist;
} // END - if
// Free result
@@ -160,84 +138,99 @@ 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=".constant('CODE_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=".constant('CODE_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=".constant('CODE_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=".constant('CODE_URL_TLOCK')."&id=".$id;
+ $url = 'modules.php?module=login&what=order&code=' . getCode('URL_TIME_LOCK') . '&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')))) {
+ $add = '';
+ 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')),
- $GLOBALS['userid'],
- 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.{?order_select?} {?order_mode?}",
+ array(
+ bigintval(postRequestParameter('cat')),
+ getMemberId()
+ ), __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 +239,286 @@ 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(
- $GLOBALS['userid'],
- 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(
- $GLOBALS['userid'],
- 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(
- $GLOBALS['userid'],
- 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=".constant('CODE_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=".constant('CODE_MORE_POINTS');
+ $url = 'modules.php?module=login&what=order&code=' . getCode('MORE_POINTS');
}
- } else {
+ } else {
// Ordered more mails than he can send in this category
- $URL = "modules.php?module=login&what=order&msg=".constant('CODE_NO_RECS_LEFT');
+ $url = 'modules.php?module=login&what=order&code=' . getCode('NO_RECS_LEFT');
}
- }
-} elseif (REQUEST_POST('receiver') == "0") {
+ } // END - if
+} elseif (postRequestParameter('receiver') == '0') {
// Not enougth receivers selected
- $URL = "modules.php?module=login&what=order&msg=".constant('CODE_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) {
- if ($TOTAL > 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']), $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) {
+ $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_holiday);
// 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
- $MSG = "";
- switch (REQUEST_GET('msg'))
- {
- case constant('CODE_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");
+ $result = SQL_QUERY("SELECT `id`, `price`, `payment`, `mail_title` FROM `{?_MYSQL_PREFIX?}_payments` ORDER BY `payment` ASC", __FILE__, __LINE__);
- // 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
- $MSG = "{--MEMBER_URL_TIME_LOCK--}
{--CONFIG_URL_TLOCK--} ".$STD."
- {--_HOURS--}, ".$MIN." {--_MINUTES--} {--_AND--} ".$SEC." {--_SECONDS--}
- {--MEMBER_LAST_TLOCK--}: ".$LORDER;
- break;
-
- case constant('CODE_OVERLENGTH'):
- $MSG = getMessage('MEMBER_TEXT_OVERLENGTH');
- break;
-
- case constant('CODE_URL_FOUND'):
- $MSG = getMessage('MEMBER_TEXT_CONTAINS_URL');
- break;
-
- case constant('CODE_SUBJ_URL'):
- $MSG = getMessage('MEMBER_SUBJ_CONTAINS_URL');
- break;
-
- case constant('CODE_BLIST_URL'):
- $MSG = "{--MEMBER_URL_BLACK_LISTED--}
\n{--MEMBER_BLIST_TIME--}: ".MAKE_DATETIME(REQUEST_GET('blist'), "0");
- break;
-
- case constant('CODE_NO_RECS_LEFT'):
- $MSG = getMessage('MEMBER_SELECTED_MORE_RECS');
- break;
-
- case constant('CODE_INVALID_TAGS'):
- $MSG = getMessage('MEMBER_HTML_INVALID_TAGS');
- break;
-
- case constant('CODE_MORE_POINTS'):
- $MSG = getMessage('MEMBER_MORE_POINTS_NEEDED');
- break;
-
- case constant('CODE_MORE_RECEIVERS1'):
- $MSG = getMessage('MEMBER_ENTER_MORE_RECEIVERS');
- break;
-
- case constant('CODE_MORE_RECEIVERS2'):
- $MSG = getMessage('MEMBER_NO_MORE_RECEIVERS_FOUND');
- break;
-
- case constant('CODE_MORE_RECEIVERS3'):
- $MSG = sprintf(getMessage('MEMBER_ENTER_MORE_MIN_RECEIVERS'), getConfig('order_min'));
- break;
+ $types = array();
+ if (!SQL_HASZERONUMS($result)) {
+ // Check for message id in URL
+ $message = getMessageFromErrorCode(getRequestParameter('code'));
- case constant('CODE_INVALID_URL'):
- $MSG = 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')));
- $MSG = sprintf(getMessage('UNKNOWN_CODE'), REQUEST_GET('msg'));
- 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
@@ -575,159 +526,158 @@ LIMIT 1", array(bigintval($ucat)), __FILE__, __LINE__);
SQL_FREERESULT($result);
// Output user's points
- $TOTAL = TRANSLATE_COMMA($TOTAL);
+ $content['total'] = $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($GLOBALS['userid']), __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'] = '{?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 .= "