3 // Deprecated. Node Manager should manage keys.
5 // .ssh/authorized_keys generator
8 // keys.php?role=admin (all PlanetLab administrators)
9 // keys.php?root (PlanetLab root and users allowed root on the querying node)
10 // keys.php?site_admin (PIs and tech contacts at the querying node's site)
12 // Mark Huang <mlhuang@cs.princeton.edu>
13 // Aaron Klingaman <alk@cs.princeton.edu>
14 // Copyright (C) 2004 The Trustees of Princeton University
19 // Get admin API handle
20 require_once 'plc_api.php';
26 if (!empty($_REQUEST['role'])) {
27 // XXX Implement API query filters
28 // $persons = $adm->GetPersons(array('roles' => array($_REQUEST['role'])));
29 $all_persons = $adm->GetPersons();
30 foreach ($all_persons as $person) {
31 if (in_array($_REQUEST['role'], $person['roles'])) {
36 if (isset($_REQUEST[PLC_SLICE_PREFIX . '_monitor'])) {
37 $user = $adm->GetPersons(array('first_name' => 'Site', 'last_name' => 'Assistant'));
39 $persons[] = $user[0];
43 if (isset($_REQUEST['site_admin'])) {
45 $nodenetworks = $adm->GetNodeNetworks(array('ip' => $_SERVER['REMOTE_ADDR']));
46 if (!empty($nodenetworks)) {
47 $nodes = $adm->GetNodes(array($nodenetworks[0]['node_id']));
54 $sites = $adm->GetSites(array($node['site_id']));
55 // Can't filter on roles so have to bruit force through entire userlist of site.
56 if ($sites && $sites[0]['person_ids']) {
57 $all_persons = $adm->GetPersons($sites[0]['person_ids']);
58 foreach ($all_persons as $person) {
59 if ((in_array('pi', $person['roles']) || in_array('tech', $person['roles'])) &&
68 if (isset($_REQUEST['root'])) {
69 $keys[] = array('key' => file_get_contents(PLC_ROOT_SSH_KEY_PUB));
73 if (!empty($persons)) {
75 foreach ($persons as $person) {
76 if ($person['key_ids']) {
77 $key_ids[] = $person['key_ids'][0];
80 if (!empty($key_ids)) {
81 $keys = $adm->GetKeys($key_ids);
85 foreach ($keys as $key) {
86 print $key['key']. "\n";