the basics for client-side filtering + a few tweaks
[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 $unused='
46 <script type="text/javascript" src="/planetlab/tablesort/more.js"></script>
47 <link href="/planetlab/css/more.css" rel="stylesheet" type="text/css" />
48 <body OnLoad="init();">
49 ';
50
51 drupal_set_html_head($header_autocomplete_js);
52 drupal_set_html_head($header_tablesort_js);
53 drupal_set_html_head($header_tablesort_css);
54
55 $nodepattern=$_GET['nodepattern'];
56 $peerscope=$_GET['peerscope'];
57 $tablesize=$_GET['tablesize'];
58 if (empty($tablesize)) $tablesize=25;
59
60 ?>
61
62 <script type"text/javascript">
63 function nodesTextInfo (opts) {
64   displayTextInfo (opts,"nodes");
65 }
66 </script>
67
68 <div class="plc_filter">
69 <form method=get action='newindex.php'>
70 <table>
71
72 <tr>
73 <th><label for='peerscope'>Federation scope </label></th>
74 <td colspan=2><select id='peerscope' name='peerscope' onChange='submit()'>
75 <?php echo plc_peers_option_list($api); ?>
76 </select></td>
77 </tr>
78
79 <tr>
80 <th><label for='nodepattern'>Hostname (server-side pattern)</label></th>
81 <td><input type='text' id='nodepattern' name='nodepattern' 
82      size=40 value='<?php print $nodepattern; ?>'/></td>
83 <td><input type=submit value='Go' /></td>
84 </tr> 
85
86 <tr> 
87 <th><label for='tablesize'>Table size</label></th>
88 <td> <input type='text' id='tablesize' name='tablesize' 
89       size=3 value='<?php print $tablesize; ?>'/></td>
90 <td><input type=submit value='Go' /> </td>
91 </tr>
92 </table>
93 </form>
94 </div>
95
96 <script type="text/javascript">
97 var options = {
98         script:"/planetlab/nodes/test.php?",
99         varname:"input",
100         minchars:1
101 };
102 var as = new AutoSuggest('nodepattern', options);
103 </script>
104
105
106 <?php
107
108 $peer_filter=array();
109
110 // fetch nodes
111 $node_columns=array('hostname','site_id','node_id','boot_state','interface_ids');
112 if ($nodepattern) {
113   $node_filter['hostname']=$nodepattern;
114  } else {
115   $node_filter=array('hostname'=>"*");
116  }
117
118 // peerscope
119 list ( $peer_filter, $peer_label) = plc_peer_info($api,$_GET['peerscope']);
120 $node_filter=array_merge($node_filter,$peer_filter);
121
122 $nodes=$api->GetNodes($node_filter,$node_columns);
123
124 // build site_ids and interface_ids 
125 $site_ids=array();
126 $interface_ids=array();
127 foreach ($nodes as $node) {
128   $site_ids []= $node['site_id'];
129   $interface_ids = array_merge ($interface_ids,$node['interface_ids']);
130 }
131
132 // fetch related interfaces
133 $interface_columns=array('ip','node_id','interface_id');
134 $interface_filter=array('is_primary'=>TRUE,'interface_id'=>$interface_ids);
135 $interfaces=$api->GetInterfaces($interface_filter,$interface_columns);
136
137 $interface_hash=array();
138 foreach ($interfaces as $interface) {
139     $interface_hash[$interface['node_id']]=$interface;
140 }
141
142 // fetch related sites
143 $site_columns=array('site_id','login_base');
144 $site_filter=array('site_id'=>$site_ids);
145 $sites=$api->GetSites($site_filter,$site_columns);
146
147 $site_hash=array();
148 foreach ($sites as $site) {
149     $site_hash[$site['site_id']]=$site;
150 }
151
152 ?>
153
154 <div id='tmp'>
155   <form> 
156   <label> client-side pattern </label> 
157     <input type='text' id='filter_text' size=15 onchange='plc_filter_table("nodes","filter_text");'/>
158   <input type='button' name='tmpbutton' value='click' onclick='plc_filter_table("nodes","filter_text");' />
159 </form>
160 </div>
161
162 <div class="fdtablePaginaterWrap" id="nodes-fdtablePaginaterWrapTop"><p></p></div>
163
164 <table id="nodes" cellpadding="0" cellspacing="0" border="0" 
165 class="plc_table sortable-onload-3r rowstyle-alt colstyle-alt no-arrow paginationcallback-nodesTextInfo max-pages-15 paginate-<?php print $tablesize; ?>">
166 <thead>
167 <tr>
168 <th class="sortable plc_table">State</th>
169 <th class="sortable plc_table">Hostname</th>
170 <th class="sortable plc_table">Site</th>
171 <th class="sortable plc_table">Region</th>
172 <th class="sortable-sortIPAddress plc_table">IP</th>
173 <th class="sortable plc_table">Load</th>
174 <th class="sortable plc_table">Avg Load</th>
175 </tr>
176 </thead>
177 <tbody>
178
179 <?php
180
181   $fake1=1; $fake2=3.14;
182 foreach ($nodes as $node) {
183     $hostname=$node['hostname'];
184     $node_id=$node['node_id'];
185     $site_id=$node['site_id'];
186     $site=$site_hash[$site_id];
187     $login_base = $site['login_base'];
188     $node_id=$node['node_id'];
189     $ip=$interface_hash[$node['node_id']]['ip'];
190     $interface_id=$interface_hash[$node['node_id']]['interface_id'];
191     printf ('<tr id="%s">',$hostname);
192     printf ('<td class="plc_table"> %s </td>',$node['boot_state']);
193     printf ('<td class="plc_table"> <a href="/db/nodes/index.php?id=%s">%s</a></td>',$node_id,$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>',topdomain($hostname));
196     printf ('<td class="plc_table"> <a href="/db/nodes/interfaces.php?id=%s">%s</a></td>', $interface_id,$ip);
197     printf ('<td class="plc_table"> %s </td>', $fake1);
198     printf ('<td class="plc_table"> %s </td>', $fake2);
199     printf ( '</tr>');
200     $fake1 += 3;
201     $fake2 += 2;
202 }
203
204 ?>
205 </tbody>
206 <tfoot>
207 </tfoot>
208 </table>
209
210 <div class="fdtablePaginaterWrap" id="nodes-fdtablePaginaterWrapBottom"><p></p></div>
211