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


30

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

情報:

  • 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
    )

)

コンテキストの結果配列のダンプを提供できますか?それをtheme_search_resultsに直接渡すことができるかもしれません
クライブ

1
「それらを実行して、ノードを取得し、結果を自分で表示できましたが、検索結果をレンダリングする他の方法が必要だと思います。しかし、それは見つかりませんでした。それが問題です。」- node_view_multiple()
ギャレットオルブライト14年

Clive:検索結果の出力で質問を更新しました。ギャレット:その機能を指摘してくれてありがとう、それが存在することを知らなかった。他のプロジェクトには便利ですが、ここでやりたいこととは関係ありません。:) Search APIクラスでは、キーワードの強調表示と関連する検索テキストの表示が想定されていますが、これらのメソッドを使用して結果をレンダリングする方法を把握できませんでした。これまでに助けてくれてありがとう!:)
ジェイソングレイ14年

Drupal APIの検索機能を見てみましたか?api.drupal.org/api/drupal/modules!search!search.module/7
Agi Hammerthief

私の質問で説明した状況でそれらを使用しましたか?
ジェイソングレイ14年

回答:


4

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


1
ページまたはビューを明示的に使用しないソリューションを求められました
ダニエルウォーターズ

いいえ、彼は「さまざまな理由でビューを使用しない」と言った。Search APIモジュールはサポートしていません。私の提案が
役に立た

2
Search APIページモジュールが出発点として適していることに同意する必要があります。以前にカスタム検索を実装し、そこのコードを開始点として使用しました。これはページを使用せずに実行できます。
paaat

1

これは約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
drupal_gotoではなく、フォーム状態のリダイレクトを使用します。
ケビン
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.