Below is a small patch; it adds an extra option on the device Setting menu; which slows a list of ports - and allows the editing of the ignore flag.
This is useful on switches which are partially populated - and also makes the overview page a lot more useful.
Dw.
Index: html/includes/port-edit.inc.php
===================================================================
--- html/includes/port-edit.inc.php	(revision 0)
+++ html/includes/port-edit.inc.php	(revision 0)
@@ -0,0 +1,49 @@
+<?php
+
+# enable/disable ports/interfaces on devices.
+#
+
+$device_id=intval($_POST['device']);
+$rows_updated = 0;
+
+foreach ($_POST as $key => $val) {
+	if (strncmp($key,"oldval_",7) == 0) {
+
+		# Interface identifier passed as part of the field name
+		#
+		$interface_id = intval(substr($key,7));
+
+		$oldval = intval($val) ? 1 : 0;
+		$newval = $_POST['ignore_'.$interface_id] ? 1 : 0;
+
+		# As checkboxes are not posted when unset - we effectively need to do a diff to work
+		# out a set->unset case.
+		#
+		if ($oldval == $newval)
+			continue;
+		
+		if (!mysql_query('UPDATE `ports` SET `ignore`='.$newval.' WHERE `device_id`='.$device_id.' AND `interface_id`='.$interface_id))
+			$n = -1;
+		else
+  			$n = mysql_affected_rows();
+
+		if ($n <0) {
+			$rows_updated = -1;
+			break;
+		};
+		$rows_updated += $n;
+	};
+};
+
+  if($rows_updated > 0) {
+    $update_message =  $rows_updated . " Device record updated.";
+    $updated = 1;
+  } elseif ($rows_updated = '-1') {
+    $update_message = "Device record unchanged. No update necessary.";
+    $updated = -1;
+  } else {
+    $update_message = "Device record update error.";
+    $updated = 0;
+  }
+
+?>
Property changes on: html/includes/port-edit.inc.php
___________________________________________________________________
Added: svn:executable
   + *
Index: html/pages/device/edit.inc.php
===================================================================
--- html/pages/device/edit.inc.php	(revision 1696)
+++ html/pages/device/edit.inc.php	(working copy)
@@ -6,6 +6,7 @@
 
 
 $panes =  array('device'   => 'Device Settings',
+                'ports'     => 'Port Settings',
                 'apps'     => 'Applications',
 		'services' => 'Services');
 
Index: html/pages/device/edit/ports.inc.php
===================================================================
--- html/pages/device/edit/ports.inc.php	(revision 0)
+++ html/pages/device/edit/ports.inc.php	(revision 0)
@@ -0,0 +1,51 @@
+<?php
+
+echo('<div style="padding: 10px;">');
+
+if($_POST['ignoreport']) {
+  if($_SESSION['userlevel'] == '10') {
+    include("includes/port-edit.inc.php");
+  }
+}
+
+
+if($updated && $update_message) {
+  print_message($update_message);
+} elseif ($update_message) {
+  print_error($update_message);
+}
+
+echo("<div style='float: left;'>
+<form id='ignoreport' name='ignoreport' method='post' action=''>
+  <input type=hidden name='ignoreport' value='yes'>
+  <input type=hidden name=device value='".$device['device_id']."'>
+<table>
+<tr><th>Port</th><th>ifDescr</th><th>ifAdminStatus</th><th>ifOperStatus</th><th>Ignore</th></tr>");
+
+$query = mysql_query("SELECT * FROM `ports` WHERE device_id='".$device['device_id']."' ORDER BY `ifIndex` ");
+while($device = mysql_fetch_array($query)) {
+  echo "<tr>";
+  echo "<td align=right>". $device['ifIndex']."</td>";
+  echo "<td align=left>".$device['ifDescr'] . "</td>";
+  echo "<td align=right>". $device['ifAdminStatus']."</td>";
+
+  # Mark interfaces which are down yet not ignored, or up - yet ignored - as to draw the attention 
+  # to a possible problem.
+  #
+  $outofsync =  ($device['ignore'] == ($device['ifOperStatus'] == 'down' ? 1 : 0))  ? "" : "class=red";
+
+  echo "<td align=right><span ".$outofsync.">". $device['ifOperStatus']."</span></td>"; 
+
+  echo "<td>";
+  echo "<input type=checkbox name='ignore_".$device['interface_id']."'".($device['ignore'] ? 'checked' : '').">";
+  echo "<input type=hidden name='oldval_".$device['interface_id']."' value=".($device['ignore'] ? 1 : 0).">";
+  echo "</td>";
+  echo "</tr>";
+}
+
+echo('<tr><td></td><td></td><td></td><td></td><td><input type="submit" value="Save"></td></tr>');
+echo('</table>');
+echo('</form>');
+echo('</div>');
+
+?>