ข้ามไปยังเนื้อหา

แจ้งเตือน

POST https://api.pushwoosh.com/messaging/v2/notify

สร้างและกำหนดเวลาส่งข้อความเดียว

โครงสร้างคำขอ

Anchor link to

เนื้อหาของคำขอคือ NotifyRequest ที่มีหนึ่งในสองชนิดเท่านั้น:

  • segment: กำหนดเป้าหมายเซกเมนต์ผู้ชมตามรหัสเซกเมนต์, นิพจน์ seglang หรือนิพจน์ตัวกรองที่มีโครงสร้าง
  • transactional: ส่งไปยังรายการที่ระบุของ hwids, User ID, push tokens หรืออุปกรณ์ทดสอบ
Shape
{
"segment": { ... } // OR
"transactional": { ... }
}

NotifySegment

Anchor link to

กำหนดเป้าหมายผู้ใช้ที่ตรงกับเซกเมนต์ผู้ชมหรือนิพจน์ตัวกรอง

ฟิลด์ประเภทคำอธิบาย
scheduleScheduleเวลาและวิธีการส่ง จำเป็น
applicationstringรหัสแอปพลิเคชัน
platformsarray of Platformแพลตฟอร์มที่ข้อความจะส่งไปถึง
codestringรหัสเซกเมนต์ ไม่สามารถใช้ร่วมกับ expression และ filter_expression ได้
expressionstringนิพจน์ Seglang
filter_expressionFilterExpressionนิพจน์ตัวกรองที่มีโครงสร้าง (ขั้นสูง)
payloadPayloadเพย์โหลดของ Push / SMS / Telegram / Kakao ไม่สามารถใช้ร่วมกับ email_payload ได้
email_payloadEmailPayloadเพย์โหลดของอีเมล
campaignstringรหัสแคมเปญ เพื่อระบุว่าข้อความนี้เป็นของแคมเปญใด
frequency_cappingFrequencyCappingการจำกัดความถี่ต่อผู้ใช้
send_rateSendRateการควบคุมอัตราการส่ง
message_typeMessageTypeMESSAGE_TYPE_MARKETING (ค่าเริ่มต้น) หรือ MESSAGE_TYPE_TRANSACTIONAL ควบคุมการกรองกลุ่มควบคุม
dynamic_content_placeholdersmap<string, string>แทนที่ตัวยึดตำแหน่งในเนื้อหา
meta_dataobjectเมตาดาต้าแบบอิสระที่ส่งต่อไปยังการวิเคราะห์ข้อมูลปลายทาง

ตัวอย่าง: ส่งไปยังเซกเมนต์

Anchor link to
Terminal window
curl -X POST https://api.pushwoosh.com/messaging/v2/notify \
-H "Authorization: Token YOUR_API_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"segment": {
"application": "XXXXX-XXXXX",
"platforms": ["IOS", "ANDROID"],
"code": "active_users",
"payload": {
"content": {
"localized_content": {
"en": {
"ios": { "body": "Hello!" },
"android": { "body": "Hello!" }
}
}
}
},
"schedule": { "at": "2026-05-01T12:00:00Z" },
"message_type": "MESSAGE_TYPE_MARKETING"
}
}'

NotifyTransactional

Anchor link to

ส่งไปยังรายชื่อผู้รับที่ระบุอย่างชัดเจน

ฟิลด์ประเภทคำอธิบาย
scheduleScheduleจำเป็น
applicationstringรหัสแอปพลิเคชัน
platformsarray of Platformแพลตฟอร์มที่ข้อความจะส่งไปถึง
test_devicesboolถ้าเป็น true จะส่งไปยังอุปกรณ์ทดสอบของแอปเท่านั้น
hwids{ "list": [string, ...] }ส่งไปยัง hwids เหล่านี้เท่านั้น
users{ "list": [string, ...] }ส่งไปยัง User ID เหล่านี้เท่านั้น
push_tokens{ "list": [string, ...] }ส่งไปยัง push tokens เหล่านี้เท่านั้น
payloadPayloadเพย์โหลดของ Push / SMS / Telegram / Kakao
email_payloadEmailPayloadเพย์โหลดของอีเมล
return_unknown_identifiersboolเมื่อเป็น true การตอบกลับในส่วน unknown_identifiers จะแสดงรายการตัวระบุที่ไม่พบ
use_latest_user_deviceboolใช้ได้เฉพาะเมื่อคุณกำหนดเป้าหมายเป็น users เมื่อเป็น true ข้อความจะถูกส่งไปยังอุปกรณ์ที่ใช้งานล่าสุดของผู้ใช้แต่ละคน — อุปกรณ์ที่มี Last Application Open ล่าสุด — แทนที่จะส่งไปยังทุกอุปกรณ์ที่ผูกกับ User ID นั้น ค่าเริ่มต้นคือ false (ส่งไปยังทุกอุปกรณ์)
campaign, frequency_capping, send_rate, message_type, dynamic_content_placeholders, meta_dataดู NotifySegment ด้านบน

test_devices, hwids, users และ push_tokens ไม่สามารถใช้ร่วมกันได้ ต้องตั้งค่าเพียงหนึ่งอย่างเท่านั้น

ตัวอย่าง: การทำธุรกรรมตาม User ID

Anchor link to
Terminal window
curl -X POST https://api.pushwoosh.com/messaging/v2/notify \
-H "Authorization: Token YOUR_API_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"transactional": {
"application": "XXXXX-XXXXX",
"platforms": ["IOS", "ANDROID"],
"users": { "list": ["user-123", "user-456"] },
"payload": {
"content": {
"localized_content": {
"en": { "ios": { "body": "Your order has shipped." } }
}
}
},
"schedule": { "at": "2026-05-01T12:00:00Z" },
"message_type": "MESSAGE_TYPE_TRANSACTIONAL",
"return_unknown_identifiers": true,
"use_latest_user_device": true
}
}'

การตอบกลับ

Anchor link to
{
"result": {
"message_code": "XXXXX-XXXXX-XXXXX",
"unknown_identifiers": []
}
}
ฟิลด์ประเภทคำอธิบาย
message_codestringรหัสข้อความ ที่ไม่ซ้ำกัน ใช้กับ /getMessageDetails และเอ็นด์พอยต์สถิติข้อความ
unknown_identifiersarray of stringตัวระบุที่ไม่พบบนบัญชี จะถูกเติมข้อมูลก็ต่อเมื่อมีการตั้งค่า return_unknown_identifiers: true ในชนิด transactional เท่านั้น

ประเภทที่ใช้ร่วมกัน

Anchor link to
{
"at": "2026-05-01T12:00:00Z",
"follow_user_timezone": true,
"past_timezones_behaviour": "PAST_TIMEZONES_BEHAVIOUR_SEND_IMMEDIATELY"
}
ฟิลด์ประเภทคำอธิบาย
attimestampเวลาส่งที่แน่นอน (RFC 3339) หากเป็นเวลาในอดีต ข้อความจะถูกส่งทันที สามารถตั้งล่วงหน้าได้สูงสุด 14 วัน
afterdurationทางเลือกแทน at ส่งหลังจากเวลาที่กำหนดนับจาก “ตอนนี้” (เช่น "3600s")
follow_user_timezoneboolเมื่อเป็น true แต่ละอุปกรณ์จะได้รับข้อความ ณ เวลา at ตามเขตเวลาท้องถิ่นของอุปกรณ์นั้น
past_timezones_behaviourenumPAST_TIMEZONES_BEHAVIOUR_SEND_IMMEDIATELY (ค่าเริ่มต้น), PAST_TIMEZONES_BEHAVIOUR_DO_NOT_SEND หรือ PAST_TIMEZONES_BEHAVIOUR_NEXT_DAY จะมีความหมายก็ต่อเมื่อ follow_user_timezone เป็น true เท่านั้น

FrequencyCapping

Anchor link to

การจำกัดความถี่ต่อผู้ใช้สำหรับการส่งข้อความทางการตลาด

{ "days": 7, "count": 3, "exclude": false, "avoid": true }
  • days (int, 1–30): กรอบเวลาย้อนหลัง
  • count (int): จำนวนข้อความสูงสุดที่อนุญาตภายใน days
  • exclude (bool): ไม่รวมผู้ใช้ที่ถึงขีดจำกัดแล้วอย่างเด็ดขาด
  • avoid (bool): หลีกเลี่ยงผู้ใช้ที่ถึงขีดจำกัดแล้ว (แต่ยังคงนับรวมในสถิติ)
{ "value": 500, "bucket": "1s", "avoid": false }

ควบคุมอัตราการส่ง value คือจำนวนข้อความต่อ bucket; bucket ทั่วไปคือ "1s"

Platform enum

Anchor link to

IOS, ANDROID, OSX, WINDOWS, AMAZON, SAFARI, CHROME, FIREFOX, IE, EMAIL, BAIDU_ANDROID, HUAWEI_ANDROID, SMS, WEB, KAKAO, TELEGRAM, LINE, WHATS_APP

MessageType enum

Anchor link to
  • MESSAGE_TYPE_UNSPECIFIED: เทียบเท่ากับ MESSAGE_TYPE_MARKETING
  • MESSAGE_TYPE_MARKETING: อยู่ภายใต้การกรองกลุ่มควบคุมและการจำกัดความถี่
  • MESSAGE_TYPE_TRANSACTIONAL: ข้ามการกรองกลุ่มควบคุมและการจำกัดความถี่ ใช้สำหรับการยืนยันคำสั่งซื้อ, OTP และโฟลว์ที่สำคัญอื่นๆ ที่คล้ายกัน

ที่เกี่ยวข้อง

Anchor link to