You are here

public function DefaultContentScanner::scan in Default Content 8

Returns a list of file objects.

Parameters

string $directory: Absolute path to the directory to search.

Return value

array List of stdClass objects with name and uri properties.

File

src/DefaultContentScanner.php, line 24
Contains \Drupal\defaultcontent\DefaultContentScanner.

Class

DefaultContentScanner
A scanner to find YAML files in a given folder.

Namespace

Drupal\defaultcontent

Code

public function scan($directory, $ext = 'json') {

  // Use Unix paths regardless of platform, skip dot directories, follow
  // symlinks (to allow extensions to be linked from elsewhere), and return
  // the RecursiveDirectoryIterator instance to have access to getSubPath(),
  // since SplFileInfo does not support relative paths.
  $flags = \FilesystemIterator::UNIX_PATHS;
  $flags |= \FilesystemIterator::SKIP_DOTS;
  $flags |= \FilesystemIterator::CURRENT_AS_SELF;
  $directory_iterator = new \RecursiveDirectoryIterator($directory, $flags);
  $iterator = new \RecursiveIteratorIterator($directory_iterator);
  $files = array();
  foreach ($iterator as $fileinfo) {

    /* @var \SplFileInfo $fileinfo */

    // Skip directories and non-json files.
    if ($fileinfo
      ->isDir() || $fileinfo
      ->getExtension() != $ext) {
      continue;
    }

    // @todo Use a typed class?
    $file = new \stdClass();
    $file->name = $fileinfo
      ->getFilename();
    $file->uri = $fileinfo
      ->getPathname();
    $files[$file->uri] = $file;
  }
  return $files;
}