Files
Sio-Back/app/Http/Middleware/RequestLogs.php
2025-12-26 17:21:11 -08:00

50 lines
1.2 KiB
PHP

<?php
namespace App\Http\Middleware;
use App\Models\User;
use App\Models\UserLoginLog;
use Closure;
use Illuminate\Support\Facades\Auth;
class RequestLogs
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
try {
$request_uri = $request->getRequestUri();
if(str_contains($request_uri,'?')){
list($request_uri, $query) = explode('?', $request_uri);
}
$data = [
'device_info' => $request->header('DEVICE-INFO'),
'browser_info' => $request->header('BROWSER-INFO'),
'ip' => $request->ip(),
'request_uri' => $request_uri,
];
if(Auth::check()){
$data['user_id'] = Auth::id();
}else{
$data['user_id'] = User::where('email', $request->input('email'))
->first()
->id;
}
UserLoginLog::create($data);
}catch (\Exception $exception){
\Log::info(json_encode($exception));
}
return $next($request);
}
}