X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Fmonthly%2Fmonthly_beg.php;h=fa34df7d042891c64866fb3c7170e034014ceed3;hb=330dbb3e2b34450cd1665497506455e195a0a166;hp=fde8d234f21ea8855fc3cf168be201bbe191c1c5;hpb=5f8c1a333627cd0145f778a6eebdb251f5bb40b6;p=mailer.git diff --git a/inc/monthly/monthly_beg.php b/inc/monthly/monthly_beg.php index fde8d234f2..fa34df7d04 100644 --- a/inc/monthly/monthly_beg.php +++ b/inc/monthly/monthly_beg.php @@ -1,7 +1,7 @@ \n"; - -// Get current month (2 digits) -$curr = date("m", time()); +// Debug line +//* DEBUG: */ logDebugMessage(__FILE__, __LINE__, 'Monthly reset started.'); // Check if month is done -if (($curr != $_CONFIG['last_month']) && ($_CONFIG['last_month'] > 0) && ($_CONFIG['beg_ranks'] > 0) && ($CSS != 1)) { - // Extension "autopurge" is inactive or purging of inactive accounts is deactivated - $whereStatement1 = ""; - $whereStatement2 = bigintval($_CONFIG['beg_ranks']); +if ((getBegRanks() > 0) && (!isCssOutputMode())) { + // Extension 'autopurge' is inactive or purging of inactive accounts is deactivated + $whereStatement = ''; - // Let's check if there are some points left we can "pay"... - if (EXT_IS_ACTIVE("autopurge")) { - // Use last online stamp only when autopurge for inactive members is activated - if (($_CONFIG['ap_inactive_since'] > 0) && ($_CONFIG['beg_active'] == "Y")) { - // Okay, include last online timestamp - $whereStatement1 = sprintf(" AND last_online >= (UNIX_TIMESTAMP() - %s)", bigintval($_CONFIG['ap_inactive_since']));; - $whereStatement2 = bigintval($_CONFIG['beg_ranks']); - } // END - if + // Shall we exclude webmaster's own userid? + if ((!isBegIncludeOwnEnabled()) && (isValidUserId(getBegUserid()))) { + // Exclude it + $whereStatement = " AND `userid` != {?beg_userid?}"; + } // END - if + + // Let's check if there are some points left we can pay... + if ((isExtensionActive('autopurge')) && (isBegActiveEnabled()) && ((getApInactiveSince() > 0))) { + // Okay, include last online timestamp + $whereStatement .= ' AND (UNIX_TIMESTAMP() - `last_online`) >= {?ap_inactive_since?}'; } // END - if // SQL string to check for accounts - $result_main = SQL_QUERY_ESC("SELECT userid, email, gender, surname, family, beg_points AS points -FROM "._MYSQL_PREFIX."_user_data -WHERE status='CONFIRMED'".$whereStatement1." AND beg_points > 0 -ORDER BY beg_points DESC, userid -LIMIT %s", - array($whereStatement2), __FILE__, __LINE__); + $result_main = SQL_QUERY("SELECT + `userid`, `email`, `gender`, `surname`, `family`, `beg_points` +FROM + `{?_MYSQL_PREFIX?}_user_data` +WHERE + `status`='CONFIRMED'" . $whereStatement . " AND + `beg_points` > 0 +ORDER BY + `beg_points` DESC, + `userid` ASC +LIMIT {?beg_ranks?}", __FILE__, __LINE__); - if (SQL_NUMROWS($result_main) > 0) { + if (!SQL_HASZERONUMS($result_main)) { // Load our winners... while ($content = SQL_FETCHARRAY($result_main)) { // Add points to user's account directly - ADD_POINTS_REFSYSTEM($content['userid'], $content['points'], false, "0", false, "direct"); - - // Translate gender/points - $content['gender'] = TRANSLATE_GENDER($content['gender']); - $content['points'] = TRANSLATE_COMMA($content['points']); + addPointsDirectly('monthly_beg', $content['userid'], $content['beg_points']); // Load email template and email it away - $msg = LOAD_EMAIL_TEMPLATE("member_beg", $content, bigintval($content['userid'])); - SEND_EMAIL($content['email'], BEG_MONTHLY_RALLYE, $msg); + $message = loadEmailTemplate('member_beg', $content, bigintval($content['userid'])); + sendEmail($content['email'], '{--BEG_MONTHLY_RALLYE--}', $message); } // END - while // Reset accounts - $result = SQL_QUERY("UPDATE "._MYSQL_PREFIX."_user_data SET beg_points=0.00000 WHERE beg_points > 0", __FILE__, __LINE__); + $result = SQL_QUERY('UPDATE `{?_MYSQL_PREFIX?}_user_data` SET `beg_points`=0.00000 WHERE `beg_points` > 0', __FILE__, __LINE__); } // END - if // Free memory SQL_FREERESULT($result_main); } // END - if -// +// Debug line +//* DEBUG: */ logDebugMessage(__FILE__, __LINE__, 'Monthly reset ended.'); + +// [EOF] ?>