web-dev-qa-db-ja.com

プログラムによるSearch APIの使用

問題:Search APIを使用してプログラムで自分の検索を実行する必要があります。私が見つけたすべてのgoogleの結果は、非開発者にビューでモジュールを使用する方法を教えることを目的としています。

情報:

  • Solrなどの代わりにローカルデータベースサービスを使用する。
  • 他の結果と一緒に表示されるデータがデータベースに保存されていない。
  • コンテンツは「タイプ」タブにグループ化されます。
  • さまざまな理由でビューを使用しない。
  • Facets APIを有効にしますが、使用方法の手掛かりもありません。

理由:検索ページを/ site-searchに置き、ページ引数の後に/ node/keywordを付けないようにするためです。また、同じタイプの機能を提供する可能性のある他のモジュールの範囲を超えて、これをカスタマイズするよう求められます。そして、私はこれを行う方法を学びたいのですが、それを達成する方法に関するチュートリアルや他の洞察を見つけていません。

残り:検索ページを作成し、その上で次のように検索を実行しています:

$term = $_SESSION['my-search']['term'];
$server = search_api_server_load('database');
$index = search_api_index_load('default_node_index');
$query = new SearchApiQuery($index);
$query->keys($term); 
$query->fields(array('title','body:value')); 
$srv= new SearchApiDbService($server);
$result = $srv->search($query);

セッション変数は、検索フォームが送信されたときに設定され、ユーザーを/ site-searchにリダイレクトして検索を実行し、結果を表示します。

$ resultを出力すると、ノードIDとそのスコアの配列である結果セットを含む、さまざまな情報を持つ配列であることがわかります。

それらを実行し、ノードを取得して結果を自分で表示することもできますが、検索結果をレンダリングするための別の方法が必要だと思います。私はそれを見つけていませんが、それが問題です。

私はSearch APIとFacet APIのさまざまなクラスを調べてきましたが、結果出力を構築するように見えるクラスを見つけることができません。

これでどんな助けでもありがたいです。

結果の例:

Array
(
[result count] => 11
[results] => Array
    (
        [37] => Array
            (
                [id] => 37
                [score] => 15.7503318786621
            )

        [39] => Array
            (
                [id] => 39
                [score] => 7
            )

        [40] => Array
            (
                [id] => 40
                [score] => 5
            )

        [31] => Array
            (
                [id] => 31
                [score] => 4
            )

        [33] => Array
            (
                [id] => 33
                [score] => 1
            )

        [36] => Array
            (
                [id] => 36
                [score] => 1
            )

        [1] => Array
            (
                [id] => 1
                [score] => 1
            )

        [15] => Array
            (
                [id] => 15
                [score] => 1
            )

        [16] => Array
            (
                [id] => 16
                [score] => 1
            )

        [27] => Array
            (
                [id] => 27
                [score] => 1
            )

        [35] => Array
            (
                [id] => 35
                [score] => 0.980873763561249
            )

    )

[warnings] => Array
    (
    )

[ignored] => Array
    (
    )

[performance] => Array
    (
        [complete] => 0.0033111572265625
        [preprocessing] => 0.00053095817565918
        [execution] => 0.0027379989624023
        [postprocessing] => 4.2200088500977E-5
    )

)
29
Jason Gray

検索APIページモジュール を見ましたか? Search APIモジュールを使用して、カスタム検索ページを作成します。あなたはおそらくあなたがしようとしていることを実装する方法についての手がかりのためにそのモジュールを見ることができます。モジュール自体は、あなたが探している多くの機能を提供するかもしれません。

4
n30r3b3l

これが約100行の私の解決策です-ページより少し簡単です...

define('SEARCH_QUERY_TERM', 'query');
define('SEARCH_PAGE_TERM', 'page');
define('SEARCH_LIMIT_TERM', 'limit');
define('SEARCH_DEFAULT_LIMIT', 10);

/**
 * Implements hook_menu().
 */
function my_module_menu() {
    $items['search'] = array(
        'title' => 'Search',
        'page callback' => 'my_module_page',
        'access callback' => TRUE,
        'type' => MENU_CALLBACK,
    );

    return $items;
}

/**
 * My Module Search Functions
 */

function my_module_page() {
    $build = array(
        'form' => drupal_get_form('my_module_form'),
        'results' => array('#theme_wrappers' => array('container')),
    );

    foreach (my_module_result() as $eid => $entity) {
        $build['results'][$eid] = entity_view('node', array($entity), 'teaser');
    }

    return $build;
}

function my_module_form($form, &$form_state) {
    list($query, $page, $limit) = my_module_params();

    $form['query'] = array(
        '#type' => 'textfield',
        '#title' => t('Search'),
        '#default_value' => $query,
    );
    $form['actions'] = array('#type' => 'actions');
    $form['actions']['submit'] = array(
        '#type' => 'submit',
        '#value' => t('Search'),
    );

    return $form;
}

function my_module_form_submit($form, &$form_state) {
    $values = $form_state['values'];
    $query = isset($values['query']) ? $values['query'] : '';
    $form_state['redirect'] = array('search', array('query' => array('query' => $query)));
}

function my_module_params() {
    $query = '';
    $page_number = 0;
    $limit = SEARCH_DEFAULT_LIMIT;
    $params = drupal_get_query_parameters();

    if (isset($params[SEARCH_QUERY_TERM])) {
        $query = $params[SEARCH_QUERY_TERM];
    }
    if (isset($params[SEARCH_PAGE_TERM]) && is_numeric($params[SEARCH_PAGE_TERM])) {
        $page_number = $params[SEARCH_PAGE_TERM];
    }
    if (isset($params[SEARCH_LIMIT_TERM]) && is_numeric($params[SEARCH_LIMIT_TERM])) {
        $limit = $params[SEARCH_LIMIT_TERM];
    }

    return array($query, $page_number, $limit);
}

function my_module_result() {
    $index_id = 'default_node_index';

    list($keys, $page_number, $limit) = my_module_params();
    $offset = $limit * $page_number;

    $options = array(
        'search id' => 'node:default',
    );

    $query = search_api_query($index_id, $options)->keys($keys);

    if ($limit > 0) {
        $query->range($offset, $limit);
    }

    $results = $query->execute();
    $results = isset($results['results']) ? $results['results'] : array();

    return entity_load('node', array_keys($results));
}
1
Aronanda