123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266 |
- <?php
- require_once 'xapian.php';
- require_once dirname(__FILE__) . '/../IndexableChunk.class.php';
- require_once api_get_path(LIBRARY_PATH) . 'specific_fields_manager.lib.php';
- define('XAPIAN_DB', api_get_path(SYS_UPLOAD_PATH) . 'plugins/xapian/searchdb/');
- function xapian_query($query_string, $db = NULL, $start = 0, $length = 10, $extra = array(), $count_type = 0) {
- try {
- if (!is_object($db)) {
- $db = new XapianDatabase(XAPIAN_DB);
- }
-
- $subqueries = array();
- foreach ($extra as $subquery) {
- if (!empty($subquery)) {
- $subqueries[] = new XapianQuery($subquery);
- }
- }
- $query = NULL;
- $enquire = new XapianEnquire($db);
- if (!empty($query_string)) {
- $query_parser = new XapianQueryParser();
-
- $stemmer = new XapianStem("english");
- $query_parser->set_stemmer($stemmer);
- $query_parser->set_database($db);
- $query_parser->set_stemming_strategy(XapianQueryParser::STEM_SOME);
- $query_parser->add_boolean_prefix('courseid', XAPIAN_PREFIX_COURSEID);
- $query_parser->add_boolean_prefix('toolid', XAPIAN_PREFIX_TOOLID);
- $query = $query_parser->parse_query($query_string);
- $final_array = array_merge($subqueries, array($query));
- $query = new XapianQuery(XapianQuery::OP_AND, $final_array);
- } else {
- $query = new XapianQuery(XapianQuery::OP_OR, $subqueries);
- }
- $enquire->set_query($query);
- $matches = $enquire->get_mset((int) $start, (int) $length);
- $specific_fields = get_specific_field_list();
- $results = array();
- $i = $matches->begin();
-
-
- $count = 0;
- while (!$i->equals($matches->end())) {
- $count++;
- $document = $i->get_document();
- if (is_object($document)) {
-
- $courseid_terms = xapian_get_doc_terms($document, XAPIAN_PREFIX_COURSEID);
- $results[$count]['courseid'] = substr($courseid_terms[0]['name'], 1);
- $toolid_terms = xapian_get_doc_terms($document, XAPIAN_PREFIX_TOOLID);
- $results[$count]['toolid'] = substr($toolid_terms[0]['name'], 1);
-
- foreach ($specific_fields as $specific_field) {
- $results[$count]['sf-' . $specific_field['code']] = xapian_get_doc_terms($document, $specific_field['code']);
- }
-
- $results[$count]['xapian_data'] = unserialize($document->get_data());
- $results[$count]['score'] = ($i->get_percent());
- }
- $i->next();
- }
- switch ($count_type) {
- case 1:
- $count = $matches->get_matches_lower_bound();
- break;
- case 2:
- $count = $matches->get_matches_upper_bound();
- break;
- case 0:
- default:
- $count = $matches->get_matches_estimated();
- break;
- }
- return array($count, $results);
- } catch (Exception $e) {
- display_xapian_error($e->getMessage());
- return NULL;
- }
- }
- function xapian_get_boolean_query($term) {
- return new XapianQuery($term);
- }
- function xapian_get_all_terms($count = 0, $prefix, $db = NULL) {
- try {
- if (!is_object($db)) {
- $db = new XapianDatabase(XAPIAN_DB);
- }
- if (!empty($prefix)) {
- $termi = $db->allterms_begin($prefix);
- } else {
- $termi = $db->allterms_begin();
- }
- $terms = array();
- $i = 0;
- for (; !$termi->equals($db->allterms_end()) && (++$i <= $count || $count == 0); $termi->next()) {
- $terms[] = array(
- 'frequency' => $termi->get_termfreq(),
- 'name' => $termi->get_term(),
- );
- }
- return $terms;
- } catch (Exception $e) {
- display_xapian_error($e->getMessage());
- return NULL;
- }
- }
- function xapian_get_doc_terms($doc = NULL, $prefix) {
- try {
- if (!is_a($doc, 'XapianDocument')) {
- return;
- }
-
-
-
- $terms = array();
- for ($termi = $doc->termlist_begin(); !$termi->equals($doc->termlist_end()); $termi->next()) {
- $term = array(
- 'frequency' => $termi->get_termfreq(),
- 'name' => $termi->get_term(),
- );
- if ($term['name'][0] === $prefix) {
- $terms[] = $term;
- }
- }
- return $terms;
- } catch (Exception $e) {
- display_xapian_error($e->getMessage());
- return NULL;
- }
- }
- function xapian_join_queries($query1, $query2 = NULL, $op = 'or') {
-
- switch ($op) {
- case 'or': $op = XapianQuery::OP_OR;
- break;
- case 'and': $op = XapianQuery::OP_AND;
- break;
- default: $op = XapianQuery::OP_OR;
- break;
- }
-
- if (!is_array($query1)) {
- $query1 = array($query1);
- }
- if (is_null($query2)) {
-
- return new XapianQuery($op, $query1);
- }
- if (!is_array($query2)) {
- $query2 = array($query2);
- }
- return new XapianQuery($op, array_merge($query1, $query2));
- }
- function display_xapian_error($xapian_error_message) {
- $message = explode(':', $xapian_error_message);
- $type_error_message = $message[0];
- if ($type_error_message == 'DatabaseOpeningError') {
- $message_error = get_lang('SearchDatabaseOpeningError');
- } elseif ($type_error_message == 'DatabaseVersionError') {
- $message_error = get_lang('SearchDatabaseVersionError');
- } elseif ($type_error_message == 'DatabaseModifiedError') {
- $message_error = get_lang('SearchDatabaseModifiedError');
- } elseif ($type_error_message == 'DatabaseLockError') {
- $message_error = get_lang('SearchDatabaseLockError');
- } elseif ($type_error_message == 'DatabaseCreateError') {
- $message_error = get_lang('SearchDatabaseCreateError');
- } elseif ($type_error_message == 'DatabaseCorruptError') {
- $message_error = get_lang('SearchDatabaseCorruptError');
- } elseif ($type_error_message == 'NetworkTimeoutError') {
- $message_error = get_lang('SearchNetworkTimeoutError');
- } else {
- $message_error = get_lang('SearchOtherXapianError');
- }
- $display_message = get_lang('Error') . ' : ' . $message_error;
- Display::display_error_message($display_message);
- }
|