Skip to content

Интеграция с использованием API

Поиск может быть интегрирован на сайт или в приложении при помощи API - документация swagger.

вебинар по API SearchBooster .

Поиск

Основной метод поиска - /search,

Пример запроса:

https://api.searchbooster.net/api/ca8fc618-9ee9-48f1-b9b6-92e810424297/search?query=соб&limit=1

Пример ответа:

{
    "topOffersIds": [],
    "offers": [
        {
            "available": true,
            "id": "110166",
            "score": 28.942768,
            "name": "Самоедская собака 1",
            "url": "https://demo.searchbooster.io/product/%d1%81%d0%b0%d0%bc%d0%be%d0%b5%d0%b4%d1%81%d0%ba%d0%b0%d1%8f-%d1%81%d0%be%d0%b1%d0%b0%d0%ba%d0%b0-1/",
            "price": 960,
            "oldPrice": 1200,
            "currency": "RUR",
            "pictures": [
                "https://slc.searchbooster.io/go_epWGY8CPz1vdaEVpxppaDxDuFE784qYqWUS8sVhw/rs:fit:200:300:0:sm/aHR0cHM6Ly9kZW1vLnNlYXJjaGJvb3N0ZXIuaW8vd3AtY29udGVudC91cGxvYWRzL24wMjExMTg4OV8xOTg0LmpwZw.jpeg"
            ],
            "category": {
                "id": "8145",
                "name": "Самоедская собака"
            },
            "categories": [
                {
                    "id": "8145",
                    "name": "Самоедская собака"
                }
            ]
        }
    ],
    "extraOffers": null,
    "ads": [],
    "hits": 905,
    "categories": [
        {
            "hits": 218,
            "id": "8145",
            "name": "Самоедская собака",
            "score": 28.942768096923828
        },
        {
            "hits": 213,
            "id": "8144",
            "name": "Пиренейская горная собака",
            "score": 24.499252319335938
        },
        {
            "hits": 155,
            "id": "8163",
            "name": "Мексиканская голая собака",
            "score": 24.037940979003906
        },
        {
            "hits": 169,
            "id": "8176",
            "name": "Африканская охотничья собака",
            "score": 22.752670288085938
        },
        {
            "hits": 150,
            "id": "8116",
            "name": "Американская эскимосская собака",
            "score": 21.96955108642578
        }
    ],
    "params": [
        {
            "id": "category",
            "name": "category",
            "type": "multiple",
            "options": [
                {
                    "id": "8145",
                    "hits": 218,
                    "name": "Самоедская собака",
                    "score": 28.942768096923828
                },
                {
                    "id": "8144",
                    "hits": 213,
                    "name": "Пиренейская горная собака",
                    "score": 24.499252319335938
                },
                {
                    "id": "8163",
                    "hits": 155,
                    "name": "Мексиканская голая собака",
                    "score": 24.037940979003906
                },
                {
                    "id": "8176",
                    "hits": 169,
                    "name": "Африканская охотничья собака",
                    "score": 22.752670288085938
                },
                {
                    "id": "8116",
                    "hits": 150,
                    "name": "Американская эскимосская собака",
                    "score": 21.96955108642578
                }
            ]
        },
        {
            "id": "price",
            "name": "price",
            "type": "range",
            "maxValue": 198700,
            "minValue": 55
        }
    ],
    "query": "соб",
    "suggestions": null,
    "meta": {
        "searchType": [
            "narrow-autocomplete"
        ],
        "searchTypePassed": [
            "narrow-autocomplete"
        ]
    }
}

Параметр searchType отвечает за уровень, на котором нашлись товары. Если уровень отличается от narrow-* - поиск сработал по неточному соответствию.

Помимо описанных в документации параметров метод принимает также GET-параметр:

  • userParams (JSON):

  • width - ширина экрана пользователя;

  • height - высота экрана пользователя;

  • userAgent - User agent — идентификационная строка клиентского приложения.

Пагинация

Для пагинации используются параметры skip и limit.

  • skip: Этот параметр указывает, сколько записей нужно пропустить перед тем, как начать возвращать результаты.
  • limit: Этот параметр определяет максимальное количество записей, которые будут возвращены в ответе.

Чтобы получить значения skip и limit исходя из номера страницы и длины страницы, можно использовать следующие формулы:

  1. limit: Это фиксированное значение, которое определяет количество записей на одной странице. Например, если длина страницы составляет 10 записей, то limit будет равен 10.

  2. skip: Для расчета значения skip можно использовать следующую формулу:

skip = (номер страницы - 1) * limit

Где: - номер страницы — это номер страницы, которую вы хотите получить (например, 1, 2, 3 и т.д.). - limit — количество записей на странице.

Например, если вы хотите получить данные для 3-й страницы и длина страницы составляет 10 записей: - номер страницы = 3 - limit = 10

Тогда skip будет рассчитан следующим образом: skip = (3 - 1) * 10 = 20 Таким образом, для запроса данных на 3-й странице с длиной страницы 10, параметры будут следующими: - skip = 20 - limit = 10

Фильтрация результатов поиска

Фильтрация результатов поиска осуществляется через GET-параметр params - могут быть применены условие равенства:


{"field":"vendor","condition":"in","options":["Cool vendor","Bad vendor"]}

и вхождения в диапазон:


{"field":"price","min":"200","max":"1000","condition":"range"}

Данные условия могут быть комбинированы в формате:


params=[{"field":"price","min":"200","max":"1000","condition":"range"},{"field":"vendor","condition":"in","options":["Cool vendor","Bad Vendor"]}]

Подобные фильтры могут быть применены к любому параметру товара, передаваемому в каталоге. Для фильтрации параметра из фида в качестве field нужно использовать его название. Например если в фиде парамтер передается как <param name="цвет">красный</param>

То для фильтрации нужно передать


{"field":"цвет","condition":"in","options":["красный"]}

Сортировка

В методе /search допустимо использовать сортировку результатов.

Допустимые значения get-параметров sortBy и sortDest для сортировки результатов поиска метода /search:

&sortBy=price&sortDest=DESC - для фильтрации по цене (сначала дорогие)

&sortBy=price&sortDest=ASC - для фильтрации по цене (сначала дешевые)

&sortBy=available&sortDest=DESC - для фильтрации по наличию

&sortBy=_score&sortDest=DESC - для фильтрации по популярности &sortBy=_score&sortDest=ASC – не имеет смысла. Рекомендуем, не использовать данное сочетание параметров

Дополнительно можно сортировать по кастомным полям, но для этого нужно вносить изменения в Личном кабинете SearchBooster на странице Настройки в в Разделе "Формула сортировки поиска". После внесения изменений в формулу сортировки поиска, в методе /search можно передавать наименование поля в get-параметре sortBy. При наличии затруднений обращайтесь к своему аккаунт-менеджеру.

Предварительные результаты поиска (поисковые подсказки)

Подсказки могут быть получены при помощи метода /completions.

Пример запроса:

https://api.searchbooster.net/api/v2/ca8fc618-9ee9-48f1-b9b6-92e810424297/completions?query=соб&completionSettings={"orders":["popular","categories","brands","history","suggestions","special_offers","offers"],"totalCompletionCount":6,"limits":{"brands":1,"offers":1,"history":1,"popular":1,"categories":1,"suggestions":1,"special_offers":1}}

Описание параметров запроса: query - поисковый запрос - обязательный параметр completionSettings - настройки вывода подсказок

Параметр completionSettings представляет собой объект JSON, который включает следующие поля:

  • orders (обязательно): Массив строк, который указывает порядок, в котором следует возвращать предложения для автозаполнения. Возможные значения: "popular" (популярные), "categories" (категории), "brands" (бренды), "history" (история), "suggestions" (предложения), "special_offers" (специальные предложения) и "offers" (предложения).
  • totalCompletionCount (обязательно): Общее количество предложений для автозаполнения, которые следует вернуть.
  • limits (обязательно): Объект JSON, который указывает максимальное количество предложений для автозаполнения, которые следует вернуть для каждого типа. Возможные типы: "brands" (бренды), "offers" (предложения), "history" (история), "popular" (популярные), "categories" (категории), "suggestions" (предложения) и "special_offers" (специальные предложения).

Пример ответа:

{
  "searchBox": [
    {
      "text": {
        "html": "Самоедская \u003Cstrong\u003Eсоб\u003C/strong\u003Eака",
        "value": "Самоедская собака"
      },
      "label": "categories",
      "id": "8145",
      "count": 218,
      "search": {
        "query": "",
        "categoryId": "8145"
      },
      "snippet": "",
      "offer": {
        "available": false,
        "offerLabelsTyped": null
      }
    }
  ],
  "offers": [
    {
      "available": true,
      "id": "110166",
      "score": 28.942768,
      "name": "Самоедская собака 1",
      "url": "https://demo.searchbooster.io/product/самоедская-собака-1/",
      "price": 960,
      "oldPrice": 1200,
      "currency": "RUR",
      "pictures": [
        "https://slc.searchbooster.io/fOqSfd1rCKB-lx5EaXkh-LdhS9-MdvRhP66V6NPBGbo/rs:fit:300:450:0:sm/aHR0cHM6Ly9kZW1vLnNlYXJjaGJvb3N0ZXIuaW8vd3AtY29udGVudC91cGxvYWRzL24wMjExMTg4OV8xOTg0LmpwZw.jpeg"
      ],
      "category": {
        "id": "8145",
        "name": "Самоедская собака"
      },
      "categories": [
        {
          "id": "8145",
          "name": "Самоедская собака"
        }
      ],
      "isPickup": false,
      "isDelivery": false,
      "isPreorder": false
    }
  ],
  "tips": [],
  "meta": {

  },
  "hits": 0
}

Поиск по фото

Для поиска по фото следует использовать метод /search, но отсылать его как POST, дополнительно указав фото в теле запроса. Для кодирования фото необходимо использовать формат data:image/jpeg и передовать изображение в base64

{
  "image": "data:image/jpeg;base64,....."
}

Пример запроса

curl 'https://api.searchbooster.net/api/ca8fc618-9ee9-48f1-b9b6-92e810424297/search?skip=0&limit=24' \
  -H 'accept: */*' \
  -H 'content-type: text/plain;charset=UTF-8' \
  --data-raw '{"image":""}'