class FeaturesAssignmentPackages in Features 8.4
Same name and namespace in other branches
- 8.3 src/Plugin/FeaturesAssignment/FeaturesAssignmentPackages.php \Drupal\features\Plugin\FeaturesAssignment\FeaturesAssignmentPackages
Class for assigning existing modules to packages.
Plugin annotation
@Plugin(
id = "packages",
weight = -20,
name = @Translation("Packages"),
description = @Translation("Detect and add existing package modules."),
)
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\features\Plugin\FeaturesAssignment\FeaturesAssignmentPackages
- class \Drupal\features\FeaturesAssignmentMethodBase implements FeaturesAssignmentMethodInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of FeaturesAssignmentPackages
File
- src/
Plugin/ FeaturesAssignment/ FeaturesAssignmentPackages.php, line 17
Namespace
Drupal\features\Plugin\FeaturesAssignmentView source
class FeaturesAssignmentPackages extends FeaturesAssignmentMethodBase {
/**
* {@inheritdoc}
*/
public function assignPackages($force = FALSE) {
$bundle = $this->assigner
->getBundle();
$existing = $this->featuresManager
->getFeaturesModules();
foreach ($existing as $extension) {
$package = $this->featuresManager
->initPackageFromExtension($extension);
$short_name = $package
->getMachineName();
// Copy over package excluded settings, if any.
if ($package
->getExcluded()) {
$config_collection = $this->featuresManager
->getConfigCollection();
foreach ($package
->getExcluded() as $config_name) {
if (isset($config_collection[$config_name])) {
$package_excluded = $config_collection[$config_name]
->getPackageExcluded();
$package_excluded[] = $short_name;
$config_collection[$config_name]
->setPackageExcluded($package_excluded);
}
}
$this->featuresManager
->setConfigCollection($config_collection);
}
// Assign required components, if any.
if ($package
->getRequired() !== FALSE) {
$config = $package
->getRequired();
if (empty($config) || !is_array($config)) {
// If required is "true" or empty, add all config as required.
$config = $this->featuresManager
->listExtensionConfig($extension);
}
$this->featuresManager
->assignConfigPackage($short_name, $config);
}
}
}
}
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 | Injects the features manager. | |
FeaturesAssignmentPackages:: |
public | function |
Performs package assignment. Overrides FeaturesAssignmentMethodInterface:: |
|
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. |