class ConfigEntityReference in Feeds 8.3
Defines a config entity reference mapper.
Plugin annotation
@FeedsTarget(
id = "config_entity_reference",
field_types = {"entity_reference"},
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\feeds\Plugin\Type\PluginBase implements FeedsPluginInterface uses DependencyTrait
- class \Drupal\feeds\Plugin\Type\ConfigurablePluginBase implements PluginFormInterface
- class \Drupal\feeds\Plugin\Type\Target\TargetBase implements TargetInterface
- class \Drupal\feeds\Plugin\Type\Target\FieldTargetBase implements ConfigurableTargetInterface, TranslatableTargetInterface
- class \Drupal\feeds\Feeds\Target\ConfigEntityReference implements ContainerFactoryPluginInterface, ConfigurableTargetInterface
- class \Drupal\feeds\Plugin\Type\Target\FieldTargetBase implements ConfigurableTargetInterface, TranslatableTargetInterface
- class \Drupal\feeds\Plugin\Type\Target\TargetBase implements TargetInterface
- class \Drupal\feeds\Plugin\Type\ConfigurablePluginBase implements PluginFormInterface
- class \Drupal\feeds\Plugin\Type\PluginBase implements FeedsPluginInterface uses DependencyTrait
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of ConfigEntityReference
1 file declares its use of ConfigEntityReference
- ConfigEntityReferenceTest.php in tests/
src/ Unit/ Feeds/ Target/ ConfigEntityReferenceTest.php
File
- src/
Feeds/ Target/ ConfigEntityReference.php, line 33
Namespace
Drupal\feeds\Feeds\TargetView source
class ConfigEntityReference extends FieldTargetBase implements ConfigurableTargetInterface, ContainerFactoryPluginInterface {
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* The Feeds entity finder service.
*
* @var \Drupal\feeds\EntityFinderInterface
*/
protected $entityFinder;
/**
* The transliteration manager.
*
* @var \Drupal\Component\Transliteration\TransliterationInterface
*/
protected $transliteration;
/**
* The manager for managing config schema type plugins.
*
* @var \Drupal\Core\Config\TypedConfigManagerInterface
*/
protected $typedConfigManager;
/**
* Constructs a ConfigEntityReference object.
*
* @param array $configuration
* The plugin configuration.
* @param string $plugin_id
* The plugin id.
* @param array $plugin_definition
* The plugin definition.
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
* @param \Drupal\feeds\EntityFinderInterface $entity_finder
* The Feeds entity finder service.
* @param \Drupal\Component\Transliteration\TransliterationInterface $transliteration
* The transliteration manager.
* @param \Drupal\Core\Config\TypedConfigManagerInterface $typed_config_manager
* The manager for managing config schema type plugins.
*/
public function __construct(array $configuration, $plugin_id, array $plugin_definition, EntityTypeManagerInterface $entity_type_manager, EntityFinderInterface $entity_finder, TransliterationInterface $transliteration, TypedConfigManagerInterface $typed_config_manager) {
$this->entityTypeManager = $entity_type_manager;
$this->entityFinder = $entity_finder;
$this->transliteration = $transliteration;
$this->typedConfigManager = $typed_config_manager;
parent::__construct($configuration, $plugin_id, $plugin_definition);
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container
->get('entity_type.manager'), $container
->get('feeds.entity_finder'), $container
->get('transliteration'), $container
->get('config.typed'));
}
/**
* {@inheritdoc}
*/
protected static function prepareTarget(FieldDefinitionInterface $field_definition) {
$type = $field_definition
->getSetting('target_type');
if (!\Drupal::entityTypeManager()
->getDefinition($type)
->entityClassImplements(ConfigEntityInterface::class)) {
return;
}
return FieldTargetDefinition::createFromFieldDefinition($field_definition)
->addProperty('target_id');
}
/**
* {@inheritdoc}
*/
public function setTarget(FeedInterface $feed, EntityInterface $entity, $field_name, array $raw_values) {
$values = [];
foreach ($raw_values as $delta => $columns) {
try {
$this
->prepareValue($delta, $columns);
$values[] = $columns;
} catch (ReferenceNotFoundException $e) {
// The referenced entity is not found. We need to enforce Feeds to try
// to import the same item again on the next import.
// Feeds stores a hash of every imported item in order to make the
// import process more efficient by ignoring items it has already seen.
// In this case we need to destroy the hash in order to be able to
// import the reference on a next import.
$entity
->get('feeds_item')->hash = NULL;
$feed
->getState(StateInterface::PROCESS)
->setMessage($e
->getFormattedMessage(), 'warning', TRUE);
} catch (EmptyFeedException $e) {
// Nothing wrong here.
} catch (TargetValidationException $e) {
// Validation failed.
$this
->addMessage($e
->getFormattedMessage(), 'error');
}
}
if (!empty($values)) {
$entity_target = $this
->getEntityTarget($feed, $entity);
if ($entity_target) {
$item_list = $entity_target
->get($field_name);
// Append these values to the existing values.
$values = array_merge($item_list
->getValue(), $values);
$item_list
->setValue($values);
}
}
}
/**
* Returns possible fields to reference by for a config entity.
*
* @return array
* A list of fields to reference by.
*/
protected function getPotentialFields() {
/** @var \Drupal\Core\Config\Entity\ConfigEntityTypeInterface $config_entity_type */
$config_entity_type = $this->entityTypeManager
->getDefinition($this
->getEntityType());
$config_name = $config_entity_type
->getConfigPrefix() . '.*';
$definition = $this->typedConfigManager
->getDefinition($config_name);
if (!empty($definition['mapping'])) {
$options = [];
foreach ($definition['mapping'] as $key => $mapper) {
switch ($mapper['type']) {
case 'integer':
case 'label':
case 'string':
case 'text':
case 'uuid':
$options[$key] = $mapper['label'];
break;
}
}
return $options;
}
return [
'id' => $this
->t('ID'),
'uuid' => $this
->t('UUID'),
];
}
/**
* Returns the entity type that can be referenced.
*
* @return string
* The entity type being referenced.
*/
protected function getEntityType() {
return $this->settings['target_type'];
}
/**
* {@inheritdoc}
*/
protected function prepareValue($delta, array &$values) {
// Check if there is a value for target ID.
if (!isset($values['target_id']) || strlen(trim($values['target_id'])) === 0) {
// No value.
throw new EmptyFeedException();
}
if ($target_id = $this
->findEntity($this->configuration['reference_by'], $values['target_id'])) {
$values['target_id'] = $target_id;
return;
}
throw new ReferenceNotFoundException($this
->t('Referenced entity not found for field %field with value %target_id.', [
'%target_id' => $values['target_id'],
'%field' => $this->configuration['reference_by'],
]));
}
/**
* Searches for an entity by entity key.
*
* @param string $field
* The subfield to search in.
* @param string $search
* The value to search for.
*
* @return int|bool
* The entity id, or false, if not found.
*/
protected function findEntity(string $field, $search) {
$ids = $this->entityFinder
->findEntities($this
->getEntityType(), $field, $search);
if ($ids) {
return reset($ids);
}
return FALSE;
}
/**
* Generates a machine name from a string.
*
* This is basically the same as what is done in
* \Drupal\Core\Block\BlockBase::getMachineNameSuggestion() and
* \Drupal\system\MachineNameController::transliterate(), but it seems
* that so far there is no common service for handling this.
*
* @param string $string
* The string to generate a machine name for.
*
* @return string
* The generated machine name.
*
* @see \Drupal\Core\Block\BlockBase::getMachineNameSuggestion()
* @see \Drupal\system\MachineNameController::transliterate()
*/
protected function generateMachineName($string) {
$transliterated = $this->transliteration
->transliterate($string, LanguageInterface::LANGCODE_DEFAULT, '_');
$transliterated = mb_strtolower($transliterated);
$transliterated = preg_replace('@[^a-z0-9_.]+@', '_', $transliterated);
return $transliterated;
}
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
$config = [
'reference_by' => 'id',
];
return $config;
}
/**
* {@inheritdoc}
*/
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
$options = $this
->getPotentialFields();
// Hack to find out the target delta.
foreach ($form_state
->getValues() as $key => $value) {
if (strpos($key, 'target-settings-') === 0) {
list(, , $delta) = explode('-', $key);
break;
}
}
$form['reference_by'] = [
'#type' => 'select',
'#title' => $this
->t('Reference by'),
'#options' => $options,
'#default_value' => $this->configuration['reference_by'],
];
return $form;
}
/**
* {@inheritdoc}
*/
public function getSummary() {
$options = $this
->getPotentialFields();
$summary = [];
if ($this->configuration['reference_by'] && isset($options[$this->configuration['reference_by']])) {
$summary[] = $this
->t('Reference by: %message', [
'%message' => $options[$this->configuration['reference_by']],
]);
}
else {
$summary[] = $this
->t('Please select a field to reference by.');
}
return $summary;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigEntityReference:: |
protected | property | The Feeds entity finder service. | |
ConfigEntityReference:: |
protected | property | The entity type manager. | |
ConfigEntityReference:: |
protected | property | The transliteration manager. | |
ConfigEntityReference:: |
protected | property | The manager for managing config schema type plugins. | |
ConfigEntityReference:: |
public | function |
Form constructor. Overrides FieldTargetBase:: |
1 |
ConfigEntityReference:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
ConfigEntityReference:: |
public | function |
Gets default configuration for this plugin. Overrides FieldTargetBase:: |
1 |
ConfigEntityReference:: |
protected | function | Searches for an entity by entity key. | 1 |
ConfigEntityReference:: |
protected | function | Generates a machine name from a string. | |
ConfigEntityReference:: |
protected | function | Returns the entity type that can be referenced. | |
ConfigEntityReference:: |
protected | function | Returns possible fields to reference by for a config entity. | |
ConfigEntityReference:: |
public | function |
Returns the summary for a target. Overrides FieldTargetBase:: |
1 |
ConfigEntityReference:: |
protected static | function |
Prepares a target definition. Overrides FieldTargetBase:: |
|
ConfigEntityReference:: |
protected | function |
Prepares a single value. Overrides FieldTargetBase:: |
1 |
ConfigEntityReference:: |
public | function |
Sets the values on an object. Overrides FieldTargetBase:: |
1 |
ConfigEntityReference:: |
public | function |
Constructs a ConfigEntityReference object. Overrides FieldTargetBase:: |
|
ConfigurablePluginBase:: |
public | function |
Form validation handler. Overrides PluginFormInterface:: |
|
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
DependencyTrait:: |
protected | property | The object's dependencies. | |
DependencyTrait:: |
protected | function | Adds multiple dependencies. | |
DependencyTrait:: |
protected | function | Adds a dependency. | |
FieldTargetBase:: |
protected | property | The field settings. | |
FieldTargetBase:: |
protected | property | The language manager. | |
FieldTargetBase:: |
protected | function | Adds a message. | |
FieldTargetBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides PluginBase:: |
|
FieldTargetBase:: |
public | function | Get entity, or entity translation to set the map. | |
FieldTargetBase:: |
public | function |
Gets the configured language. Overrides TranslatableTargetInterface:: |
|
FieldTargetBase:: |
protected | function | Gets the language manager. | |
FieldTargetBase:: |
protected | function | Returns the messenger to use. | |
FieldTargetBase:: |
protected | function | Constructs a base query which is used to find an existing entity. | |
FieldTargetBase:: |
public | function | Looks for an existing entity and returns an entity ID if found. | |
FieldTargetBase:: |
public | function |
Returns if the value for the target is empty. Overrides TargetInterface:: |
|
FieldTargetBase:: |
public | function |
Returns if the target is mutable. Overrides TargetInterface:: |
1 |
FieldTargetBase:: |
protected | function | Checks if the targeted field is translatable. | |
FieldTargetBase:: |
public | function |
Checks if the target is translatable. Overrides TranslatableTargetInterface:: |
|
FieldTargetBase:: |
public | function |
Checks if the language selected on the target exists. Overrides TranslatableTargetInterface:: |
|
FieldTargetBase:: |
public | function |
Allows a plugin to define whether it should be removed. Overrides TargetBase:: |
|
FieldTargetBase:: |
protected | function | Prepares the the values that will be mapped to an entity. | |
FieldTargetBase:: |
public | function | Sets the language manager. | |
FieldTargetBase:: |
public static | function |
Returns the targets defined by this plugin. Overrides TargetInterface:: |
1 |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The importer this plugin is working for. | |
PluginBase:: |
protected | property | The link generator. | |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
protected | property | The url generator. | |
PluginBase:: |
private | function | Returns the service container. | |
PluginBase:: |
public | function |
Returns default feed configuration. Overrides FeedsPluginInterface:: |
3 |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurableInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
PluginBase:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
PluginBase:: |
protected | function | Returns the link generator service. | |
PluginBase:: |
public | function | A feed is being deleted. | 3 |
PluginBase:: |
public | function | A feed is being saved. | |
PluginBase:: |
public | function | The feed type is being deleted. | 1 |
PluginBase:: |
public | function | The feed type is being saved. | 1 |
PluginBase:: |
public | function |
Returns the type of plugin. Overrides FeedsPluginInterface:: |
|
PluginBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: |
1 |
PluginBase:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. | |
PluginBase:: |
protected | function | Returns the URL generator service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
TargetBase:: |
protected | property | The target definition. | |
TargetBase:: |
public | function |
Returns the target's definition. Overrides TargetInterface:: |
|
TargetBase:: |
public | function |
Form submission handler. Overrides ConfigurablePluginBase:: |