2004-02-02 23:34:39 +00:00
|
|
|
<?php
|
2008-08-05 22:43:14 +00:00
|
|
|
// This file is part of BOINC.
|
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2008 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/>.
|
2004-02-02 23:34:39 +00:00
|
|
|
|
2004-06-21 20:14:38 +00:00
|
|
|
function result_claimed_credit_string($result, $string_to_show) {
|
|
|
|
if ($result->server_state <> 5) return "---";
|
|
|
|
switch($result->outcome) {
|
2008-06-11 16:49:56 +00:00
|
|
|
case 3:
|
|
|
|
if ($result->exit_status <> -221) {
|
2007-07-11 17:14:02 +00:00
|
|
|
return $string_to_show; //Client error
|
2008-06-11 16:49:56 +00:00
|
|
|
}
|
|
|
|
default:
|
|
|
|
if ($result->claimed_credit > 0) {
|
|
|
|
return $string_to_show;
|
|
|
|
}
|
|
|
|
return "---"; // no claimed credit
|
2004-06-21 20:14:38 +00:00
|
|
|
}
|
2004-04-04 02:59:42 +00:00
|
|
|
}
|
|
|
|
|
2004-06-21 20:14:38 +00:00
|
|
|
function result_granted_credit_string($result, $string_to_show) {
|
|
|
|
if ($result->server_state <> 5) return "---";
|
|
|
|
switch($result->outcome) {
|
|
|
|
case 1: //Success
|
2004-12-14 00:57:03 +00:00
|
|
|
switch ($result->validate_state) {
|
|
|
|
case 0:
|
|
|
|
case 4:
|
|
|
|
return "pending";
|
2004-06-21 20:14:38 +00:00
|
|
|
}
|
2004-12-14 00:57:03 +00:00
|
|
|
return $string_to_show;
|
2008-06-11 16:49:56 +00:00
|
|
|
default:
|
|
|
|
if ($result->granted_credit > 0) {
|
|
|
|
return $string_to_show;
|
|
|
|
}
|
|
|
|
return "---"; // no claimed credit
|
2004-06-21 20:14:38 +00:00
|
|
|
}
|
2004-04-04 02:59:42 +00:00
|
|
|
}
|
|
|
|
|
2009-03-18 22:53:55 +00:00
|
|
|
// various states that we allow users to filter on
|
|
|
|
|
|
|
|
define("STATE_ALL", 0);
|
|
|
|
define("STATE_IN_PROGRESS", 1);
|
|
|
|
define("STATE_PENDING", 2);
|
|
|
|
define("STATE_VALID", 3);
|
|
|
|
define("STATE_INVALID", 4);
|
|
|
|
define("STATE_ERROR", 5);
|
|
|
|
define("NSTATES", 6);
|
|
|
|
|
|
|
|
$state_name = array(
|
|
|
|
"All",
|
|
|
|
"In progress",
|
|
|
|
"Pending",
|
|
|
|
"Valid",
|
|
|
|
"Invalid",
|
|
|
|
"Error",
|
|
|
|
);
|
|
|
|
|
|
|
|
$state_clause = array(
|
|
|
|
"",
|
|
|
|
" and server_state=4 ",
|
2009-04-02 17:41:14 +00:00
|
|
|
" and server_state=5 and outcome=1 and (validate_state=0 or validate_state=4) ",
|
2009-03-18 22:53:55 +00:00
|
|
|
" and server_state=5 and outcome=1 and validate_state=1 ",
|
2009-06-08 17:08:52 +00:00
|
|
|
" and server_state=5 and (outcome=6 or (outcome=1 and (validate_state=2 or validate_state=3 or validate_state=5))) ",
|
|
|
|
" and server_state=5 and (outcome=3 or outcome=4 or outcome=7) ",
|
2009-03-18 22:53:55 +00:00
|
|
|
);
|
|
|
|
|
2009-03-16 19:39:16 +00:00
|
|
|
function state_string($result) {
|
|
|
|
switch ($result->server_state) {
|
|
|
|
case 1: return "Inactive";
|
|
|
|
case 2: return "Unsent";
|
|
|
|
case 4: return "In progress";
|
|
|
|
case 5:
|
|
|
|
switch ($result->outcome) {
|
|
|
|
case 1:
|
|
|
|
switch ($result->validate_state) {
|
|
|
|
case 0: return "Completed, waiting for validation";
|
|
|
|
case 1: return "Completed and validated";
|
|
|
|
case 2: return "Completed, marked as invalid";
|
|
|
|
case 3: return "Completed, can't validate";
|
|
|
|
case 4: return "Completed, validation inconclusive";
|
2009-03-17 15:06:10 +00:00
|
|
|
case 5: return "Completed, too late to validate";
|
2009-03-16 19:39:16 +00:00
|
|
|
}
|
|
|
|
return "Completed";
|
|
|
|
case 2: return "Couldn't send";
|
|
|
|
case 3:
|
|
|
|
if ($result->exit_status == -221) {
|
|
|
|
return "Redundant result";
|
|
|
|
}
|
|
|
|
switch($result->client_state) {
|
|
|
|
case 1: return "Error while downloading";
|
|
|
|
case 2: return "Error while computing";
|
|
|
|
case 3: return "Error while computing";
|
|
|
|
case 4: return "Error while uploading";
|
2009-03-18 22:53:55 +00:00
|
|
|
case 6:
|
|
|
|
if ($result->exit_status == -221) {
|
|
|
|
return "Cancelled by server";
|
|
|
|
}
|
|
|
|
return "Aborted by user";
|
2009-03-16 19:39:16 +00:00
|
|
|
}
|
|
|
|
return "Error";
|
|
|
|
case 4: return "Timed out - no response";
|
|
|
|
case 5: return "Didn't need";
|
|
|
|
case 6: return "Validate error";
|
|
|
|
case 7: return "Client detached";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return "Unknown";
|
|
|
|
}
|
|
|
|
|
2007-07-11 17:14:02 +00:00
|
|
|
function result_server_state_string($result) {
|
|
|
|
switch($result->server_state) {
|
2004-02-02 23:34:39 +00:00
|
|
|
case 1: return "Inactive";
|
|
|
|
case 2: return "Unsent";
|
2008-06-11 16:49:56 +00:00
|
|
|
case 4: return "In progress";
|
2004-02-02 23:34:39 +00:00
|
|
|
case 5: return "Over";
|
|
|
|
}
|
2004-06-21 20:14:38 +00:00
|
|
|
return "Unknown";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
|
2007-07-11 17:14:02 +00:00
|
|
|
function result_outcome_string($result) {
|
|
|
|
switch($result->outcome) {
|
2008-06-11 16:49:56 +00:00
|
|
|
case 0: return "---";
|
2004-02-02 23:34:39 +00:00
|
|
|
case 1: return "Success";
|
|
|
|
case 2: return "Couldn't send";
|
2008-06-11 16:49:56 +00:00
|
|
|
case 3:
|
|
|
|
if ($result->exit_status <> -221) {
|
2009-03-16 19:39:16 +00:00
|
|
|
return "Client error";
|
2008-06-11 16:49:56 +00:00
|
|
|
}
|
|
|
|
return "Redundant result";
|
2004-02-02 23:34:39 +00:00
|
|
|
case 4: return "No reply";
|
|
|
|
case 5: return "Didn't need";
|
2004-12-01 23:20:12 +00:00
|
|
|
case 6: return "Validate error";
|
2006-07-06 17:30:03 +00:00
|
|
|
case 7: return "Client detached";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
2004-06-21 20:14:38 +00:00
|
|
|
return "Unknown";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
|
2007-07-11 17:14:02 +00:00
|
|
|
function result_client_state_string($result) {
|
|
|
|
switch($result->client_state) {
|
2004-02-02 23:34:39 +00:00
|
|
|
case 0: return "New";
|
|
|
|
case 1: return "Downloading";
|
2006-05-25 20:10:08 +00:00
|
|
|
case 2: return "Computing";
|
|
|
|
case 3: return "Compute error";
|
2004-02-02 23:34:39 +00:00
|
|
|
case 4: return "Uploading";
|
|
|
|
case 5: return "Done";
|
2008-06-11 16:49:56 +00:00
|
|
|
case 6:
|
2009-03-16 19:39:16 +00:00
|
|
|
if ($result->exit_status == -221) {
|
|
|
|
return "Cancelled by server";
|
2008-06-11 16:49:56 +00:00
|
|
|
}
|
2009-03-16 19:39:16 +00:00
|
|
|
return "Aborted by user";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-11 17:14:02 +00:00
|
|
|
function validate_state_str($result) {
|
|
|
|
switch($result->validate_state) {
|
2004-02-02 23:34:39 +00:00
|
|
|
case 0: return "Initial";
|
|
|
|
case 1: return "Valid";
|
2008-06-11 16:49:56 +00:00
|
|
|
case 2:
|
|
|
|
if ($result->exit_status <> -221) {
|
|
|
|
return "Invalid";
|
|
|
|
}
|
|
|
|
return "Not necessary";
|
2005-02-08 00:39:05 +00:00
|
|
|
case 3: return "Workunit error - check skipped";
|
2004-12-14 00:57:03 +00:00
|
|
|
case 4: return "Checked, but no consensus yet";
|
2007-10-04 17:30:28 +00:00
|
|
|
case 5: return "Task was reported too late to validate";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
2004-06-21 20:14:38 +00:00
|
|
|
return "Unknown";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
|
2004-12-15 23:50:00 +00:00
|
|
|
function wu_error_mask_str($s) {
|
|
|
|
$x = "";
|
|
|
|
if ($s & 1) {
|
|
|
|
$x = $x."Couldn't send result ";
|
|
|
|
$s -= 1;
|
|
|
|
}
|
|
|
|
if ($s & 2) {
|
|
|
|
$x = $x."Too many error results ";
|
|
|
|
$s -= 2;
|
|
|
|
}
|
|
|
|
if ($s & 4) {
|
|
|
|
$x = $x."Too many success results ";
|
|
|
|
$s -= 4;
|
|
|
|
}
|
|
|
|
if ($s & 8) {
|
|
|
|
$x = $x."Too many total results ";
|
|
|
|
$s -= 8;
|
|
|
|
}
|
|
|
|
if ($s & 16) {
|
|
|
|
$x = $x."Cancelled ";
|
|
|
|
$s -= 16;
|
|
|
|
}
|
|
|
|
if ($s) {
|
|
|
|
$x = $x."Unrecognized Error: $s ";
|
|
|
|
}
|
2008-06-11 16:49:56 +00:00
|
|
|
if (!strlen($x)) {
|
2004-12-15 23:50:00 +00:00
|
|
|
$x="<br>";
|
|
|
|
}
|
|
|
|
return $x;
|
|
|
|
}
|
|
|
|
|
2009-02-19 18:39:03 +00:00
|
|
|
function result_page_url($info) {
|
|
|
|
$c = $info->clause;
|
|
|
|
$o = $info->offset;
|
|
|
|
$sn = $info->show_names;
|
2009-03-18 22:53:55 +00:00
|
|
|
$st = $info->state;
|
|
|
|
return "results.php?$c&offset=$o&show_names=$sn&state=$st";
|
2009-02-19 18:39:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function result_table_start($show_wu_link, $show_host_link, $info) {
|
2004-02-02 23:34:39 +00:00
|
|
|
start_table();
|
2009-02-19 18:39:03 +00:00
|
|
|
echo "<tr>";
|
|
|
|
if ($info) {
|
|
|
|
if ($info->show_names) {
|
|
|
|
$i2 = clone $info;
|
|
|
|
$i2->show_names = 0;
|
|
|
|
$url = result_page_url($i2);
|
|
|
|
echo "<th>Task name<br><span class=\"smalltext\">click for details<br><a href=$url>Show IDs</a></span></th>\n";
|
|
|
|
} else {
|
|
|
|
$i2 = clone $info;
|
|
|
|
$i2->show_names = 1;
|
|
|
|
$url = result_page_url($i2);
|
|
|
|
echo "<th>Task ID<br><span class=\"smalltext\">click for details<br><a href=$url>Show names</a></span></th>\n";
|
|
|
|
}
|
|
|
|
} else {
|
2007-10-04 17:30:28 +00:00
|
|
|
echo "<th>Task ID<br><span class=\"smalltext\">click for details</span></th>\n";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
if ($show_wu_link) {
|
2007-09-01 19:43:24 +00:00
|
|
|
echo "<th>Work unit ID<br><span class=\"smalltext\">click for details</span></th>\n";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
if ($show_host_link) {
|
2005-02-07 06:24:14 +00:00
|
|
|
echo "<th>Computer</th>\n";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
echo "
|
|
|
|
<th>Sent</th>
|
2004-12-15 23:50:00 +00:00
|
|
|
<th>Time reported
|
|
|
|
<br>or deadline
|
2007-09-01 19:43:24 +00:00
|
|
|
<br><span class=\"smalltext\"><a href=\"explain_state.php?field=result_time\">explain</a></span>
|
2004-12-15 23:50:00 +00:00
|
|
|
</th>
|
2009-03-16 19:39:16 +00:00
|
|
|
<th>Status</th>
|
2004-02-02 23:34:39 +00:00
|
|
|
<th>CPU time (sec)</th>
|
|
|
|
<th>claimed credit</th>
|
|
|
|
<th>granted credit</th>
|
|
|
|
</tr>
|
|
|
|
";
|
|
|
|
}
|
|
|
|
|
2006-02-20 07:55:32 +00:00
|
|
|
// was result invalid or timed out?
|
|
|
|
//
|
|
|
|
function bad_result($result) {
|
|
|
|
if ($result->validate_state == 2) return true;
|
|
|
|
if (!$result->received_time && ($result->report_deadline < time())) return true;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2004-02-02 23:34:39 +00:00
|
|
|
function show_result_row(
|
2009-02-19 18:39:03 +00:00
|
|
|
$result, $show_wu_link, $show_host_link, $show_name, $i
|
2004-02-02 23:34:39 +00:00
|
|
|
) {
|
|
|
|
$s = time_str($result->sent_time);
|
2009-02-19 18:39:03 +00:00
|
|
|
// if result has been reported, show the received time,
|
2004-12-15 23:50:00 +00:00
|
|
|
// else show the reporting deadline in green if in the future
|
|
|
|
// and in red if in the past.
|
|
|
|
//
|
|
|
|
if ($result->received_time) {
|
2004-12-01 23:20:12 +00:00
|
|
|
$r = time_str($result->received_time);
|
2004-12-15 23:50:00 +00:00
|
|
|
} else if ($result->report_deadline) {
|
|
|
|
if ($result->report_deadline>time()) {
|
2007-10-26 22:07:39 +00:00
|
|
|
$r = "<font color='#33cc33'>" . time_str($result->report_deadline) . "</font>";
|
2004-12-14 00:57:03 +00:00
|
|
|
} else {
|
2007-10-26 22:07:39 +00:00
|
|
|
$r = "<font color='#ff3333'>" . time_str($result->report_deadline) . "</font>";
|
2004-12-14 00:57:03 +00:00
|
|
|
}
|
2004-12-15 23:50:00 +00:00
|
|
|
} else {
|
|
|
|
$r = "---";
|
2004-12-01 23:20:12 +00:00
|
|
|
}
|
2009-03-16 19:39:16 +00:00
|
|
|
$ss = state_string($result);
|
2004-04-04 02:59:42 +00:00
|
|
|
$result_claimed_credit = format_credit($result->claimed_credit);
|
|
|
|
$result_granted_credit = format_credit($result->granted_credit);
|
2004-06-21 20:14:38 +00:00
|
|
|
$result_claimed_credit = result_claimed_credit_string($result, $result_claimed_credit);
|
|
|
|
$result_granted_credit = result_granted_credit_string($result, $result_granted_credit);
|
2008-08-07 20:43:52 +00:00
|
|
|
$j = $i % 2;
|
|
|
|
echo "<tr class=row$j>";
|
2009-02-19 18:39:03 +00:00
|
|
|
if ($show_name) {
|
|
|
|
$x = $result->name;
|
|
|
|
} else {
|
|
|
|
$x = $result->id;
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
2009-02-19 18:39:03 +00:00
|
|
|
echo "<td><a href=\"result.php?resultid=$result->id\">$x</a></td>\n";
|
2004-02-02 23:34:39 +00:00
|
|
|
if ($show_wu_link) {
|
2004-12-18 17:27:03 +00:00
|
|
|
echo "<td><a href=\"workunit.php?wuid=$result->workunitid\">$result->workunitid</a></td>\n";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
if ($show_host_link) {
|
2004-02-05 21:35:48 +00:00
|
|
|
echo "<td>", host_link($result->hostid), "</td>\n";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
2004-06-21 20:14:38 +00:00
|
|
|
if ($result->server_state <> 5) {
|
|
|
|
$cpu_time = "---";
|
|
|
|
} else {
|
|
|
|
$cpu_time = number_format($result->cpu_time, 2);
|
|
|
|
}
|
2004-02-02 23:34:39 +00:00
|
|
|
echo "
|
|
|
|
<td>$s</td>
|
|
|
|
<td>$r</td>
|
|
|
|
<td>$ss</td>
|
2009-02-19 18:39:03 +00:00
|
|
|
<td align=right>$cpu_time</td>
|
|
|
|
<td align=right>$result_claimed_credit</td>
|
|
|
|
<td align=right>$result_granted_credit</td>
|
2004-02-02 23:34:39 +00:00
|
|
|
</tr>
|
|
|
|
";
|
|
|
|
}
|
|
|
|
|
2004-10-29 20:22:22 +00:00
|
|
|
function version_string($version_num) {
|
|
|
|
if (!$version_num) {
|
2004-02-02 23:34:39 +00:00
|
|
|
return '---';
|
|
|
|
} else {
|
2004-10-29 20:22:22 +00:00
|
|
|
return sprintf("%.2f", $version_num/100);
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
function exit_status_string($result) {
|
|
|
|
$x = $result->exit_status;
|
|
|
|
if ($x == 0) {
|
|
|
|
$y = parse_element($result->stderr_out, "<exit_status>");
|
|
|
|
if ($y) {
|
|
|
|
$x = (int)$y;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return sprintf("%d (0x%x)", $x, $x);
|
|
|
|
}
|
|
|
|
|
|
|
|
function show_result($result) {
|
|
|
|
start_table();
|
|
|
|
row2("Name", $result->name);
|
2004-12-18 17:27:03 +00:00
|
|
|
row2("Workunit", "<a href=\"workunit.php?wuid=$result->workunitid\">$result->workunitid</a>");
|
2004-02-02 23:34:39 +00:00
|
|
|
row2("Created", time_str($result->create_time));
|
|
|
|
row2("Sent", time_str($result->sent_time));
|
|
|
|
row2("Received", time_str($result->received_time));
|
2007-07-11 17:14:02 +00:00
|
|
|
row2("Server state", result_server_state_string($result));
|
|
|
|
row2("Outcome", result_outcome_string($result));
|
|
|
|
row2("Client state", result_client_state_string($result));
|
2004-02-02 23:34:39 +00:00
|
|
|
row2("Exit status", exit_status_string($result));
|
2005-02-07 06:24:14 +00:00
|
|
|
row2("Computer ID", host_link($result->hostid));
|
2004-02-02 23:34:39 +00:00
|
|
|
row2("Report deadline", time_str($result->report_deadline));
|
|
|
|
row2("CPU time", $result->cpu_time);
|
|
|
|
row2("stderr out", "<pre>".htmlspecialchars($result->stderr_out)."</pre>");
|
2007-09-17 19:15:01 +00:00
|
|
|
row2("Validate state", validate_state_str($result));
|
2004-10-29 20:22:22 +00:00
|
|
|
row2("Claimed credit", $result->claimed_credit);
|
2004-02-02 23:34:39 +00:00
|
|
|
row2("Granted credit", $result->granted_credit);
|
2004-10-29 20:22:22 +00:00
|
|
|
row2("application version", version_string($result->app_version_num));
|
2004-02-02 23:34:39 +00:00
|
|
|
end_table();
|
|
|
|
}
|
|
|
|
|
2009-02-19 18:39:03 +00:00
|
|
|
function show_result_navigation($info) {
|
2009-03-18 22:53:55 +00:00
|
|
|
global $state_name;
|
|
|
|
|
2006-05-04 04:29:28 +00:00
|
|
|
echo "<br><center>";
|
2009-02-19 18:39:03 +00:00
|
|
|
$show_prev = ($info->offset >= $info->results_per_page);
|
|
|
|
$show_next = ($info->number_of_results > $info->results_per_page);
|
|
|
|
if ($show_prev) {
|
|
|
|
$i2 = clone $info;
|
|
|
|
$i2->offset = $info->offset - $info->results_per_page;
|
|
|
|
$url = result_page_url($i2);
|
|
|
|
echo "<a href=$url>Previous ".$info->results_per_page."</a>";
|
2006-05-04 04:29:28 +00:00
|
|
|
}
|
2009-02-19 18:39:03 +00:00
|
|
|
if ($show_prev && $show_next) {
|
2006-05-04 04:29:28 +00:00
|
|
|
echo " | ";
|
|
|
|
}
|
2009-02-19 18:39:03 +00:00
|
|
|
if ($show_next) {
|
|
|
|
$i2 = clone $info;
|
|
|
|
$i2->offset = $info->offset + $info->results_per_page;
|
|
|
|
$url = result_page_url($i2);
|
|
|
|
echo "<a href=$url>Next ".$info->results_per_page."</a>";
|
2006-05-04 04:29:28 +00:00
|
|
|
}
|
2009-03-18 22:53:55 +00:00
|
|
|
echo "<br>Show: ";
|
|
|
|
for ($i=0; $i<NSTATES; $i++) {
|
|
|
|
if ($i) echo " | ";
|
|
|
|
if ($info->state == $i) {
|
|
|
|
echo $state_name[$i];
|
|
|
|
} else {
|
|
|
|
$i2 = clone $info;
|
|
|
|
$i2->state = $i;
|
|
|
|
$i2->offset = 0;
|
|
|
|
$url = result_page_url($i2);
|
|
|
|
echo "<a href=$url>".$state_name[$i]."</a>";
|
|
|
|
}
|
|
|
|
}
|
2009-02-19 18:39:03 +00:00
|
|
|
echo "</center><br>";
|
2006-05-04 04:29:28 +00:00
|
|
|
}
|
2007-11-14 16:03:47 +00:00
|
|
|
|
|
|
|
$cvs_version_tracker[]="\$Id$"; //Generated automatically - do not edit
|
|
|
|
|
2004-02-02 23:34:39 +00:00
|
|
|
?>
|