跳到内容

Email API

createEmailMessage

Anchor link to

创建一封电子邮件消息。

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

请求体参数

Anchor link to
名称类型
必需描述
authstring来自 Pushwoosh 控制面板的 API access token
applicationstringPushwoosh application code
notificationsarray包含电子邮件消息详情的 JSON 数组。请参阅下方的 Notifications 参数 表。

Notifications 参数

Anchor link to
名称类型
必需描述
send_datestring定义发送电子邮件的时间。格式:YYYY-MM-DD HH:mm"now"
presetstringEmail preset code。从 Pushwoosh 控制面板中 Email Content Editor 的 URL 栏复制。
subjectstringobject电子邮件的主题行。电子邮件将始终使用内容的语言。如果 subject 不包含与 content 匹配的语言,则主题将为空。
contentstringobject电子邮件正文内容。可以是纯 HTML 内容的字符串,也可以是本地化版本的对象。
attachmentsarray电子邮件附件。最多只能有两个附件。每个附件(base64 编码后)不得超过 1MB。
list_unsubscribestring允许为 “Link-Unsubscribe” 标头设置自定义 URL。
campaignstringCampaign code,用于将电子邮件与特定营销活动关联。
ignore_user_timezoneboolean如果为 true,则立即发送电子邮件,忽略用户时区。
timezonestring根据用户的时区发送电子邮件。示例:"America/New_York"
filterstring将电子邮件发送给符合特定筛选条件的用户。
devicesarray用于发送定向电子邮件的电子邮件地址列表(最多 1000 个)。如果使用此参数,消息将仅发送给这些地址。如果使用 Application Group,则此参数将被忽略。
use_auto_registrationboolean如果为 true,则自动注册来自 devices 参数的电子邮件。
usersarray如果设置,电子邮件消息将仅发送给指定的 User ID(通过 /registerEmail 调用注册)。数组中不超过 1000 个 User ID。如果指定了 “devices” 参数,则 “users” 参数将被忽略。
dynamic_content_placeholdersobject用于动态内容的占位符,以替代设备标签值。
conditionsarray使用标签的细分条件。示例:[["Country", "EQ", "BR"]]
fromobject指定自定义发件人姓名和电子邮件,以覆盖应用程序属性中的默认设置。
reply-toobject指定自定义回复电子邮件,以覆盖应用程序属性中的默认设置。
bccarrayBCC (密送):接收电子邮件副本但其他收件人看不到的电子邮件地址数组。
email_typestring指定电子邮件类型:"marketing""transactional"。如果省略,PW_ControlGroup: true 的用户将不会收到该消息。
email_categorystringemail_type"marketing" 时必需。指定在订阅偏好中心配置的类别名称之一(例如 Newsletter、Promotional、Product Updates)。
transactionIdstring唯一的消息标识符,用于在出现网络问题时防止重复发送。在 Pushwoosh 端存储 5 分钟。
capping_daysinteger对每个设备应用频次上限的天数(最多 30 天)。注意: 确保在控制面板中配置了全局频次上限
capping_countintegercapping_days 期间内,可从特定应用发送到特定设备的最大电子邮件数量。如果创建的消息超出了设备的 capping_count 限制,则不会发送到该设备。
capping_excludeboolean如果设置为 true,则此电子邮件将不计入未来电子邮件的频次上限。
capping_avoidboolean如果设置为 true,则频次上限将不适用于此特定电子邮件。
send_rateinteger限制每秒可向所有用户发送的消息数量。有助于防止在大批量发送期间后端过载。
send_rate_avoidboolean如果设置为 true,则节流限制将不适用于此特定电子邮件。

请求示例

Anchor link to
{
"request": {
"auth": "API_ACCESS_TOKEN", // 必需。来自 Pushwoosh 控制面板的 API access token
"application": "APPLICATION_CODE", // 必需。Pushwoosh application code。
"notifications": [{
"send_date": "now", // 必需。YYYY-MM-DD HH:mm 或 'now'
"preset": "ERXXX-32XXX", // 必需。从 Pushwoosh 控制面板的 Email Content
// 编辑器页面的 URL 栏复制 Email preset code。
"subject": { // 可选。电子邮件消息主题行。
"de": "subject de",
"en": "subject en"
},
"content": { // 可选。电子邮件正文内容。
"de": "<html><body>de Hello, moto</body></html>",
"default": "<html><body>default Hello, moto</body></html>"
},
"attachments": [{ // 可选。电子邮件附件
"name": "image.png", // "name" - 文件名
"content": "iVBANA...AFTkuQmwC" // "content" - 文件的 base64 编码内容
}, {
"name": "file.pdf",
"content": "JVBERi...AFTarEGC"
}],
"list_unsubscribe": "URL", // 可选。允许为 "Link-Unsubscribe" 标头设置自定义 URL
"campaign": "CAMPAIGN_CODE", // 可选。要将此电子邮件消息分配给特定营销活动,
// 请在此处添加营销活动代码。
"ignore_user_timezone": true, // 可选。
"timezone": "America/New_York", // 可选。指定根据用户设备上设置的时区
// 发送消息。
"filter": "FILTER_NAME", // 可选。将消息发送给符合筛选条件的特定用户。
"devices": [ // 可选。指定电子邮件地址以发送定向电子邮件消息。
"email_address1", // 数组中不超过 1000 个地址。
"email_address2" // 如果设置,消息将仅发送给列表中的地址。
], // 如果使用 Application Group,则此参数将被忽略。
"use_auto_registration": true, // 可选。自动注册在 "devices" 参数中指定的电子邮件
"users": [ // 可选。如果设置,电子邮件消息将仅发送给
"userId1", // 指定的用户 ID(通过 /registerEmail 调用注册)。
"userId2" // 数组中不超过 1000 个用户 ID。
], // 如果指定了 "devices" 参数,
// 则 "users" 参数将被忽略。
"dynamic_content_placeholders": { // 可选。用于动态内容的占位符,以替代设备标签值。
"firstname": "John",
"firstname_en": "John"
},
"conditions": [ // 可选。细分条件,请参阅下面的说明。
["Country", "EQ", "BR"],
["Language", "EQ", "pt"]
],
"from": { // 可选。指定发件人姓名和发件人电子邮件地址
"name": "alias from", // 以替换应用程序属性中设置的
"email": "from-email@email.com" // 默认“发件人姓名”和“发件人电子邮件”。
},
"reply-to": { // 可选。指定一个电子邮件地址以替换
"name": "alias reply to ", // 应用程序属性中设置的默认“回复至”。
"email": "reply-to@email.com"
},
"bcc": [ // 可选。BCC:接收副本但其他收件人看不到的电子邮件地址数组。
"bcc1@example.com",
"bcc2@example.com"
],
"email_type": "marketing", // 可选。"marketing" 或 "transactional"。
// 如果省略,PW_ControlGroup: true 的用户将不会收到该消息。
"email_category": "category name",// 当 email_type 为 "marketing" 时必需。类别名称。
"transactionId": "unique UUID", // 可选。唯一的消息标识符,用于在出现网络问题时
// 防止重复发送。在 Pushwoosh 端存储 5 分钟。
// 频次上限参数。确保在控制面板中配置了全局频次上限。
// 频次上限不适用于事务性消息。
// 在所有其他情况下,包括省略 "email_type",频次上限均适用。
"capping_days": 30, // 可选。频次上限的天数(最多 30 天)
"capping_count": 10, // 可选。在 'capping_days' 期间内,可从特定应用
// 发送到特定设备的最大电子邮件数量。
// 如果创建的消息超出了设备的 'capping_count'
// 限制,则不会发送到该设备。
"capping_exclude": true, // 可选。如果设置为 true,此电子邮件将不计入
// 未来电子邮件的频次上限。
"capping_avoid": true, // 可选。如果设置为 true,频次上限将不适用于
// 此特定电子邮件。
"send_rate": 100, // 可选。节流限制。
// 限制每秒可向所有用户发送的消息数量。
// 有助于防止在大批量发送期间后端过载。
"send_rate_avoid": true, // 可选。如果设置为 true,节流限制将不适用于
// 此特定电子邮件。
}]
}
}

响应示例

Anchor link to
{
"status_code": 200,
"status_message": "OK",
"response": null
}

标签条件

Anchor link to

每个标签条件都是一个类似 [tagName, operator, operand] 的数组,其中

  • tagName:标签的名称
  • operator: “EQ” | “IN” | “NOTEQ” | “NOTIN” | “LTE” | “GTE” | “BETWEEN”
  • operand: string | integer | array | date

操作数描述

Anchor link to
  • EQ:标签值等于操作数;
  • IN:标签值与操作数相交(操作数必须始终为数组);
  • NOTEQ:标签值不等于操作数;
  • NOTIN:标签值不与操作数相交(操作数必须始终为数组);
  • GTE:标签值大于或等于操作数;
  • LTE:标签值小于或等于操作数;
  • BETWEEN:标签值大于或等于最小操作数值,但小于或等于最大操作数值(操作数必须始终为数组)。

字符串标签

Anchor link to

有效操作符:EQ, IN, NOTEQ, NOTIN
有效操作数:

  • EQ, NOTEQ:操作数必须是字符串;
  • IN, NOTIN:操作数必须是字符串数组,如 ["value 1", "value 2", "value N"]

整数标签

Anchor link to

有效操作符:EQ, IN, NOTEQ, NOTIN, BETWEEN, GTE, LTE
有效操作数:

  • EQ, NOTEQ, GTE, LTE:操作数必须是整数;
  • IN, NOTIN:操作数必须是整数数组,如 [value 1, value 2, value N]
  • BETWEEN:操作数必须是整数数组,如 [min_value, max_value]

日期标签

Anchor link to

有效操作符:EQ, IN, NOTEQ, NOTIN, BETWEEN, GTE, LTE
有效操作数:

  • "YYYY-MM-DD 00:00" (字符串)
  • unix 时间戳 1234567890 (整数)
  • "N days ago" (字符串),用于操作符 EQ, BETWEEN, GTE, LTE

布尔标签

Anchor link to

有效操作符:EQ
有效操作数:0, 1, true, false

列表标签

Anchor link to

有效操作符:IN
有效操作数:操作数必须是字符串数组,如 ["value 1", "value 2", "value N"]

registerEmail

Anchor link to

为应用注册电子邮件地址。

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

名称必需描述
AuthorizationToken XXXX用于访问 Device API 的 API Device Token。将 XXXX 替换为您的实际 Device API token。
名称类型描述
application*stringPushwoosh application code
email*string电子邮件地址。
languagestring设备的语言区域设置。必须是符合 ISO-639-1 标准的小写双字母代码。
userIdstring与电子邮件地址关联的 User ID
tz_offsetinteger时区偏移量(秒)。
tagsobject分配给已注册设备的标签值。
{
"status_code": 200,
"status_message": "OK",
"response": null
}
示例
{
"request": {
"application": "APPLICATION_CODE", // 必需。Pushwoosh application code。
"email":"email@domain.com", // 必需。要注册的电子邮件地址。
"language": "en", // 可选。语言区域设置。
"userId": "userId", // 可选。与电子邮件地址关联的用户 ID。
"tz_offset": 3600, // 可选。时区偏移量(秒)。
"tags": { // 可选。为已注册设备设置的标签值。
"StringTag": "string value",
"IntegerTag": 42,
"ListTag": ["string1","string2"], // 为列表类型的标签设置值列表
"DateTag": "2024-10-02 22:11", // 注意时间应为 UTC
"BooleanTag": true // 有效值为:true, false
}
}
}

deleteEmail

Anchor link to

从您的用户群中移除电子邮件地址。

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

名称必需描述
AuthorizationToken XXXX用于访问 Device API 的 API Device Token。将 XXXX 替换为您的实际 Device API token。
名称类型描述
applicationstringPushwoosh application code
emailstring/registerEmail 请求中使用的电子邮件地址。
{
"status_code": 200,
"status_message": "OK",
"response": null
}
示例
{
"request": {
"application": "APPLICATION_CODE", // 必需。Pushwoosh application code
"email": "email@domain.com" // 必需。要从应用订阅者中删除的电子邮件。
}
}

setEmailTags

Anchor link to

为电子邮件地址设置标签值。

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

名称必需描述
AuthorizationToken XXXX用于访问 Device API 的 API Device Token。将 XXXX 替换为您的实际 Device API token。
名称类型描述
applicationstringPushwoosh application code
emailstring电子邮件地址。
tagsobject要设置的标签的 JSON 对象,发送 ‘null’ 以移除值。
userIdstring与电子邮件地址关联的 User ID
{
"status_code": 200,
"status_message": "OK",
"response": {
"skipped": []
}
}
示例
{
"request": {
"email": "email@domain.com", // 必需。要为其设置标签的电子邮件地址。
"application": "APPLICATION_CODE", // 必需。Pushwoosh application code。
"tags": {
"StringTag": "string value",
"IntegerTag": 42,
"ListTag": ["string1", "string2"],
"DateTag": "2024-10-02 22:11", // UTC 时间
"BooleanTag": true // 有效值为:true, false
},
"userId": "userId" // 可选。与电子邮件地址关联的用户 ID。
}
}

registerEmailUser

Anchor link to

将外部 User ID 与指定的电子邮件地址关联。

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

可在 /createEmailMessage API 调用中使用(‘users’ 参数)。

名称必需描述
AuthorizationToken XXXX用于访问 Device API 的 API Device Token。将 XXXX 替换为您的实际 Device API token。
名称类型描述
application*stringPushwoosh application code
email*string电子邮件地址。
userId*string与电子邮件地址关联的 User ID
tz_offsetinteger时区偏移量(秒)。
{
"status_code": 200,
"status_message": "OK",
"response": null
}
示例
{
"request": {
"application": "APPLICATION_CODE", // 必需。Pushwoosh application code。
"email": "email@domain.com", // 必需。用户电子邮件地址。
"userId": "userId", // 必需。与电子邮件地址关联的用户 ID。
"tz_offset": 3600 // 可选。时区偏移量(秒)。
}
}