<?php /* |-------------------------------------------------------------------------- | Application & Route Filters |-------------------------------------------------------------------------- | | Below you will find the "before" and "after" events for the application | which may be used to do any work before or after a request into your | application. Here you may also register your custom route filters. | */ App::before(function($request) { Log::debug('START '.Request::getClientIp().': '.Request::method().' '.Request::path()); if( ! Request::secure()) { return Redirect::secure(Request::path()); } }); App::after(function($request, $response) { // }); /* |-------------------------------------------------------------------------- | Authentication Filters |-------------------------------------------------------------------------- | | The following filters are used to verify that the user of the current | session is logged into this application. The "basic" filter easily | integrates HTTP Basic authentication for quick, simple checking. | */ Route::filter('auth', function() { if (Auth::guest()) { if (Request::ajax()) { return Response::make('Unauthorized', 401); } else { return Redirect::guest('/'); } } }); Route::filter('auth.basic', function() { return Auth::basic(); }); Route::filter('has_access', function() { if(!Auth::user()->has_access) { Session::flash('status', 'info'); Session::flash('message', 'At this time, access to OLAS is limited to some users. Check back later or contact an administrator.'); Auth::logout(); return Redirect::action('AuthController@showLogin'); } }); /* |-------------------------------------------------------------------------- | Guest Filter |-------------------------------------------------------------------------- | | The "guest" filter is the counterpart of the authentication filters as | it simply checks that the current user is not logged in. A redirect | response will be issued if they are, which you may freely change. | */ Route::filter('guest', function() { if (Auth::check()) { switch (Auth::user()->role) { case 1: return Redirect::to('administrator'); break; case 2: return Redirect::to('school-coordinator'); break; case 3: return Redirect::to('program-coordinator'); break; case 4: return Redirect::to('professor'); break; } } }); /* |-------------------------------------------------------------------------- | Administrator Filter |-------------------------------------------------------------------------- | | This filter redirects logged in users except administrators to their | default page if they try to access a forbidden page. | */ Route::filter('admin', function() { if (Auth::user()->role !=1) { switch (Auth::user()->role) { case 2: return Redirect::to('school-coordinator'); break; case 3: return Redirect::to('program-coordinator'); break; case 4: return Redirect::to('professor'); break; } } }); /* |-------------------------------------------------------------------------- | School Coordinator Filter |-------------------------------------------------------------------------- | | This filter redirects logged in users below school coordinators to their | default page if they try to access a forbidden page. | */ Route::filter('scoord', function() { if (!(Auth::user()->role ==2 || Auth::user()->role ==1)) { switch (Auth::user()->role) { case 3: return Redirect::to('program-coordinator'); break; case 4: return Redirect::to('professor'); break; } } }); /* |-------------------------------------------------------------------------- | Program Coordinator Filter |-------------------------------------------------------------------------- | | This filter redirects logged in users below program coordinators to their | default page if they try to access a forbidden page. | */ Route::filter('pcoord', function() { if (!(Auth::user()->role ==3 || Auth::user()->role ==2 || Auth::user()->role ==1)) { return Redirect::to('professor'); } }); /* |-------------------------------------------------------------------------- | Professor Filter |-------------------------------------------------------------------------- | | This filter redirects logged in users except profesors to their | default page if they try to access a forbidden page. | */ Route::filter('prof', function() { // If user has no courses then s/he is not a professor // and must be redirected to her/his overview page if (!count(Auth::user()->courses)) { switch (Auth::user()->role) { case 1: return Redirect::to('administrator'); break; case 2: return Redirect::to('school-coordinator'); break; case 3: return Redirect::to('program-coordinator'); break; } } }); /* |-------------------------------------------------------------------------- | CSRF Protection Filter |-------------------------------------------------------------------------- | | The CSRF filter is responsible for protecting your application against | cross-site request forgery attacks. If this special token in a user | session does not match the one given in this request, we'll bail. | */ Route::filter('csrf', function() { $token = Request::ajax() ? Request::header('X-CSRF-Token') : Input::get('_token'); if (Session::token() !== $token) { throw new Illuminate\Session\TokenMismatchException; } });