* nodes page looks good, going generic
[plewww.git] / planetlab / nodes / newindex.php
1 <?php
2
3 // $Id$
4
5 // Require login
6 require_once 'plc_login.php';
7
8 // Get session and API handles
9 require_once 'plc_session.php';
10 global $plc, $api, $adm;
11
12 // Print header
13 require_once 'plc_drupal.php';
14 include 'plc_header.php';
15
16 // Common functions
17 require_once 'plc_functions.php';
18 require_once 'plc_sorts.php';
19
20 // find person roles
21 $_person= $plc->person;
22 $_roles= $_person['role_ids'];
23
24 $header_tablesort_js='
25 <script type="text/javascript" src="/planetlab/tablesort/tablesort.js"></script>
26 <script type="text/javascript" src="/planetlab/tablesort/customsort.js"></script>
27 <script type="text/javascript" src="/planetlab/tablesort/paginate.js"></script>
28 <script type="text/javascript" src="/planetlab/js/plc_paginate.js"></script>
29 <script type="text/javascript" src="/planetlab/js/plc_filter.js"></script>
30 ';
31
32 $header_tablesort_css='
33 <link href="/planetlab/css/plc_style.css" rel="stylesheet" type="text/css" />
34 <link href="/planetlab/css/plc_table.css" rel="stylesheet" type="text/css" />
35 <link href="/planetlab/css/plc_paginate.css" rel="stylesheet" type="text/css" />
36 ';
37
38 drupal_set_html_head($header_tablesort_js);
39 drupal_set_html_head($header_tablesort_css);
40
41 // -------------------- 
42 $nodepattern=$_GET['nodepattern'];
43 $peerscope=$_GET['peerscope'];
44 $tablesize=25;
45
46 ?>
47
48 <!------------------------------------------------------------>
49 <?php
50
51 $peer_filter=array();
52
53 // fetch nodes - use nodepattern for server-side filtering
54 $node_columns=array('hostname','site_id','node_id','boot_state','interface_ids','peer_id');
55 if ($nodepattern) {
56   $node_filter['hostname']=$nodepattern;
57  } else {
58   $node_filter=array('hostname'=>"*");
59  }
60
61 // server-side selection on peerscope
62 list ( $peer_filter, $peer_label) = plc_peer_info($api,$_GET['peerscope']);
63 $node_filter=array_merge($node_filter,$peer_filter);
64
65 $title='Nodes';
66 if ($nodepattern) {
67   $title .= " matching " . $nodepattern;
68  }
69 $title .= ' (' . $peer_label . ')';
70 drupal_set_title($title);
71
72 // go
73 $nodes=$api->GetNodes($node_filter,$node_columns);
74
75 // build site_ids - interface_ids
76 $site_ids=array();
77 $interface_ids=array();
78 foreach ($nodes as $node) {
79   $site_ids []= $node['site_id'];
80   $interface_ids = array_merge ($interface_ids,$node['interface_ids']);
81 }
82
83 // fetch related interfaces
84 $interface_columns=array('ip','node_id','interface_id');
85 $interface_filter=array('is_primary'=>TRUE,'interface_id'=>$interface_ids);
86 $interfaces=$api->GetInterfaces($interface_filter,$interface_columns);
87
88 $interface_hash=array();
89 foreach ($interfaces as $interface) {
90     $interface_hash[$interface['node_id']]=$interface;
91 }
92
93 // fetch related sites
94 $site_columns=array('site_id','login_base');
95 $site_filter=array('site_id'=>$site_ids);
96 $sites=$api->GetSites($site_filter,$site_columns);
97
98 $site_hash=array();
99 foreach ($sites as $site) {
100     $site_hash[$site['site_id']]=$site;
101 }
102
103 // fetch peers
104 $peer_columns=array('peer_id','shortname');
105 $peer_filter=array();
106 $peers = $api->GetPeers($peer_filter,$peer_columns);
107
108 $peer_hash=array();
109 foreach ($peers as $peer) {
110     $peer_hash[$peer['peer_id']]=$peer;
111 }
112
113 ?>
114
115 <!------------------------------------------------------------>
116 <!-- instantiate generic mechanisms for nodes -->
117 <script type"text/javascript">
118 function nodes_paginator (opts) {
119   plc_table_paginator (opts,"nodes");
120 }
121 function nodes_filter () {
122   plc_table_filter("nodes","search_text","nodes_and");
123 }
124 </script>
125
126 <!------------------------------------------------------------>
127 <table class='table_dialogs'> <tr>
128 <td class='table_flushleft'>
129 <form class='table_size'>
130   <input class='table_size_input' type='text' id='tablesize_text' value="<?php echo $tablesize; ?>" 
131   onkeyup='plc_table_setsize("nodes","tablesize_text", "<?php echo $tablesize; ?>" );' 
132   size=3 maxlength=3 /> 
133   <label class='table_size_label'> Items per page </label>   
134   <img class='table_reset' src="/planetlab/icons/clear.png" 
135     onmousedown='plc_table_size_reset("nodes","tablesize_text","999");'>
136 </form>
137 </td>
138
139 <td class='table_flushright'> 
140 <form class='table_search'>
141   <label class='table_search_label'> Search </label> 
142   <input class='table_search_input' type='text' id='search_text'
143      onkeyup='nodes_filter();'
144   size=40 maxlength=256 />
145   <label>and</label>
146   <input id='nodes_and' class='table_search_and' 
147     type='checkbox' checked='checked' onchange='nodes_filter();' />
148   <img class='table_reset' src="/planetlab/icons/clear.png" 
149   onmousedown='plc_table_filter_reset("nodes","search_text");'>
150 </form>
151 </td>
152 </tr></table>
153
154 <!------------------------------------------------------------>
155 <!-- <div class="fdtablePaginaterWrap" id="nodes-fdtablePaginaterWrapTop"><p></p></div> -->
156
157 <!------------------------------------------------------------>
158 <table id="nodes" cellpadding="0" cellspacing="0" border="0" 
159 class="plc_table sortable-onload-4 rowstyle-alt colstyle-alt no-arrow paginationcallback-nodes_paginator max-pages-15 paginate-<?php print $tablesize; ?>">
160 <thead>
161 <tr>
162 <th class="sortable plc_table">Peer</th>
163 <th class="sortable plc_table">Region</th>
164 <th class="sortable plc_table">Site</th>
165 <th class="sortable plc_table">State</th>
166 <th class="sortable plc_table">Hostname</th>
167 <th class="sortable-sortIPAddress plc_table">IP</th>
168 <th class="sortable plc_table">Load</th>
169 <th class="sortable plc_table">Avg Load</th>
170 </tr>
171 </thead>
172 <tbody>
173
174 <?php
175
176   $fake1=1; $fake2=3.14; $fake_i=0;
177 foreach ($nodes as $node) {
178     $hostname=$node['hostname'];
179     $node_id=$node['node_id'];
180     $site_id=$node['site_id'];
181     $site=$site_hash[$site_id];
182     $login_base = $site['login_base'];
183     $node_id=$node['node_id'];
184     $ip=$interface_hash[$node['node_id']]['ip'];
185     $interface_id=$interface_hash[$node['node_id']]['interface_id'];
186     if ( ! $node['peer_id'] ) {
187       $shortname="local";
188     } else {
189       $shortname=$peer_hash[$node['peer_id']]['shortname'];
190     }
191     printf ('<tr id="%s">',$hostname);
192     printf ('<td class="plc_table"> %s </td>',$shortname);
193     printf ('<td class="plc_table"> %s </td>',topdomain($hostname));
194     printf ('<td class="plc_table"> <a href="/db/sites/index.php?id=%s">%s</a></td>',$site_id,$login_base);
195     printf ('<td class="plc_table"> %s </td>',$node['boot_state']);
196     printf ('<td class="plc_table"> <a href="/db/nodes/index.php?id=%s">%s</a></td>',$node_id,$hostname);
197     printf ('<td class="plc_table"> <a href="/db/nodes/interfaces.php?id=%s">%s</a></td>', $interface_id,$ip);
198     printf ('<td class="plc_table"> %s </td>', $fake1);
199     printf ('<td class="plc_table"> %s </td>', $fake2);
200     printf ( '</tr>');
201                                  
202     if ($fake_i % 5 == 0) $fake1 += 3; 
203     if ($fake_i % 3 == 0) $fake2 +=5; else $fake2 -= $fake_i;
204     $fake_i += 1;
205 }
206
207 ?>
208 </tbody>
209 <tfoot>
210 </tfoot>
211 </table>
212
213 <!-- <div class="fdtablePaginaterWrap" id="nodes-fdtablePaginaterWrapBottom"><p></p></div> -->
214
215 <p class='plc_filter_note'> 
216 Notes: Enter & or | in the search area to alternate between <bold>AND</bold> and <bold>OR</bold> search modes
217 <br/> 
218 Hold down the shift key to select multiple columns to sort 
219 </p>
220