filters.php 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. <?php
  2. /*
  3. |--------------------------------------------------------------------------
  4. | Application & Route Filters
  5. |--------------------------------------------------------------------------
  6. |
  7. | Below you will find the "before" and "after" events for the application
  8. | which may be used to do any work before or after a request into your
  9. | application. Here you may also register your custom route filters.
  10. |
  11. */
  12. App::before(function($request)
  13. {
  14. //
  15. });
  16. App::after(function($request, $response)
  17. {
  18. //
  19. });
  20. /*
  21. |--------------------------------------------------------------------------
  22. | Authentication Filters
  23. |--------------------------------------------------------------------------
  24. |
  25. | The following filters are used to verify that the user of the current
  26. | session is logged into this application. The "basic" filter easily
  27. | integrates HTTP Basic authentication for quick, simple checking.
  28. |
  29. */
  30. Route::filter('auth', function()
  31. {
  32. if (Auth::guest())
  33. {
  34. if (Request::ajax()) App::abort(401);
  35. return Redirect::guest('login');
  36. }
  37. });
  38. Route::filter('auth.basic', function()
  39. {
  40. return Auth::basic();
  41. });
  42. /*
  43. |--------------------------------------------------------------------------
  44. | Guest Filter
  45. |--------------------------------------------------------------------------
  46. |
  47. | The "guest" filter is the counterpart of the authentication filters as
  48. | it simply checks that the current user is not logged in. A redirect
  49. | response will be issued if they are, which you may freely change.
  50. |
  51. */
  52. Route::filter('guest', function()
  53. {
  54. if (Auth::check()) return Redirect::to('/');
  55. });
  56. /*
  57. |--------------------------------------------------------------------------
  58. | CSRF Protection Filter
  59. |--------------------------------------------------------------------------
  60. |
  61. | The CSRF filter is responsible for protecting your application against
  62. | cross-site request forgery attacks. If this special token in a user
  63. | session does not match the one given in this request, we'll bail.
  64. |
  65. */
  66. Route::filter('csrf', function()
  67. {
  68. if (Session::token() != Input::get('_token'))
  69. {
  70. throw new Illuminate\Session\TokenMismatchException;
  71. }
  72. });