replication-8.x-1.x-dev/src/Plugin/ReplicationFilter/PublishedFilter.php
src/Plugin/ReplicationFilter/PublishedFilter.php
<?php
namespace Drupal\replication\Plugin\ReplicationFilter;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
use Drupal\replication\Plugin\ReplicationFilter\ReplicationFilterBase;
use Symfony\Component\DependencyInjection\ContainerInterface;
/**
* Provides a filter for published entities.
*
* Use the configuration "include_unpublishable_entities" to determine what
* happens to entities that do not have a "status" field, if set to TRUE they
* will be included by the filter, else excluded.
*
* @ReplicationFilter(
* id = "published",
* label = @Translation("Filter Published Nodes"),
* description = @Translation("Replicate only nodes that are published.")
* )
*/
class PublishedFilter extends ReplicationFilterBase implements ContainerFactoryPluginInterface {
/**
* The entity type manager to check for "status" entity key.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* Constructs a new PublishedFilter.
*
* @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 \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
*/
public function __construct(array $configuration, $plugin_id, $plugin_definition, EntityTypeManagerInterface $entity_type_manager) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->entityTypeManager = $entity_type_manager;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container->get('entity_type.manager'));
}
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
return [
'include_unpublishable_entities' => FALSE,
];
}
/**
* {@inheritdoc}
*/
public function filter(EntityInterface $entity) {
// @todo handle translations?
// @todo is there an easier way to tell if an entity is published?
$definition = $this->entityTypeManager->getDefinition($entity->getEntityTypeId());
if ($definition->hasKey('status')) {
$field_name = $definition->getKey('status');
$field_definition = $entity->getFieldDefinition($field_name);
$property = $field_definition->getFieldStorageDefinition()->getMainPropertyName();
return (bool) $entity->get($field_name)->$property;
}
// Determine what to do with entities without a 'status' field.
$configuration = $this->getConfiguration();
return $configuration['include_unpublishable_entities'];
}
}
