Reduzir assinaturas ausentes e alterar notificações
Durante a duração de uma subscrição, o Microsoft Graph envia tipos especiais de notificações para o ciclo de vida especificadoNotificationUrl para sinalizar a ação necessária. Estas notificações são denominadas notificações de ciclo de vida e ajudam-no a minimizar o risco de falta de subscrições e de notificações de alteração.
Existem três tipos de notificações de ciclo de vida:
- reauthorizationRequired notifications (reautorização) Notificações necessárias
- Notificações removidas da subscrição
- notificações perdidas
Se ignorar estes eventos, este poderá interromper o fluxo de notificação de alteração; pode processar os eventos ao implementar lógica na sua aplicação para retomar um fluxo de notificação de alteração contínua.
Este artigo apresenta notificações de ciclo de vida nas notificações de alteração do Microsoft Graph e fornece orientações para lidar com as notificações.
Recursos com suporte
Embora possa fornecer um ciclo de vidaNotificationUrl ao criar uma subscrição em qualquer tipo de recurso, as notificações de ciclo de vida são atualmente suportadas apenas para os seguintes tipos de recursos.
- reauthorizationRequired notifications - All resources (reauthorizationRequired notifications - All resources)
- subscriptionRemoved notifications - Outlook message, Outlook event, Outlook personal contact, Teams chatMessage
- notificações perdidas – Mensagem do Outlook, evento do Outlook, contacto pessoal do Outlook
Configurar a sua subscrição para receber notificações de ciclo de vida
Para receber notificações de ciclo de vida, tem de fornecer um ponto final de lifecycleNotificationUrl válido ao criar a subscrição. O seguinte pedido de criação de subscrição define os pontos finais notificationUrl e lifecycleNotificationUrl .
POST https://graph.microsoft.com/v1.0/subscriptions
Content-Type: application/json
{
"changeType": "created,updated",
"notificationUrl": "https://webhook.azurewebsites.net/api/resourceNotifications",
"lifecycleNotificationUrl": "https://webhook.azurewebsites.net/api/lifecycleNotifications",
"resource": "/users/{id}/messages",
"expirationDateTime": "2020-03-20T11:00:00.0000000Z",
"clientState": "<secretClientState>"
}
O ponto final lifecycleNotificationUrl pode ser o mesmo que o notificationUrl.
As subscrições existentes sem a propriedade lifecycleNotificationUrl não recebem as notificações de ciclo de vida. Também não pode adicionar a propriedade lifecycleNotificationUrl a uma subscrição existente ao atualizar a subscrição. Para adicionar a propriedade lifecycleNotificationUrl , tem de eliminar a subscrição existente e criar uma nova subscrição ao especificar a propriedade durante a criação da subscrição.
Ao utilizar o canal de entrega de webhooks, tem de validar os pontos finais de lifecycleNotificationUrl e notificationUrl.
Estrutura de uma notificação de ciclo de vida
Um payload de notificação de ciclo de vida segue a estrutura do objeto changeNotificationCollection e o objeto changeNotification relacionado da seguinte forma:
{
"value": [
{
"subscriptionId":"<subscription_guid>",
"subscriptionExpirationDateTime":"2019-03-20T11:00:00.0000000Z",
"tenantId": "<tenant_guid>",
"clientState":"<secretClientState>",
"lifecycleEvent": "subscriptionRemoved or missed or reauthorizationRequired"
}
]
}
Em que o ciclo de vidaEvento pode ser subscriptionRemoved
, missed
ou reauthorizationRequired
, a representar os tipos de notificação do ciclo de vida.
Uma notificação de ciclo de vida não contém informações sobre um recurso específico, porque não está relacionada com uma alteração de recursos, mas sim com a alteração do estado da subscrição. À semelhança das notificações de alteração, as notificações de ciclo de vida podem ser agrupadas em conjunto e recebidas como uma coleção, cada uma com um valor de ciclo de vida Possivelmente diferenteEvento . Processe cada notificação de ciclo de vida no lote adequadamente.
Quando processa a notificação de ciclo de vida e retoma o fluxo de notificações de alteração, as notificações de alteração começam a fluir para o notificationUrl.
reauthorizationRequired notifications (reautorização) Notificações necessárias
reauthorizationRequired
Os eventos de ciclo de vida alertam-no quando o Microsoft Graph requer que a aplicação reautorize a subscrição, por exemplo, nos seguintes casos:
- Quando o token de acesso está prestes a expirar.
- Quando uma subscrição está prestes a expirar.
- Quando um administrador tiver revogado as permissões da sua aplicação para ler um recurso.
Antes de qualquer uma destas condições se tornar verdadeira, o Microsoft Graph envia um desafio de autorização para o ciclo de vidaNotificationUrl.
O seguinte exemplo de código ilustra como o serviço de notificações de alteração do Microsoft Graph pode calcular o intervalo destas notificações.
//The following code is for illustrative purposes only
var TokenTimeToExpirationInMinutes=(TokenExpirationTime-CurrentTime)/4;
if((TokenTimeToExpirationInMinutes)<=180 && TokenTimeToExpirationInMinutes>60){
//Microsoft Graph will send reauthorizationRequired notification
TokenTimeToExpirationInMinutes=TokenTimeToExpirationInMinutes/2;
}
elseif(TokenTimeToExpirationInMinutes<60 && TokenTimeToExpirationInMinutes>=0){
//Microsoft Graph will send reauthorizationRequired notification every 15 mins
TokenTimeToExpirationInMinutes=TokenTimeToExpirationInMinutes-15;
} else {
//Microsoft Graph will stop sending reauthorizationRequired notifications
}
As etapas a seguir representam o fluxo de um desafio de autorização para uma assinatura ativa:
O Microsoft Graph exige que uma assinatura seja autorizada novamente.
Os motivos podem variar de recurso para recurso e podem mudar ao longo do tempo. Para manter a subscrição, tem de responder a um evento de reautorização, independentemente da causa.
O Microsoft Graph envia uma notificação de desafio de autorização para lifecycleNotificationUrl.
O fluxo de notificações de alteração pode continuar durante algum tempo, dando-lhe tempo extra para responder. No entanto, eventualmente a alteração na entrega de notificação fará uma pausa até você executar a ação necessária. Quaisquer notificações sobre alterações de recursos que ocorram quando a entrega da notificação de alteração é interrompida e a hora em que a aplicação cria a subscrição novamente com êxito são perdidas. Nestes casos, a aplicação deve obter separadamente essas alterações, por exemplo, utilizando a consulta delta.
Respondendo a notificações reauthorizationRequired
Confirme a receção da notificação de ciclo de vida ao responder à chamada POST com
202 - Accepted
o código de resposta.Valide a autenticidade da notificação do ciclo de vida.
Certifique-se de que o aplicativo tenha um token de acesso válido para a próxima etapa.
Chamar uma das duas APIs a seguir. Se a chamada da API for bem-sucedida, o fluxo de notificação de mudança será retomado.
Chame a ação
/reauthorize
para reautorizar a subscrição sem prolongar a data de expiração.POST https://graph.microsoft.com/v1.0/subscriptions/{id}/reauthorize
Execute a operação de atualização para reautorizar e renovar a subscrição ao mesmo tempo.
PATCH https://graph.microsoft.com/v1.0/subscriptions/{id} Content-Type: application/json { "expirationDateTime": "2019-09-21T11:00:00.0000000Z" }
A renovação poderá falhar se a aplicação já não estiver autorizada a aceder ao recurso. Em seguida, poderá ser necessário que a aplicação obtenha um novo token de acesso para reautorizar uma subscrição com êxito.
Você pode tentar essa ações mais tarde, a qualquer momento e obter êxito se as condições de acesso mudarem.
Informações adicionais
Os desafios de autorização não substituem a necessidade de renovar uma subscrição antes de esta expirar. Os ciclos de vida dos tokens de acesso e da expiração da subscrição não são os mesmos. O token de acesso pode expirar antes da sua subscrição. É importante estar preparado para reautorizar regularmente o ponto final para atualizar o token de acesso. Reautorizar o ponto final não renova a sua subscrição. No entanto, renovar a sua subscrição também reautoriza o ponto final.
A frequência dos desafios de autorização está sujeita a mudanças.
Não assuma a frequência dos desafios de autorização. Estas notificações de ciclo de vida indicam-lhe quando deve tomar medidas, impedindo-o de controlar quais as subscrições que necessitam de reautorização. Esteja pronto para lidar com desafios de autorização a cada poucos minutos para cada subscrição raramente para algumas das suas subscrições.
subscriptionRemoved notifications (notificações subscriptionRemoved)
subscriptionRemoved
Os eventos de ciclo de vida alertam-no quando o Microsoft Graph removeu uma subscrição. Nesses casos, se quiser continuar a receber notificações de alteração para o recurso relacionado, terá de recriar a subscrição.
Mesmo que tenha uma subscrição de longa duração, as condições de acesso aos dados dos recursos podem mudar ao longo do tempo. Por exemplo, pode ocorrer um evento no serviço que requer que a aplicação reautentica o utilizador. Nesse caso, o Microsoft Graph envia-lhe uma notificação subscriptionRemoved .
O fluxo seguinte mostra o fluxo de um evento subscriptionRemoved :
O serviço detecta que uma assinatura precisa ser removida do Microsoft Graph.
Não há cadência definida para estes eventos. Eles podem ocorrer com frequência para alguns recursos e quase nunca para outros.
O Microsoft Graph envia uma notificação
subscriptionRemoved
de ciclo de vida para lifecycleNotificationUrl (se especificado).Não existem notificações de ciclo de vida disponíveis a partir do período em que a
subscriptionRemoved
notificação de ciclo de vida foi enviada para quando a aplicação recria a subscrição com êxito. A aplicação tem de obter essas alterações por si só.
Responder a notificações subscriptionRemoved
Confirme a receção da notificação de ciclo de vida ao responder à chamada POST com
202 - Accepted
o código de resposta.Valide a autenticidade da notificação do ciclo de vida.
Certifique-se de que o aplicativo tenha um token de acesso válido para a próxima etapa.
Crie uma nova assinatura.
Esta ação pode falhar porque as verificações de autorização realizadas pelo sistema podem negar o acesso da aplicação ao recurso. Poderá ser necessário que a aplicação obtenha um novo token de acesso para reautorizar uma subscrição com êxito. Pode repetir estas ações mais tarde, em qualquer altura; por exemplo, quando as condições de acesso mudam.
Depois de criar a nova subscrição, pode sincronizar os dados do recurso para identificar as notificações de alteração perdidas; por exemplo, com a consulta delta.
notificações perdidas
missed
Os eventos de ciclo de vida alertam-no de que algumas notificações de alteração não foram entregues. Por exemplo, devido à limitação.
Responder notificações perdidas
- Confirme a receção da notificação de ciclo de vida ao responder à chamada POST com
202 - Accepted
o código de resposta. - Valide a autenticidade da notificação do ciclo de vida.
- Execute uma ressincronização de dados completa do recurso para identificar as alterações que não foram entregues como notificações; por exemplo, com a consulta delta.