ExtensionMimeTypeGuesser.php

Same filename in this branch
  1. main core/lib/Drupal/Core/ProxyClass/File/MimeType/ExtensionMimeTypeGuesser.php
Same filename and directory in other branches
  1. 11.x core/lib/Drupal/Core/File/MimeType/ExtensionMimeTypeGuesser.php
  2. 11.x core/lib/Drupal/Core/ProxyClass/File/MimeType/ExtensionMimeTypeGuesser.php
  3. 10 core/lib/Drupal/Core/File/MimeType/ExtensionMimeTypeGuesser.php
  4. 10 core/lib/Drupal/Core/ProxyClass/File/MimeType/ExtensionMimeTypeGuesser.php
  5. 9 core/lib/Drupal/Core/File/MimeType/ExtensionMimeTypeGuesser.php
  6. 9 core/lib/Drupal/Core/ProxyClass/File/MimeType/ExtensionMimeTypeGuesser.php
  7. 8.9.x core/lib/Drupal/Core/File/MimeType/ExtensionMimeTypeGuesser.php
  8. 8.9.x core/lib/Drupal/Core/ProxyClass/File/MimeType/ExtensionMimeTypeGuesser.php

Namespace

Drupal\Core\File\MimeType

File

core/lib/Drupal/Core/File/MimeType/ExtensionMimeTypeGuesser.php

View source
<?php

namespace Drupal\Core\File\MimeType;

use Symfony\Component\Mime\MimeTypeGuesserInterface;

/**
 * Makes possible to guess the MIME type of a file using its extension.
 */
class ExtensionMimeTypeGuesser implements MimeTypeGuesserInterface {
  
  /**
   * Constructs a new ExtensionMimeTypeGuesser.
   *
   * @param \Drupal\Core\File\MimeType\MimeTypeMapInterface $map
   *   The MIME type map.
   */
  public function __construct(protected MimeTypeMapInterface $map) {
  }
  
  /**
   * {@inheritdoc}
   */
  public function guessMimeType($path) : ?string {
    $file_parts = explode('.', basename($path));
    // Remove the first part: a full filename should not match an extension,
    // then iterate over the file parts, trying to find a match.
    // For 'my.awesome.image.jpeg', we try: 'awesome.image.jpeg', then
    // 'image.jpeg', then 'jpeg'.
    // We explicitly check for NULL because that indicates that the array is
    // empty.
    while (array_shift($file_parts) !== NULL) {
      $extension = strtolower(implode('.', $file_parts));
      if ($mimeType = $this->map
        ->getMimeTypeForExtension($extension)) {
        return $mimeType;
      }
    }
    return NULL;
  }
  
  /**
   * {@inheritdoc}
   */
  public function isGuesserSupported() : bool {
    return TRUE;
  }

}

Classes

Title Deprecated Summary
ExtensionMimeTypeGuesser Makes possible to guess the MIME type of a file using its extension.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.