6 require_once 'plc_login.php';
8 // Get session and API handles
9 require_once 'plc_session.php';
13 require_once 'plc_drupal.php';
14 include 'plc_header.php';
17 require_once 'plc_functions.php';
18 require_once 'plc_minitabs.php';
19 require_once 'plc_tables.php';
21 // --------------------
22 // recognized URL arguments
23 $peerscope=$_GET['peerscope'];
24 $pattern=$_GET['pattern'];
25 $site_id=intval($_GET['site_id']);
26 $slice_id=intval($_GET['slice_id']);
30 $tabs["Logout"]=array('url'=>l_logout(),
31 'bubble'=>'Logout ' . $plc->person['email']);
33 // --------------------
38 // performs sanity check and summarize the result in a single column
39 function node_status ($node) {
43 // do all this stuff on local nodes only
44 if ( ! $node['peer_id'] ) {
45 // check that the node has keys
46 if (count($node['interface_ids']) == 0) {
47 $messages [] = "No interface";
50 return plc_make_table('plc-warning',$messages);
54 // fetch nodes - set pattern in the url for server-side filtering
55 $node_columns=array('hostname','node_type','site_id','node_id','boot_state','interface_ids','peer_id');
57 $node_filter['hostname']=$pattern;
58 $title .= " matching " . $pattern;
60 $node_filter['hostname']="*";
63 // server-side selection on peerscope
64 list ( $peer_filter, $peer_label) = plc_peer_info($api,$_GET['peerscope']);
65 $node_filter=array_merge($node_filter,$peer_filter);
68 $sites=$api->GetSites(array($site_id),array("name","login_base"));
71 $login_base=$site['login_base'];
72 $title .= t_site($site);
73 $tabs = array_merge($tabs,tabs_site($site));
74 $node_filter['site_id']=array($site_id);
78 $slices=$api->GetSlices(array($slice_id),array('node_ids','name'));
80 $title .= t_slice($slice);
81 $tabs = array_merge($tabs,tabs_slice($slice));
82 $node_filter['node_id'] = $slice['node_ids'];
86 $nodes=$api->GetNodes($node_filter,$node_columns);
88 // build site_ids - interface_ids
90 $interface_ids=array();
91 if ($nodes) foreach ($nodes as $node) {
92 $site_ids []= $node['site_id'];
93 $interface_ids = array_merge ($interface_ids,$node['interface_ids']);
96 // fetch related interfaces
97 $interface_columns=array('ip','node_id','interface_id');
98 $interface_filter=array('is_primary'=>TRUE,'interface_id'=>$interface_ids);
99 $interfaces=$api->GetInterfaces($interface_filter,$interface_columns);
101 $interface_hash=array();
102 foreach ($interfaces as $interface) {
103 $interface_hash[$interface['node_id']]=$interface;
106 // fetch related sites
107 $site_columns=array('site_id','login_base');
108 $site_filter=array('site_id'=>$site_ids);
109 $sites=$api->GetSites($site_filter,$site_columns);
112 foreach ($sites as $site) {
113 $site_hash[$site['site_id']]=$site;
116 // --------------------
117 drupal_set_title($title);
122 drupal_set_message ('No node found');
126 $columns = array ("Peer"=>"string",
130 "Hostname"=>"string",
137 # initial sort on hostnames
138 plc_table_start("nodes",$columns,4);
140 $peer_hash = plc_peer_get_hash ($api);
142 $fake1=1; $fake2=3.14; $fake_i=0;
143 foreach ($nodes as $node) {
144 $hostname=$node['hostname'];
145 $node_id=$node['node_id'];
146 $site_id=$node['site_id'];
147 $site=$site_hash[$site_id];
148 $login_base = $site['login_base'];
149 $node_id=$node['node_id'];
150 $ip=$interface_hash[$node['node_id']]['ip'];
151 $interface_id=$interface_hash[$node['node_id']]['interface_id'];
152 $shortname = plc_peer_shortname ($peer_hash,$node['peer_id']);
153 $node_type = $node['node_type'];
155 plc_table_row_start($hostname);
156 plc_table_cell ($shortname);
157 plc_table_cell (topdomain($hostname));
158 plc_table_cell (l_site2($site_id,$login_base));
159 plc_table_cell ($node['boot_state']);
160 plc_table_cell (l_node2($node_id,$hostname));
161 plc_table_cell (l_interface2($interface_id,$ip));
162 plc_table_cell ($node_type);
163 plc_table_cell (node_status($node));
164 plc_table_cell ($fake1);
165 plc_table_cell ($fake2);
168 if ($fake_i % 5 == 0) $fake1 += 3;
169 if ($fake_i % 3 == 0) $fake2 +=5; else $fake2 -= $fake_i;