n1ed-8.x-2.31/src/FlmngrLegacy/lib/file/Utils.php

src/FlmngrLegacy/lib/file/Utils.php
<?php

/**
 * File Uploader Server package
 * Developer: N1ED
 * Website: https://n1ed.com/
 * License: GNU General Public License Version 3 or later
 **/

namespace Drupal\n1ed\FlmngrLegacy\lib\file;

use Drupal\n1ed\FlmngrLegacy\lib\action\resp\Message;
use Drupal\n1ed\FlmngrLegacy\lib\MessageException;
use Drupal\n1ed\FlmngrLegacy\model\ImageInfo;
use Exception;

class Utils
{
    public static function getNameWithoutExt($filename)
    {
        $ext = Utils::getExt($filename);
        if ($ext == null) {
            return $filename;
        }
        return substr($filename, 0, strlen($filename) - strlen($ext) - 1);
    }

    public static function getExt($name)
    {
        $i = strrpos($name, '.');
        if ($i !== false) {
            return substr($name, $i + 1);
        }
        return null;
    }

    public static function getFreeFileName($dir, $defaultName, $alwaysWithIndex)
    {
        $i = $alwaysWithIndex ? 0 : -1;
        do {
            $i++;
            if ($i == 0) {
                $name = $defaultName;
            } else {
                $name =
                    Utils::getNameWithoutExt($defaultName) .
                    '_' .
                    $i .
                    (Utils::getExt($defaultName) != null
                        ? '.' . Utils::getExt($defaultName)
                        : '');
            }
            $filePath = $dir . $name;
            $ok = !file_exists($filePath);
        } while (!$ok);
        return $name;
    }

    const PROHIBITED_SYMBOLS = "/\\?%*:|\"<>";

    public static function fixFileName($name)
    {
        $newName = '';
        for ($i = 0; $i < strlen($name); $i++) {
            $ch = substr($name, $i, 1);
            if (strpos(Utils::PROHIBITED_SYMBOLS, $ch) !== false) {
                $ch = '_';
            }
            $newName = $newName . $ch;
        }
        return $newName;
    }

    public static function isFileNameSyntaxOk($name)
    {
        if (strlen($name) == 0 || $name == '.' || strpos($name, '..') > -1) {
            return false;
        }

        for ($i = 0; $i < strlen(Utils::PROHIBITED_SYMBOLS); $i++) {
            if (
                strpos($name, substr(Utils::PROHIBITED_SYMBOLS, $i, 1)) !==
                false
            ) {
                return false;
            }
        }

        if (strlen($name) > 260) {
            return false;
        }

        /*
         * TODO: fix this and uncomment
         * On Windows + IIS + PHP produces:
         * Warning:  preg_match(): Unknown modifier '\' in <b>...\vendor\edsdk\file-uploader-server-php\src\lib\file\Utils.php on line 83
         *
         * if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
            // https://stackoverflow.com/questions/6730009/validate-a-file-name-on-windows
            // https://msdn.microsoft.com/en-us/library/aa365247(v=vs.85).aspx#file_and_directory_names
            $pattern =
                "/" .
                "^" .
                "(?!" .
                "  (?:" .
                "    CON|PRN|AUX|NUL|" .
                "    COM[1-9]|LPT[1-9]" .
                "  )" .
                "  (?:\\.[^.]*)?" .
                "  $" .
                ")" .
                "[^<>:\"/\\\\|?*\\x00-\\x1F]*" .
                "[^<>:\"/\\\\|?*\\x00-\\x1F\\ .]" .
                "$/ui";
            if (!preg_match($pattern, $name))
                return false;
        }*/

        return true;
    }

    public static function isImage($name)
    {
        $exts = ['gif', 'jpg', 'jpeg', 'png', 'svg', 'webp', 'bmp'];
        $ext = Utils::getExt($name);
        for ($i = 0; $i < count($exts); $i++) {
            if ($exts[$i] === strtolower($ext)) {
                return true;
            }
        }
        return false;
    }

    public static function addTrailingSlash($value)
    {
        if (
            $value != null &&
            (strlen($value) == 0 || !substr($value, strlen($value) - 1) == '/')
        ) {
            $value .= '/';
        }
        return $value;
    }

    public static function removeTrailingSlash($value)
    {
        if (
            $value != null &&
            (strlen($value) > 0 && substr($value, strlen($value) - 1) == '/')
        ) {
            $value = substr(0, strlen($value) - 1);
        }
        return $value;
    }

    public static function getMimeType($filePath)
    {
        $mimeType = null;
        $filePath = strtolower($filePath);
        if (Utils::endsWith($filePath, '.png')) {
            $mimeType = 'image/png';
        }
        if (Utils::endsWith($filePath, '.gif')) {
            $mimeType = 'image/gif';
        }
        if (Utils::endsWith($filePath, '.bmp')) {
            $mimeType = 'image/bmp';
        }
        if (
            Utils::endsWith($filePath, '.jpg') ||
            Utils::endsWith($filePath, '.jpeg')
        ) {
            $mimeType = 'image/jpeg';
        }
        if (Utils::endsWith($filePath, '.webp')) {
            $mimeType = 'image/webp';
        }
        if (Utils::endsWith($filePath, '.svg')) {
            $mimeType = 'image/svg+xml';
        }

        return $mimeType;
    }

    public static function endsWith($str, $ends)
    {
        return substr($str, -strlen($ends)) === $ends;
    }

    public static function getImageInfo($file)
    {
        $size = @getimagesize($file);
        if ($size === false) {
            //error_log("Unable to read image info of " . $file);
            throw new MessageException(
                Message::createMessage(Message::IMAGE_PROCESS_ERROR)
            );
        }

        $imageInfo = new ImageInfo();
        $imageInfo->width = $size[0];
        $imageInfo->height = $size[1];
        return $imageInfo;
    }

    public static function cleanDirectory($dir)
    {
        Utils::delete($dir, false);
    }

    public static function delete($dirOrFile, $deleteSelfDir = true)
    {
        if (is_file($dirOrFile)) {
            $result = is_dir($dirOrFile)
                ? rmdir($dirOrFile)
                : unlink($dirOrFile);
            if (!$result) {
                throw new Exception('Unable to delete file: ' . $dirOrFile);
            }
        } elseif (is_dir($dirOrFile)) {
            $scan = glob(rtrim($dirOrFile, '/') . '/*');
            foreach ($scan as $index => $path) {
                Utils::delete($path);
            }
            if ($deleteSelfDir) {
                if (!rmdir($dirOrFile)) {
                    throw new Exception(
                        'Unable to delete directory: ' . $dirOrFile
                    );
                }
            }
        }
    }

    public static function copyFile($src, $dst)
    {
        // File will be overwritten if exists - it is OK
        if (!copy($src, $dst)) {
            throw new Exception('Unable to copy file ' . $src . ' to ' . $dst);
        }
    }

    public static function normalizeNoEndSeparator($path)
    {
        // TODO: normalize
        return rtrim($path, '/');
    }

}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc