A lot while() conditions rewritten to SQL_FETCHARRAY(), see bug #107, @TODO tags...
[mailer.git] / inc / modules / member / what-points.php
1 <?php
2 /************************************************************************
3  * MXChange v0.2.1                                    Start: 10/19/2003 *
4  * ===============                              Last change: 11/12/2004 *
5  *                                                                      *
6  * -------------------------------------------------------------------- *
7  * File              : what-points.php                                  *
8  * -------------------------------------------------------------------- *
9  * Short description : All your collected points...                     *
10  * -------------------------------------------------------------------- *
11  * Kurzbeschreibung  : Alle Ihrer gesammelten Punkte                    *
12  * -------------------------------------------------------------------- *
13  *                                                                      *
14  * -------------------------------------------------------------------- *
15  * Copyright (c) 2003 - 2008 by Roland Haeder                           *
16  * For more information visit: http://www.mxchange.org                  *
17  *                                                                      *
18  * This program is free software; you can redistribute it and/or modify *
19  * it under the terms of the GNU General Public License as published by *
20  * the Free Software Foundation; either version 2 of the License, or    *
21  * (at your option) any later version.                                  *
22  *                                                                      *
23  * This program is distributed in the hope that it will be useful,      *
24  * but WITHOUT ANY WARRANTY; without even the implied warranty of       *
25  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the        *
26  * GNU General Public License for more details.                         *
27  *                                                                      *
28  * You should have received a copy of the GNU General Public License    *
29  * along with this program; if not, write to the Free Software          *
30  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,               *
31  * MA  02110-1301  USA                                                  *
32  ************************************************************************/
33
34 // Some security stuff...
35 if (!defined('__SECURITY')) {
36         $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";
37         require($INC);
38 } elseif (!IS_MEMBER()) {
39         LOAD_URL("modules.php?module=index");
40 }
41
42 // Add description as navigation point
43 ADD_DESCR("member", __FILE__);
44
45 $result_depths = SQL_QUERY("SELECT level, percents FROM `{!_MYSQL_PREFIX!}_refdepths` ORDER BY level", __FILE__, __LINE__);
46 $depths = SQL_NUMROWS($result_depths);
47
48 // Add many more rows for the login/turbo/ref/order bonus
49 // @TODO Should we rewrite this to a filter?
50 if (!EXT_IS_ACTIVE("bonus")) $depths += 1;
51 if (GET_EXT_VERSION("bonus") >= "0.2.2") $depths += 6;
52 if (GET_EXT_VERSION("bonus") >= "0.4.4") $depths += 4;
53
54 // Remember row count in constant
55 define('__ROWS_VALUE', ($depths*2+15));
56
57 // Init some vars...
58 $TPTS = 0; $TREF = 0; $TLOCK = 0; $OUT = "";
59
60 // Load ref levels
61 while ($content = SQL_FETCHARRAY($result_depths)) {
62         // Initialize ref-count
63         $REFS = 0;
64
65         // Load referal points
66         $result_points = SQL_QUERY_ESC("SELECT points, locked_points FROM `{!_MYSQL_PREFIX!}_user_points` WHERE userid=%s AND ref_depth=%d LIMIT 1", array($GLOBALS['userid'], bigintval($content['level'])), __FILE__, __LINE__);
67         if (SQL_NUMROWS($result_points) == 1) {
68                 list($points, $locked) = SQL_FETCHROW($result_points);
69                 SQL_FREERESULT($result_points);
70                 // Also count locked points
71                 $TPTS += $points; $TLOCK += $locked;
72         } else {
73                 $points = "0.00000"; $locked = "0.00000";
74         }
75
76         // Load referal counts
77         $result_refs = SQL_QUERY_ESC("SELECT counter FROM `{!_MYSQL_PREFIX!}_refsystem` WHERE userid=%s AND level='%s' LIMIT 1",
78                 array($GLOBALS['userid'], bigintval($content['level'])), __FILE__, __LINE__);
79         if (SQL_NUMROWS($result_refs) == 1) {
80                 list($REFS) = SQL_FETCHROW($result_refs);
81                 SQL_FREERESULT($result_refs);
82                 $TREF += $REFS;
83         } else {
84                 $REFS = 0;
85         }
86
87         // Transfer data to array for template
88         $content = array(
89                 'lvl'    => $content['level'],
90                 'per'    => TRANSLATE_COMMA($content['percents']),
91                 'points' => TRANSLATE_COMMA($points),
92                 'refs'   => TRANSLATE_COMMA($REFS),
93         );
94
95         // Output row
96         $OUT .= LOAD_TEMPLATE("member_points_row", true, $content);
97 }
98
99 // Free memory
100 SQL_FREERESULT($result_depths);
101
102 // Put rows to constant for the main template
103 define('__REF_LEVEL_ROWS', $OUT);
104
105 $result = SQL_QUERY_ESC("SELECT used_points, ref_payout FROM `{!_MYSQL_PREFIX!}_user_data` WHERE userid=%s LIMIT 1",
106         array($GLOBALS['userid']), __FILE__, __LINE__);
107 list($USED, $PAY) = SQL_FETCHROW($result);
108 SQL_FREERESULT($result);
109
110 // Initialize variables
111 $CONFIRMED = "---"; $SENT = "---"; $RECEIVED = "---";
112
113 // Only user >= v0.1.2: Fetch confirmed mails counter
114 if (GET_EXT_VERSION("user") >= "0.1.2") {
115         $ADD = "";
116         if (GET_EXT_VERSION("user") >= "0.1.4") {
117                 $ADD = ", emails_sent, emails_received";
118         }
119         $result = SQL_QUERY_ESC("SELECT mails_confirmed".$ADD." FROM `{!_MYSQL_PREFIX!}_user_data` WHERE userid=%s LIMIT 1", array($GLOBALS['userid']), __FILE__, __LINE__);
120         list($CONFIRMED, $SENT, $RECEIVED) = SQL_FETCHROW($result);
121         SQL_FREERESULT($result);
122
123         // Please update the user extension if you see 3 dashes
124         if (empty($SENT))     $SENT     = "---";
125         if (empty($RECEIVED)) $RECEIVED = "---";
126 } else {
127         // Please update!
128         $CONFIRMED = "---";
129 }
130
131 // If TLOCK is 0 add 3 zeros for floating
132 if ($TLOCK == "0") $TLOCK = "0.00000";
133
134 // Remember several values in constants
135 define('__USED_VALUE' , TRANSLATE_COMMA($USED));
136 define('__TPTS_VALUE' , TRANSLATE_COMMA($TPTS - $USED));
137 define('__TREF_VALUE' , $TREF);
138 define('__TLOCK_VALUE', TRANSLATE_COMMA($TLOCK));
139
140 // Fixes a bug when there is no bonus extension installed
141 if (EXT_VERSION_IS_OLDER("bonus", "0.4.4")) setConfigEntry('bonus_active', "X");
142
143 // Display login bonus and turbo-click bonus
144 if ((GET_EXT_VERSION("bonus") >= "0.2.2") && (EXT_IS_ACTIVE("bonus")) && (getConfig('bonus_active') == "Y")) {
145         $ADD = ", 0, 0, 0";
146         if (GET_EXT_VERSION("bonus") >= "0.4.4") $ADD = ", bonus_ref, bonus_order, bonus_stats";
147
148         // Load data
149         $result = SQL_QUERY_ESC("SELECT login_bonus, turbo_bonus".$ADD." FROM `{!_MYSQL_PREFIX!}_user_data` WHERE userid=%s LIMIT 1",
150                 array($GLOBALS['userid']), __FILE__, __LINE__);
151
152         // We don't add this points now. This will be done after each month
153         list($login, $turbo, $ref, $order, $stats) = SQL_FETCHROW($result);
154         SQL_FREERESULT($result);
155
156         // Prepare constants
157         define('__TURBO_VALUE',  TRANSLATE_COMMA($turbo));
158         define('__LOGIN_VALUE',  TRANSLATE_COMMA($login));
159
160         if (GET_EXT_VERSION("bonus") >= "0.4.4") {
161                 // Add referal, stats and order bonys
162                 define('__REF_VALUE'  ,  TRANSLATE_COMMA($ref));
163                 define('__ORDER_VALUE',  TRANSLATE_COMMA($order));
164                 define('__STATS_VALUE',  TRANSLATE_COMMA($stats));
165         }
166
167         // Total bonus points
168         define('__TTOTAL_VALUE', TRANSLATE_COMMA($turbo + $login + $ref + $order + $stats));
169
170         // Output rows
171         define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_bonus_rows", true));
172 } elseif (getConfig('bonus_active') != "Y") {
173         // Bonus active rallye deactivated
174         define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_bonus_disabled", true));
175 } elseif ((IS_ADMIN()) && (EXT_VERSION_IS_OLDER("bonus", "0.2.2")) && (EXT_IS_ACTIVE("bonus"))) {
176         // Please upgrade your bonus extension to v0.2.2 or newer!
177         define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_upgrade"));
178 } else {
179         // Members shall see no special rows here
180         define('__SPECIAL_ROWS', "");
181 }
182
183 // Remeber values for the final template
184 define('__PAY_VALUE'      , $PAY);
185 define('__CONFIRMED_VALUE', $CONFIRMED);
186 define('__RECEIVE_VALUE'  , $RECEIVED);
187 define('__SENT_VALUE'     , $SENT);
188
189 // Load final template
190 if (EXT_IS_ACTIVE("user")) {
191         // Load template when required extension is there
192         LOAD_TEMPLATE("member_points");
193 } elseif (IS_ADMIN()) {
194         // Missing extension
195         addFatalMessage(__FILE__, __LINE__, getMessage('EXTENSION_PROBLEM_EXT_INACTIVE'), "user");
196 } else {
197         // Message for user
198         LOAD_TEMPLATE("admin_settings_saved", false, getMessage('PROBLEM_POINTS_OVERVIEW_UNAVAILABLE'));
199 }
200
201 if (EXT_IS_ACTIVE("payout")) {
202         // Payput extension is installed and active so we can check if the user has enougth points
203         PAYOUT_OUTPUT_PAYOUT_LIST(REVERT_COMMA(($TPTS - $USED)));
204 }
205
206 //
207 ?>