migrate_file_to_media-8.x-1.x-dev/src/Plugin/migrate/source/MediaEntityGeneratorTaxonomyD7.php
src/Plugin/migrate/source/MediaEntityGeneratorTaxonomyD7.php
<?php
namespace Drupal\migrate_file_to_media\Plugin\migrate\source;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Drupal\Core\State\StateInterface;
use Drupal\migrate\Plugin\MigrationInterface;
use Drupal\taxonomy\Plugin\migrate\source\d7\Term;
use Symfony\Component\DependencyInjection\ContainerInterface;
/**
* Returns bare-bones information about every available file entity.
*
* @MigrateSource(
* id = "media_entity_generator_d7_taxonomy",
* source_module = "file",
* )
*/
class MediaEntityGeneratorTaxonomyD7 extends Term {
/**
* An array of source fields.
*
* @var array
*/
protected array $sourceFields = [];
/**
* MediaEntityGenerator constructor.
*
* @param array $configuration
* Configuration values.
* @param string $plugin_id
* Plugin IDs.
* @param mixed $plugin_definition
* Definition of Plugins.
* @param \Drupal\migrate\Plugin\MigrationInterface $migration
* Parameter for the interface of Migration.
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* Parameter of Entity Type Manager.
* @param \Drupal\Core\State\StateInterface $state
* State Management.
*/
public function __construct(
array $configuration,
string $plugin_id,
$plugin_definition,
MigrationInterface $migration,
EntityTypeManagerInterface $entity_type_manager,
StateInterface $state,
) {
parent::__construct($configuration, $plugin_id, $plugin_definition, $migration, $state, $entity_type_manager);
// Do not Join tables.
$this->configuration['ignore_map'] = TRUE;
foreach ($this->configuration['field_names'] as $name) {
$this->sourceFields[$name] = $name;
}
}
/**
* {@inheritdoc}
*/
public static function create(
ContainerInterface $container,
array $configuration,
$plugin_id,
$plugin_definition,
?MigrationInterface $migration = NULL,
) {
return new static(
$configuration,
$plugin_id,
$plugin_definition,
$migration,
$container->get('entity_type.manager'),
$container->get('state')
);
}
/**
* {@inheritDoc}
*/
public function count($refresh = FALSE): int {
return $this->initializeIterator()->count();
}
/**
* {@inheritdoc}
*/
public function getIds() {
return [
'target_id' => [
'type' => 'integer',
],
];
}
/**
* {@inheritdoc}
*/
protected function initializeIterator(): \ArrayIterator {
$query_files = $this->select('file_managed', 'f')
->fields('f')
->condition('uri', 'temporary://%', 'NOT LIKE')
->orderBy('f.timestamp');
$all_files = $query_files->execute()->fetchAllAssoc('fid');
$files_found = [];
foreach ($this->sourceFields as $name => $source_field) {
$parent_iterator = parent::initializeIterator();
foreach ($parent_iterator as $entity) {
$id = $entity['tid'];
$field_value = $this->getFieldValues($this->configuration['entity_type'], $name, $id);
foreach ($field_value as $reference) {
// Support remote file urls.
$file_url = $all_files[$reference['fid']]['uri'];
if (!empty($this->configuration['d7_file_url'])) {
$file_url = str_replace('public://', '', $file_url);
$file_path = rawurlencode($file_url);
$file_url = $this->configuration['d7_file_url'] . $file_path;
}
if (!empty($all_files[$reference['fid']]['uri'])) {
$files_found[] = [
'tid' => $entity['tid'],
'target_id' => $reference['fid'],
'alt' => $reference['alt'] ?? NULL,
'title' => $reference['title'] ?? NULL,
'display' => $reference['display'] ?? NULL,
'description' => $reference['description'] ?? NULL,
'langcode' => $this->configuration['langcode'],
'entity' => $entity,
'file_name' => $all_files[$reference['fid']]['filename'],
'file_path' => $file_url,
'file_mime' => $all_files[$reference['fid']]['filemime'],
'file_type' => $all_files[$reference['fid']]['type'],
];
}
}
}
}
return new \ArrayIterator($files_found);
}
}
