This repository has been archived by the owner on Sep 18, 2023. It is now read-only.
/
user.php
113 lines (96 loc) · 3.29 KB
/
user.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
<?php
require_once(dirname(__FILE__) . "/config.inc.php");
require_once(VPANEL_UI . "/session.class.php");
$session = $config->getSession();
$ui = $session->getTemplate();
if (!$session->isAllowed("users_show")) {
$ui->viewLogin();
exit;
}
require_once(VPANEL_CORE . "/user.class.php");
require_once(VPANEL_CORE . "/role.class.php");
function parseUserFormular($session, &$user = null) {
$username = $session->getVariable("username");
$password = $session->getVariable("password");
$aktiv = $session->getBoolVariable("aktiv");
$defaultgliederungid = $session->getVariable("defaultgliederungid");
$defaultdokumentkategorieid = $session->getVariable("defaultdokumentkategorieid");
$defaultdokumentstatusid = $session->getVariable("defaultdokumentstatusid");
$generateapikey = $session->hasVariable("apikey") && $session->getVariable("apikey") == "generate";
$removeapikey = $session->hasVariable("apikey") && $session->getVariable("apikey") == "remove";
if ($user == null) {
$user = new User($session->getStorage());
}
$user->setUsername($username);
if (!empty($password)) {
$user->changePassword($password);
}
if ($generateapikey) {
$user->generateAPIKey();
}
if ($removeapikey) {
$user->unsetAPIKey();
}
$user->setAktiv($aktiv);
$user->setDefaultGliederungID($defaultgliederungid);
$user->setDefaultDokumentKategorieID($defaultdokumentkategorieid);
$user->setDefaultDokumentStatusID($defaultdokumentstatusid);
$user->save();
}
switch ($session->hasVariable("mode") ? $session->getVariable("mode") : null) {
case "addrole":
if (!$session->isAllowed("users_modify")) {
$ui->viewLogin();
exit;
}
$user = $session->getStorage()->getUser($session->getIntVariable("userid"));
$user->addRoleID($session->getIntVariable("roleid"));
$user->save();
$ui->redirect();
exit;
case "delrole":
if (!$session->isAllowed("users_modify")) {
$ui->viewLogin();
exit;
}
$user = $session->getStorage()->getUser($session->getIntVariable("userid"));
$user->delRoleID($session->getIntVariable("roleid"));
$user->save();
$ui->redirect();
exit;
case "details":
$userid = $session->getIntVariable("userid");
$user = $session->getStorage()->getUser($userid);
if ($session->getBoolVariable("save")) {
if (!$session->isAllowed("users_modify")) {
$ui->viewLogin();
exit;
}
parseUserFormular($session, $user);
}
$roles = $session->getStorage()->getRoleList();
$gliederungen = $session->getStorage()->getGliederungList();
$dokumentkategorien = $session->getStorage()->getDokumentKategorieList();
$dokumentstatuslist = $session->getStorage()->getDokumentStatusList();
$ui->viewUserDetails($user, $roles, $gliederungen, $dokumentkategorien, $dokumentstatuslist);
exit;
case "create":
if ($session->getBoolVariable("save")) {
if (!$session->isAllowed("users_create")) {
$ui->viewLogin();
exit;
}
parseUserFormular($session, $user);
$ui->redirect($session->getLink("users_details", $user->getUserID()));
}
$gliederungen = $session->getStorage()->getGliederungList();
$dokumentkategorien = $session->getStorage()->getDokumentKategorieList();
$dokumentstatuslist = $session->getStorage()->getDokumentStatusList();
$ui->viewUserCreate($gliederungen, $dokumentkategorien, $dokumentstatuslist);
exit;
default:
$users = $session->getStorage()->getUserList();
$ui->viewUserList($users);
exit;
}
?>