使用 Microsoft Graph 获取团队和频道中成员身份更改的更改通知
更改通知使你能够订阅成员身份更改, (在团队 或私人 频道中创建、更新和删除) 。 每当在团队或专用频道中添加、删除或更新成员时,都可以收到通知。 你还可以在通知中获取资源数据,因此避免调用 API 来获取有效负载。
继续阅读本文,了解团队或频道上下文中的 conversationMember 资源方案。 或者,了解 其他 Microsoft Teams 资源的更改通知。
注意
如果请求的订阅 expirationDateTime 在未来超过 1 小时,则必须通过在订阅请求中包含 lifecycleNotificationUrl 属性来订阅生命周期通知。 否则,订阅请求将失败并显示以下错误消息: 当 expirationDateTime 值设置为大于 1 小时时,lifecycleNotificationUrl 是在此资源上创建订阅所需的属性。
订阅特定团队的成员资格更改
若要获取特定团队中成员资格更改的更改通知,请订阅 /teams/{team-id}/members
。 此资源支持在通知中包括资源数据。
权限
权限类型 | 权限(从最低特权到最高特权) |
---|---|
委派(工作或学校帐户) | TeamMember.Read.All, TeamMember.ReadWrite.All |
委派(个人 Microsoft 帐户) | 不支持。 |
应用程序 | TeamMember.Read.Group*, TeamMember.Read.All, TeamMember.ReadWrite.All |
注意: 带有 * 标记的权限作为 资源特定的许可 的一部分受到支持。
示例
POST https://graph.microsoft.com/v1.0/subscriptions
Content-Type: application/json
{
"changeType": "created,deleted,updated",
"notificationUrl": "https://webhook.azurewebsites.net/api/resourceNotifications",
"resource": "/teams/{team-id}/members",
"includeResourceData": true,
"encryptionCertificate": "{base64encodedCertificate}",
"encryptionCertificateId": "{customId}",
"expirationDateTime": "2019-09-19T11:00:00.0000000Z",
"clientState": "{secretClientState}"
}
订阅租户中所有团队的成员身份更改
若要获取有关租户中所有团队成员身份更改的更改通知,请 /teams/getAllMembers
订阅 。 此资源支持在通知中包括资源数据。
权限
权限类型 | 权限(从最低特权到最高特权) |
---|---|
委派(工作或学校帐户) | 不支持。 |
委派(个人 Microsoft 帐户) | 不支持。 |
应用程序 | TeamMember.Read.All, TeamMember.ReadWrite.All |
示例
POST https://graph.microsoft.com/v1.0/subscriptions
Content-Type: application/json
{
"changeType": "created,deleted,updated",
"notificationUrl": "https://webhook.azurewebsites.net/api/resourceNotifications",
"resource": "/teams/getAllMembers",
"includeResourceData": true,
"encryptionCertificate": "{base64encodedCertificate}",
"encryptionCertificateId": "{customId}",
"expirationDateTime": "2022-08-10T11:00:00.0000000Z",
"clientState": "{secretClientState}"
}
订阅租户中所有频道的成员身份更改 (预览)
若要获取有关租户中所有通道中成员身份更改的更改通知,请 /teams/getAllChannels/getAllMembers
订阅 。 此资源支持在通知中包括资源数据。 目前,仅支持专用频道。 此订阅仅在 beta 终结点中可用。
权限
权限类型 | 权限(从最低特权到最高特权) |
---|---|
委派(工作或学校帐户) | 不支持。 |
委派(个人 Microsoft 帐户) | 不支持。 |
应用程序 | ChannelMember.Read.All、 ChannelMember.ReadWrite.All |
示例
POST https://graph.microsoft.com/beta/subscriptions
Content-Type: application/json
{
"changeType": "created,deleted,updated",
"notificationUrl": "https://webhook.azurewebsites.net/api/resourceNotifications",
"resource": "/teams/getAllChannels/getAllMembers",
"includeResourceData": true,
"encryptionCertificate": "{base64encodedCertificate}",
"encryptionCertificateId": "{customId}",
"expirationDateTime": "2022-08-10T11:00:00.0000000Z",
"clientState": "{secretClientState}"
}
订阅特定团队的所有专用频道和共享频道中的成员身份更改
若要获取特定团队中所有专用频道和共享频道中成员身份更改的更改通知,请 /teams/{team-id}/channels/getAllMembers
订阅 。 此资源支持在通知中包括资源数据。
注意:此 API 具有许可和付款要求。 它支持
model=A
和model=B
查询参数。 如果未指定模型,将使用评估模式。
权限
权限类型 | 权限(从最低特权到最高特权) |
---|---|
委派(工作或学校帐户) | ChannelMember.Read.All。 |
委派(个人 Microsoft 帐户) | 不支持。 |
应用程序 | ChannelMember.Read.All |
示例
POST https://graph.microsoft.com/v1.0/subscriptions
Content-Type: application/json
{
"changeType": "created,deleted,updated",
"notificationUrl": "https://webhook.azurewebsites.net/api/resourceNotifications",
"resource": "/teams/{team-id}/channels/getAllMembers",
"includeResourceData": true,
"encryptionCertificate": "{base64encodedCertificate}",
"encryptionCertificateId": "{customId}",
"expirationDateTime": "2019-09-19T11:00:00.0000000Z",
"clientState": "{secretClientState}"
}
包含资源数据的通知
对于包含资源数据的通知,负载如下所示。 此有效负载用于团队中的成员资格更改。
{
"value": [{
"subscriptionId": "10493aa0-4d29-4df5-bc0c-ef742cc6cd7f",
"changeType": "created",
"clientState": "<<--SpecifiedClientState-->>",
"subscriptionExpirationDateTime": "2021-02-02T10:30:34.9097561-08:00",
"resource": "teams('ee0f5ae2-8bc6-4ae5-8466-7daeebbfa062')/members('ZWUwZjVhZTItOGJjNi00YWU1LTg0NjYtN2RhZWViYmZhMDYyIyM3Mzc2MWYwNi0yYWM5LTQ2OWMtOWYxMC0yNzlhOGNjMjY3Zjk=')",
"resourceData": {
"id": "ZWUwZjVhZTItOGJjNi00YWU1LTg0NjYtN2RhZWViYmZhMDYyIyM3Mzc2MWYwNi0yYWM5LTQ2OWMtOWYxMC0yNzlhOGNjMjY3Zjk=",
"@odata.type": "#Microsoft.Graph.aadUserConversationMember",
"@odata.id": "teams('ee0f5ae2-8bc6-4ae5-8466-7daeebbfa062')/members('ZWUwZjVhZTItOGJjNi00YWU1LTg0NjYtN2RhZWViYmZhMDYyIyM3Mzc2MWYwNi0yYWM5LTQ2OWMtOWYxMC0yNzlhOGNjMjY3Zjk=')"
},
"encryptedContent": {
"data": "<<--EncryptedContent-->",
"dataKey": "<<--EnryptedDataKeyUsedForEncryptingContent-->>",
"encryptionCertificateId": "<<--IdOfTheCertificateUsedForEncryptingDataKey-->>",
"encryptionCertificateThumbprint": "<<--ThumbprintOfTheCertificateUsedForEncryptingDataKey-->>"
},
"tenantId": "<<--TenantForWhichNotificationWasSent-->>"
}],
"validationTokens": ["<<--ValidationTokens-->>"]
}
频道成员资格事件的有效负载与之前的有效负载类似,只不过 资源 属性指向频道成员,而不是团队成员。
有关如何验证令牌和解密负载的详细信息,请参阅设置包含资源数据的更改通知。
解密的通知负载如下所示。 有效负载符合 aaduserconversationmember 架构。 该负载类似于 GET 操作返回的负载。
{
"id": "/ZWUwZjVhZTItOGJjNi00YWU1LTg0NjYtN2RhZWViYmZhMDYyIyM3Mzc2MWYwNi0yYWM5LTQ2OWMtOWYxMC0yNzlhOGNjMjY3Zjk=",
"roles": [
"owner"
],
"displayName": "John Doe",
"userId": "8b081ef6-4792-4def-b2c9-c363a1bf41d5",
"email": null
}
不含资源数据的通知
不含资源数据的通知为你提供了足够的信息来进行 GET 调用以获取消息内容。 没有资源数据的通知订阅不需要加密证书 (,因为 Microsoft Graph 不会) 发送实际资源数据。
对于不包含资源数据的通知,有效负载如下所示。 此有效负载用于团队中的成员资格更改。
{
"subscriptionId": "9f9d1ed0-c9cc-42e7-8d80-a7fc4b0cda3c",
"changeType": "created",
"tenantId": "<<--TenantForWhichNotificationWasSent-->>",
"clientState": "<<--SpecifiedClientState-->>",
"subscriptionExpirationDateTime": "2021-02-02T11:26:41.0537895-08:00",
"resource": "teams('ee0f5ae2-8bc6-4ae5-8466-7daeebbfa062')/members('ZWUwZjVhZTItOGJjNi00YWU1LTg0NjYtN2RhZWViYmZhMDYyIyM3Mzc2MWYwNi0yYWM5LTQ2OWMtOWYxMC0yNzlhOGNjMjY3Zjk=')",
"resourceData": {
"id": "ZWUwZjVhZTItOGJjNi00YWU1LTg0NjYtN2RhZWViYmZhMDYyIyM3Mzc2MWYwNi0yYWM5LTQ2OWMtOWYxMC0yNzlhOGNjMjY3Zjk",
"@odata.type": "#Microsoft.Graph.aadUserConversationMember",
"@odata.id": "teams('ee0f5ae2-8bc6-4ae5-8466-7daeebbfa062')/members('ZWUwZjVhZTItOGJjNi00YWU1LTg0NjYtN2RhZWViYmZhMDYyIyM3Mzc2MWYwNi0yYWM5LTQ2OWMtOWYxMC0yNzlhOGNjMjY3Zjk=')"
}
}
频道成员资格事件的有效负载与之前的有效负载类似,只不过 资源 属性指向频道成员,而不是团队成员。
resource 和 @odata.id 属性可用于对 Microsoft Graph 进行调用以获取消息负载。 GET 调用始终返回消息的当前状态。 如果在发送通知和检索消息之间更改了消息,则操作将返回更新的消息。