SearchPage.php

Same filename in this branch
  1. 8.9.x core/modules/search/src/Entity/SearchPage.php
  2. 8.9.x core/modules/search/src/Plugin/migrate/source/d6/SearchPage.php
Same filename in other branches
  1. 9 core/modules/search/src/Entity/SearchPage.php
  2. 9 core/modules/search/src/Plugin/migrate/source/d6/SearchPage.php
  3. 9 core/modules/search/src/Plugin/migrate/source/d7/SearchPage.php
  4. 10 core/modules/search/src/Entity/SearchPage.php
  5. 10 core/modules/search/src/Plugin/migrate/source/d6/SearchPage.php
  6. 10 core/modules/search/src/Plugin/migrate/source/d7/SearchPage.php
  7. 11.x core/modules/search/src/Entity/SearchPage.php
  8. 11.x core/modules/search/src/Plugin/migrate/source/d6/SearchPage.php
  9. 11.x core/modules/search/src/Plugin/migrate/source/d7/SearchPage.php

Namespace

Drupal\search\Plugin\migrate\source\d7

File

core/modules/search/src/Plugin/migrate/source/d7/SearchPage.php

View source
<?php

namespace Drupal\search\Plugin\migrate\source\d7;

use Drupal\migrate\Row;
use Drupal\migrate_drupal\Plugin\migrate\source\Variable;

/**
 * Get search_active_modules and rankings for core modules.
 *
 * @MigrateSource(
 *   id = "d7_search_page",
 *   source_module = "search"
 * )
 */
class SearchPage extends Variable {
    
    /**
     * {@inheritdoc}
     */
    protected function initializeIterator() {
        return new \ArrayIterator($this->values());
    }
    
    /**
     * {@inheritdoc}
     */
    protected function values() {
        $search_active_modules = $this->variableGet('search_active_modules', '');
        $values = [];
        foreach ([
            'node',
            'user',
        ] as $module) {
            if (isset($search_active_modules[$module])) {
                // Add a module key to identify the source search provider. This value
                // is used in the EntitySearchPage destination plugin.
                $tmp = [
                    'module' => $module,
                    'status' => $search_active_modules[$module],
                ];
                // Add the node_rank_* variables (only relevant to the node module).
                if ($module === 'node') {
                    $tmp = array_merge($tmp, parent::values());
                }
                $values[] = $tmp;
            }
        }
        return $values;
    }
    
    /**
     * {@inheritdoc}
     */
    public function fields() {
        return [
            'module' => $this->t('The module providing a search page.'),
            'status' => $this->t('Whether or not this module is enabled for search.'),
        ];
    }
    
    /**
     * {@inheritdoc}
     */
    public function getIds() {
        $ids['module']['type'] = 'string';
        return $ids;
    }
    
    /**
     * {@inheritdoc}
     */
    public function count($refresh = FALSE) {
        return $this->initializeIterator()
            ->count();
    }
    
    /**
     * {@inheritdoc}
     */
    public function prepareRow(Row $row) {
        $exists = $this->moduleExists($row->getSourceProperty('module'));
        $row->setSourceProperty('module_exists', $exists);
        return parent::prepareRow($row);
    }

}

Classes

Title Deprecated Summary
SearchPage Get search_active_modules and rankings for core modules.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.