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