2 /************************************************************************
\r
3 * MXChange v0.2.1 Start: 04/04/2004 *
\r
4 * ================ Last change: 06/13/2005 *
\r
6 * -------------------------------------------------------------------- *
\r
7 * File : ext-bonus.php *
\r
8 * -------------------------------------------------------------------- *
\r
9 * Short description : Bonus pages *
\r
10 * -------------------------------------------------------------------- *
\r
11 * Kurzbeschreibung : Bonus-Seiten *
\r
12 * -------------------------------------------------------------------- *
\r
14 * -------------------------------------------------------------------- *
\r
15 * Copyright (c) 2003 - 2008 by Roland Haeder *
\r
16 * For more information visit: http://www.mxchange.org *
\r
18 * This program is free software; you can redistribute it and/or modify *
\r
19 * it under the terms of the GNU General Public License as published by *
\r
20 * the Free Software Foundation; either version 2 of the License, or *
\r
21 * (at your option) any later version. *
\r
23 * This program is distributed in the hope that it will be useful, *
\r
24 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
\r
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
\r
26 * GNU General Public License for more details. *
\r
28 * You should have received a copy of the GNU General Public License *
\r
29 * along with this program; if not, write to the Free Software *
\r
30 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *
\r
31 * MA 02110-1301 USA *
\r
32 ************************************************************************/
\r
34 // Some security stuff...
\r
35 if (ereg(basename(__FILE__), $_SERVER['PHP_SELF']))
\r
37 $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4)."/security.php";
\r
41 // Version of this extension
\r
42 $EXT_VERSION = "0.8.6";
\r
44 // Auto-set extension version
\r
45 if (empty($EXT_VER)) $EXT_VER = $EXT_VERSION;
\r
47 // Version history array (add more with , "0.1" and so on)
\r
48 $EXT_VER_HISTORY = array("0.0", "0.1.6", "0.2.0", "0.2.1", "0.2.2", "0.2.3", "0.2.4", "0.2.5", "0.2.6", "0.2.7", "0.2.8", "0.2.9", "0.3.0", "0.3.1", "0.3.2", "0.3.3", "0.3.4", "0.3.5", "0.3.6", "0.3.7", "0.3.8", "0.3.9", "0.4.0", "0.4.1", "0.4.2", "0.4.3", "0.4.4", "0.4.5", "0.4.6", "0.4.7", "0.4.8", "0.4.9", "0.5.0", "0.5.1", "0.5.2", "0.5.3", "0.5.4", "0.5.5", "0.5.6", "0.5.7", "0.5.8", "0.5.9", "0.6.0", "0.6.1", "0.6.2", "0.6.3", "0.6.4", "0.6.5", "0.6.6", "0.6.7", "0.6.8", "0.6.9", "0.7.0", "0.7.1", "0.7.2", "0.7.3", "0.7.4", "0.7.5", "0.7.6", "0.7.7", "0.7.8", "0.7.9", "0.8.0", "0.8.1", "0.8.2", "0.8.3", "0.8.4", "0.8.5", "0.8.6");
\r
50 switch ($EXT_LOAD_MODE)
\r
52 case "register": // Do stuff when installtion is running (modules.php?module=admin&action=login is called)
\r
53 // SQL commands to run
\r
54 $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_admin_menu VALUES (NULL,'email','send_bonus','Bonusmail senden',5,'Versenden Sie hier Bonus-Mails an alle Mitglieder oder nur an alle aus einer Kategorie. Es spielt keine Rolle, wie viele Mails bereits versendet worden, Sie können hier immer senden.')";
\r
55 $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_member_menu VALUES (NULL,'main','bonus','Bonuspunkte',7,'Y','Y','',0)";
\r
56 $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_bonus";
\r
57 $SQLs[] = "CREATE TABLE "._MYSQL_PREFIX."_bonus (
\r
58 id bigint(20) NOT NULL auto_increment,
\r
59 cat_id bigint(20) NOT NULL default '0',
\r
60 subject varchar(255) NOT NULL default '',
\r
61 text longblob NOT NULL,
\r
62 receivers longblob NOT NULL,
\r
63 points bigint(20) NOT NULL default '0',
\r
64 time tinyint(4) NOT NULL default '0',
\r
65 data_type enum('NEW','QUEUE','SEND') NOT NULL default 'NEW',
\r
66 timestamp varchar(10) NOT NULL default '0',
\r
67 url varchar(255) NOT NULL default '',
\r
68 target_send bigint(20) NOT NULL default '0',
\r
69 clicks bigint(20) not null default '0',
\r
70 mails_sent bigint(20) not null default '0',
\r
74 $SQLs[] = "alter table "._MYSQL_PREFIX."_user_links modify link_type enum('NORMAL','BONUS') not null default 'NORMAL'";
\r
75 $SQLs[] = "alter table "._MYSQL_PREFIX."_user_links add bonus_id bigint not null default '0'";
\r
76 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_links ADD INDEX (bonus_id)";
\r
78 // Run this SQL when html or html_mail extension is installed
\r
79 if (EXT_IS_ACTIVE("html_mail")) $SQLs[] = "alter table "._MYSQL_PREFIX."_bonus add html_msg enum('Y','N') not null default 'N'";
\r
82 case "remove": // Do stuff when removing extension
\r
83 // SQL commands to run
\r
84 $SQLs[] = "DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_admin_menu WHERE what='bonus' OR what='config_bonus' OR what='send_bonus' OR what='list_bonus' LIMIT 4";
\r
85 $SQLs[] = "DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_member_menu WHERE what='bonus' LIMIT 1";
\r
86 $SQLs[] = "DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_guest_menu WHERE action='bonus' LIMIT 1";
\r
87 $SQLs[] = "alter table "._MYSQL_PREFIX."_user_links modify link_type enum('NORMAL') not null default 'NORMAL'";
\r
88 $SQLs[] = "alter table "._MYSQL_PREFIX."_user_links drop bonus_id";
\r
89 $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_bonus";
\r
90 $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_bonus_urls";
\r
91 $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_bonus_customer";
\r
92 $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_bonus_turbo";
\r
95 case "activate": // Do stuff when admin activates this extension
\r
96 // SQL commands to run
\r
97 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_member_menu SET visible='Y', locked='N' WHERE action='main' AND what='bonus' LIMIT 1";
\r
98 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_guest_menu SET visible='Y', locked='N' WHERE action='bonus' LIMIT 1";
\r
99 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_mod_reg SET locked='N', hidden='N', admin_only='N', mem_only='N' WHERE module='show_bonus' LIMIT 1";
\r
102 case "deactivate": // Do stuff when admin deactivates this extension
\r
103 // SQL commands to run
\r
104 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_member_menu SET visible='Y', locked='Y' WHERE action='main' AND what='bonus' LIMIT 1";
\r
105 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_guest_menu SET visible='Y', locked='Y' WHERE action='bonus' LIMIT 1";
\r
106 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_mod_reg SET locked='Y' WHERE module='show_bonus' LIMIT 1";
\r
109 case "update": // Update an extension
\r
112 case "0.1.6": // SQL queries for v0.1.6
\r
113 // Update notes (these will be set as task text!)
\r
114 $UPDATE_NOTES = "Paid-Links wurden verschoben in die Erweiterung <STRONG>paidlinks</STRONG>.";
\r
117 case "0.2.0": // SQL queries for v0.2.0
\r
118 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_bonus SET target_send=mails_sent WHERE target_send='0' AND mails_sent>0 AND receivers != ''";
\r
120 // Update notes (these will be set as task text!)
\r
121 $UPDATE_NOTES = "Behebt ein Versand-Problem mit den Bonus-Mails. Es wurde die Spalte target_send nicht beim Einfügen der Buchung gessetzt. Bitte laden Sie sich dazu - wenn nicht bereits geschehen - alle Patches bis mindestens Patch 240 unter <A href=\"".URL."/modules.php?module=admin&what=updates\">Updates prüfen</A> herunter.";
\r
124 case "0.2.1": // SQL queries for v0.2.1
\r
125 $SQLs[] = "DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_admin_menu WHERE what='config_bonus' LIMIT 1";
\r
126 $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_admin_menu VALUES (NULL,'setup','config_bonus','Bonus-{!POINTS!}',8,'Richten Sie Bonus-{!POINTS!} ein, die beim x'ten Klick auf die Mail verbucht werden sollen. Beispiele: Der 1. Klick sollte mehr {!POINTS!} zusätzlich bekommen, als der 10. Klick.')";
\r
127 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD login_bonus double(20,3) not null default '10.000'";
\r
128 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD turbo_bonus double(20,3) not null default '100.000'";
\r
129 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD login_timeout bigint(20) not null default '86400'";
\r
130 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD turbo_rates varchar(255) not null default '50;20;10'";
\r
131 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_ranks tinyint(4) not null default '10'";
\r
132 // Use actual month for this update
\r
133 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD last_bonus_month char(2) not null default '".date("m", time())."'";
\r
134 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data ADD login_bonus double(20,3) not null default '0.000'";
\r
135 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data ADD turbo_bonus double(20,3) not null default '0.000'";
\r
136 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_stats ADD bonus_stats enum('Y', 'N') not null default 'N'";
\r
137 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_extensions SET ext_has_css='Y' WHERE ext_name='bonus' AND ext_has_css='N' LIMIT 1";
\r
139 // Update notes (these will be set as task text!)
\r
140 $UPDATE_NOTES = "Login-Bonus und Turbo-Klick-Bonus intergriert.";
\r
143 case "0.2.2": // SQL queries for v0.2.2
\r
144 $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_bonus_turbo";
\r
145 $SQLs[] = "CREATE TABLE "._MYSQL_PREFIX."_bonus_turbo (
\r
146 id bigint(20) NOT NULL auto_increment,
\r
147 userid bigint(20) NOT NULL default '0',
\r
148 mail_id bigint(20) NOT NULL default '0',
\r
149 bonus_id bigint(20) NOT NULL default '0',
\r
150 level bigint(20) NOT NULL default '0',
\r
151 points double(20,3) NOT NULL default '0.000',
\r
152 timemark varchar(32) NOT NULL default '0',
\r
154 KEY mail_id (mail_id),
\r
155 KEY bonus_id (bonus_id),
\r
156 KEY userid (userid)
\r
159 // Update notes (these will be set as task text!)
\r
160 $UPDATE_NOTES = "Turbo-Bonus wird in Tabelle gezählt für Anzeige, wer alles bereits geklickt hat und welchen Platz er gemacht hat.";
\r
163 case "0.2.3": // SQL queries for v0.2.3
\r
164 $SQLs[] = "DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_member_menu WHERE action='main' AND what='bonus' LIMIT 1";
\r
165 $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_member_menu VALUES (NULL,'main','bonus','Aktiv-Rallye',7,'Y','Y','',0)";
\r
167 // Update notes (these will be set as task text!)
\r
168 $UPDATE_NOTES = "Aktiv-Rallye mit Klick-Vergütung hinzugefügt.";
\r
171 case "0.2.4": // SQL queries for v0.2.4
\r
172 // Update notes (these will be set as task text!)
\r
173 $UPDATE_NOTES = "Wegen des Theme-Supportes hat sich die URL zur CSS-Datei geändert.";
\r
176 case "0.2.5": // SQL queries for v0.2.5
\r
177 $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_bonus_urls";
\r
178 $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_bonus_customer";
\r
180 // Update notes (these will be set as task text!)
\r
181 $UPDATE_NOTES = "Tabellen <U>"._MYSQL_PREFIX."_bonus_urls</U> und <U>"._MYSQL_PREFIX."_bonus_customer</U> entfernt, da dies bald von der Erweiterung <U>paidlinks</U> erledigt wird.";
\r
184 case "0.2.6": // SQL queries for v0.2.6
\r
185 // Update notes (these will be set as task text!)
\r
186 $UPDATE_NOTES = "Fehler beseitigt, wenn error_reporting=E_ALL gesetzt ist.";
\r
189 case "0.2.7": // SQL queries for v0.2.7
\r
190 // Update notes (these will be set as task text!)
\r
191 $UPDATE_NOTES = "Turbo-Bonus klappt wieder (dies sind {!POINTS!} die an die schnellsten Klicker vergütet werden!)";
\r
194 case "0.2.8": // SQL queries for v0.2.8
\r
195 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_bonus SET timestamp='0' WHERE timestamp='0000000000'";
\r
196 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_bonus_turbo CHANGE points points double(22,5) not null default '0.00000'";
\r
197 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config CHANGE turbo_bonus turbo_bonus double(22,5) not null default '0.00000'";
\r
198 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config CHANGE login_bonus login_bonus double(22,5) not null default '0.00000'";
\r
199 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data CHANGE turbo_bonus turbo_bonus double(22,5) not null default '0.00000'";
\r
200 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data CHANGE login_bonus login_bonus double(22,5) not null default '0.00000'";
\r
202 // Update notes (these will be set as task text!)
\r
203 $UPDATE_NOTES = "5 Nachkommastellen implementiert";
\r
206 case "0.2.9": // SQL queries for v0.2.9
\r
207 // Update notes (these will be set as task text!)
\r
208 $UPDATE_NOTES = "Problem mit Speicherung der Einstellungen beseitigt.";
\r
211 case "0.3.0": // SQL queries for v0.3.0
\r
212 // Update notes (these will be set as task text!)
\r
213 $UPDATE_NOTES = "Menüpunkte im Gast-/Mitgliedsbereich können nicht mehr aufgerufen werden, wenn die Erweiterung deaktiviert ist.";
\r
216 case "0.3.1": // SQL queries for v0.3.1
\r
217 // Update notes (these will be set as task text!)
\r
218 $UPDATE_NOTES = "Sicherheitsupdate am Script <U>show_bonus.php</U> durchgeführt.";
\r
221 case "0.3.2": // SQL queries for v0.3.2
\r
222 // Update notes (these will be set as task text!)
\r
223 $UPDATE_NOTES = "Design "Solid-Business" eingebaut.";
\r
226 case "0.3.3": // SQL queries for v0.3.3
\r
227 // Update notes (these will be set as task text!)
\r
228 $UPDATE_NOTES = "Seit <A href=\"".SERVER_URL."/patches/340-Gast_Mitgliedsmenue_Deaktivieren.zip\">Patch 340</A> überflüssige HTML-Tags entfernt.";
\r
231 case "0.3.4": // SQL queries for v0.3.4
\r
232 $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_admin_menu (action, what, title, descr, sort) VALUES ('user', 'list_bonus', 'Aktiv-Rallye-Teilnehmer', 'Listet alle Mitglieder auf, die einen Aktiv-Bonus haben und zeigt die derzeit möglichen Gewinner an.', 10)";
\r
234 // Update notes (these will be set as task text!)
\r
235 $UPDATE_NOTES = "Link <U>Aktiv-Rallye-Teilnehmer</U> hinzugefügt, inklusive manuelle Vorbereitung der Vergütung.";
\r
238 case "0.3.5": // SQL queries for v0.3.5
\r
239 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_mode enum('UID', 'JACKPOT', 'ADD') not null default 'ADD'";
\r
240 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_uid bigint(20) not null default '0'";
\r
242 // Update notes (these will be set as task text!)
\r
243 $UPDATE_NOTES = "Der Login-Bonus Aktiv-Bonus (= Klick-Bonus) können nun zuerst von einem Mitgliederaccount (das sollte Ihres sein!), vom Jackpot abgezogen oder einfach dazuadiert werden.";
\r
246 case "0.3.6": // SQL queries for v0.3.6
\r
247 // Update notes (these will be set as task text!)
\r
248 $UPDATE_NOTES = "In der Admin-Liste werden nur aktive Mitglieder gelistet und zudem die späteste Zeitmarke für die Auswertung angezeigt.";
\r
251 case "0.3.7": // SQL queries for v0.3.7
\r
252 // Update notes (these will be set as task text!)
\r
253 $UPDATE_NOTES = "Mitglieder-Account auwählbar, von dem die {!POINTS!} für den Aktiv- und Login-Bonus abgebucht werden.";
\r
256 case "0.3.8": // SQL queries for v0.3.8
\r
257 // Update notes (these will be set as task text!)
\r
258 $UPDATE_NOTES = "Ausgabe des generierten HTML-Codes nach <U>inc/footer.php</U> verlagert.";
\r
261 case "0.3.9": // SQL queries for v0.3.9
\r
262 // Update notes (these will be set as task text!)
\r
263 $UPDATE_NOTES = "Fehlende Variablen gefixt.";
\r
266 case "0.4.0": // SQL queries for v0.4.0
\r
267 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_timeout bigint(20) not null default '".(ONE_DAY * 7)."'";
\r
268 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_lines bigint(20) not null default '10'";
\r
270 // Update notes (these will be set as task text!)
\r
271 $UPDATE_NOTES = "Automatisches Löschen von Turbo-Bonus-Zeilen ("._MYSQL_PREFIX."_bonus_turbo) und begrenzte Anzahl von Einträgen hinzugefügt.";
\r
274 case "0.4.1": // SQL queries for v0.4.1
\r
275 // Update notes (these will be set as task text!)
\r
276 $UPDATE_NOTES = "Vergütung des Aktiv-Bonus repariert.";
\r
279 case "0.4.2": // SQL queries for v0.4.2
\r
280 // Update notes (these will be set as task text!)
\r
281 $UPDATE_NOTES = "Admin-Bereich / Aktiv-Teilnehmer auflisten: Problem mit Konstante __AUTOPURGE_TIMEOUT und das Template <U>admin_list_bonus.tpl</U> korregiert.";
\r
284 case "0.4.3": // SQL queries for v0.4.3
\r
285 // Update notes (these will be set as task text!)
\r
286 $UPDATE_NOTES = "Verbesserung des Versandes von HTML-Bonus-Mails.";
\r
289 case "0.4.4": // SQL queries for v0.4.4
\r
290 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_order double(20,5) not null default '15.00000'";
\r
291 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_ref double(20,5) not null default '100.00000'";
\r
292 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_stats double(20,5) not null default '5.00000'";
\r
293 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_active enum('Y', 'N') not null default 'Y'";
\r
294 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data ADD bonus_order double(20,5) not null default '0.00000'";
\r
295 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data ADD bonus_ref double(20,5) not null default '0.00000'";
\r
296 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data ADD bonus_stats double(20,5) not null default '0.00000'";
\r
297 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_stats ADD is_stats enum('Y', 'N') not null default 'N'";
\r
299 // Update notes (these will be set as task text!)
\r
300 $UPDATE_NOTES = "Bonus-{!POINTS!} für: Mailbestellung, Referral-Werbung (bei Best. der EMail-Adresse) und wenn 100% Klickrate jeder Mailbuchung erreicht wurde.<br>Template <u>admin_config_bonus_pro.tpl</u> ist überflüssig geworden. Bitte löschen Sie dies!<br>Eingestellte Bonus-{!POINTS!} für Rank 2 war um eins verschoben.";
\r
303 case "0.4.5": // SQL queries for v0.4.5
\r
304 // Update notes (these will be set as task text!)
\r
305 $UPDATE_NOTES = "Abzug vom Bonus-Account integriert.";
\r
308 case "0.4.6": // SQL queries for v0.4.6
\r
309 // Update notes (these will be set as task text!)
\r
310 $UPDATE_NOTES = "Rank 2 bekommt nun auch seine {!POINTS!} gutgeschrieben.";
\r
313 case "0.4.7": // SQL queries for v0.4.7
\r
314 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_user_data SET login_bonus=0, turbo_bonus=0,bonus_ref=0,bonus_order=0,bonus_stats=0";
\r
316 // Update notes (these will be set as task text!)
\r
317 $UPDATE_NOTES = "Die Aktiv-Rallye wurde nicht auf 0 {!POINTS!} gesetzt. Dieser Fehler ist nun behoben. Allerdings ist mit diesem Update auch die Aktiv-Rallye zurückgesetzt worden.";
\r
320 case "0.4.8": // SQL queries for v0.4.8
\r
321 // Update notes (these will be set as task text!)
\r
322 $UPDATE_NOTES = "In <U>inc/monthly_bonus.php</U> fehlte ein Punkt; Fehler besseitigt.";
\r
325 case "0.4.9": // SQL queries for v0.4.9
\r
326 // Update notes (these will be set as task text!)
\r
327 $UPDATE_NOTES = "Login-Bonus wird mit angezeigt.";
\r
330 case "0.5.0": // SQL queries for v0.5.0
\r
331 // Update notes (these will be set as task text!)
\r
332 $UPDATE_NOTES = "Problem mit <STRONG>is_hundred</STRONG> beim täglichen Reset beseitigt.";
\r
335 case "0.5.1": // SQL queries for v0.5.1
\r
336 // Update notes (these will be set as task text!)
\r
337 $UPDATE_NOTES = "Problem mit <STRONG>bonus_stats / Zeile 31</STRONG> beim täglichen Reset beseitigt.";
\r
340 case "0.5.2": // SQL queries for v0.5.2
\r
341 // Update notes (these will be set as task text!)
\r
342 $UPDATE_NOTES = "Wörter <STRONG>Mailtausch</STRONG>, <STRONG>Mailtausches</STRONG> und <STRONG>Mailtauscher</STRONG> sind austauschbar.";
\r
345 case "0.5.3": // SQL queries for v0.5.3
\r
346 // Update notes (these will be set as task text!)
\r
347 $UPDATE_NOTES = "Speichern der Aktiv-{!POINTS!} für Platz 2 bis <STRONG>x</STRONG> korregiert.";
\r
350 case "0.5.4": // SQL queries for v0.5.4
\r
351 // Update notes (these will be set as task text!)
\r
352 $UPDATE_NOTES = "Variablenfehler in <STRONG>inc/monthly_bonus.php</STRONG> behoben.";
\r
355 case "0.5.5": // SQL queries for v0.5.5
\r
356 // Get previous month
\r
357 $prev = date("m", time()) - 1;
\r
358 if (strlen($prev) == 1) $prev = "0".$prev;
\r
359 if ($prev == "00") $prev = "12";
\r
361 // Reset monthly active rallye
\r
362 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_config SET last_bonus_month='".$prev."' WHERE config='0' LIMIT 1";
\r
364 // Update notes (these will be set as task text!)
\r
365 $UPDATE_NOTES = "Weitere Variablenfehler in <STRONG>inc/monthly_bonus.php</STRONG> haben dafür gesorgt, dass die monatliche Aktiv-Rallye nicht ausgeschüttet wurde. Mit diesem Update wurde die Ausschüttung initialisiert. Ihre Mitglieder bekommen voraussichtlicht nichts doppelt vergütet.";
\r
368 case "0.5.6": // SQL queries for v0.5.6
\r
369 // Get current month
\r
370 $curr = date("m", time());
\r
371 if (strlen($curr) == 1) $curr = "0".$curr;
\r
372 if ($curr == "00") $curr = "12";
\r
374 // Generate timemark...
\r
375 $mark = mktime(0, 0, 0, $curr, 1, date("Y", time()));
\r
377 // Update accounts which are not active last months
\r
378 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_user_data
\r
379 SET turbo_bonus=0, login_bonus=0, bonus_order=0, bonus_stats=0, bonus_ref=0
\r
380 WHERE last_online < ".$mark." ORDER BY userid";
\r
382 // Update notes (these will be set as task text!)
\r
383 $UPDATE_NOTES = "Ein weiterer Scriptfehler hat nur die Gewinner aus der Aktiv-Rallye genommen. Die anderen Mitglieder sind somit "nach oben gerutsch".";
\r
386 case "0.5.7": // SQL queries for v0.5.7
\r
389 case "0.5.8": // SQL queries for v0.5.8
\r
390 // Update notes (these will be set as task text!)
\r
391 $UPDATE_NOTES = "Problem mit <STRONG>is_hundred</STRONG> beim täglichen Reset endlich beseitigt.";
\r
394 case "0.5.9": // SQL queries for v0.5.9
\r
395 $UPDATE_NOTES = "Fehlermeldung <STRONG>/home/verzeichnis/html/inc/stats_bonus.php (42):You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '' WHERE userid='59' LIMIT 1' at line 1</STRONG> beseitigt.";
\r
398 case "0.6.0": // SQL queries for v0.6.0
\r
399 $UPDATE_NOTES = "SQL-Fehlermeldung in <STRONG>inc/monthly_bonus.php</STRONG> beseitigt.";
\r
402 case "0.6.1": // SQL queries for v0.6.1
\r
403 $UPDATE_NOTES = "Versand von Bonus-Mails repariert.";
\r
406 case "0.6.2": // SQL queries for v0.6.2
\r
407 $UPDATE_NOTES = "Löschen von bereits gelöschten Mails wird nun abgelehnt.";
\r
410 case "0.6.3": // SQL queries for v0.6.3
\r
411 $UPDATE_NOTES = "Abspeichern von Einstellungen repariert.";
\r
414 case "0.6.4": // SQL queries for v0.6.4
\r
415 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_admin_menu SET title='Aktiv-Rallye' WHERE what='config_bonus' LIMIT 1";
\r
417 // Update notes (these will be set as task text!)
\r
418 $UPDATE_NOTES = "Der Menüpunkt "Bonus-{!POINTS!}" unter Einstellungen wird nach "Aktiv-Rallye umbenannt. Und die Aktiv-Rallye konnte aufgrund eines Template-Fehlers nicht gespeichert werden.";
\r
421 case "0.6.5": // SQL queries for v0.6.5
\r
422 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_stats ADD bonus_stats enum('Y', 'N') not null default 'N'";
\r
424 // Update notes (these will be set as task text!)
\r
425 $UPDATE_NOTES = "Fehler mit bonus_stats beseitigt.";
\r
428 case "0.6.6": // SQL queries for v0.6.6
\r
429 $UPDATE_NOTES = "Template-Fehler beseitigt im Admin-Bereich.";
\r
432 case "0.6.7": // SQL queries for v0.6.7
\r
433 $UPDATE_NOTES = "Vorbereitung auf die neue Mediendaten v0.0.4.";
\r
436 case "0.6.8": // SQL queries for v0.6.8
\r
437 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_bonus SET data_type='SEND' WHERE data_type != 'SEND' AND data_type != 'DELETED' AND receivers='' AND target_send='0'";
\r
439 // Update notes (these will be set as task text!)
\r
440 $UPDATE_NOTES = "Eingegebene Anzahl auszusendener Bonus-Mails wurde bei der Empfänderauswahl nicht berücksichtigt. Zudem wird jetzt das eingestellte Auswahlverfahren mitberücksichtigt.";
\r
443 case "0.6.9": // SQL queries for v0.6.9
\r
444 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_order_yn enum('Y', 'N') not null default 'N'";
\r
445 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_ref_yn enum('Y', 'N') not null default 'N'";
\r
446 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_stats_yn enum('Y', 'N') not null default 'N'";
\r
447 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_login_yn enum('Y', 'N') not null default 'N'";
\r
448 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_click_yn enum('Y', 'N') not null default 'Y'";
\r
450 // Update notes (these will be set as task text!)
\r
451 $UPDATE_NOTES = "Es können nun auch die folgenden Vergütungen bei der Auswertung der monatlichen Aktiv-Rallye mit berücksichtigt werden: Mailbestätigung (war vorher schon), Login-, Mailbuchung, Referral und Statistik-Bonus (100% Klickrate erreicht).";
\r
454 case "0.7.0": // SQL queries for v0.7.0
\r
455 $UPDATE_NOTES = "Zuschaltung von weiteren Bonis wird jetzt auch bei der Auflistung der mitmachenden Mitglieder im Mitgliedsbereich beachtet.";
\r
458 case "0.7.1": // SQL queries for v0.7.1
\r
459 $UPDATE_NOTES = "Im Adminbereich wird nun ebenfalls die Zuschaltung von weiteren Bonis berücksichtigt. Zudem wird der Gesamtbonus an alle Mitglieder errechnet und auch angezeigt.";
\r
462 case "0.7.2": // SQL queries for v0.7.2
\r
463 $UPDATE_NOTES = "Die Vergütung der erreichten 100%-Klickrate war noch wegen Programmierungen am Script auskommentiert. Sorry!";
\r
466 case "0.7.3": // SQL queries for v0.7.3
\r
467 $UPDATE_NOTES = "Gutgeschriebene Bonus-{!POINTS!} werden nach Deaktivierung der Aktiv-Rallye gelöscht.";
\r
470 case "0.7.4": // SQL queries for v0.7.4
\r
471 $UPDATE_NOTES = "Rechtlichen Hinweis im Mitgliedsbereich vergessen. (<STRONG>member_bonus.tpl</STRONG>)";
\r
474 case "0.7.5": // SQL queries for v0.7.5
\r
475 $UPDATE_NOTES = "Im Admin-Bereich Hinweis hinzugefügt, wenn Aktiv-Rallye inaktiv ist. Bitte Script inc/monthly_bonus.php löschen!";
\r
478 case "0.7.6": // SQL queries for v0.7.6
\r
479 $UPDATE_NOTES = "Auswahlmechanismus der Gewinner repariert. Trotz Hinzuschalten von weiteren zu berücksichtigen Boni wurden diese bei der Sortierung der User-IDs nicht berücksichtig.";
\r
482 case "0.7.7": // SQL queries for v0.7.7
\r
483 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_en_notify enum('Y', 'N') not null default 'N'";
\r
484 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_di_notify enum('Y', 'N') not null default 'N'";
\r
485 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_new_mem_notify enum('Y', 'N') not null default 'N'";
\r
486 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_notify_points double(20,5) not null default '0.00000'";
\r
487 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_notify_wait bigint(20) not null default '30'";
\r
488 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data ADD bonus_ral_notify bigint(20) not null default '0'";
\r
489 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data ADD bonus_ral_en_notify bigint(20) not null default '0'";
\r
490 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_data ADD bonus_ral_di_notify bigint(20) not null default '0'";
\r
492 // Update notes (these will be set as task text!)
\r
493 $UPDATE_NOTES = "Optionale automatische Benachrichtigung über aktivierte und/oder deaktivierte Aktiv-Rallye einstellbar.";
\r
496 case "0.7.8": // SQL queries for v0.7.8
\r
497 // Update notes (these will be set as task text!)
\r
498 $UPDATE_NOTES = "Fehler im täglichen Reset beseitigt.";
\r
501 case "0.7.9": // SQL queries for v0.7.9
\r
502 $UPDATE_NOTES = "Dollarzeichen fehlte in <STRONG>inc/reset/reset_bonus.php</STRONG>, Zeile 39";
\r
505 case "0.8.0": // SQL queries for v0.8.0
\r
506 $UPDATE_NOTES = "De-/Aktivieren des mit dieser Erweiterung verknüpften Modules eingebunden.";
\r
509 case "0.8.1": // SQL queries for v0.8.1
\r
510 $UPDATE_NOTES = "Bei ".POINTS."-Gleichstand wird als nächstes nach wer als letztes Online war umsortiert.";
\r
513 case "0.8.2": // SQL queries for v0.8.2
\r
514 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_config ADD bonus_include_own enum('Y', 'N') not null default 'N'";
\r
515 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_bonus ADD is_notify enum('Y', 'N') not null default 'N'";
\r
517 // Update notes (these will be set as task text!)
\r
518 $UPDATE_NOTES = "Eigene User-ID von Aktiv-Rallye ausschliessbar. Benachrichtigungsmails sind von Aktiv-Rallye ausgeschlossen.";
\r
521 case "0.8.3": // SQL queries for v0.8.3
\r
522 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_member_menu SET action='rals', sort='2', title='Aktiv-Rallye' WHERE what='bonus' LIMIT 1";
\r
524 // Update notes (these will be set as task text!)
\r
525 $UPDATE_NOTES = "Mitgliedsmenü komplett umgebaut.";
\r
528 case "0.8.4": // SQL queries for v0.8.4
\r
529 $UPDATE_NOTES = "Ladeproblem bei nicht installierter Erweiterung <strong>cache</strong> gefixt.";
\r
532 case "0.8.5": // SQL queries for v0.8.5
\r
533 $UPDATE_NOTES = "CSS-Klassenname gefixt in Templates.";
\r
536 case "0.8.6": // SQL queries for v0.8.6
\r
537 $UPDATE_NOTES = "Fehlerhinweis bei deaktivierter Erweiterung verbessert.";
\r
542 default: // Do stuff when extension is loaded
\r
543 $DUMMY = LOAD_CONFIG("0");
\r
544 $CONFIG['login_bonus'] = $DUMMY['login_bonus']; // Bonus points for successfull logins
\r
545 $CONFIG['turbo_bonus'] = $DUMMY['turbo_bonus']; // Bonus points for the fastest clicker, No. 1
\r
546 $CONFIG['bonus_rates'] = $DUMMY['turbo_rates']; // Points for clicker no. 2 to x
\r
547 $CONFIG['bonus_ranks'] = $DUMMY['bonus_ranks']; // Total ranks who can win
\r
548 $CONFIG['login_timeout'] = $DUMMY['login_timeout']; // Time in seconds between two logins
\r
549 $CONFIG['bonus_month'] = $DUMMY['last_bonus_month']; // Last month where click-bonus are "paid"
\r
550 $CONFIG['bonus_mode'] = $DUMMY['bonus_mode']; // Mode for adding points for login/click bonus
\r
551 $CONFIG['bonus_uid'] = $DUMMY['bonus_uid']; // Member account to take points from
\r
552 $CONFIG['bonus_lines'] = $DUMMY['bonus_lines']; // Number of lines to display in show_bonus.php
\r
553 $CONFIG['bonus_timeout'] = $DUMMY['bonus_timeout']; // Auto-Purge timeout for bonus lines in mxchange_bonus_turbo
\r
554 $CONFIG['bonus_order'] = $DUMMY['bonus_order']; // Bonus points for ordering mails
\r
555 $CONFIG['bonus_ref'] = $DUMMY['bonus_ref']; // Bonus points for "making" a referral
\r
556 $CONFIG['bonus_stats'] = $DUMMY['bonus_stats']; // Bonus points for 100% clickrate in mail stats
\r
557 $CONFIG['bonus_active'] = $DUMMY['bonus_active']; // De/activate bonus active rallye
\r
558 $CONFIG['bonus_order_yn'] = $DUMMY['bonus_order_yn']; // Include order bonus in analysis?
\r
559 $CONFIG['bonus_ref_yn'] = $DUMMY['bonus_ref_yn']; // Include referral bonus in analysis?
\r
560 $CONFIG['bonus_stats_yn'] = $DUMMY['bonus_stats_yn']; // Include statistics bonus in analysis?
\r
561 $CONFIG['bonus_login_yn'] = $DUMMY['bonus_login_yn']; // Include login bonus in analysis?
\r
562 $CONFIG['bonus_click_yn'] = $DUMMY['bonus_click_yn']; // Include "mailid" bonus in analysis?
\r
563 $CONFIG['bonus_en_notify'] = $DUMMY['bonus_en_notify']; // Notify members about enabled active rallye?
\r
564 $CONFIG['bonus_di_notify'] = $DUMMY['bonus_di_notify']; // Notify members about disabled active rallye?
\r
565 $CONFIG['bonus_new_mem_notify'] = $DUMMY['bonus_new_mem_notify']; // Notify members about disabled active rallye?
\r
566 $CONFIG['bonus_notify_points'] = $DUMMY['bonus_notify_points']; // Bonus points for the enable-notification mail? 0 = disable!
\r
567 $CONFIG['bonus_notify_wait'] = $DUMMY['bonus_notify_wait']; // Time to wait in seconds for bonus mails
\r
568 $CONFIG['bonus_include_own'] = $DUMMY['bonus_include_own']; // Include webmaster's own userid in active rallye?
\r
571 if (defined('__DAILY_RESET') && (!DEBUG_MODE) && ($CSS != 1))
\r
573 // Daily reset was run so let's check if active rallye is activated
\r
574 if ($CONFIG['bonus_active'] == "Y")
\r
576 // Run active rallye
\r
577 if($CONFIG['bonus_stats'] > 0) $INC_POOL[] = PATH."inc/stats_bonus.php";
\r
578 $INC_POOL[] = PATH."inc/monthly/monthly_bonus.php";
\r
583 $INC_POOL[] = PATH."inc/reset/reset_bonus.php";
\r
587 // Check for bonus rallye is active and send mails out
\r
588 if (($CONFIG['bonus_active'] == "Y") && ($CONFIG['bonus_new_mem_notify'] == "Y"))
\r
590 // Include file for sending out mails
\r
591 $INC_POOL[] = PATH."inc/mails/bonus_mails.php";
\r
596 // Language file prefix
\r
597 $EXT_LANG_PREFIX = "bonus";
\r
599 // Extension is always active?
\r
600 $EXT_ALWAYS_ACTIVE = "N";
\r