X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=0.2.1%2Finc%2Fmodules%2Fmember%2Fwhat-order.php;h=9c63dbbe36526060d4d7e284610770bd8dc34b8c;hp=5b39004faf99a2902d28c44a6ea59850c40af757;hb=7bc25dd08431c94ce9edca131d56c1a36b13c28a;hpb=157ee010917df5ca07e6d31b42f67417b2516d74 diff --git a/0.2.1/inc/modules/member/what-order.php b/0.2.1/inc/modules/member/what-order.php index 5b39004faf..9c63dbbe36 100644 --- a/0.2.1/inc/modules/member/what-order.php +++ b/0.2.1/inc/modules/member/what-order.php @@ -1,818 +1,818 @@ -$value) -{ - // Skip submit buttons - if (($key != "data") && ($key != "frametester")) $_POST[$key] = addslashes($value); -} - -// Minimum mails / order -define('__MIN_VALUE', $CONFIG['order_min']); - -// Count unconfirmed mails -$result_links = SQL_QUERY_ESC("SELECT id FROM "._MYSQL_PREFIX."_user_links WHERE userid=%d", - 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"; -} - -$result_mmails = SQL_QUERY_ESC("SELECT userid, receive_mails, mail_orders, ".$HOLIDAY." -FROM "._MYSQL_PREFIX."_user_data -WHERE userid=%d AND max_mails > 0 LIMIT 1", - array($GLOBALS['userid']), __FILE__, __LINE__); - -$mmails = SQL_NUMROWS($result_mmails); -list($DMY, $MAXI, $ORDERS, $HOLIDAY) = SQL_FETCHROW($result_mmails); -SQL_FREERESULT($result_mmails); -if ($HOLIDAY == $DMY) $HOLIDAY="N"; - -$ALLOWED = $MAXI - $ORDERS; -if ($CONFIG['order_max'] == "MAX") $ALLOWED = $MAXI; - -// Check HTML extension -$HTML_EXT = EXT_IS_ACTIVE("html_mail"); - -// Now check his points amount -$result_p = SQL_QUERY_ESC("SELECT SUM(points) FROM "._MYSQL_PREFIX."_user_points WHERE userid=%d", - 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=%d 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"; -} - -if (($HOLIDAY == "Y") && (GET_EXT_VERSION("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)) -{ - // 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=%d AND url='%s' AND timestamp > %d LIMIT 1", - array($GLOBALS['userid'], $_POST['url'], bigintval(time() - $CONFIG['url_tlock'])), __FILE__, __LINE__); - - $type = "TEMP"; $id = "0"; - if (SQL_NUMROWS($result) == 1) - { - list($id, $type) = SQL_FETCHROW($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") - { - // 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)) - { - // URL found! - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_URL_FOUND; - } - $TEST = str_replace("\n", "", str_replace("\r", "", addslashes($_POST['text']))); - if (strlen($TEST) > $CONFIG['max_tlength']) - { - // Text is too long! - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_OVERLENGTH; - } - } - // Shall I test the subject line against URLs? - if ($CONFIG['test_subj'] == "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)) - { - // URL in subject found - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_SUBJ_URL; - } - } - // And shall I check that his URL is not in the black list? - if ($CONFIG['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__); - - if (SQL_NUMROWS($result) == 1) - { - // Jupp, we got one listed - list($blist) = SQL_FETCHROW($result); - SQL_FREERESULT($result); - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_BLIST_URL."&blist=".$blist; - } - } - if (($_POST['receiver'] < $CONFIG['order_min']) && (!IS_ADMIN())) - { - // Less than allowed receivers entered! - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_MORE_RECEIVERS3; - } - - // Validate URL - if (!VALIDATE_URL($_POST['url'])) - { - // URL is invalid! - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_INVALID_URL; - } - - // Probe for HTML extension - if ($HTML_EXT) - { - if ($_POST['html'] == "Y") - { - // Chek for valid HTML tags - $_POST['text'] = HTML_CHECK_TAGS($_POST['text']); - - // Maybe invalid tags found? - if (empty($_POST['text'])) $URL = URL."/modules.php?module=login&what=order&msg=".CODE_INVALID_TAGS."&id=".$id; - } - else - { - // Remove any HTML code - $_POST['text'] = str_replace("<", "{OPEN_HTML}", str_replace(">", "{CLOSE_HTML}", $_POST['text'])); - } - } - } - elseif (!IS_ADMIN()) - { - // He has already sent a mail within a specific time - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_URL_TLOCK."&id=".$id; - } - 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}'"; - - // 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=%d 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__); - - // 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; - } - - // Load receivers from database - $TEST = array(); $cnt = 0; - while (list($REC) = SQL_FETCHROW($result)) - { - if ($HOLIDAY) - { - // Check for his holiday status - $result_holiday = SQL_QUERY_ESC("SELECT id FROM "._MYSQL_PREFIX."_user_holidays -WHERE userid=%d 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 - - // Free memory - SQL_FREERESULT($result_holiday); - } - - if ($REC > 0) - { - // Add receiver - $TEST[] = $REC; - $cnt++; - } - } - - // Free memory - SQL_FREERESULT($result); - - // Implode array into string for the sending pool - $RECEIVER = implode($TEST, ";"); - - // Count array for maximum sent - $MAX_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__); - - // Is calculated max receivers larger than wanted receivers then reset it - if ($MAX_SEND > $_POST['receiver']) $MAX_SEND = $_POST['receiver']; - - // Calculate used points - $USED = $MAX_SEND * GET_PAY_POINTS(bigintval($_POST['type'])); - - // Check if he has enougth points for this order and selected more than 0 receivers - if (($USED > 0) && ($USED <= $TOTAL) && ($MAX_SEND > 0)) - { - // Gettings points is okay, so we can add $USED later from - $TIME = time(); - if (($id == "0") || ($type != "TEMP")) - { - // New order - $id = 0; - if ($HTML_EXT) - { - // 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 - { - // 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__); - } - } - else - { - // Change current order - if ($HTML_EXT) - { - // HTML extension is active - $result = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_pool SET -subject='%s', -text='%s', -receivers='%s', -payment_id=%d, -timestamp=UNIX_TIMESTAMP(), -url='%s', -cat_id=%d, -target_send=%d, -zip=%d, -html_msg='%s' -WHERE id=%d 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 - { - // No HTML extension is active - $result = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_pool SET -subject='%s', -text='%s', -receivers='%s', -payment_id=%d, -timestamp=UNIX_TIMESTAMP(), -url='%s', -cat_id=%d, -target_send=%d, -zip=%d -WHERE id=%d 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__); - } - } - - // 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=%d AND subject='%s' AND payment_id=%d AND data_type='TEMP' AND timestamp=%d LIMIT 1", - array( - $GLOBALS['userid'], - $_POST['subject'], - bigintval($_POST['type']), - $TIME - ), __FILE__, __LINE__); - - list($id) = SQL_FETCHROW($result); - SQL_FREERESULT($result); - } - - // 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&order=".$id.""; - } - elseif ($MAX_SEND == 0) - { - // Not enougth receivers found which can receive mails - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_MORE_RECEIVERS2; - } - else - { - // No enougth points left! - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_MORE_POINTS; - } - } - else - { - // Ordered more mails than he can send in this category - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_NO_RECS_LEFT; - } - } -} - elseif ($_POST['receiver'] == "0") -{ - // Not enougth receivers selected - $URL = URL."/modules.php?module=login&what=order&msg=".CODE_MORE_RECEIVERS1; -} - elseif (($ALLOWED == 0) && ($CONFIG['order_max'] == "ORDER")) -{ - // No more mail orders allowed - LOAD_TEMPLATE("admin_settings_saved", false, MEMBER_ORDER_ALLOWED_EXHAUSTED); -} - elseif (($links < $CONFIG['unconfirmed']) && ($mmails == "1")) -{ - // Display order form - $result_cats = SQL_QUERY("SELECT id, cat FROM "._MYSQL_PREFIX."_cats".$WHERE." ORDER BY sort", __FILE__, __LINE__); - if (SQL_NUMROWS($result_cats) > 0) - { - if ($TOTAL > 0) - { - // Initialize array... - $CATS = array( - 'id' => array(), - 'name' => array(), - 'uids' => 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") - { - // Extension's version is fine - $HOLIDAY = true; $HOL_STRING = " AND holiday_active='N'"; - } - - // ... and begin loading stuff - while (list($id, $cat) = SQL_FETCHROW($result_cats)) - { - $CATS['id'][] = bigintval($id); - $CATS['name'][] = $cat; - - // Select users in current category - $result_uids = SQL_QUERY_ESC("SELECT userid FROM "._MYSQL_PREFIX."_user_cats WHERE cat_id=%d AND userid != '%s' ORDER BY userid", - array(bigintval($id), $GLOBALS['userid']), __FILE__, __LINE__); - - $uid_cnt = "0"; - while (list($ucat) = SQL_FETCHROW($result_uids)) - { - // Check for holiday system - $HOL_ACTIVE = false; - if ($HOLIDAY) - { - // 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=%d 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; - } - - // Free memory - SQL_FREERESULT($result_holiday); - } - - if (!$HOL_ACTIVE) - { - // Check if the user want's to receive mails? - $result_ver = SQL_QUERY_ESC("SELECT zip FROM "._MYSQL_PREFIX."_user_data WHERE userid=%d".$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")) - { - list($zip) = SQL_FETCHROW($result_ver); - SQL_FREERESULT($result_ver); - if (substr($zip, 0, strlen($_POST['zip'])) == $_POST['zip']) - { - // Ok, ZIP part is found - $uid_cnt++; - } - } - else - { - // Count numbers up! - $uid_cnt += SQL_NUMROWS($result_ver); - } - } - } - - // Free memory - SQL_FREERESULT($result_uids); - $CATS['uids'][] = $uid_cnt; - } - - // 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=%d 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; - - // Finally contruct the message - $MSG = MEMBER_URL_TIME_LOCK."
".CONFIG_URL_TLOCK." ".$STD." ". - HOURS.", ".$MIN." ".MINS." "._AND." ".$SEC." ".SECS."
". - MEMBER_LAST_TLOCK.": ".$LORDER; - break; - - 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."
-".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)) - { - // We got system message so we drop it out to the user - LOAD_TEMPLATE("admin_settings_saved", false, $MSG); - } - - // Load all email types... - while ($TYPES[] = SQL_FETCHROW($result)) - { - // Nothing to do here... ;-) - } - - // Free memory - SQL_FREERESULT($result); - - // Output user's points - $TOTAL = TRANSLATE_COMMA($TOTAL); - - // Check how many mail orders he has placed today and how many he's allowed to send - switch ($CONFIG['order_max']) - { - 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; - } - - // Load final template - LOAD_TEMPLATE("member_order_points", false, $TOTAL); - - // Reset variables - $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=%d AND data_type='TEMP' LIMIT 1", - array($GLOBALS['userid']), __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); - - // Fix max receivers when it is too much - if ($target > $CATS['uids'][$cat]) $target = $CATS['uids'][$cat]; - - // Old order is grabbed - $OLD_ORDER = true; - } - else - { - // Default output for that your members don't forget it... - $url = "http://"; - } - - // 01 2 21 12 2 23 443 3 3210 - if ((!empty($_POST['data'])) || (($CONFIG['order_multi_page'] == "N") && ((!IS_ADMIN()) && (!$HTML_EXT)))) - { - // Pre-output categories - $CAT = ""; - foreach ($CATS['id'] as $key=>$value) - { - $CAT .= "