Add Superuser Logging Dashboard

This commit is contained in:
2024-03-31 13:07:25 +02:00
parent aa7020c19d
commit 5afbe54268
13 changed files with 320 additions and 25 deletions

View File

@@ -3,11 +3,11 @@
namespace App\Http\Controllers;
use App\Http\Requests\DataTableRequest;
use App\Models\Login;
use App\Models\Logging;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Http\Request;
use Inertia\Inertia;
use Illuminate\Support\Facades\Log;
class LoggingController extends Controller
{
/**
@@ -26,22 +26,10 @@ class LoggingController extends Controller
{
$request->validated();
return Logging::join('users', 'login_activities.user_id', '=', 'users.id')
->where(function (Builder $query) use ($request) {
$search = '%' . $request->search . '%';
$rec = Logging::today()->select(['*'])->paginate($request->per_page ?: 30);
$query->where('users.name', 'like', $search)
->orWhere('users.username', 'like', $search)
->orWhere('login_activities.ip_address', 'like', $search)
->orWhere('login_activities.browser', 'like', $search)
->orWhere('login_activities.platform', 'like', $search)
->orWhere('login_activities.created_at', 'like', $search);
})
->when(!$request->user()->hasRole('superuser'), function (Builder $query) use ($request) {
$query->where('users.id', $request->user()->id);
})
->select(['users.*', 'login_activities.*'])
->orderBy($request->input('order.key') ?: 'login_activities.created_at', $request->input('order.dir') ?: 'desc')
->paginate($request->per_page ?: 10);
Log::info("message",["rec" => $rec]);
return $rec;
}
}

View File

@@ -25,8 +25,9 @@ class ProductsCompareController extends Controller
$countries = $request->input("countries");
$online = $request->input("online");
$text = $request->input("text");
$country = $request->input("country");
Log::channel('db')->info("{codes} {countries} {online} {text} {ip} {referer}", ["codes" => $codes, "countries" => $countries, "online" => $online, "text" => $text, "ip" => $request->ip(), $request->headers->get('referer')]);
Log::channel('db')->info("{codes} {countries} {country} {online} {text} {ip} {referer}", ["codes" => $codes, "countries" => $countries, "country" => $country, "online" => $online, "text" => $text, "ip" => $request->ip(), $request->headers->get('referer')]);
$codes = collect($codes);
$countries = collect($countries);

21
app/Models/Logging.php Normal file
View File

@@ -0,0 +1,21 @@
<?php
namespace App\Models;
use Carbon\Carbon;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class Logging extends Model
{
use HasFactory;
/**
* @var string
*/
protected $table = 'log_messages';
protected function today() {
return $this->whereDate('logged_at',Carbon::today());
}
}