<?php

namespace BookStack\Http\Controllers;

use BookStack\Actions\Activity;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

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'),
            'date_from' => $request->get('date_from', ''),
            'date_to'   => $request->get('date_to', ''),
            'user'      => $request->get('user', ''),
            'ip'        => $request->get('ip', ''),
        ];

        $query = Activity::query()
            ->with([
                'entity' => function ($query) {
                    $query->withTrashed();
                },
                '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,
            'activityTypes' => $types,
        ]);
    }
}