Uso programmatico dell'API di ricerca


30

Problema: è necessario eseguire le mie ricerche programmaticamente con l'API di ricerca. Ogni risultato di Google che trovo è orientato a insegnare ai non sviluppatori come utilizzare il modulo con Views senza risultati nel farlo come voglio.

Informazione:

  • Utilizzo del servizio di database locale anziché Solr o qualsiasi altro.
  • Hanno dati non memorizzati nel database che appariranno accanto ad altri risultati.
  • Il contenuto verrà raggruppato in schede "tipo".
  • Non utilizzare Views per vari motivi.
  • L'API Facets è abilitata, ma non si sa nemmeno come usarla.

Perché: perché voglio che la pagina di ricerca sia in / site-search e senza / node / parola chiave dopo l'argomento della pagina. Inoltre verrà chiesto di personalizzare questo oltre l'ambito di altri moduli che possono fornire lo stesso tipo di funzionalità. E voglio imparare a farlo, ma non ho trovato nessun tutorial o altra intuizione su come realizzarlo.

Il resto: ho creato la mia pagina di ricerca e su di essa sto eseguendo la ricerca con:

$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);

La variabile di sessione viene impostata quando viene inviato un modulo di ricerca, quindi reindirizza l'utente a / site-search per eseguire la ricerca e mostrare i risultati.

Se output $ risultato vedo che è un array con informazioni diverse tra cui un set di risultati che è un array di ID nodo e i loro punteggi.

Potrei scorrere quelli, afferrando il nodo e mostrando i risultati da solo, ma immagino che ci debba essere un altro metodo per rendere i risultati della ricerca. Non l'ho trovato però e questo è il problema.

Ho esaminato le diverse classi nell'API di ricerca e nell'API Facet e non riesco a trovare nulla in esse che sembra che creino un risultato.

Qualsiasi aiuto con questo sarà apprezzato.

Esempio di risultati:

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
    )

)

Potresti fornire un dump dell'array dei risultati per il contesto? Potresti riuscire a passarlo direttamente a theme_search_results
Clive

1
"Potrei scorrere quelli, afferrando il nodo e mostrando i risultati da solo, ma immagino che ci debba essere un altro metodo per rendere i risultati della ricerca. Non l'ho trovato e questo è il problema." - node_view_multiple () ?
Garrett Albright,

Clive: ho aggiornato la mia domanda con l'output dei risultati della ricerca. Garrett: Grazie per aver sottolineato quella funzione, non sapevo che esistesse. Sarà utile per alcuni altri progetti, ma non ha alcuna rilevanza per quello che voglio fare qui. :) Si suppone che ci sia l'evidenziazione delle parole chiave e la visualizzazione del testo di ricerca pertinente nelle classi dell'API di ricerca, ma non sono stato in grado di capire come ottenere i risultati per il rendering utilizzando questi metodi. Grazie per l'aiuto finora! :)
Jason Gray,

Hai provato a guardare le funzioni di ricerca nell'API Drupal? api.drupal.org/api/drupal/modules!search!search.module/7
Agi Hammerthief

Li hai usati nella situazione che ho descritto nella mia domanda?
Jason Gray,

Risposte:


4

Hai guardato il modulo Pagine dell'API di ricerca . Utilizza il modulo API di ricerca e crea una pagina di ricerca personalizzata. Probabilmente potresti dare un'occhiata a quel modulo per indizi su come implementare ciò che stai cercando di fare. Il modulo stesso potrebbe anche fornire molte delle funzionalità che stai cercando.


1
È stata chiesta una soluzione che non utilizzava esplicitamente pagine o visualizzazioni
Daniel Waters il

No, ha detto "Non usare Views per vari motivi". Il modulo API di ricerca no. Scusate se il mio suggerimento non ha aiutato
n30r3b3l

2
Dovrei essere d'accordo sul fatto che il modulo delle pagine dell'API di ricerca sia un buon punto di partenza! In passato ho implementato una ricerca personalizzata e ho usato il codice come punto di partenza, cosa che può essere fatta senza usare le pagine!
paaat,

1

Ecco la mia soluzione in circa 100 righe - un po 'più semplice delle pagine ...

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
Utilizza i reindirizzamenti dello stato del modulo e non drupal_goto.
Kevin,
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.