KickOutInactiveUser.php 1.6 KB

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