]> git.sur5r.net Git - bacula/bacula/blob - gui/baculum/protected/Init.php
baculum: Assign Baculum copyright to Kern Sibbald
[bacula/bacula] / gui / baculum / protected / Init.php
1 <?php
2 /*
3  * Bacula(R) - The Network Backup Solution
4  * Baculum   - Bacula web interface
5  *
6  * Copyright (C) 2013-2016 Kern Sibbald
7  *
8  * The main author of Baculum is Marcin Haba.
9  * The original author of Bacula is Kern Sibbald, with contributions
10  * from many others, a complete list can be found in the file AUTHORS.
11  *
12  * You may use this file and others of this release according to the
13  * license defined in the LICENSE file, which includes the Affero General
14  * Public License, v3.0 ("AGPLv3") and some additional permissions and
15  * terms pursuant to its AGPLv3 Section 7.
16  *
17  * This notice must be preserved when any source code is
18  * conveyed and/or propagated.
19  *
20  * Bacula(R) is a registered trademark of Kern Sibbald.
21  */
22
23 $timezone = 'UTC';
24 if (!ini_get('date.timezone')) {
25         if (strtoupper(substr(PHP_OS, 0, 3)) != 'WIN') {
26                 exec('date +%Z', $tz, $retcode);
27                 if ($retcode === 0 && count($tz) === 1) {
28                         $timezone = $tz[0];
29                 }
30         }
31         date_default_timezone_set($timezone);
32 }
33
34 /*
35  * Support for web servers (for example Lighttpd) which do not provide direct
36  * info about HTTP Basic auth to PHP superglobal $_SERVER array.
37  */
38 if (!isset($_SERVER['PHP_AUTH_USER']) && !isset($_SERVER['PHP_AUTH_PW']) && isset($_SERVER['HTTP_AUTHORIZATION'])) {
39         /*
40          * Substring 'Basic ' from  HTTP authorization header
41          * Example 'Basic YWRtaW46YWRtaW4=' becomes 'YWRtaW46YWRtaW4='
42          */
43         $encoded_credentials = substr($_SERVER['HTTP_AUTHORIZATION'], 6);
44         $decoded_credentials = base64_decode($encoded_credentials);
45
46         // initialize required auth superglobal $_SERVER array
47         list($_SERVER['PHP_AUTH_USER'], $_SERVER['PHP_AUTH_PW']) = explode(':', $decoded_credentials);
48 }
49
50 // Check requirements and if are some needed then show requirements page
51 require_once('./protected/Pages/Requirements.php');
52 new Requirements(dirname(__DIR__));
53
54 ?>