abstract class ConfigActionsSourceBase in Config Actions 8
Base class for config_actions plugins.
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\config_actions\ConfigActionsSourceBase implements ConfigActionsSourceInterface, ContainerFactoryPluginInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of ConfigActionsSourceBase
5 files declare their use of ConfigActionsSourceBase
- ConfigActionsArray.php in src/
Plugin/ ConfigActionsSource/ ConfigActionsArray.php - ConfigActionsFile.php in src/
Plugin/ ConfigActionsSource/ ConfigActionsFile.php - ConfigActionsId.php in src/
Plugin/ ConfigActionsSource/ ConfigActionsId.php - ConfigActionsList.php in src/
Plugin/ ConfigActionsSource/ ConfigActionsList.php - ConfigActionsTemplate.php in src/
Plugin/ ConfigActionsSource/ ConfigActionsTemplate.php
File
- src/
ConfigActionsSourceBase.php, line 13
Namespace
Drupal\config_actionsView source
abstract class ConfigActionsSourceBase extends PluginBase implements ConfigActionsSourceInterface, ContainerFactoryPluginInterface {
/**
* @var \Drupal\config_actions\ConfigActionsServiceInterface
*/
protected $actionService;
/**
* The type of the plugin instance
* @var string
*/
protected $pluginType;
/**
* The cached config data for this source instance.
* @var array
*/
protected $sourceData = [];
/**
* The ID value of the source. Plugin specific.
* @var string
*/
protected $sourceId = '';
/**
* The Base namespace for the source. Plugin specific.
* @var string
*/
protected $sourceBase = '';
/**
* Determine if sourceData has been changed since last load/save.
* @var bool
*/
protected $changed = FALSE;
protected $merge = FALSE;
/** ---------------------------------------------- */
/** ABSTRACT Functions to be implemented in Plugin */
/** ---------------------------------------------- */
/**
* {@inheritdoc}
*/
public abstract function doLoad();
/**
* {@inheritdoc}
*/
public abstract function doSave($data);
/**
* {@inheritdoc}
*/
public abstract function detect($source);
/** ------------------------------------------- */
/** GENERAL Functions implemented in Base class */
/** ------------------------------------------- */
/**
* Constructs a new ConfigActionsSource plugin object.
*
* @param array $configuration
* A configuration array containing information about the plugin instance.
* @param string $plugin_id
* The plugin_id for the plugin instance.
* @param mixed $plugin_definition
* The plugin implementation definition.
* @param ConfigActionsServiceInterface $config_action_service
* The ConfigActionsService from the container.
*/
public function __construct(array $configuration, $plugin_id, $plugin_definition, ConfigActionsServiceInterface $config_action_service) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->actionService = $config_action_service;
$this->sourceId = !empty($configuration['source']) ? $configuration['source'] : '';
$this->sourceBase = !empty($configuration['base']) ? $configuration['base'] : '';
$this->pluginType = $plugin_id;
$this
->setData([], FALSE);
}
/**
* Create a plugin instance from the container
*
* @param \Symfony\Component\DependencyInjection\ContainerInterface $container
* @param array $configuration
* @param string $plugin_id
* @param mixed $plugin_definition
* @return static
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
/** @var ConfigActionsServiceInterface $config_action_service */
$config_action_service = $container
->get('config_actions');
return new static($configuration, $plugin_id, $plugin_definition, $config_action_service);
}
/**
* {@inheritdoc}
*/
public function load() {
if ($this
->isChanged()) {
// If data has been changed, return it instead of loading fresh
return $this->sourceData;
}
$data = $this
->doLoad();
return $this
->setData($data, FALSE);
}
/**
* {@inheritdoc}
*/
public function save($data) {
if (!empty($this->sourceId)) {
if ($this
->getMerge() && !empty($data)) {
$existing = $this
->doLoad();
if (!empty($existing)) {
$data = NestedArray::mergeDeepArray([
$existing,
$data,
], TRUE);
}
}
$this
->setData($data, FALSE);
return $this
->doSave($data);
}
else {
return FALSE;
}
}
/**
* {@inheritdoc}
*/
public function getData() {
return $this->sourceData;
}
/**
* {@inheritdoc}
*/
public function setData($data = [], $changed = TRUE) {
$this->sourceData = $data;
$this->changed = $changed;
return $data;
}
/**
* {@inheritdoc}
*/
public function isChanged() {
return $this->changed;
}
/**
* {@inheritdoc}
*/
public function getType() {
return $this->pluginType;
}
/**
* {@inheritdoc}
*/
public function setMerge($merge) {
$this->merge = $merge;
}
/**
* {@inheritdoc}
*/
public function getMerge() {
return $this->merge;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigActionsSourceBase:: |
protected | property | ||
ConfigActionsSourceBase:: |
protected | property | Determine if sourceData has been changed since last load/save. | |
ConfigActionsSourceBase:: |
protected | property | ||
ConfigActionsSourceBase:: |
protected | property | The type of the plugin instance | |
ConfigActionsSourceBase:: |
protected | property | The Base namespace for the source. Plugin specific. | |
ConfigActionsSourceBase:: |
protected | property | The cached config data for this source instance. | |
ConfigActionsSourceBase:: |
protected | property | The ID value of the source. Plugin specific. | |
ConfigActionsSourceBase:: |
public static | function |
Create a plugin instance from the container Overrides ContainerFactoryPluginInterface:: |
3 |
ConfigActionsSourceBase:: |
abstract public | function |
Determine if $source is valid for the specific plugin. Overrides ConfigActionsSourceInterface:: |
5 |
ConfigActionsSourceBase:: |
abstract public | function |
Load data from the source. Overrides ConfigActionsSourceInterface:: |
5 |
ConfigActionsSourceBase:: |
abstract public | function |
Save data to the source. Overrides ConfigActionsSourceInterface:: |
5 |
ConfigActionsSourceBase:: |
public | function |
Get the data cached from the last load/save. Overrides ConfigActionsSourceInterface:: |
|
ConfigActionsSourceBase:: |
public | function |
Return whether the data from this source will be merged Overrides ConfigActionsSourceInterface:: |
|
ConfigActionsSourceBase:: |
public | function |
Return the type of plugin. Overrides ConfigActionsSourceInterface:: |
|
ConfigActionsSourceBase:: |
public | function |
Return TRUE if the data has changed since the last load. Overrides ConfigActionsSourceInterface:: |
|
ConfigActionsSourceBase:: |
public | function |
Load data from the source. Overrides ConfigActionsSourceInterface:: |
|
ConfigActionsSourceBase:: |
public | function |
Save data to the source. Overrides ConfigActionsSourceInterface:: |
|
ConfigActionsSourceBase:: |
public | function |
Set the data cached in this plugin instance.
Causes the plugin to be marked as Changed. Overrides ConfigActionsSourceInterface:: |
|
ConfigActionsSourceBase:: |
public | function |
Set whether data saved in this source should be merged with existing data Overrides ConfigActionsSourceInterface:: |
|
ConfigActionsSourceBase:: |
public | function |
Constructs a new ConfigActionsSource plugin object. Overrides PluginBase:: |
3 |
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 | |
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 plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
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 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. | |
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. |