class AuditLogController extends Controller
{
-
public function index(Request $request)
{
$this->checkPermission('settings-manage');
$this->checkPermission('users-manage');
$listDetails = [
- 'order' => $request->get('order', 'desc'),
- 'event' => $request->get('event', ''),
- 'sort' => $request->get('sort', 'created_at'),
+ 'order' => $request->get('order', 'desc'),
+ 'event' => $request->get('event', ''),
+ 'sort' => $request->get('sort', 'created_at'),
'date_from' => $request->get('date_from', ''),
- 'date_to' => $request->get('date_to', ''),
+ 'date_to' => $request->get('date_to', ''),
+ 'user' => $request->get('user', ''),
+ 'ip' => $request->get('ip', ''),
];
$query = Activity::query()
'entity' => function ($query) {
$query->withTrashed();
},
- 'user'
+ 'user',
])
->orderBy($listDetails['sort'], $listDetails['order']);
if ($listDetails['event']) {
$query->where('type', '=', $listDetails['event']);
}
+ if ($listDetails['user']) {
+ $query->where('user_id', '=', $listDetails['user']);
+ }
if ($listDetails['date_from']) {
$query->where('created_at', '>=', $listDetails['date_from']);
if ($listDetails['date_to']) {
$query->where('created_at', '<=', $listDetails['date_to']);
}
+ if ($listDetails['ip']) {
+ $query->where('ip', 'like', $listDetails['ip'] . '%');
+ }
$activities = $query->paginate(100);
$activities->appends($listDetails);
$types = DB::table('activities')->select('type')->distinct()->pluck('type');
$this->setPageTitle(trans('settings.audit'));
+
return view('settings.audit', [
- 'activities' => $activities,
- 'listDetails' => $listDetails,
+ 'activities' => $activities,
+ 'listDetails' => $listDetails,
'activityTypes' => $types,
]);
}