54 lines
1.8 KiB
PHP
54 lines
1.8 KiB
PHP
<?php
|
|
|
|
try {
|
|
$user = $user_dir->get_user_by_uid($router->vars['username']);
|
|
} catch(UserNotFoundException $e) {
|
|
require('views/error404.php');
|
|
die;
|
|
}
|
|
$access = $user->list_remote_access();
|
|
$admined_servers = $user->list_admined_servers(array('pending_requests'));
|
|
$admined_groups = $user->list_admined_groups(array('members', 'admins'));
|
|
$groups = $user->list_group_memberships(array('members', 'admins'));
|
|
usort($admined_servers, function($a, $b) {return strnatcasecmp($a->hostname, $b->hostname);});
|
|
|
|
if(isset($_POST['reassign_servers']) && is_array($_POST['servers']) && $active_user->admin) {
|
|
try {
|
|
$new_admin = $user_dir->get_user_by_uid($_POST['reassign_to']);
|
|
} catch(UserNotFoundException $e) {
|
|
try {
|
|
$new_admin = $group_dir->get_group_by_name($_POST['reassign_to']);
|
|
} catch(GroupNotFoundException $e) {
|
|
$content = new PageSection('user_not_found');
|
|
}
|
|
}
|
|
if(isset($new_admin)) {
|
|
foreach($admined_servers as $server) {
|
|
if(in_array($server->hostname, $_POST['servers'])) {
|
|
$server->add_admin($new_admin);
|
|
$server->delete_admin($user);
|
|
}
|
|
}
|
|
redirect('#details');
|
|
}
|
|
} elseif(isset($_POST['edit_user']) && $active_user->admin) {
|
|
$user->force_disable = $_POST['force_disable'];
|
|
$user->get_details_from_ldap();
|
|
redirect('#settings');
|
|
} else {
|
|
$content = new PageSection('user');
|
|
$content->set('user', $user);
|
|
$content->set('user_access', $access);
|
|
$content->set('user_admined_servers', $admined_servers);
|
|
$content->set('user_admined_groups', $admined_groups);
|
|
$content->set('user_groups', $groups);
|
|
$content->set('user_keys', $user->list_public_keys());
|
|
$content->set('admin', $active_user->admin);
|
|
}
|
|
|
|
$page = new PageSection('base');
|
|
$page->set('title', $user->name);
|
|
$page->set('content', $content);
|
|
$page->set('alerts', $active_user->pop_alerts());
|
|
echo $page->generate();
|