// Common functions
require_once 'plc_functions.php';
require_once 'plc_peers.php';
-require_once 'plc_minitabs.php';
-require_once 'plc_tables.php';
+require_once 'linetabs.php';
+require_once 'table.php';
+require_once 'nifty.php';
+
+ini_set("memory_limit","48M");
// --------------------
// recognized URL arguments
// --- decoration
$title="Nodes";
$tabs=array();
-$mysite_id=plc_my_site_id();
-$tabs['My nodes'] = array('url'=>l_nodes(),
- 'values'=>array('site_id'=>plc_my_site_id()),
- 'bubble'=>'Lists nodes on site ' . $mysite_id);
+$tabs []= tab_nodes_mysite();
+$tabs []= tab_nodes_local();
+
// --------------------
$node_filter=array();
// performs sanity check and summarize the result in a single column
function node_status ($node) {
- $messages=array();
-
// do all this stuff on local nodes only
- if ( ! $node['peer_id'] ) {
- // check that the node has keys
- if (count($node['interface_ids']) == 0) {
- $messages [] = "No interface";
- }
+ if ( $node['peer_id'] )
+ return "n/a";
+
+ $messages=array();
+ // check that the node has interfaces
+ if (count($node['interface_ids']) == 0) {
+ $messages [] = "No interface";
}
return plc_vertical_table($messages,'plc-warning');
}
// fetch nodes
-$node_columns=array('hostname','node_type','site_id','node_id','boot_state','interface_ids','peer_id', "arch");
+$node_columns=array('hostname','node_type','site_id','node_id','boot_state','interface_ids','peer_id', 'arch','slice_ids');
// server-side filtering - set pattern in $_GET for filtering on hostname
if ($pattern) {
$node_filter['hostname']=$pattern;
$title .= ' - ' . $peerscope->label();
if ($site_id) {
- $sites=$api->GetSites(array($site_id),array("name","login_base"));
+ $sites=$api->GetSites(array($site_id));
$site=$sites[0];
$name=$site['name'];
$login_base=$site['login_base'];
$title .= t_site($site);
- $tabs = array_merge($tabs,tabs_site($site));
+ $tabs []= tab_site($site);
$node_filter['site_id']=array($site_id);
}
$slices=$api->GetSlices(array($slice_id),array('node_ids','name'));
$slice=$slices[0];
$title .= t_slice($slice);
- $tabs = array_merge($tabs,tabs_slice($slice));
+ $tabs []= tab_slice($slice);
$node_filter['node_id'] = $slice['node_ids'];
}
// --------------------
drupal_set_title($title);
-plc_tabs($tabs);
+plekit_linetabs($tabs);
if ( ! $nodes ) {
drupal_set_message ('No node found');
return;
}
-$headers = array ("Peer"=>"string",
- "Region"=>"string",
- "Site"=>"string",
- "State"=>"string",
- "Hostname"=>"string",
- "IP"=>"IPAddress",
- "Type"=>"string",
- "Arch"=>"string",
- "?"=>"string",
- );
+$nifty=new PlekitNifty ('','objects-list','big');
+$nifty->start();
+$headers = array ();
+$headers["P"]="string";
+$headers["R"]="string";
+$headers["Site"]="string";
+$headers["State"]="string";
+$headers["Hostname"]="string";
+$headers["Type"]="string";
+$headers["IP"]="IPAddress";
+$headers["A"]="string";
+$headers["S"]='int';
+if (plc_is_admin()) $headers["I"]="int";
+$headers["?"]="string";
# initial sort on hostnames
-plc_table_start("nodes",$headers,4);
+$table=new PlekitTable ("nodes",$headers,4);
+$table->start();
$peers = new Peers ($api);
// write rows
foreach ($nodes as $node) {
- $hostname=$node['hostname'];
- $node_id=$node['node_id'];
- $site_id=$node['site_id'];
- $site=$site_hash[$site_id];
- $login_base = $site['login_base'];
- $node_id=$node['node_id'];
- $ip=$interface_hash[$node['node_id']]['ip'];
- $interface_id=$interface_hash[$node['node_id']]['interface_id'];
- $peer_id=$node['peer_id'];
- $shortname = $peers->shortname($peer_id);
- $node_type = $node['node_type'];
-
- plc_table_row_start();
- plc_table_cell ($peers->link($peer_id,$shortname));
- plc_table_cell (topdomain($hostname));
- plc_table_cell (l_site_t($site_id,$login_base));
- plc_table_cell ($node['boot_state']);
- plc_table_cell (l_node_t($node_id,$hostname));
- plc_table_cell (l_interface_t($interface_id,$ip));
- plc_table_cell ($node_type);
- plc_table_cell ($node['arch']);
- plc_table_cell (node_status($node));
- plc_table_row_end();
-
+ $hostname=$node['hostname'];
+ $node_id=$node['node_id'];
+ $site_id=$node['site_id'];
+ $site=$site_hash[$site_id];
+ $login_base = $site['login_base'];
+ $ip=$interface_hash[$node['node_id']]['ip'];
+ $interface_id=$interface_hash[$node['node_id']]['interface_id'];
+ $peer_id=$node['peer_id'];
+ $node_type = $node['node_type'];
+
+ $table->row_start();
+ $peers->cell ($table,$peer_id);
+ $table->cell (topdomain($hostname));
+ $table->cell (l_site_t($site_id,$login_base));
+ $table->cell ($node['boot_state']);
+ $table->cell (l_node_t($node_id,$hostname));
+ $table->cell ($node_type);
+ $table->cell (l_interface_t($interface_id,$ip),array('only-if'=> !$peer_id));
+ $table->cell ($node['arch'],array('only-if'=> !$peer_id));
+ $table->cell (count($node['slice_ids']));
+ if (plc_is_admin()) $table->cell(l_node_t($node_id,$node_id));
+ $table->cell (node_status($node));
+ $table->row_end();
+
}
-plc_table_end("nodes");
+$notes=array();
+$notes []= "R = region";
+$notes []= "A = arch";
+$notes []= "S = number of slivers";
+if (plc_is_admin()) $notes []= "I = node_id";
+$table->end(array('notes'=>$notes));
+$nifty->end();
+
+//plekit_linetabs ($tabs,"bottom");
// Print footer
include 'plc_footer.php';