-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathrebuild_accounting.php
executable file
·84 lines (72 loc) · 2.29 KB
/
rebuild_accounting.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
#!/usr/bin/env php
<?php
// This file is part of BOINC.
// http://boinc.berkeley.edu
// Copyright (C) 2019 University of California
//
// BOINC is free software; you can redistribute it and/or modify it
// under the terms of the GNU Lesser General Public License
// as published by the Free Software Foundation,
// either version 3 of the License, or (at your option) any later version.
//
// BOINC 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 Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
// to fix bad accounting entries due to bugs:
// enumerate at the records (totals, project, host)
// to identify bad records; delete them
// Then run this script; it rebuilds totals from deltas.
//
// Of course this erases valid data for those days. That's OK.
require_once("../inc/su_util.inc");
require_once("../inc/su_db.inc");
require_once("../inc/util.inc");
function rebuild($recs) {
$sum = new_delta_set();
foreach ($recs as $rec) {
add_record($rec, $sum);
//echo date_str($rec->create_time)." id $rec->id gpu sum $sum->gpu_ec rec $rec->gpu_ec_total\n";
$q = total_update_string($sum);
//echo "$rec->id: $q\n";
$rec->update($q);
}
}
function rebuild_totals() {
$recs = SUAccounting::enum("", "order by id");
rebuild($recs);
}
function rebuild_project($id) {
$recs = SUAccountingProject::enum("project_id = $id", "order by id");
echo count($recs)." records\n";
rebuild($recs);
}
function rebuild_projects() {
$projs = SUProject::enum();
foreach ($projs as $p) {
echo "Project $p->id $p->name\n";
rebuild_project($p->id);
}
}
function rebuild_user($id) {
$recs = SUAccountingUser::enum("user_id = $id", "order by id");
echo count($recs)." records\n";
rebuild($recs);
}
function rebuild_users() {
$users = BoincUser::enum("");
foreach ($users as $u) {
echo "User $u->id $u->name\n";
rebuild_user($u->id);
}
}
function main() {
//rebuild_totals();
//rebuild_projects();
rebuild_users();
}
main();
?>