class ConfigEntityAdapter in Drupal 8
Same name and namespace in other branches
- 9 core/lib/Drupal/Core/Entity/Plugin/DataType/ConfigEntityAdapter.php \Drupal\Core\Entity\Plugin\DataType\ConfigEntityAdapter
Enhances EntityAdapter for config entities.
Hierarchy
- class \Drupal\Core\TypedData\TypedData implements PluginInspectionInterface, TypedDataInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Core\Entity\Plugin\DataType\EntityAdapter implements \Drupal\Core\Entity\Plugin\DataType\IteratorAggregate, ComplexDataInterface
- class \Drupal\Core\Entity\Plugin\DataType\ConfigEntityAdapter
- class \Drupal\Core\Entity\Plugin\DataType\EntityAdapter implements \Drupal\Core\Entity\Plugin\DataType\IteratorAggregate, ComplexDataInterface
Expanded class hierarchy of ConfigEntityAdapter
2 files declare their use of ConfigEntityAdapter
- ConfigEntityAdapterTest.php in core/
tests/ Drupal/ KernelTests/ Core/ Entity/ ConfigEntityAdapterTest.php - EntityDeriver.php in core/
lib/ Drupal/ Core/ Entity/ Plugin/ DataType/ Deriver/ EntityDeriver.php
File
- core/
lib/ Drupal/ Core/ Entity/ Plugin/ DataType/ ConfigEntityAdapter.php, line 12
Namespace
Drupal\Core\Entity\Plugin\DataTypeView source
class ConfigEntityAdapter extends EntityAdapter {
/**
* The wrapped entity object.
*
* @var \Drupal\Core\Config\Entity\ConfigEntityInterface
*/
protected $entity;
/**
* The typed config manager.
*
* @var \Drupal\Core\Config\TypedConfigManagerInterface
*/
protected $typedConfigManager;
/**
* {@inheritdoc}
*/
public function get($property_name) {
if (!isset($this->entity)) {
throw new MissingDataException("Unable to get property {$property_name} as no entity has been provided.");
}
return $this
->getConfigTypedData()
->get($property_name);
}
/**
* {@inheritdoc}
*/
public function set($property_name, $value, $notify = TRUE) {
if (!isset($this->entity)) {
throw new MissingDataException("Unable to set property {$property_name} as no entity has been provided.");
}
$this->entity
->set($property_name, $value, $notify);
return $this;
}
/**
* {@inheritdoc}
*/
public function getProperties($include_computed = FALSE) {
if (!isset($this->entity)) {
throw new MissingDataException('Unable to get properties as no entity has been provided.');
}
return $this
->getConfigTypedData()
->getProperties($include_computed);
}
/**
* {@inheritdoc}
*/
public function onChange($property_name) {
if (isset($this->entity)) {
// Let the entity know of any changes.
$this
->getConfigTypedData()
->onChange($property_name);
}
}
/**
* {@inheritdoc}
*/
public function getIterator() {
if (isset($this->entity)) {
return $this
->getConfigTypedData()
->getIterator();
}
return new \ArrayIterator([]);
}
/**
* Gets the typed config manager.
*
* @return \Drupal\Core\Config\TypedConfigManagerInterface
* The typed config manager.
*/
protected function getTypedConfigManager() {
if (empty($this->typedConfigManager)) {
// Use the typed data manager if it is also the typed config manager.
// @todo Remove this in https://www.drupal.org/node/3011137.
$typed_data_manager = $this
->getTypedDataManager();
if ($typed_data_manager instanceof TypedConfigManagerInterface) {
$this->typedConfigManager = $typed_data_manager;
}
else {
$this->typedConfigManager = \Drupal::service('config.typed');
}
}
return $this->typedConfigManager;
}
/**
* {@inheritdoc}
*
* @todo Remove this in https://www.drupal.org/node/3011137.
*/
public function getTypedDataManager() {
if (empty($this->typedDataManager)) {
$this->typedDataManager = \Drupal::service('config.typed');
}
return $this->typedDataManager;
}
/**
* {@inheritdoc}
*
* @todo Remove this in https://www.drupal.org/node/3011137.
*/
public function setTypedDataManager(TypedDataManagerInterface $typed_data_manager) {
$this->typedDataManager = $typed_data_manager;
if ($typed_data_manager instanceof TypedConfigManagerInterface) {
$this->typedConfigManager = $typed_data_manager;
}
return $this;
}
/**
* {@inheritdoc}
*/
public function applyDefaultValue($notify = TRUE) {
// @todo Figure out what to do for this method, see
// https://www.drupal.org/project/drupal/issues/2945635.
throw new \BadMethodCallException('Method not supported');
}
/**
* Gets typed data for config entity.
*
* @return \Drupal\Core\TypedData\ComplexDataInterface
* The typed data.
*/
protected function getConfigTypedData() {
return $this
->getTypedConfigManager()
->createFromNameAndData($this->entity
->getConfigDependencyName(), $this->entity
->toArray());
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigEntityAdapter:: |
protected | property |
The wrapped entity object. Overrides EntityAdapter:: |
|
ConfigEntityAdapter:: |
protected | property | The typed config manager. | |
ConfigEntityAdapter:: |
public | function |
Applies the default value. Overrides EntityAdapter:: |
|
ConfigEntityAdapter:: |
public | function |
Gets a property object. Overrides EntityAdapter:: |
|
ConfigEntityAdapter:: |
protected | function | Gets typed data for config entity. | |
ConfigEntityAdapter:: |
public | function |
Overrides EntityAdapter:: |
|
ConfigEntityAdapter:: |
public | function |
Gets an array of property objects. Overrides EntityAdapter:: |
|
ConfigEntityAdapter:: |
protected | function | Gets the typed config manager. | |
ConfigEntityAdapter:: |
public | function |
@todo Remove this in https://www.drupal.org/node/3011137. Overrides TypedDataTrait:: |
|
ConfigEntityAdapter:: |
public | function |
React to changes to a child property or item. Overrides EntityAdapter:: |
|
ConfigEntityAdapter:: |
public | function |
Sets a property value. Overrides EntityAdapter:: |
|
ConfigEntityAdapter:: |
public | function |
@todo Remove this in https://www.drupal.org/node/3011137. Overrides TypedDataTrait:: |
|
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 | |
EntityAdapter:: |
public static | function | Creates an instance wrapping the given entity. | |
EntityAdapter:: |
public | function | Returns the wrapped entity object. | |
EntityAdapter:: |
public | function |
Returns a string representation of the data. Overrides TypedData:: |
|
EntityAdapter:: |
public | function |
Gets the data value. Overrides TypedData:: |
|
EntityAdapter:: |
public | function |
Determines whether the data structure is empty. Overrides ComplexDataInterface:: |
|
EntityAdapter:: |
public | function |
Sets the data value. Overrides TypedData:: |
|
EntityAdapter:: |
public | function |
Returns an array of all property values. Overrides ComplexDataInterface:: |
|
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. | |
TypedData:: |
protected | property | The data definition. | 1 |
TypedData:: |
protected | property | The property name. | |
TypedData:: |
protected | property | The parent typed data object. | |
TypedData:: |
public static | function |
Constructs a TypedData object given its definition and context. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Gets a list of validation constraints. Overrides TypedDataInterface:: |
9 |
TypedData:: |
public | function |
Gets the data definition. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the name of a property or item. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the parent data structure; i.e. either complex data or a list. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
|
TypedData:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
TypedData:: |
public | function |
Returns the property path of the data. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Returns the root of the typed data tree. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Sets the context of a property or item via a context aware parent. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function |
Validates the currently set data value. Overrides TypedDataInterface:: |
|
TypedData:: |
public | function | Constructs a TypedData object given its definition and context. | 3 |
TypedDataTrait:: |
protected | property | The typed data manager used for creating the data types. |