Skip to main content

Meeting Events

Microsoft Teams provides meeting events that allow your application to respond to various meeting lifecycle changes. Your app can listen to events like when a meeting starts, meeting ends, and participant activities to create rich, interactive experiences.

Overview​

Meeting events enable your application to:

  • Send notifications when meetings start or end
  • Track participant activity (join/leave events)
  • Display relevant information or cards based on meeting context
  • Integrate with meeting workflows

Configuring Your Bot​

There are a few requirements in the Teams app manifest (manifest.json) to support these events.

  1. The scopes section must include team, and groupChat
bots": [
{
"botId": "",
"scopes": [
"team",
"personal",
"groupChat"
],
"isNotificationOnly": false
}
]
  1. In the authorization section, make sure to specify the following resource-specific permissions:
 "authorization":{
"permissions":{
"resourceSpecific":[
{
"name":"OnlineMeetingParticipant.Read.Chat",
"type":"Application"
},
{
"name":"ChannelMeeting.ReadBasic.Group",
"type":"Application"
},
{
"name":"OnlineMeeting.ReadBasic.Chat",
"type":"Application"
}
]
}
}
  1. In the Teams Developer Portal, for your Bot, make sure the Meeting Event Subscriptions are checked off. This enables you to receive the Meeting Participant events. For these events, you must create your Bot via TDP.

Meeting Start Event​

When a meeting starts, your app can handle the meetingStart event to send a notification or card to the meeting chat.

using Microsoft.Teams.Apps;
using Microsoft.Teams.Apps.Activities;
using Microsoft.Teams.Apps.Activities.Events;
using Microsoft.Teams.Cards;

// Register meeting start handler
teamsApp.OnMeetingStart(async context =>
{
var activity = context.Activity.Value;
var startTime = activity.StartTime.ToLocalTime();

var card = new AdaptiveCard
{
Schema = "http://adaptivecards.io/schemas/adaptive-card.json",
Body = new List<CardElement>
{
new TextBlock($"'{activity.Title}' has started at {startTime}.")
{
Wrap = true,
Weight = TextWeight.Bolder
}
},
Actions = new List<Microsoft.Teams.Cards.Action>
{
new OpenUrlAction(activity.JoinUrl)
{
Title = "Join the meeting",
}
}
};

await context.Send(card);
});

Meeting End Event​

When a meeting ends, your app can handle the meetingEnd event to send a summary or follow-up information.

using Microsoft.Teams.Apps;
using Microsoft.Teams.Apps.Activities;
using Microsoft.Teams.Apps.Activities.Events;
using Microsoft.Teams.Cards;

// Register meeting end handler
teamsApp.OnMeetingEnd(async context =>
{
var activity = context.Activity.Value;
var endTime = activity.EndTime.ToLocalTime();

var card = new AdaptiveCard
{
Schema = "http://adaptivecards.io/schemas/adaptive-card.json",
Body = new List<CardElement>
{
new TextBlock($"'{activity.Title}' has ended at {endTime}.")
{
Wrap = true,
Weight = TextWeight.Bolder
}
}
};

await context.Send(card);
});

Participant Join Event​

When a participant joins a meeting, your app can handle the meetingParticipantJoin event to welcome them or display their role.

using Microsoft.Teams.Apps;
using Microsoft.Teams.Apps.Activities;
using Microsoft.Teams.Apps.Activities.Events;
using Microsoft.Teams.Cards;

// Register participant join handler
teamsApp.OnMeetingJoin(async context =>
{
var activity = context.Activity.Value;
var member = activity.Members[0].User.Name;
var role = activity.Members[0].Meeting.Role;

var card = new AdaptiveCard
{
Schema = "http://adaptivecards.io/schemas/adaptive-card.json",
Body = new List<CardElement>
{
new TextBlock($"{member} has joined the meeting as {role}.")
{
Wrap = true,
Weight = TextWeight.Bolder
}
}
};

await context.Send(card);
});

Participant Leave Event​

When a participant leaves a meeting, your app can handle the meetingParticipantLeave event to notify others.

using Microsoft.Teams.Apps;
using Microsoft.Teams.Apps.Activities;
using Microsoft.Teams.Apps.Activities.Events;
using Microsoft.Teams.Cards;

// Register participant leave handler
teamsApp.OnMeetingLeave(async context =>
{
var activity = context.Activity.Value;
var member = activity.Members[0].User.Name;

var card = new AdaptiveCard
{
Schema = "http://adaptivecards.io/schemas/adaptive-card.json",
Body = new List<CardElement>
{
new TextBlock($"{member} has left the meeting.")
{
Wrap = true,
Weight = TextWeight.Bolder
}
}
};

await context.Send(card);
});