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
90 lines (85 loc) · 2.81 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
89
90
<?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 CodeInc\Psr7Responses\Tests\FileResponseTest;
/**
* Class FileResponse
*
* @see FileResponseTest
* @package CodeInc\Psr7Responses
* @author Joan Fabrégat <[email protected]>
*/
class FileResponse extends StreamResponse
{
public const DEFAULT_MIME_TYPE = 'application/octet-stream';
/**
* FileResponse constructor.
*
* @param string $filePath
* @param null|string $fileName
* @param null|string $mimeType
* @param bool $asAttachment
* @param int $status
* @param array $headers
* @param string $version
* @param null|string $reason
* @throws ResponseException
* @throws \CodeInc\MediaTypes\Exceptions\MediaTypesException
*/
public function __construct(string $filePath, ?string $fileName = null, ?string $mimeType = null,
bool $asAttachment = true, int $status = 200, array $headers = [],
string $version = '1.1', ?string $reason = null)
{
if (!is_file($filePath)) {
throw new ResponseException(
sprintf("The path \"%s\" is not a file or does not exist", $filePath),
$this
);
}
if (($f = fopen($filePath, "r")) === false) {
throw new ResponseException(
sprintf("Unable to open the file \"%s\" for reading", $filePath),
$this
);
}
if (!$fileName) {
$fileName = basename($filePath);
}
// looking up the mime type using
if (!$mimeType && $fileName) {
$mimeType = MediaTypes::getFilenameMediaType($fileName);
}
parent::__construct(
$f,
$mimeType ?? self::DEFAULT_MIME_TYPE,
filesize($filePath) ?: null,
$fileName ?? basename($filePath),
$asAttachment,
$status,
$headers,
$version,
$reason
);
}
}