Перейти к содержанию

Device API

registerDevice

Anchor link to

POST https://api.pushwoosh.com/json/1.3/registerDevice

Вызывается SDK изнутри. Регистрирует устройство для приложения.

Заголовки запроса
Anchor link to
ИмяОбязательноЗначениеОписание
AuthorizationДаToken XXXXТокен Device API для доступа к Device API. Замените XXXX на ваш реальный токен Device API.
Тело запроса
Anchor link to
ИмяТипОписание
application*stringКод приложения Pushwoosh
push_tokenstringPush-токен для устройства.
languagestringЯзыковая локаль устройства. Должен быть двухбуквенным кодом в нижнем регистре в соответствии со стандартом ISO-639-1.
hwid*stringУникальная строка для идентификации устройства (IDFV на iOS, случайно сгенерированное значение на Android). Узнать больше
timezoneintegerСмещение часового пояса устройства в секундах.
device_type*integerТип устройства. Возможные значения см. ниже.
emailstringАдрес электронной почты для регистрации (используйте для email-пользователей вместо HWID и push-токена).
tagsobjectЗначения тегов, которые будут присвоены регистрируемому устройству.
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Пример
{
"request": {
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"push_token": "dec301908b9ba8XXXXX57a58e40f96f5XXXXX2068674f5XXXXa25cdc250a2a41", // необязательно.
"hwid": "1CA6XXXXX-8DAC-XXXXX-XXXXX-B756288B6D3C", // обязательно. Аппаратный ID устройства (HWID)
"idfa": "AEBE52E7-0XXXXX-455A-XXXXX-E57283966239", // необязательно.
"timezone": 3600, // необязательно. Смещение в секундах
"device_type": 1, // обязательно. Возможные значения см. ниже. Для email-адресов
// используйте параметр "emails", как описано ниже.
"email": "email_address@domain.com", // используйте вместо "hwid" и "push_token" для регистрации
// адреса электронной почты для вашего email-проекта
"language": "en", // необязательно. Код языка ISO 639-1|639-2
"userId": "Alex", // необязательно.
"tags": { // необязательно. Значения тегов для регистрируемого устройства
"StringTag": "string value",
"IntegerTag": 42,
"ListTag": ["string1", "string2"], // устанавливает список значений для тегов типа "Список"
"DateTag": "2024-10-02 22:11", // обратите внимание, время должно быть в формате UTC
"BooleanTag": true // допустимые значения: true, false
},
// системные теги, необязательно
"app_version": "1.2.3",
"device_model": "Samsung SM-G355H",
"os_version": "2.3",
// необязательные ключи шифрования для chrome/firefox
"public_key": "BNmDO4BTKEMJqaqprTf7t/HBXXXXX/orcXXXXX/scS5CFP6XXXXXHI1/GgRQD8c4kTxTEEF0quvIUiLQqoBY0/Qo=",
"auth_token": "RlRmCXXXXX/s7XXXXXjKFzoQ==",
// необязательные ключи FCM для Chrome (для XMPP)
"fcm_token": "BNmDO4BTKEMJXXXXXprTf7t/XXXXXBQ/orXXXXXc/scS5CFP6zhQGIHI1/GgRQD8c4kTxTEEF0quvIUiLQqoBY0/Qo=",
"fcm_push_set": "RlXXXXXGM/s7XXXXXjKFzoQ=="
}
}

Возможные типы устройств:

  • 1 – iOS
  • 3 – Android
  • 7 – Mac OS X
  • 8 – Windows
  • 9 – Amazon
  • 10 – Safari
  • 11 – Chrome
  • 12 – Firefox
  • 14 – Email
  • 17 – Huawei
  • 18 – SMS
  • 21 – WhatsApp

Регистрация email-устройств

Anchor link to

Чтобы зарегистрировать email-подписчика для вашего приложения, отправьте параметр "email": "email_address@domain.com" в вашем запросе /registerDevice или /registerEmail следующим образом:

Пример запроса
Anchor link to
{
"request":{
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"email": "email_address@domain.com", // обязательно. Адрес электронной почты для регистрации в вашем email-проекте
"language": "en", // необязательно. Код языка ISO 639-1|639-2
"userId": "Alex", // необязательно.
"tags": { // необязательно. Значения тегов для регистрируемого устройства
"StringTag": "string value",
"IntegerTag": 42,
"ListTag": ["string1", "string2"], // устанавливает список значений для тегов типа "Список"
"DateTag": "2024-10-02 22:11", // обратите внимание, время должно быть в формате UTC
"BooleanTag": true // допустимые значения: true, false
}
}
}

Регистрация устройств WhatsApp

Anchor link to

Чтобы зарегистрировать устройство WhatsApp для вашего приложения, следуйте этим рекомендациям:

  • hwid: Убедитесь, что это поле содержит префикс whatsapp:, за которым следует номер телефона в формате E.164 (например, whatsapp:+0000000000). Номер телефона должен быть действительным, Pushwoosh его проверит.

  • Push-токен: Push-токен не требуется, так как hwid будет автоматически выполнять функцию push-токена.

  • device_type: Установите значение этого поля 21, чтобы указать WhatsApp в качестве платформы.

Пример запроса
Anchor link to
{
"request": {
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "whatsapp:+0000000000", // обязательно. Префикс WhatsApp и действительный номер телефона
"timezone": 3600, // необязательно. Смещение времени в секундах
"device_type": 21, // обязательно. Тип устройства WhatsApp — 21
"language": "en", // необязательно. Код языка ISO 639-1|639-2
"userId": "Alex", // необязательно. Идентификатор пользователя
"tags": { // необязательно. Значения тегов для кастомной сегментации
"StringTag": "string value",
"IntegerTag": 42,
"ListTag": ["string1", "string2"],
"DateTag": "2024-10-02 22:11", // формат UTC
"BooleanTag": true
},
"app_version": "1.2.3", // необязательно. Версия приложения
"device_model": "Samsung SM-G355H", // необязательно. Модель устройства
"os_version": "2.3" // необязательно. Версия операционной системы
}
}

Регистрация SMS-устройств

Anchor link to

Чтобы зарегистрировать SMS-устройство для вашего приложения, следуйте этим рекомендациям:

  • hwid: Убедитесь, что это поле содержит номер телефона в формате E.164 (например, +0000000000). Номер телефона должен быть действительным, Pushwoosh его проверит.

  • Push-токен: Push-токен не требуется, так как hwid будет автоматически выполнять функцию push-токена.

  • device_type: Установите для этого обязательного поля значение 18, чтобы указать SMS в качестве платформы.

Пример запроса
Anchor link to
{
"request": {
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "+0000000000", // обязательно. Действительный номер телефона в формате E.164
"timezone": 3600, // необязательно. Смещение времени в секундах
"device_type": 18, // обязательно. Тип устройства SMS — 18
"language": "en", // необязательно. Код языка ISO 639-1|639-2
"userId": "Alex", // необязательно. Идентификатор пользователя
"tags": { // необязательно. Значения тегов для кастомной сегментации
"StringTag": "string value",
"IntegerTag": 42,
"ListTag": ["string1", "string2"],
"DateTag": "2024-10-02 22:11", // формат UTC
"BooleanTag": true
},
"app_version": "1.2.3", // необязательно. Версия приложения
"device_model": "Samsung SM-G355H", // необязательно. Модель устройства
"os_version": "2.3" // необязательно. Версия операционной системы
}
}

Коды состояния:

Код состояния HTTPstatus_codeОписание
200200Устройство успешно зарегистрировано
200210Ошибка аргумента. Подробности см. в status_message.
400N/AНеверно сформированная строка запроса
500500Внутренняя ошибка

unregisterDevice

Anchor link to

POST https://go.pushwoosh.com/json/1.3/unregisterDevice

Удаляет push-токен устройства. Устройство с отмененной регистрацией по-прежнему учитывается в Total Devices и может получать In-App сообщения. Вызывается SDK изнутри.

Заголовки запроса
Anchor link to
ИмяОбязательноЗначениеОписание
AuthorizationДаToken XXXXТокен Device API для доступа к Device API. Замените XXXX на ваш реальный токен Device API.
Тело запроса
Anchor link to
ИмяТипОписание
application*stringКод приложения Pushwoosh
hwid*stringАппаратный ID устройства (HWID), использованный в запросе /registerDevice.
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Пример
{
"request": {
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "8f65b16XXXXXe7a6beceXXXXX530fb2" // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
}
}

Коды состояния:

Код состояния HTTPstatus_codeОписание
200200Подписка устройства успешно отменена
200210Ошибка аргумента. Подробности см. в status_message.
400N/AНеверно сформированная строка запроса
500500Внутренняя ошибка

POST https://go.pushwoosh.com/json/1.3/setTags

Устанавливает значения тегов для устройства. Вызывается из SDK.

Заголовки запроса
Anchor link to
ИмяОбязательноЗначениеОписание
AuthorizationДаToken XXXXТокен Device API для доступа к Device API. Замените XXXX на ваш реальный токен Device API.
Тело запроса
Anchor link to
ИмяТипОписание
application*stringКод приложения Pushwoosh
hwid*stringАппаратный ID устройства (HWID), использованный в запросе /registerDevice.
tags*objectJSON-объект с тегами для установки; отправьте “null”, чтобы удалить значение.
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Пример
{
"request":{
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "8f65b16XXXXXe7a6becXXXXXe1530fb2", // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
"tags": { // обязательно.
"StringTag": "string value",
"IntegerTag": 42,
"ListTag": ["string1", "string2"], // устанавливает список значений для тегов типа "Список"
"DateTag": "2024-10-02 22:11", // обратите внимание, время в формате UTC
"BooleanTag": true // допустимые значения - true, false
}
}
}

Увеличение значений тега Integer (целочисленный)

Anchor link to

Чтобы увеличить (инкрементировать) значение тега типа “Integer”, используйте параметр operation со значением “increment” следующим образом:

{
"request":{
"application": "12345-67890", // обязательно. Код приложения Pushwoosh
"hwid": "21AB7628-XXXX-XXXX-CCC0-PO287CS24CA4", // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
"tags": { // обязательно.
"Level": { // Имя тега
"operation": "increment", // перезаписывает целочисленный тег с шагом, равным следующему значению
"value": 1 // инкремент для значения тега
}
}
}
}

Уменьшение значений тега Integer (целочисленный)

Anchor link to

Для уменьшения (декремента) используйте отрицательные числа в качестве значения для операции “increment” (-1, -2, -3,-n):

{
"request":{
"application": "12345-67890", // обязательно. Код приложения Pushwoosh
"hwid": "21AB7628-XXXX-XXXX-CCC0-PO287CS24CA4", // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
"tags": { // обязательно
"Level": { // Имя тега
"operation": "increment", // перезаписывает целочисленный тег с шагом, равным следующему значению (уменьшение)
"value": -1 // декремент для значения тега
}
}
}
}

Добавление значений в тег List (список)

Anchor link to

Чтобы дополнить тег типа “List” новыми значениями, используйте параметр operation со значением “append” следующим образом:

Пример
{
"request": {
"hwid": "3d124a79XXXXf189XXXX7dfd9XXXXafd", // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
"application": "6XXXX-XXXX3", // обязательно. Код приложения Pushwoosh
"tags": { // обязательно.
"ListTag": { // Имя тега
"operation": "append", // добавляет следующие значения в список значений тега
"value": [ // значения для добавления
"tag2",
"tag3"
]
}
}
}
}

Удаление значений из тега List (список)

Anchor link to

Чтобы удалить некоторые значения из тега типа “List”, используйте операцию “remove” следующим образом:

{
"request":{
"application": "12345-67890", // обязательно. Код приложения Pushwoosh
"hwid": "21AB7628-XXXX-XXXX-CCC0-PO287CS24CA4", // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
"tags": { // обязательно.
"In-App Product": { // Имя тега
"operation": "remove", // удаляет следующие значения из тега-списка
"value": "outwear_02" // значение или значения для удаления
}
}
}
}

Установка тегов по User ID

Anchor link to

Чтобы установить теги для всех устройств, связанных с определенным User ID, используйте параметр “userId” вместо “hwid”.

Пример
{
"request":{
"application": "AAAAA-BBBBB", // Код приложения Pushwoosh
"userId": "some_user", // User ID, для которого вы хотите установить теги
"tags": { // теги и значения для установки
"Language": "es"
}
}
}

Коды состояния:

Код состояния HTTPstatus_codeОписание
200200Теги успешно установлены
200210Ошибка аргумента. Подробности см. в status_message.
400N/AНеверно сформированная строка запроса
500500Внутренняя ошибка

POST https://go.pushwoosh.com/json/1.3/getTags

Получает список тегов с соответствующими значениями для конкретного устройства.

Заголовки запроса
Anchor link to
ИмяОбязательноЗначениеОписание
AuthorizationДаToken XXXXТокен Device API для доступа к Device API. Замените XXXX на ваш реальный токен Device API.
Тело запроса
Anchor link to
ИмяТипОписание
application*stringКод приложения Pushwoosh
userIdstringUser ID для использования вместо “hwid”. Если используется вместе с “hwid”, приоритет имеет “hwid”.
hwidstringАппаратный ID устройства (HWID), использованный в запросе /registerDevice.
{
"status_code": 200,
"status_message": "OK",
"response": {
"result": {
"Language": "fr"
}
}
}
Пример
{
"request":{
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "HWID", // необязательно. Аппаратный ID устройства, использованный в API /registerDevice
"userId": "USER_ID" // необязательно. Может использоваться вместо "hwid" для получения тегов для конкретного пользователя
}
}

POST https://api.pushwoosh.com/json/1.3/setBadge

Отправляет текущее значение бейджа для устройства в Pushwoosh. Вызывается SDK изнутри.

Заголовки запроса
Anchor link to
ИмяОбязательноЗначениеОписание
AuthorizationДаToken XXXXТокен Device API для доступа к Device API. Замените XXXX на ваш реальный токен Device API.
Тело запроса
Anchor link to
ИмяТипОписание
application*stringКод приложения Pushwoosh
hwid*stringАппаратный ID устройства (HWID), использованный в запросе /registerDevice.
badge*integerТекущий бейдж на приложении.
{
"status_code": 200,
"status_message": "OK"
}
Пример
{
"request":{
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "8f65b16dXXXXe7a6XXXX9614XXXX0fb2", // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
"badge": 4 // обязательно. Текущий бейдж на приложении
}
}

Вызывается из SDK изнутри. Отправляет текущее значение бейджа для устройства в Pushwoosh. Это происходит изнутри, когда приложение изменяет значение бейджа на устройстве iOS. Позволяет корректно работать автоинкременту бейджей.

applicationOpen

Anchor link to

POST https://api.pushwoosh.com/json/1.3/applicationOpen

Регистрирует событие открытия приложения. Вызывается SDK изнутри.

Заголовки запроса
Anchor link to
ИмяОбязательноЗначениеОписание
AuthorizationДаToken XXXXТокен Device API для доступа к Device API. Замените XXXX на ваш реальный токен Device API.
Тело запроса
Anchor link to
ИмяТипОписание
application*stringКод приложения Pushwoosh
hwid*stringАппаратный ID устройства (HWID), использованный в запросе /registerDevice.
{
"status_code": 200,
"status_message": "OK"
}
Пример
{
"request": {
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "8f65b16dXXXXe7a6XXXX9614eXXXXfb2" // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
}
}

POST https://api.pushwoosh.com/json/1.3/pushStat

Регистрирует событие открытия push-уведомления. Вызывается SDK изнутри.

Заголовки запроса
Anchor link to
ИмяОбязательноЗначениеОписание
AuthorizationДаToken XXXXТокен Device API для доступа к Device API. Замените XXXX на ваш реальный токен Device API.
Тело запроса
Anchor link to
ИмяТипОписание
application*stringКод приложения Pushwoosh
hwid*stringАппаратный ID устройства (HWID), использованный в запросе /registerDevice.
userIdstringUser ID для связи с событием открытия push-уведомления.
hashstringХэш-тег, полученный в push-уведомлении (параметр “p” в полезной нагрузке push-уведомления).
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Пример
{
"request": {
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "8f65b16dfXXXX7a6beXXXX14e1530fb2", // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
"userId": "USER012345", // необязательно. User ID для связи с событием открытия push-уведомления
"hash": "HASH_TAG" // необязательно. Хэш-тег, полученный в push-уведомлении
// (параметр "p" в полезной нагрузке push-уведомления)
}
}

messageDeliveryEvent

Anchor link to

POST https://api.pushwoosh.com/json/1.3/messageDeliveryEvent

Регистрирует событие доставки push-уведомления для устройства. Вызывается SDK изнутри.

Заголовки запроса
Anchor link to
ИмяОбязательноЗначениеОписание
AuthorizationДаToken XXXXТокен Device API для доступа к Device API. Замените XXXX на ваш реальный токен Device API.
Тело запроса
Anchor link to
ИмяТипОписание
application*stringКод приложения Pushwoosh
hwid*stringАппаратный ID устройства (HWID), использованный в запросе /registerDevice.
hashstringХэш-тег, полученный в push-уведомлении (параметр “p” в полезной нагрузке push-уведомления).
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Пример
{
"request": {
"application": "XXXXX-XXXXX", // обязательно. Код приложения Pushwoosh
"hwid": "8f65b16dfXXXX7a6bece9XXXX1530fb2", // обязательно. Аппаратный ID устройства, использованный в API /registerDevice
"hash": "HASH_TAG" // необязательно. Хэш-тег, полученный в push-уведомлении
// (параметр "p" в полезной нагрузке push-уведомления)
}
}