allerta-vvf/backend/app/Http/Controllers/LogsController.php

63 lines
2.1 KiB
PHP
Raw Normal View History

2023-09-01 14:24:10 +02:00
<?php
namespace App\Http\Controllers;
use App\Models\Log;
2023-09-01 14:39:44 +02:00
use App\Models\User;
use App\Utils\DBTricks;
2023-09-01 14:24:10 +02:00
use Illuminate\Http\Request;
use Carbon\Carbon;
2023-09-01 14:24:10 +02:00
class LogsController extends Controller
{
/**
2024-02-24 00:52:25 +01:00
* List all logs
2023-09-01 14:24:10 +02:00
*/
public function index(Request $request)
{
2023-09-01 14:39:44 +02:00
User::where('id', $request->user()->id)->update(['last_access' => now()]);
2024-02-24 00:52:25 +01:00
$request->validate([
'from' => 'date',
'to' => 'date'
]);
$query = Log::join('users as changed_user', 'changed_user.id', '=', 'logs.changed_id')
->join('users as editor_user', 'editor_user.id', '=', 'logs.editor_id')
->orderBy('created_at', 'desc');
2024-02-24 00:52:25 +01:00
$selectedCols = [
"logs.id", "logs.action", "logs.editor_id", "logs.changed_id", "logs.created_at", "logs.source_type",
DBTricks::nameSelect("changed", "changed_user"), DBTricks::nameSelect("editor", "editor_user"), "editor_user.hidden as editor_hidden"
];
if($request->has('from')) {
try {
$from = Carbon::parse($request->input('from'));
$query->whereDate('logs.created_at', '>=', $from->toDateString());
} catch (\Carbon\Exceptions\InvalidFormatException $e) { }
}
if($request->has('to')) {
try {
$to = Carbon::parse($request->input('to'));
$query->whereDate('logs.created_at', '<=', $to->toDateString());
} catch (\Carbon\Exceptions\InvalidFormatException $e) { }
}
2024-02-24 00:52:25 +01:00
if($request->user()->hasPermission("logs-limited-read")) {
$query = $query->where(function ($query) {
$query->where('editor_user.hidden', false)
->orWhere('editor_user.id', auth()->user()->id);
});
} else if($request->user()->hasPermission("logs-read")) {
$selectedCols = array_merge($selectedCols, ["logs.ip", "logs.user_agent"]);
} else {
abort(401);
}
2023-09-01 14:24:10 +02:00
return response()->json(
$query->select($selectedCols)->get()
2023-09-01 14:24:10 +02:00
);
}
}