boinc/html/ops/cancel_wu_action.php

78 lines
2.0 KiB
PHP
Raw Normal View History

<?php
$cvs_version_tracker[]="\$Id$"; //Generated automatically - do not edit
// cancel a WU:
// - mark unsent results as OVER, outcome DIDNT_NEED
// - set CANCELLED bit in WU error mask
//
function test_mysql_query($msg) {
echo "mysql_query($msg)<br/>";
return 1;
}
// for purposes of testing and seeing queries,
// replace the two instances of mysql_query() below with test_mysql_query().
//
function cancel_wu($wuid1, $wuid2) {
$command1="update result set server_state=5, outcome=5 where server_state=2 and $wuid1<=workunitid and workunitid<=$wuid2";
$command2="update workunit set error_mask=error_mask|16 where $wuid1<=id and id<=$wuid2";
if (!mysql_query($command1)) {
echo "MySQL command $command1 failed:<br/>unable to cancel unsent results.<br/>";
return 1;
} else if (!mysql_query($command2)) {
echo "MySQL command $command2 failed:<br/>unable to cancel workunits.<br/>";
return 2;
}
// trigger the transitioner (it will set file_delete_state)
$now = time();
$query="update workunit set transition_time=$now where $wuid1<=id and id<=$wuid2";
mysql_query($query);
return 0;
}
require_once("../inc/db.inc");
require_once("../inc/util_ops.inc");
// REMOVE THE FOLLOWING ONLY AFTER PASSWORD-PROTECTING html/ops
//
if (1) {
echo "
WARNING! Make sure the html/ops directory is password-protected,
then edit html/ops/cancel_wu_action.php by hand to remove this message.
";
exit();
}
admin_page_head("Cancel WU");
db_init();
$wuid1 = $_GET['wuid1'];
$wuid2 = $_GET['wuid2'];
if ($wuid1<1 || $wuid2<$wuid1) {
echo "<h2>Workunit IDs fail to satisfy the conditions:<br/>
1 <= WU1 ($wuid1) <= WU2 ($wuid2)<br/>
Unable to process request to cancel workunits.
</h2>
";
exit();
}
echo "CANCELLING workunits $wuid1 to $wuid2 inclusive....<br/>";
if (cancel_wu($wuid1, $wuid2)) {
echo "<h2>Failed in";
} else {
echo "<h2>Success in";
}
echo " cancelling workunits $wuid1 <= WUID <= $wuid2</h2>";
admin_page_tail();
?>