4 // pattern-matching selection not implemented
5 // due to GetSlices bug, see test.php for details
6 // in addition that would not make much sense
9 require_once 'plc_login.php';
11 // Get session and API handles
12 require_once 'plc_session.php';
16 require_once 'plc_drupal.php';
17 include 'plc_header.php';
20 require_once 'plc_functions.php';
21 require_once 'plc_peers.php';
22 require_once 'linetabs.php';
23 require_once 'table.php';
24 require_once 'nifty.php';
26 ini_set('memory_limit','48M');
28 // --------------------
29 // recognized URL arguments
30 $peerscope=$_GET['peerscope'];
31 $pattern=$_GET['pattern'];
32 $site_id=intval($_GET['site_id']);
33 $person_id=intval($_GET['person_id']);
40 $tabs []= tab_slices();
43 $tabs []= tab_slices_person();
45 $tabs []= tab_slices_mysite();
46 if (plc_is_admin()) $tabs []= tab_slices_local();
49 $slice_filter=array();
53 $slice_columns=array('slice_id','name','expires','person_ids','peer_id','node_ids');
54 // server-side filtering - set pattern in $_GET for filtering on hostname
56 $slice_filter['name']=$pattern;
57 $title .= " matching " . $pattern;
59 $slice_filter['name']="*";
62 // server-side selection on peerscope
63 $peerscope=new PeerScope($api,$_GET['peerscope']);
64 $slice_filter=array_merge($slice_filter,$peerscope->filter());
65 $title .= ' - ' . $peerscope->label();
69 $sites=$api->GetSites(array($site_id));
72 $login_base=$site['login_base'];
73 $title .= t_site($site);
74 $tabs []= tab_site($site);
75 $slice_filter['site_id']=array($site_id);
79 // fetch the person's slice_ids
80 $persons = $api->GetPersons(array('person_id'=>$person_id),array('person_id','email','slice_ids'));
82 $slice_ids['slice_id']=$person['slice_ids'];
83 $title .= t_person($person);
84 $slice_filter['slice_id']=$person['slice_ids'];
88 $slices=$api->GetSlices($slice_filter,$slice_columns);
92 if ($slices) foreach ($slices as $slice) {
93 $person_ids = array_merge ($person_ids,$slice['person_ids']);
95 $persons=$api->GetPersons($person_ids,array('person_id','email'));
98 if ($persons) foreach ($persons as $person) $person_hash[$person['person_id']]=$person;
100 function email_link_from_hash($person_id) {
102 return l_person_obj($person_hash[$person_id]);
105 // --------------------
106 drupal_set_title($title);
108 plekit_linetabs($tabs);
111 drupal_set_message ('No slice found');
115 $nifty=new PlekitNifty ('','objects-list','big');
117 if (plc_is_admin()) $headers["I"]="int";
118 $headers["Peer"]="string";
119 $headers["Name"]="string";
120 $headers["Users"]="string";
123 $headers["Exp. d/m/y"]="date-dmy";
125 # initial sort on hostnames
126 if (plc_is_admin()) $slices_sort_column = 3;
127 else $slices_sort_column = 2;
129 $table=new PlekitTable ("slices",$headers,$slices_sort_column,
130 array('search_width'=>20));
133 $peers = new Peers ($api);
135 foreach ($slices as $slice) {
136 $slice_id=$slice['slice_id'];
137 $peer_id=$slice['peer_id'];
138 $users=plc_vertical_table (array_map ("email_link_from_hash",$slice['person_ids']));
139 $expires= date( "d/m/Y", $slice['expires'] );
142 if (plc_is_admin()) $table->cell (l_slice_t($slice_id,$slice_id));
143 $peers->cell($table,$peer_id);
144 $table->cell (href(l_slice_nodes($slice_id),$slice['name']));
145 $table->cell ($users);
146 $table->cell(href(l_persons_slice($slice_id),count($slice['person_ids'])));
147 $table->cell (href(l_nodes_slice($slice_id),count($slice['node_ids'])));
148 $table->cell ($expires);
153 $notes []= "U = number of users";
154 $notes []= "N = number of nodes";
155 $table->end(array('notes'=>$notes));
158 //plekit_linetabs ($tabs,"bottom");
161 include 'plc_footer.php';