This repository has been archived by the owner on Feb 5, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
FileResponse.php
88 lines (85 loc) · 3 KB
/
FileResponse.php
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
<?php
//
// +---------------------------------------------------------------------+
// | CODE INC. SOURCE CODE |
// +---------------------------------------------------------------------+
// | Copyright (c) 2017 - Code Inc. SAS - All Rights Reserved. |
// | Visit https://www.codeinc.fr for more information about licensing. |
// +---------------------------------------------------------------------+
// | NOTICE: All information contained herein is, and remains the |
// | property of Code Inc. SAS. The intellectual and technical concepts |
// | contained herein are proprietary to Code Inc. SAS are protected by |
// | trade secret or copyright law. Dissemination of this information or |
// | reproduction of this material is strictly forbidden unless prior |
// | written permission is obtained from Code Inc. SAS. |
// +---------------------------------------------------------------------+
//
// Author: Joan Fabrégat <[email protected]>
// Date: 23/02/2018
// Time: 19:15
// Project: Psr7Responses
//
declare(strict_types = 1);
namespace CodeInc\Psr7Responses;
use CodeInc\MediaTypes\MediaTypes;
use function GuzzleHttp\Psr7\stream_for;
use Psr\Http\Message\StreamInterface;
/**
* Class FileResponse
*
* @see FileResponseTest
* @package CodeInc\Psr7Responses
* @author Joan Fabrégat <[email protected]>
* @license MIT <https://github.com/CodeIncHQ/Psr7Responses/blob/master/LICENSE>
* @link https://github.com/CodeIncHQ/Psr7Responses
* @version 2
*/
class FileResponse extends StreamResponse
{
/**
* FileResponse constructor.
*
* @param string|resource|StreamInterface $file
* @param string $fileName
* @param int $code
* @param string $reasonPhrase
* @param null|string $contentType
* @param bool $asAttachment
* @param array $headers
* @param string $version
* @throws \CodeInc\MediaTypes\Exceptions\MediaTypesException
*/
public function __construct($file, string $fileName, int $code = 200, string $reasonPhrase = '',
?string $contentType = null, bool $asAttachment = true, array $headers = [], string $version = '1.1')
{
if (is_string($file)) {
if (!is_file($file)) {
throw new ResponseException(
sprintf("The path \"%s\" is not a file or does not exist", $file),
$this
);
}
if (($handler = fopen($file, "r")) === false) {
throw new ResponseException(
sprintf("Unable to open the file \"%s\" for reading", $file),
$this
);
}
$stream = stream_for($handler);
}
else {
$stream = stream_for($file);
}
parent::__construct(
$stream,
$code,
$reasonPhrase,
$contentType ?? MediaTypes::getFilenameMediaType($fileName, 'application/octet-stream'),
null,
$fileName,
$asAttachment,
$headers,
$version
);
}
}