d19e7064e43d63e90f8a97ae09b040f698358499
[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 require_once 'plc_tables.php';
20
21 // find person roles
22 $_person= $plc->person;
23 $_roles= $_person['role_ids'];
24
25 $header_js='
26 <script type="text/javascript" src="/planetlab/tablesort/tablesort.js"></script>
27 <script type="text/javascript" src="/planetlab/tablesort/customsort.js"></script>
28 <script type="text/javascript" src="/planetlab/tablesort/paginate.js"></script>
29 <script type="text/javascript" src="/planetlab/minitabs/minitabs.js"></script>
30 <script type="text/javascript" src="/planetlab/js/plc_tables.js"></script>
31 ';
32
33 $header_css='
34 <link href="/planetlab/minitabs/minitabs.css" rel="stylesheet" type="text/css" />
35 <link href="/planetlab/css/plc_style.css" rel="stylesheet" type="text/css" />
36 <link href="/planetlab/css/plc_tables.css" rel="stylesheet" type="text/css" />
37 ';
38
39 drupal_set_html_head($header_js);
40 drupal_set_html_head($header_css);
41
42 // -------------------- 
43 $pattern=$_GET['pattern'];
44 $peerscope=$_GET['peerscope'];
45
46 drupal_set_title('Nodes');
47
48 require_once 'plc_minitabs.php';
49 $minitabs=array("Old page"=>"/db/nodes/index.php",
50                "About"=>"/db/about.php",
51                "Logout"=>"/planetlab/logout.php",
52                "And others"=>"http://www.google.com",
53                "For demo"=>"/undefined");
54 plc_show_options($minitabs);
55
56 // -------------------- 
57 $peer_filter=array();
58
59 // fetch nodes - set pattern in the url for server-side filtering
60 $node_columns=array('hostname','site_id','node_id','boot_state','interface_ids','peer_id');
61 if ($pattern) {
62   $node_filter['hostname']=$pattern;
63  } else {
64   $node_filter=array('hostname'=>"*");
65  }
66
67 // server-side selection on peerscope
68 list ( $peer_filter, $peer_label) = plc_peer_info($api,$_GET['peerscope']);
69 $node_filter=array_merge($node_filter,$peer_filter);
70
71 // go
72 $nodes=$api->GetNodes($node_filter,$node_columns);
73
74 // build site_ids - interface_ids
75 $site_ids=array();
76 $interface_ids=array();
77 foreach ($nodes as $node) {
78   $site_ids []= $node['site_id'];
79   $interface_ids = array_merge ($interface_ids,$node['interface_ids']);
80 }
81
82 // fetch related interfaces
83 $interface_columns=array('ip','node_id','interface_id');
84 $interface_filter=array('is_primary'=>TRUE,'interface_id'=>$interface_ids);
85 $interfaces=$api->GetInterfaces($interface_filter,$interface_columns);
86
87 $interface_hash=array();
88 foreach ($interfaces as $interface) {
89     $interface_hash[$interface['node_id']]=$interface;
90 }
91
92 // fetch related sites
93 $site_columns=array('site_id','login_base');
94 $site_filter=array('site_id'=>$site_ids);
95 $sites=$api->GetSites($site_filter,$site_columns);
96
97 $site_hash=array();
98 foreach ($sites as $site) {
99     $site_hash[$site['site_id']]=$site;
100 }
101
102 // fetch peers
103 $peer_columns=array('peer_id','shortname');
104 $peer_filter=array();
105 $peers = $api->GetPeers($peer_filter,$peer_columns);
106
107 $peer_hash=array();
108 foreach ($peers as $peer) {
109     $peer_hash[$peer['peer_id']]=$peer;
110 }
111
112 ?>
113
114 <?php
115 $tablesize=25;
116 plc_table_header("nodes",$tablesize,999);
117 ?>
118
119 <!------------------------------------------------------------>
120 <!-- instantiate generic mechanisms for nodes -->
121 <script type"text/javascript">
122 function nodes_paginator (opts) {
123   plc_table_paginator (opts,"nodes");
124 }
125 </script>
126
127 <br/>
128 <!------------------------------------------------------------>
129 <!------------------------------------------------------------>
130 <table id="nodes" cellpadding="0" cellspacing="0" border="0" 
131 class="plc_table sortable-onload-4 rowstyle-alt colstyle-alt no-arrow paginationcallback-nodes_paginator max-pages-15 paginate-<?php print $tablesize; ?>">
132 <thead>
133 <tr>
134 <th class="sortable plc_table">Peer</th>
135 <th class="sortable plc_table">Region</th>
136 <th class="sortable plc_table">Site</th>
137 <th class="sortable plc_table">State</th>
138 <th class="sortable plc_table">Hostname</th>
139 <th class="sortable-sortIPAddress plc_table">IP</th>
140 <th class="sortable plc_table">Load</th>
141 <th class="sortable plc_table">Avg Load</th>
142 </tr>
143 </thead>
144 <tbody>
145
146 <?php
147
148   $fake1=1; $fake2=3.14; $fake_i=0;
149 foreach ($nodes as $node) {
150     $hostname=$node['hostname'];
151     $node_id=$node['node_id'];
152     $site_id=$node['site_id'];
153     $site=$site_hash[$site_id];
154     $login_base = $site['login_base'];
155     $node_id=$node['node_id'];
156     $ip=$interface_hash[$node['node_id']]['ip'];
157     $interface_id=$interface_hash[$node['node_id']]['interface_id'];
158     if ( ! $node['peer_id'] ) {
159       $shortname="local";
160     } else {
161       $shortname=$peer_hash[$node['peer_id']]['shortname'];
162     }
163     printf ('<tr id="%s">',$hostname);
164     printf ('<td class="plc_table"> %s </td>',$shortname);
165     printf ('<td class="plc_table"> %s </td>',topdomain($hostname));
166     printf ('<td class="plc_table"> <a href="/db/sites/index.php?id=%s">%s</a></td>',$site_id,$login_base);
167     printf ('<td class="plc_table"> %s </td>',$node['boot_state']);
168     printf ('<td class="plc_table"> <a href="/db/nodes/index.php?id=%s">%s</a></td>',$node_id,$hostname);
169     printf ('<td class="plc_table"> <a href="/db/nodes/interfaces.php?id=%s">%s</a></td>', $interface_id,$ip);
170     printf ('<td class="plc_table"> %s </td>', $fake1);
171     printf ('<td class="plc_table"> %s </td>', $fake2);
172     printf ( '</tr>');
173                                  
174     if ($fake_i % 5 == 0) $fake1 += 3; 
175     if ($fake_i % 3 == 0) $fake2 +=5; else $fake2 -= $fake_i;
176     $fake_i += 1;
177 }
178
179 ?>
180 </tbody>
181 <tfoot>
182 </tfoot>
183 </table>
184
185 <p class='plc_filter_note'> 
186 Notes: Enter & or | in the search area to alternate between <bold>AND</bold> and <bold>OR</bold> search modes
187 <br/> 
188 Hold down the shift key to select multiple columns to sort 
189 </p>