class ImagemagickMimeTypeMapper in ImageMagick 8.2
Maps MIME types to file extensions.
Hierarchy
- class \Drupal\imagemagick\ImagemagickMimeTypeMapper
Expanded class hierarchy of ImagemagickMimeTypeMapper
1 string reference to 'ImagemagickMimeTypeMapper'
1 service uses ImagemagickMimeTypeMapper
File
- src/
ImagemagickMimeTypeMapper.php, line 12
Namespace
Drupal\imagemagickView source
class ImagemagickMimeTypeMapper {
/**
* The extension MIME type guesser.
*
* @var \Drupal\Core\File\MimeType\ExtensionMimeTypeGuesser
*/
protected $mimeTypeGuesser;
/**
* The MIME types mapping array after going through the module handler.
*
* Copied via Reflection from
* \Drupal\Core\File\MimeType\ExtensionMimeTypeGuesser.
*
* @var array
*/
protected $mapping;
/**
* Constructs an ImagemagickMimeTypeMapper object.
*
* @param \Symfony\Component\HttpFoundation\File\MimeType\MimeTypeGuesserInterface $extension_mimetype_guesser
* The extension MIME type guesser.
*/
public function __construct(MimeTypeGuesserInterface $extension_mimetype_guesser) {
$this->mimeTypeGuesser = $extension_mimetype_guesser;
}
/**
* Returns the MIME types mapping array from ExtensionMimeTypeGuesser.
*
* Copied via Reflection from
* \Drupal\Core\File\MimeType\ExtensionMimeTypeGuesser.
*
* @return array
* The MIME types mapping array.
*/
protected function getMapping() {
if (!$this->mapping) {
// Guess a fake file name just to ensure the guesser loads any mapping
// alteration through the hooks.
$this->mimeTypeGuesser
->guess('fake.png');
// Use Reflection to get a copy of the protected $mapping property in the
// guesser class. Get the proxied service first, then the actual mapping.
$reflection = new \ReflectionObject($this->mimeTypeGuesser);
$proxied_service = $reflection
->getProperty('service');
$proxied_service
->setAccessible(TRUE);
$service = $proxied_service
->getValue(clone $this->mimeTypeGuesser);
$reflection = new \ReflectionObject($service);
$reflection_mapping = $reflection
->getProperty('mapping');
$reflection_mapping
->setAccessible(TRUE);
$this->mapping = $reflection_mapping
->getValue(clone $service);
}
return $this->mapping;
}
/**
* Returns the appropriate extensions for a given MIME type.
*
* @param string $mimetype
* A MIME type.
*
* @return string[]
* An array of file extensions matching the MIME type, without leading dot.
*
* @deprecated in ImageMagick 8.x-2.4, will be removed in 8.x-3.0.
* Use FileEye\MimeMap\Type::getExtensions() instead.
*
* @see https://www.drupal.org/project/imagemagick/issues/3026733
*/
public function getExtensionsForMimeType($mimetype) {
@trigger_error(__METHOD__ . ' is deprecated in ImageMagick 8.x-2.4, will be removed in 8.x-3.0. Use FileEye\\MimeMap\\Type::getExtensions() instead. See https://www.drupal.org/project/imagemagick/issues/3026733.', E_USER_DEPRECATED);
$mapping = $this
->getMapping();
if (!in_array($mimetype, $mapping['mimetypes'])) {
return [];
}
$key = array_search($mimetype, $mapping['mimetypes']);
$extensions = array_keys($mapping['extensions'], $key, TRUE);
sort($extensions);
return $extensions;
}
/**
* Returns known MIME types.
*
* @return string[]
* An array of MIME types.
*
* @deprecated in ImageMagick 8.x-2.4, will be removed in 8.x-3.0.
* Use FileEye\MimeMap\AbstractMap::listTypes() instead.
*
* @see https://www.drupal.org/project/imagemagick/issues/3026733
*/
public function getMimeTypes() {
@trigger_error(__METHOD__ . ' is deprecated in ImageMagick 8.x-2.4, will be removed in 8.x-3.0. Use FileEye\\MimeMap\\AbstractMap::listTypes() instead. See https://www.drupal.org/project/imagemagick/issues/3026733.', E_USER_DEPRECATED);
return array_values($this
->getMapping()['mimetypes']);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ImagemagickMimeTypeMapper:: |
protected | property | The MIME types mapping array after going through the module handler. | |
ImagemagickMimeTypeMapper:: |
protected | property | The extension MIME type guesser. | |
ImagemagickMimeTypeMapper:: |
public | function | Returns the appropriate extensions for a given MIME type. | |
ImagemagickMimeTypeMapper:: |
protected | function | Returns the MIME types mapping array from ExtensionMimeTypeGuesser. | |
ImagemagickMimeTypeMapper:: |
public | function | Returns known MIME types. | |
ImagemagickMimeTypeMapper:: |
public | function | Constructs an ImagemagickMimeTypeMapper object. |