blob: 96ff29decf2019ea9a42d18addcc628fe9df2bcb [file] [log] [blame]
Andrey Andreevb38c5dd2012-02-29 14:07:45 +02001<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Phil Sturgeon07c1ac82012-03-09 17:03:37 +00005 * An open source application development framework for PHP 5.2.4 or newer
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05007 * NOTICE OF LICENSE
Andrey Andreevb38c5dd2012-02-29 14:07:45 +02008 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05009 * Licensed under the Open Software License version 3.0
Andrey Andreevb38c5dd2012-02-29 14:07:45 +020010 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -050011 * This source file is subject to the Open Software License (OSL 3.0) that is
12 * bundled with this package in the files license.txt / license.rst. It is
13 * also available through the world wide web at this URL:
14 * http://opensource.org/licenses/OSL-3.0
15 * If you did not receive a copy of the license and are unable to obtain it
16 * through the world wide web, please send an email to
17 * licensing@ellislab.com so we can send you a copy immediately.
18 *
Derek Allard2067d1a2008-11-13 22:59:24 +000019 * @package CodeIgniter
Derek Jonesf4a4bd82011-10-20 12:18:42 -050020 * @author EllisLab Dev Team
Greg Aker0defe5d2012-01-01 18:46:41 -060021 * @copyright Copyright (c) 2008 - 2012, EllisLab, Inc. (http://ellislab.com/)
Derek Jonesf4a4bd82011-10-20 12:18:42 -050022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
Derek Allard2067d1a2008-11-13 22:59:24 +000023 * @link http://codeigniter.com
24 * @since Version 1.0
25 * @filesource
26 */
27
Derek Allard2067d1a2008-11-13 22:59:24 +000028/**
29 * CodeIgniter Download Helpers
30 *
31 * @package CodeIgniter
32 * @subpackage Helpers
33 * @category Helpers
Derek Jonesf4a4bd82011-10-20 12:18:42 -050034 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000035 * @link http://codeigniter.com/user_guide/helpers/download_helper.html
36 */
37
38// ------------------------------------------------------------------------
39
40/**
41 * Force Download
42 *
43 * Generates headers that force a download to happen
44 *
45 * @access public
46 * @param string filename
47 * @param mixed the data to be downloaded
Andrey Andreevb38c5dd2012-02-29 14:07:45 +020048 * @param bool wether to try and send the actual file MIME type
Derek Allard2067d1a2008-11-13 22:59:24 +000049 * @return void
Barry Mienydd671972010-10-04 16:33:58 +020050 */
Derek Allard2067d1a2008-11-13 22:59:24 +000051if ( ! function_exists('force_download'))
52{
Andrey Andreevb38c5dd2012-02-29 14:07:45 +020053 function force_download($filename = '', $data = '', $set_mime = FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +000054 {
55 if ($filename == '' OR $data == '')
56 {
57 return FALSE;
58 }
59
Andrey Andreevb38c5dd2012-02-29 14:07:45 +020060 // Set the default MIME type to send
61 $mime = 'application/octet-stream';
62
Andrey Andreevfce2ed62012-03-11 22:04:48 +020063 $x = explode('.', $filename);
64 $extension = end($x);
65
Andrey Andreevb38c5dd2012-02-29 14:07:45 +020066 if ($set_mime === TRUE)
Derek Allard2067d1a2008-11-13 22:59:24 +000067 {
Andrey Andreevfce2ed62012-03-11 22:04:48 +020068 if (count($x) === 1 OR $extension === '')
Andrey Andreevb38c5dd2012-02-29 14:07:45 +020069 {
Andrey Andreevfce2ed62012-03-11 22:04:48 +020070 /* If we're going to detect the MIME type,
71 * we'll need a file extension.
72 */
Andrey Andreevb38c5dd2012-02-29 14:07:45 +020073 return FALSE;
74 }
75
Andrey Andreevb38c5dd2012-02-29 14:07:45 +020076 // Load the mime types
77 if (defined('ENVIRONMENT') && is_file(APPPATH.'config/'.ENVIRONMENT.'/mimes.php'))
78 {
79 include(APPPATH.'config/'.ENVIRONMENT.'/mimes.php');
80 }
81 elseif (is_file(APPPATH.'config/mimes.php'))
82 {
83 include(APPPATH.'config/mimes.php');
84 }
85
86 // Only change the default MIME if we can find one
87 if (isset($mimes[$extension]))
88 {
89 $mime = is_array($mimes[$extension]) ? $mimes[$extension][0] : $mimes[$extension];
90 }
Derek Allard2067d1a2008-11-13 22:59:24 +000091 }
Barry Mienydd671972010-10-04 16:33:58 +020092
Andrey Andreevfce2ed62012-03-11 22:04:48 +020093 /* It was reported that browsers on Android 2.1 (and possibly older as well)
94 * need to have the filename extension upper-cased in order to be able to
95 * download it.
96 *
97 * Reference: http://digiblog.de/2011/04/19/android-and-the-download-file-headers/
98 */
Andrey Andreev3d933b62012-03-11 22:08:57 +020099 if (count($x) !== 1 && isset($_SERVER['HTTP_USER_AGENT']) && preg_match('/Android\s(1|2\.[01])/', $_SERVER['HTTP_USER_AGENT']))
Andrey Andreevfce2ed62012-03-11 22:04:48 +0200100 {
101 $x[count($x) - 1] = strtoupper($extension);
102 $filename = implode('.', $x);
103 }
104
Derek Allard2067d1a2008-11-13 22:59:24 +0000105 // Generate the server headers
dododedodonl4da94782012-03-10 13:56:17 +0100106 header('Content-Type: '.$mime);
Eric Roberts0e4d2b62012-01-23 18:19:20 -0600107 header('Content-Disposition: attachment; filename="'.$filename.'"');
108 header('Expires: 0');
Andrey Andreevb38c5dd2012-02-29 14:07:45 +0200109 header('Content-Transfer-Encoding: binary');
110 header('Content-Length: '.strlen($data));
Eric Roberts0e4d2b62012-01-23 18:19:20 -0600111
Andrey Andreevb38c5dd2012-02-29 14:07:45 +0200112 // Internet Explorer-specific headers
113 if (isset($_SERVER['HTTP_USER_AGENT']) && strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE') !== FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000114 {
Derek Allard2067d1a2008-11-13 22:59:24 +0000115 header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
Derek Allard2067d1a2008-11-13 22:59:24 +0000116 header('Pragma: public');
Derek Allard2067d1a2008-11-13 22:59:24 +0000117 }
Andrey Andreevb38c5dd2012-02-29 14:07:45 +0200118 else
119 {
120 header('Pragma: no-cache');
121 }
Barry Mienydd671972010-10-04 16:33:58 +0200122
Derek Allard2067d1a2008-11-13 22:59:24 +0000123 exit($data);
124 }
125}
126
Derek Allard2067d1a2008-11-13 22:59:24 +0000127/* End of file download_helper.php */
Andrey Andreevb38c5dd2012-02-29 14:07:45 +0200128/* Location: ./system/helpers/download_helper.php */