engelsystem/public/index.php

187 lines
6.7 KiB
PHP
Raw Normal View History

<?php
2015-05-14 16:37:12 +02:00
require_once realpath(__DIR__ . '/../includes/engelsystem_provider.php');
2011-06-01 14:30:29 +02:00
$free_pages = [
'admin_event_config',
'angeltypes',
'api',
'atom',
2014-03-09 13:39:04 +01:00
'credits',
'ical',
'login',
'rooms',
2014-12-19 22:41:55 +01:00
'shifts',
'shifts_json_export',
'shifts_json_export_all',
'stats',
'users',
'user_driver_licenses',
2017-01-02 03:57:23 +01:00
'user_password_recovery'
];
2013-12-09 17:10:07 +01:00
// Gewünschte Seite/Funktion
2017-01-03 03:22:48 +01:00
$page = '';
$title = '';
$content = '';
2017-01-02 15:43:36 +01:00
if (!isset($_REQUEST['p'])) {
2017-01-03 03:22:48 +01:00
$_REQUEST['p'] = isset($user) ? 'news' : 'login';
}
2017-01-02 15:43:36 +01:00
if (
isset($_REQUEST['p'])
2017-01-03 03:22:48 +01:00
&& preg_match('/^[a-z0-9_]*$/i', $_REQUEST['p'])
2017-01-02 15:43:36 +01:00
&& (
in_array($_REQUEST['p'], $free_pages)
2017-01-03 03:22:48 +01:00
|| (isset($privileges) && in_array($_REQUEST['p'], $privileges))
2017-01-02 15:43:36 +01:00
)
) {
2017-01-02 03:57:23 +01:00
$page = $_REQUEST['p'];
2017-01-02 15:43:36 +01:00
2017-01-02 03:57:23 +01:00
$title = $page;
2017-01-02 15:43:36 +01:00
2017-01-03 03:22:48 +01:00
if ($page == 'api') {
error('Api disabled temporily.');
redirect(page_link_to());
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/controller/api.php');
api_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'ical') {
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/pages/user_ical.php');
user_ical();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'atom') {
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/pages/user_atom.php');
user_atom();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'shifts_json_export') {
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/controller/shifts_controller.php');
shifts_json_export_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'shifts_json_export_all') {
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/controller/shifts_controller.php');
shifts_json_export_all_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'stats') {
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/pages/guest_stats.php');
guest_stats();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_password_recovery') {
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/controller/users_controller.php');
$title = user_password_recovery_title();
$content = user_password_recovery_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'angeltypes') {
2017-01-02 03:57:23 +01:00
list($title, $content) = angeltypes_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'shifts') {
2017-01-02 03:57:23 +01:00
list($title, $content) = shifts_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'users') {
2017-01-02 03:57:23 +01:00
list($title, $content) = users_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_angeltypes') {
2017-01-02 03:57:23 +01:00
list($title, $content) = user_angeltypes_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_driver_licenses') {
2017-01-02 03:57:23 +01:00
list($title, $content) = user_driver_licenses_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'shifttypes') {
2017-01-02 03:57:23 +01:00
list($title, $content) = shifttypes_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_event_config') {
2017-01-02 03:57:23 +01:00
list($title, $content) = event_config_edit_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'rooms') {
2017-01-02 03:57:23 +01:00
list($title, $content) = rooms_controller();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'news') {
2017-01-02 03:57:23 +01:00
$title = news_title();
$content = user_news();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'news_comments') {
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/pages/user_news.php');
$title = user_news_comments_title();
$content = user_news_comments();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_meetings') {
2017-01-02 03:57:23 +01:00
$title = meetings_title();
$content = user_meetings();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_myshifts') {
2017-01-02 03:57:23 +01:00
$title = myshifts_title();
$content = user_myshifts();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_shifts') {
2017-01-02 03:57:23 +01:00
$title = shifts_title();
$content = user_shifts();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_messages') {
2017-01-02 03:57:23 +01:00
$title = messages_title();
$content = user_messages();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_questions') {
2017-01-02 03:57:23 +01:00
$title = questions_title();
$content = user_questions();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'user_settings') {
2017-01-02 03:57:23 +01:00
$title = settings_title();
$content = user_settings();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'login') {
2017-01-02 03:57:23 +01:00
$title = login_title();
$content = guest_login();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'register') {
2017-01-02 03:57:23 +01:00
$title = register_title();
$content = guest_register();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'logout') {
2017-01-02 03:57:23 +01:00
$title = logout_title();
$content = guest_logout();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_questions') {
2017-01-02 03:57:23 +01:00
$title = admin_questions_title();
$content = admin_questions();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_user') {
2017-01-02 03:57:23 +01:00
$title = admin_user_title();
$content = admin_user();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_arrive') {
2017-01-02 03:57:23 +01:00
$title = admin_arrive_title();
$content = admin_arrive();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_active') {
2017-01-02 03:57:23 +01:00
$title = admin_active_title();
$content = admin_active();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_free') {
2017-01-02 03:57:23 +01:00
$title = admin_free_title();
$content = admin_free();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_news') {
2017-01-02 03:57:23 +01:00
require_once realpath(__DIR__ . '/../includes/pages/admin_news.php');
$content = admin_news();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_rooms') {
2017-01-02 03:57:23 +01:00
$title = admin_rooms_title();
$content = admin_rooms();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_groups') {
2017-01-02 03:57:23 +01:00
$title = admin_groups_title();
$content = admin_groups();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_import') {
2017-01-02 03:57:23 +01:00
$title = admin_import_title();
$content = admin_import();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_shifts') {
2017-01-02 03:57:23 +01:00
$title = admin_shifts_title();
$content = admin_shifts();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'admin_log') {
2017-01-02 03:57:23 +01:00
$title = admin_log_title();
$content = admin_log();
2017-01-03 03:22:48 +01:00
} elseif ($page == 'credits') {
2017-01-02 03:57:23 +01:00
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();
}
2011-06-02 00:48:29 +02:00
} else {
2017-01-02 03:57:23 +01:00
// Wenn schon eingeloggt, keine-Berechtigung-Seite anzeigen
2017-01-02 15:43:36 +01:00
if (isset($user)) {
2017-01-03 03:22:48 +01:00
$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!');
2017-01-02 15:43:36 +01:00
} else {
// Sonst zur Loginseite leiten
2017-01-03 03:22:48 +01:00
redirect(page_link_to('login'));
2017-01-02 15:43:36 +01:00
}
2011-06-02 00:48:29 +02:00
}
2016-09-29 09:25:06 +02:00
$event_config = EventConfig();
2017-01-01 05:49:02 +01:00
echo template_render(__DIR__ . '/../templates/layout.html', [
2017-01-02 15:43:36 +01:00
'theme' => isset($user) ? $user['color'] : $default_theme,
'title' => $title,
2017-01-03 03:22:48 +01:00
'atom_link' => ($page == 'news' || $page == 'user_meetings')
? ' <link href="' . page_link_to('atom') . (($page == 'user_meetings') ? '&meetings=1' : '')
. '&amp;key=' . (isset($user) ? $user['api_key'] : '')
. '" type = "application/atom+xml" rel = "alternate" title = "Atom Feed">'
: '',
2017-01-02 15:43:36 +01:00
'menu' => make_menu(),
'content' => msg() . $content,
2013-12-03 16:28:37 +01:00
'header_toolbar' => header_toolbar(),
2017-01-02 15:43:36 +01:00
'faq_url' => $faq_url,
'contact_email' => $contact_email,
'locale' => locale(),
2017-01-03 14:12:17 +01:00
'event_info' => EventConfig_info($event_config) . ' <br />'
]);