2 /* vim: set ts=4 tw=0 sw=4 noet: */
3 require_once $CFG->root
.'config.php';
7 private $timeout = false;
11 private $header = '<!DOCTYPE html>
14 <meta charset="utf-8">
15 <link rel="stylesheet" href="css/styles.css">
17 var timeout = __TIMEOUT__;
19 <script src="__ROOT__js/timer.js"></script>
20 <script src="__ROOT__js/checkbox.js"></script>
21 <title>__TITLE__</title>
24 private $footer = '<p class="footer">Powered by <a href="https://qtadmin.datanom.net"
25 title="Goto QtAdmin homepage">QtAdmin</a>. © 2015 by Michael Rasmussen</p></body></html>';
26 private $heading = '<p id="time" class="time">Session timeout:
27 <span id="timer"></span></p><h1 class="h1">__TITLE__</h1>';
29 public function __construct() {
32 if (isset($CFG->log_level
)) {
33 $this->log_level
= $CFG->log_level
;
38 if (isset($CFG->log_method
)) {
39 $this->log_method
= $CFG->log_method
;
41 $this->log_level
= 'syslog';
44 $this->log("Init Utils", 4);
46 $this->log("__construct[1]: user ".var_export($this->settings
['user'], true), 3);
47 $this->startSession();
48 $this->log("__construct[2]: user ".var_export($this->settings
['user'], true), 3);
50 if (! isset($_SESSION['settings'])) {
51 $this->initSettings();
53 $this->log("__construct[3]: user ".var_export($this->settings
['user'], true), 3);
54 $this->settings
= $_SESSION['settings'];
55 $this->log("__construct[4]: user ".var_export($this->settings
['user'], true), 3);
57 if ($CFG->auth_method
== 'HTTP_AUTH') {
58 if (isset($this->server
['PHP_AUTH_USER'])) {
59 $this->settings
['user'] = $this->server
['PHP_AUTH_USER'];
60 $this->settings
['loginStatus'] = 'OK';
61 if ($CFG->admin_user
== $this->settings
['user'])
62 $this->settings
['admin'] = true;
67 private function log($message, $level = 1) {
70 if ($level > $this->log_level
)
77 case 1: $priority = LOG_ERR
; break;
78 case 2: $priority = LOG_WARNING
; break;
79 case 3: $priority = LOG_INFO
; break;
80 case 4: $priority = LOG_DEBUG
; break;
83 switch ($this->log_method
) {
87 syslog($priority, $message);
92 private function initSettings() {
93 $this->log("InitSettings", 4);
95 if ('' == session_id()) {
96 $this->startSession();
99 if (false !== $this->timeout
) {
100 $timeout = $this->timeout
;
105 $this->settings
= array(
106 'server' => $_SERVER,
109 'loginStatus' => 'Not logged in',
110 'timeout' => $timeout
113 $_SESSION['settings'] = $this->settings
;
116 private function startSession() {
119 $this->log("startSession", 4);
121 if (isset($CFG->session_timeout
)) {
122 $this->timeout
= $CFG->session_timeout
* 60;
124 $this->timeout
= 20 * 60;
127 if (ini_get('session.gc_maxlifetime') != $this->timeout
)
128 ini_set('session.gc_maxlifetime', $this->timeout
);
129 if (ini_get('session.cookie_lifetime') != $this->timeout
)
130 ini_set('session.cookie_lifetime', $this->timeout
);
135 private function checkSession() {
138 $this->log("checkSession", 4);
140 if ('' == session_id()) {
141 $this->startSession();
144 $time = $_SERVER['REQUEST_TIME'];
145 if (isset($_SESSION['LAST_ACTIVITY']) &&
146 ($time - $_SESSION['LAST_ACTIVITY']) >= $this->settings
['timeout']) {
147 echo 'R_TIME: '.date('c', $time).' L_ACT: '.date('c', $_SESSION['LAST_ACTIVITY']);
150 $_SESSION['LAST_ACTIVITY'] = $time;
154 public function logout() {
155 $this->log("logout", 4);
157 if (ini_get('session.use_cookies')) {
158 $params = session_get_cookie_params();
159 setcookie(session_name(), '', time() - 42000,
160 $params['path'], $params['domain'],
161 $params['secure'], $params['httponly']);
164 if ('' != session_id()) {
169 $this->settings
= array();
172 public function isAdmin() {
175 $this->log("isAdmin", 4);
177 if (isset($this->settings
['admin'])) {
178 $admin = $this->settings
['admin'];
184 public function login($user, $pw) {
188 $this->log("login", 4);
190 if ('' == session_id()) {
191 $this->startSession();
194 $this->settings
['user'] = null;
195 $this->settings
['admin'] = false;
197 $p = explode('@', $user);
198 if (count($p) != 2) {
199 $this->settings
['loginStatus'] = 'Bad username';
202 $dn = "mail=$user,ou=Users,domainName=$domain,$CFG->ldap_base_dn";
203 $filter = "(&(objectclass=mailUser)(accountStatus=active)(mail=$user))";
204 $ds = @ldap_connect
($CFG->ldap_dsn
);
206 @ldap_set_option
($ds, LDAP_OPT_PROTOCOL_VERSION
, 3);
207 $r = @ldap_bind
($ds, $dn, $pw);
209 $sr = @ldap_search
($ds, $CFG->ldap_base_dn
, $filter, array('mail','domainglobaladmin'));
210 $info = @ldap_get_entries
($ds, $sr); // array
211 if ($info['count'] > 0) {
212 $this->settings
['user'] = $user;
214 $this->settings
['loginStatus'] = 'OK';
216 if (isset($info[0]['domainglobaladmin'])) {
217 $admin = $info[0]['domainglobaladmin'][0];
218 $admin = strtoupper($admin);
220 $this->settings
['admin'] = ($admin == 'YES') ?
true : false;
222 $this->settings
['loginStatus'] = 'Login failed';
225 $this->settings
['loginStatus'] = ldap_error($ds);
229 $this->settings
['loginStatus'] = 'Connect to LDAP server failed';
233 $_SESSION['settings'] = $this->settings
;
238 public function getLoginStatus() {
239 $status = 'Not logged in';
241 $this->log("getLoginStatus", 4);
243 if (isset($this->settings
['loginStatus'])) {
244 $status = $this->settings
['loginStatus'];
250 public function isLoggedIn() {
254 $this->log("isLoggedIn[1]: user ".var_export($this->settings
['user'], true), 3);
256 if ('' == session_id()) {
257 $this->startSession();
260 $this->log("isLoggedIn[2]: user ".var_export($this->settings
['user'], true), 3);
261 $this->checkSession();
262 $this->log("isLoggedIn[3]: user ".var_export($this->settings
['user'], true), 3);
264 if (isset($this->settings
['user'])) {
265 if ($this->settings
['user'] != null) {
268 if ($CFG->auth_method
== 'HTTP_AUTH') {
269 if (isset($this->server
['PHP_AUTH_USER'])) {
270 $this->settings
['user'] = $this->server
['PHP_AUTH_USER'];
277 if ($loggedIn == false) {
278 echo '$this->settings: '.var_export($this->settings
, true);
279 echo 'R_TIME: '.date('c', $_SERVER['REQUEST_TIME']).' L_ACT: '.date('c', $_SESSION['LAST_ACTIVITY']);
283 $_SESSION['settings'] = $this->settings
;
288 public function getUser() {
291 $this->log("getUser", 4);
293 if ($this->isLoggedIn()) {
294 $user = $this->settings
['user'];
300 public function getHeader() {
301 $this->log("getHeader", 4);
303 return $this->header
;
306 public function getFooter() {
307 $this->log("getFooter", 4);
309 return $this->footer
;
312 public function getHeading() {
313 $this->log("getHeading", 4);
315 return $this->heading
;
318 public function setHeading($heading) {
321 $this->log("setHeading", 4);
323 $timeout = $CFG->session_timeout
* 60 * 1000;
324 $this->heading
= str_replace('__TITLE__', $heading, $this->heading
);
325 $this->header
= str_replace('__TITLE__', $heading, $this->header
);
326 $this->header
= str_replace('__ROOT__', $CFG->wwwroot
, $this->header
);
327 $this->header
= str_replace('__TIMEOUT__', $timeout, $this->header
);
330 public function convertContent($code) {
331 $this->log("convertContent", 4);
346 $string = $table[$code];