| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- <?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\MimeType;
- use Symfony\Component\HttpFoundation\File\Exception\FileNotFoundException;
- use Symfony\Component\HttpFoundation\File\Exception\AccessDeniedException;
- /**
- * Guesses the mime type with the binary "file" (only available on *nix)
- *
- * @author Bernhard Schussek <bernhard.schussek@symfony.com>
- */
- class FileBinaryMimeTypeGuesser implements MimeTypeGuesserInterface
- {
- private $cmd;
- /**
- * Constructor.
- *
- * The $cmd pattern must contain a "%s" string that will be replaced
- * with the file name to guess.
- *
- * The command output must start with the mime type of the file.
- *
- * @param string $cmd The command to run to get the mime type of a file
- */
- public function __construct($cmd = 'file -b --mime %s 2>/dev/null')
- {
- $this->cmd = $cmd;
- }
- /**
- * Returns whether this guesser is supported on the current OS
- *
- * @return Boolean
- */
- static public function isSupported()
- {
- return !defined('PHP_WINDOWS_VERSION_BUILD');
- }
- /**
- * Guesses the mime type of the file with the given path
- *
- * @see MimeTypeGuesserInterface::guess()
- */
- public function guess($path)
- {
- if (!is_file($path)) {
- throw new FileNotFoundException($path);
- }
- if (!is_readable($path)) {
- throw new AccessDeniedException($path);
- }
- if (!self::isSupported()) {
- return null;
- }
- ob_start();
- // need to use --mime instead of -i. see #6641
- passthru(sprintf($this->cmd, escapeshellarg($path)), $return);
- if ($return > 0) {
- ob_end_clean();
- return null;
- }
- $type = trim(ob_get_clean());
- if (!preg_match('#^([a-z0-9\-]+/[a-z0-9\-]+)#i', $type, $match)) {
- // it's not a type, but an error message
- return null;
- }
- return $match[1];
- }
- }
|