Пожалуйста, убедитесь, что у вас:
Для этого подготовьте файл в одном из форматов: XLSX, CSV или JSONL:
Если у вас есть только отзывы (без комментариев/ответов от вашей команды или представителей брендов) и нет отзывов без текста (только оценка), рекомендуем использовать форматы XLSX или CSV, как наиболее простые в подготовке. Требования к файлу, а также инструкцию по импорту смотрите по ссылке.
Если у отзывов есть комментарии/ответы, а также есть отзывы без текста, используйте формат JSONL (см. пример ниже).
Пример формата для файла первоначального импорта отзывов.
Файл предоставляется в формате JSONL(лучше сжатым gzip). Каждая строчка описывает один отзыв с комментариями.
Пример файла.
полный список полей можно посмотреть тут
работы по основному этапу могут выполнятся параллельно с подготовительными, это не должно тормозить интеграцию
Клиент <-> Aplaut
Важный элемент в платформе Aplaut — товар. Все основные процессы и почти все дополнительные завязаны на товаре. Поэтому важно обеспечить своевременную передачу и обновление данных о товарах, для этого в платформу импортируется каталог (фид):
Клиент -> Aplaut
1. Для отправки отзывов из форм на сайте или в моб. приложении в Aplaut используйте Submissions API, метод "Создание отзыва" (см документацию).
2. Если вы хотите разрешить пользователям создавать отзывы без текста (только с рейтингом или рейтинг + фото/видео), необходимо активировать эту функцию через поддержку Aplaut (написав на support@aplaut.com, в телеграм @aplaut_support_bot или чат поддержки в ЛК), а также при передаче отзывов добавить атрибут wordless и значение true или false, соотв., если отзыв без текста и с текстом.
Как отправить отзыв с текстом через Submissions API?
curl -X POST https://s-api.aplaut.io/v2/reviews \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer token={APLAUT_TOKEN}' \
--data-raw '{
"review": {
"rating": 5,
"wordless": false,
"body": "Текст отзыва",
"pros": "Текст поля Достоинства",
"cons": "Текст поля Недостатки,
"recommended": true,
"author_id": "qwerty123",
"author_name": "Манишева Рада Якимовна",
"author_email": "youname@yourmail.ru",
"author_phone": "79991112233",
"location_name": "Уфа",
"photo_urls": ["https://yoursite.ru/picture1.png", "https://yoursite.ru/picture1.png"],
"photo_ids": ["8787258c9549834e99febf05", "8787258c9549834e99febf06"],
"video_ids": ["654258c9549834e99febf05c"],
"product_id": "178963",
"author_ip": "178.214.291.62",
"hide_my_data": false
}
}'Как отправить отзыв без текста через Submissions API:
curl -X POST https://s-api.aplaut.io/v2/reviews \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer token={APLAUT_TOKEN}' \
--data-raw '{
"review": {
"rating": 5,
"wordless": true,
"recommended": true,
"author_id": "qwerty123",
"author_name": "Иван",
"author_email": "youname@yourmail.ru",
"author_phone": "79991112233",
"location_name": "Уфа",
"photo_urls": ["https://yoursite.ru/picture1.png", "https://yoursite.ru/picture1.png"],
"photo_ids": ["8787258c9549834e99febf05", "8787258c9549834e99febf06"],
"video_ids": ["654258c9549834e99febf05c"],
"product_id": "178963",
"author_ip": "178.214.291.62",
"hide_my_data": false
}
}'Как отправить комментарий к отзыву через Submissions API:
curl -X POST https://s-api.aplaut.io/v2/reviews/{REVIEW_ID}/comments] \
--header 'Accept: */*' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer token={APLAUT_TOKEN}' \
--data-raw '{
"comment": {
"text": "Текст комментария на отзыв",
"author_id": "qwerty123",
"author_name": "Иван",
"author_email": "yorname@yourmail.ru",
"hide_my_data": true
}
}'Как отправить комментарий к комментарию через Submissions API:
curl -X POST https://s-api.aplaut.io/v2/reviews/{REVIEW_ID}/comments] \
--header 'Accept: */*' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer token={APLAUT_TOKEN}' \
--data-raw '{
"comment": {
"text": "Текст комментария на комментарий",
"parent_id": {REVIEW_ID},
"external_parent_id": {REVIEW_EXTERNAL_ID}
"author_id": "qwerty123",
"author_name": "Иван",
"author_email": "yorname@yourmail.ru",
"hide_my_data": true
}
}'список других полей можно посмотреть тут
Aplaut -> Клиент
1. Для отображения отзывов и рейтинга в карточке товара используйте Widgets API, метод Запрос одного виджета в формате JSON.
Пример запроса:
curl 'https://https://w-api2.aplaut.io/widgets/v2/render.json?authentication_token={APLAUT_TOKEN}&theme_id=default&context=product&context_id={OFFER.ID}&widget_id=product-reviews'Где APLAUT_TOKEN — ключ к Widgets API (посмотреть можно в ЛК Aplaut, раздел Настройки — Разработчикам), а {OFFER.ID} — список ID услуг из каталога, импортируемого в Aplaut.
Пример ответа, а также описание атрибутов можно найти в документации, под параметрами запроса в блоке Responses.
2. Для отображения данных на листинг-страницах, а также в доп. блоках с рекомендациями товаров, недавно просмотренные и т.д., в которых необходимо показать рейтинг и кол-во отзывов на несколько товаров, синхронизируйте рейтинги с помощью периодических экспортов. Рекомендуем раз в сутки запрашивать список товаров, у которых обновился рейтинг за предыдущий день.
Экспорт дельты товаров.
Чтобы получить дельту обновленных товаров за определенную дату, нужно создать задачу на экспорт, указав в параметрах соотвествующий фильтр.
Пример:
curl -X POST \
'http://api.aplaut.io/v4/export_tasks' \
--header 'Accept: */*' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer {TOKEN}' \
--data-raw '{
"data": {
"type": "export_tasks",
"attributes": {
"records_type": "products",
"search_options": {
"filter": {
"created_at": {
"eq": "ГГГГ-ММ-ДД"
}
},
},
"format": "jsonl"
}
}
}'Где {TOKEN} — ключ от Platform API (посмотреть можно в ЛК Aplaut, раздел Настройки —> Разработчикам)
В ответе будет ID задачи, статут которой нужно проверять не чаще 1 раз в 1 минуту.
Пример запроса:
curl 'https://api.aplaut.io/v4/export_tasks/{TASK_ID}' \
-H 'Authorization: Bearer token={TOKEN}'Пример ответа:
{
"data": {
"id": "TASK_ID",
"type": "export_tasks",
"attributes": {
"records_type": "products",
"search_options": {
"filter": {"created_at": {"eq": "ГГГГ-ММ-ДД"}},
},
"state": "completed",
"refuse_reason": null,
"error_message": null,
"format": "jsonl",
"export_format": null,
"archive_url": "{ARCHIVE_URL}",
"archive_size": 144696,
"archive_content_type": "application/gzip",
"created_at": "2023-11-03T17:00:41.353+03:00",
"updated_at": "2023-11-03T17:14:53.529+03:00",
"started_at": "2023-11-03T17:14:47.633+03:00",
"finished_at": "2023-11-03T17:14:53.529+03:00"
}
}
}Когда state=completed , параметр archive_url будет содержать URL c архивом файла экспорта.
Важно помнить:
completed . Если за 3 часа статус задачи не поменялся, считайте что она "подвисла". Создавайте новую;