Web SDK API
鉴权
开发者在执行初始化的时候,需要传入必要信息,该数据结构由开发者服务端生成并传回浏览器,用于开发者授权此浏览器运行的 MTpush 初始化。开发者需确保能调用获取到此数据的皆为合法用户。
初始化数据结构
interface MTInitInfo {
website_push_id: string;
code: number;
master_secret: string;
passwd: string;
pull: number;
regid: string;
sess: string;
tagalias: number;
uid: number;
vapid_pubkey: string;
}
type dataType = {
code: number,
content: string,
message: string,
};
interface InitType {
appkey: string; //开发者在 URORA 平台注册的应用appkey,必填
user_str: string; //用户唯一标识,必填
swUrl?: string; //默认 "/sw.min." + sdkEnv.version + ".js"
debugMode?: boolean; //默认 false,
webSocketUrl?: string; //如果不存在则用 baseUrl
fail?: (data: dataType | undefined) => void; //初始化失败回调
success?: (data: dataType | undefined) => void; //初始化成功回调
webPushcallback?: def;
canGetInfo?: (d: MTInitInfo) => void;
custom?: (Callback: () => void) => void; //自定义提示可用时回调,完成操用后调用Callback可申请
maCompletion?: (code: number, msg: string) => void; // ma-sdk初始化完成回调
/**
* 点击通知时的跳转链接,优先级:发送通知时设置的URL -> InitType.openUrl -> 集成页面的域名
* 对于safari浏览器,系统通道下发的消息,需要额外做处理:在加载 SDK 前设置 window.MTpushInterfaceTempData = { openUrl: 'https://example.com' }
*/
openUrl?: string;
}
同一作用域只能注册一个service worker,当初始化成功报类似Failed to execute 'subscribe' on 'PushManager': Subscription failed - no active Service Worker错误,确认是否有 service worker冲突,需合并service worker或解决service worker 作用域冲突。
SDK 初始化
接口说明
初始化接口。
window.MTpushInterface.init(Object:InitType)
参数说明
- 详见 InitType 说明。
- 回调 Object data 说明:
参数名称 | 参数类型 | 参数说明 |
---|---|---|
code | number | 返回码,0 代表成功,其他失败,详见 错误码 |
message | string | 结果描述 |
content | string | 注册失败 1003 时返回失败信息 |
调用示例
MTpushInterface.init({
appkey: "xxx",
user_str: "adminDemo",
fail(data) {
console.log("在线推送创建失败", data);
},
success(data) {
console.log("在线推送创建成功", data);
},
webPushcallback(cod, tip) {
console.log("用户得到的状态码及提示", code, tip);
},
//swUrl?: string; //默认 "/sw.min." + sdkEnv.version + ".js"
canGetInfo(d) {
//此时可以得到 RegId 也可以在d里面取到所有的数据
console.log("得到RegId", MTpushInterface.getRegistrationID(), d);
// MTpushInterface.setTagsAlias({ tags: ["test1", "test2"], alias: "swefgwwefwfwfwf" });
},
custom: (reqPermission) => {
//当使用自定义提示配置时,需调用 reqPermission 来请求并配置权限 在custom回调中拿到请求权限函数,在适当的时机直接调用reqPermission来请求通知权限。
document.getElementById("xx")?.addEventListener("click", reqPermission); },
});
获取 RegistrationID
接口说明
调用此 API 来取得当前账户对应的 RegistrationID。 只有初始化签名成功后才返回对应的值,否则返回空字符串。该方法需在 canGetInfo 回调触发后调用。
window.MTpushInterface.getRegistrationID()
调用示例
var rid = window.MTpushInterface.getRegistrationID();
停止推送
调用此 API 来断开与后台建立的推送长连接,停止接收推送消息。
window.MTpushInterface.mtPush.stopPush()
推送消息监听
接口说明
建议在初始化前调用消息监听。
window.MTpushInterface.onMsgReceive(fn)
参数说明
参数名称 | 参数类型 | 参数说明 |
---|---|---|
fn | function | 消息接收处理函数 |
调用示例
window.MTpushInterface.onMsgReceive(function (res) {
if(res.type===0){
// res.data.messages[]
// res.data.messages[].msg_id
// res.data.messages[].title
// res.data.messages[].content
// res.data.messages[].extras
}else{
// res.data.title
}
});
返回数据
参数名称 | 参数类型 | 参数说明 |
---|---|---|
type | number | |
data | Object | 消息内容 |
Engagelab 通道消息数组(messages)
参数名称 | 参数类型 | 参数说明 |
---|---|---|
msg_id | string | 消息 ID |
title | string | 消息标题 |
content | string | 消息内容 |
extras | Object | 消息附加字段 |
系统通道消息数据
支持 w3c interface NotificationOptions,详见 mdn web docs。
检查推送服务状态
window.MTpushInterface.getPushAuthority()
返回数据结构为如下:
{
mtPush:{
code:1, //1 成功,-1 初始化中,0失败
msg:'成功'
},
webPush:{
code:1, // 0 webpush不可用(浏览器不支持) 1可用 2 权限已被禁用 3 权限没确认
msg:'成功'
}
}
获取浏览器通知权限
window.MTpushInterface.getWebPermission()
返回参数说明
- granted :可用
- denied :禁用
- default:权限没确认
上报自定义消息数据
如需做自定义消息的数据统计,请使用自定义上报接口上报数据。
window.MTpushInterface.customClickReport('msg_id');//msg_id为自定义消息的msg_id
断线监听
接口说明
初始化成功后出现断线,SDK 会自动尝试重连和签名. 建议在初始化前调用此事件监听,收到此事件请重新调用初始化。
window.MTpushInterface.mtPush.onDisconnect(fn)
调用示例
window.MTpushInterface.mtPush.onDisconnect(function () {
});
取消浏览器订阅
取消通知订阅,某些帐号隐私等级较高情况下,退出帐号时不需要通接收知时可使用该方法。
MTpushInterface.unSubscribe();
设置 TagsAlias
window.MTpushInterface.setTagsAlias({})
MTpushInterface.setTagsAlias({ tags: ["test1", "test2"], alias: "aliass" });
参数说明
参数名称 | 参数类型 | 参数说明 |
---|---|---|
tags | string[] | 必填,数组最大长度为 1000,每个元素最多 40 个字符 |
alias | string | 必填,最多 40 个字符 |
接口说明
开发者通过该接口可以设置及删除特定 alias 下的 tags,该接口是覆盖逻辑,通知设置为空串可以删除已有 tags。
多次显示类别提示
window.MTpushInterface.promptPushCategories()
接口说明
在用户订阅推送后,开发者可以根据需要多次显示类别提示,需要在初始化SDK完成后调用。
调用示例:
MTpushInterface.promptPushCategories();
推送消息展示回调
接口说明
建议在初始化前调用消息监听。
调用示例
window.MTpushInterface.onMsgDisplay((msgData) => {});
参数说明
通知消息回调参数 msgData
说明:
{
title: string;
content: string;
msg_id: string;
ntf_or_msg: number;
engagelab_appkey: string;
engagelab_passwd: string;
engagelab_uid: string;
engagelab_url: string;
type: string; // 0:Engagelab 通道消息 1:系统通道消息
}
应用内消息回调参数 msgData
说明:
{
title: string;
content: string;
msg_id: string;
ntf_or_msg: number;
type: string;
}
注意:
1、应用内消息 HTML 编辑模式下,展示回调的参数 title、content 为空字符串
2、safari 浏览器使用系统通道下发消息,无法得到消息的展示回调
推送消息点击回调
接口说明
建议在初始化前调用消息监听。
调用示例
window.MTpushInterface.onMsgClick((msgData) => {});
参数说明
通知消息回调参数 msgData
说明:
{
title: string;
content: string;
msg_id: string;
ntf_or_msg: number;
engagelab_appkey: string;
engagelab_passwd: string;
engagelab_uid: string;
engagelab_url: string;
position: string; // 点击位置,'msgBody' | 按钮的id
type: string; // 0:Engagelab通道消息 1:系统通道消息
}
应用内消息回调参数 msgData
说明:
{
title: string;
content: string;
msg_id: string;
ntf_or_msg: number;
position: 'msgBody' | 'mainBtn' | 'subBtn' | 'closeBtn';
type: string;
}
注意: 1、应用内消息HTML编辑模式,position 的值由开发者决定,点击回调的参数 title、content 为空字符串。 2、safari 浏览器使用系统通道下发消息,无法得到消息的点击回调。
错误码
code | message | 备注 |
---|---|---|
0 | success | 调用成功 |
1000 | unknown error | 未知错误 |
1001 | initing , please try again later | 正在初始化,稍后再试 |
1002 | invalid config | 初始化配置错误 |
1003 | init failed | 初始化失败,详情参考控制台打印 |
1004 | init timeout | 初始化超时 |
1005 | network error | 网络错误,无网络或者连接不上 websocket |