Skype For Business
Overview
With this Remote Action, collect information about Skype for Business calls within the last 7 days and calculate metrics for the current day.
Prerequisites
The compatible Skype for Business versions are 2015 and 2016.
The Remote Action gathers all the information about calls from the Skype for Business logs, they are located at:
%LocalAppData%\Microsoft\Office\16.0\Lync\Tracing **For Skype for Business 2016** %LocalAppData%\Microsoft\Office\15.0\Lync\Tracing **For Skype for Business 2015**
Make sure you have FULL or LIGHT logs enabled for Skype for Business, further information in this link.
Input parameters
To a good usage of the Remote Action, set these input parameter values:
Parameter | Description | Value |
---|---|---|
MinSecondsForCall | Minimum number of seconds to consider a call as a short call | 15 |
NumHoursForTimeout | Number of hours to consider an unfinished call as a dropped call | 7 |
CorporateNetworks | Comma-separated list of IPv4 subnets to check if a call was made in a corporate network or externally. They must be listed in CIDR notation. Provide "" to consider all the calls as made out of the office | The proper value depends on your environment configuration |
The first value is useful for identifying calls properly established and dropped by either the caller or the receiver, but whose duration was too short to consider them as "normal" call. It covers the cases when the device is muted, or a wrong audio device was selected and the user has to leave the call and set it up again, etc.
The second parameter is useful for identifying calls established but still in progress or the ones which, due to a Skype for Business crash, don't have the proper termination traces, hence they are never considered as ended. When a call reaches the provided time, they are considered as Dropped with the reason "The call exceed the maximum expected duration".
The third parameter is useful for identifying calls made within the corporate network or externally, to reduce the scope of those users who have problems with their calls.
Desired configuration
Parameter | Value |
---|---|
Schedule time | Hourly. Recommended value to be more accurate and to avoid missing some calls if the user has logged out and hence the Remote Action cannot be executed |
User context | Current interactive user. The Remote Action needs to access data that is stored in the user folder |
Timeout | At least 120 seconds, depending on the size of the logs it may be reduced but this value covers most of the cases |
The Remote Action in detail
The aim of this section is to describe how the Remote Action gets the information from the Skype for Business logs, analyzes the results and categorizes the calls.
How it filters the amount of data to read
At the first execution, the Remote Actions reads all the traces since the midnight up to the current moment. The last execution timestamp is stored in the registry at the property:
HKCU:\Software\Nexthink\Act\SkypeForBusiness\LastExecution
For the following executions, this last execution timestamp is taken as start date to reduce resources and to avoid reading already processed calls. In case of this timestamp is not within the current day, the start time will be the midnight.
Call types
Type | Description |
---|---|
Audio | The most typical call, when a call or a conference is made using computer audio, then it is categorized in this way |
Video | A call or a conference started with video or when the video is activated during them |
Sharing | A call or a conference started by sharing either the screen or a Windows application. If this feature was activated during a video or audio call, it is categorized also as Sharing |
Call results
Type | Description |
---|---|
Unfinished | A call of any type which was established and it is supposed to be in progress during the Remote Action execution |
Rejected | A call of any type which was cancelled by the caller or declined by the receiver before it could be established. This result is not taken into account for the metrics |
FinishedManually | A call of any type which was established and finished manually by the caller or the receiver |
Failed | A call of any type which could not be established, or the destination did not receive, typically due to network issues. The users could not communicate each other because the call was not started, it was only an attempt |
Dropped | A call of any type which was established correctly but due to serious issues, was cancelled. Skype for Business cancelled the communication automatically |
How calls are categorized
To identify calls and process them properly, the Remote Action performs the following steps while it is reading text blocks from the Skype for Business logs.
The text "[xxx]" in the following examples, represents a text that is skipped, it is usually the user identity or email.
It detects the request of a call by getting this message:
INFO :: INVITE [xxx] SIP/2.0
If the gathered block does not have these content types, it is skipped.
application/sdp
multipart/alternative
If the block is taken into consideration, the call mode is identified by these tags for audio, video or screen/application sharing.
m=audio
m=video
m=applicationsharing-video
m=applicationsharing
In case of getting CANCEL or DECLINE blocks, it tries to get the reason of it by checking the value until the first ';' from the ms-client-diagnostics node.
CANCEL [xxx] SIP/2.0
SIP/2.0 [xxx] DECLINE
ms-client-diagnostics: [NUMBER]
If the value of [NUMBER] is 51004, then the call is categorized as Rejected and it does not count for the daily statistics. Otherwise, the call is categorized as Failed.
In case of getting a BYE block, it means that the call was established and initiated.
BYE [xxx] SIP/2.0
If the value obtained from the ms-client-diagnostics node is one of the SKYPE_GOOD_CALL_CODES constant values, then it is categorized as FinishedManually.
Otherwise, the call is categorized as Dropped and the Remote Action tries to get the reason from the ms-client-diagnostics node.
In case of getting the SERVICE block, it contains the VQReport with details about the call and its quality.
SERVICE [xxx] SIP/2.0
When the result of the call is FinishedManually, the quality is measured, categorizing the call as PoorDueTo... in case of any value is over the threshold recommended by Microsoft, otherwise the call is categorized as Good.
Collected metrics/data
The values about the quality call are computed by Skype for Business and stored in the VQReport node within SERVICE trace in the log file. The Remote Action does not perform any calculation.
Those metrics are only available when the result of the call is FinishedManually and depending on the values, the call is categorized as Good or PoorDueTo... and any reason such as RoundTrip, Jitter, and so on.
The data collection is performed as detailed on the following link.
Only the calls for the current day are considered for the metrics calculation.
Nexthink log details
The Nexthink log is the CSV file where the Remote Action stores the calls information for the last 7 days. It is available at this location:
%LOCALAPPDATA%\Nexthink\SkypeForBusiness\nxt_skype_calls.csv
Below, you can see the fields description:
Field | Description |
---|---|
CallId | Id of the call. It is a unique value assigned to all the traces related to the same call |
Type | Type of the call, audio, video or sharing |
Timestamp | Timestamp of the beginning of the call |
FinishTimestamp | Timestamp when the call was finished |
Duration | Duration in seconds of the call |
DurationUnderMinimumTime | Whether the duration of the call was under the minimum desired to consider a call has a "normal" duration or not |
Result | How the call was ended |
Quality | Good or poor due to any reason |
OverWiFi | Whether the call was made over Wi-Fi network or not |
IpAddress | Public IP address of the network |
Corporate | Whether the call was made within a network categorized as corporate or not |
BadResultReason | Reason of the issue in case of the call had any |