DefaultLogWriter   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 34
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 5

Importance

Changes 0
Metric Value
wmc 4
lcom 1
cbo 5
dl 0
loc 34
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A logRequest() 0 19 1
A flatFiles() 0 11 3
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