Add Superuser Logging Dashboard
This commit is contained in:
@@ -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;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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
21
app/Models/Logging.php
Normal 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());
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user