You are here

public function SearchApiAttachmentsFieldCollectionsAlterSettings::alterItems in Search API attachments 7

Alter items before indexing.

Items which are removed from the array won't be indexed, but will be marked as clean for future indexing. This could for instance be used to implement some sort of access filter for security purposes (e.g., don't index unpublished nodes or comments).

Parameters

array $items: An array of items to be altered, keyed by item IDs.

Overrides SearchApiAttachmentsAlterSettings::alterItems

File

contrib/search_api_attachments_field_collections/includes/callback_attachments_field_collections_settings.inc, line 16
Search API data alteration callback.

Class

SearchApiAttachmentsFieldCollectionsAlterSettings

Code

public function alterItems(array &$items) {

  // Get the field collection bundles.
  $field_collections_instances = field_info_instances('field_collection_item');
  $field_collections = array_keys($field_collections_instances);
  if (!empty($field_collections_instances)) {
    foreach ($items as &$item) {

      // Case of field collection fields.
      foreach ($field_collections as $field_collection) {
        if (isset($item->{$field_collection})) {

          // Get the file fields of the field collection item.
          $file_fields = array();
          foreach (array_keys($field_collections_instances[$field_collection]) as $field_name) {
            $field_info = field_info_field($field_name);
            if ($field_info['type'] == 'file') {
              $file_fields[] = $field_name;
            }
          }
          if (empty($file_fields)) {
            return;
          }
          $collections = field_get_items($this->index
            ->getEntityType(), $item, $field_collection);
          if ($collections) {
            $collection_item_ids = array();
            foreach ($collections as $field_collection_id) {
              $collection_item_ids[] = $field_collection_id['value'];
            }
            $collection_items = entity_load_multiple_by_name('field_collection_item', $collection_item_ids);

            // Index the files content.
            foreach ($file_fields as $file_field) {
              foreach ($collection_items as $collection_item) {
                $field_collection_name = $collection_item->field_name;
                if (isset($item->{$field_collection_name}) && !empty($item->{$field_collection_name})) {
                  $files = field_get_items('field_collection_item', $collection_item, $file_field);
                  if (!empty($files)) {

                    // Limit to the max number of value per field.
                    if (isset($this->options['number_indexed']) && $this->options['number_indexed'] != '0' && count($files) > $this->options['number_indexed']) {
                      $files = array_slice($files, 0, $this->options['number_indexed']);
                    }
                    foreach ($files as $file) {
                      if ($this
                        ->isFileIndexable($file, $item, $field_collection_name)) {
                        $attachments = 'attachments_' . $file_field;
                        if (isset($item->{$attachments})) {
                          $item->{$attachments} .= ' ' . $this
                            ->getFileContent($file);
                        }
                        else {
                          $item->{$attachments} = $this
                            ->getFileContent($file);
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}