koblog/bl-kernel/helpers/filesystem.class.php

347 lines
8.3 KiB
PHP
Raw Permalink Normal View History

2015-05-05 03:00:01 +02:00
<?php defined('BLUDIT') or die('Bludit CMS.');
2015-03-08 18:02:59 +01:00
2024-06-23 21:46:43 +02:00
class Filesystem
{
2015-03-08 18:02:59 +01:00
2015-09-20 23:46:50 +02:00
// Returns an array with the absolutes directories.
2024-06-23 21:46:43 +02:00
public static function listDirectories($path, $regex = '*', $sortByDate = false)
2015-03-08 18:02:59 +01:00
{
2024-06-23 21:46:43 +02:00
$directories = glob($path . $regex, GLOB_ONLYDIR);
2015-09-15 01:07:15 +02:00
2024-06-23 21:46:43 +02:00
if (empty($directories)) {
2015-09-15 01:07:15 +02:00
return array();
}
2024-06-23 21:46:43 +02:00
if ($sortByDate) {
usort(
$directories,
function ($a, $b) {
return filemtime($b) - filemtime($a);
}
2017-12-06 19:14:33 +01:00
);
2017-06-26 22:50:56 +02:00
}
2015-09-15 01:07:15 +02:00
return $directories;
}
2017-12-26 17:45:02 +01:00
// Returns an array with the list of files with the absolute path
// $sortByDate = TRUE, the first file is the newer file
// $chunk = amount of chunks, FALSE if you don't want to chunk
2024-06-23 21:46:43 +02:00
public static function listFiles($path, $regex = '*', $extension = '*', $sortByDate = false, $chunk = false)
2015-09-15 01:07:15 +02:00
{
2024-06-23 21:46:43 +02:00
error_log($path . $regex . '.' . $extension);
$files = glob($path . $regex . '.' . $extension);
2015-09-15 01:07:15 +02:00
2017-11-16 23:22:55 +01:00
if (empty($files)) {
2015-09-15 01:07:15 +02:00
return array();
}
2017-11-16 23:22:55 +01:00
if ($sortByDate) {
2024-06-23 21:46:43 +02:00
usort(
$files,
function ($a, $b) {
2017-12-06 19:14:33 +01:00
return filemtime($b) - filemtime($a);
}
);
2015-11-04 01:28:11 +01:00
}
// Split the list of files into chunks
// http://php.net/manual/en/function.array-chunk.php
if ($chunk) {
return array_chunk($files, $chunk);
}
2015-09-15 01:07:15 +02:00
return $files;
2015-03-08 18:02:59 +01:00
}
2024-06-23 21:46:43 +02:00
public static function mkdir($pathname, $recursive = false)
2015-05-05 03:00:01 +02:00
{
2024-06-23 21:46:43 +02:00
Log::set('mkdir ' . $pathname . ' recursive = ' . $recursive, LOG_TYPE_INFO);
return mkdir($pathname, DIR_PERMISSIONS, $recursive);
2015-05-05 03:00:01 +02:00
}
public static function rmdir($pathname)
{
2024-06-23 21:46:43 +02:00
Log::set('rmdir = ' . $pathname, LOG_TYPE_INFO);
2015-05-05 03:00:01 +02:00
return rmdir($pathname);
}
public static function mv($oldname, $newname)
{
2024-06-23 21:46:43 +02:00
Log::set('mv ' . $oldname . ' ' . $newname, LOG_TYPE_INFO);
2015-05-05 03:00:01 +02:00
return rename($oldname, $newname);
}
public static function rmfile($filename)
{
2024-06-23 21:46:43 +02:00
Log::set('rmfile = ' . $filename, LOG_TYPE_INFO);
2015-05-05 03:00:01 +02:00
return unlink($filename);
}
2017-06-29 22:13:25 +02:00
public static function fileExists($filename)
{
return file_exists($filename);
}
2017-07-02 18:55:27 +02:00
public static function directoryExists($path)
{
return file_exists($path);
}
2017-11-16 23:22:55 +01:00
// Copy recursive a directory to another
// If the destination directory not exists is created
// $source = /home/diego/example or /home/diego/example/
// $destination = /home/diego/newplace or /home/diego/newplace/
2024-06-23 21:46:43 +02:00
public static function copyRecursive($source, $destination, $skipDirectory = false)
2017-07-02 18:55:27 +02:00
{
2017-11-16 23:22:55 +01:00
$source = rtrim($source, DS);
$destination = rtrim($destination, DS);
// Check $source directory if exists
2017-10-02 23:17:32 +02:00
if (!self::directoryExists($source)) {
return false;
}
2017-11-16 23:22:55 +01:00
// Check $destionation directory if exists
if (!self::directoryExists($destination)) {
// Create the $destination directory
if (!mkdir($destination, DIR_PERMISSIONS, true)) {
2017-11-16 23:22:55 +01:00
return false;
}
}
2017-07-02 18:55:27 +02:00
2017-11-16 23:22:55 +01:00
foreach ($iterator = new RecursiveIteratorIterator(
2024-06-23 21:46:43 +02:00
new RecursiveDirectoryIterator($source, RecursiveDirectoryIterator::SKIP_DOTS),
RecursiveIteratorIterator::SELF_FIRST
) as $item) {
2018-03-07 15:43:41 +01:00
$currentDirectory = dirname($item->getPathName());
if ($skipDirectory !== $currentDirectory) {
if ($item->isDir()) {
2024-06-23 21:46:43 +02:00
@mkdir($destination . DS . $iterator->getSubPathName());
2018-03-07 15:43:41 +01:00
} else {
2024-06-23 21:46:43 +02:00
copy($item, $destination . DS . $iterator->getSubPathName());
2018-03-07 15:43:41 +01:00
}
}
2017-07-02 18:55:27 +02:00
}
2017-11-16 23:22:55 +01:00
2017-07-02 18:55:27 +02:00
return true;
}
2017-11-16 23:22:55 +01:00
// Delete a file or directory recursive
// The directory is delete
2024-06-23 21:46:43 +02:00
public static function deleteRecursive($source, $deleteDirectory = true)
2017-07-02 18:55:27 +02:00
{
2024-06-23 21:46:43 +02:00
Log::set('deleteRecursive = ' . $source, LOG_TYPE_INFO);
2019-05-27 19:07:53 +02:00
2017-10-02 23:17:32 +02:00
if (!self::directoryExists($source)) {
return false;
}
2018-09-26 17:55:19 +02:00
foreach (new RecursiveIteratorIterator(
2017-07-02 18:55:27 +02:00
new RecursiveDirectoryIterator($source, FilesystemIterator::SKIP_DOTS),
2024-06-23 21:46:43 +02:00
RecursiveIteratorIterator::CHILD_FIRST
) as $item) {
if ($item->isFile() || $item->isLink()) {
unlink($item);
} else {
rmdir($item);
}
2017-07-02 18:55:27 +02:00
}
2018-09-26 17:55:19 +02:00
if ($deleteDirectory) {
return rmdir($source);
}
return true;
2017-07-02 18:55:27 +02:00
}
2017-11-16 23:22:55 +01:00
// Compress a file or directory
// $source = /home/diego/example
// $destionation = /tmp/example.zip
public static function zip($source, $destination)
{
2017-11-16 23:22:55 +01:00
if (!extension_loaded('zip')) {
return false;
}
if (!file_exists($source)) {
return false;
}
$zip = new ZipArchive();
if (!$zip->open($destination, ZIPARCHIVE::CREATE)) {
return false;
}
if (is_dir($source) === true) {
$iterator = new RecursiveDirectoryIterator($source);
$iterator->setFlags(RecursiveDirectoryIterator::SKIP_DOTS);
$files = new RecursiveIteratorIterator($iterator, RecursiveIteratorIterator::SELF_FIRST);
foreach ($files as $file) {
$file = realpath($file);
if (is_dir($file)) {
$zip->addEmptyDir(ltrim(str_replace($source, '', $file), "/\\"));
} elseif (is_file($file)) {
$zip->addFromString(ltrim(str_replace($source, '', $file), "/\\"), file_get_contents($file));
}
}
} elseif (is_file($source)) {
$zip->addFromString(basename($source), file_get_contents($source));
}
return $zip->close();
}
2017-11-16 23:22:55 +01:00
// Uncompress a zip file
// $source = /home/diego/example.zip
// $destionation = /home/diego/content
public static function unzip($source, $destination)
{
if (!extension_loaded('zip')) {
return false;
}
if (!file_exists($source)) {
return false;
}
$zip = new ZipArchive();
if (!$zip->open($source)) {
return false;
}
$zip->extractTo($destination);
return $zip->close();
}
2024-06-23 21:46:43 +02:00
/*
2023-07-15 15:58:33 +02:00
| Returns the next filename if the filename already exist otherwise returns the original filename
|
| @path string Path
| @filename string Filename
|
| @return string
*/
2024-06-23 21:46:43 +02:00
public static function nextFilename($filename, $path = PATH_UPLOADS)
{
// Clean filename and get extension
$fileExtension = pathinfo($filename, PATHINFO_EXTENSION);
$fileExtension = Text::lowercase($fileExtension);
$filename = pathinfo($filename, PATHINFO_FILENAME);
2019-01-15 19:53:04 +01:00
$filename = Text::removeSpaces($filename);
$filename = Text::removeQuotes($filename);
// Search for the next filename
2024-06-23 21:46:43 +02:00
$tmpName = $filename . '.' . $fileExtension;
if (Sanitize::pathFile($path . $tmpName)) {
$number = 0;
2024-06-23 21:46:43 +02:00
$tmpName = $filename . '_' . $number . '.' . $fileExtension;
while (Sanitize::pathFile($path . $tmpName)) {
2018-09-26 17:55:19 +02:00
$number = $number + 1;
2024-06-23 21:46:43 +02:00
$tmpName = $filename . '_' . $number . '.' . $fileExtension;
}
}
return $tmpName;
}
2024-06-23 21:46:43 +02:00
/*
2023-07-15 15:58:33 +02:00
| Returns the filename
| Example:
| @file /home/diego/dog.jpg
| @return dog.jpg
|
| @file string Full path of the file
|
| @return string
*/
2024-06-23 21:46:43 +02:00
public static function filename($file)
{
return basename($file);
}
/*
2023-07-15 15:58:33 +02:00
| Returns the file extension
| Example:
| @file /home/diego/dog.jpg
| @return jpg
|
| @file string Full path of the file
|
| @return string
*/
2024-06-23 21:46:43 +02:00
public static function extension($file)
{
return pathinfo($file, PATHINFO_EXTENSION);
}
2019-11-15 16:47:56 +01:00
/**
* Get Size of file or directory in bytes
* @param [string] $fileOrDirectory
* @return [int|bool] [bytes or false on error]
2019-11-15 16:47:56 +01:00
*/
2024-06-23 21:46:43 +02:00
public static function getSize($fileOrDirectory)
{
2019-11-15 16:47:56 +01:00
// Files
if (is_file($fileOrDirectory)) {
return filesize($fileOrDirectory);
}
// Directories
if (file_exists($fileOrDirectory)) {
2024-06-23 21:46:43 +02:00
$size = 0;
foreach (new RecursiveIteratorIterator(new RecursiveDirectoryIterator($fileOrDirectory, FilesystemIterator::SKIP_DOTS)) as $file) {
2020-02-28 09:36:09 +01:00
try {
$size += $file->getSize();
} catch (Exception $e) {
// SplFileInfo::getSize RuntimeException will be thrown on broken symlinks/errors
}
2024-06-23 21:46:43 +02:00
}
return $size;
2019-11-15 16:47:56 +01:00
}
return false;
}
2024-06-23 21:46:43 +02:00
public static function bytesToHumanFileSize($bytes, $decimals = 2)
{
$size = array('B', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB');
$factor = floor((strlen($bytes) - 1) / 3);
return sprintf("%.{$decimals}f ", $bytes / pow(1024, $factor)) . @$size[$factor];
2019-11-15 16:47:56 +01:00
}
2020-03-14 12:03:43 +01:00
/*
2023-07-15 15:58:33 +02:00
| Returns the mime type of the file
| Example:
| @file /home/diego/dog.jpg
| @return image/jpeg
|
| @file [string] Full path of the file
|
| @return [string|bool] Mime type as string or FALSE if not possible to get the mime type
*/
2024-06-23 21:46:43 +02:00
public static function mimeType($file)
{
2020-07-24 10:37:30 +02:00
if (function_exists('mime_content_type')) {
return mime_content_type($file);
}
if (function_exists('finfo_file')) {
$fileinfo = finfo_open(FILEINFO_MIME_TYPE);
$mimeType = finfo_file($fileinfo, $file);
finfo_close($fileinfo);
return $mimeType;
}
return false;
2020-03-14 12:03:43 +01:00
}
2024-06-23 21:46:43 +02:00
public static function symlink($from, $to)
{
2023-07-15 15:58:33 +02:00
if (function_exists('symlink')) {
2024-06-23 21:46:43 +02:00
Log::set('symlink from = ' . $from . ' to = ' . $to, LOG_TYPE_INFO);
2023-07-15 15:58:33 +02:00
return symlink($from, $to);
} else {
return copy($from, $to);
}
}
2017-12-06 19:14:33 +01:00
}