SQL_FREERESULT($result);
// Set notified to Y
- SQL_QUERY_ESC("UPDATE `{?_MYSQL_PREFIX?}_rallye_data` SET `notified`='Y' WHERE `id`=%s LIMIT 1",
+ SQL_QUERY_ESC("UPDATE
+ `{?_MYSQL_PREFIX?}_rallye_data`
+SET
+ `notified`='Y'
+WHERE
+ `id`=%s
+LIMIT 1",
array(bigintval($id)), __FUNCTION__, __LINE__);
// Transfer all neccessary data to the $content array
- $content['userid_cnt'] = countSumTotalData('CONFIRMED','user_data','userid','status',true);
+ $content['userid_cnt'] = getTotalConfirmedUser();
$content['start'] = generateDateTime($start, 2);
$content['end'] = generateDateTime($end , 2);
$content['now_t'] = generateDateTime(time(), 2);
$content['prices'] = addReferalRallyePrices($id);
// Query all users
- $result_user = SQL_QUERY("SELECT `userid` FROM `{?_MYSQL_PREFIX?}_user_data` WHERE `status`='CONFIRMED' ORDER BY `userid` ASC", __FUNCTION__, __LINE__);
+ $result_user = SQL_QUERY("SELECT
+ `userid`
+FROM
+ `{?_MYSQL_PREFIX?}_user_data`
+WHERE
+ `status`='CONFIRMED'
+ORDER BY
+ `userid` ASC", __FUNCTION__, __LINE__);
// Let's begin with the userids...
while ($row = SQL_FETCHARRAY($result_user)) {
if (empty($cnt)) $cnt = '0'; // Added prevent some unknown troubles... :-?
// Check if line is already included...
- $result_ref = SQL_QUERY_ESC("SELECT `id` FROM `{?_MYSQL_PREFIX?}_rallye_users` WHERE `rallye_id`=%s AND `userid`=%s LIMIT 1",
+ $result_ref = SQL_QUERY_ESC("SELECT
+ `id`
+FROM
+ `{?_MYSQL_PREFIX?}_rallye_users`
+WHERE
+ `rallye_id`=%s AND
+ `userid`=%s
+LIMIT 1",
array(bigintval($id), bigintval($content['userid'])), __FUNCTION__, __LINE__);
if (SQL_NUMROWS($result_ref) == 0) {
// Free memory
d.max_mails > 0 AND
d.mails_confirmed >= {?ref_payout?} AND
p.ref_depth=1 AND
- p.points > 0
- AND d.userid=%s",
+ p.points > 0 AND
+ d.userid=%s",
array(bigintval($content['userid'])), __FUNCTION__, __LINE__);
// Get points
if (empty($cpoints)) $cpoints = '0.00000';
// Add info line
- SQL_QUERY_ESC("INSERT INTO `{?_MYSQL_PREFIX?}_rallye_users` (`rallye_id`, `userid`, `refs`, `curr_points`)
-VALUES (%s, %s, %s, %s)",
+ SQL_QUERY_ESC("INSERT INTO
+ `{?_MYSQL_PREFIX?}_rallye_users`
+(`rallye_id`, `userid`, `refs`, `curr_points`)
+ VALUES
+(%s, %s, %s, %s)",
array(
bigintval($id),
bigintval($content['userid']),
}
//
-function addReferalRallyePrices ($rallye, $mode='email') {
+function addReferalRallyePrices ($rallye, $mode = 'email') {
// Output mode
switch($mode) {
- case 'email': $mode = "\n"; break;
+ case 'email': $mode = "\n"; break;
case 'html' : $mode = "<br />\n"; break;
} // END - switch
// Load prices
- $result_prices = SQL_QUERY("SELECT
+ $result_prices = SQL_QUERY_ESC("SELECT
`price_level`, `points`, `info`
FROM
`{?_MYSQL_PREFIX?}_rallye_prices`
WHERE
- `rallye_id`='".$rallye."'
+ `rallye_id`=%s
ORDER BY
`price_level` ASC",
- __FUNCTION__, __LINE__);
+ array($rallye), __FUNCTION__, __LINE__);
+
+ // Entries found?
if (SQL_NUMROWS($result_prices) > 0) {
// Load prices
- if ($mode == "\n") $prices = "{--RALLYE_MEMBER_PRICES_ADDED--}:".$mode."------------------------------".$mode;
+ if ($mode == "\n") $prices = '{--RALLYE_MEMBER_PRICES_ADDED--}:' . $mode . '------------------------------' . $mode;
+
$prices = '';
while ($content = SQL_FETCHARRAY($result_prices)) {
- $prices .= $content['price_level'].getMessage('RALLYE_PRICE').": ";
+ $prices .= $content['price_level']. '{--RALLYE_PRICE--}: ';
if (!empty($content['info'])) {
$prices .= $content['info'];
} else {
//
function addReferalRallyeTopUsers ($rallye, $default=0) {
+ // Init variables
+ $min_users = 0; $min_prices = 0;
+
// First check how many prices are set
- $result = SQL_QUERY_ESC("SELECT `id` FROM `{?_MYSQL_PREFIX?}_rallye_prices` WHERE `rallye_id`=%s ORDER BY price_level",
- array(bigintval($rallye)), __FUNCTION__, __LINE__);
- $prices = SQL_NUMROWS($result);
- SQL_FREERESULT($result);
+ $prices = countSumTotalData($rallye, 'rallye_prices', 'id', 'rallye_id', true);
// And load only limited users
$result = SQL_QUERY_ESC("SELECT
ON
u.rallye_id=rd.id
WHERE
- u.`rallye_id`=%s AND r.counter > 0
+ u.`rallye_id`=%s AND
+ r.counter > 0
ORDER BY
u.refs DESC",
array(bigintval($rallye)), __FUNCTION__, __LINE__);
// Load users
$DATA = array(
- 'userid' => array(),
- 'ref' => array(),
- 'cpoints' => array()
+ 'userid' => array(),
+ 'ref' => array(),
+ 'cpoints' => array()
);
+ // Load all users
while ($content = SQL_FETCHARRAY($result)) {
// Get current refs
$cnt = getReferalRallyeRefsCount($content['userid'], $content['refs']);
$userid = '---';
// List only users with at least one ref!
- //* DEBUG: */ print("*".$cnt.'/'.$content['userid'].'/'.$content['curr_points'].'/'.$refpoints."*<br />");
+ //* DEBUG: */ debugOutput('*'.$cnt.'/'.$content['userid'].'/'.$content['curr_points'].'/'.$refpoints.'*');
if (($cnt > 0) && ($refpoints > $content['curr_points'])) { $userid = $content['userid']; } else { $cnt = ''; }
// Save values to array
array_pk_sort($DATA, array('ref', 'cpoints'), 0, 1, true);
// Generate table
- $OUT = loadTemplate('guest_rallye_header', true);
+ $OUT = '';
$SW = 2;
for ($idx = '0'; $idx < $prices; $idx++) {
if (empty($DATA['userid'][$idx])) $DATA['userid'][$idx] = '---';
if (empty($DATA['ref'][$idx])) $DATA['ref'][$idx] = '---';
- // Add row
- $OUT .= "<tr>
- <td class=\"switch_sw".$SW." bottom\">".($idx+1).".</td>
- <td align=\"center\" class=\"switch_sw".$SW." bottom\">";
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '<strong>';
- $OUT .= $DATA['userid'][$idx];
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '</strong>';
- $OUT .= "</td>
- <td align=\"center\" class=\"switch_sw".$SW." bottom\">";
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '<strong>';
- $OUT .= $DATA['ref'][$idx];
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '</strong>';
- $OUT .= "</td>
-</tr>\n";
+
+ // Prepare marking of default (maybe current user's) id
+ $start = ''; $end = '';
+ if (($DATA['userid'][$idx] == $default) && ($default > 0)) {
+ $start = '<strong>';
+ $end = '</strong>';
+ } // END - if
+
+ // Prepare content
+ $content = array(
+ 'sw' => $SW,
+ 'idx' => ($idx + 1),
+ 'start' => $start,
+ 'end' => $end,
+ 'userid' => $DATA['userid'][$idx],
+ 'ref' => $DATA['ref'][$idx],
+ 'info' => ''
+ );
+
+ // Load row template and switch color
+ $OUT .= loadTemplate('guest_rallye_row', true, $content);
$SW = 3 - $SW;
} // END - for
- // Translate min_prices/users
- $content['min_prices'] = determineReferalRallyeMinimumPrices($min_prices);
- $content['min_users'] = determineReferalRallyeMinimumUsers($min_users);
-
- // Add footer
- $OUT .= loadTemplate('guest_rallye_footer', true, $content);
+ // Add min_prices/users
+ $content['rows'] = $OUT;
+ $content['min_prices'] = bigintval($min_prices);
+ $content['min_users'] = bigintval($min_users);
// And finnally return the output
- return $OUT;
+ return loadTemplate('guest_rallye', true, $content);
}
// Run this function only when a new member has confirmed his email address!
// Updated extension?
if (isExtensionInstalledAndNewer('rallye', '0.2.0')) {
- $add .= ", `min_users`, `min_prices`";
+ $add .= ', `min_users`, `min_prices`';
} // END - if
// Check for an auto-add rallye
} // END - if
// Check if line is already included...
- $result = SQL_QUERY_ESC("SELECT `id` FROM `{?_MYSQL_PREFIX?}_rallye_users` WHERE `rallye_id`=%s AND `userid`=%s LIMIT 1",
+ $result = SQL_QUERY_ESC("SELECT
+ `id`
+FROM
+ `{?_MYSQL_PREFIX?}_rallye_users`
+WHERE
+ `rallye_id`=%s AND
+ `userid`=%s
+LIMIT 1",
array(
bigintval($id),
bigintval($userid)
// Is this user added?
if (SQL_NUMROWS($result) < 1) {
// Add userid and his ref count to table
- SQL_QUERY_ESC("INSERT INTO `{?_MYSQL_PREFIX?}_rallye_users` (`rallye_id`, `userid`, `refs`)
-VALUES ('%s','%s',0)",
+ SQL_QUERY_ESC("INSERT INTO
+ `{?_MYSQL_PREFIX?}_rallye_users`
+(`rallye_id`, `userid`, `refs`)
+ VALUES
+(%s,%s,0)",
array(
bigintval($id),
bigintval($userid)
$prices = getArrayFromReferalRallyeUsers($id);
// Init array
- $DATA = array(); $cnt = '0';
+ $DATA = array();
+ $cnt = '0';
$users = array();
$DATA['title'] = $title;
$DATA['start'] = generateDateTime($start, 1);
foreach($prices['userid'] as $key => $userid) {
// Check status
// active = 1: account is still confirmed
- // active = '0': account is deleted or locked
- $result = SQL_QUERY_ESC("SELECT
- COUNT(`userid`) AS active
-FROM
- `{?_MYSQL_PREFIX?}_user_data`
-WHERE
- `userid`=%s AND `status`='CONFIRMED'
-LIMIT 1",
- array(bigintval($userid)), __FUNCTION__, __LINE__);
- list($active) = SQL_FETCHROW($result);
- SQL_FREERESULT($result);
+ // active = 0: account is deleted or locked
+ $active = countSumTotalData($DATA['userid'][$idx], 'user_data', 'userid', 'userid', true, " AND `status`='CONFIRMED'");
$prices['active'][$key] = $active;
$ret = '';
// Load users
- $result = SQL_QUERY_ESC("SELECT `userid`, `gender`, `surname`, `family`, `email` FROM `{?_MYSQL_PREFIX?}_user_data` WHERE `userid` IN(%s) AND `status`='CONFIRMED' ORDER BY `userid` ASC LIMIT %s",
- array($userid_string, count($userIds)), __FUNCTION__, __LINE__);
+ $result = SQL_QUERY_ESC("SELECT
+ `userid`, `gender`, `surname`, `family`, `email`
+FROM
+ `{?_MYSQL_PREFIX?}_user_data`
+WHERE
+ `userid` IN(%s) AND
+ `status`='CONFIRMED'
+ORDER BY
+ `userid` ASC
+LIMIT %s",
+ array(
+ $userid_string,
+ count($userIds)
+ ), __FUNCTION__, __LINE__);
while ($content = SQL_FETCHARRAY($result)) {
// Construct the message masked and add it
$ret .= sprintf("%s %s %s (%s) - %s\n",
);
// Load prices
- $result = SQL_QUERY_ESC("SELECT price_level, points, info FROM `{?_MYSQL_PREFIX?}_rallye_prices` WHERE `rallye_id`=%s ORDER BY price_level",
- array(bigintval($rallye)), __FUNCTION__, __LINE__);
+ $result = SQL_QUERY_ESC("SELECT
+ `price_level`, `points`, `info`
+FROM
+ `{?_MYSQL_PREFIX?}_rallye_prices`
+WHERE
+ `rallye_id`=%s
+ORDER BY
+ `price_level` ASC",
+ array(bigintval($rallye)), __FUNCTION__, __LINE__);
// Transfer elements
while ($content = SQL_FETCHARRAY($result)) {
// Init multi array
$users = array(
- 'userid' => array(),
+ 'userid' => array(),
'ref' => array(),
'cpoints' => array(),
);
if (empty($refpoints)) $refpoints = '0';
// Store calculated new refs to array
- $users['userid'][] = $content['userid'];
+ $users['userid'][] = $content['userid'];
$users['ref'][] = abs($cnt - $content['refs']);
$users['cpoints'][] = $refpoints - $content['curr_points'];
} // END - while
SQL_FREERESULT($result_user);
// Sort array for refs (descending)
- array_pk_sort($users, array("ref", "cpoints"), 0, 1, true);
+ array_pk_sort($users, array('ref', 'cpoints'), 0, 1, true);
// Load prices array (!)
$prices = getArrayFromReferalRallyePrices($rallye);
return $prices;
}
-//
+// @TODO This function does not load min_users, min_prices, please encapsulate loading rallye data with e.g. getRallyeDataFromId()
function addReferalRallyeWinners ($rallye, $default=0) {
// First check how many prices are set
$result_prices = SQL_QUERY_ESC("SELECT `id` FROM `{?_MYSQL_PREFIX?}_rallye_prices` WHERE `rallye_id`=%s ORDER BY `price_level` ASC",
$DATA = getArrayFromReferalRallyeUsers($rallye);
// Generate table
- $OUT = loadTemplate('guest_rallye_expired_header', true);
- $SW = 2;
+ $OUT = ''; $SW = 2;
for ($idx = '0'; $idx < $prices; $idx++) {
// Check status
// active = 1: account is still confirmed
- // active = '0': account is deleted or locked
+ // active = 0: account is deleted or locked
$active = countSumTotalData($DATA['userid'][$idx], 'user_data', 'userid', 'userid', true, " AND `status`='CONFIRMED'");
if (empty($DATA['userid'][$idx])) $DATA['userid'][$idx] = '---';
$DATA['infos'][$idx] = $DATA['points'][$idx] . ' {?POINTS?}';
}
- // Add row
- $add = '';
- $OUT .= "<tr>
- <td class=\"switch_sw".$SW." bottom".$add."\">".($idx+1).".</td>
- <td align=\"center\" class=\"switch_sw".$SW." bottom".$add."\">";
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '<strong>';
- $OUT .= $DATA['userid'][$idx];
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '</strong>';
- $OUT .= "</td>
- <td align=\"center\" class=\"switch_sw".$SW." bottom".$add."\">";
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '<strong>';
- $OUT .= $DATA['ref'][$idx];
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '</strong>';
- $OUT .= "</td>
- <td align=\"center\" class=\"switch_sw".$SW." bottom".$add."\">";
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '<strong>';
- $OUT .= $DATA['infos'][$idx];
- if (($DATA['userid'][$idx] == $default) && ($default > 0)) $OUT .= '</strong>';
- $OUT .= "</td>
-</tr>\n";
+ // Prepare marking of default (maybe current user's) id
+ $start = ''; $end = '';
+ if (($DATA['userid'][$idx] == $default) && ($default > 0)) {
+ $start = '<strong>';
+ $end = '</strong>';
+ } // END - if
+
+ // Prepare content
+ $content = array(
+ 'sw' => $SW,
+ 'idx' => ($idx + 1),
+ 'userid' => $DATA['userid'][$idx],
+ 'ref' => $DATA['ref'][$idx],
+ 'infos' => $DATA['infos'][$idx],
+ 'start' => $start,
+ 'end' => $end
+ );
+
+ // Load row template
+ $OUT .= loadTemplate('guest_rallye_row', true, $content);
$SW = 3 - $SW;
} // END - for
- // Add footer
- $OUT .= loadTemplate('guest_rallye_expired_footer', true);
+ // Prepare content
+ $content = array(
+ 'rows' => $OUT,
+ 'min_users' => '???',
+ 'min_prices' => '???'
+ );
- // And finnally return the output
- return $OUT;
+ // Load main template and finnally return the output
+ return loadTemplate('guest_rallye', true, $content);
}
//
function purgeExpiredReferalRallyes () {
// Check for expired rallyes
$EXPIRE = 3; // @TODO The hard-coded value...
- $result_rallye = SQL_QUERY_ESC("SELECT id, title, start_time, end_time
-FROM `{?_MYSQL_PREFIX?}_rallye_data`
-WHERE end_time <= (UNIX_TIMESTAMP() - {?ONE_DAY?} - %s) AND expired='Y'",
+ $result_rallye = SQL_QUERY_ESC("SELECT
+ `id`, `title`, `start_time`, `end_time`
+FROM
+ `{?_MYSQL_PREFIX?}_rallye_data`
+WHERE
+ `end_time` <= (UNIX_TIMESTAMP() - {?ONE_DAY?} - %s) AND
+ `expired`='Y'",
array($EXPIRE), __FUNCTION__, __LINE__);
if (SQL_NUMROWS($result_rallye) > 0) {
$read = substr($read, 7, strpos($read, '.') - 7);
// Accept only template names between 1 and 255 chars length
- if ((strlen($read) < 256) && (!empty($read))) $ral[] = $read;
- } // END - while
+ if ((strlen($read) < 256) && (!empty($read))) {
+ // Valid entry found!
+ $ral[$read] = $read;
+ } else {
+ // Log invalid
+ logDebugMessage(__FUNCTION__, __LINE__, sprintf("WARNING: Template %s not used.", $read));
+ }
+ } // END - foreach
// Do we have found templates which we can link with the new rallye?
if (!empty($ral[0])) {
// Generate selection box for all found templates
- // @TODO Rewrite this to our API function
- $OUT = "<select name=\"".$name."\" size=\"1\" class=\"admin_select\">
- <option value=\"\">{--SELECT_NONE--}</option>\n";
- foreach ($ral as $rallye) {
- $OUT .= " <option value=\"".$rallye."\"";
- if ($default == $rallye) $OUT .= ' selected="selected"';
- $OUT .= ">".$rallye."</option>\n";
- } // END - foreach
- $OUT .= "</select>\n";
+ $OUT = '<select name="' . $name . '" size="1" class="admin_select">';
+ $OUT .= generateOptionList('/ARRAY/', array_keys($ral), array_values($ral), $default, '', 'none');
+ $OUT .= '</select>';
} else {
// No rallye templates found
$OUT = getMessage('RALLYE_NO_TEMPLATES_FOUND');
return $OUT;
}
-//
-function getReferalRallyeRefsCount ($userid, $old = '0') {
+// @TODO Please document this function
+function getReferalRallyeRefsCount ($currUserid, $old = '0') {
// Check current refs
if (isExtensionInstalledAndNewer('cache', '0.1.2')) {
// Get refs from cache
$cnt = '0';
foreach ($GLOBALS['cache_array']['refsystem']['userid'] as $id => $userid) {
// Do we have a ref for this user?
- //* DEBUG: */ print("id={$id},userid={$userid},userid={$userid},old={$old},level={$GLOBALS['cache_array']['refsystem']['level'][$id]}<br />");
- if (($userid == $userid) && ($GLOBALS['cache_array']['refsystem']['level'][$id] == 1)) {
- //* DEBUG: */ print("userid matches!<br />");
+ //* DEBUG: */ debugOutput('id='.$id.',userid='.$userid.',userid='.$userid.',old='.$old.',level='.$GLOBALS['cache_array']['refsystem']['level'][$id]);
+ if (($currUserid == $userid) && ($GLOBALS['cache_array']['refsystem']['level'][$id] == 1)) {
+ //* DEBUG: */ debugOutput('userid matches!');
foreach ($GLOBALS['cache_array']['refdepths']['level'] as $level) {
if (($level == $GLOBALS['cache_array']['refsystem']['level'][$id]) && ($level == 1)) {
// Level does exist so abort here
$cnt = $GLOBALS['cache_array']['refsystem']['counter'][$id];
- //* DEBUG: */ print("*".$userid.'/'.$cnt."*<br />");
+ //* DEBUG: */ debugOutput('*'.$userid.'/'.$cnt.'*');
break;
} elseif ($level > 1) {
// Not interesting here...
} // END - if
} // END - foreach
- //* DEBUG: */ print("<pre>");
- //* DEBUG: */ print(print_r($GLOBALS['cache_array']['refsystem'], true));
- //* DEBUG: */ print("</pre>");
+ //* DEBUG: */ debugOutput('<pre>'.print_r($GLOBALS['cache_array']['refsystem'], true).'</pre>');
//* DEBUG: */ shutdown();
if ($cnt > 0) {
incrementStatsEntry('cache_hits');
// Remove old refs
- //* DEBUG: */ print('+'.$cnt.'/'.$old."+<br />");
+ //* DEBUG: */ debugOutput('+'.$cnt.'/'.$old.'+');
$cnt -= $old;
} // END - if
} else {
// Load current refs from database
- $result_ref = SQL_QUERY_ESC("SELECT SUM(s.counter) AS cnt
-FROM `{?_MYSQL_PREFIX?}_refsystem` AS s
-LEFT JOIN `{?_MYSQL_PREFIX?}_refdepths` AS d
-ON s.level=d.level
-WHERE s.userid=%s AND s.level=1", array(bigintval($userid)), __FUNCTION__, __LINE__);
+ $result_ref = SQL_QUERY_ESC("SELECT
+ SUM(s.counter) AS cnt
+FROM
+ `{?_MYSQL_PREFIX?}_refsystem` AS s
+LEFT JOIN
+ `{?_MYSQL_PREFIX?}_refdepths` AS d
+ON
+ s.level=d.level
+WHERE
+ s.userid=%s AND
+ s.level=1",
+ array(
+ bigintval($userid)
+ ), __FUNCTION__, __LINE__);
+
+ // Load count @TODO Can't we rewrite this to our API?
list($cnt) = SQL_FETCHROW($result_ref);
+
+ // Free result
SQL_FREERESULT($result_ref);
if (empty($cnt)) {
$cnt = '0';
}
// Return count
- //* DEBUG: */ print("*".$userid.'/'.$old.'/'.$cnt."*<br />");
+ //* DEBUG: */ debugOutput('*'.$userid.'/'.$old.'/'.$cnt.'*');
return $cnt;
}