Teams Analytics

  1. Teams Analytics Tab
  2. Teams Analytics And Reports Powershell

Re: Teams Call Analytics/Call history Well, everyone in a call has plenty of inbound and outbound streams for audio, video, screensharing and video based screen sharing. I guess audio was not the issue for your case, but likely video was the problem. The secrets of highly successful data analytics teams Effective data teams bring diverse, cross-functional skill sets to bear on clearly defined business priorities — without losing sight of the value of experimentation and ongoing education. Also, having a good sense of the different types of analytics techniques will help you frame who you need on the team. Analytics is defined as, the systematic computational analysis of data or statistics. Analytics is the umbrella for — data visualization (dashboards), EDA, machine learning, AI, etc. Core Analytics / data mining methods.


In my previous blog post, I wrote about the new Teams activity policy templates in Cloud App Security. A great addition to easily keep an eye on your teams. Let’s take a short look a the policies before we continue. The policies will create alerts when:

  • a team’s access level is changed from private to public
  • an external user is added to a team
  • a user deletes a large number of teams

These templates are easy to use, and will only take a couple of minutes to configure. But what if you don’t have the licenses for Cloud App Security? Is an (expensive) E5 license your only way out? Let’s get this straight. As a cloud (security) consultant it is not my main job to cross- or upsell organizations’ licenses. Sometimes you have to be creative. Spending a lot of money on products that you not fully utilize, is money down the drain. Let’s see if I can create the same alerts without the use of Cloud App Security.

I used Log Analytics and Azure Monitor alerts to create three equivalent polices. This is also to show you what’s possible. This can be used in many, many use cases. Today, we focus on Microsoft Teams, just like the new activity policies in Cloud App Security.

Requirements & pricing

For the use of Log Analytics, you’ll need a subscription. The good thing about Log Analytics pricing is that you can choose for a pay-as-you-go pricing model. You pay for data ingestion and retention. The first 5 GB data ingestion is free and you can send up to a thousand alerts without charge. As you create your workspace, you’ll have a good overview of your estimated costs and the amount of data is handled. I suggest you take a look at this page for further details on pricing.

Teams analytics no data available

Log Analytics

To start off, if you don’t have a Log Analytics Workspace yet, please create one. Choose your pricing tier and region in the wizard.

Next, we’ll make sure that our Azure AD audit data is sent to Log Analytics. In order to that, head over to Azure Active Directory -> Diagnostic settings and choose + Add diagnostic setting

For this example, we just need our audit logs, but you can choose to push both audit and sign-in data to your workspace. Sign-in logs require additional licenses. For now, we just need the audit logs.

Alert rules

Now that the data is stored in Log Analytics, we can go on and create our alert rules. Head over to your Log Analytics workspace and go to Alerts. Next, choose + New alert rule to create our first rule.


Let’s start with the rule to detect if a Team is changed from private to public. The steps for the remaining policies are almost the same. An overview of all the setting is listed below.

For our condition, we use a Custom log search.

In the search query field, add the following (KQL) query:

In this example, I filtered out most of the output and narrowed it down to a few columns, so that your alert mail will be much cleaner. In this example, I only parse the date and name of the activity, the team that is changed, and the display name and UPN of the user that changed it. Of course, you can change this to whatever your needs are. For now, we leave it like this.

Next, choose the alert logic and the interval for this query. I want my alert to kick off at 1 or more results. The query has to run every 60 minutes. Take note of the “count” parameter that is added at the end of your query. This is automatically added because we use the alert logic “number of results”. Basically, we’re just counting events and trigger the alert when the threshold is reached.

Again, you can change this if you want this to run more or less frequent.

Now we have configured our query, we have to select an action. Assuming this is your first Action Group, we are going to create a new one. Otherwise, just pick your existing action group. In this example, I create an action group to alert my OPS team using Email

To create the rule, pick a name and description for your alert, and select the severity level you want. You can also choose to suppress the alerts or adjust the email subject if you want.

Now that we created our first alert, we can continue and create the remaining two alerts. Because the steps are almost the same, I give you an overview of the settings I used.

Alert emails

To give you an idea, this is how an alert email will look like. The email will show an overview of the alert query and the top 10 results.

Let’s wrap up

This blog post will give you an idea of what is possible with Log Analytics, KQL queries, and Azure Monitor Alert rules. This is the most basic setup, but keep in mind that you can search for any event and trigger any workload. You can kick off workbooks, playbooks, Power Automate Flows, webhooks, Logic Apps, Azure Functions, and so on. The sky is the limit here.

In this example, we only used the audit logs, but you can ingest any data into Log Analytics and query for results. If you want more information, start reading here. Before this blog post, I had never written any KQL queries. So just get started and see how far you can come.

Teams Analytics Tab

Teams Analytics

Also, hopefully this will give you ideas on what is possible, even if you don’t have proper licenses or budget for security products.

Teams Analytics And Reports Powershell

Stay safe!