Code rewritings, load base config improved and many minor fixes...
[mailer.git] / 0.2.1 / inc / extensions / ext-payout.php
1 <?php\r
2 /************************************************************************\r
3  * MXChange v0.2.1                                    Start: 04/11/2004 *\r
4  * ================                             Last change: 11/15/2004 *\r
5  *                                                                      *\r
6  * -------------------------------------------------------------------- *\r
7  * File              : ext-payout.php                                   *\r
8  * -------------------------------------------------------------------- *\r
9  * Short description : Payout extension                                 *\r
10  * -------------------------------------------------------------------- *\r
11  * Kurzbeschreibung  : Auszahlung-Erweiterung                           *\r
12  * -------------------------------------------------------------------- *\r
13  *                                                                      *\r
14  * -------------------------------------------------------------------- *\r
15  * Copyright (c) 2003 - 2008 by Roland Haeder                           *\r
16  * For more information visit: http://www.mxchange.org                  *\r
17  *                                                                      *\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
22  *                                                                      *\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
27  *                                                                      *\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
33 \r
34 // Some security stuff...\r
35 if (ereg(basename(__FILE__), $_SERVER['PHP_SELF']))\r
36 {\r
37         $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";\r
38         require($INC);\r
39 }\r
40 \r
41 // Version of this extension\r
42 $EXT_VERSION = "0.3.8";\r
43 \r
44 // Auto-set extension version\r
45 if (empty($EXT_VER)) $EXT_VER = $EXT_VERSION;\r
46 \r
47 // Version history array (add more with , "0.1" and so on)\r
48 $EXT_VER_HISTORY = array("0.0", "0.1", "0.1.1", "0.1.2", "0.1.3", "0.1.4", "0.1.5", "0.1.6", "0.1.7", "0.1.8", "0.1.9", "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");\r
49 \r
50 switch ($EXT_LOAD_MODE)\r
51 {\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[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_user_payouts";\r
55         $SQLs[] = "CREATE TABLE "._MYSQL_PREFIX."_user_payouts (\r
56 id bigint(20) NOT NULL auto_increment,\r
57 userid bigint(20) NOT NULL default '0',\r
58 payout_total double(22,3) NOT NULL default '0.000',\r
59 target_account varchar(255) NOT NULL default '',\r
60 target_bank varchar(255) NOT NULL default '',\r
61 payout_id bigint(20) NOT NULL default '0',\r
62 payout_timestamp varchar(10) NOT NULL default '0',\r
63 status enum('NEW', 'ACCEPTED', 'REJECTED') NOT NULL default 'NEW',\r
64 KEY(userid),\r
65 KEY(payout_id),\r
66 PRIMARY KEY(id)\r
67 ) TYPE=MyISAM";\r
68         $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_payout_types";\r
69         $SQLs[] = "CREATE TABLE "._MYSQL_PREFIX."_payout_types (\r
70 id bigint(20) NOT NULL auto_increment,\r
71 type varchar(255) NOT NULL default '',\r
72 rate double(22,3) NOT NULL default '0.000',\r
73 min_points bigint(20) NOT NULL default '0',\r
74 PRIMARY KEY(id)\r
75 ) TYPE=MyISAM";\r
76         $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_admin_menu (action, what, title, descr, sort) VALUES('setup', 'config_payouts', 'Auszahlungen', 'Auszahlungsarten einstellen, neu anlegen oder l&ouml;schen.', '15')";\r
77         $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_admin_menu (action, what, title, descr, sort) VALUES('payouts', 'list_payouts', 'Anfragen auflisten', 'Listet alle Auszahlungsanfragen Ihrer Mitglieder auf.', '16')";\r
78         $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_member_menu (action, what, title, visible, locked, sort) VALUES('main', 'payout', 'Auszahlungen', 'N', 'N', '11')";\r
79         break;\r
80 \r
81 case "remove": // Do stuff when removing extension\r
82         // SQL commands to run\r
83         $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_user_payouts";\r
84         $SQLs[] = "DROP TABLE IF EXISTS "._MYSQL_PREFIX."_payout_types";\r
85         $SQLs[] = "DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_admin_menu WHERE action='payouts'";\r
86         $SQLs[] = "DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_member_menu WHERE action='main' AND what='payout' LIMIT 1";\r
87         break;\r
88 \r
89 case "activate": // Do stuff when admin activates this extension\r
90         // SQL commands to run\r
91         $SQLs[] = "UPDATE "._MYSQL_PREFIX."_member_menu SET visible='Y', locked='N' WHERE action='main' AND what='payout' LIMIT 1";\r
92         break;\r
93 \r
94 case "deactivate": // Do stuff when admin deactivates this extension\r
95         // SQL commands to run\r
96         $SQLs[] = "UPDATE "._MYSQL_PREFIX."_member_menu SET visible='Y', locked='Y' WHERE action='main' AND what='payout' LIMIT 1";\r
97         break;\r
98 \r
99 case "update": // Update an extension\r
100         switch ($EXT_VER)\r
101         {\r
102         case "0.1.2": // SQL queries for v0.1.2\r
103                 $SQLs[] = "INSERT INTO "._MYSQL_PREFIX."_admin_menu (action, what, title, descr, sort) VALUES('payouts', '', 'Auszahlungsmanagement', 'Management der Auszahlungsarten.', '8')";\r
104                 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_admin_menu SET action='payouts', title='Einstellungen' WHERE action='setup' AND what='config_payouts' LIMIT 1";\r
105                 break;\r
106 \r
107         case "0.1.3": // SQL queries for v0.1.3\r
108                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types ADD from_account varchar(255) NOT NULL default ''";\r
109                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types ADD from_pass varchar(255) NOT NULL default ''";\r
110                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types ADD engine_url varchar(255) NOT NULL default ''";\r
111                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types ADD engine_ret_ok varchar(255) NOT NULL default ''";\r
112                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types ADD engine_ret_failed varchar(255) NOT NULL default ''";\r
113                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types ADD pass_enc enum('md5', 'base64', 'none') NOT NULL default 'md5'";\r
114                 break;\r
115 \r
116         case "0.1.4": // SQL queries for v0.1.4\r
117                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_payouts ADD password varchar(255) NOT NULL default ''";\r
118                 break;\r
119 \r
120         case "0.1.5": // SQL queries for v0.1.5\r
121                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_payouts ADD target_url longblob NOT NULL";\r
122                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_payouts ADD banner_url longblob NOT NULL";\r
123                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_payouts ADD link_text varchar(30) NOT NULL default ''";\r
124                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types ADD allow_url enum('Y', 'N') NOT NULL default 'N'";\r
125                 break;\r
126 \r
127         case "0.1.6": // SQL queries for v0.1.6\r
128                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types CHANGE pass_enc pass_enc enum('md5', 'base64', 'xxx') NOT NULL default 'xxx'";\r
129                 break;\r
130 \r
131         case "0.1.8": // SQL queries for v0.1.8\r
132                 // Update notes (these will be set as task text!)\r
133                 $UPDATE_NOTES = "Auflistung der Auszahlungen ausgelagert in Template <I>member_payout.tpl</I>.";\r
134                 break;\r
135 \r
136         case "0.1.9": // SQL queries for v0.1.9\r
137                 // Update notes (these will be set as task text!)\r
138                 $UPDATE_NOTES = "Fehler beseitigt, wenn error_reporting=E_ALL gesetzt ist.";\r
139                 break;\r
140 \r
141         case "0.2.0": // SQL queries for v0.2.0\r
142                 // Update notes (these will be set as task text!)\r
143                 $UPDATE_NOTES = "5 Nachkommastellen implementiert.";\r
144                 break;\r
145 \r
146         case "0.2.1": // SQL queries for v0.2.1\r
147                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_user_payouts CHANGE payout_total payout_total double(22,5) not null default '0.00000'";\r
148                 $SQLs[] = "ALTER TABLE "._MYSQL_PREFIX."_payout_types CHANGE rate rate double(22,5) not null default '0.00000'";\r
149 \r
150                 // Update notes (these will be set as task text!)\r
151                 $UPDATE_NOTES = "Problem mit Speicherung der Einstellungen beseitigt.";\r
152 \r
153         case "0.2.2": // SQL queries for v0.2.2\r
154                 // Update notes (these will be set as task text!)\r
155                 $UPDATE_NOTES = "Buttons aus Aufgabenauflisten ausgelagert";\r
156                 break;\r
157 \r
158         case "0.2.3": // SQL queries for v0.2.3\r
159                 // Update notes (these will be set as task text!)\r
160                 $UPDATE_NOTES = "Men&uuml;punkte im Gast-/Mitgliedsbereich k&ouml;nnen nicht mehr aufgerufen werden, wenn die Erweiterung deaktiviert ist.";\r
161                 break;\r
162 \r
163         case "0.2.4": // SQL queries for v0.2.4\r
164                 // Update notes (these will be set as task text!)\r
165                 $UPDATE_NOTES = "Ausgabe der Auszahlungsm&ouml;glichkeiten im Mitgliedsbereich repariert.";\r
166                 break;\r
167 \r
168         case "0.2.5": // SQL queries for v0.2.5\r
169                 // Update notes (these will be set as task text!)\r
170                 $UPDATE_NOTES = "Seit <A href=\"".SERVER_URL."/patches/340-Gast_Mitgliedsmenue_Deaktivieren.zip\">Patch 340</A> &uuml;berfl&uuml;ssige HTML-Tags entfernt.";\r
171                 break;\r
172 \r
173         case "0.2.6": // SQL queries for v0.2.6\r
174                 // Update notes (these will be set as task text!)\r
175                 $UPDATE_NOTES = "IP-Nummer und Browserbezeichnung wird in Admin-Mails eingesetzt.";\r
176                 break;\r
177 \r
178         case "0.2.7": // SQL queries for v0.2.7\r
179                 // Update notes (these will be set as task text!)\r
180                 $UPDATE_NOTES = "Link zum Mitgliedsprofil in Funktion <U>ADMIN_USER_PROFILE_LINK()</U> ausgelagert.";\r
181                 break;\r
182 \r
183         case "0.2.8": // SQL queries for v0.2.8\r
184                 // Update notes (these will be set as task text!)\r
185                 $UPDATE_NOTES = "Work-Arount-L&ouml;sung zu tempor&auml;ren Problemen mit der Task-ID eingebaut.";\r
186                 break;\r
187 \r
188         case "0.2.9": // SQL queries for v0.2.9\r
189                 // Update notes (these will be set as task text!)\r
190                 $UPDATE_NOTES = "Nachricht an Admin bei Auszahlungsanfrage wird endlich versendet.";\r
191                 break;\r
192 \r
193         case "0.3.0": // SQL queries for v0.3.0\r
194                 // Update notes (these will be set as task text!)\r
195                 $UPDATE_NOTES = "HTML-Code ausgelagert in Templates und SQL-Anweisungen abgesichert.";\r
196                 break;\r
197 \r
198         case "0.3.1": // SQL queries for v0.3.1\r
199                 // Update notes (these will be set as task text!)\r
200                 $UPDATE_NOTES = "Fehler in Auszahlungsfunktion beseitigt, wenn Umrechnungsrate ungleich 1 eingestellt ist.";\r
201                 break;\r
202 \r
203         case "0.3.2": // SQL queries for v0.3.2\r
204                 // Update notes (these will be set as task text!)\r
205                 $UPDATE_NOTES = "Abspeichern von Einstellungen repariert.";\r
206                 break;\r
207 \r
208         case "0.3.3": // SQL queries for v0.3.3\r
209                 // Update notes (these will be set as task text!)\r
210                 $UPDATE_NOTES = "Vorbereitung auf die neue Mediendaten v0.0.4.";\r
211                 break;\r
212 \r
213         case "0.3.4": // SQL queries for v0.3.4\r
214                 // Update notes (these will be set as task text!)\r
215                 $UPDATE_NOTES = "Anzahl zu &uuml;berweisende {!POINTS!} m&uuml;ssen immer gr&ouml;sser 0 sein, ansonsten bricht das Script mit einer Fehlermeldung an das Mitglied ab.";\r
216                 break;\r
217 \r
218         case "0.3.5": // SQL queries for v0.3.5\r
219                 // Update notes (these will be set as task text!)\r
220                 $UPDATE_NOTES = "Sicherheitsupdate f&uuml;r die Include-Befehle.";\r
221                 break;\r
222 \r
223         case "0.3.6": // SQL queries for v0.3.6\r
224                 // Update notes (these will be set as task text!)\r
225                 $UPDATE_NOTES = "Hash-Erstellung von <STRONG>md5()</STRONG> auf bessere Funktion <STRONG>generateHash()</STRONG> umgestellt.";\r
226                 break;\r
227 \r
228         case "0.3.7": // SQL queries for v0.3.7\r
229                 $SQLs[] = "UPDATE "._MYSQL_PREFIX."_admin_menu SET title = 'Auszahlungsmanagement' WHERE action = 'payouts' AND what='' LIMIT 1";\r
230 \r
231                 // Update notes (these will be set as task text!)\r
232                 $UPDATE_NOTES = "Verwaltung nach Management umgestellt.";\r
233                 break;\r
234 \r
235         case "0.3.8": // SQL queries for v0.3.8\r
236                 // Update notes (these will be set as task text!)\r
237                 $UPDATE_NOTES = "Fehlerhinweis bei deaktivierter Erweiterung verbessert.";\r
238                 break;\r
239         }\r
240         break;\r
241 \r
242 default: // Do stuff when extension is loaded\r
243         break;\r
244 }\r
245 // Language file prefix\r
246 $EXT_LANG_PREFIX = "payout";\r
247 \r
248 // Extension is always active?\r
249 $EXT_ALWAYS_ACTIVE = "N";\r
250 \r
251 //\r
252 ?>\r