summaryrefslogtreecommitdiff
path: root/src/Http/AccessLogMiddleware.php
blob: 92f9810b9ecb5e98c64b343b184503bf8523c2fc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
<?php

namespace Lightscale\AccessLog\Http;

use Lightscale\AccessLog\Models\AccessLog;

use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;

use Closure;

class AccessLogMiddleware
{
    public function properties(Request $request, Response $response): ?iterable
    {
        return null;
    }

    public function shouldLog(): boolean
    {
        return config('access_log.enabled');
    }

    public function createLog(Request $request, Response $response): void
    {
        $model = config('access_log.model');
        $log = new $model([
            'path' => $request->path(),
            'referer' => $request->referer(),
            'status' => $request->status(),
            'properties' => $this->properties($request, $response),
        ]);
        $log->user()->associate($request->user());
        $log->save();
    }

    public function handle(Request $request, Closure $next): Response
    {
        $response = $next();
        if ($this->shouldLog()) $this->createLog($request, $response);
        return $response;
    }
}