KickOutInactiveUser.php 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Facades\Settings;
  4. use Carbon\Carbon;
  5. use Closure;
  6. use Illuminate\Http\Response;
  7. use Illuminate\Support\Facades\Auth;
  8. use Illuminate\Support\Facades\Log;
  9. class KickOutInactiveUser
  10. {
  11. /**
  12. * Handle an incoming request.
  13. *
  14. * @param \Illuminate\Http\Request $request
  15. * @param \Closure $next
  16. * @param string $guards
  17. * @return mixed
  18. */
  19. public function handle($request, Closure $next, ...$guards)
  20. {
  21. // We do not track activity of:
  22. // - Guest
  23. // - User authenticated against a bearer token
  24. // - User authenticated via a reverse-proxy
  25. if (Auth::guest() || $request->bearerToken() || config('auth.defaults.guard') === 'reverse-proxy-guard') {
  26. return $next($request);
  27. }
  28. $user = Auth::user();
  29. $now = Carbon::now();
  30. $inactiveFor = $now->diffInSeconds(Carbon::parse($user->last_seen_at));
  31. // Fetch all setting values
  32. $kickUserAfterXSecond = intval(Settings::get('kickUserAfter')) * 60;
  33. // If user has been inactive longer than the allowed inactivity period
  34. if ($kickUserAfterXSecond > 0 && $inactiveFor > $kickUserAfterXSecond) {
  35. $user->last_seen_at = $now->format('Y-m-d H:i:s');
  36. $user->save();
  37. Log::info('Inactive user detected, authentication rejected');
  38. if (method_exists('Illuminate\Support\Facades\Auth', 'logout')) {
  39. Auth::logout();
  40. }
  41. return response()->json(['message' => 'inactivity detected'], Response::HTTP_I_AM_A_TEAPOT);
  42. }
  43. return $next($request);
  44. }
  45. }