2005-09-10 19:25:43 +02:00
< ? php
2011-06-01 14:30:29 +02:00
require_once ( 'bootstrap.php' );
2013-09-18 01:38:36 +02:00
require_once ( 'includes/mysql_provider.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' );
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_page.php' );
require_once ( 'includes/sys_template.php' );
2005-09-10 19:25:43 +02:00
2014-01-05 19:30:06 +01:00
require_once ( 'includes/model/AngelType_model.php' );
2012-12-26 20:36:31 +01:00
require_once ( 'includes/model/LogEntries_model.php' );
2014-01-05 19:30:06 +01:00
require_once ( 'includes/model/Message_model.php' );
2013-12-09 17:10:07 +01:00
require_once ( 'includes/model/NeededAngelTypes_model.php' );
2014-01-05 19:30:06 +01:00
require_once ( 'includes/model/Room_model.php' );
2013-12-09 17:17:23 +01:00
require_once ( 'includes/model/ShiftEntry_model.php' );
2013-12-09 17:10:07 +01:00
require_once ( 'includes/model/Shifts_model.php' );
2014-01-05 19:30:06 +01:00
require_once ( 'includes/model/UserAngelTypes_model.php' );
2012-12-26 20:36:31 +01:00
require_once ( 'includes/model/User_model.php' );
2014-01-05 19:30:06 +01:00
require_once ( 'includes/view/AngelTypes_view.php' );
2013-11-25 21:56:56 +01:00
require_once ( 'includes/view/Questions_view.php' );
2013-09-18 01:38:36 +02:00
require_once ( 'includes/view/Shifts_view.php' );
2013-11-25 21:56:56 +01:00
require_once ( 'includes/view/ShiftEntry_view.php' );
2014-01-05 19:30:06 +01:00
require_once ( 'includes/view/UserAngelTypes_view.php' );
2013-09-18 01:38:36 +02:00
require_once ( 'includes/view/User_view.php' );
2014-01-05 19:30:06 +01:00
require_once ( 'includes/controller/angeltypes_controller.php' );
require_once ( 'includes/controller/user_angeltypes_controller.php' );
2013-11-25 19:12:19 +01:00
require_once ( 'includes/helper/internationalization_helper.php' );
2013-09-18 01:38:36 +02:00
require_once ( 'includes/helper/message_helper.php' );
require_once ( 'includes/helper/error_helper.php' );
2013-12-26 13:34:48 +01:00
require_once ( 'includes/helper/email_helper.php' );
2013-09-18 01:38:36 +02:00
2013-12-03 16:18:22 +01:00
require_once ( 'config/config.default.php' );
2013-12-09 17:17:23 +01:00
if ( file_exists ( '../config/config.php' ))
2013-12-03 16:18:22 +01:00
require_once ( 'config/config.php' );
2005-09-10 19:25:43 +02:00
2013-11-25 21:04:58 +01:00
require_once ( 'includes/pages/admin_active.php' );
require_once ( 'includes/pages/admin_arrive.php' );
require_once ( 'includes/pages/admin_free.php' );
require_once ( 'includes/pages/admin_groups.php' );
require_once ( 'includes/pages/admin_import.php' );
require_once ( 'includes/pages/admin_log.php' );
2011-06-03 00:22:11 +02:00
require_once ( 'includes/pages/admin_questions.php' );
2013-11-25 21:04:58 +01:00
require_once ( 'includes/pages/admin_rooms.php' );
require_once ( 'includes/pages/admin_shifts.php' );
require_once ( 'includes/pages/admin_user.php' );
2011-12-26 19:28:34 +01:00
require_once ( 'includes/pages/admin_user_angeltypes.php' );
2013-11-25 21:56:56 +01:00
require_once ( 'includes/pages/guest_login.php' );
2011-06-02 21:38:19 +02:00
require_once ( 'includes/pages/user_messages.php' );
2013-11-25 21:04:58 +01:00
require_once ( 'includes/pages/user_myshifts.php' );
require_once ( 'includes/pages/user_news.php' );
require_once ( 'includes/pages/user_questions.php' );
2013-11-25 21:56:56 +01:00
require_once ( 'includes/pages/user_settings.php' );
2013-11-25 21:04:58 +01:00
require_once ( 'includes/pages/user_shifts.php' );
require_once ( 'includes/pages/user_wakeup.php' );
2011-06-02 21:38:19 +02:00
2011-06-02 00:48:29 +02:00
session_start ();
2005-09-10 19:25:43 +02:00
2013-11-25 19:12:19 +01:00
gettext_init ();
2011-06-02 00:48:29 +02:00
sql_connect ( $config [ 'host' ], $config [ 'user' ], $config [ 'pw' ], $config [ 'db' ]);
2005-09-10 19:25:43 +02:00
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?
2013-10-13 00:52:44 +02:00
if ( isset ( $_REQUEST [ 'auth' ]))
2013-09-10 14:27:31 +02:00
json_auth_service ();
2013-12-09 17:10:07 +01:00
2013-12-26 13:34:48 +01:00
$free_pages = array (
2013-12-09 17:10:07 +01:00
'stats' ,
2013-12-26 13:34:48 +01:00
'shifts_json_export_all' ,
2013-12-29 15:08:21 +01:00
'user_password_recovery' ,
2014-01-05 19:30:06 +01:00
'api' ,
'credits'
2013-12-09 17:10:07 +01:00
);
// Gewünschte Seite/Funktion
2013-12-26 17:31:05 +01:00
if ( ! isset ( $_REQUEST [ 'p' ]))
2013-12-26 17:29:29 +01:00
$_REQUEST [ 'p' ] = isset ( $user ) ? " news " : " login " ;
2013-12-26 13:34:48 +01:00
if ( isset ( $_REQUEST [ 'p' ]) && preg_match ( " /^[a-z0-9_]* $ /i " , $_REQUEST [ 'p' ]) && ( in_array ( $_REQUEST [ 'p' ], $free_pages ) || in_array ( $_REQUEST [ 'p' ], $privileges ))) {
2013-09-10 14:27:31 +02:00
$p = $_REQUEST [ 'p' ];
2013-12-26 13:34:48 +01:00
$title = $p ;
$content = " " ;
2013-12-29 15:08:21 +01:00
if ( $p == " api " ) {
require_once ( 'includes/controller/api.php' );
2013-12-29 15:24:54 +01:00
error ( " Api disabled temporily. " );
redirect ( page_link_to ( 'login' ));
2014-01-05 19:30:06 +01:00
// api_controller();
2013-12-29 15:08:21 +01:00
} elseif ( $p == " ical " ) {
2013-12-26 13:34:48 +01:00
require_once ( 'includes/pages/user_ical.php' );
user_ical ();
} elseif ( $p == " atom " ) {
require_once ( 'includes/pages/user_atom.php' );
user_atom ();
} elseif ( $p == " shifts_json_export " ) {
require_once ( 'includes/controller/shifts_controller.php' );
shifts_json_export_controller ();
} elseif ( $p == " shifts_json_export_all " ) {
require_once ( 'includes/controller/shifts_controller.php' );
shifts_json_export_all_controller ();
} elseif ( $p == " stats " ) {
require_once ( 'includes/pages/guest_stats.php' );
guest_stats ();
} elseif ( $p == " user_password_recovery " ) {
require_once ( 'includes/controller/users_controller.php' );
$title = user_password_recovery_title ();
$content = user_password_recovery_controller ();
2014-01-05 19:30:06 +01:00
} elseif ( $p == " angeltypes " ) {
list ( $title , $content ) = angeltypes_controller ();
} elseif ( $p == " user_angeltypes " ) {
list ( $title , $content ) = user_angeltypes_controller ();
2013-12-26 13:34:48 +01:00
} elseif ( $p == " news " ) {
2013-11-25 21:04:58 +01:00
$title = news_title ();
2013-09-10 14:27:31 +02:00
$content = user_news ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " news_comments " ) {
2013-09-10 14:27:31 +02:00
require_once ( 'includes/pages/user_news.php' );
2013-11-25 21:56:56 +01:00
$title = user_news_comments_title ();
2013-09-10 14:27:31 +02:00
$content = user_news_comments ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " user_meetings " ) {
2013-11-25 21:04:58 +01:00
$title = meetings_title ();
2013-09-10 14:27:31 +02:00
$content = user_meetings ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " user_myshifts " ) {
2013-11-25 21:04:58 +01:00
$title = myshifts_title ();
2013-09-10 14:27:31 +02:00
$content = user_myshifts ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " user_shifts " ) {
2013-11-25 21:04:58 +01:00
$title = shifts_title ();
2013-09-10 14:27:31 +02:00
$content = user_shifts ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " user_messages " ) {
2013-11-25 21:04:58 +01:00
$title = messages_title ();
2013-09-10 14:27:31 +02:00
$content = user_messages ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " user_questions " ) {
2013-11-25 21:04:58 +01:00
$title = questions_title ();
2013-09-10 14:27:31 +02:00
$content = user_questions ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " user_wakeup " ) {
2013-11-25 21:04:58 +01:00
$title = wakeup_title ();
2013-09-10 14:27:31 +02:00
$content = user_wakeup ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " user_settings " ) {
2013-11-25 21:56:56 +01:00
$title = settings_title ();
2013-09-10 14:27:31 +02:00
$content = user_settings ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " login " ) {
2013-11-25 21:56:56 +01:00
$title = login_title ();
2013-09-10 14:27:31 +02:00
$content = guest_login ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " register " ) {
2013-11-25 21:56:56 +01:00
$title = register_title ();
2013-09-10 14:27:31 +02:00
$content = guest_register ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " logout " ) {
2013-11-25 21:56:56 +01:00
$title = logout_title ();
2013-09-10 14:27:31 +02:00
$content = guest_logout ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_questions " ) {
2013-11-25 21:04:58 +01:00
$title = admin_questions_title ();
2013-09-10 14:27:31 +02:00
$content = admin_questions ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_user " ) {
2013-11-25 21:04:58 +01:00
$title = admin_user_title ();
2013-09-10 14:27:31 +02:00
$content = admin_user ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_user_angeltypes " ) {
2013-11-25 21:04:58 +01:00
$title = admin_user_angeltypes_title ();
2013-09-10 14:27:31 +02:00
$content = admin_user_angeltypes ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_arrive " ) {
2013-11-25 21:04:58 +01:00
$title = admin_arrive_title ();
2013-09-10 14:27:31 +02:00
$content = admin_arrive ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_active " ) {
2013-11-25 21:04:58 +01:00
$title = admin_active_title ();
2013-09-10 14:27:31 +02:00
$content = admin_active ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_free " ) {
2013-11-25 21:04:58 +01:00
$title = admin_free_title ();
2013-09-10 14:27:31 +02:00
$content = admin_free ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_news " ) {
2013-09-10 14:27:31 +02:00
require_once ( 'includes/pages/admin_news.php' );
$content = admin_news ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_rooms " ) {
2013-11-25 21:04:58 +01:00
$title = admin_rooms_title ();
2013-09-10 14:27:31 +02:00
$content = admin_rooms ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_groups " ) {
2013-11-25 21:04:58 +01:00
$title = admin_groups_title ();
2013-09-10 14:27:31 +02:00
$content = admin_groups ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_language " ) {
2013-09-10 14:27:31 +02:00
require_once ( 'includes/pages/admin_language.php' );
$content = admin_language ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_import " ) {
2013-11-25 21:04:58 +01:00
$title = admin_import_title ();
2013-09-10 14:27:31 +02:00
$content = admin_import ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_shifts " ) {
2013-11-25 21:04:58 +01:00
$title = admin_shifts_title ();
2013-09-10 14:27:31 +02:00
$content = admin_shifts ();
2013-10-13 00:52:44 +02:00
} elseif ( $p == " admin_log " ) {
2013-11-25 21:04:58 +01:00
$title = admin_log_title ();
2013-09-10 14:27:31 +02:00
$content = admin_log ();
2013-12-26 13:34:48 +01:00
} elseif ( $p == " credits " ) {
require_once ( 'includes/pages/guest_credits.php' );
$title = credits_title ();
$content = guest_credits ();
2013-09-10 14:27:31 +02:00
} else {
require_once ( 'includes/pages/guest_start.php' );
$content = guest_start ();
}
2011-06-02 00:48:29 +02:00
} else {
2013-09-10 14:27:31 +02:00
// Wenn schon eingeloggt, keine-Berechtigung-Seite anzeigen
2013-10-13 00:52:44 +02:00
if ( isset ( $user )) {
2013-11-25 21:04:58 +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! " );
2013-09-10 14:27:31 +02:00
} else {
// Sonst zur Loginseite leiten
redirect ( page_link_to ( " login " ));
}
2011-06-02 00:48:29 +02:00
}
2013-12-26 13:34:48 +01:00
if ( isset ( $user )) {
2013-12-27 18:45:27 +01:00
$freeloaded_shifts_count = count ( ShiftEntries_freeloaded_by_user ( $user ));
2014-01-05 19:30:06 +01:00
if ( $freeloaded_shifts_count >= $max_freeloadable_shifts )
2013-12-27 18:45:27 +01:00
$content = error ( sprintf ( _ ( " You freeloaded %s shifts. Shift signup is locked. Please go to heavens desk to be unlocked again. " ), $freeloaded_shifts_count ), true ) . $content ;
2014-01-05 19:30:06 +01:00
// Hinweis für ungelesene Nachrichten
2013-12-26 13:34:48 +01:00
if ( $p != " user_messages " )
$content = user_unread_messages () . $content ;
// Hinweis für Engel, die noch nicht angekommen sind
if ( $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 ;
2013-11-25 19:12:19 +01:00
2013-12-26 13:34:48 +01:00
if ( $enable_tshirt_size && $user [ 'Size' ] == " " )
$content = error ( _ ( " You need to specify a tshirt size in your settings! " ), true ) . $content ;
2013-11-25 19:12:19 +01:00
2013-12-26 13:34:48 +01:00
if ( $user [ 'DECT' ] == " " )
$content = error ( _ ( " You need to specify a DECT phone number in your settings! If you don't have a DECT phone, just enter \" - \" . " ), true ) . $content ;
// Erzengel Hinweis für unbeantwortete Fragen
if ( $p != " admin_questions " )
$content = admin_new_questions () . $content ;
}
2011-12-26 19:28:34 +01:00
2013-11-25 19:12:19 +01:00
echo template_render ( '../templates/layout.html' , array (
2013-10-13 00:52:44 +02:00
'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' => $content ,
2013-12-03 16:28:37 +01:00
'header_toolbar' => header_toolbar (),
2013-12-09 17:10:07 +01:00
'faq_url' => $faq_url
2011-06-02 00:48:29 +02:00
));
2011-06-02 01:09:03 +02:00
counter ();
2005-09-10 19:25:43 +02:00
?>