class FlagIndexer in Flag Search API 8
Search API Processor for indexing flags.
Plugin annotation
@SearchApiProcessor(
id = "flag_indexer",
label = @Translation("Flag indexing"),
description = @Translation("Switching on will enable indexing flags on
content"), stages = {
"add_properties" = 1,
"pre_index_save" = -10
}
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\search_api\Plugin\HideablePluginBase implements HideablePluginInterface
- class \Drupal\search_api\Plugin\ConfigurablePluginBase implements ConfigurablePluginInterface uses PluginDependencyTrait
- class \Drupal\search_api\Plugin\IndexPluginBase implements IndexPluginInterface
- class \Drupal\search_api\Processor\ProcessorPluginBase implements ProcessorInterface
- class \Drupal\flag_search_api\Plugin\search_api\processor\FlagIndexer implements ContainerFactoryPluginInterface, PluginFormInterface
- class \Drupal\search_api\Processor\ProcessorPluginBase implements ProcessorInterface
- class \Drupal\search_api\Plugin\IndexPluginBase implements IndexPluginInterface
- class \Drupal\search_api\Plugin\ConfigurablePluginBase implements ConfigurablePluginInterface uses PluginDependencyTrait
- class \Drupal\search_api\Plugin\HideablePluginBase implements HideablePluginInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of FlagIndexer
File
- src/
Plugin/ search_api/ processor/ FlagIndexer.php, line 30
Namespace
Drupal\flag_search_api\Plugin\search_api\processorView source
class FlagIndexer extends ProcessorPluginBase implements PluginFormInterface, ContainerFactoryPluginInterface {
/**
* Flag service.
*
* @var \Drupal\flag\FlagInterface
*/
protected $flagService;
/**
* Logger.
*
* @var \Psr\Log\LoggerInterface
*/
protected $logger;
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container
->get('flag'), $container
->get('logger.factory')
->get('flag_search_api'));
}
/**
* {@inheritdoc}
*/
public function __construct(array $configuration, $plugin_id, array $plugin_definition, FlagService $flagService, LoggerInterface $logger) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->flagService = $flagService;
$this->logger = $logger;
}
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
return array(
'flag_index' => array(),
);
}
/**
* {@inheritdoc}
*/
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
$options = [];
$flags = $this->flagService
->getAllFlags();
foreach ($flags as $flag) {
$options[$flag
->get('id')] = $flag
->get('label');
}
$form['flag_index'] = array(
'#type' => 'checkboxes',
'#title' => $this
->t('Enable these flags on this index'),
'#description' => $this
->t('This will index IDs from users that flagged this content'),
'#options' => $options,
'#default_value' => isset($this->configuration['flag_index']) ? $this->configuration['flag_index'] : [],
);
return $form;
}
/**
* {@inheritdoc}
*/
public function validateConfigurationForm(array &$form, FormStateInterface $form_state) {
$fields = array_filter($form_state
->getValues()['flag_index']);
if ($fields) {
$fields = array_keys($fields);
}
$form_state
->setValue('flag_index', $fields);
}
/**
* {@inheritdoc}
*/
public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
$this
->setConfiguration($form_state
->getValues());
}
/**
* {@inheritdoc}
*/
public function getPropertyDefinitions(DatasourceInterface $datasource = NULL) {
$properties = array();
if (!$datasource) {
// Ensure that our fields are defined.
$fields = $this
->getFieldsDefinition();
foreach ($fields as $field_id => $field_definition) {
$properties[$field_id] = new ProcessorProperty($field_definition);
}
}
return $properties;
}
/**
* Helper function for defining our custom fields.
*/
protected function getFieldsDefinition() {
$config = $this->configuration['flag_index'];
$fields = [];
foreach ($config as $flag) {
$label = $this->flagService
->getFlagById($flag)
->get('label');
$fields['flag_' . $flag] = array(
'label' => $label,
'description' => $label,
'type' => 'integer',
'processor_id' => $this
->getPluginId(),
);
}
return $fields;
}
/**
* {@inheritdoc}
*/
public function addFieldValues(ItemInterface $item) {
$config = $this->configuration['flag_index'];
$flags = $this->flagService
->getAllFlags();
try {
$entity = $item
->getOriginalObject()
->getValue();
foreach ($config as $flag_id) {
$fields = $this
->getFieldsHelper()
->filterForPropertyPath($item
->getFields(), NULL, 'flag_' . $flag_id);
foreach ($fields as $flag_field) {
$users = $this->flagService
->getFlaggingUsers($entity, $flags[$flag_id]);
/** @var \Drupal\user\Entity\User $user */
foreach ($users as $user) {
$flag_field
->addValue($user
->id());
}
}
}
} catch (SearchApiException $exception) {
$this->logger
->error($exception
->getMessage());
}
}
/**
* {@inheritdoc}
*/
public function preIndexSave() {
foreach ($this
->getFieldsDefinition() as $field_id => $field_definition) {
try {
$this
->ensureField(NULL, $field_id, $field_definition['type']);
} catch (SearchApiException $exception) {
$this->logger
->error($exception
->getMessage());
}
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigurablePluginBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
6 |
ConfigurablePluginBase:: |
protected | function | Calculates and adds dependencies of a specific plugin instance. | |
ConfigurablePluginBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurableInterface:: |
|
ConfigurablePluginBase:: |
public | function |
Returns the plugin's description. Overrides ConfigurablePluginInterface:: |
|
ConfigurablePluginBase:: |
protected | function | Calculates and returns dependencies of a specific plugin instance. | |
ConfigurablePluginBase:: |
public | function |
Returns the label for use on the administration pages. Overrides ConfigurablePluginInterface:: |
|
ConfigurablePluginBase:: |
protected | function | Wraps the module handler. | |
ConfigurablePluginBase:: |
public | function |
Informs the plugin that some of its dependencies are being removed. Overrides ConfigurablePluginInterface:: |
5 |
ConfigurablePluginBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: |
3 |
ConfigurablePluginBase:: |
protected | function | Wraps the theme handler. | |
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 | |
DependencyTrait:: |
protected | property | The object's dependencies. | |
DependencyTrait:: |
protected | function | Adds multiple dependencies. | |
DependencyTrait:: |
protected | function | Adds a dependency. | |
FlagIndexer:: |
protected | property | Flag service. | |
FlagIndexer:: |
protected | property | Logger. | |
FlagIndexer:: |
public | function |
Adds the values of properties defined by this processor to the item. Overrides ProcessorPluginBase:: |
|
FlagIndexer:: |
public | function |
Form constructor. Overrides PluginFormInterface:: |
|
FlagIndexer:: |
public static | function |
Creates an instance of the plugin. Overrides ProcessorPluginBase:: |
|
FlagIndexer:: |
public | function |
Gets default configuration for this plugin. Overrides ConfigurablePluginBase:: |
|
FlagIndexer:: |
protected | function | Helper function for defining our custom fields. | |
FlagIndexer:: |
public | function |
Retrieves the properties this processor defines for the given datasource. Overrides ProcessorPluginBase:: |
|
FlagIndexer:: |
public | function |
Preprocesses the search index entity before it is saved. Overrides ProcessorPluginBase:: |
|
FlagIndexer:: |
public | function |
Form submission handler. Overrides PluginFormInterface:: |
|
FlagIndexer:: |
public | function |
Form validation handler. Overrides PluginFormInterface:: |
|
FlagIndexer:: |
public | function |
Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides IndexPluginBase:: |
|
IndexPluginBase:: |
protected | property | The index this processor is configured for. | |
IndexPluginBase:: |
public | function |
Retrieves the index this plugin is configured for. Overrides IndexPluginInterface:: |
|
IndexPluginBase:: |
public | function |
Sets the index this plugin is configured for. Overrides IndexPluginInterface:: |
|
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. | |
PluginDependencyTrait:: |
protected | function | Calculates and adds dependencies of a specific plugin instance. Aliased as: traitCalculatePluginDependencies | 1 |
PluginDependencyTrait:: |
protected | function | Calculates and returns dependencies of a specific plugin instance. Aliased as: traitGetPluginDependencies | |
PluginDependencyTrait:: |
protected | function | Wraps the module handler. Aliased as: traitModuleHandler | 1 |
PluginDependencyTrait:: |
protected | function | Wraps the theme handler. Aliased as: traitThemeHandler | 1 |
ProcessorInterface:: |
constant | Processing stage: add properties. | ||
ProcessorInterface:: |
constant | Processing stage: alter indexed items. | ||
ProcessorInterface:: |
constant | Processing stage: postprocess query. | ||
ProcessorInterface:: |
constant | Processing stage: preprocess index. | ||
ProcessorInterface:: |
constant | Processing stage: preprocess query. | ||
ProcessorInterface:: |
constant | Processing stage: preprocess index. | ||
ProcessorPluginBase:: |
protected | property | The fields helper. | 1 |
ProcessorPluginBase:: |
public | function |
Alter the items to be indexed. Overrides ProcessorInterface:: |
3 |
ProcessorPluginBase:: |
protected | function | Ensures that a field with certain properties is indexed on the index. | |
ProcessorPluginBase:: |
protected | function | Finds a certain field in the index. | |
ProcessorPluginBase:: |
public | function | Retrieves the fields helper. | 1 |
ProcessorPluginBase:: |
public | function |
Returns the weight for a specific processing stage. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Determines whether this plugin should be hidden in the UI. Overrides HideablePluginBase:: |
|
ProcessorPluginBase:: |
public | function |
Determines whether this processor should always be enabled. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Postprocess search results before they are returned by the query. Overrides ProcessorInterface:: |
2 |
ProcessorPluginBase:: |
public | function |
Preprocesses search items for indexing. Overrides ProcessorInterface:: |
5 |
ProcessorPluginBase:: |
public | function |
Preprocesses a search query. Overrides ProcessorInterface:: |
4 |
ProcessorPluginBase:: |
public | function |
Determines whether re-indexing is required after a settings change. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function | Sets the fields helper. | 1 |
ProcessorPluginBase:: |
public | function |
Sets the weight for a specific processing stage. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public static | function |
Checks whether this processor is applicable for a certain index. Overrides ProcessorInterface:: |
8 |
ProcessorPluginBase:: |
public | function |
Checks whether this processor implements a particular stage. Overrides ProcessorInterface:: |
2 |
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. |