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 
<?php

/* --------------------------------------------------------------
   FileDownloadHttpControllerResponse.inc.php 2018-05-17
   Gambio GmbH
   http://www.gambio.de
   Copyright (c) 2015 Gambio GmbH
   Released under the GNU General Public License (Version 2)
   [http://www.gnu.org/licenses/gpl-2.0.html]
   --------------------------------------------------------------
*/

/**
 * Class FileDownloadHttpControllerResponse
 *
 * @category   System
 * @package    Http
 * @subpackage ValueObjects
 * @extends    HttpControllerResponse
 */
class FileDownloadHttpControllerResponse extends HttpControllerResponse
{
    /**
     * Initializes the file download dialog http controller response.
     *
     * @param NonEmptyStringType            $file           File path
     * @param NonEmptyStringType|null       $name           Custom file name (optional)
     * @param NonEmptyStringType|null       $type           Content MIME type (optional)
     */
    public function __construct(
        NonEmptyStringType $file,
        NonEmptyStringType $name = null,
        NonEmptyStringType $type = null
    )
    {
        $realPath = realpath($file->asString());

        $contentDispositionHeaderChunk = $name ? ' filename="' . $name->asString() . '"' : '';

        $this->httpHeadersArray[] = 'Content-Disposition: attachment;' . $contentDispositionHeaderChunk;

        if ($type) {
            $this->httpHeadersArray[] = 'Content-Type: ' . $type->asString();
        }

        if (!$realPath) {
            throw new InvalidArgumentException('Invalid file path' . $file->asString());
        }

        $this->httpBody = file_get_contents($realPath);
    }
}