nodecontrol_form.php3 5.13 KB
Newer Older
1 2 3
<?php
include("defs.php3");

4 5 6 7 8
#
# Standard Testbed Header
#
PAGEHEADER("Node Control Form");

9 10 11
#
# Only known and logged in users can do this.
#
12
$uid = GETLOGIN();
13 14
LOGGEDINORDIE($uid);

15 16 17 18 19 20 21 22
#
# Verify form arguments.
# 
if (!isset($node_id) ||
    strcmp($node_id, "") == 0) {
    USERERROR("You must provide a node ID.", 1);
}

23
#
24 25 26 27 28 29 30 31 32 33 34 35
# Check to make sure that this is a valid nodeid
#
$query_result = mysql_db_query($TBDBNAME,
	"SELECT * FROM nodes WHERE node_id=\"$node_id\"");
if (mysql_num_rows($query_result) == 0) {
  USERERROR("The node $node_id is not a valid nodeid", 1);
}
$row = mysql_fetch_array($query_result);

#
# Admin users can control any node, but normal users can only control
# nodes in their own experiments.
36 37 38
#
$isadmin = ISADMIN($uid);
if (! $isadmin) {
39
    $query_result = mysql_db_query($TBDBNAME,
40 41 42
	"select proj_memb.* from proj_memb left join reserved ".
	"on proj_memb.pid=reserved.pid and proj_memb.uid='$uid' ".
	"where reserved.node_id='$node_id'");
43
    if (mysql_num_rows($query_result) == 0) {
44 45
        USERERROR("The node $node_id is not in an experiment ".
		  "or not in the same project as you", 1);
46 47
    }
    $foorow = mysql_fetch_array($query_result);
48 49
    $trust = $foorow[trust];
    if ($trust != "local_root" && $trust != "group_root") {
50 51
        USERERROR("You do not have permission to modify node $node_id!", 1);
    }
52 53 54 55
}

$node_id            = $row[node_id]; 
$type               = $row[type];
56
$def_boot_osid      = $row[def_boot_osid];
57
$def_boot_path      = $row[def_boot_path];
58 59 60
$def_boot_cmd_line  = $row[def_boot_cmd_line];
$next_boot_path     = $row[next_boot_path];
$next_boot_cmd_line = $row[next_boot_cmd_line];
61
$rpms               = $row[rpms];
62
$startupcmd         = $row[startupcmd];
63

64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
#
# Get the OSID list.
#
if ($isadmin) {
    $osid_result = mysql_db_query($TBDBNAME,
	"SELECT * FROM os_info order by osid");
}
else {
    $osid_result = mysql_db_query($TBDBNAME,
	"select distinct o.* from os_info as o ".
	"left join proj_memb as p on o.pid IS NULL or p.pid=o.pid ".
	"where p.uid='$uid' order by o.pid,o.osid");
}
if (! $osid_result) {
    $err = mysql_error();
    TBERROR("Database Error getting OSID list: $err\n", 1);
}

82 83 84 85
echo "<table border=2 cellpadding=0 cellspacing=2
       align='center'>\n";

#
86 87
# Generate the form. Note that $refer is set by the caller so we know
# how we got to the nodecontrol page. 
88
# 
89
echo "<form action=\"nodecontrol.php3?refer=$refer\"
90
            method=\"post\">\n";
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106

echo "<tr>
          <td>Node ID:</td>
          <td class=\"left\"> 
              <input type=\"readonly\" name=\"node_id\" value=\"$node_id\">
              </td>
      </tr>\n";

echo "<tr>
          <td>Node Type:</td>
          <td class=\"left\"> 
              <input type=\"readonly\" name=\"node_type\" value=\"$type\">
              </td>
      </tr>\n";

#
107 108
# OSID, as a menu of those allowed.
#
109
echo "<tr>
110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
          <td>*Def Boot OSID:</td>";
echo "    <td><select name=\"def_boot_osid\">\n";
               while ($row = mysql_fetch_array($osid_result)) {
                  $osid = $row[osid];
		  $pid  = $row[pid];
		  if (!$pid)
		      $pid = "testbed";

                  echo "<option ";
		  if ($def_boot_osid == $osid) {
			  echo "selected ";
		  }
                  echo "value=\"$osid\">$pid - $osid</option>\n";
               }
if ($isadmin) {
    echo "<option value=\"None\">No OSID</option>\n";
}
echo "       </select>";
echo "    </td>
129 130
      </tr>\n";

131 132 133 134 135 136 137 138
echo "<tr>
          <td>Def Boot Path:</td>
          <td class=\"left\">
              <input type=\"text\" name=\"def_boot_path\" size=\"40\"
                     value=\"$def_boot_path\"></td>
      </tr>\n";


139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162
echo "<tr>
          <td>Def Boot Command Line:</td>
          <td class=\"left\">
              <input type=\"text\" name=\"def_boot_cmd_line\" size=\"40\"
                     value=\"$def_boot_cmd_line\"></td>
      </tr>\n";


echo "<tr>
          <td>Next Boot Path:</td>
          <td class=\"left\">
              <input type=\"text\" name=\"next_boot_path\" size=\"40\"
                     value=\"$next_boot_path\"></td>
      </tr>\n";


echo "<tr>
          <td>Next Boot Command Line:</td>
          <td class=\"left\">
              <input type=\"text\" name=\"next_boot_cmd_line\" size=\"40\"
                     value=\"$next_boot_cmd_line\"></td>
      </tr>\n";


163
echo "<tr>
164
          <td>Startup Command[1]:</td>
165 166
          <td class=\"left\">
              <input type=\"text\" name=\"startupcmd\" size=\"60\"
167
                     maxlength=\"256\" value=\"$startupcmd\"></td>
168 169 170
      </tr>\n";


171 172 173 174
echo "<tr>
          <td>RPMs[2]:</td>
          <td class=\"left\">
              <input type=\"text\" name=\"rpms\" size=\"60\"
175
                     maxlength=\"1024\" value=\"$rpms\"></td>
176 177
      </tr>\n";

178 179 180 181 182 183 184 185
echo "<tr>
          <td colspan=2 align=center>
              <b><input type=\"submit\" value=\"Submit\"></b>
          </td>
     </tr>
     </form>
     </table>\n";

186 187 188 189 190 191
echo "<p>
      <dl COMPACT>
        <dt> [1]
           <dd> Node startup command must be a pathname. You may also include
                optional arguments.
        <dt> [2]
192
           <dd> RPMs must be a colon separated list of pathnames.
193 194
      </dl>\n";

195 196 197 198 199
#
# Standard Testbed Footer
# 
PAGEFOOTER();
?>