You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
167 lines
5.8 KiB
PHP
167 lines
5.8 KiB
PHP
<?php
|
|
require_once realpath(__DIR__ . '/../includes/engelsystem_provider.php');
|
|
|
|
// JSON Authorisierung gewünscht?
|
|
if (isset($_REQUEST['auth']))
|
|
json_auth_service();
|
|
|
|
$free_pages = array(
|
|
'stats',
|
|
'shifts_json_export_all',
|
|
'user_password_recovery',
|
|
'api',
|
|
'credits',
|
|
'angeltypes',
|
|
'users',
|
|
'ical',
|
|
'shifts_json_export',
|
|
'shifts',
|
|
'atom'
|
|
);
|
|
|
|
// Gewünschte Seite/Funktion
|
|
$p = "";
|
|
if (! isset($_REQUEST['p']))
|
|
$_REQUEST['p'] = isset($user) ? "news" : "login";
|
|
if (isset($_REQUEST['p']) && preg_match("/^[a-z0-9_]*$/i", $_REQUEST['p']) && (in_array($_REQUEST['p'], $free_pages) || in_array($_REQUEST['p'], $privileges))) {
|
|
$p = $_REQUEST['p'];
|
|
|
|
$title = $p;
|
|
$content = "";
|
|
|
|
if ($p == "api") {
|
|
require_once realpath(__DIR__ . '/../includes/controller/api.php');
|
|
error("Api disabled temporily.");
|
|
redirect(page_link_to('login'));
|
|
api_controller();
|
|
} elseif ($p == "ical") {
|
|
require_once realpath(__DIR__ . '/../includes/pages/user_ical.php');
|
|
user_ical();
|
|
} elseif ($p == "atom") {
|
|
require_once realpath(__DIR__ . '/../includes/pages/user_atom.php');
|
|
user_atom();
|
|
} elseif ($p == "shifts_json_export") {
|
|
require_once realpath(__DIR__ . '/../includes/controller/shifts_controller.php');
|
|
shifts_json_export_controller();
|
|
} elseif ($p == "shifts_json_export_all") {
|
|
require_once realpath(__DIR__ . '/../includes/controller/shifts_controller.php');
|
|
shifts_json_export_all_controller();
|
|
} elseif ($p == "stats") {
|
|
require_once realpath(__DIR__ . '/../includes/pages/guest_stats.php');
|
|
guest_stats();
|
|
} elseif ($p == "user_password_recovery") {
|
|
require_once realpath(__DIR__ . '/../includes/controller/users_controller.php');
|
|
$title = user_password_recovery_title();
|
|
$content = user_password_recovery_controller();
|
|
} elseif ($p == "angeltypes") {
|
|
list($title, $content) = angeltypes_controller();
|
|
} elseif ($p == "shifts") {
|
|
list($title, $content) = shifts_controller();
|
|
} elseif ($p == "users") {
|
|
list($title, $content) = users_controller();
|
|
} elseif ($p == "user_angeltypes") {
|
|
list($title, $content) = user_angeltypes_controller();
|
|
} elseif ($p == "shifttypes") {
|
|
list($title, $content) = shifttypes_controller();
|
|
} elseif ($p == "news") {
|
|
$title = news_title();
|
|
$content = user_news();
|
|
} elseif ($p == "news_comments") {
|
|
require_once realpath(__DIR__ . '/../includes/pages/user_news.php');
|
|
$title = user_news_comments_title();
|
|
$content = user_news_comments();
|
|
} elseif ($p == "user_meetings") {
|
|
$title = meetings_title();
|
|
$content = user_meetings();
|
|
} elseif ($p == "user_myshifts") {
|
|
$title = myshifts_title();
|
|
$content = user_myshifts();
|
|
} elseif ($p == "user_shifts") {
|
|
$title = shifts_title();
|
|
$content = user_shifts();
|
|
} elseif ($p == "user_messages") {
|
|
$title = messages_title();
|
|
$content = user_messages();
|
|
} elseif ($p == "user_questions") {
|
|
$title = questions_title();
|
|
$content = user_questions();
|
|
} elseif ($p == "user_settings") {
|
|
$title = settings_title();
|
|
$content = user_settings();
|
|
} elseif ($p == "login") {
|
|
$title = login_title();
|
|
$content = guest_login();
|
|
} elseif ($p == "register") {
|
|
$title = register_title();
|
|
$content = guest_register();
|
|
} elseif ($p == "logout") {
|
|
$title = logout_title();
|
|
$content = guest_logout();
|
|
} elseif ($p == "admin_questions") {
|
|
$title = admin_questions_title();
|
|
$content = admin_questions();
|
|
} elseif ($p == "admin_user") {
|
|
$title = admin_user_title();
|
|
$content = admin_user();
|
|
} elseif ($p == "admin_arrive") {
|
|
$title = admin_arrive_title();
|
|
$content = admin_arrive();
|
|
} elseif ($p == "admin_active") {
|
|
$title = admin_active_title();
|
|
$content = admin_active();
|
|
} elseif ($p == "admin_free") {
|
|
$title = admin_free_title();
|
|
$content = admin_free();
|
|
} elseif ($p == "admin_news") {
|
|
require_once realpath(__DIR__ . '/../includes/pages/admin_news.php');
|
|
$content = admin_news();
|
|
} elseif ($p == "admin_rooms") {
|
|
$title = admin_rooms_title();
|
|
$content = admin_rooms();
|
|
} elseif ($p == "admin_groups") {
|
|
$title = admin_groups_title();
|
|
$content = admin_groups();
|
|
} elseif ($p == "admin_language") {
|
|
require_once realpath(__DIR__ . '/../includes/pages/admin_language.php');
|
|
$content = admin_language();
|
|
} elseif ($p == "admin_import") {
|
|
$title = admin_import_title();
|
|
$content = admin_import();
|
|
} elseif ($p == "admin_shifts") {
|
|
$title = admin_shifts_title();
|
|
$content = admin_shifts();
|
|
} elseif ($p == "admin_log") {
|
|
$title = admin_log_title();
|
|
$content = admin_log();
|
|
} elseif ($p == "credits") {
|
|
require_once realpath(__DIR__ . '/../includes/pages/guest_credits.php');
|
|
$title = credits_title();
|
|
$content = guest_credits();
|
|
} else {
|
|
require_once realpath(__DIR__ . '/../includes/pages/guest_start.php');
|
|
$content = guest_start();
|
|
}
|
|
} else {
|
|
// Wenn schon eingeloggt, keine-Berechtigung-Seite anzeigen
|
|
if (isset($user)) {
|
|
$title = _("No Access");
|
|
$content = _("You don't have permission to view this page. You probably have to sign in or register in order to gain access!");
|
|
} else {
|
|
// Sonst zur Loginseite leiten
|
|
redirect(page_link_to("login"));
|
|
}
|
|
}
|
|
|
|
echo template_render('../templates/layout.html', array(
|
|
'theme' => isset($user) ? $user['color'] : $default_theme,
|
|
'title' => $title,
|
|
'atom_link' => ($p == 'news' || $p == 'user_meetings') ? '<link href="' . page_link_to('atom') . (($p == 'user_meetings') ? '&meetings=1' : '') . '&key=' . $user['api_key'] . '" type="application/atom+xml" rel="alternate" title="Atom Feed">' : '',
|
|
'menu' => make_menu(),
|
|
'content' => msg() . $content,
|
|
'header_toolbar' => header_toolbar(),
|
|
'faq_url' => $faq_url,
|
|
'locale' => $_SESSION['locale']
|
|
));
|
|
|
|
?>
|