2FAuth/app/Http/Middleware/LogUserLastSeen.php

37 lines
1012 B
PHP
Raw Normal View History

2020-10-08 15:38:36 +02:00
<?php
namespace App\Http\Middleware;
use Carbon\Carbon;
2022-11-22 15:15:52 +01:00
use Closure;
2020-10-08 15:38:36 +02:00
use Illuminate\Support\Facades\Auth;
class LogUserLastSeen
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
2022-11-22 15:15:52 +01:00
* @param string $guards
2020-10-08 15:38:36 +02:00
* @return mixed
*/
public function handle($request, Closure $next, ...$guards)
2020-10-08 15:38:36 +02:00
{
$guards = empty($guards) ? [null] : $guards;
2020-10-08 15:38:36 +02:00
foreach ($guards as $guard) {
// We do not track activity of:
// - Guest
// - User authenticated against a bearer token
// - User authenticated via a reverse-proxy
2022-11-22 15:15:52 +01:00
if (Auth::guard($guard)->check() && ! $request->bearerToken() && config('auth.defaults.guard') !== 'reverse-proxy-guard') {
Auth::guard($guard)->user()->last_seen_at = Carbon::now()->format('Y-m-d H:i:s');
Auth::guard($guard)->user()->save();
break;
}
2020-10-08 15:38:36 +02:00
}
return $next($request);
}
}