Пожалуйста, убедитесь, что у вас:
Для этого подготовьте файл в одном из форматов: XLSX, CSV или JSONL:
Если у вас есть только отзывы (без комментариев/ответов от вашей команды или представителей брендов) и нет отзывов без текста (только оценка), рекомендуем использовать форматы XLSX или CSV, как наиболее простые в подготовке. Требования к файлу, а также инструкцию по импорту смотрите по ссылке.
Если у отзывов есть комментарии/ответы, а также есть отзывы без текста, используйте формат JSONL (см. пример ниже).
Пример формата для файла первоначального импорта отзывов.
Файл предоставляется в формате JSONL (лучше сжатым gzip). Каждая строчка описывает один отзыв с комментариями.
Пример файла.
полный список полей можно посмотреть тут
работы по основному этапу могут выполнятся параллельно с подготовительными, это не должно тормозить интеграцию
Клиент <-> Aplaut
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
}
}'список других полей можно посмотреть тут
Для синхронизации контента, а также рейтингов и кол-ва отзывов на товары используйте периодические экспорты раз в сутки.
Экспорт дельты обновленных товаров.
Чтобы получить дельту за определенный период, нужно создать задачу на экспорт, указав в параметрах соотвествующий фильтр в параметре search_option . Например, за текущую дату:
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": {
"updated_at": {
"eq": "ГГГГ-ММ-ДД"
}
},
},
"format": "jsonl"
}
}
}'В ответе будет 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 архивом файла экспорта.
Экспорт дельты новых и обновленных отзывов за день.
По аналогии с товарами, чтобы получить дельту за определенный период, нужно создать задачу на экспорт, указав в параметрах соотвествующий фильтр. В отличии от товаров в records_type значение reviews :
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": {
"updated_at": {
"eq": "ГГГГ-ММ-ДД"
}
},
},
"format": "jsonl"
}
}
}'Также, по аналогии с экспортом товаров, необходимо проверять статус задачи.
Важно помнить:
completed. Если за 3 часа статус задачи не поменялся, считайте что она "подвисла". Создавайте новую;Альтернативы экспортам.
В качестве альтернативы экспортам, для синхронизации контента можно использовать веб-хуки. Для настройки необходимо:
На какие события веб-хука можно подписаться.
Отзывы:
create_review, update_review, destroy_review, publish_review, ban_review, update_review_tags, create_comment, update_comment, destroy_comment, publish_comment, ban_comment, update_comment_tags
Вопросы и ответы:
create_question, update_question, destroy_question, create_answer, update_answer, destroy_answer
Как выглядит содержание веб-хука можно посмотреть в файле с примером.