6c215fb56199243347731dae4328159dc0f6f891
[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 drupal_set_title('Nodes');
15 include 'plc_header.php';
16
17 // Common functions
18 require_once 'plc_functions.php';
19 require_once 'plc_sorts.php';
20
21 // find person roles
22 $_person= $plc->person;
23 $_roles= $_person['role_ids'];
24
25 $header_autocomplete_js='
26 <script type="text/javascript" src="/planetlab/bsn/bsn.Ajax.js"></script>
27 <script type="text/javascript" src="/planetlab/bsn/bsn.DOM.js"></script>
28 <script type="text/javascript" src="/planetlab/bsn/bsn.AutoSuggest.js"></script>
29 ';
30
31 $header_tablesort_js='
32 <script type="text/javascript" src="/planetlab/tablesort/tablesort.js"></script>
33 <script type="text/javascript" src="/planetlab/tablesort/customsort.js"></script>
34 <script type="text/javascript" src="/planetlab/tablesort/paginate.js"></script>
35 <script type="text/javascript" src="/planetlab/js/plc_paginate.js"></script>
36 <script type="text/javascript" src="/planetlab/js/plc_filter.js"></script>
37 ';
38
39 $header_tablesort_css='
40 <link href="/planetlab/css/plc_style.css" rel="stylesheet" type="text/css" />
41 <link href="/planetlab/css/plc_table.css" rel="stylesheet" type="text/css" />
42 <link href="/planetlab/css/plc_paginate.css" rel="stylesheet" type="text/css" />
43 ';
44
45 drupal_set_html_head($header_autocomplete_js);
46 drupal_set_html_head($header_tablesort_js);
47 drupal_set_html_head($header_tablesort_css);
48
49 // -------------------- 
50 $nodepattern=$_GET['nodepattern'];
51 $peerscope=$_GET['peerscope'];
52 $tablesize=25;
53
54 ?>
55
56 <!------------------------------------------------------------>
57 <?php
58
59 $peer_filter=array();
60
61 // fetch nodes - use nodepattern for server-side filtering
62 $node_columns=array('hostname','site_id','node_id','boot_state','interface_ids','peer_id');
63 if ($nodepattern) {
64   $node_filter['hostname']=$nodepattern;
65  } else {
66   $node_filter=array('hostname'=>"*");
67  }
68
69 // server-side selection on peerscope
70 list ( $peer_filter, $peer_label) = plc_peer_info($api,$_GET['peerscope']);
71 $node_filter=array_merge($node_filter,$peer_filter);
72
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 <table class='table_dialogs'> <tr>
117 <td class='table_flushleft'>
118 <form class='table_size'>
119   <input class='table_size_input' type='text' id='tablesize_text' value="<?php echo $tablesize; ?>" 
120   onkeyup='plc_table_setsize("nodes","tablesize_text", "<?php echo $tablesize; ?>" );' 
121   size=3 maxlength=3 /> 
122   <label class='table_size_label'> items per page </label>   
123   <img class='table_reset' src="/planetlab/icons/clear.png" 
124     onmousedown='plc_table_size_reset("nodes","tablesize_text","999");'>
125 </form>
126 </td>
127
128 <td class='table_flushright'> 
129 <form class='table_search'>
130   <label class='table_search_label'> search </label> 
131   <input class='table_search_input' type='text' id='search_text'
132   onkeyup='plc_table_filter("nodes","search_text");'
133   size=40 maxlength=256 />
134   <img class='table_reset' src="/planetlab/icons/clear.png" 
135   onmousedown='plc_table_filter_reset("nodes","search_text");'>
136 </form>
137 </td>
138 </tr></table>
139
140 <!------------------------------------------------------------>
141 <div class="fdtablePaginaterWrap" id="nodes-fdtablePaginaterWrapTop"><p></p></div>
142
143 <!------------------------------------------------------------>
144 <table id="nodes" cellpadding="0" cellspacing="0" border="0" 
145 class="plc_table sortable-onload-4 rowstyle-alt colstyle-alt no-arrow paginationcallback-nodesTextInfo max-pages-15 paginate-<?php print $tablesize; ?>">
146 <thead>
147 <tr>
148 <th class="sortable plc_table">Peer</th>
149 <th class="sortable plc_table">Region</th>
150 <th class="sortable plc_table">Site</th>
151 <th class="sortable plc_table">State</th>
152 <th class="sortable plc_table">Hostname</th>
153 <th class="sortable-sortIPAddress plc_table">IP</th>
154 <th class="sortable plc_table">Load</th>
155 <th class="sortable plc_table">Avg Load</th>
156 </tr>
157 </thead>
158 <tbody>
159
160 <?php
161
162   $fake1=1; $fake2=3.14; $fake_i=0;
163 foreach ($nodes as $node) {
164     $hostname=$node['hostname'];
165     $node_id=$node['node_id'];
166     $site_id=$node['site_id'];
167     $site=$site_hash[$site_id];
168     $login_base = $site['login_base'];
169     $node_id=$node['node_id'];
170     $ip=$interface_hash[$node['node_id']]['ip'];
171     $interface_id=$interface_hash[$node['node_id']]['interface_id'];
172     if ( ! $node['peer_id'] ) {
173       $shortname="local";
174     } else {
175       $shortname=$peer_hash[$node['peer_id']]['shortname'];
176     }
177     printf ('<tr id="%s">',$hostname);
178     printf ('<td class="plc_table"> %s </td>',$shortname);
179     printf ('<td class="plc_table"> %s </td>',topdomain($hostname));
180     printf ('<td class="plc_table"> <a href="/db/sites/index.php?id=%s">%s</a></td>',$site_id,$login_base);
181     printf ('<td class="plc_table"> %s </td>',$node['boot_state']);
182     printf ('<td class="plc_table"> <a href="/db/nodes/index.php?id=%s">%s</a></td>',$node_id,$hostname);
183     printf ('<td class="plc_table"> <a href="/db/nodes/interfaces.php?id=%s">%s</a></td>', $interface_id,$ip);
184     printf ('<td class="plc_table"> %s </td>', $fake1);
185     printf ('<td class="plc_table"> %s </td>', $fake2);
186     printf ( '</tr>');
187                                  
188     if ($fake_i % 5 == 0) $fake1 += 3; 
189     if ($fake_i % 3 == 0) $fake2 +=5; else $fake2 -= $fake_i;
190     $fake_i += 1;
191 }
192
193 ?>
194 </tbody>
195 <tfoot>
196 </tfoot>
197 </table>
198
199 <div class="fdtablePaginaterWrap" id="nodes-fdtablePaginaterWrapBottom"><p></p></div>
200
201 <p class='plc_filter_note'> 
202 Notes: Several words in pattern are combined with <em> OR </em>
203 <br/> 
204 Hold down the shift key to select multiple columns to sort 
205 </p>
206
207 <!------------------------------------------------------------>
208 <hr>
209 <hr>
210 <p> This section is for trying out server-side filtering </p>
211 <hr>
212 <hr>
213
214 <script type"text/javascript">
215  /* instantiate generic mechanisms for nodes */
216 function nodesTextInfo (opts) {
217   plc_table_update_paginaters (opts,"nodes");
218 }
219 var options = {
220         script:"/planetlab/nodes/test.php?",
221         varname:"input",
222         minchars:1
223 };
224 var as = new AutoSuggest('nodepattern', options);
225 </script>
226
227 <!------------------------------------------------------------>
228 <div class="plc_filter">
229 <form method='get' id='filter_nodes'>
230 <table>
231
232 <tr>
233 <th><label for='peerscope'>Federation scope </label></th>
234 <td colspan=2><select id='peerscope' name='peerscope' onChange='submit()'>
235 <?php echo plc_peers_option_list($api); ?>
236 </select></td>
237 </tr>
238
239 <tr>
240 <th><label for='nodepattern'>Hostname (server-side pattern)</label></th>
241 <td><input type='text' id='nodepattern' name='nodepattern' 
242      size=40 value='<?php print $nodepattern; ?>'/></td>
243 <td><input id='go' rowspan=2 type=submit value='Go' /></td>
244 </tr> 
245
246 <tr> 
247 <th><label for='tablesize'>Table size</label></th>
248 <td> <input type='text' id='tablesize' name='tablesize' 
249       size=3 value='<?php print $tablesize; ?>'/></td>
250 </tr>
251 </table>
252 </form>
253 </div>
254
255 <!-- trash -->
256 <script type="text/javascript">
257   function foo () {
258       var tbody=document.getElementById("nodes").getElementsByTagName("tbody")[0];
259       alert ('current classname = [' + tbody.className + "]");
260     }
261 </script>
262
263 <hr>
264 <form> <input type='button' onclick="foo()" value='debug classname'> </form>
265