-
Notifications
You must be signed in to change notification settings - Fork 1
/
integritycheck.php
100 lines (89 loc) · 2.25 KB
/
integritycheck.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<?php
/*
* Webviewer for my teamspeak3 statistics bot - see github.com/yugecin/tsstats
* Copyright (C) 2014-2017 Robin C.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
if( php_sapi_name() !== 'cli' ) {
die( 'commandline only kthxbai' );
}
include "db.php";
$db = new Database();
// fix
$values = '';
for( $i = 0; $i < 24; $i++ ) {
$values .= ",(?,{$i},0)";
}
$values = substr( $values, 1 );
$sql = <<<SQL
INSERT IGNORE INTO tod
(uid,tod,`count`)
VALUES
$values
SQL;
$fix = $db->freeStatement( $sql );
function fixuser( $uid )
{
global $fix;
for( $i = 0; $i < 24;) {
$fix->bindValue( ++$i, $uid );
}
$fix->execute();
}
// fix
try
{
$sql = <<<SQL
SELECT uid, count(tod) AS c
FROM tod
GROUP BY uid
SQL;
$stmt = $db->freeStatement( $sql );
$stmt->execute();
//$info = $stmt->fetchAll( PDO::FETCH_CLASS );
$info = $stmt->fetchAll();
echo( 'checking 24 hours per user' . "\n" );
foreach( $info as $user ) {
if( $user['c'] != 24 ) {
echo( 'incorrect hours for uid ' . $user['uid'] . ' (' . $user['c'] . ')...' );
fixuser( $user['uid'] );
echo( 'fixed' . "\n" );
}
}
$sql = <<<SQL
SELECT uid
FROM users
WHERE uid NOT IN (
SELECT DISTINCT(uid)
FROM tod
)
SQL;
$stmt = $db->freeStatement( $sql );
$stmt->execute();
//$info = $stmt->fetchAll( PD0::FETCH_CLASS );
$info = $stmt->fetchAll();
echo( 'checking users without hours' . "\n" );
if( count( $info ) > 0 ) {
echo( 'some users don\'t have hours!' . "\n" );
foreach( $info as $user ) {
fixuser( $user['uid'] );
echo( 'fixed user ' . $user['uid'] . "\n" );
}
}
}
catch ( PDOException $e )
{
die( 'Database panic!<br/>' . $e->getMessage() );
}