4fad3694a8bd508eebc9c77ca16779104be0ffc1
[mailer.git] / inc / extensions / ext-yoomedia.php
1 <?php
2 /************************************************************************
3  * MXChange v0.2.1                                    Start: 08/27/2008 *
4  * ================                             Last change: 08/27/2008 *
5  *                                                                      *
6  * -------------------------------------------------------------------- *
7  * File              : ext-yoomedia.php                                 *
8  * -------------------------------------------------------------------- *
9  * Short description : Extension for contacting the API of Yoo!Media    *
10  * -------------------------------------------------------------------- *
11  * Kurzbeschreibung  : Erweitertung zur Anbindung an die API von        *
12  *                     Yoo!Media                                        *
13  * -------------------------------------------------------------------- *
14  *                                                                      *
15  * -------------------------------------------------------------------- *
16  * Copyright (c) 2003 - 2008 by Roland Haeder                           *
17  * For more information visit: http://www.mxchange.org                  *
18  *                                                                      *
19  * This program is free software; you can redistribute it and/or modify *
20  * it under the terms of the GNU General Public License as published by *
21  * the Free Software Foundation; either version 2 of the License, or    *
22  * (at your option) any later version.                                  *
23  *                                                                      *
24  * This program is distributed in the hope that it will be useful,      *
25  * but WITHOUT ANY WARRANTY; without even the implied warranty of       *
26  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the        *
27  * GNU General Public License for more details.                         *
28  *                                                                      *
29  * You should have received a copy of the GNU General Public License    *
30  * along with this program; if not, write to the Free Software          *
31  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,               *
32  * MA  02110-1301  USA                                                  *
33  ************************************************************************/
34
35 // Some security stuff...
36 if (!defined('__SECURITY')) {
37         $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";
38         require($INC);
39 }
40
41 // Version number
42 $EXT_VERSION = "0.0";
43
44 // Auto-set extension version
45 if (empty($EXT_VER)) $EXT_VER = $EXT_VERSION;
46
47 // Version history array (add more with , "0.1" and so on)
48 $EXT_VER_HISTORY = array("0.0");
49
50 // This extension is deprecated!
51 $EXT_DEPRECATED = "Y";
52
53 switch ($EXT_LOAD_MODE)
54 {
55 case "register": // Do stuff when installation is running (modules.php?module=admin&action=login is called)
56         // SQL commands to run
57         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_id` BIGINT(20) UNSIGNED NOT NULL DEFAULT 0";
58         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_sid` BIGINT(20) UNSIGNED NOT NULL DEFAULT 0";
59         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_passwd` VARCHAR(255) NOT NULL DEFAULT ''";
60         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_erotic_allowed` TINYINT(2) UNSIGNED NOT NULL DEFAULT 0";
61         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_tm_max_reload` SMALLINT(6) UNSIGNED NOT NULL DEFAULT ".(24 * 8)."";
62         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_tm_min_wait` SMALLINT(6) UNSIGNED NOT NULL DEFAULT 60";
63         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_tm_clicks_remain` INT(7) UNSIGNED NOT NULL DEFAULT 1000";
64         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_tm_min_pay` FLOAT(20,5) UNSIGNED NOT NULL DEFAULT 0.00000";
65         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_requests_total` SMALLINT(6) UNSIGNED NOT NULL DEFAULT 200";
66         $SQLs[] = "ALTER TABLE `"._MYSQL_PREFIX."_config` ADD `yoomedia_requests_remain` SMALLINT(6) UNSIGNED NOT NULL DEFAULT 200";
67
68         // Admin menu
69         $SQLs[] = "INSERT INTO `"._MYSQL_PREFIX."_admin_menu` (`action`,`what`,`title`,`descr`,`sort`) VALUES ('setup','config_yoomedia','Yoo!Media Interface 2.0','Einstellungen zum Yoo!Media Interface 2.0, wie User-ID, Interface-Passwort und vieles mehr.',17)";
70         $SQLs[] = "INSERT INTO `"._MYSQL_PREFIX."_admin_menu` (`action`,`what`,`title`,`descr`,`sort`) VALUES ('email','list_yoomedia_tm','Yoo!Media Textmails','Listet Textmail-Buchungen &uuml;ber das Interface 2.0 von Yoo!Media nach Ihren eingestellten Kriterien auf. <strong>Vorsicht:</strong> Jede Aktualisierung dieser Liste kostet Ihnen eine Abfrage!',10)";
71
72         // Reload lock table
73         $SQLs[] = "DROP TABLE IF EXISTS `"._MYSQL_PREFIX."_yoomedia_reload`";
74         $SQLs[] = "CREATE TABLE `"._MYSQL_PREFIX."_yoomedia_reload` (
75 `id` BIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT,
76 `type` VARCHAR(255) NOT NULL DEFAULT 'general',
77 `y_id` BIGINT(20) UNSIGNED NOT NULL DEFAULT 0,
78 `y_reload` SMALLINT(6) UNSIGNED NOT NULL DEFAULT 0,
79 `inserted` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
80 PRIMARY KEY (`id`),
81 UNIQUE `y_type` (`type`,`y_id`)
82 ) TYPE=MyISAM COMMENT='Reload lock reminder for Yoo!Media campaigns'";
83         break;
84
85 case "remove": // Do stuff when removing extension
86         // SQL commands to run
87         $SQLs[] = "DELETE LOW_PRIORITY FROM `"._MYSQL_PREFIX."_admin_menu` WHERE `what` IN('config_yoomedia','list_yoomedia_tm') LIMIT 2";
88         $SQLs[] = "DROP TABLE IF EXISTS `"._MYSQL_PREFIX."_yoomedia_reload`";
89         break;
90
91 case "activate": // Do stuff when admin activates this extension
92         // SQL commands to run
93         break;
94
95 case "deactivate": // Do stuff when admin deactivates this extension
96         // SQL commands to run
97         break;
98
99 case "update": // Update an extension
100         switch ($EXT_VER)
101         {
102         case "0.0.1": // SQL queries for v0.0.1
103                 $SQLs[] = "";
104
105                 // Update notes (these will be set as task text!)
106                 $UPDATE_NOTES = "";
107                 break;
108         }
109         break;
110
111 default: // Do stuff when extension is loaded
112         // The translation table
113         $yoomediaTranslationTable = array(
114                 // Error messages
115                 'error_codes' => array(
116                         1  => 'wrong_pass',
117                         2  => 'wrong_sid',
118                         3  => 'website_locked',
119                         4  => 'api_data_error',
120                         5  => 'requests_depleted',
121                         6  => 'zero_result',
122                         10 => 'incomplete_request'
123                 ),
124                 // For text mails
125                 'textmail' => array(
126                         0 => 'id',
127                         1 => 'name',
128                         2 => 'reload',
129                         3 => 'wait',
130                         4 => 'remain',
131                         5 => 'pay',
132                         6 => 'text'
133                 )
134         );
135         break;
136 }
137
138 // Keep this extension always active!
139 $EXT_ALWAYS_ACTIVE = "Y";
140
141 //
142 ?>