class EntityTypeFilter in Replication 8
Same name and namespace in other branches
- 8.2 src/Plugin/ReplicationFilter/EntityTypeFilter.php \Drupal\replication\Plugin\ReplicationFilter\EntityTypeFilter
Provides a filter based on entity type.
Use the configuration "types" which is an array of values in the format "{entity_type_id}.{bundle}".
Plugin annotation
@ReplicationFilter(
id = "entity_type",
label = @Translation("Filter By Entity Type"),
description = @Translation("Replicate only entities that match a given type.")
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\replication\Plugin\ReplicationFilter\ReplicationFilterBase implements ReplicationFilterInterface
- class \Drupal\replication\Plugin\ReplicationFilter\EntityTypeFilter
- class \Drupal\replication\Plugin\ReplicationFilter\ReplicationFilterBase implements ReplicationFilterInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of EntityTypeFilter
1 file declares its use of EntityTypeFilter
- EntityTypeFilterTest.php in tests/
src/ Unit/ Plugin/ ReplicationFilter/ EntityTypeFilterTest.php
File
- src/
Plugin/ ReplicationFilter/ EntityTypeFilter.php, line 20
Namespace
Drupal\replication\Plugin\ReplicationFilterView source
class EntityTypeFilter extends ReplicationFilterBase {
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
return [
'types' => [],
];
}
/**
* {@inheritdoc}
*/
public function filter(EntityInterface $entity) {
$configuration = $this
->getConfiguration();
$types = $configuration['types'];
foreach ($types as $type) {
// Handle cases like "node.".
$type = trim($type, '.');
$split = explode('.', $type);
$entity_type_id = $split[0];
$bundle = isset($split[1]) ? $split[1] : NULL;
// Filter for only the entity type id.
if ($bundle == NULL && $entity
->getEntityTypeId() == $entity_type_id) {
return TRUE;
}
// Filter for both the entity type id and bundle.
if ($entity
->getEntityTypeId() == $entity_type_id && $entity
->bundle() == $bundle) {
return TRUE;
}
}
return FALSE;
}
}
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 | |
EntityTypeFilter:: |
public | function |
Gets default configuration for this plugin. Overrides ConfigurablePluginInterface:: |
|
EntityTypeFilter:: |
public | function |
Filter the given entity. Overrides ReplicationFilterInterface:: |
|
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 |
ReplicationFilterBase:: |
protected | property | The description of what the replication filter does. | |
ReplicationFilterBase:: |
protected | property | The human readable label for the replication filter. | |
ReplicationFilterBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
|
ReplicationFilterBase:: |
public | function |
For replication filters, the plugin configuration contains what would be
passed as "query_params" to a CouchDB filter function. Overrides ConfigurablePluginInterface:: |
|
ReplicationFilterBase:: |
public | function |
Get the description of what the filter does. Overrides ReplicationFilterInterface:: |
|
ReplicationFilterBase:: |
public | function |
Get the label for the filter. Overrides ReplicationFilterInterface:: |
|
ReplicationFilterBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurablePluginInterface:: |
|
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. |