50 lines
1.2 KiB
PHP
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);
|
|
}
|
|
}
|