158 lines
2.5 KiB
PHP
Raw Normal View History

2013-02-17 21:48:21 -05:00
<?php
2015-08-28 21:34:34 -04:00
namespace Response;
2013-02-17 21:48:21 -05:00
function force_download($filename)
{
header('Content-Disposition: attachment; filename="'.$filename.'"');
}
2014-02-08 14:13:14 -05:00
function content_type($mimetype)
{
header('Content-Type: '.$mimetype);
}
2013-02-17 21:48:21 -05:00
function status($status_code)
{
2014-03-16 21:56:43 -04:00
$sapi_name = php_sapi_name();
if (strpos($sapi_name, 'apache') !== false || $sapi_name === 'cli-server') {
2013-02-17 21:48:21 -05:00
header('HTTP/1.0 '.$status_code);
2016-04-17 19:44:45 -04:00
} else {
2013-02-17 21:48:21 -05:00
header('Status: '.$status_code);
}
}
function redirect($url, $status_code = 302)
2013-02-17 21:48:21 -05:00
{
header('Location: '.$url, true, $status_code);
2013-02-17 21:48:21 -05:00
exit;
}
function json(array $data, $status_code = 200)
{
status($status_code);
header('Content-Type: application/json');
echo json_encode($data);
exit;
}
function text($data, $status_code = 200)
{
status($status_code);
header('Content-Type: text/plain; charset=utf-8');
echo $data;
exit;
}
function html($data, $status_code = 200)
{
status($status_code);
header('Content-Type: text/html; charset=utf-8');
echo $data;
exit;
}
function xml($data, $status_code = 200)
{
status($status_code);
header('Content-Type: text/xml; charset=utf-8');
echo $data;
exit;
}
2013-06-14 23:12:08 -04:00
function js($data, $status_code = 200)
{
status($status_code);
header('Content-Type: text/javascript; charset=utf-8');
echo $data;
exit;
}
function raw($data, $status_code = 200)
{
status($status_code);
echo $data;
exit;
}
2013-03-24 10:30:55 -04:00
function binary($data, $status_code = 200)
{
status($status_code);
header('Content-Transfer-Encoding: binary');
header('Content-Type: application/octet-stream');
echo $data;
exit;
}
2013-02-17 21:48:21 -05:00
function csp(array $policies = array())
{
$policies['default-src'] = "'self'";
2013-08-05 19:21:37 -04:00
$values = '';
2013-02-17 21:48:21 -05:00
2013-08-05 19:21:37 -04:00
foreach ($policies as $policy => $hosts) {
if (is_array($hosts)) {
$acl = '';
2013-02-17 21:48:21 -05:00
2013-08-05 19:21:37 -04:00
foreach ($hosts as &$host) {
2015-02-01 14:48:05 -05:00
if ($host === '*' || $host === "'self'" || strpos($host, 'http') === 0) {
2013-08-05 19:21:37 -04:00
$acl .= $host.' ';
}
}
2016-04-17 19:44:45 -04:00
} else {
2013-08-05 19:21:37 -04:00
$acl = $hosts;
2013-02-17 21:48:21 -05:00
}
2013-08-05 19:21:37 -04:00
$values .= $policy.' '.trim($acl).'; ';
2013-02-17 21:48:21 -05:00
}
2013-08-05 19:21:37 -04:00
header('Content-Security-Policy: '.$values);
2013-02-17 21:48:21 -05:00
}
function nosniff()
{
header('X-Content-Type-Options: nosniff');
}
function xss()
{
header('X-XSS-Protection: 1; mode=block');
}
function hsts()
{
header('Strict-Transport-Security: max-age=31536000');
}
function xframe($mode = 'DENY', array $urls = array())
{
header('X-Frame-Options: '.$mode.' '.implode(' ', $urls));
2015-10-19 21:21:18 -04:00
}