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

API Сегментации (Фильтры)

createFilter

Anchor link to

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

Создает новый фильтр.

Тело запроса

НазваниеОбязательноТипОписание
auth*ДаstringТокен доступа API из Панели управления Pushwoosh.
name*ДаstringНазвание фильтра.
filter_expression*Даstring

Выражение, составленное в соответствии с правилами языка Сегментации.
Пример: T(“City”, eq, “Madrid”) для сегментации пользователей, чей город — Мадрид.

applicationНетstringКод приложения Pushwoosh. Этот параметр используется только с High-Speed Setup; в противном случае его следует опустить.
expiration_dateНетstringСрок действия фильтра. Фильтр будет автоматически удален в указанную дату, если он не используется в Пресете или RSS-ленте.

200

{
"status_code": 200,
"status_message": "OK",
"response": {
"name": "filter name"
}
}

Пример

{
"request": {
"auth": "yxoPUlwqm…………pIyEX4H",
"name": "City = Madrid",
"filter_expression": "T(\"City\", eq, \"Madrid\")",
"application": "B18XX-XXXXX",
"expiration_date": "2025-01-01"
}
}
// создание Фильтров для часовых поясов
{
"request": {
"auth": "yxoPUlwqm…………pIyEX4H", // Токен доступа API из Панели управления Pushwoosh
"name": "Timezone Filter",
"filter_expression": "T(\"Timezone\", BETWEEN, [\"UTC-12:00\", \"UTC+14:00\"])"
}
}

listFilters

Anchor link to

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

Возвращает список доступных сегментов (фильтров) с их условиями.

Тело запроса

НазваниеОбязательноТипОписание
auth*ДаstringТокен доступа API из Панели управления Pushwoosh.
application*ДаstringКод приложения Pushwoosh

200

{
"status_code": 200,
"status_message": "OK",
"response": {
"filters": [{
"code": "52551-F2F42",
"name": "City = Madrid",
"filter_expression": "T(\"City\", eq, \"madrid\")",
"expiration_date": "2025-01-01",
"application": "B18XX-XXXXX"
}]
}
}

Пример

{
"request": {
"auth": "yxoPUlwqm…………pIyEX4H",
"application": "B18XX-XXXXX"
}
}

deleteFilter

Anchor link to

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

Удаляет существующий фильтр.

Тело запроса

НазваниеТипОписание
auth*stringТокен доступа API из Панели управления Pushwoosh.
name*stringНазвание фильтра.
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Пример
{
"request": {
"auth": "yxoPUlwqm…………pIyEX4H", // Токен доступа API из Панели управления Pushwoosh
"name": "filter name"
}
}

exportSegment

Anchor link to

POST https://api.pushwoosh.com/api/v2/audience/exportSegment

Запланированный запрос. Экспортирует список подписчиков, которые подпадают под указанные условия Фильтра.

Тело запроса

Название
Обязательно
ТипОписание
auth*ДаstringТокен доступа API из Панели управления Pushwoosh.
filterExpression*ДаstringУсловия фильтра
exportDataНетarrayДанные для экспорта. Возможные значения: "hwids", "push_tokens", "users", "tags", "location". Включение "location" добавляет столбцы Latitude и Longitude в экспортируемый CSV. Если exportData опущен, Latitude и Longitude включаются в экспорт по умолчанию.
filterCodeНетstringГотовый код фильтра, можно использовать вместо filterExpression. Можно получить из API /listFilters или из адресной строки вашего браузера при просмотре фильтра в Панели управления.
applicationCodeОбязательно, если вы используете filterExpression или filterCode.stringКод приложения Pushwoosh
generateExportНетbooleanПо умолчанию установлено true, и ответ содержит ссылку для скачивания файла. Если false, в ответе будет отправлено только количество устройств.
formatНетstringУстанавливает формат экспортируемого файла: “csv” или “json_each_line”. Если не указано, генерируется CSV-файл.
tagsListНетarrayУказывает теги для экспорта. Чтобы получить только определенные теги, массив “exportData” должен содержать значение “tags”.
includeWithoutTokensНетbooleanУстановите true, чтобы включить пользователей без push-токенов в экспортируемый файл. По умолчанию false.
{
"task_id": "177458"
}
Пример
{
"auth": "yxoPUlwqm…………pIyEX4H", // обязательно. Токен доступа API из Панели управления Pushwoosh
"filterExpression": "AT(\"12345-67890\", \"Name\", any)", // условия фильтра, синтаксис см. в руководстве по языку Сегментации
"filterCode": "12345-67890", // готовый код фильтра, можно использовать вместо filterExpression
"applicationCode": "00000-AAAAA", // Обязательно, если вы используете `filterExpression` или `filterCode`. Код приложения Pushwoosh. Можно получить из API-запроса /listFilters или из адресной строки браузера при просмотре фильтра в Панели управления.
"generateExport": true, // если false, в ответе будет только количество устройств; по умолчанию ответ содержит ссылку для скачивания CSV-файла
"format": "json_each_line", // формат файла для представления данных: "csv" – скачивается .csv-файл; "json" – JSON-файл со всеми экспортированными устройствами; или "json_each_line" – строка JSON для каждого устройства. Если не указано, по умолчанию используется формат CSV.
"exportData": ["hwids", "tags"], // необязательно. Данные для экспорта. Возможные значения: "hwids", "push_tokens", "users", "tags", "location", "fcm_keys", "web keys"
"tagsList": ["Name", "Level"], // необязательно. Указывает теги для экспорта. Чтобы получить только определенные теги, в массиве "exportData" должно быть значение "tags", либо массив "exportData" должен быть пустым.
"includeWithoutTokens": true // необязательно. Установите true, чтобы включить пользователей без push-токенов в экспортируемый файл. По умолчанию false.
}

Например, чтобы экспортировать всех подписчиков определенного приложения, используйте следующие условия Фильтра:

{
"auth": "yxoPUlwqm…………pIyEX4H", // Токен доступа API из Панели управления Pushwoosh
"filterExpression": "A(\"AAAAA-BBBBB\")", // Выражение фильтра, ссылающееся на сегмент приложения
"applicationCode": "AAAAA-BBBBB" // Обязательный код приложения Pushwoosh
}

exportSegment results

Anchor link to

POST https://api.pushwoosh.com/api/v2/audience/exportSegment/result

Получает ссылку на CSV с результатами /exportSegment.

Тело запроса

НазваниеТипОписание
auth*StringТокен доступа API из Панели управления Pushwoosh.
task_id*StringИдентификатор, полученный в вашем ответе на /exportSegment.
{
"devicesCount": "24735",
"filename": "https://static.pushwoosh.com/segment-export/export_segment_XXXXX_XXXXX_xxxxxxxxxxxxxxxxx.csv.zip",
"status": "completed"
}

Передайте «task_id», полученный в ответе на ваш запрос /exportSegment, в теле запроса /exportSegment/result.

В ответе на запрос /exportSegment/result вы получите параметр «filename». Перейдите по ссылке, указанной в значении этого параметра, чтобы автоматически загрузить ZIP-архив. Распакуйте архив, чтобы получить CSV или JSON файл (в зависимости от «format», указанного в вашем запросе), содержащий данные устройств.

С 3 апреля 2025 года для скачивания файла потребуется авторизация:

  • При скачивании через браузер просто войдите в Панель управления Pushwoosh, чтобы получить доступ.
  • При скачивании через серверное ПО включите в ваш запрос следующий заголовок: Authorization: Token YOUR_API_TOKEN

Если вы укажете «exportData» в вашем запросе /exportSegment, скачанный файл будет содержать только запрошенные данные. По умолчанию файл содержит следующие данные пользователя:

ПолеОписаниеПример значения
HwidАппаратный ID устройства01D1BA5C-AAAA-0000-BBBB-9B81CD5823C8
User IDUser ID, связывающий устройство с определенным пользователем. Если User ID не назначен, используется HWID.user8192
Push TokenУникальный идентификатор, присваиваемый устройству шлюзами облачных сообщений. Узнать большеeeeb2fd7…0fc3547
TypeТип платформы (целое число).1
Type (humanized)Тип платформы (строка).iOS
AgeЗначение тега по умолчанию Age.29
ApplicationVersionЗначение тега по умолчанию Application Version.1.12.0.0
CityЗначение тега по умолчанию City.us, boston
TagNameЗначение тега, созданного в вашем аккаунте.TagValue