6 require_once 'plc_login.php';
8 // Get session and API handles
9 require_once 'plc_session.php';
10 global $plc, $api, $adm;
13 require_once 'plc_drupal.php';
14 include 'plc_header.php';
17 require_once 'plc_functions.php';
18 require_once 'plc_sorts.php';
21 $_person= $plc->person;
22 $_roles= $_person['role_ids'];
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/minitab/minitab.js"></script>
29 <script type="text/javascript" src="/planetlab/js/plc_paginate.js"></script>
30 <script type="text/javascript" src="/planetlab/js/plc_filter.js"></script>
33 $header_tablesort_css='
34 <link href="/planetlab/minitab/minitab.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_table.css" rel="stylesheet" type="text/css" />
37 <link href="/planetlab/css/plc_paginate.css" rel="stylesheet" type="text/css" />
40 drupal_set_html_head($header_tablesort_js);
41 drupal_set_html_head($header_tablesort_css);
43 // --------------------
44 $nodepattern=$_GET['nodepattern'];
45 $peerscope=$_GET['peerscope'];
48 drupal_set_title('Nodes');
54 <li class='minitab'><a href="/db/nodes/index.php" title="">Old page</a></li>
55 <li class='minitab'><a href="/db/about.php" title="">About</a></li>
56 <li class='minitab'><a href="/planetlab/logout.php" title="">Log out</a></li>
57 <li class='minitab'><a href="http://www.google.com/" title="">Google</a></li>
58 <li class='minitab'><a href="/undefined/" title="">Other stuff</a></li>
63 <!------------------------------------------------------------>
68 // fetch nodes - use nodepattern for server-side filtering
69 $node_columns=array('hostname','site_id','node_id','boot_state','interface_ids','peer_id');
71 $node_filter['hostname']=$nodepattern;
73 $node_filter=array('hostname'=>"*");
76 // server-side selection on peerscope
77 list ( $peer_filter, $peer_label) = plc_peer_info($api,$_GET['peerscope']);
78 $node_filter=array_merge($node_filter,$peer_filter);
81 $nodes=$api->GetNodes($node_filter,$node_columns);
83 // build site_ids - interface_ids
85 $interface_ids=array();
86 foreach ($nodes as $node) {
87 $site_ids []= $node['site_id'];
88 $interface_ids = array_merge ($interface_ids,$node['interface_ids']);
91 // fetch related interfaces
92 $interface_columns=array('ip','node_id','interface_id');
93 $interface_filter=array('is_primary'=>TRUE,'interface_id'=>$interface_ids);
94 $interfaces=$api->GetInterfaces($interface_filter,$interface_columns);
96 $interface_hash=array();
97 foreach ($interfaces as $interface) {
98 $interface_hash[$interface['node_id']]=$interface;
101 // fetch related sites
102 $site_columns=array('site_id','login_base');
103 $site_filter=array('site_id'=>$site_ids);
104 $sites=$api->GetSites($site_filter,$site_columns);
107 foreach ($sites as $site) {
108 $site_hash[$site['site_id']]=$site;
112 $peer_columns=array('peer_id','shortname');
113 $peer_filter=array();
114 $peers = $api->GetPeers($peer_filter,$peer_columns);
117 foreach ($peers as $peer) {
118 $peer_hash[$peer['peer_id']]=$peer;
123 <!------------------------------------------------------------>
124 <!-- instantiate generic mechanisms for nodes -->
125 <script type"text/javascript">
126 function nodes_paginator (opts) {
127 plc_table_paginator (opts,"nodes");
129 function nodes_filter () {
130 plc_table_filter("nodes","search_text","nodes_and");
135 <!------------------------------------------------------------>
136 <table class='table_dialogs'> <tr>
137 <td class='table_flushleft'>
138 <form class='table_size'>
139 <input class='table_size_input' type='text' id='tablesize_text' value="<?php echo $tablesize; ?>"
140 onkeyup='plc_table_setsize("nodes","tablesize_text", "<?php echo $tablesize; ?>" );'
141 size=3 maxlength=3 />
142 <label class='table_size_label'> Items per page </label>
143 <img class='table_reset' src="/planetlab/icons/clear.png"
144 onmousedown='plc_table_size_reset("nodes","tablesize_text","999");'>
148 <td class='table_flushright'>
149 <form class='table_search'>
150 <label class='table_search_label'> Search </label>
151 <input class='table_search_input' type='text' id='search_text'
152 onkeyup='nodes_filter();'
153 size=40 maxlength=256 />
155 <input id='nodes_and' class='table_search_and'
156 type='checkbox' checked='checked' onchange='nodes_filter();' />
157 <img class='table_reset' src="/planetlab/icons/clear.png"
158 onmousedown='plc_table_filter_reset("nodes","search_text");'>
163 <!------------------------------------------------------------>
164 <!-- <div class="fdtablePaginaterWrap" id="nodes-fdtablePaginaterWrapTop"><p></p></div> -->
166 <!------------------------------------------------------------>
167 <table id="nodes" cellpadding="0" cellspacing="0" border="0"
168 class="plc_table sortable-onload-4 rowstyle-alt colstyle-alt no-arrow paginationcallback-nodes_paginator max-pages-15 paginate-<?php print $tablesize; ?>">
171 <th class="sortable plc_table">Peer</th>
172 <th class="sortable plc_table">Region</th>
173 <th class="sortable plc_table">Site</th>
174 <th class="sortable plc_table">State</th>
175 <th class="sortable plc_table">Hostname</th>
176 <th class="sortable-sortIPAddress plc_table">IP</th>
177 <th class="sortable plc_table">Load</th>
178 <th class="sortable plc_table">Avg Load</th>
185 $fake1=1; $fake2=3.14; $fake_i=0;
186 foreach ($nodes as $node) {
187 $hostname=$node['hostname'];
188 $node_id=$node['node_id'];
189 $site_id=$node['site_id'];
190 $site=$site_hash[$site_id];
191 $login_base = $site['login_base'];
192 $node_id=$node['node_id'];
193 $ip=$interface_hash[$node['node_id']]['ip'];
194 $interface_id=$interface_hash[$node['node_id']]['interface_id'];
195 if ( ! $node['peer_id'] ) {
198 $shortname=$peer_hash[$node['peer_id']]['shortname'];
200 printf ('<tr id="%s">',$hostname);
201 printf ('<td class="plc_table"> %s </td>',$shortname);
202 printf ('<td class="plc_table"> %s </td>',topdomain($hostname));
203 printf ('<td class="plc_table"> <a href="/db/sites/index.php?id=%s">%s</a></td>',$site_id,$login_base);
204 printf ('<td class="plc_table"> %s </td>',$node['boot_state']);
205 printf ('<td class="plc_table"> <a href="/db/nodes/index.php?id=%s">%s</a></td>',$node_id,$hostname);
206 printf ('<td class="plc_table"> <a href="/db/nodes/interfaces.php?id=%s">%s</a></td>', $interface_id,$ip);
207 printf ('<td class="plc_table"> %s </td>', $fake1);
208 printf ('<td class="plc_table"> %s </td>', $fake2);
211 if ($fake_i % 5 == 0) $fake1 += 3;
212 if ($fake_i % 3 == 0) $fake2 +=5; else $fake2 -= $fake_i;
222 <!-- <div class="fdtablePaginaterWrap" id="nodes-fdtablePaginaterWrapBottom"><p></p></div> -->
224 <p class='plc_filter_note'>
225 Notes: Enter & or | in the search area to alternate between <bold>AND</bold> and <bold>OR</bold> search modes
227 Hold down the shift key to select multiple columns to sort