abstract class FeaturesAssignmentMethodBase in Features 8.4
Same name and namespace in other branches
- 8.3 src/FeaturesAssignmentMethodBase.php \Drupal\features\FeaturesAssignmentMethodBase
Base class for package assignment methods.
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\features\FeaturesAssignmentMethodBase implements FeaturesAssignmentMethodInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of FeaturesAssignmentMethodBase
12 files declare their use of FeaturesAssignmentMethodBase
- FeaturesAssignmentAlter.php in src/
Plugin/ FeaturesAssignment/ FeaturesAssignmentAlter.php - FeaturesAssignmentBaseType.php in src/
Plugin/ FeaturesAssignment/ FeaturesAssignmentBaseType.php - FeaturesAssignmentCoreType.php in src/
Plugin/ FeaturesAssignment/ FeaturesAssignmentCoreType.php - FeaturesAssignmentDependency.php in src/
Plugin/ FeaturesAssignment/ FeaturesAssignmentDependency.php - FeaturesAssignmentExclude.php in src/
Plugin/ FeaturesAssignment/ FeaturesAssignmentExclude.php
File
- src/
FeaturesAssignmentMethodBase.php, line 12
Namespace
Drupal\featuresView source
abstract class FeaturesAssignmentMethodBase extends PluginBase implements FeaturesAssignmentMethodInterface {
/**
* The features manager.
*
* @var \Drupal\features\FeaturesManagerInterface
*/
protected $featuresManager;
/**
* The features assigner.
*
* @var \Drupal\features\FeaturesAssignerInterface
*/
protected $assigner;
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* The configuration factory.
*
* @var \Drupal\Core\Config\ConfigFactoryInterface
*/
protected $configFactory;
/**
* {@inheritdoc}
*/
public function setfeaturesManager(FeaturesManagerInterface $features_manager) {
$this->featuresManager = $features_manager;
}
/**
* {@inheritdoc}
*/
public function setAssigner(FeaturesAssignerInterface $assigner) {
$this->assigner = $assigner;
}
/**
* {@inheritdoc}
*/
public function setEntityTypeManager(EntityTypeManagerInterface $entity_type_manager) {
$this->entityTypeManager = $entity_type_manager;
}
/**
* {@inheritdoc}
*/
public function setConfigFactory(ConfigFactoryInterface $config_factory) {
$this->configFactory = $config_factory;
}
/**
* Assigns configuration of the types specified in a setting to a package.
*
* @param string $machine_name
* Machine name of the package.
* @param bool $force
* (optional) If TRUE, assign config regardless of restrictions such as it
* being already assigned to a package.
*/
protected function assignPackageByConfigTypes($machine_name, $force = FALSE) {
$current_bundle = $this->assigner
->getBundle();
$settings = $current_bundle
->getAssignmentSettings($this
->getPluginId());
$types = $settings['types']['config'];
$config_collection = $this->featuresManager
->getConfigCollection();
foreach ($config_collection as $item_name => $item) {
// Don't assign configuration that's provided by an extension.
if (in_array($item
->getType(), $types) && !$item
->isProviderExcluded()) {
try {
$this->featuresManager
->assignConfigPackage($machine_name, [
$item_name,
]);
} catch (\Exception $exception) {
\Drupal::logger('features')
->error($exception
->getMessage());
}
}
}
}
/**
* Assigns a given subdirectory to configuration of specified types.
*
* @param string $subdirectory
* The subdirectory that designated configuration should be exported to.
*/
protected function assignSubdirectoryByConfigTypes($subdirectory) {
$current_bundle = $this->assigner
->getBundle();
$settings = $current_bundle
->getAssignmentSettings($this
->getPluginId());
$types = $settings['types']['config'];
if (!empty($types)) {
$config_collection = $this->featuresManager
->getConfigCollection();
foreach ($config_collection as &$item) {
if (in_array($item
->getType(), $types)) {
$item
->setSubdirectory($subdirectory);
}
}
// Clean up the $item pass by reference.
unset($item);
$this->featuresManager
->setConfigCollection($config_collection);
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
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 | |
FeaturesAssignmentMethodBase:: |
protected | property | The features assigner. | |
FeaturesAssignmentMethodBase:: |
protected | property | The configuration factory. | |
FeaturesAssignmentMethodBase:: |
protected | property | The entity type manager. | |
FeaturesAssignmentMethodBase:: |
protected | property | The features manager. | |
FeaturesAssignmentMethodBase:: |
protected | function | Assigns configuration of the types specified in a setting to a package. | |
FeaturesAssignmentMethodBase:: |
protected | function | Assigns a given subdirectory to configuration of specified types. | |
FeaturesAssignmentMethodBase:: |
public | function |
Injects the features assigner. Overrides FeaturesAssignmentMethodInterface:: |
|
FeaturesAssignmentMethodBase:: |
public | function |
Injects the configuration factory. Overrides FeaturesAssignmentMethodInterface:: |
|
FeaturesAssignmentMethodBase:: |
public | function |
Injects the entity manager. Overrides FeaturesAssignmentMethodInterface:: |
|
FeaturesAssignmentMethodBase:: |
public | function | ||
FeaturesAssignmentMethodInterface:: |
public | function | Performs package assignment. | 12 |
FeaturesAssignmentMethodInterface:: |
public | function | Injects the features manager. | |
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. | |
PluginBase:: |
public | function | Constructs a \Drupal\Component\Plugin\PluginBase object. | 92 |
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. |