engelsystem/public/index.php

210 lines
6.3 KiB
PHP
Raw Normal View History

<?php
2011-06-01 14:30:29 +02:00
require_once ('bootstrap.php');
2011-06-02 00:48:29 +02:00
require_once ('includes/sys_auth.php');
2011-06-02 01:09:03 +02:00
require_once ('includes/sys_counter.php');
2011-06-02 00:48:29 +02:00
require_once ('includes/sys_lang.php');
2012-12-26 14:02:27 +01:00
require_once ('includes/sys_log.php');
2011-06-02 00:48:29 +02:00
require_once ('includes/sys_menu.php');
require_once ('includes/sys_mysql.php');
require_once ('includes/sys_page.php');
2011-06-02 16:56:45 +02:00
require_once ('includes/sys_shift.php');
2011-06-02 00:48:29 +02:00
require_once ('includes/sys_template.php');
2011-06-02 01:45:19 +02:00
require_once ('includes/sys_user.php');
2012-12-26 20:36:31 +01:00
require_once ('includes/model/LogEntries_model.php');
require_once ('includes/model/User_model.php');
2011-06-02 00:48:29 +02:00
require_once ('config/config.php');
require_once ('config/config_db.php');
2011-06-03 00:22:11 +02:00
require_once ('includes/pages/admin_questions.php');
2011-12-26 19:28:34 +01:00
require_once ('includes/pages/admin_user_angeltypes.php');
2011-06-02 21:38:19 +02:00
require_once ('includes/pages/user_messages.php');
2011-06-02 00:48:29 +02:00
session_start();
2011-06-02 00:48:29 +02:00
sql_connect($config['host'], $config['user'], $config['pw'], $config['db']);
2011-06-02 00:48:29 +02:00
load_auth();
2011-06-01 14:30:29 +02:00
2011-06-03 15:30:17 +02:00
// JSON Authorisierung gewünscht?
if (isset ($_REQUEST['auth']))
json_auth_service();
2011-06-02 00:48:29 +02:00
// Gewünschte Seite/Funktion
2011-09-14 22:19:10 +02:00
$p = isset ($user) ? "news" : "login";
2012-12-28 22:53:05 +01:00
if (isset ($_REQUEST['p']) && preg_match("/^[a-z0-9_]*$/i", $_REQUEST['p']) && ($_REQUEST['p'] == 'stats' || (sql_num_query("SELECT * FROM `Privileges` WHERE `name`='" . sql_escape($_REQUEST['p']) . "' LIMIT 1") > 0)))
2011-06-02 00:48:29 +02:00
$p = $_REQUEST['p'];
$title = Get_Text($p);
$content = "";
2011-10-11 19:47:49 +02:00
if ($p == "ical") {
require_once ('includes/pages/user_ical.php');
user_ical();
}
2012-12-26 20:39:54 +01:00
elseif ($p == "atom") {
require_once ('includes/pages/user_atom.php');
user_atom();
}
2012-12-28 22:53:05 +01:00
elseif ($p == "stats") {
require_once ('includes/pages/guest_stats.php');
guest_stats();
}
2011-06-02 00:48:29 +02:00
// Recht dafür vorhanden?
2011-10-11 19:47:49 +02:00
elseif (in_array($p, $privileges)) {
2011-06-02 00:48:29 +02:00
if ($p == "news") {
2011-06-02 01:45:19 +02:00
require_once ('includes/pages/user_news.php');
$content = user_news();
2011-06-02 00:48:29 +02:00
}
2011-06-03 05:12:50 +02:00
elseif ($p == "news_comments") {
require_once ('includes/pages/user_news.php');
$content = user_news_comments();
}
2011-06-03 06:47:35 +02:00
elseif ($p == "user_meetings") {
require_once ('includes/pages/user_news.php');
$content = user_meetings();
}
2011-07-15 17:50:57 +02:00
elseif ($p == "user_myshifts") {
require_once ('includes/pages/user_myshifts.php');
$content = user_myshifts();
}
2011-07-13 14:29:40 +02:00
elseif ($p == "user_shifts") {
require_once ('includes/pages/user_shifts.php');
$content = user_shifts();
}
2011-06-02 21:38:19 +02:00
elseif ($p == "user_messages") {
$content = user_messages();
}
2011-06-02 23:45:54 +02:00
elseif ($p == "user_questions") {
require_once ('includes/pages/user_questions.php');
$content = user_questions();
}
2011-06-03 16:22:33 +02:00
elseif ($p == "user_wakeup") {
require_once ('includes/pages/user_wakeup.php');
$content = user_wakeup();
}
2011-06-02 20:18:01 +02:00
elseif ($p == "user_settings") {
require_once ('includes/pages/user_settings.php');
$content = user_settings();
}
2011-06-02 00:48:29 +02:00
elseif ($p == "login") {
require_once ('includes/pages/guest_login.php');
$content = guest_login();
}
elseif ($p == "register") {
require_once ('includes/pages/guest_login.php');
$content = guest_register();
}
elseif ($p == "logout") {
require_once ('includes/pages/guest_login.php');
$content = guest_logout();
2011-06-02 16:56:45 +02:00
}
2011-06-03 00:22:11 +02:00
elseif ($p == "admin_questions") {
$content = admin_questions();
}
2011-06-03 06:40:29 +02:00
elseif ($p == "admin_user") {
require_once ('includes/pages/admin_user.php');
$content = admin_user();
}
2011-12-26 19:28:34 +01:00
elseif ($p == "admin_user_angeltypes") {
require_once ('includes/pages/admin_user_angeltypes.php');
$content = admin_user_angeltypes();
}
elseif ($p == "admin_arrive") {
require_once ('includes/pages/admin_arrive.php');
$content = admin_arrive();
}
2011-12-17 15:18:13 +01:00
elseif ($p == "admin_active") {
require_once ('includes/pages/admin_active.php');
$content = admin_active();
}
elseif ($p == "admin_free") {
require_once ('includes/pages/admin_free.php');
$content = admin_free();
}
2011-06-03 05:49:56 +02:00
elseif ($p == "admin_news") {
require_once ('includes/pages/admin_news.php');
$content = admin_news();
}
2011-06-02 17:30:17 +02:00
elseif ($p == "admin_angel_types") {
require_once ('includes/pages/admin_angel_types.php');
$content = admin_angel_types();
}
2011-06-02 16:56:45 +02:00
elseif ($p == "admin_rooms") {
require_once ('includes/pages/admin_rooms.php');
$content = admin_rooms();
2011-06-02 22:40:08 +02:00
}
elseif ($p == "admin_groups") {
require_once ('includes/pages/admin_groups.php');
$content = admin_groups();
2011-06-03 15:30:17 +02:00
}
2011-06-03 01:03:39 +02:00
elseif ($p == "admin_faq") {
require_once ('includes/pages/admin_faq.php');
$content = admin_faq();
2011-06-03 15:30:17 +02:00
}
2011-06-03 14:38:12 +02:00
elseif ($p == "admin_language") {
require_once ('includes/pages/admin_language.php');
$content = admin_language();
2011-06-03 15:30:17 +02:00
}
2011-06-03 16:52:57 +02:00
elseif ($p == "admin_import") {
require_once ('includes/pages/admin_import.php');
$content = admin_import();
}
2011-09-06 20:45:06 +02:00
elseif ($p == "admin_shifts") {
require_once ('includes/pages/admin_shifts.php');
$content = admin_shifts();
}
2011-06-03 14:44:01 +02:00
elseif ($p == "admin_log") {
require_once ('includes/pages/admin_log.php');
$content = admin_log();
2011-06-02 00:48:29 +02:00
} else {
require_once ('includes/pages/guest_start.php');
$content = guest_start();
}
}
elseif ($p == "credits") {
require_once ('includes/pages/guest_credits.php');
$content = guest_credits();
}
elseif ($p == "faq") {
require_once ('includes/pages/guest_faq.php');
$content = guest_faq();
} else {
// Wenn schon eingeloggt, keine-Berechtigung-Seite anzeigen
if (isset ($user)) {
$title = Get_Text("no_access_title");
$content = Get_Text("no_access_text");
} else {
// Sonst zur Loginseite leiten
2011-12-28 14:45:49 +01:00
redirect(page_link_to("login"));
2011-06-02 00:48:29 +02:00
}
}
2011-06-02 21:38:19 +02:00
// Hinweis für ungelesene Nachrichten
if (isset ($user) && $p != "user_messages")
$content = user_unread_messages() . $content;
2012-12-30 18:04:20 +01:00
// Hinweis für Engel, die noch nicht angekommen sind
if(isset($user) && $user['Gekommen'] == 0)
$content = error("You are not marked as arrived. Please go to heaven's desk, get your angel badge and/or tell them that you arrived already.", true) . $content;
2011-06-03 00:22:11 +02:00
// Erzengel Hinweis für unbeantwortete Fragen
if (isset ($user) && $p != "admin_questions")
$content = admin_new_questions() . $content;
2011-12-26 19:28:34 +01:00
// Erzengel Hinweis für freizuschaltende Engeltypen
if (isset ($user) && $p != "admin_user_angeltypes")
$content = admin_new_user_angeltypes() . $content;
2011-06-02 00:48:29 +02:00
echo template_render('../templates/layout.html', array (
'theme' => isset ($user) ? $user['color'] : $default_theme,
'title' => $title,
2012-12-26 20:39:54 +01:00
'atom_link' => ($p == 'news' || $p == 'user_meetings')? '<link href="' . page_link_to('atom') . (($p == 'user_meetings')? '&amp;meetings=1' : '') . '&amp;key=' . $user['ical_key'] . '" type="application/atom+xml" rel="alternate" title="Atom Feed">' : '',
2011-06-02 00:48:29 +02:00
'menu' => make_menu(),
'content' => $content
));
2011-06-02 01:09:03 +02:00
counter();
?>