例如
如果我想听两个
'eventFilters' => array(
"/restapi/v1.0/account/~/extension/~/presence?detailedTelephonyState=true&aggregate=true",
"/restapi/v1.0/account/~/extension/~/message-store/instant?type=SMS"
如果我想过滤和分析这两个事件,我是否应该对RingCentral的每个帖子请求进行切换?
说..
switch($eventid){
case '/restapi/v1.0/account/<accountid>/extension/<extension>/presence?detailedTelephonyState=true&aggregate=true'
//process data
break;
}
但是webhook帖子有不同的扩展名。是否有触发了哪个事件的标识符?
答案 0 :(得分:2)
我可以通过几种方式来解决您提出的问题......
webhook.event
URI并匹配字符串类型可能是最快的,然后路由到特定的通知事件输入处理程序。webhook.body
是否具有所需的属性。 PHP中的3号(未经测试的代码)
$instantMessageEventTypeKeys = array('id', 'to', 'from', 'type', 'creationTime', 'lastModifiedTime', 'readStatus', 'priority', 'attachments', 'direction', 'availability', 'subject', 'messageStatus', 'conversationid');
function genericNotificationHandler($eventJson) {
$eventObj = json_decode($eventJson, true);
foreach($instantMessageEventTypeKeys) {
// If the event.body keys match, route to
if(arrayKeys(eventObj=>['body']) === $instantMessageEventType)) {
//Call some instantMessageSpecificEventHandler($eventObj);
}
}
}
JavaScript中的第3位(未经测试的代码)
// Instant Message Notification Event Type properties
const instantMessageEventTypeKeys = ['id', 'to', 'from', 'type', 'creationTime', 'lastModifiedTime', 'readStatus', 'priority', 'attachments', 'direction', 'availability', 'subject', 'messageStatus', 'conversationid']
const proxyHandlers = {
get (target, key) {
if ('notificationEventType' === key[0]) {
let targetKeys = target.body.ownKeys.sort().join(',');
if(targetKeys === instantMessageEventTypeKeys.sort().join(',')) return 'Instant Message'
}
}
}
const genericNotificationHandler = (notificationData) => {
// You could create traps in handlers below to simplify further
let pEvent = new Proxy(notificationData, proxyHandlers);
if('Instant Message' === pEvent.notificationEventType) {
// instantMessageSpecificEventHandler(notificationData)
}
}
答案 1 :(得分:0)
以Ben的第一种方法为基础:
如果您在多个扩展上有多个eventFilter的单个订阅,正如您所说,过滤传入的
webhook.event
URI并匹配字符串类型可能是最快的,然后路由到特定的通知事件输入处理程序。
webhook有效负载将如下所示。 event
属性将指示正在触发的事件类型,您的应用可以使用该属性启动差异化处理。我在下方使用了空body
,但在实际帖子中,它将填充特定于该事件类型的主体。
{
"uuid":"12345678901234567890",
"event":"/restapi/v1.0/glip/posts",
"timestamp":"2018-05-01T16:39:41.693Z",
"subscriptionId":"11112222-3333-4444-5555-666677778888",
"ownerId":"11111111",
"body":{}
}
在Go community SDK go-ringcentral
中,我开始构建一个返回事件类型的函数,给定事件字符串:
ParseEventTypeForFilter(eventFilter string) (EventType, error) {
这是一个事件类型列表:
const(
AccountPresenceEvent EventType = iota
ContactDirectoryEvent
DetailedExtensionPresenceEvent
DetailedExtensionPresenceWithSIPEvent
ExtensionFavoritesEvent
ExtensionFavoritesPresenceEvent
ExtensionGrantListEvent
ExtensionListEvent
ExtensionInfoEvent
ExtensionPresenceEvent
ExtensionPresenceLineEvent
GlipGroupsEvent
GlipPostEvent
GlipUnreadMessageCountEvent
InboundMessageEvent
IncomingCallEvent
InstantMessageEvent
MessageEvent
MissedCallEvent
RCVideoNotificationsEvent
SubscriptionRenewalEvent
)
代码:https://github.com/grokify/go-ringcentral/blob/master/clientutil/event_filter.go