New upstream version 0.6.27
This commit is contained in:
@@ -1,210 +1,260 @@
|
||||
<?php defined('SYSPATH') OR die('No direct access allowed.');
|
||||
<?php
|
||||
|
||||
// phpcs:disable PSR1.Classes.ClassDeclaration.MissingNamespace
|
||||
// phpcs:disable PSR1.Files.SideEffects
|
||||
defined('SYSPATH') or die('No direct access allowed.');
|
||||
// phpcs:enable PSR1.Files.SideEffects
|
||||
// phpcs:disable Squiz.Classes.ValidClassName.NotCamelCaps
|
||||
|
||||
/**
|
||||
* system controller.
|
||||
*
|
||||
* @package pnp4nagios
|
||||
* @package pnp4nagios
|
||||
* @author Joerg Linge
|
||||
* @license GPL
|
||||
*/
|
||||
class System_Controller extends Template_Controller {
|
||||
class System_Controller extends Template_Controller
|
||||
{
|
||||
public $data = '';
|
||||
|
||||
public $config = '';
|
||||
|
||||
public $rrdtool = '';
|
||||
|
||||
public $auth = '';
|
||||
|
||||
public $start = '';
|
||||
|
||||
public $end = '';
|
||||
|
||||
public $theme = '';
|
||||
|
||||
public $view = '';
|
||||
|
||||
public $host = '';
|
||||
|
||||
public $service = '';
|
||||
|
||||
public $source = '';
|
||||
|
||||
public $version = '';
|
||||
|
||||
public $tpl = '';
|
||||
|
||||
public $controller = '';
|
||||
|
||||
public $session = '';
|
||||
|
||||
public $url = '';
|
||||
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
parent::__construct();
|
||||
|
||||
$this->data = new Data_Model();
|
||||
$this->config = new Config_Model();
|
||||
$this->rrdtool = new Rrdtool_Model();
|
||||
$this->auth = new Auth_Model();
|
||||
#$this->system = new System_Model();
|
||||
|
||||
$this->data = new Data_Model();
|
||||
$this->config = new Config_Model();
|
||||
$this->rrdtool = new Rrdtool_Model();
|
||||
$this->auth = new Auth_Model();
|
||||
// $this->system = new System_Model();
|
||||
$this->config->read_config();
|
||||
Kohana::config_set('locale.language',$this->config->conf['lang']);
|
||||
Kohana::config_set('locale.language', $this->config->conf['lang']);
|
||||
// Check for mod_rewrite
|
||||
$this->check_mod_rewrite();
|
||||
|
||||
$this->start = $this->input->get('start',FALSE);
|
||||
$this->end = $this->input->get('end',FALSE);
|
||||
$this->theme = pnp::clean($this->input->get('theme',FALSE));
|
||||
$this->view = pnp::clean($this->input->get('view', ""));
|
||||
$this->host = pnp::clean($this->input->get('host',NULL));
|
||||
$this->service = pnp::clean($this->input->get('srv',NULL));
|
||||
$this->source = pnp::clean($this->input->get('source',NULL));
|
||||
$this->version = pnp::clean($this->input->get('version',NULL));
|
||||
$this->tpl = pnp::clean($this->input->get('tpl'));
|
||||
$this->controller = Router::$controller;
|
||||
$this->start = $this->input->get('start', false);
|
||||
$this->end = $this->input->get('end', false);
|
||||
$this->theme = pnp::clean($this->input->get('theme', false));
|
||||
$this->view = pnp::clean($this->input->get('view', ''));
|
||||
$this->host = pnp::clean($this->input->get('host', null));
|
||||
$this->service = pnp::clean($this->input->get('srv', null));
|
||||
$this->source = pnp::clean($this->input->get('source', null));
|
||||
$this->version = pnp::clean($this->input->get('version', null));
|
||||
$this->tpl = pnp::clean($this->input->get('tpl'));
|
||||
$this->controller = Router::$controller;
|
||||
|
||||
$this->data->getTimeRange($this->start,$this->end,$this->view);
|
||||
if(Router::$controller != "image" && Router::$controller != "image_special"){
|
||||
$this->data->getTimeRange($this->start, $this->end, $this->view);
|
||||
if (! in_array(Router::$controller, ['image', 'image_special', 'xport'])) {
|
||||
$this->session = Session::instance();
|
||||
|
||||
# Session withou theme info
|
||||
if($this->session->get("theme","new") == "new"){
|
||||
if($this->theme){
|
||||
# store $this->theme if available
|
||||
Kohana::config_set('core.theme',$this->theme);
|
||||
$this->session->set('theme', $this->theme );
|
||||
}else{
|
||||
# set $this->theme to default value
|
||||
$this->theme = $this->config->conf['ui-theme'];
|
||||
Kohana::config_set('core.theme',$this->theme);
|
||||
}
|
||||
# Sesion with theme info
|
||||
}else{
|
||||
if($this->theme && $this->theme != 'default'){
|
||||
# store $this->theme if available
|
||||
$this->session->set('theme', $this->theme );
|
||||
Kohana::config_set('core.theme',$this->theme);
|
||||
}elseif($this->theme == 'default'){
|
||||
# reset to default theme
|
||||
$this->theme = $this->config->conf['ui-theme'];
|
||||
$this->session->set('theme', $this->theme );
|
||||
Kohana::config_set('core.theme',$this->theme);
|
||||
}else{
|
||||
# set $this->theme with session infos
|
||||
$this->theme = $this->session->get('theme');
|
||||
Kohana::config_set('core.theme',$this->theme);
|
||||
}
|
||||
}
|
||||
// Initialize CSRF Token
|
||||
$this->session->set('csrf_token', Security::token());
|
||||
|
||||
if($this->start && $this->end ){
|
||||
if($this->session->get('timerange-reset',0) == 0){
|
||||
$this->session->set("start", $this->start);
|
||||
$this->session->set("end", $this->end);
|
||||
}else{
|
||||
// Session withou theme info
|
||||
if ($this->session->get('theme', 'new') == 'new') {
|
||||
if ($this->theme) {
|
||||
// store $this->theme if available
|
||||
Kohana::config_set('core.theme', $this->theme);
|
||||
$this->session->set('theme', $this->theme);
|
||||
} else {
|
||||
// set $this->theme to default value
|
||||
$this->theme = $this->config->conf['ui-theme'];
|
||||
Kohana::config_set('core.theme', $this->theme);
|
||||
}
|
||||
// Sesion with theme info
|
||||
} else {
|
||||
if ($this->theme && $this->theme != 'default') {
|
||||
// store $this->theme if available
|
||||
$this->session->set('theme', $this->theme);
|
||||
Kohana::config_set('core.theme', $this->theme);
|
||||
} elseif ($this->theme == 'default') {
|
||||
// reset to default theme
|
||||
$this->theme = $this->config->conf['ui-theme'];
|
||||
$this->session->set('theme', $this->theme);
|
||||
Kohana::config_set('core.theme', $this->theme);
|
||||
} else {
|
||||
// set $this->theme with session infos
|
||||
$this->theme = $this->session->get('theme');
|
||||
Kohana::config_set('core.theme', $this->theme);
|
||||
}
|
||||
}
|
||||
//end if
|
||||
|
||||
if ($this->start && $this->end) {
|
||||
if ($this->session->get('timerange-reset', 0) == 0) {
|
||||
$this->session->set('start', $this->start);
|
||||
$this->session->set('end', $this->end);
|
||||
} else {
|
||||
$this->session->set('timerange-reset', 0);
|
||||
}
|
||||
}
|
||||
if($this->start && !$this->end){
|
||||
if($this->session->get('timerange-reset',0) == 0){
|
||||
$this->session->set("start", $this->start);
|
||||
$this->session->set("end", "");
|
||||
}else{
|
||||
if ($this->start && !$this->end) {
|
||||
if ($this->session->get('timerange-reset', 0) == 0) {
|
||||
$this->session->set('start', $this->start);
|
||||
$this->session->set('end', '');
|
||||
} else {
|
||||
$this->session->set('timerange-reset', 0);
|
||||
}
|
||||
}
|
||||
if($this->end && !$this->start){
|
||||
if($this->session->get('timerange-reset',0) == 0){
|
||||
$this->session->set("end", $this->end);
|
||||
$this->session->set("start", "");
|
||||
}else{
|
||||
if ($this->end && !$this->start) {
|
||||
if ($this->session->get('timerange-reset', 0) == 0) {
|
||||
$this->session->set('end', $this->end);
|
||||
$this->session->set('start', '');
|
||||
} else {
|
||||
$this->session->set('timerange-reset', 0);
|
||||
}
|
||||
}
|
||||
}
|
||||
//end if
|
||||
}
|
||||
//end __construct()
|
||||
|
||||
|
||||
public function __call($method, $arguments)
|
||||
{
|
||||
// Disable auto-rendering
|
||||
$this->auto_render = FALSE;
|
||||
$this->auto_render = false;
|
||||
|
||||
// By defining a __call method, all pages routed to this controller
|
||||
// that result in 404 errors will be handled by this method, instead of
|
||||
// being displayed as "Page Not Found" errors.
|
||||
echo $this->_("The requested page doesn't exist") . " ($method)";
|
||||
}
|
||||
//end __call()
|
||||
|
||||
|
||||
/**
|
||||
* Handle paths to current theme etc
|
||||
*
|
||||
*/
|
||||
public function add_view($view=false)
|
||||
public function add_view($view = false)
|
||||
{
|
||||
$view = trim($view);
|
||||
if (empty($view)) {
|
||||
return false;
|
||||
}
|
||||
if (!file_exists(APPPATH."/views/".$view.".php")) {
|
||||
if (!file_exists(APPPATH . '/views/' . $view . '.php')) {
|
||||
return false;
|
||||
}
|
||||
#return new View($this->theme_path.$view);
|
||||
// return new View($this->theme_path.$view);
|
||||
return new View($view);
|
||||
}
|
||||
//end add_view()
|
||||
|
||||
public function check_mod_rewrite(){
|
||||
if(!function_exists('apache_get_modules')){
|
||||
// Add index.php to every URL while not running withn apache mod_php
|
||||
Kohana::config_set('core.index_page','index.php');
|
||||
return TRUE;
|
||||
|
||||
public function check_mod_rewrite()
|
||||
{
|
||||
if (!function_exists('apache_get_modules')) {
|
||||
// Add index.php to every URL while not running withn apache mod_php
|
||||
Kohana::config_set('core.index_page', 'index.php');
|
||||
return true;
|
||||
}
|
||||
if(!in_array('mod_rewrite', apache_get_modules())){
|
||||
if (!in_array('mod_rewrite', apache_get_modules())) {
|
||||
// Add index.php to every URL while mod_rewrite is not available
|
||||
Kohana::config_set('core.index_page','index.php');
|
||||
Kohana::config_set('core.index_page', 'index.php');
|
||||
}
|
||||
if ( $this->config->conf['use_url_rewriting'] == 0 ){
|
||||
Kohana::config_set('core.index_page','index.php');
|
||||
if ($this->config->conf['use_url_rewriting'] == 0) {
|
||||
Kohana::config_set('core.index_page', 'index.php');
|
||||
}
|
||||
}
|
||||
//end check_mod_rewrite()
|
||||
|
||||
public function isAuthorizedFor($auth) {
|
||||
|
||||
public function isAuthorizedFor($auth)
|
||||
{
|
||||
$conf = $this->config->conf;
|
||||
if ($auth == "service_links") {
|
||||
if ($auth == 'service_links') {
|
||||
$users = explode(',', $conf['allowed_for_service_links']);
|
||||
if (in_array('EVERYONE', $users)) {
|
||||
return 1;
|
||||
} elseif (in_array('NONE', $users)) {
|
||||
return 0;
|
||||
} elseif (in_array($this->auth->REMOTE_USER, $users)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
if ($auth == 'host_search') {
|
||||
$users = explode(',', $conf['allowed_for_host_search']);
|
||||
if (in_array('EVERYONE', $users)) {
|
||||
return 1;
|
||||
} elseif (in_array('NONE', $users)) {
|
||||
return 0;
|
||||
} elseif (in_array($this->auth->REMOTE_USER, $users)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
if ($auth == 'host_overview') {
|
||||
$users = explode(',', $conf['allowed_for_host_overview']);
|
||||
if (in_array('EVERYONE', $users)) {
|
||||
return 1;
|
||||
} elseif (in_array('NONE', $users)) {
|
||||
return 0;
|
||||
} elseif (in_array($this->auth->REMOTE_USER, $users)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
if ($auth == 'pages') {
|
||||
$users = explode(',', $conf['allowed_for_pages']);
|
||||
if (in_array('EVERYONE', $users)) {
|
||||
return 1;
|
||||
} elseif (in_array('NONE', $users)) {
|
||||
return 0;
|
||||
} elseif (in_array($this->auth->REMOTE_USER, $users)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
//end isAuthorizedFor()
|
||||
|
||||
$users = explode(",", $conf['allowed_for_service_links']);
|
||||
if (in_array('EVERYONE', $users)) {
|
||||
return 1;
|
||||
}
|
||||
elseif (in_array('NONE', $users)) {
|
||||
return 0;
|
||||
}
|
||||
elseif (in_array($this->auth->REMOTE_USER, $users)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
|
||||
public function isMobileDevice()
|
||||
{
|
||||
if ($this->session->get('classic-ui', 0) == 1) {
|
||||
return false;
|
||||
}
|
||||
if ($auth == "host_search") {
|
||||
$users = explode(",", $conf['allowed_for_host_search']);
|
||||
if (in_array('EVERYONE', $users)) {
|
||||
return 1;
|
||||
}
|
||||
elseif (in_array('NONE', $users)) {
|
||||
return 0;
|
||||
}
|
||||
elseif (in_array($this->auth->REMOTE_USER, $users)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
if (preg_match('/' . $this->config->conf['mobile_devices'] . '/', $_SERVER['HTTP_USER_AGENT'])) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
if ($auth == "host_overview") {
|
||||
$users = explode(",", $conf['allowed_for_host_overview']);
|
||||
if (in_array('EVERYONE', $users)) {
|
||||
return 1;
|
||||
}
|
||||
elseif (in_array('NONE', $users)) {
|
||||
return 0;
|
||||
}
|
||||
elseif (in_array($this->auth->REMOTE_USER, $users)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
if ($auth == "pages") {
|
||||
$users = explode(",", $conf['allowed_for_pages']);
|
||||
if (in_array('EVERYONE', $users)) {
|
||||
return 1;
|
||||
}
|
||||
elseif (in_array('NONE', $users)) {
|
||||
return 0;
|
||||
}
|
||||
elseif (in_array($this->auth->REMOTE_USER, $users)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
public function isMobileDevice (){
|
||||
if( $this->session->get('classic-ui',0) == 1){
|
||||
return FALSE;
|
||||
}
|
||||
if ( preg_match('/'.$this->config->conf['mobile_devices'].'/', $_SERVER['HTTP_USER_AGENT'] ) ){
|
||||
return TRUE;
|
||||
}else{
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
}
|
||||
//end isMobileDevice()
|
||||
}
|
||||
//end class
|
||||
|
||||
Reference in New Issue
Block a user