mirror of
https://port.numenaute.org/aleajactaest/khanat-opennel-code.git
synced 2025-01-15 04:05:35 +00:00
169 lines
6.2 KiB
PHP
169 lines
6.2 KiB
PHP
<?php
|
|
|
|
//error_reporting(E_ALL); // extreme debug info ;)
|
|
set_time_limit(180); // 3 min time out
|
|
|
|
// add the path for the nel class files
|
|
ini_set('include_path',ini_get('include_path') .':./nel/');
|
|
|
|
require_once('config.php');
|
|
|
|
require_once(NELTOOL_SYSTEMBASE .'functions_common.php');
|
|
require_once(NELTOOL_SYSTEMBASE .'functions_auth.php');
|
|
|
|
//assert_options(ASSERT_ACTIVE, 1);
|
|
//assert_options(ASSERT_WARNING, 0);
|
|
//assert_options(ASSERT_QUIET_EVAL, 1);
|
|
//assert_options(ASSERT_CALLBACK, 'nt_common_assert');
|
|
|
|
require_once(NELTOOL_SYSTEMBASE .'functions_mysqli.php');
|
|
require_once(NELTOOL_SYSTEMBASE .'smarty/Smarty.class.php');
|
|
require_once(NELTOOL_SYSTEMBASE. 'functions_tool_administration.php');
|
|
require_once(NELTOOL_SYSTEMBASE. 'nel/admin_modules_itf.php');
|
|
|
|
// lets set up the database
|
|
$db = new sql_db(NELTOOL_DBHOST, NELTOOL_DBUSER, NELTOOL_DBPASS, NELTOOL_DBNAME);
|
|
if (!is_object($db)) die("error on db init");
|
|
|
|
// lets set up the smarty template engine
|
|
$tpl = new Smarty;
|
|
if (!is_object($tpl)) die("error on smarty init");
|
|
|
|
$iPhone = (strstr($_SERVER['HTTP_USER_AGENT'], "iPhone") !== FALSE);
|
|
$tpl->assign('iPhone', $iPhone);
|
|
|
|
$tpl->template_dir = NELTOOL_SYSTEMBASE .'/templates/default/';
|
|
$tpl->compile_dir = NELTOOL_SYSTEMBASE .'/templates/default_c/';
|
|
$tpl->config_dir = NELTOOL_SYSTEMBASE .'/templates/config/';
|
|
$tpl->cache_dir = NELTOOL_SYSTEMBASE .'/templates/cache/';
|
|
|
|
$tpl->caching = false;
|
|
$tpl->clear_all_cache();
|
|
if (NELTOOL_DEBUG) $tpl->debugging = false;
|
|
|
|
if (defined('NELTOOL_NO_USER_NEEDED'))
|
|
{
|
|
// this is used for cron jobs that don't need authentifications when running
|
|
}
|
|
else
|
|
{
|
|
nt_auth_start_session();
|
|
|
|
$NELTOOL = array(
|
|
'POST_VARS' => &$_POST,
|
|
'GET_VARS' => &$_GET,
|
|
'COOKIE_VARS' => &$_COOKIE,
|
|
'SESSION_VARS' => &$_SESSION,
|
|
'SERVER_VARS' => &$_SERVER,
|
|
);
|
|
|
|
$nel_user = null;
|
|
$nel_debug = array();
|
|
|
|
nt_common_add_debug(date("Y-m-d H:i:s",time()));
|
|
nt_common_add_debug('-- Basic init complete, time to get some work done.');
|
|
|
|
|
|
// login and session process
|
|
if (isset($NELTOOL['GET_VARS']['mode']) && ($NELTOOL['GET_VARS']['mode'] == 'logout'))
|
|
{
|
|
$nel_user = null;
|
|
nt_auth_stop_session();
|
|
nt_common_redirect('');
|
|
exit();
|
|
}
|
|
elseif (isset($NELTOOL['SESSION_VARS']['nelid']) && !empty($NELTOOL['SESSION_VARS']['nelid']))
|
|
{
|
|
$nel_user = nt_auth_load_user($NELTOOL['SESSION_VARS']['nelid']);
|
|
}
|
|
elseif (isset($NELTOOL['POST_VARS']['nel_login']) && isset($NELTOOL['POST_VARS']['nel_passwd']) && ($NELTOOL['POST_VARS']['action'] == 'login'))
|
|
{
|
|
$nel_user = nt_auth_check_login($NELTOOL['POST_VARS']['nel_login'], $NELTOOL['POST_VARS']['nel_passwd']);
|
|
if ($nel_user)
|
|
{
|
|
nt_auth_set_session_var('nelid',$nel_user['user_id']);
|
|
nt_auth_set_logging_count($nel_user['user_id']);
|
|
$nel_user['new_login'] = true;
|
|
}
|
|
}
|
|
|
|
if (!$nel_user)
|
|
{
|
|
nt_auth_load_login();
|
|
exit();
|
|
}
|
|
|
|
nt_common_add_debug('-- User authentification complete.');
|
|
|
|
// some site settings
|
|
|
|
if (NELTOOL_DEBUG && ($nel_user['group_level'] == 10)) // need to use the array instead of the value being hardcoded
|
|
{
|
|
$tpl->assign('NELTOOL_DEBUG', true); //$nel_debug);
|
|
}
|
|
|
|
$tpl->assign('nel_script', $NELTOOL['SERVER_VARS']['SCRIPT_NAME']);
|
|
$tpl->assign('nel_request_uri', basename($NELTOOL['SERVER_VARS']['REQUEST_URI']));
|
|
$tpl->assign('nel_tool_title', NELTOOL_SITETITLE);
|
|
$tpl->assign('nel_web_base_uri', NELTOOL_SITEBASE);
|
|
|
|
$tpl->assign('tool_title', "<unknown>");
|
|
$tpl->assign('user_info', $nel_user['user_name'] .' ('. $nel_user['group_name'] .')');
|
|
|
|
// load user & group applications/domains/shards
|
|
|
|
$nel_user['access'] = array(
|
|
'applications' => tool_admin_applications_get_list(),
|
|
'user_applications' => tool_admin_users_applications_get_list($nel_user['user_id']),
|
|
'user_domains' => tool_admin_users_domains_get_list($nel_user['user_id']),
|
|
'user_shards' => tool_admin_users_shards_get_list($nel_user['user_id']),
|
|
'group_applications' => tool_admin_groups_applications_get_list($nel_user['user_group_id']),
|
|
'group_domains' => tool_admin_groups_domains_get_list($nel_user['user_group_id']),
|
|
'group_shards' => tool_admin_groups_shards_get_list($nel_user['user_group_id']),
|
|
);
|
|
|
|
$nel_user['access']['domains'] = tool_admin_users_groups_domains_merge();
|
|
$nel_user['access']['shards'] = tool_admin_users_groups_shards_merge();
|
|
$nel_user['has_lock'] = false;
|
|
|
|
//nt_common_add_debug($nel_user);
|
|
|
|
// load the user application menu
|
|
|
|
$tool_application_list = tool_admin_applications_build_menu_list($nel_user['access']);
|
|
$tpl->assign('nel_menu', $tool_application_list);
|
|
$tpl->assign('menu_style', $nel_user['user_menu_style']);
|
|
$tpl->assign('unknown_menu', 'imgs/icon_unknown.png');
|
|
|
|
if (isset($nel_user['new_login']))
|
|
{
|
|
$default_user_application_id = 0;
|
|
if (isset( $nel_user['user_default_application_id']) &&($nel_user['user_default_application_id'] > 0)) {
|
|
$default_user_application_id = $nel_user['user_default_application_id'];
|
|
}elseif (isset( $nel_user['group_default_application_id']) &&($nel_user['group_default_application_id'] > 0)) {
|
|
$default_user_application_id = $nel_user['group_default_application_id'];
|
|
}
|
|
|
|
if ($default_user_application_id > 0)
|
|
{
|
|
nt_common_add_debug("default application : user:". $nel_user['user_default_application_id'] ." group:". $nel_user['group_default_application_id']);
|
|
$default_user_application_data = tool_admin_applications_get_default($tool_application_list, $default_user_application_id);
|
|
nt_common_redirect($default_user_application_data['application_uri']);
|
|
exit();
|
|
}
|
|
}
|
|
|
|
$nel_tool_extra_css = '';
|
|
if (BG_IMG !== null)
|
|
{
|
|
$nel_tool_extra_css .= "<style><!--\n";
|
|
$nel_tool_extra_css .= "body { background: url(". BG_IMG ."); }\n";
|
|
$nel_tool_extra_css .= "--></style>\n";
|
|
}
|
|
$tpl->assign('nel_tool_extra_css', $nel_tool_extra_css);
|
|
$tpl->assign('system_time', time());
|
|
|
|
nt_common_add_debug('-- Common init. complete.');
|
|
}
|
|
|
|
?>
|