|
| 1 | +# getDataSetFromSphinx |
| 2 | + |
| 3 | +Использовалось в SteamboatEngine/functions.php в версии 1.26.1 (latest implementation), предполагался перенос в SphinxToolkit, |
| 4 | +но не сделан (т.к. есть зависимость от AppLogger) |
| 5 | + |
| 6 | +Как временное решение, функция задается индивидуально для каждого проекта. |
| 7 | + |
| 8 | +```php |
| 9 | +/** |
| 10 | + * Загружает список айдишников из сфинкс-индекса по переданному запросу. |
| 11 | + * |
| 12 | + * Old implementation is `\SteamBoat\SBSearch::get_IDs_DataSet` |
| 13 | + * |
| 14 | + * @param string $search_query - строка запроса |
| 15 | + * @param string $source_index - имя индекса |
| 16 | + * @param string $sort_field - поле сортировки |
| 17 | + * @param string $sort_order - условие сортировки |
| 18 | + * @param int $limit - количество |
| 19 | + * @param array $option_weight - опции "веса" |
| 20 | + * @return array - список айдишников |
| 21 | + */ |
| 22 | +function getDataSetFromSphinx(string $search_query, string $source_index, string $sort_field, string $sort_order = 'DESC', int $limit = 5, array $option_weight = []): array |
| 23 | + { |
| 24 | + $found_dataset = []; |
| 25 | + $compiled_request = ''; |
| 26 | + if (empty($source_index)) return $found_dataset; |
| 27 | + try { |
| 28 | + $search_request = \Arris\Toolkit\SphinxToolkit::createInstance() |
| 29 | + ->select() |
| 30 | + ->from($source_index); |
| 31 | + if (!empty($sort_field)) { |
| 32 | + $search_request = $search_request |
| 33 | + ->orderBy($sort_field, $sort_order); |
| 34 | + } |
| 35 | + if (!empty($option_weight)) { |
| 36 | + $search_request = $search_request |
| 37 | + ->option('field_weights', $option_weight); |
| 38 | + } |
| 39 | + if (!is_null($limit) && is_numeric($limit)) { |
| 40 | + $search_request = $search_request |
| 41 | + ->limit($limit); |
| 42 | + } |
| 43 | + if (strlen($search_query) > 0) { |
| 44 | + $search_request = $search_request |
| 45 | + ->match(['title'], $search_query); |
| 46 | + } |
| 47 | + $search_result = $search_request->execute(); |
| 48 | + while ($row = $search_result->fetchAssoc()) { |
| 49 | + $found_dataset[] = $row['id']; |
| 50 | + } |
| 51 | + } catch (Exception $e) { |
| 52 | + \Arris\AppLogger::scope('sphinx')->error( |
| 53 | + __CLASS__ . '/' . __METHOD__ . |
| 54 | + " Error fetching data from `{$source_index}` : " . $e->getMessage(), |
| 55 | + [ |
| 56 | + htmlspecialchars(urldecode($_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'])), |
| 57 | + $search_request->getCompiled(), |
| 58 | + $e->getCode() |
| 59 | + ] |
| 60 | + ); |
| 61 | + } |
| 62 | + return $found_dataset; |
| 63 | + } // get_IDs_DataSet() |
| 64 | +``` |
0 commit comments