Completed
Pull Request — master (#50)
by Tobias
08:21
created

CurlCommandFormatter::formatRequest()   B

Complexity

Conditions 5
Paths 12

Size

Total Lines 22
Code Lines 13

Duplication

Lines 0
Ratio 0 %

Importance

Changes 2
Bugs 1 Features 1
Metric Value
c 2
b 1
f 1
dl 0
loc 22
rs 8.6737
cc 5
eloc 13
nc 12
nop 1
1
<?php
2
3
namespace Http\Message\Formatter;
4
5
use Http\Message\Formatter;
6
use Psr\Http\Message\RequestInterface;
7
use Psr\Http\Message\ResponseInterface;
8
9
/**
10
 * A formatter that prints a cURL command for HTTP requests.
11
 *
12
 * @author Tobias Nyholm <[email protected]>
13
 */
14
class CurlCommandFormatter implements Formatter
15
{
16
    /**
17
     * {@inheritdoc}
18
     */
19
    public function formatRequest(RequestInterface $request)
20
    {
21
        $command = sprintf('curl \'%s\'', $request->getUri());
22
        if ($request->getProtocolVersion() === '1.0') {
23
            $command .= ' --http1.0';
24
        } elseif ($request->getProtocolVersion() === '2.0') {
25
            $command .= ' --http2';
26
        }
27
28
        $command .= ' --request '.$request->getMethod();
29
30
        foreach ($request->getHeaders() as $name => $values) {
31
            $command .= sprintf(' -H \'%s: %s\'', $name, $request->getHeaderLine($name));
32
        }
33
34
        $body = $request->getBody()->__toString();
35
        if (!empty($body)) {
36
            $command .= sprintf(' --data \'%s\'', escapeshellarg($body));
37
        }
38
39
        return $command;
40
    }
41
42
    /**
43
     * {@inheritdoc}
44
     */
45
    public function formatResponse(ResponseInterface $response)
46
    {
47
        return '';
48
    }
49
}
50