X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=inc%2Freset%2Freset_daily.php;h=eb1dc15b3dbd3183621e41460486516ec42500cd;hb=64c8349613addc3da2242c5cd6b99d64e3fb5f8e;hp=9df8158716b335d423c99fe096c40e2487d22e28;hpb=43885129ac24cee5545a8a5ad51e90aa182fdf46;p=mailer.git diff --git a/inc/reset/reset_daily.php b/inc/reset/reset_daily.php index 9df8158716..eb1dc15b3d 100644 --- a/inc/reset/reset_daily.php +++ b/inc/reset/reset_daily.php @@ -10,9 +10,14 @@ * -------------------------------------------------------------------- * * Kurzbeschreibung : Dinge, die beim taeglichen Reset erledigt werden * * -------------------------------------------------------------------- * - * * + * $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 * * For more information visit: http://www.mxchange.org * * * * This program is free software; you can redistribute it and/or modify * @@ -32,75 +37,71 @@ ************************************************************************/ // Some security stuff... -if (ereg(basename(__FILE__), $_SERVER['PHP_SELF'])) -{ - $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php"; - require($INC); +if (!defined('__SECURITY')) { + die(); +} elseif (!isExtensionActive('sql_patches')) { + return; } +// Do not execute when script is in CSS mode or no daily reset +if ((getOutputMode() != 0) || (!isResetModeEnabled())) return; +//* DEBUG: */ outputHtml(basename(__FILE__)."
"); + // Update user profiles -if (GET_EXT_VERSION("order") >= "0.1.1") { +if ((isExtensionActive('order')) && (getExtensionVersion('order') >= '0.1.1')) { // Latest version - $result_daily = SQL_QUERY("UPDATE "._MYSQL_PREFIX."_user_data SET receive_mails=max_mails, mail_orders=0 WHERE receive_mails != max_mails", __FILE__, __LINE__); + $result_daily = SQL_QUERY("UPDATE `{?_MYSQL_PREFIX?}_user_data` SET receive_mails=max_mails, mail_orders=0 WHERE receive_mails != max_mails", __FILE__, __LINE__); } else { // Obsolete version - $result_daily = SQL_QUERY("UPDATE "._MYSQL_PREFIX."_user_data SET receive_mails=max_mails WHERE receive_mails != max_mails", __FILE__, __LINE__); + $result_daily = SQL_QUERY("UPDATE `{?_MYSQL_PREFIX?}_user_data` SET receive_mails=max_mails WHERE receive_mails != max_mails", __FILE__, __LINE__); } // Transfer points from locked_points to points -$result_daily = SQL_QUERY("SELECT userid FROM "._MYSQL_PREFIX."_user_data WHERE ref_payout=0 AND status='CONFIRMED' ORDER BY userid", __FILE__, __LINE__); +$result_daily = SQL_QUERY("SELECT userid FROM `{?_MYSQL_PREFIX?}_user_data` WHERE ref_payout=0 AND `status`='CONFIRMED' ORDER BY `userid` ASC", __FILE__, __LINE__); + +//* DEBUG: */ outputHtml(basename(__FILE__).":payout=0;daily|numRows=".SQL_NUMROWS($result_daily)."
"); +if (SQL_NUMROWS($result_daily) > 0) { + // Init SQLs + initSqls(); -if (SQL_NUMROWS($result_daily) > 0) -{ // Start checking accounts which are on 0 confirmed-to-go mails - while (list($uid) = SQL_FETCHROW($result_daily)) - { - $result_points = SQL_QUERY_ESC("SELECT ref_depth, locked_points FROM "._MYSQL_PREFIX."_user_points -WHERE userid=%s AND locked_points != 0.00000 ORDER BY ref_depth", - array(bigintval($uid)), __FILE__, __LINE__); - if (SQL_NUMROWS($result_points) > 0) - { + while ($content = SQL_FETCHARRAY($result_daily)) { + //* DEBUG: */ outputHtml(basename(__FILE__).":userid={$content['userid']}
"); + $result_points = SQL_QUERY_ESC("SELECT `ref_depth`, `locked_points` FROM `{?_MYSQL_PREFIX?}_user_points` +WHERE `userid`=%s AND `locked_points` != 0.00000 ORDER BY `ref_depth` ASC", + array(bigintval($content['userid'])), __FILE__, __LINE__); + + //* DEBUG: */ outputHtml(basename(__FILE__).":payout=0;points|numRows=".SQL_NUMROWS($result_points)."
"); + if (SQL_NUMROWS($result_points) > 0) { // Ok transfer points - while (list($dep, $locked) = SQL_FETCHROW($result_points)) - { - $result_update = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_user_points SET points=points+%s, locked_points=0.00000 -WHERE userid=%s AND ref_depth=%s LIMIT 1", - array($locked, bigintval($uid), $dep), __FILE__, __LINE__); + while ($content2 = SQL_FETCHARRAY($result_points)) { + // Merge both arrays + $content = merge_array($content, $content2); + + //* DEBUG: */ outputHtml(basename(__FILE__).":userid={$content['userid']},depth={$content['ref_depth']},locked={$content['locked_points']}
"); + addSql(SQL_QUERY_ESC("UPDATE `{?_MYSQL_PREFIX?}_user_points` SET `points`=`points`+%s, `locked_points`=0.00000 +WHERE `userid`=%s AND `ref_depth`=%d +LIMIT 1", + array($content['locked_points'], bigintval($content['userid']), $content['ref_depth']), __FILE__, __LINE__, false)); // Update mediadata as well - if (GET_EXT_VERSION("mediadata") >= "0.0.4") - { + if (getExtensionVersion('mediadata') >= '0.0.4') { // Update database - MEDIA_UPDATE_ENTRY(array("total_points"), "add", $locked); - } - } - } + updateMediadataEntry(array('total_points'), 'add', $content['locked_points']); + } // END - if + } // END - while + } // END - if // Free memory SQL_FREERESULT($result_points); - } -} + } // END - while + + // Run all SQLs + runFilterChain('run_sqls'); +} // END - if // Free memory SQL_FREERESULT($result_daily); -// Save config value for later references -$_CONFIG['last_update'] = time(); - -// Update database -$result_daily = SQL_QUERY("UPDATE "._MYSQL_PREFIX."_config -SET last_update=UNIX_TIMESTAMP() -WHERE config=0 AND last_update != UNIX_TIMESTAMP() -LIMIT 1", __FILE__, __LINE__); - -// Destroy cache -if ((GET_EXT_VERSION("cache") >= "0.1.2") && (SQL_AFFECTEDROWS() == 1)) -{ - if ($cacheInstance->cache_file("config", true)) - { - $cacheInstance->cache_replace("last_update", time(), "0", $cacheArray); - } -} - -// +// [EOF] ?>