mirror of https://github.com/BOINC/boinc.git
167 lines
5.7 KiB
PHP
167 lines
5.7 KiB
PHP
<?php
|
|
// This file is part of BOINC.
|
|
// http://boinc.berkeley.edu
|
|
// Copyright (C) 2015 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/>.
|
|
|
|
// web interface for canceling WUs according to either
|
|
// - ID range
|
|
// - ID list
|
|
// - SQL where clause
|
|
|
|
// This page shows the form, and a "confirm" page.
|
|
// The actual cancellation is done cancel_workunits_action.php
|
|
|
|
// TODO:
|
|
// - use get_int() etc. rather than $_REQUEST
|
|
// - use DB interfaces classes, not mysql_query() etc.
|
|
|
|
require_once("../inc/util_ops.inc");
|
|
|
|
admin_page_head("Cancel Jobs");
|
|
|
|
$limit = 100;
|
|
if (array_key_exists('limit',$_REQUEST)) {
|
|
$nlimit=$_REQUEST['limit'];
|
|
if ($nlimit != 0) {
|
|
$limit = $nlimit;
|
|
}
|
|
}
|
|
|
|
$clause = "";
|
|
|
|
if (array_key_exists('minid',$_REQUEST) && $_REQUEST['minid'] != "" &&
|
|
array_key_exists('maxid',$_REQUEST) && $_REQUEST['maxid'] != "")
|
|
$clause = "id >=" . $_REQUEST['minid'] . " AND id <=" . $_REQUEST['maxid'];
|
|
else if (array_key_exists('list',$_REQUEST) && $_REQUEST['list'] != "")
|
|
$clause = "id IN (" . $_REQUEST['list'] . ")";
|
|
else if (array_key_exists('uclause',$_REQUEST) && $_REQUEST['uclause'] != "")
|
|
$clause = urldecode($_REQUEST['uclause']);
|
|
else if (array_key_exists('clause',$_REQUEST) && $_REQUEST['clause'] != "")
|
|
// the following line is BS, but apparently I can't find another way to pass a
|
|
// double quote (") to the query
|
|
$clause = str_replace('\"', '"', $_REQUEST['clause']);
|
|
|
|
if ($clause == "") {
|
|
|
|
// copied from old cancel_wu_form.php
|
|
echo "<p>
|
|
This form may be used to cancel unnecessary or unwanted jobs.
|
|
We recommend that you stop the project before doing this.
|
|
Note that the jobs and their corresponding
|
|
results (if any) are NOT removed from the database.
|
|
Instead, they are marked as 'no longer needed'.
|
|
In most cases you should probably only remove jobs whose results
|
|
are all unsent,
|
|
since otherwise a user will not get credit
|
|
for a result that they might return.
|
|
</p>
|
|
<p>
|
|
Please specify jobs by ID range, ID list or clause to be used in a
|
|
'SELECT FROM workunit WHERE' query.
|
|
</p>
|
|
<p>
|
|
You will be given a list of jobs matching your specification
|
|
for confirmation before these are actually canceled.
|
|
</p>
|
|
";
|
|
|
|
$page = $_SERVER["REQUEST_URI"];
|
|
echo "<form action=\"$page\" method=\"get\" enctype=\"application/x-www-form-urlencoded\">\n";
|
|
echo "<ul><li>\n";
|
|
echo ' Range: ID of first WU to cancel ';
|
|
echo '<input name="minid" type="text" size="10" maxlength="15">';
|
|
echo ' ID of last WU to cancel ';
|
|
echo '<input name="maxid" type="text" size="10" maxlength="15">';
|
|
echo "</li><li>\n";
|
|
echo ' Comma-separated list of IDs ';
|
|
echo '<input name="list" type="text" size="100" maxlength="200">';
|
|
echo "</li><li>\n";
|
|
echo ' WHERE clause (w/o "WHERE") ';
|
|
echo '<input name="clause" type="text" size="100" maxlength="200">';
|
|
echo "</li></ul>\n";
|
|
echo "<p>\n";
|
|
echo ' Limit ';
|
|
echo "<input name=\"limit\" type=\"text\" size=\"3\" maxlength=\"3\" value=\"$limit\">";
|
|
echo "</p>\n";
|
|
echo "<p>\n";
|
|
echo '<input type="submit" value="Cancel jobs">';
|
|
echo "</p>\n";
|
|
|
|
} else { // if ($clause)
|
|
|
|
db_init(true); // try to get list of WUs from replica
|
|
|
|
$query = "SELECT id, name FROM workunit WHERE canonical_resultid = 0 AND error_mask = 0 AND $clause;";
|
|
$dbresult = _mysql_query($query);
|
|
|
|
if (!$dbresult) {
|
|
echo "Error in query '$query'<br>\n";
|
|
} else {
|
|
|
|
echo "<form action=\"cancel_workunits_action.php\" method=\"post\">\n";
|
|
echo "<input type=\"hidden\" name=\"back\" value=\"cancelwus\"/>";
|
|
|
|
echo "<br><table border=\"1\">\n";
|
|
echo "<tr><th>WU ID</th><th>WU name</th></tr>\n";
|
|
|
|
$rescount = 0;
|
|
while ($res = _mysql_fetch_object($dbresult)) {
|
|
if ($rescount < $limit) {
|
|
$id = $res->id;
|
|
echo "<tr>\n";
|
|
|
|
echo "<td align=\"left\" valign=\"top\">";
|
|
echo "<input type=\"checkbox\" name=\"WU[]\" value=\"$id\" checked>\n";
|
|
echo "<a href=db_action.php?table=workunit&detail=high&id=";
|
|
echo $id;
|
|
echo ">";
|
|
echo $id;
|
|
echo "</a>";
|
|
echo "</td>\n";
|
|
|
|
echo "<td align=\"left\" valign=\"top\">";
|
|
echo $res->name;
|
|
echo "</td>\n";
|
|
|
|
echo "</tr>\n";
|
|
}
|
|
$rescount++;
|
|
} // while (_mysql_fetch_object())
|
|
|
|
_mysql_free_result($dbresult);
|
|
|
|
echo "</table>\n<p>";
|
|
echo $rescount;
|
|
echo " WUs match the query ($query)\n</p>";
|
|
|
|
echo "<p>";
|
|
echo "<input type=\"hidden\" name=\"cancel\" value=\"1\"/>";
|
|
echo "<input type=\"hidden\" name=\"limit\" value=\"$limit\"/>";
|
|
$eclause = urlencode($clause);
|
|
echo "<input type=\"hidden\" name=\"clause\" value=\"$eclause\"/>";
|
|
echo "<input type=\"submit\" value=\"Cancel checked WUs\">";
|
|
echo "</p>\n";
|
|
echo "</form>\n";
|
|
|
|
} // if (!$dbresult)
|
|
|
|
} // if ($clause)
|
|
|
|
admin_page_tail();
|
|
|
|
$cvs_version_tracker[]="\$Id$"; //Generated automatically - do not edit
|
|
?>
|