| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 | <?php/* * This file is part of the Symfony package. * * (c) Fabien Potencier <fabien@symfony.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */namespace Symfony\Component\HttpFoundation\File;use Symfony\Component\HttpFoundation\File\Exception\FileException;use Symfony\Component\HttpFoundation\File\Exception\FileNotFoundException;use Symfony\Component\HttpFoundation\File\MimeType\MimeTypeGuesser;use Symfony\Component\HttpFoundation\File\MimeType\ExtensionGuesser;/** * A file in the file system. * * @author Bernhard Schussek <bernhard.schussek@symfony.com> * * @api */class File extends \SplFileInfo{    /**     * Constructs a new file from the given path.     *     * @param string  $path      The path to the file     * @param Boolean $checkPath Whether to check the path or not     *     * @throws FileNotFoundException If the given path is not a file     *     * @api     */    public function __construct($path, $checkPath = true)    {        if ($checkPath && !is_file($path)) {            throw new FileNotFoundException($path);        }        parent::__construct($path);    }    /**     * Returns the extension based on the mime type.     *     * If the mime type is unknown, returns null.     *     * @return string|null The guessed extension or null if it cannot be guessed     *     * @api     */    public function guessExtension()    {        $type = $this->getMimeType();        $guesser = ExtensionGuesser::getInstance();        return $guesser->guess($type);    }    /**     * Returns the mime type of the file.     *     * The mime type is guessed using the functions finfo(), mime_content_type()     * and the system binary "file" (in this order), depending on which of those     * is available on the current operating system.     *     * @return string|null The guessed mime type (i.e. "application/pdf")     *     * @api     */    public function getMimeType()    {        $guesser = MimeTypeGuesser::getInstance();        return $guesser->guess($this->getPathname());    }    /**     * Returns the extension of the file.     *     * \SplFileInfo::getExtension() is not available before PHP 5.3.6     *     * @return string The extension     *     * @api     */    public function getExtension()    {        return pathinfo($this->getBasename(), PATHINFO_EXTENSION);    }    /**     * Moves the file to a new location.     *     * @param string $directory The destination folder     * @param string $name      The new file name     *     * @return File A File object representing the new file     *     * @throws FileException if the target file could not be created     *     * @api     */    public function move($directory, $name = null)    {        if (!is_dir($directory)) {            if (false === @mkdir($directory, 0777, true)) {                throw new FileException(sprintf('Unable to create the "%s" directory', $directory));            }        } elseif (!is_writable($directory)) {            throw new FileException(sprintf('Unable to write in the "%s" directory', $directory));        }        $target = $directory.DIRECTORY_SEPARATOR.(null === $name ? $this->getBasename() : basename($name));        if (!@rename($this->getPathname(), $target)) {            $error = error_get_last();            throw new FileException(sprintf('Could not move the file "%s" to "%s" (%s)', $this->getPathname(), $target, strip_tags($error['message'])));        }        chmod($target, 0666);        return new File($target);    }}
 |