Пожалуйста, убедитесь, что у вас:
Для этого подготовьте файл в одном из форматов: 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
Как выглядит содержание веб-хука можно посмотреть в файле с примером.