|
1
|
|
|
<?php |
|
2
|
|
|
/* |
|
3
|
|
|
* You may not change or alter any portion of this comment or credits |
|
4
|
|
|
* of supporting developers from this source code or any supporting source code |
|
5
|
|
|
* which is considered copyrighted (c) material of the original comment or credit authors. |
|
6
|
|
|
* |
|
7
|
|
|
* This program is distributed in the hope that it will be useful, |
|
8
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
9
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
|
10
|
|
|
*/ |
|
11
|
|
|
|
|
12
|
|
|
/** |
|
13
|
|
|
* @copyright {@link https://xoops.org/ XOOPS Project} |
|
14
|
|
|
* @license {@link https://www.gnu.org/licenses/gpl-2.0.html GNU GPL 2 or later} |
|
15
|
|
|
* @package |
|
16
|
|
|
* @since |
|
17
|
|
|
* @author XOOPS Development Team |
|
18
|
|
|
*/ |
|
19
|
|
|
require_once __DIR__ . '/admin_header.php'; |
|
20
|
|
|
xoops_cp_header(); |
|
21
|
|
|
|
|
22
|
|
|
function TableExists($tablename) |
|
23
|
|
|
{ |
|
24
|
|
|
global $xoopsDB; |
|
25
|
|
|
$result = $xoopsDB->queryF("SHOW TABLES LIKE '$tablename'"); |
|
26
|
|
|
|
|
27
|
|
|
return ($xoopsDB->getRowsNum($result) > 0); |
|
28
|
|
|
} |
|
29
|
|
|
|
|
30
|
|
|
function FieldExists($fieldname, $table) |
|
31
|
|
|
{ |
|
32
|
|
|
global $xoopsDB; |
|
33
|
|
|
$result = $xoopsDB->queryF("SHOW COLUMNS FROM $table LIKE '$fieldname'"); |
|
34
|
|
|
|
|
35
|
|
|
return ($xoopsDB->getRowsNum($result) > 0); |
|
36
|
|
|
} |
|
37
|
|
|
|
|
38
|
|
|
function AddField($field, $table) |
|
39
|
|
|
{ |
|
40
|
|
|
global $xoopsDB; |
|
41
|
|
|
$result = $xoopsDB->queryF('ALTER TABLE ' . $table . " ADD $field;"); |
|
42
|
|
|
|
|
43
|
|
|
return $result; |
|
44
|
|
|
} |
|
45
|
|
|
|
|
46
|
|
|
if (is_object($xoopsUser) && $xoopsUser->isAdmin($xoopsModule->mid())) { |
|
47
|
|
|
$errors = 0; |
|
48
|
|
|
$warning = 0; |
|
49
|
|
|
// 1) Create, if it does not exists |
|
50
|
|
|
if (!TableExists($xoopsDB->prefix('stats_refer_blacklist'))) { |
|
51
|
|
|
$sql = 'CREATE TABLE ' . $xoopsDB->prefix('stats_refer_blacklist') . ' ( |
|
52
|
|
|
`id` INT( 3 ) NOT NULL AUTO_INCREMENT , |
|
53
|
|
|
`referer` VARCHAR( 255 ) NOT NULL, |
|
54
|
|
|
PRIMARY KEY (id) |
|
55
|
|
|
) ENGINE=MyISAM'; |
|
56
|
|
|
|
|
57
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
58
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED1; |
|
59
|
|
|
++$errors; |
|
60
|
|
|
} |
|
61
|
|
|
} else { |
|
62
|
|
|
$sql = 'TRUNCATE TABLE ' . $xoopsDB->prefix('stats_refer_blacklist'); |
|
63
|
|
|
|
|
64
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
65
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED10; |
|
66
|
|
|
++$errors; |
|
67
|
|
|
} else { |
|
68
|
|
|
$sql = 'INSERT INTO ' |
|
69
|
|
|
. $xoopsDB->prefix('stats_refer_blacklist') |
|
70
|
|
|
. " VALUES (1, 'a:101:{i:0;s:11:\"bergvall.nu\";i:1;" |
|
71
|
|
|
. 's:15:"allnetgoods.com";i:2;s:23:"100-online-gambling.com";i:3;s:8:"amkf.com";i:4;s:18:"keytomarketing.com";i:5;s' |
|
72
|
|
|
. ':18:"dental[A-Za-z0-9]*";i:6;s:9:"paint.com";i:7;s:6:"7h.com";i:8;s:7:"dad.com";i:9;s:8:"ds4a.com";i:10;s' |
|
73
|
|
|
. ':7:"9cy.com";i:11;s:10:"palajo.com";i:12;s:9:"imals.com";i:13;s:15:"bigsitecity.com";i:14;s:8:"hamj.com";i:15;s' |
|
74
|
|
|
. ':9:"iemkt.com";i:16;s:11:"sidelog.com";i:17;s:8:"zuvl.com";i:18;s:9:"dfing.com";i:19;s:10:"gasvac.com";i:20;s' |
|
75
|
|
|
. ':10:"gasvac.net";i:21;s:9:"lojka.com";i:22;s:9:"aubek.com";i:23;s:12:"maclenet.com";i:24;s:15:"gay[A-Za-z0-9]*";i:25;s' |
|
76
|
|
|
. ':9:"jsvan.com";i:26;s:11:"tellima.com";i:27;s:7:"jixx.de";i:28;s:17:"detox[A-Za-z0-9]*";i:29;s:16' |
|
77
|
|
|
. ':"drug[A-Za-z0-9]*";i:30;s:15:"buy[A-Za-z0-9]*";i:31;s:15:"ass[A-Za-z0-9]*";i:32;s:7:"move.to";i:33;s:13' |
|
78
|
|
|
. ':"fullspeed.com";i:34;s:18:"viagra[A-Za-z0-9]*";i:35;s:14:"givemepink.com";i:36;s:17:"sperm[A-Za-z0-9]*";i:37;s:16' |
|
79
|
|
|
. ':"fuck[A-Za-z0-9]*";i:38;s:11:"shemale.com";i:39;s:16:"cock[A-Za-z0-9]*";i:40;s:7:"jixx.de";i:41;s:16' |
|
80
|
|
|
. ':"plugherholes.com";i:42;s:18:"hentai[A-Za-z0-9]*";i:43;s:9:"pagina.de";i:44;s:19:"shemale[A-Za-z0-9]*";i:45;s:17' |
|
81
|
|
|
. ':"bitch[A-Za-z0-9]*";i:46;s:19:"bondage[A-Za-z0-9]*";i:47;s:19:"blowjob[A-Za-z0-9]*";i:48;s:17:"semen[A-Za-z0-9]*";i:49;s:15' |
|
82
|
|
|
. ':"cum[A-Za-z0-9]*";i:50;s:19:"bondage[A-Za-z0-9]*";i:51;s:7:"3333.ws";i:52;s:15:"ebony-white.com";i:53;s:19' |
|
83
|
|
|
. ':"thebest[A-Za-z0-9]*";i:54;s:17:"nice-[A-Za-z0-9]*";i:55;s:15:"ime[A-Za-z0-9]*";i:56;s:14:"bjsandwich.com";i:57;s' |
|
84
|
|
|
. ':16:"bdsm[A-Za-z0-9]*";i:58;s:17:"gooey[A-Za-z0-9]*";i:59;s:11:"21ebony.com";i:60;s:6:"olo.cc";i:61;s:18' |
|
85
|
|
|
. ':"18inch[A-Za-z0-9]*";i:62;s:23:"allinternal[A-Za-z0-9]*";i:63;s:25:"furniturefind[A-Za-z0-9]*";i:64;s:17' |
|
86
|
|
|
. ':"poker[A-Za-z0-9]*";i:65;s:7:"2rx.biz";i:66;s:7:"0me.com";i:67;s:15:"ads[A-Za-z0-9]*";i:68;s:16:"diet[A-Za-z0-9]*";i' |
|
87
|
|
|
. ':69;s:20:"ringtone[A-Za-z0-9]*";i:70;s:8:"a1a1.com";i:71;s:8:"b1b1.com";i:72;s:16:"shit[A-Za-z0-9]*";i:73;s:15' |
|
88
|
|
|
. ':"sex[A-Za-z0-9]*";i:74;s:16:"porn[A-Za-z0-9]*";i:75;s:18:"ambien[A-Za-z0-9]*";i:76;s:6:"get.to";i:77;s:17' |
|
89
|
|
|
. ':"xanax[A-Za-z0-9]*";i:78;s:19:"vicodin[A-Za-z0-9]*";i:79;s:22:"alprazolam[A-Za-z0-9]*";i:80;s:5:"go.to";i:81;s:15' |
|
90
|
|
|
. ':"circleofsex.net";i:82;s:20:"fioricet[A-Za-z0-9]*";i:83;s:23:"phentermine[A-Za-z0-9]*";i:84;s:7:"come.to";i:85;s' |
|
91
|
|
|
. ':7:"drop.to";i:86;s:9:"mysite.de";i:87;s:23:"hydrocodone[A-Za-z0-9]*";i:88;s:6:"hey.to";i:89;s:18' |
|
92
|
|
|
. ':"cialis[A-Za-z0-9]*";i:90;s:23:"bikinibabes[A-Za-z0-9]*";i:91;s:19:"wrongsideoftown.com";i:92;s:8:"babes.tv";i:93' |
|
93
|
|
|
. ';s:6:"v3.com";i:94;s:16:"myphotoalbum.com";i:95;s:12:"hotgames.com";i:96;s:14:"myblogsite.com";i:97;s:15' |
|
94
|
|
|
. ":\"fortunecity.com\";i:98;s:14:\"dreambabes.com\";i:99;s:6:\"lol.to\";i:100;s:8:\"blogs.it\";}')"; |
|
95
|
|
|
|
|
96
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
97
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED11; |
|
98
|
|
|
++$errors; |
|
99
|
|
|
} |
|
100
|
|
|
} |
|
101
|
|
|
} |
|
102
|
|
|
|
|
103
|
|
|
if (!TableExists($xoopsDB->prefix('stats_userscreen'))) { |
|
104
|
|
|
$sql = 'CREATE TABLE ' . $xoopsDB->prefix('stats_userscreen') . ' ( |
|
105
|
|
|
`id` INT( 1 ) NOT NULL, |
|
106
|
|
|
`hits` INT( 5 ) NOT NULL, |
|
107
|
|
|
PRIMARY KEY (id) |
|
108
|
|
|
) ENGINE=MyISAM'; |
|
109
|
|
|
|
|
110
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
111
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED3; |
|
112
|
|
|
++$errors; |
|
113
|
|
|
} else { |
|
114
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_userscreen') . ' VALUES (1, 0)'); |
|
115
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_userscreen') . ' VALUES (2, 0)'); |
|
116
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_userscreen') . ' VALUES (3, 0)'); |
|
117
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_userscreen') . ' VALUES (4, 0)'); |
|
118
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_userscreen') . ' VALUES (5, 0)'); |
|
119
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_userscreen') . ' VALUES (6, 0)'); |
|
120
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_userscreen') . ' VALUES (7, 0)'); |
|
121
|
|
|
} |
|
122
|
|
|
} |
|
123
|
|
|
|
|
124
|
|
|
if (!TableExists($xoopsDB->prefix('stats_usercolor'))) { |
|
125
|
|
|
$sql = 'CREATE TABLE ' . $xoopsDB->prefix('stats_usercolor') . ' ( |
|
126
|
|
|
`id` INT( 1 ) NOT NULL, |
|
127
|
|
|
`hits` INT( 5 ) NOT NULL, |
|
128
|
|
|
PRIMARY KEY (id) |
|
129
|
|
|
) ENGINE=MyISAM'; |
|
130
|
|
|
|
|
131
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
132
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED4; |
|
133
|
|
|
++$errors; |
|
134
|
|
|
} else { |
|
135
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_usercolor') . ' VALUES (1, 0)'); |
|
136
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_usercolor') . ' VALUES (2, 0)'); |
|
137
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_usercolor') . ' VALUES (3, 0)'); |
|
138
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_usercolor') . ' VALUES (4, 0)'); |
|
139
|
|
|
$xoopsDB->queryF('INSERT INTO ' . $xoopsDB->prefix('stats_usercolor') . ' VALUES (5, 0)'); |
|
140
|
|
|
} |
|
141
|
|
|
} |
|
142
|
|
|
|
|
143
|
|
|
if (!TableExists($xoopsDB->prefix('stats_blockedyear'))) { |
|
144
|
|
|
$sql = 'CREATE TABLE ' . $xoopsDB->prefix('stats_blockedyear') . " ( |
|
145
|
|
|
`year` SMALLINT(6) NOT NULL DEFAULT '0', |
|
146
|
|
|
`hits` BIGINT(20) NOT NULL DEFAULT '0' |
|
147
|
|
|
) ENGINE=MyISAM"; |
|
148
|
|
|
|
|
149
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
150
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED6; |
|
151
|
|
|
++$errors; |
|
152
|
|
|
} |
|
153
|
|
|
} |
|
154
|
|
|
|
|
155
|
|
|
if (!TableExists($xoopsDB->prefix('stats_blockedmonth'))) { |
|
156
|
|
|
$sql = 'CREATE TABLE ' . $xoopsDB->prefix('stats_blockedmonth') . " ( |
|
157
|
|
|
`year` SMALLINT(6) NOT NULL DEFAULT '0', |
|
158
|
|
|
`month` TINYINT(4) NOT NULL DEFAULT '0', |
|
159
|
|
|
`hits` BIGINT(20) NOT NULL DEFAULT '0' |
|
160
|
|
|
) ENGINE=MyISAM"; |
|
161
|
|
|
|
|
162
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
163
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED7; |
|
164
|
|
|
++$errors; |
|
165
|
|
|
} |
|
166
|
|
|
} |
|
167
|
|
|
|
|
168
|
|
|
if (!TableExists($xoopsDB->prefix('stats_blockeddate'))) { |
|
169
|
|
|
$sql = 'CREATE TABLE ' . $xoopsDB->prefix('stats_blockeddate') . " ( |
|
170
|
|
|
`year` SMALLINT(6) NOT NULL DEFAULT '0', |
|
171
|
|
|
`month` TINYINT(4) NOT NULL DEFAULT '0', |
|
172
|
|
|
`date` TINYINT(4) NOT NULL DEFAULT '0', |
|
173
|
|
|
`hits` BIGINT(20) NOT NULL DEFAULT '0' |
|
174
|
|
|
) ENGINE=MyISAM"; |
|
175
|
|
|
|
|
176
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
177
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED8; |
|
178
|
|
|
++$errors; |
|
179
|
|
|
} |
|
180
|
|
|
} |
|
181
|
|
|
|
|
182
|
|
|
if (!TableExists($xoopsDB->prefix('stats_blockedhour'))) { |
|
183
|
|
|
$sql = 'CREATE TABLE ' . $xoopsDB->prefix('stats_blockedhour') . " ( |
|
184
|
|
|
`year` SMALLINT(6) NOT NULL DEFAULT '0', |
|
185
|
|
|
`month` TINYINT(4) NOT NULL DEFAULT '0', |
|
186
|
|
|
`date` TINYINT(4) NOT NULL DEFAULT '0', |
|
187
|
|
|
`hour` TINYINT(4) NOT NULL DEFAULT '0', |
|
188
|
|
|
`hits` INT(11) NOT NULL DEFAULT '0' |
|
189
|
|
|
) ENGINE=MyISAM"; |
|
190
|
|
|
|
|
191
|
|
|
if (!$xoopsDB->queryF($sql)) { |
|
192
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED9; |
|
193
|
|
|
++$errors; |
|
194
|
|
|
} |
|
195
|
|
|
} |
|
196
|
|
|
|
|
197
|
|
|
// 2) Change some fields |
|
198
|
|
|
if (!FieldExists('referpath', $xoopsDB->prefix('stats_refer'))) { |
|
199
|
|
|
$sql = 'ALTER TABLE ' . $xoopsDB->prefix('stats_refer') . ' ADD `referpath` VARCHAR(150) NOT NULL'; |
|
200
|
|
|
$result = $xoopsDB->queryF($sql); |
|
201
|
|
|
if (!$result) { |
|
202
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED2; |
|
203
|
|
|
++$warning; |
|
204
|
|
|
} |
|
205
|
|
|
} |
|
206
|
|
|
|
|
207
|
|
|
$sql = 'INSERT INTO ' . $xoopsDB->prefix('counter') . " VALUES ('browser', 'Deepnet', 0)"; |
|
208
|
|
|
$result = $xoopsDB->queryF($sql); |
|
209
|
|
|
if (!$result) { |
|
210
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED5; |
|
211
|
|
|
++$errors; |
|
212
|
|
|
} |
|
213
|
|
|
$sql = 'INSERT INTO ' . $xoopsDB->prefix('counter') . " VALUES ('browser', 'Avant', 0)"; |
|
214
|
|
|
$result = $xoopsDB->queryF($sql); |
|
215
|
|
|
if (!$result) { |
|
216
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED5; |
|
217
|
|
|
++$errors; |
|
218
|
|
|
} |
|
219
|
|
|
$sql = 'INSERT INTO ' . $xoopsDB->prefix('counter') . " VALUES ('totalblocked', 'hits', 0 )"; |
|
220
|
|
|
$result = $xoopsDB->queryF($sql); |
|
221
|
|
|
if (!$result) { |
|
222
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED5; |
|
223
|
|
|
++$errors; |
|
224
|
|
|
} |
|
225
|
|
|
$sql = 'INSERT INTO ' . $xoopsDB->prefix('counter') . " VALUES ('blocked', 'bots', 0)"; |
|
226
|
|
|
$result = $xoopsDB->queryF($sql); |
|
227
|
|
|
if (!$result) { |
|
228
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED5; |
|
229
|
|
|
++$errors; |
|
230
|
|
|
} |
|
231
|
|
|
$sql = 'INSERT INTO ' . $xoopsDB->prefix('counter') . " VALUES ('blocked', 'referers', 0)"; |
|
232
|
|
|
$result = $xoopsDB->queryF($sql); |
|
233
|
|
|
if (!$result) { |
|
234
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED . ' ' . _STATS_UPGRADEFAILED5; |
|
235
|
|
|
++$errors; |
|
236
|
|
|
} |
|
237
|
|
|
|
|
238
|
|
|
if (!FieldExists('ip', $xoopsDB->prefix('stats_refer'))) { |
|
239
|
|
|
AddField("'ip' VARCHAR(20) NOT NULL", $xoopsDB->prefix('stats_refer')); |
|
240
|
|
|
} |
|
241
|
|
|
|
|
242
|
|
|
// At the end, if there was errors, show them or redirect user to the module's upgrade page |
|
243
|
|
|
if ($errors) { |
|
244
|
|
|
echo '<H1>' . _STATS_UPGRADEFAILED . '</H1>'; |
|
245
|
|
|
echo '<br>' . _STATS_UPGRADEFAILED0; |
|
246
|
|
|
} elseif ($warning) { |
|
247
|
|
|
echo '<H1>' . _STATS_UPGRADEFAILEDWWARN . '</H1>'; |
|
248
|
|
|
echo '<br>' . _STATS_UPGRADECOMPLETEWITHWARN; |
|
249
|
|
|
} else { |
|
250
|
|
|
echo _STATS_UPGRADECOMPLETE . " - <a href='" . XOOPS_URL . "/modules/system/admin.php?fct=modulesadmin&op=update&module=statistics'>" . _AM_NEWS_UPDATEMODULE . '</a>'; |
|
|
|
|
|
|
251
|
|
|
} |
|
252
|
|
|
} else { |
|
253
|
|
|
printf("<H2>%s</H2>\n", _STATS_UPGR_ACCESS_ERROR); |
|
254
|
|
|
} |
|
255
|
|
|
xoops_cp_footer(); |
|
256
|
|
|
|