2 /* vim: set ts=4 tw=0 sw=4 noet: */
3 require_once $CFG->root
.'config.php';
7 private $timeout = false;
9 private $header = '<!DOCTYPE html>
12 <meta charset="utf-8">
13 <link rel="stylesheet" href="css/styles.css">
15 var timeout = __TIMEOUT__;
17 <script src="__ROOT__js/timer.js"></script>
18 <script src="__ROOT__js/checkbox.js"></script>
19 <title>__TITLE__</title>
22 private $footer = '<p class="footer">Powered by <a href="https://qtadmin.datanom.net"
23 title="Goto QtAdmin homepage">QtAdmin</a>. © 2015 by Michael Rasmussen</p></body></html>';
24 private $heading = '<p id="time" class="time">Session timeout:
25 <span id="timer"></span></p><h1 class="h1">__TITLE__</h1>';
27 public function __construct() {
30 $this->startSession();
32 if (! isset($_SESSION['settings'])) {
33 $this->initSettings();
35 $this->settings
= $_SESSION['settings'];
37 if ($CFG->auth_method
== 'HTTP_AUTH') {
38 if (isset($this->server
['PHP_AUTH_USER'])) {
39 $this->settings
['user'] = $this->server
['PHP_AUTH_USER'];
40 $this->settings
['loginStatus'] = 'OK';
41 if ($CFG->admin_user
== $this->settings
['user'])
42 $this->settings
['admin'] = true;
47 private function initSettings() {
48 if ('' == session_id()) {
49 $this->startSession();
52 if (false !== $this->timeout
) {
53 $timeout = $this->timeout
;
58 $this->settings
= array(
62 'loginStatus' => 'Not logged in',
66 $_SESSION['settings'] = $this->settings
;
69 private function startSession() {
72 if (isset($CFG->session_timeout
)) {
73 $this->timeout
= $CFG->session_timeout
* 60;
75 $this->timeout
= 20 * 60;
78 if (ini_get('session.gc_maxlifetime') != $this->timeout
)
79 ini_set('session.gc_maxlifetime', $this->timeout
);
80 if (ini_get('session.cookie_lifetime') != $this->timeout
)
81 ini_set('session.cookie_lifetime', $this->timeout
);
86 private function checkSession() {
89 if ('' == session_id()) {
90 $this->startSession();
93 $time = $_SERVER['REQUEST_TIME'];
94 if (isset($_SESSION['LAST_ACTIVITY']) &&
95 ($time - $_SESSION['LAST_ACTIVITY']) >= $this->settings
['timeout']) {
96 echo 'R_TIME: '.date('c', $time).' L_ACT: '.date('c', $_SESSION['LAST_ACTIVITY']);
99 $_SESSION['LAST_ACTIVITY'] = $time;
103 public function logout() {
104 if (ini_get('session.use_cookies')) {
105 $params = session_get_cookie_params();
106 setcookie(session_name(), '', time() - 42000,
107 $params['path'], $params['domain'],
108 $params['secure'], $params['httponly']);
111 if ('' != session_id()) {
116 $this->settings
= array();
119 public function isAdmin() {
122 if (isset($this->settings
['admin'])) {
123 $admin = $this->settings
['admin'];
129 public function login($user, $pw) {
133 if ('' == session_id()) {
134 $this->startSession();
137 $this->settings
['user'] = null;
138 $this->settings
['admin'] = false;
140 $p = explode('@', $user);
141 if (count($p) != 2) {
142 $this->settings
['loginStatus'] = 'Bad username';
145 $dn = "mail=$user,ou=Users,domainName=$domain,$CFG->ldap_base_dn";
146 $filter = "(&(objectclass=mailUser)(accountStatus=active)(mail=$user))";
147 $ds = @ldap_connect
($CFG->ldap_dsn
);
149 @ldap_set_option
($ds, LDAP_OPT_PROTOCOL_VERSION
, 3);
150 $r = @ldap_bind
($ds, $dn, $pw);
152 $sr = @ldap_search
($ds, $CFG->ldap_base_dn
, $filter, array('mail','domainglobaladmin'));
153 $info = @ldap_get_entries
($ds, $sr); // array
154 if ($info['count'] > 0) {
155 $this->settings
['user'] = $user;
157 $this->settings
['loginStatus'] = 'OK';
159 if (isset($info[0]['domainglobaladmin'])) {
160 $admin = $info[0]['domainglobaladmin'][0];
161 $admin = strtoupper($admin);
163 $this->settings
['admin'] = ($admin == 'YES') ?
true : false;
165 $this->settings
['loginStatus'] = 'Login failed';
168 $this->settings
['loginStatus'] = ldap_error($ds);
172 $this->settings
['loginStatus'] = 'Connect to LDAP server failed';
176 $_SESSION['settings'] = $this->settings
;
181 public function getLoginStatus() {
182 $status = 'Not logged in';
184 if (isset($this->settings
['loginStatus'])) {
185 $status = $this->settings
['loginStatus'];
191 public function isLoggedIn() {
195 if ('' == session_id()) {
196 $this->startSession();
199 $this->checkSession();
201 if (isset($this->settings
['user'])) {
202 if ($this->settings
['user'] != null) {
205 if ($CFG->auth_method
== 'HTTP_AUTH') {
206 if (isset($this->server
['PHP_AUTH_USER'])) {
207 $this->settings
['user'] = $this->server
['PHP_AUTH_USER'];
214 if ($loggedIn == false) {
215 echo '$this->settings: '.var_export($this->settings
, true);
216 echo 'R_TIME: '.date('c', $_SERVER['REQUEST_TIME']).' L_ACT: '.date('c', $_SESSION['LAST_ACTIVITY']);
220 $_SESSION['settings'] = $this->settings
;
225 public function getUser() {
228 if ($this->isLoggedIn()) {
229 $user = $this->settings
['user'];
235 public function getHeader() {
236 return $this->header
;
239 public function getFooter() {
240 return $this->footer
;
243 public function getHeading() {
244 return $this->heading
;
247 public function setHeading($heading) {
250 $timeout = $CFG->session_timeout
* 60 * 1000;
251 $this->heading
= str_replace('__TITLE__', $heading, $this->heading
);
252 $this->header
= str_replace('__TITLE__', $heading, $this->header
);
253 $this->header
= str_replace('__ROOT__', $CFG->wwwroot
, $this->header
);
254 $this->header
= str_replace('__TIMEOUT__', $timeout, $this->header
);
257 public function convertContent($code) {
271 $string = $table[$code];