interface form
[plewww.git] / planetlab / persons / persons.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;
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_peers.php';
19 require_once 'plc_minitabs.php';
20 require_once 'plc_tables.php';
21
22 //fix the memory limit for this page
23 ini_set("memory_limit","48M");
24
25 // -------------------- 
26 // recognized URL arguments
27 $peerscope=$_GET['peerscope'];
28 $pattern=$_GET['pattern'];
29 $site_id=intval($_GET['site_id']);
30 $slice_id=intval($_GET['slice_id']);
31
32 // --- decoration
33 $title="Accounts";
34 $tabs=array();
35 $tabs['My accounts'] = array('url'=>l_persons(),
36                              'values'=>array('site_id'=>plc_my_site_id()),
37                              'bubble'=>'Lists accounts on site ' . plc_my_site_id());
38 if (plc_is_admin()) 
39   $tabs['Local accounts'] = array('url'=>l_persons(),
40                                   'values'=>array('peerscope'=>'local'));
41 // -------------------- 
42 $person_filter=array();
43
44 ////////////////////
45 function person_status ($person) {
46
47   $messages=array();
48   
49   if ( $person['peer_id'] ) {
50     $class='plc-foreign';
51   } else {
52     $class='plc-warning';
53   }
54   // check that the person has keys
55   if ( count($person['key_ids']) == 0)
56     $messages [] = "No Key";
57   if ( ! $person['enabled'] ) 
58     $messages[] = "Disabled";
59   // for tech-only people: outline user if in a slice
60   if ( ( count($person['roles'])==1 ) && 
61        ( in_array('tech',$person['roles']) ) ) {
62     if (! empty($person["slice_ids"]) ) $messages[]="Tech in a Slice";  
63   } else {
64     // or for other kind of people, if they have no slice
65     if ( count($person['slice_ids']) == 0) $messages [] = "No Slice";
66   }
67   return plc_vertical_table($messages,$class);
68 }
69
70
71 // fetch persons 
72 $person_columns=array('person_id','first_name','last_name','email','roles','peer_id','key_ids','site_ids','enabled','slice_ids');
73 // PIs and admins can see users not yet enabled
74 $privileges=plc_is_admin() || plc_is_pi();
75 if ( ! $privileges ) 
76   $person_filter['enabled']=true;
77 // server-side filtering - set pattern in $_GET for filtering on email
78 if ($pattern) {
79   $person_filter['email']=$pattern;
80   $title .= " matching " . $pattern;
81  } else {
82   $person_filter['email']="*";
83  }
84
85 // server-side selection on peerscope
86 $peerscope=new PeerScope ($api,$_GET['peerscope']);
87 $person_filter=array_merge($person_filter,$peerscope->filter());
88 $title .= ' - ' . $peerscope->label();
89
90 if ($site_id) {
91   $sites=$api->GetSites(array($site_id),array("name","login_base","person_ids"));
92   $site=$sites[0];
93   $name=$site['name'];
94   $login_base=$site['login_base'];
95   $title .= t_site($site);
96   $tabs = array_merge($tabs,tabs_site($site));
97   $person_filter['person_id']=$site['person_ids'];
98   if ($site_id == plc_my_site_id()) 
99     unset($tabs['My accounts']);
100 }
101
102 if ($slice_id) {
103   $slices=$api->GetSlices(array($slice_id),array('person_ids','name'));
104   $slice=$slices[0];
105   $title .= t_slice($slice);
106   $tabs = array_merge($tabs,tabs_slice($slice));
107   $person_filter['person_id'] = $slice['person_ids'];
108  }
109
110 // go
111 $persons=$api->GetPersons($person_filter,$person_columns);
112
113 // build site_ids 
114 $site_ids=array();
115 if ($persons) foreach ($persons as $person) 
116                 if ($person['site_ids'][0])
117                   $site_ids []= $person['site_ids'][0];
118
119 // fetch related sites
120 $site_columns=array('site_id','login_base');
121 $site_filter=array('site_id'=>$site_ids);
122 $sites=$api->GetSites($site_filter,$site_columns);
123
124 // hash on site_id
125 $site_hash=array();
126 foreach ($sites as $site) {
127     $site_hash[$site['site_id']]=$site;
128 }
129
130 // --------------------
131 drupal_set_title($title);
132
133 plc_tabs($tabs);
134
135 if ( ! $persons ) {
136   drupal_set_message ('No account found');
137   return;
138  }
139   
140 $headers = array ("Peer"=>"string",
141                   "First"=>"string",
142                   "Last"=>"string",
143                   "Email"=>"string",
144                   "Site" => "string",
145                   "Roles"=>"string",
146                   "S" => "int",
147                   "Status"=>"string",
148                   );
149
150 // initial sort on email
151 $table=new PlcTable("persons",$headers,4);
152 $table->start();
153
154 $peers=new Peers ($api);
155 // write rows
156
157 foreach ($persons as $person) {
158     $person_id=$person['person_id'];
159     $email=$person['email'];
160     $shortname = $peers->shortname($person['peer_id']);
161     $site_id=$person['site_ids'][0];
162     $site=$site_hash[$site_id];
163     $login_base = $site['login_base'];
164     $roles = plc_vertical_table ($person['roles']);
165
166     $table->row_start();
167     
168     $table->cell($shortname);
169     $table->cell ($person['first_name']);
170     $table->cell ($person['last_name']);
171     $table->cell(l_person_t($person_id,$email));
172     $table->cell(l_site_t($site_id,$login_base));
173     $table->cell($roles);
174     $table->cell(count($person['slice_ids']));
175     $table->cell(person_status($person));
176     $table->row_end();
177                                  
178 }
179 $notes=array("The S column shows the number of slices for the given user");
180 $table->end(array('notes'=>$notes));
181
182 // Print footer
183 include 'plc_footer.php';
184
185
186 ?>