DefaultLogWriter::logRequest()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 19

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
nc 1
nop 1
dl 0
loc 19
rs 9.6333
c 0
b 0
f 0
1
<?php
2
3
namespace Spatie\HttpLogger;
4
5
use Illuminate\Http\Request;
6
use Illuminate\Support\Collection;
7
use Illuminate\Support\Facades\Log;
8
use Symfony\Component\HttpFoundation\File\UploadedFile;
9
10
class DefaultLogWriter implements LogWriter
11
{
12
    public function logRequest(Request $request)
13
    {
14
        $method = strtoupper($request->getMethod());
15
16
        $uri = $request->getPathInfo();
17
18
        $bodyAsJson = json_encode($request->except(config('http-logger.except')));
19
20
        $headersAsJson = json_encode($request->headers->all());
21
22
        $files = (new Collection(iterator_to_array($request->files)))
23
            ->map([$this, 'flatFiles'])
24
            ->flatten()
25
            ->implode(',');
26
27
        $message = "{$method} {$uri} - Body: {$bodyAsJson} - Headers: {$headersAsJson} - Files: ".$files;
28
29
        Log::info($message);
30
    }
31
32
    public function flatFiles($file)
33
    {
34
        if ($file instanceof UploadedFile) {
35
            return $file->getClientOriginalName();
36
        }
37
        if (is_array($file)) {
38
            return array_map([$this, 'flatFiles'], $file);
39
        }
40
41
        return (string) $file;
42
    }
43
}
44