Download OpenAPI specification:Download
1MSG.IO идеальный инструмент для управления WhatsApp аккаунтом вашего бизнеса. С нами вы получаете полный доступ к официальному Whatsapp API/webhooks.
Каждый API запрос должен содержать Authorize HTTP header с токеном. Токен вашего канала можно найти в проекте канала на странице вашего профиля. Пожалуйста, не передавайте токен никому и не публикуйте его.
Токен авторизации должен добавляться к каждому запросу в GET параметре ‘token’ и всегда передаваться в query string (?token={your_token}). Параметры в GET запросах передавайте через query string. Параметры в POST запросах — через через JSON-encoded тело запроса.
Все ‘send’ методы (кроме /sendTemplate) работают только тогда, когда открыта диалоговая сессия с пользователем. Некоторые наши решения помогают упростить и избежать таких ограничений. Пожалуйста, будьте внимательны к этому нюансу.
Обновления от 20 мая 2024 (все изменения актуальны для версии Cloud API):
-
-
Реферальная программа:
Реферальная программа для сервисов, разработчиков и интеграторов. Подробности и условия участия в программе можно узнать здесь.
Используйте этот метод, чтобы получить информацию о вашем профиле
{- "about": "Some about info",
- "address": "Neverland, Unexpected st.",
- "description": "Some company description",
- "email": "john@neverland.play",
- "phone": "78005553535",
- "vertical": "Other",
}
Изменить данные о пользователе
about | string Раздел Описание. |
address | string Адрес компании |
description | string Описание. Максимум 256 символов |
string | |
phone | string Связанный номер телефона |
vertical | string Enum: "Automotive" "Beauty, Spa and Salon" "Clothing and Apparel" "Education" "Entertainment" "Event Planning and Service" "Finance and Banking" "Food and Grocery" "Public Service" "Hotel and Lodging" "Medical and Health" "Non-profit" "Professional Services" "Shopping and Retail" "Travel and Transportation" "Restaurant" "Other" Industry of the business |
photo | string Ссылка на файл, например https://... Или файл в base64, например ... Или файл в поле формы |
{- "result": "success"
}
Получить расширенную статистику использования Канала
[- {
- "business_initiated_paid_quantity": 1,
- "business_initiated_price": 0.0691,
- "business_initiated_quantity": 2,
- "free_entry_point": 0,
- "free_quantity": 1,
- "free_tier": 1,
- "paid_quantity": 1,
- "period_date": "2022-11-01T00:00:00Z",
- "quantity": 2,
- "total_price": 0.0691,
- "user_initiated_paid_quantity": 1,
- "user_initiated_price": 0.0691,
- "user_initiated_quantity": 2
}
]
Возвращает статус вашего клиента WhatsApp Business API. Статусы Каналов:
connected/connecting - все в порядке.
disconnected - Coreapp не подключен к серверам WhatsApp.
uninitialized - возможно, приложение находится в процессе обновления или инициализации схемы базы данных. Повторите попытку через несколько минут и обратитесь в службу поддержки, если вы по-прежнему видите этот статус.
unregistered - вам необходимо зарегистрировать клиент WhatsApp Business API. Либо вы были заблокированы, и вам необходимо предпринять какие-либо действия (Обратиться в Службу поддержки)
{- "status": "connected"
}
Устанавливает URL для получения webhook уведомлений о новых сообщениях и статусах доставки исходящих сообщений (ack).
**Описание ответов от API во вкладке "Callbacks" **
webhookUrl required | string http или https URL для получения оповещений. Для тестирования рекомендуем использовать наш RequestBin. |
{- "set": true,
}
{- "messages": [
- {
- "id": "ABGHYoIXMAmY13IKOick9az6QYmt4R",
- "body": "Ok!",
- "fromMe": true,
- "self": 0,
- "isForwarded": false,
- "author": "12020721369@c.us",
- "time": 1665396610,
- "chatId": "12020721369@c.us",
- "type": "chat",
- "senderName": "John",
- "caption": "photo.jpg",
- "quotedMsgId": "ABGHYoIXMAmYTwIKOick9az6QYmt4R"
}
]
}
messageId required | string Example: messageId=0XzkmGNn4prUAQlzsHApGNRXQ0U Идентификатор Сообщения. Пример: 0XzkmGNn4prUAQlzsHApGNRXQ0U |
{- "hooks": [
- {
- "id": "gBGGeSaGViBfAgnlzOSHEwK9O6F",
- "type": "message",
- "status": "sent",
- "pricing": {
- "billable": true,
- "category": "business_initiated",
- "pricing_model": "CBP"
}, - "timestamp": "1654864094",
- "conversation": {
- "id": "c1f5a3a1b9ff6f2e1c43fd31543137e0",
- "origin": {
- "type": "business_initiated"
}, - "expiration_timestamp": 1654943940
}, - "recipient_id": "556123122026"
}
]
}
Отправка списка опций в существующий чат (только с открытым диалоговым окном). Нужен только один из двух параметров для определения адресата - chatId или phone.
body required | string Основной текст сообщения |
header | string Текст, который будет расположен над текстом сообщения |
footer | string Текст, который будет расположен под текстом сообщения |
action required | string Подпись кнопки раскрытия списка |
required | Array of objects Массив с разделами доступных для выбора опций Не более 10. Каждый раздел - это объект, содержащий следующие поля: title - Заголовок раздела, не более 24 символов. Обязателен, если указано более 1 раздела rows - доступные для выбора опции. Обязателен Каждая опция - это объект, содержащий следующие поля: id - Уникальный идентификатор, не более 200 символов. Обязателен title - Заголовок опции, не более 24 символов. Обязателен description - Описание опции, не более 72 символов Пример: [{"title":"Section 1","rows":[{"id":"1","title":"Option 1","description":"Description 1"}]},{"title":"Section 2","rows":[{"id":"2","title":"Option 2","description":"Description 2"}]}] |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
Отправка кнопок ответа в существующий чат (только с открытым диалоговым окном). Нужен только один из двух параметров для определения адресата - chatId или phone.
body required | string Основной текст сообщения |
object or object or object or object | |
footer | string Нижний колонтитул будет размещен под текстом сообщения. |
required | Array of objects До 3-х разделов включительно. Каждый раздел представляет собой объект с полями: type - всегда "reply" Обязателен reply – объекты кнопки ответа Обязателен Каждый ответ кнопки представляет собой объект с полями: id - уникальный идентификатор кнопки, до 200 символов. Обязателен title — Название кнопки, до 20 символов. Обязателен Пример: "sections": [{"type": "reply","reply": {"id ": "1","title": "1 Button's Title"}},{"type": "reply", "reply": {"id": "2", "title": "2 Button's Title"}}] |
quotedMsgId | string Идентификатор цитируемого сообщения (Cloud API) |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
Отправкас сообщения запрос локации в существующий чат (только с открытым диалоговым окном). Нужен только один из двух параметров для определения адресата - chatId или phone.
body required | string Текст сообщения, любая строка включая emoji 🍏. Может использоваться с "mentionedPhones", пример: "Этот текст для @78005553535" |
quotedMsgId | string Идентификатор цитируемого сообщения (Cloud API) |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
Отправка файла в существующий чат (только с открытым диалоговым окном). Нужен только один из двух параметров для определения адресата - chatId или phone.
Кириллические символы в URL файла не поддерживаются. Чтобы корректно передать и обработать ссылку с русским текстом, следует применять кодировку URL.
body required | string Ссылка на файл, например https://... Или файл в base64, например ... Или файл в поле формы |
filename required | string Имя отправляемого файла, например 1.jpg или hello.xlsx |
caption | string Текст под файлом. При отправке изображения может использоваться с "mentionedPhones", Пример: "Изображение для @78005553535" |
quotedMsgId | string Идентификатор цитируемого сообщения (Cloud API) |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
Отправка сообщения в существующий чат (только с открытым диалоговым окном). Сообщение будет добавлено в очередь на отправку и доставлено, даже если телефон отключен от интернета или не пройдена авторизация.
Нужен только один из двух параметров для определения адресата - chatId или phone.
body required | string Текст сообщения, любая строка включая emoji 🍏. Может использоваться с "mentionedPhones", пример: "Этот текст для @78005553535" |
quotedMsgId | string Идентификатор цитируемого сообщения (Cloud API) |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
Отправка локации в существующий чат (только с открытым диалоговым окном). Нужен только один из двух параметров для определения адресата - chatId или phone.
lat required | string Широта локации. Пример: 45.018337 |
lng required | string Долгота локации. Пример: -73.968285 |
address | string Адрес локации. Отображается, если указано поле name. Пример: 9766 Valley View St., New York, NY 10024 |
name | string Имя локации. Пример: Facebook HQ |
quotedMsgId | string Идентификатор цитируемого сообщения (Cloud API) |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
Отправка контакта в существующий чат (только с открытым диалоговым окном). Нужен только один из двух параметров для определения адресата - chatId или phone.
contacts | Array of objects Массив, содержащий объекты контактов. Параметры объекта контакта: name - Имя контакта. Обязательное поле. Объект с параметрами:
birthday - Строка в формате YYYY-MM-DD. Пример: 2012-08-18 addresses - Массив, содержащий объекты с параметрами:
emails - массив, содержащий объекты с параметрами:
org - объект, содержащий параметры:
phones - массив, содержащий объекты с параметрами:
urls - массив, содержащий объекты с параметрами:
Общий пример: [{"addresses":[{"city":"Menlo Park","country":"United States","country_code":"us","state":"CA","street":"1 Hacker Way","type":"HOME","zip":"94025"},{"city":"Menlo Park","country":"United States","country_code":"us","state":"CA","street":"200 Jefferson Dr","type":"WORK","zip":"94025"}],"birthday":"2012-08-18","emails":[{"email":"test@fb.com","type":"WORK"},{"email":"test@whatsapp.com","type":"WORK"}],"name":{"first_name":"John","formatted_name":"John Smith","last_name":"Smith"},"org":{"company":"WhatsApp","department":"Design","title":"Manager"},"phones":[{"phone":"+1 (940) 555-1234","type":"HOME"},{"phone":"+1 (650) 555-1234","type":"WORK","wa_id":"16505551234"}],"urls":[{"url":"https://www.facebook.com","type":"WORK"}]}] |
quotedMsgId | string Идентификатор цитируемого сообщения (Cloud API) |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
По умолчанию история сообщений не сохраняется для выдачи в методе. Для включения метода отпишите в тех поддержку
last | boolean Example: last=true Отображает последние 100 сообщений. Если передан этот параметр, то lastMessageNumber игнорируется. |
lastMessageNumber | integer Example: lastMessageNumber=100 Параметр lastMessageNumber из предыдущего запроса. Пример: 100 |
firstMessageNumber | integer Example: firstMessageNumber=1 Параметр lastMessageNumber из предыдущего запроса. Пример: 1 |
limit | integer Example: limit=200 Устанавливает длину списка сообщений. По умолчанию 100. При значении 0 вернет все сообщения. |
chatId | string Example: chatId=556123122026@c.us Filter messages by chatId Chat ID from the message list. Example: 556123122026@c.us |
min_time | integer Example: min_time=1665396610 Фильтрует сообщения по chatId Идентификатор чата из списка сообщений. Пример: 1665396610 |
max_time | integer Example: max_time=1665396610 Фильтрует сообщения, полученные после указанного времени. Пример: 1665396610 |
msgId | string Example: msgId=0XzkmGNn4prUAQlzsHApGNRXQ0U Идентификатор Сообщения. Пример: 0XzkmGNn4prUAQlzsHApGNRXQ0U |
{- "messages": [
- {
- "messageNumber": 1,
- "id": "0XzkmGNn4prUAQlzsHApGNRXQ0U",
- "body": "Test message",
- "fromMe": true,
- "self": 1,
- "isForwarded": 0,
- "author": "556123122026@c.us",
- "time": 1665396610,
- "chatId": "556123122026@c.us",
- "type": "chat",
- "senderName": "780005553535@c.us",
- "caption": null,
- "quotedMsgId": null,
- "metadata": { },
- "chatName": "556123122026"
}
]
}
Отправка шаблона в новый или существующий чат. Нужен только один из двух параметров для определения адресата - chatId или phone.
Кириллические символы в URL файла не поддерживаются. Чтобы корректно передать и обработать ссылку с русским текстом, следует применять кодировку URL.
Пример №1:
{"template":"template_name","language":{"policy":"deterministic","code":"en"},"namespace":"namespace_id","params":[{"type":"header","parameters":[{"type":"image","image": {"link":"https://..."}}]},{"type":"body","parameters":[{"type":"text","text":"test"}]}],"phone":"556123122026"}
Пример №2 - отправка шаблона 'Карусель' (доступно только на версии Cloud API):
{"template": "test_carousel", "language": {"policy": "deterministic", "code": "en_US"}, "namespace": "41123797_o98r_4f06_fi44_443b27c6f5ec","params": [{"type": "body", "parameters": [{"type": "text", "text": "b1"}, {"type": "text", "text": "b2"}]}, {"type": "CAROUSEL", "cards": [{"card_index": 0, "components": [{"type": "header", "parameters": [{"type": "video", "video": {"link": "https://test.com/video.mp4"}}]}, {"type": "button", "sub_type": "url", "index": "0", "parameters": [{"type": "text", "text": "1"}]}, {"type": "button", "sub_type": "url", "index": "1", "parameters": [{"type": "text", "text": "2"}]}, {"type": "body", "parameters": [{"type": "text", "text": "b3"}, {"type": "text", "text": "b4"}]}]}]}], "phone": "556123122026"}
Пример №3 каталог
{ "token": "jxL4WBheceYEVvMd32Hwuk2h5Cvn1qpm", "namespace": "", "template": "catalog", "language": {"policy": "deterministic","code": "en_US" }, "params": [{ "type": "button", "sub_type": "CATALOG", "index": 0, "parameters": [ {"type": "action","action": { "thumbnail_product_retailer_id": "001"} } ]},{ "type": "body", "parameters": [ {"type": "text","text": "Ознакомьтесь с продукцией нашего магазина" } ]} ], "chatId": "" }
namespace required | string Можно получить в методе /templates |
template required | string Имя шаблона |
required | object Объект, содержащий поля "policy" и "code". policy - сейчас поддерживается только значение "deterministic"; code - один из поддерживаемых языковых кодов |
Array of objects Массив локализируемых параметров, которые будут переданы в шаблон. Каждый параметр - это объект, который может содержать следующие поля: type - раздел параметров - header, body, footer, button, carousel parameters - переменные для раздела. Каждая переменная - объект, который может осдержать следующие поля: type - тип переменной: text, currency, date_time, image, document или video video- нужно указать id (mediaId) document
image - объект, содержащий поле link (url изображения) currency - объект, содержащий следующие поля: currency_code и amount_1000.
date_time - Если используется, то должен соответствовать следующему формату.
button - если в компоненте были параметры
cards - заполняется, если необходимо отправить шаблон Карусель
Количество переданных параметров должно соответствовать количеству параметров шаблона | |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
Создать новый шаблон для отправки.
Пример №1:
[{"type": "HEADER", "format": "IMAGE", "example": {"header_handle": ["https://test.net/v.jpg"]}}, {"text": "We remind you that you have an appointment at {{1}} with the dentist tomorrow. Are you confirming your appointment with the doctor?", "type": "BODY", "example": {"body_text": [["9:00"]]}}, {"text": "white", "type": "FOOTER"}, {"type": "BUTTONS", "buttons": [{"text": "Yes", "type": "QUICK_REPLY"}, {"text": "No", "type": "QUICK_REPLY"}]}]
Пример №2 - создать шаблон Карусель (доступно на Cloud API):
[{"text": "Test body text","type": "BODY"},{"type": "CAROUSEL","cards":[{"components":[{"type": "HEADER","format": "VIDEO","example":{"header_handle":["4::aW..."]}},{"text": "Carousel body {{1}}","type": "BODY"},{"type": "BUTTONS","buttons":[{"text": "Send more like this","type": "QUICK_REPLY"},{"url": "https://www.test.com/shop?promo={{1}}","text": "Buy now","type": "URL","example": ["https://www.test.com/shop?promo=summer_lemons_2023"]}]}]}]}]
name | string Имя шаблона |
category | string (TemplateCategoryProp) Enum: "MARKETING" "UTILITY" "AUTHENTICATION" Категория Шаблона |
Array of objects (TemplateComponentsProp) Массив компонентов Шаблона | |
language | string (TemplateLanguageProp) Enum: "af" "sq" "ar" "az" "bn" "bg" "ca" "zh_CN" "zh_HK" "zh_TW" "hr" "cs" "da" "nl" "en" "en_GB" "en_US" "et" "fil" "fi" "fr" "de" "el" "gu" "he" "hi" "hu" "id" "ga" "it" "ja" "kn" "kk" "ko" "lo" "lv" "lt" "mk" "ms" "mr" "nb" "fa" "pl" "pt_BR" "pt_PT" "pa" "ro" "ru" "sr" "sk" "sl" "es" "es_AR" "es_ES" "es_MX" "sw" "sv" "ta" "te" "th" "tr" "uk" "ur" "uz" "vi" Язык шаблона |
{ }
{- "total": 3,
- "templates": [
- {
- "category": "MARKETING",
- "components": [
- {
- "type": "BODY",
- "format": "TEXT",
- "text": "header text {{1}}",
- "example": { },
- "buttons": [
- {
- "type": "QUICK_REPLY",
- "text": "phone-button-text",
- "phone_number": "+1(234) 235-5678",
- "example": [
- null
]
}
], - "cards": [
- {
- "components": [
- {
- "type": "BODY",
- "format": "TEXT",
- "text": "header text {{1}}",
- "example": { },
- "buttons": [
- { }
]
}
]
}
]
}
], - "language": "en",
- "name": "start",
- "namespace": "ca300906_cfbc_410b_99fb_dcee8e13d578",
- "rejected_reason": "NONE",
- "status": "approved"
}
]
}
is_catalog_visible - true - показывать иконку каталога, false - скрыть. is_cart_enabled - true - включить корзину, false - открлючить.
[- {
- "id": "789887292550821",
- "is_cart_enabled": true,
- "is_catalog_visible": true
}
]
is_catalog_visible - true - показывать иконку каталога, false - скрыть. is_cart_enabled - true - включить корзину, false - открлючить.
object |
{ }
{- "success": true
}
Отправка товара или списка товаров в новый или существующий чат (Только с открытым диалоговым окном). Нужен только один из двух параметров для определения адресата - chatId или phone.
Сначала вам необходимо загрузить свой инвентарь в Facebook. Для этого вы можете использовать API или Facebook Commerce Manager. Если у вас уже настроен каталог Facebook, мы рекомендуем вам использовать этот каталог для коммерческих случаев использования WhatsApp.
Вы не можете отправлять товары клиентам Business WhatsApp.
required | object Объект, содержащий информацию о товаре или каталоге. Может иметь следующий параметры: catalog_id - идентификатор каталога product_retailer_id - идентификатор товара. Только для отправки одного товара. sections - Используется для отправки нескольких товаров, массив, содержащий объекты с информацией о наборах товаров. См пример ниже. Пример: {"catalog_id":"{{catalog_id}}","sections":[{"title":"the-section-title","product_items":[{"product_retailer_id":"{{SKU-1}}"},{"product_retailer_id":"{{SKU-2}}"}]},{"title":"the-section-title2","product_items":[{"product_retailer_id":"{{SKU-1}}"}]}]} |
body | string Текст сообщения. Пример: Some text. |
footer | string Располагается под текстом сообщения. Пример: Footer. |
header | string Заголовок каталога. Пример: Header. Обязателен при отправке каталога (нескольких товаров). |
chatId | string Обязателен если не указан phone ID чата из списка сообщений. Пример: 12020721369@c.us . Используется вместо параметра phone. |
phone | integer Обязателен если не указан chatId Номер телефона, начинающийся с кода страны. Для России и Казахстана это всегда 7, затем 10 цифр. Сообщения на номера телефона с 8 не будут доставлены. Пример: "79995253422". |
{- "sent": true,
- "id": "gBGGeRhGZTEfAgkJCh2wAz4ZH-8",
- "message": "Sent to 556123122026@c.us",
- "description": "Message has been sent to the provider"
}
Используется для загрузки медиа и полчения mediaId. Загруженные медиа могут быть отправлены в шаблонах
body required | string Ссылка на файл, например https://... Или файл в base64, например ... Или файл в поле формы |
{- "mediaId": "ed2c7be7-b779-4ba8-a17c-6722f37be2a7"
}