244 lines
		
	
	
	
		
			7.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			244 lines
		
	
	
	
		
			7.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| use Engelsystem\Http\Request;
 | |
| 
 | |
| require_once realpath(__DIR__ . '/../includes/engelsystem.php');
 | |
| 
 | |
| $free_pages = [
 | |
|     'admin_event_config',
 | |
|     'angeltypes',
 | |
|     'api',
 | |
|     'atom',
 | |
|     'credits',
 | |
|     'ical',
 | |
|     'login',
 | |
|     'public_dashboard',
 | |
|     'rooms',
 | |
|     'shifts',
 | |
|     'shifts_json_export',
 | |
|     'shifts_json_export_all',
 | |
|     'stats',
 | |
|     'users',
 | |
|     'user_driver_licenses',
 | |
|     'user_password_recovery',
 | |
| ];
 | |
| 
 | |
| // Gewünschte Seite/Funktion
 | |
| $page = '';
 | |
| $title = '';
 | |
| $content = '';
 | |
| 
 | |
| /** @var Request $request */
 | |
| $request = $app->get('request');
 | |
| $page = $request->query->get('p');
 | |
| if (empty($page)) {
 | |
|     $page = $request->path();
 | |
|     $page = str_replace('-', '_', $page);
 | |
| }
 | |
| if ($page == '/') {
 | |
|     $page = isset($user) ? 'news' : 'login';
 | |
| }
 | |
| 
 | |
| if (
 | |
|     preg_match('/^\w*$/i', $page)
 | |
|     && (
 | |
|         in_array($page, $free_pages)
 | |
|         || (isset($privileges) && in_array($page, $privileges))
 | |
|     )
 | |
| ) {
 | |
|     $title = $page;
 | |
| 
 | |
|     switch ($page) {
 | |
|         case 'api':
 | |
|             error('Api disabled temporarily.');
 | |
|             redirect(page_link_to());
 | |
|             break;
 | |
|         case 'ical':
 | |
|             require_once realpath(__DIR__ . '/../includes/pages/user_ical.php');
 | |
|             user_ical();
 | |
|             break;
 | |
|         case 'atom':
 | |
|             require_once realpath(__DIR__ . '/../includes/pages/user_atom.php');
 | |
|             user_atom();
 | |
|             break;
 | |
|         case 'shifts_json_export':
 | |
|             require_once realpath(__DIR__ . '/../includes/controller/shifts_controller.php');
 | |
|             shifts_json_export_controller();
 | |
|             break;
 | |
|         case 'shifts_json_export_all':
 | |
|             require_once realpath(__DIR__ . '/../includes/controller/shifts_controller.php');
 | |
|             shifts_json_export_all_controller();
 | |
|             break;
 | |
|         case 'stats':
 | |
|             require_once realpath(__DIR__ . '/../includes/pages/guest_stats.php');
 | |
|             guest_stats();
 | |
|             break;
 | |
|         case 'user_password_recovery':
 | |
|             require_once realpath(__DIR__ . '/../includes/controller/users_controller.php');
 | |
|             $title = user_password_recovery_title();
 | |
|             $content = user_password_recovery_controller();
 | |
|             break;
 | |
|         case 'public_dashboard':
 | |
|             list($title, $content) = public_dashboard_controller();
 | |
|             break;
 | |
|         case 'angeltypes':
 | |
|             list($title, $content) = angeltypes_controller();
 | |
|             break;
 | |
|         case 'shifts':
 | |
|             list($title, $content) = shifts_controller();
 | |
|             break;
 | |
|         case 'users':
 | |
|             list($title, $content) = users_controller();
 | |
|             break;
 | |
|         case 'user_angeltypes':
 | |
|             list($title, $content) = user_angeltypes_controller();
 | |
|             break;
 | |
|         case 'user_driver_licenses':
 | |
|             list($title, $content) = user_driver_licenses_controller();
 | |
|             break;
 | |
|         case 'shifttypes':
 | |
|             list($title, $content) = shifttypes_controller();
 | |
|             break;
 | |
|         case 'admin_event_config':
 | |
|             list($title, $content) = event_config_edit_controller();
 | |
|             break;
 | |
|         case 'rooms':
 | |
|             list($title, $content) = rooms_controller();
 | |
|             break;
 | |
|         case 'news':
 | |
|             $title = news_title();
 | |
|             $content = user_news();
 | |
|             break;
 | |
|         case 'news_comments':
 | |
|             require_once realpath(__DIR__ . '/../includes/pages/user_news.php');
 | |
|             $title = user_news_comments_title();
 | |
|             $content = user_news_comments();
 | |
|             break;
 | |
|         case 'user_meetings':
 | |
|             $title = meetings_title();
 | |
|             $content = user_meetings();
 | |
|             break;
 | |
|         case 'user_myshifts':
 | |
|             $title = myshifts_title();
 | |
|             $content = user_myshifts();
 | |
|             break;
 | |
|         case 'user_shifts':
 | |
|             $title = shifts_title();
 | |
|             $content = user_shifts();
 | |
|             break;
 | |
|         case 'user_messages':
 | |
|             $title = messages_title();
 | |
|             $content = user_messages();
 | |
|             break;
 | |
|         case 'user_questions':
 | |
|             $title = questions_title();
 | |
|             $content = user_questions();
 | |
|             break;
 | |
|         case 'user_settings':
 | |
|             $title = settings_title();
 | |
|             $content = user_settings();
 | |
|             break;
 | |
|         case 'login':
 | |
|             $title = login_title();
 | |
|             $content = guest_login();
 | |
|             break;
 | |
|         case 'register':
 | |
|             $title = register_title();
 | |
|             $content = guest_register();
 | |
|             break;
 | |
|         case 'logout':
 | |
|             $title = logout_title();
 | |
|             $content = guest_logout();
 | |
|             break;
 | |
|         case 'admin_questions':
 | |
|             $title = admin_questions_title();
 | |
|             $content = admin_questions();
 | |
|             break;
 | |
|         case 'admin_user':
 | |
|             $title = admin_user_title();
 | |
|             $content = admin_user();
 | |
|             break;
 | |
|         case 'admin_arrive':
 | |
|             $title = admin_arrive_title();
 | |
|             $content = admin_arrive();
 | |
|             break;
 | |
|         case 'admin_active':
 | |
|             $title = admin_active_title();
 | |
|             $content = admin_active();
 | |
|             break;
 | |
|         case 'admin_free':
 | |
|             $title = admin_free_title();
 | |
|             $content = admin_free();
 | |
|             break;
 | |
|         case 'admin_news':
 | |
|             require_once realpath(__DIR__ . '/../includes/pages/admin_news.php');
 | |
|             $content = admin_news();
 | |
|             break;
 | |
|         case 'admin_rooms':
 | |
|             $title = admin_rooms_title();
 | |
|             $content = admin_rooms();
 | |
|             break;
 | |
|         case 'admin_groups':
 | |
|             $title = admin_groups_title();
 | |
|             $content = admin_groups();
 | |
|             break;
 | |
|         case 'admin_import':
 | |
|             $title = admin_import_title();
 | |
|             $content = admin_import();
 | |
|             break;
 | |
|         case 'admin_shifts':
 | |
|             $title = admin_shifts_title();
 | |
|             $content = admin_shifts();
 | |
|             break;
 | |
|         case 'admin_log':
 | |
|             $title = admin_log_title();
 | |
|             $content = admin_log();
 | |
|             break;
 | |
|         case 'credits':
 | |
|             require_once realpath(__DIR__ . '/../includes/pages/guest_credits.php');
 | |
|             $title = credits_title();
 | |
|             $content = guest_credits();
 | |
|             break;
 | |
|         default:
 | |
|             require_once realpath(__DIR__ . '/../includes/pages/guest_start.php');
 | |
|             $content = guest_start();
 | |
|             break;
 | |
|     }
 | |
| } 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'));
 | |
|     }
 | |
| }
 | |
| 
 | |
| $event_config = EventConfig();
 | |
| 
 | |
| $parameters = [
 | |
|     'key' => (isset($user) ? $user['api_key'] : ''),
 | |
| ];
 | |
| if ($page == 'user_meetings') {
 | |
|     $parameters['meetings'] = 1;
 | |
| }
 | |
| 
 | |
| echo view(__DIR__ . '/../templates/layout.html', [
 | |
|     'theme'          => isset($user) ? $user['color'] : config('theme'),
 | |
|     'title'          => $title,
 | |
|     'atom_link'      => ($page == 'news' || $page == 'user_meetings')
 | |
|         ? ' <link href="'
 | |
|         . page_link_to('atom', $parameters)
 | |
|         . '" type = "application/atom+xml" rel = "alternate" title = "Atom Feed">'
 | |
|         : '',
 | |
|     'start_page_url' => page_link_to('/'),
 | |
|     'credits_url'    => page_link_to('credits'),
 | |
|     'menu'           => make_menu(),
 | |
|     'content'        => msg() . $content,
 | |
|     'header_toolbar' => header_toolbar(),
 | |
|     'faq_url'        => config('faq_url'),
 | |
|     'contact_email'  => config('contact_email'),
 | |
|     'locale'         => locale(),
 | |
|     'event_info'     => EventConfig_info($event_config) . ' <br />'
 | |
| ]);
 | 
