Completed
Push — master ( 5da50f...149fe4 )
by Freek
23s queued 10s
created

DefaultLogWriter::flatFiles()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 10

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 10
rs 9.9332
c 0
b 0
f 0
cc 3
nc 3
nop 1
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
        $files = (new Collection(iterator_to_array($request->files)))
21
            ->map([$this, 'flatFiles'])
22
            ->flatten()
23
            ->implode(',')
24
        ;
25
        $message = "{$method} {$uri} - Body: {$bodyAsJson} - Files: ". $files;
26
27
        Log::info($message);
28
    }
29
30
    public function flatFiles($file)
31
    {
32
        if ($file instanceof UploadedFile) {
33
            return $file->getClientOriginalName();
34
        }
35
        if (is_array($file)) {
36
            return array_map([$this, 'flatFiles'], $file);
37
        }
38
        return (string) $file;
39
    }
40
}
41