Files
CHIEFSOFT\ameye 07a07ab49f first commit
2025-11-22 09:54:51 -05:00

110 lines
2.6 KiB
PHP

<?php
declare(strict_types=1);
/**
* This file is part of CodeIgniter 4 framework.
*
* (c) CodeIgniter Foundation <admin@codeigniter.com>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/
// CodeIgniter Security Helpers
if (! function_exists('sanitize_filename')) {
/**
* Sanitize Filename
*
* Tries to sanitize filenames in order to prevent directory traversal attempts
* and other security threats, which is particularly useful for files that
* were supplied via user input.
*
* If it is acceptable for the user input to include relative paths,
* e.g. file/in/some/approved/folder.txt, you can set the second optional
* parameter, $relativePath to TRUE.
*
* @param string $filename Input file name
* @param bool $relativePath Whether to preserve paths
*/
function sanitize_filename(string $filename, bool $relativePath = false): string
{
// List of sanitized filename strings
$bad = [
'../',
'<!--',
'-->',
'<',
'>',
"'",
'"',
'&',
'$',
'#',
'{',
'}',
'[',
']',
'=',
';',
'?',
'%20',
'%22',
'%3c',
'%253c',
'%3e',
'%0e',
'%28',
'%29',
'%2528',
'%26',
'%24',
'%3f',
'%3b',
'%3d',
];
if (! $relativePath) {
$bad[] = './';
$bad[] = '/';
}
$filename = remove_invisible_characters($filename, false);
do {
$old = $filename;
$filename = str_replace($bad, '', $filename);
} while ($old !== $filename);
return stripslashes($filename);
}
}
if (! function_exists('strip_image_tags')) {
/**
* Strip Image Tags
*/
function strip_image_tags(string $str): string
{
return preg_replace(
[
'#<img[\s/]+.*?src\s*=\s*(["\'])([^\\1]+?)\\1.*?\>#i',
'#<img[\s/]+.*?src\s*=\s*?(([^\s"\'=<>`]+)).*?\>#i',
],
'\\2',
$str,
);
}
}
if (! function_exists('encode_php_tags')) {
/**
* Convert PHP tags to entities
*/
function encode_php_tags(string $str): string
{
return str_replace(['<?', '?>'], ['&lt;?', '?&gt;'], $str);
}
}