You are here

class MigrateTemplateStorage in Migrate Manifest 8

Same name and namespace in other branches
  1. 8.2 src/MigrateTemplateStorage.php \Drupal\migrate_manifest\MigrateTemplateStorage
  2. 3.x src/MigrateTemplateStorage.php \Drupal\migrate_manifest\MigrateTemplateStorage

Storage to access migration template configuration in enabled extensions.

Direct copy of the template storage removed from core.

Hierarchy

Expanded class hierarchy of MigrateTemplateStorage

See also

https://www.drupal.org/node/2676258

1 string reference to 'MigrateTemplateStorage'
migrate_manifest.services.yml in ./migrate_manifest.services.yml
migrate_manifest.services.yml
1 service uses MigrateTemplateStorage
migrate_manifest.template_storage in ./migrate_manifest.services.yml
Drupal\migrate_manifest\MigrateTemplateStorage

File

src/MigrateTemplateStorage.php, line 14

Namespace

Drupal\migrate_manifest
View source
class MigrateTemplateStorage implements MigrateTemplateStorageInterface {

  /**
   * Extension sub-directory containing default configuration for migrations.
   */
  const MIGRATION_TEMPLATE_DIRECTORY = 'migrations';

  /**
   * Template subdirectory.
   *
   * @var string
   */
  protected $directory;

  /**
   * @var \Drupal\Core\Extension\ModuleHandlerInterface
   */
  protected $moduleHandler;

  /**
   * {@inheritdoc}
   */
  public function __construct(ModuleHandlerInterface $module_handler, $directory = self::MIGRATION_TEMPLATE_DIRECTORY) {
    $this->moduleHandler = $module_handler;
    $this->directory = $directory;
  }

  /**
   * {@inheritdoc}
   */
  public function findTemplatesByTag($tag) {
    $templates = $this
      ->getAllTemplates();
    $matched_templates = [];
    foreach ($templates as $template_name => $template) {
      if (!empty($template['migration_tags'])) {
        if (in_array($tag, $template['migration_tags'])) {
          $matched_templates[$template_name] = $template;
        }
      }
    }
    return $matched_templates;
  }

  /**
   * {@inheritdoc}
   */
  public function getTemplateByName($name) {
    $templates = $this
      ->getAllTemplates();
    return isset($templates[$name]) ? $templates[$name] : NULL;
  }

  /**
   * {@inheritdoc}
   */
  public function getAllTemplates() {
    $templates = [];
    foreach ($this->moduleHandler
      ->getModuleDirectories() as $directory) {
      $full_directory = $directory . '/' . $this->directory;
      if (file_exists($full_directory)) {
        $files = scandir($full_directory);
        foreach ($files as $file) {
          if ($file[0] !== '.' && preg_match('/\\.yml$/', $file)) {
            $templates[basename($file, '.yml')] = Yaml::decode(file_get_contents("{$full_directory}/{$file}"));
          }
        }
      }
    }
    return $templates;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
MigrateTemplateStorage::$directory protected property Template subdirectory.
MigrateTemplateStorage::$moduleHandler protected property
MigrateTemplateStorage::findTemplatesByTag public function Find all migration templates with the specified tag. Overrides MigrateTemplateStorageInterface::findTemplatesByTag
MigrateTemplateStorage::getAllTemplates public function Retrieves all migration templates belonging to enabled extensions. Overrides MigrateTemplateStorageInterface::getAllTemplates
MigrateTemplateStorage::getTemplateByName public function Retrieve a template given a specific name. Overrides MigrateTemplateStorageInterface::getTemplateByName
MigrateTemplateStorage::MIGRATION_TEMPLATE_DIRECTORY constant Extension sub-directory containing default configuration for migrations.
MigrateTemplateStorage::__construct public function