From 18f54fb75b091ad57c840da3016f3d013fbd18f5 Mon Sep 17 00:00:00 2001 From: zihzhan <43592314+zihzhan@users.noreply.github.com> Date: Fri, 29 May 2020 18:06:47 -0700 Subject: [PATCH] Update public Sample bot doc (#240) --- .../StatelessSamples/GroupCallBot.sln | 38 + .../StatelessSamples/GroupCallBot/Bot/Bot.cs | 360 +++ .../GroupCallBot/Bot/BotOptions.cs | 35 + .../Controllers/ControllerConstants.cs | 18 + .../Controllers/HomeController.cs | 89 + .../ParticipantsCallingController.cs | 59 + .../Controllers/PlatformCallController.cs | 42 + .../Data/ParticipantsCallingRequestData.cs | 26 + .../Extensions/BotBuilderExtensions.cs | 39 + .../Extensions/ControllerExtentions.cs | 73 + .../GroupCallBot/Extensions/HttpExtensions.cs | 72 + .../GroupCallBot/GroupCallBot.csproj | 25 + .../StatelessSamples/GroupCallBot/Program.cs | 31 + .../Properties/launchSettings.json | 28 + .../StatelessSamples/GroupCallBot/README.md | 107 + .../StatelessSamples/GroupCallBot/Startup.cs | 63 + .../GroupCallBot/appsettings.json | 16 + .../StatelessSamples/ReminderBot.sln | 38 + .../StatelessSamples/ReminderBot/Bot/Bot.cs | 463 ++++ .../ReminderBot/Bot/BotOptions.cs | 35 + .../Controllers/ControllerConstants.cs | 18 + .../ReminderBot/Controllers/HomeController.cs | 89 + .../Controllers/PlatformCallController.cs | 42 + .../Controllers/UsersController.cs | 59 + .../ReminderBot/Data/UserRequestData.cs | 25 + .../Extensions/BotBuilderExtensions.cs | 39 + .../Extensions/ControllerExtentions.cs | 73 + .../ReminderBot/Extensions/HttpExtensions.cs | 72 + .../StatelessSamples/ReminderBot/Program.cs | 27 + .../Properties/launchSettings.json | 28 + .../StatelessSamples/ReminderBot/README.md | 98 + .../ReminderBot/ReminderBot.csproj | 26 + .../StatelessSamples/ReminderBot/Startup.cs | 61 + .../ReminderBot/appsettings.json | 16 + .../ReminderBot/wwwroot/audio/reminder.wav | Bin 0 -> 189890 bytes .../StatelessSamples/SimpleIvrBot/README.md | 173 +- .../VoiceRecorderAndPlaybackBot/README.md | 153 +- docs/articles/Logging.html | 4 +- docs/articles/Testing.html | 2 +- docs/articles/calls/appHostedMediaCalls.html | 8 +- docs/articles/calls/register-calling-bot.html | 15 +- docs/articles/index.html | 10 +- docs/index.html | 2 +- docs/index.json | 2422 ++++++++--------- docs/manifest.json | 64 +- .../app-studio-app-details-app-id.png | Bin 0 -> 81520 bytes .../app-studio-connect-to-a-bot-id.png | Bin 0 -> 15660 bytes .../app-studio-connect-to-bot-id.png | Bin 0 -> 15660 bytes 48 files changed, 3776 insertions(+), 1407 deletions(-) create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot.sln create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Bot/Bot.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Bot/BotOptions.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/ControllerConstants.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/HomeController.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/ParticipantsCallingController.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/PlatformCallController.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Data/ParticipantsCallingRequestData.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/BotBuilderExtensions.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/ControllerExtentions.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/HttpExtensions.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/GroupCallBot.csproj create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Program.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Properties/launchSettings.json create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/README.md create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/Startup.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/GroupCallBot/appsettings.json create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot.sln create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Bot/Bot.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Bot/BotOptions.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/ControllerConstants.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/HomeController.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/PlatformCallController.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/UsersController.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Data/UserRequestData.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/BotBuilderExtensions.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/ControllerExtentions.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/HttpExtensions.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Program.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Properties/launchSettings.json create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/README.md create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/ReminderBot.csproj create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/Startup.cs create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/appsettings.json create mode 100644 Samples/V1.0Samples/StatelessSamples/ReminderBot/wwwroot/audio/reminder.wav create mode 100644 docs/resources/app-studio-app-details-app-id.png create mode 100644 docs/resources/app-studio-connect-to-a-bot-id.png create mode 100644 docs/resources/app-studio-connect-to-bot-id.png diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot.sln b/Samples/V1.0Samples/StatelessSamples/GroupCallBot.sln new file mode 100644 index 00000000..a3e5f65a --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot.sln @@ -0,0 +1,38 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 16 +VisualStudioVersion = 16.0.29911.84 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "GroupCallBot", "GroupCallBot\GroupCallBot.csproj", "{5F7C79C6-4A38-4B76-B34F-18E8A2CB6046}" +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Sample.Common", "..\..\Common\Sample.Common\Sample.Common.csproj", "{F303240C-2CC3-43B5-A048-1ECEF27DBC8B}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{0439C2B1-EFF3-4576-82B6-4A8DC35B484D}" + ProjectSection(SolutionItems) = preProject + ..\..\configure_cloud.ps1 = ..\..\configure_cloud.ps1 + ..\..\Graph.props = ..\..\Graph.props + ..\..\nuget.config = ..\..\nuget.config + EndProjectSection +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {5F7C79C6-4A38-4B76-B34F-18E8A2CB6046}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {5F7C79C6-4A38-4B76-B34F-18E8A2CB6046}.Debug|Any CPU.Build.0 = Debug|Any CPU + {5F7C79C6-4A38-4B76-B34F-18E8A2CB6046}.Release|Any CPU.ActiveCfg = Release|Any CPU + {5F7C79C6-4A38-4B76-B34F-18E8A2CB6046}.Release|Any CPU.Build.0 = Release|Any CPU + {F303240C-2CC3-43B5-A048-1ECEF27DBC8B}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {F303240C-2CC3-43B5-A048-1ECEF27DBC8B}.Debug|Any CPU.Build.0 = Debug|Any CPU + {F303240C-2CC3-43B5-A048-1ECEF27DBC8B}.Release|Any CPU.ActiveCfg = Release|Any CPU + {F303240C-2CC3-43B5-A048-1ECEF27DBC8B}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {4F2B3912-5AC8-47F6-8CD1-1F7200EE10D4} + EndGlobalSection +EndGlobal diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Bot/Bot.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Bot/Bot.cs new file mode 100644 index 00000000..192c4b1e --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Bot/Bot.cs @@ -0,0 +1,360 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Bot +{ + using System; + using System.Collections.Generic; + using System.Diagnostics; + using System.Linq; + using System.Net; + using System.Net.Http; + using System.Net.Http.Headers; + using System.Threading.Tasks; + using Microsoft.AspNetCore.Http; + using Microsoft.AspNetCore.Http.Extensions; + using Microsoft.Extensions.Primitives; + using Microsoft.Graph; + using Microsoft.Graph.Communications.Client.Authentication; + using Microsoft.Graph.Communications.Client.Transport; + using Microsoft.Graph.Communications.Common; + using Microsoft.Graph.Communications.Common.Telemetry; + using Microsoft.Graph.Communications.Common.Transport; + using Microsoft.Graph.Communications.Core.Notifications; + using Microsoft.Graph.Communications.Core.Serialization; + using Newtonsoft.Json; + using Sample.Common; + using Sample.Common.Authentication; + using Sample.Common.Transport; + using Sample.GroupCallBot.Data; + using Sample.GroupCallBot.Controller; + using Sample.GroupCallBot.Extensions; + + /// + /// The core bot class. + /// + public class Bot + { + private readonly Uri botBaseUri; + + private readonly string appId; + + /// + /// Initializes a new instance of the class. + /// + /// The bot options. + /// The graph logger. + public Bot(BotOptions options, IGraphLogger graphLogger) + { + this.botBaseUri = options.BotBaseUrl; + this.appId = options.AppId; + + this.GraphLogger = graphLogger; + var name = this.GetType().Assembly.GetName().Name; + this.AuthenticationProvider = new AuthenticationProvider(name, options.AppId, options.AppSecret, graphLogger); + this.Serializer = new CommsSerializer(); + + var authenticationWrapper = new AuthenticationWrapper(this.AuthenticationProvider); + this.NotificationProcessor = new NotificationProcessor(authenticationWrapper, this.Serializer); + this.NotificationProcessor.OnNotificationReceived += this.NotificationProcessor_OnNotificationReceived; + this.RequestBuilder = new GraphServiceClient(options.PlaceCallEndpointUrl.AbsoluteUri, authenticationWrapper); + + // Add the default headers used by the graph client. + // This will include SdkVersion. + var defaultProperties = new List>>(); + using (HttpClient tempClient = GraphClientFactory.Create(authenticationWrapper)) + { + defaultProperties.AddRange(tempClient.DefaultRequestHeaders.Select(header => GraphProperty.RequestProperty(header.Key, header.Value))); + } + + // graph client + var productInfo = new ProductInfoHeaderValue( + typeof(Bot).Assembly.GetName().Name, + typeof(Bot).Assembly.GetName().Version.ToString()); + this.GraphApiClient = new GraphAuthClient( + this.GraphLogger, + this.Serializer.JsonSerializerSettings, + new HttpClient(), + this.AuthenticationProvider, + productInfo, + defaultProperties); + } + + /// + /// Gets graph logger. + /// + public IGraphLogger GraphLogger { get; } + + /// + /// Gets the authentication provider. + /// + private IRequestAuthenticationProvider AuthenticationProvider { get; } + + /// + /// Gets the notification processor. + /// + private INotificationProcessor NotificationProcessor { get; } + + /// + /// Gets the URI builder. + /// + private GraphServiceClient RequestBuilder { get; } + + /// + /// Gets the serializer. + /// + private CommsSerializer Serializer { get; } + + /// + /// Gets the stateless graph client. + /// + private IGraphClient GraphApiClient { get; } + + /// + /// Bot calls users. + /// + /// Input data. + /// The . + public async Task BotCallsUsersAsync(ParticipantsCallingRequestData participantsCallingRequestData) + { + Guid scenarioId = Guid.NewGuid(); + ParticipantInfo source = new ParticipantInfo + { + Identity = new IdentitySet + { + Application = new Identity + { + Id = this.appId, + }, + }, + }; + + Call requestCall = new Call + { + Source = source, + Targets = new List(), + MediaConfig = new ServiceHostedMediaConfig { }, + RequestedModalities = new List { Modality.Audio }, + TenantId = participantsCallingRequestData.TenantId, + Direction = CallDirection.Outgoing, + CallbackUri = new Uri(this.botBaseUri, ControllerConstants.CallbackPrefix).ToString(), + }; + + List listTargets = new List(); + foreach (string userId in participantsCallingRequestData.ObjectIds) + { + InvitationParticipantInfo target = new InvitationParticipantInfo + { + Identity = new IdentitySet + { + User = new Identity + { + Id = userId, + }, + } + }; + listTargets.Add(target); + } + requestCall.Targets = listTargets; + var callRequest = this.RequestBuilder.Communications.Calls; + var request = new GraphRequest(new Uri(callRequest.RequestUrl), requestCall, RequestType.Create); + var response = await this.GraphApiClient.SendAsync(request, requestCall.TenantId, scenarioId).ConfigureAwait(false); + Call responseMeetingCall = response.Content; + this.GraphLogger.Log( + TraceLevel.Verbose, + $"Bot called users {participantsCallingRequestData.ObjectIds}, the responded state is {responseMeetingCall?.State}"); + } + + + /// + /// Processes the notification asynchronously. + /// Here we make sure we log the http request and catch/log any errors. + /// + /// The request. + /// The response. + /// The . + public async Task ProcessNotificationAsync( + HttpRequest request, + HttpResponse response) + { + // TODO: Parse out the scenario id and request id headers. + var headers = request.Headers.Select( + pair => new KeyValuePair>(pair.Key, pair.Value)); + + // Don't log content since we can't PII scrub here (we don't know the type). + var stopwatch = new Stopwatch(); + stopwatch.Start(); + this.GraphLogger.LogHttpMessage( + TraceLevel.Verbose, + TransactionDirection.Incoming, + HttpTraceType.HttpRequest, + request.GetDisplayUrl(), + request.Method, + obfuscatedContent: null, + headers: headers); + + try + { + var httpRequest = request.CreateRequestMessage(); + var results = await this.AuthenticationProvider.ValidateInboundRequestAsync(httpRequest).ConfigureAwait(false); + if (results.IsValid) + { + var httpResponse = await this.NotificationProcessor.ProcessNotificationAsync(httpRequest).ConfigureAwait(false); + await httpResponse.CreateHttpResponseAsync(response).ConfigureAwait(false); + } + else + { + var httpResponse = httpRequest.CreateResponse(HttpStatusCode.Forbidden); + await httpResponse.CreateHttpResponseAsync(response).ConfigureAwait(false); + } + + headers = response.Headers.Select( + pair => new KeyValuePair>(pair.Key, pair.Value)); + + this.GraphLogger.LogHttpMessage( + TraceLevel.Verbose, + TransactionDirection.Incoming, + HttpTraceType.HttpResponse, + request.GetDisplayUrl(), + request.Method, + obfuscatedContent: null, + headers: headers, + responseCode: response.StatusCode, + responseTime: stopwatch.ElapsedMilliseconds); + } + catch (ServiceException e) + { + string obfuscatedContent = null; + if ((int)e.StatusCode >= 300) + { + response.StatusCode = (int)e.StatusCode; + await response.WriteAsync(e.ToString()).ConfigureAwait(false); + obfuscatedContent = this.GraphLogger.SerializeAndObfuscate(e, Formatting.Indented); + } + else if ((int)e.StatusCode >= 200) + { + response.StatusCode = (int)e.StatusCode; + } + else + { + response.StatusCode = (int)e.StatusCode; + await response.WriteAsync(e.ToString()).ConfigureAwait(false); + obfuscatedContent = this.GraphLogger.SerializeAndObfuscate(e, Formatting.Indented); + } + + headers = response.Headers.Select( + pair => new KeyValuePair>(pair.Key, pair.Value)); + + if (e.ResponseHeaders?.Any() == true) + { + foreach (var pair in e.ResponseHeaders) + { + response.Headers.Add(pair.Key, new StringValues(pair.Value.ToArray())); + } + + headers = headers.Concat(e.ResponseHeaders); + } + + this.GraphLogger.LogHttpMessage( + TraceLevel.Error, + TransactionDirection.Incoming, + HttpTraceType.HttpResponse, + request.GetDisplayUrl(), + request.Method, + obfuscatedContent, + headers, + response.StatusCode, + responseTime: stopwatch.ElapsedMilliseconds); + } + catch (Exception e) + { + response.StatusCode = (int)HttpStatusCode.InternalServerError; + await response.WriteAsync(e.ToString()).ConfigureAwait(false); + + var obfuscatedContent = this.GraphLogger.SerializeAndObfuscate(e, Formatting.Indented); + headers = response.Headers.Select( + pair => new KeyValuePair>(pair.Key, pair.Value)); + + this.GraphLogger.LogHttpMessage( + TraceLevel.Error, + TransactionDirection.Incoming, + HttpTraceType.HttpResponse, + request.GetDisplayUrl(), + request.Method, + obfuscatedContent, + headers, + response.StatusCode, + responseTime: stopwatch.ElapsedMilliseconds); + } + } + + /// + /// Raised when the has received a notification. + /// + /// The instance containing the event data. + private void NotificationProcessor_OnNotificationReceived(NotificationEventArgs args) + { +#pragma warning disable 4014 + // Processing notification in the background. + // This ensures we're not holding on to the request. + this.NotificationProcessor_OnNotificationReceivedAsync(args).ForgetAndLogExceptionAsync( + this.GraphLogger, + $"Error processing notification {args.Notification.ResourceUrl} with scenario {args.ScenarioId}"); +#pragma warning restore 4014 + } + + /// + /// Raised when the has received a notification asynchronously. + /// + /// The instance containing the event data. + /// The . + private async Task NotificationProcessor_OnNotificationReceivedAsync(NotificationEventArgs args) + { + this.GraphLogger.CorrelationId = args.ScenarioId; + var headers = new[] + { + new KeyValuePair>(HttpConstants.HeaderNames.ScenarioId, new[] { args.ScenarioId.ToString() }), + new KeyValuePair>(HttpConstants.HeaderNames.ClientRequestId, new[] { args.RequestId.ToString() }), + new KeyValuePair>(HttpConstants.HeaderNames.Tenant, new[] { args.TenantId }), + }; + + // Create obfuscation content to match what we + // would have gotten from the service, then log. + var notifications = new CommsNotifications { Value = new[] { args.Notification } }; + var obfuscatedContent = this.GraphLogger.SerializeAndObfuscate(notifications, Formatting.Indented); + this.GraphLogger.LogHttpMessage( + TraceLevel.Info, + TransactionDirection.Incoming, + HttpTraceType.HttpRequest, + args.CallbackUri.ToString(), + HttpMethods.Post, + obfuscatedContent, + headers, + correlationId: args.ScenarioId, + requestId: args.RequestId); + + if (args.ResourceData is Call call) + { + if (call.State == CallState.Established && call.MediaState?.Audio == MediaState.Active) + { + this.GraphLogger.Log(TraceLevel.Info, $"Call State:{call.State}"); + } + else if (args.ChangeType == ChangeType.Deleted && call.State == CallState.Terminated) + { + this.GraphLogger.Log(TraceLevel.Info, $"Call State:{call.State}"); + } + } + else if (args.Notification.ResourceUrl.EndsWith("/participants") && args.ResourceData is List participantObjects) + { + this.GraphLogger.Log(TraceLevel.Info, "Total count of participants found in this roster is " + participantObjects.Count()); + foreach (var participantObject in participantObjects) + { + var participant = participantObject as Participant; + this.GraphLogger.Log(TraceLevel.Info, "Id: " + participant?.Info?.Identity?.User?.Id.ToString(), "DisplayName: " + participant?.Info?.Identity?.User?.DisplayName.ToString()); + } + } + } + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Bot/BotOptions.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Bot/BotOptions.cs new file mode 100644 index 00000000..3738eae8 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Bot/BotOptions.cs @@ -0,0 +1,35 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Bot +{ + using System; + + /// + /// The bot options class. + /// + public class BotOptions + { + /// + /// Gets or sets the application id. + /// + public string AppId { get; set; } + + /// + /// Gets or sets the application secret. + /// + public string AppSecret { get; set; } + + /// + /// Gets or sets the calls uri of the application. + /// + public Uri BotBaseUrl { get; set; } + + /// + /// Gets or sets the comms platform endpoint uri. + /// + public Uri PlaceCallEndpointUrl { get; set; } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/ControllerConstants.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/ControllerConstants.cs new file mode 100644 index 00000000..0b34e8d4 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/ControllerConstants.cs @@ -0,0 +1,18 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Controller +{ + /// + /// Http route constants for routing requests. + /// + public class ControllerConstants + { + /// + /// Route prefix for all incoming requests. + /// + public const string CallbackPrefix = "/callback"; + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/HomeController.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/HomeController.cs new file mode 100644 index 00000000..20a08376 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/HomeController.cs @@ -0,0 +1,89 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Controller +{ + using Microsoft.AspNetCore.Mvc; + using Sample.Common.Logging; + + /// + /// The home controller class. + /// + public class HomeController : Controller + { + private readonly SampleObserver observer; + + /// + /// Initializes a new instance of the class. + /// + /// The observer. + public HomeController(SampleObserver observer) + { + this.observer = observer; + } + + /// + /// Get the default content of home page. + /// + /// Default content. + [HttpGet("/")] + public string Get() + { + return "Home Page"; + } + + /// + /// Get the service logs. + /// + /// Skip specified lines. + /// Take specified lines. + /// The logs. + [HttpGet] + [Route("/logs")] + public IActionResult GetLogs( + [FromQuery] int skip = 0, + [FromQuery] int take = 1000) + { + this.AddRefreshHeader(3); + return this.Content( + this.observer.GetLogs(skip, take), + System.Net.Mime.MediaTypeNames.Text.Plain, + System.Text.Encoding.UTF8); + } + + /// + /// Get the service logs. + /// + /// The filter. + /// Skip specified lines. + /// Take specified lines. + /// + /// The logs. + /// + [HttpGet] + [Route("/logs/{filter}")] + public IActionResult GetLogs( + string filter, + [FromQuery] int skip = 0, + [FromQuery] int take = 1000) + { + this.AddRefreshHeader(3); + return this.Content( + this.observer.GetLogs(filter, skip, take), + System.Net.Mime.MediaTypeNames.Text.Plain, + System.Text.Encoding.UTF8); + } + + /// + /// Add refresh headers for browsers to download content. + /// + /// Refresh rate. + private void AddRefreshHeader(int seconds) + { + this.Response.Headers.Add("Cache-Control", "private,must-revalidate,post-check=1,pre-check=2,no-cache"); + this.Response.Headers.Add("Refresh", seconds.ToString()); + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/ParticipantsCallingController.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/ParticipantsCallingController.cs new file mode 100644 index 00000000..919a26a3 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/ParticipantsCallingController.cs @@ -0,0 +1,59 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Controller +{ + using System; + using System.Threading.Tasks; + using Microsoft.AspNetCore.Mvc; + using Sample.Common.Logging; + using Sample.GroupCallBot.Bot; + using Sample.GroupCallBot.Data; + using Sample.GroupCallBot.Extensions; + using Microsoft.Graph.Communications.Common; + + /// + /// The incidents controller class. + /// + [Route("participantscalling")] + public class ParticipantsCallingController : Controller + { + private Bot bot; + + /// + /// Initializes a new instance of the class. + /// + /// The bot. + public ParticipantsCallingController(Bot bot, SampleObserver observer) + { + this.bot = bot; + } + + /// + /// Raise a request to call participants. + /// + /// The incident data. + /// The action result. + /// + [HttpPost("raise")] + public async Task PostNotificationsAsync([FromBody] ParticipantsCallingRequestData participantsCallingRequestData) + { + try + { + Validator.NotNull(participantsCallingRequestData, nameof(participantsCallingRequestData), "participantsCallingRequestData is Null."); + Validator.NotNull(participantsCallingRequestData.ObjectIds, nameof(participantsCallingRequestData.ObjectIds), "Object Ids are Null or Whitespace."); + Validator.NotNullOrWhitespace(participantsCallingRequestData.TenantId, nameof(participantsCallingRequestData.TenantId), "Tenant Id is Null or Whitespace."); + + await this.bot.BotCallsUsersAsync(participantsCallingRequestData).ConfigureAwait(false); + + return this.Ok("Bot got a notification to call group of users."); + } + catch (Exception e) + { + return this.Exception(e); + } + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/PlatformCallController.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/PlatformCallController.cs new file mode 100644 index 00000000..b4b8db77 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Controllers/PlatformCallController.cs @@ -0,0 +1,42 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Controller +{ + using System.Threading.Tasks; + using Microsoft.AspNetCore.Mvc; + using Microsoft.Graph.Communications.Common.Telemetry; + using Sample.GroupCallBot.Bot; + + /// + /// Entry point for handling call-related web hook requests. + /// + public class PlatformCallController : Controller + { + private readonly IGraphLogger graphLogger; + private readonly Bot bot; + + /// + /// Initializes a new instance of the class. + /// + /// The bot. + public PlatformCallController(Bot bot) + { + this.bot = bot; + this.graphLogger = bot.GraphLogger.CreateShim(nameof(PlatformCallController)); + } + + /// + /// Handle call back for bot calls user case. + /// + /// returns when task is done. + [HttpPost] + [Route(ControllerConstants.CallbackPrefix)] + public async Task OnIncomingBotCallUserRequestAsync() + { + await this.bot.ProcessNotificationAsync(this.Request, this.Response).ConfigureAwait(false); + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Data/ParticipantsCallingRequestData.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Data/ParticipantsCallingRequestData.cs new file mode 100644 index 00000000..921a961f --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Data/ParticipantsCallingRequestData.cs @@ -0,0 +1,26 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Data +{ + using System; + using System.Collections.Generic; + + /// + /// The participants request data. + /// + public class ParticipantsCallingRequestData + { + /// + /// Gets or sets the notified user object ids. + /// + public IEnumerable ObjectIds { get; set; } + + /// + /// Gets or sets the tenant id. + /// + public string TenantId { get; set; } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/BotBuilderExtensions.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/BotBuilderExtensions.cs new file mode 100644 index 00000000..b6df7a54 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/BotBuilderExtensions.cs @@ -0,0 +1,39 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Microsoft.Extensions.DependencyInjection +{ + using System; + using Sample.GroupCallBot.Bot; + + /// + /// The bot builder extensions class. + /// + public static class BotBuilderExtensions + { + /// + /// Add bot feature. + /// + /// The service collection. + /// The updated service collection. + public static IServiceCollection AddBot(this IServiceCollection services) + => services.AddBot(_ => { }); + + /// + /// Add bot feature. + /// + /// The service collection. + /// The action for bot options. + /// The updated service collection. + public static IServiceCollection AddBot(this IServiceCollection services, Action botOptionsAction) + { + var options = new BotOptions(); + botOptionsAction(options); + services.AddSingleton(options); + + return services.AddSingleton(); + } + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/ControllerExtentions.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/ControllerExtentions.cs new file mode 100644 index 00000000..01508b7f --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/ControllerExtentions.cs @@ -0,0 +1,73 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Extensions +{ + using System; + using System.Linq; + using System.Net; + using System.Net.Http.Headers; + using Microsoft.AspNetCore.Http; + using Microsoft.AspNetCore.Mvc; + using Microsoft.Extensions.Primitives; + using Microsoft.Graph; + + /// + /// The controller exceptions. + /// + public static class ControllerExtentions + { + /// + /// Convert exception to action result. + /// + /// The controller. + /// The exception. + /// The action result. + public static IActionResult Exception(this Controller controller, Exception exception) + { + IActionResult result; + + if (exception is ServiceException e) + { + controller.HttpContext.Response.CopyHeaders(e.ResponseHeaders); + + int statusCode = (int)e.StatusCode; + + result = statusCode >= 300 + ? controller.StatusCode(statusCode, e.ToString()) + : controller.StatusCode((int)HttpStatusCode.InternalServerError, e.ToString()); + } + else + { + result = controller.StatusCode((int)HttpStatusCode.InternalServerError, exception.ToString()); + } + + return result; + } + + /// + /// Copy the response headers to controller.HttpContext.Response. + /// + /// The controller. + /// The headers. + private static void CopyHeaders(this HttpResponse response, HttpHeaders headers) + { + if (headers == null) + { + // do nothing as the source headers are null. + return; + } + + foreach (var header in headers) + { + var values = header.Value?.ToArray(); + if (values?.Any() == true) + { + response.Headers.Add(header.Key, new StringValues(values)); + } + } + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/HttpExtensions.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/HttpExtensions.cs new file mode 100644 index 00000000..5a2a192e --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Extensions/HttpExtensions.cs @@ -0,0 +1,72 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.GroupCallBot.Extensions +{ + using System; + using System.Net.Http; + using System.Threading.Tasks; + using Microsoft.AspNetCore.Http; + using Microsoft.AspNetCore.Http.Extensions; + + /// + /// Extensions for ASP.NET HTTP request and response. + /// + public static class HttpExtensions + { + /// + /// Creates the request message asynchronous. + /// + /// The request. + /// The . + public static HttpRequestMessage CreateRequestMessage(this HttpRequest request) + { + var displayUri = request.GetDisplayUrl(); + var httpRequest = new HttpRequestMessage + { + RequestUri = new Uri(displayUri), + Method = new HttpMethod(request.Method), + }; + + if (request.ContentLength.HasValue && request.ContentLength.Value > 0) + { + httpRequest.Content = new StreamContent(request.Body); + } + + // Copy headers + foreach (var header in request.Headers) + { + httpRequest.Headers.TryAddWithoutValidation(header.Key, header.Value.ToArray()); + } + + return httpRequest; + } + + /// + /// Creates the HTTP response. + /// + /// The response. + /// The HTTP response. + /// The populated . + public static async Task CreateHttpResponseAsync(this HttpResponseMessage response, HttpResponse httpResponse) + { + httpResponse.StatusCode = (int)response.StatusCode; + + if (response.Content != null) + { + var content = await response.Content.ReadAsStringAsync().ConfigureAwait(false); + await httpResponse.WriteAsync(content).ConfigureAwait(false); + } + + // Copy headers + foreach (var header in response.Headers) + { + response.Headers.Add(header.Key, header.Value); + } + + return httpResponse; + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/GroupCallBot.csproj b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/GroupCallBot.csproj new file mode 100644 index 00000000..125247c0 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/GroupCallBot.csproj @@ -0,0 +1,25 @@ + + + + netcoreapp2.1 + + + + + + + + + + + + + + + + + + + + + diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Program.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Program.cs new file mode 100644 index 00000000..3be2b699 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Program.cs @@ -0,0 +1,31 @@ +using Microsoft.AspNetCore; +using Microsoft.AspNetCore.Hosting; +using Microsoft.Extensions.Configuration; +using Microsoft.Extensions.Hosting; +using Microsoft.Extensions.Logging; +using Sample.GroupCallBot.Data; +using Microsoft.Graph.Communications.Core.Serialization; +using System.Collections.Generic; + +namespace Sample.GroupCallBot +{ + public class Program + { + + public static void Main(string[] args) + { + CreateHostBuilder(args).Build().Run(); + } + + public static IWebHostBuilder CreateHostBuilder(string[] args) => + WebHost.CreateDefaultBuilder(args) + .ConfigureLogging((hostingContext, logging) => + { + logging.AddConfiguration(hostingContext.Configuration.GetSection("Logging")); + logging.AddDebug(); + logging.AddConsole(); + logging.AddAzureWebAppDiagnostics(); + }) + .UseStartup(); + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Properties/launchSettings.json b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Properties/launchSettings.json new file mode 100644 index 00000000..53025401 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Properties/launchSettings.json @@ -0,0 +1,28 @@ +{ + "$schema": "http://json.schemastore.org/launchsettings.json", + "iisSettings": { + "windowsAuthentication": false, + "anonymousAuthentication": true, + "iisExpress": { + "applicationUrl": "http://localhost:2404", + "sslPort": 44390 + } + }, + "profiles": { + "IIS Express": { + "commandName": "IISExpress", + "launchBrowser": true, + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + }, + "GroupCallBot": { + "commandName": "Project", + "launchBrowser": true, + "applicationUrl": "https://localhost:5001;http://localhost:5000", + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/README.md b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/README.md new file mode 100644 index 00000000..e4f18c3d --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/README.md @@ -0,0 +1,107 @@ +# Introduction +The sample demostrates calling a group of users. + +# Sample status + 1. A team of engineers use the Group Call Bot to call all of them at once, if any issue needing their attention occurs. + 2. An incident occurs and the Group Call Bot creates a group call to all the members of the team. + 3. The Group Call Bot uses the participants update notification to keep track of the participants of the call. + 4. The incident is handled and the call ends. + +# Installation process + 1. Enable an Azure subscription to host web sites and bot services. + 2. Install Visual Studio 2017 + 3. Launch GroupCallBot.sln in \Samples\V1.0Samples\StatelessSamples with Visual Studio 2017 (VS2017) + 4. Click menu Build/"Build Solution" to build the whole solution + 5. Create an BotService in an Azure subscription with Azure Portal (https://portal.azure.com), then enable both Teams & Skype channels on the Azure portal, and configure the calling Uri of the bot. + * Go to "Bot Services" resource type page, click "Add", select "Bot Channels Registration", click "Create", then follow the instructions. + - Write down the application ID **\{ApplicationId}** and **\{ApplicationSecret}** for next steps. + - Type "GroupCallBot" in "Bot Handle" under "Bot Services", fill rest fields like Resource Group. Pricing Tier as per the requirement and click "Create". + * Under "Bot Services" click "GroupCallBot", Click "Channels", Then select "Microsoft Teams" channel and enable it with next step. + - Click "Calling" tab, select "Enable calling" check box, then fill the "Webhook (for calling)" edit box with value "\{BotBaseUrl}/callback". Click "Save". + 6. Configure permissions for the Bot. + * Go to the Azure Portal (https://portal.azure.com). + * Select your registered bot application, in this case "GroupCallBot", click "Settings" --> "Manage" and then click "API Permissions". + * Click "Add a Permission", click "Microsoft Graph" --> Application Permissions. + * Select all permissions starting with "Calls.", i.e. "Calls.IntiateGroupCalls.All" etc. + * Click "Ok" and then "Save". + 7. Consent the permissions + * Go to "https://login.microsoftonline.com/common/adminconsent?client_id=&state=&redirect_uri=" + * Sign in with a tenant admin + * Consent for the whole tenant. + +# Getting Started (Azure Version) + 1. Installation process + * Create web site in Azure + - Right click V1.0Samples/StatelessSamples/GroupCallBot/"Connected Services" and select "Add Connected Service" in project GroupCallBot in VS2017, then select Publish tab, and click "Create new profile" to lauch a dialog + - Select "App Service" then click "Create New" radio button, then click "Publish" button to create a App Service and publish the code on. + - Write down the web site root uri **\{BotBaseUrl}** for next steps. + + * Update the following elements in appsettings.json file in project GroupCallBot. + - Bot/AppId: "**\{ApplicationId}**" + - Bot/AppSecret: "**\{ApplicationSecret}**" + - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + + * Publish the application again. + - Right click GroupCallBot/"Connected Services" and select "Add Connected Service" in project GroupCallBot in VS2017, click "Publish" button. + + 2. Update process + * Update code properly. + * Publish the application again. + + 3. Software dependencies + * Nuget packages list are in \\Dependencies\Nuget in Solution Explorer of Visual Studio 2017 + + 4. API references + +# Getting Started (Local Run Version) + 1. Installation process + * Install Visual Studio 2017 + * Launch CommsSamples.sln in \Samples with Visual Studio 2017 (VS2017) + * Click menu Build/"Build Solution" to build the whole solution + * Setup ngrok. + - Sign up for a free ngrok account. Once signed up, go to the ngrok [dashboard](https://dashboard.ngrok.com/) and get your auth token. + - Create an ngrok configuration file `ngrok.yml` as follows: + ```yaml + authtoken: %replace_with_auth_token_from_dashboard% + tunnels: + signaling: + addr: 9442 + proto: http + media: + addr: 8445 + proto: tcp + ``` + - Start ngrok: `ngrok http https://localhost:44379 -host-header=localhost`. You will see an output like this: + ```ymal + Session Status online + Account YourName (Plan: Free) + Version x.x.xx + Region United States (us) + Web Interface http://127.0.0.1:4040 + Forwarding http://e6c2321a.ngrok.io -> https://localhost:44379 + Forwarding https://e6c2321a.ngrok.io -> https://localhost:44379 + ``` + - From **your** output, in line Forwarding (yours will be different) the first url`https://e6c2321a.ngrok.io` will be your bot base uri. Write down the bot base uri as **\{BotBaseUrl}** for next steps. + * Update the following elements in appsettings.json file in project GroupCallBot. + - Bot/AppId: "**\{ApplicationId}**" + - Bot/AppSecret: "**\{ApplicationSecret}**" + - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + +# Build and Test + 1. Get the users' object IDs as \{UserObjectId-1} for user1, \{UserObjectId-2} for user2 and \{UserObjectId-3} for user3, to all the group call needs to be made. + + 2. Login to Teams client with all the list of users, for the scenario in order to get call from the Bot. + + 3. Open "Postman", create a Post request --> {BotBaseUrl}/participantscalling/raise and then add objectIds and tenantId in Body (like mentioned below). Click on Send. + { + "objectIds": [ + "{UserObjectId-1}", + "{UserObjectId-2}", + "{UserObjectId-3}" + ], + "tenantId": "{TenantId}" + } + + 4. Bot will call all the users. + + 5. Logs will have the list of participants, updated as and when user will accept the group call. \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Startup.cs b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Startup.cs new file mode 100644 index 00000000..b67685cb --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/Startup.cs @@ -0,0 +1,63 @@ +using Microsoft.AspNetCore.Builder; +using Microsoft.AspNetCore.Hosting; +using Microsoft.AspNetCore.Mvc; +using Microsoft.Extensions.Configuration; +using Microsoft.Extensions.DependencyInjection; +using Microsoft.Extensions.Logging; +using Microsoft.Graph.Communications.Common.Telemetry; +using Sample.Common.Logging; +using System.Collections.Generic; +using System.Linq; + +namespace Sample.GroupCallBot +{ + public class Startup + { + private readonly GraphLogger logger; + private readonly SampleObserver observer; + + public Startup(IConfiguration configuration) + { + this.Configuration = configuration; + this.logger = new GraphLogger(typeof(Startup).Assembly.GetName().Name); + this.observer = new SampleObserver(this.logger); + } + + public IConfiguration Configuration { get; } + + // This method gets called by the runtime. Use this method to add services to the container. + public void ConfigureServices(IServiceCollection services) + { + services + .AddSingleton(this.observer) + .AddSingleton(this.logger); + + services + .AddBot(options => this.Configuration.Bind("Bot", options)) + .AddMvc() + .SetCompatibilityVersion(CompatibilityVersion.Latest); + } + + /// + /// This method gets called by the runtime. Use this method to configure the HTTP request pipeline. + /// + /// App builder. + /// Hosting environment. + /// /// The logger of ILogger instance. + public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) + { + this.logger.BindToILoggerFactory(loggerFactory); + + if (env.IsDevelopment()) + { + app.UseDeveloperExceptionPage(); + } + + app.UseHttpsRedirection(); + app.UseStaticFiles(); + app.UseCookiePolicy(); + + app.UseMvc(); + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/GroupCallBot/appsettings.json b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/appsettings.json new file mode 100644 index 00000000..fa4119d8 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/GroupCallBot/appsettings.json @@ -0,0 +1,16 @@ +{ + "Logging": { + "IncludeScopes": false, + "LogLevel": { + "Default": "Information", + "System": "Information", + "Microsoft": "Information" + } + }, + "Bot": { + "AppId": "%AppId%", + "AppSecret": "%AppSecret%", + "PlaceCallEndpointUrl": "https://graph.microsoft.com/v1.0", + "BotBaseUrl": "%ServiceDns%" + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot.sln b/Samples/V1.0Samples/StatelessSamples/ReminderBot.sln new file mode 100644 index 00000000..c5af4976 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot.sln @@ -0,0 +1,38 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 16 +VisualStudioVersion = 16.0.29911.84 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ReminderBot", "ReminderBot\ReminderBot.csproj", "{A35F2F12-819C-4273-A638-041354602472}" +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Sample.Common", "..\..\Common\Sample.Common\Sample.Common.csproj", "{5090294F-CB3A-41A5-9305-A9B37144E776}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{F3BB982C-D128-495B-819B-48B993B03437}" + ProjectSection(SolutionItems) = preProject + ..\..\configure_cloud.ps1 = ..\..\configure_cloud.ps1 + ..\..\Graph.props = ..\..\Graph.props + ..\..\nuget.config = ..\..\nuget.config + EndProjectSection +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {A35F2F12-819C-4273-A638-041354602472}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {A35F2F12-819C-4273-A638-041354602472}.Debug|Any CPU.Build.0 = Debug|Any CPU + {A35F2F12-819C-4273-A638-041354602472}.Release|Any CPU.ActiveCfg = Release|Any CPU + {A35F2F12-819C-4273-A638-041354602472}.Release|Any CPU.Build.0 = Release|Any CPU + {5090294F-CB3A-41A5-9305-A9B37144E776}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {5090294F-CB3A-41A5-9305-A9B37144E776}.Debug|Any CPU.Build.0 = Debug|Any CPU + {5090294F-CB3A-41A5-9305-A9B37144E776}.Release|Any CPU.ActiveCfg = Release|Any CPU + {5090294F-CB3A-41A5-9305-A9B37144E776}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {2AECF7BE-7B72-4F9D-A960-47AEC1EF6358} + EndGlobalSection +EndGlobal diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Bot/Bot.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Bot/Bot.cs new file mode 100644 index 00000000..fa856a39 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Bot/Bot.cs @@ -0,0 +1,463 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Bot +{ + using System; + using System.Collections.Generic; + using System.Diagnostics; + using System.Linq; + using System.Net; + using System.Net.Http; + using System.Net.Http.Headers; + using System.Threading.Tasks; + using Microsoft.AspNetCore.Http; + using Microsoft.AspNetCore.Http.Extensions; + using Microsoft.Extensions.Primitives; + using Microsoft.Graph; + using Microsoft.Graph.Communications.Client.Authentication; + using Microsoft.Graph.Communications.Client.Transport; + using Microsoft.Graph.Communications.Common; + using Microsoft.Graph.Communications.Common.Telemetry; + using Microsoft.Graph.Communications.Common.Transport; + using Microsoft.Graph.Communications.Core.Notifications; + using Microsoft.Graph.Communications.Core.Serialization; + using Newtonsoft.Json; + using Sample.Common; + using Sample.Common.Authentication; + using Sample.Common.Transport; + using Sample.ReminderBot.Data; + using Sample.ReminderBot.Controller; + using Sample.ReminderBot.Extensions; + using Microsoft.Graph.Communications.Client; + + /// + /// The core bot class. + /// + public class Bot + { + private readonly Uri botBaseUri; + private string appId; + + /// + /// Initializes a new instance of the class. + /// + /// The bot options. + /// The graph logger. + public Bot(BotOptions options, IGraphLogger graphLogger) + { + this.botBaseUri = options.BotBaseUrl; + this.appId = options.AppId; + + this.GraphLogger = graphLogger; + var name = this.GetType().Assembly.GetName().Name; + this.AuthenticationProvider = new AuthenticationProvider(name, options.AppId, options.AppSecret, graphLogger); + this.Serializer = new CommsSerializer(); + + var authenticationWrapper = new AuthenticationWrapper(this.AuthenticationProvider); + this.NotificationProcessor = new NotificationProcessor(authenticationWrapper, this.Serializer); + this.NotificationProcessor.OnNotificationReceived += this.NotificationProcessor_OnNotificationReceived; + this.RequestBuilder = new GraphServiceClient(options.PlaceCallEndpointUrl.AbsoluteUri, authenticationWrapper); + + // Add the default headers used by the graph client. + // This will include SdkVersion. + var defaultProperties = new List>>(); + using (HttpClient tempClient = GraphClientFactory.Create(authenticationWrapper)) + { + defaultProperties.AddRange(tempClient.DefaultRequestHeaders.Select(header => GraphProperty.RequestProperty(header.Key, header.Value))); + } + + // graph client + var productInfo = new ProductInfoHeaderValue( + typeof(Bot).Assembly.GetName().Name, + typeof(Bot).Assembly.GetName().Version.ToString()); + this.GraphApiClient = new GraphAuthClient( + this.GraphLogger, + this.Serializer.JsonSerializerSettings, + new HttpClient(), + this.AuthenticationProvider, + productInfo, + defaultProperties); + } + + /// + /// Gets graph logger. + /// + public IGraphLogger GraphLogger { get; } + + /// + /// Gets the authentication provider. + /// + public IRequestAuthenticationProvider AuthenticationProvider { get; } + + /// + /// Gets the notification processor. + /// + public INotificationProcessor NotificationProcessor { get; } + + /// + /// Gets the URI builder. + /// + public GraphServiceClient RequestBuilder { get; } + + /// + /// Gets the serializer. + /// + public CommsSerializer Serializer { get; } + + /// + /// Gets the stateless graph client. + /// + public IGraphClient GraphApiClient { get; } + + /// + /// Bot calls users. + /// + /// Input data. + /// The . + public async Task BotCallsUsersAsync(UserRequestData userRequestData) + { + var scenarioId = Guid.NewGuid(); + + var eventsExist = await this.GetEventsInNextHour(userRequestData.ObjectId, userRequestData.TenantId, scenarioId).ConfigureAwait(false); + + if (eventsExist != null) + { + var requestCall = new Call + { + Source = new ParticipantInfo + { + Identity = new IdentitySet + { + Application = new Identity + { + Id = this.appId, + }, + }, + }, + Targets = new List() + { + new InvitationParticipantInfo + { + Identity = new IdentitySet + { + User = new Identity + { + Id = userRequestData.ObjectId, + }, + } + } + }, + MediaConfig = new ServiceHostedMediaConfig() + { + PreFetchMedia = new List() + { + new MediaInfo() + { + Uri = new Uri(this.botBaseUri, "audio/reminder.wav").ToString(), + ResourceId = Guid.NewGuid().ToString(), + } + } + }, + RequestedModalities = new List { Modality.Audio }, + TenantId = userRequestData.TenantId, + Direction = CallDirection.Outgoing, + CallbackUri = new Uri(this.botBaseUri, ControllerConstants.CallbackPrefix).ToString(), + }; + + var callRequest = this.RequestBuilder.Communications.Calls; + var request = new GraphRequest(new Uri(callRequest.RequestUrl), requestCall, RequestType.Create); + await this.GraphApiClient.SendAsync(request, requestCall.TenantId, scenarioId).ConfigureAwait(false); + } + } + + /// + /// Processes the notification asynchronously. + /// Here we make sure we log the http request and + /// catch/log any errors. + /// + /// The request. + /// The response. + /// The . + public async Task ProcessNotificationAsync( + HttpRequest request, + HttpResponse response) + { + // TODO: Parse out the scenario id and request id headers. + var headers = request.Headers.Select( + pair => new KeyValuePair>(pair.Key, pair.Value)); + + // Don't log content since we can't PII scrub here (we don't know the type). + var stopwatch = new Stopwatch(); + stopwatch.Start(); + this.GraphLogger.LogHttpMessage( + TraceLevel.Verbose, + TransactionDirection.Incoming, + HttpTraceType.HttpRequest, + request.GetDisplayUrl(), + request.Method, + obfuscatedContent: null, + headers: headers); + + try + { + var httpRequest = request.CreateRequestMessage(); + var results = await this.AuthenticationProvider.ValidateInboundRequestAsync(httpRequest).ConfigureAwait(false); + if (results.IsValid) + { + var httpResponse = await this.NotificationProcessor.ProcessNotificationAsync(httpRequest).ConfigureAwait(false); + await httpResponse.CreateHttpResponseAsync(response).ConfigureAwait(false); + } + else + { + var httpResponse = httpRequest.CreateResponse(HttpStatusCode.Forbidden); + await httpResponse.CreateHttpResponseAsync(response).ConfigureAwait(false); + } + + headers = response.Headers.Select( + pair => new KeyValuePair>(pair.Key, pair.Value)); + + this.GraphLogger.LogHttpMessage( + TraceLevel.Verbose, + TransactionDirection.Incoming, + HttpTraceType.HttpResponse, + request.GetDisplayUrl(), + request.Method, + obfuscatedContent: null, + headers: headers, + responseCode: response.StatusCode, + responseTime: stopwatch.ElapsedMilliseconds); + } + catch (ServiceException e) + { + string obfuscatedContent = null; + if ((int)e.StatusCode >= 300) + { + response.StatusCode = (int)e.StatusCode; + await response.WriteAsync(e.ToString()).ConfigureAwait(false); + obfuscatedContent = this.GraphLogger.SerializeAndObfuscate(e, Formatting.Indented); + } + else if ((int)e.StatusCode >= 200) + { + response.StatusCode = (int)e.StatusCode; + } + else + { + response.StatusCode = (int)e.StatusCode; + await response.WriteAsync(e.ToString()).ConfigureAwait(false); + obfuscatedContent = this.GraphLogger.SerializeAndObfuscate(e, Formatting.Indented); + } + + headers = response.Headers.Select( + pair => new KeyValuePair>(pair.Key, pair.Value)); + + if (e.ResponseHeaders?.Any() == true) + { + foreach (var pair in e.ResponseHeaders) + { + response.Headers.Add(pair.Key, new StringValues(pair.Value.ToArray())); + } + + headers = headers.Concat(e.ResponseHeaders); + } + + this.GraphLogger.LogHttpMessage( + TraceLevel.Error, + TransactionDirection.Incoming, + HttpTraceType.HttpResponse, + request.GetDisplayUrl(), + request.Method, + obfuscatedContent, + headers, + response.StatusCode, + responseTime: stopwatch.ElapsedMilliseconds); + } + catch (Exception e) + { + response.StatusCode = (int)HttpStatusCode.InternalServerError; + await response.WriteAsync(e.ToString()).ConfigureAwait(false); + + var obfuscatedContent = this.GraphLogger.SerializeAndObfuscate(e, Formatting.Indented); + headers = response.Headers.Select( + pair => new KeyValuePair>(pair.Key, pair.Value)); + + this.GraphLogger.LogHttpMessage( + TraceLevel.Error, + TransactionDirection.Incoming, + HttpTraceType.HttpResponse, + request.GetDisplayUrl(), + request.Method, + obfuscatedContent, + headers, + response.StatusCode, + responseTime: stopwatch.ElapsedMilliseconds); + } + } + + /// + /// Raised when the has received a notification. + /// + /// The instance containing the event data. + private void NotificationProcessor_OnNotificationReceived(NotificationEventArgs args) + { +#pragma warning disable 4014 + // Processing notification in the background. + // This ensures we're not holding on to the request. + this.NotificationProcessor_OnNotificationReceivedAsync(args).ForgetAndLogExceptionAsync( + this.GraphLogger, + $"Error processing notification {args.Notification.ResourceUrl} with scenario {args.ScenarioId}"); +#pragma warning restore 4014 + } + + /// + /// Raised when the has received a notification asynchronously. + /// + /// The instance containing the event data. + /// The . + private async Task NotificationProcessor_OnNotificationReceivedAsync(NotificationEventArgs args) + { + this.GraphLogger.CorrelationId = args.ScenarioId; + var headers = new[] + { + new KeyValuePair>(HttpConstants.HeaderNames.ScenarioId, new[] { args.ScenarioId.ToString() }), + new KeyValuePair>(HttpConstants.HeaderNames.ClientRequestId, new[] { args.RequestId.ToString() }), + new KeyValuePair>(HttpConstants.HeaderNames.Tenant, new[] { args.TenantId }), + }; + + // Create obfuscation content to match what we + // would have gotten from the service, then log. + var notifications = new CommsNotifications { Value = new[] { args.Notification } }; + var obfuscatedContent = this.GraphLogger.SerializeAndObfuscate(notifications, Formatting.Indented); + this.GraphLogger.LogHttpMessage( + TraceLevel.Info, + TransactionDirection.Incoming, + HttpTraceType.HttpRequest, + args.CallbackUri.ToString(), + HttpMethods.Post, + obfuscatedContent, + headers, + correlationId: args.ScenarioId, + requestId: args.RequestId); + + if (args.ResourceData is Call call) + { + if (call.State == CallState.Established && call.MediaState?.Audio == MediaState.Active) + { + await this.BotPlayPromptAsync(call.Id, args.TenantId, args.ScenarioId).ConfigureAwait(false); + } + else if (args.ChangeType == ChangeType.Deleted && call.State == CallState.Terminated) + { + this.GraphLogger.Log(TraceLevel.Info, $"Call State:{call.State}"); + } + } + else if (args.ResourceData is PlayPromptOperation playPromptOperation) + { + // checking for the call id sent in ClientContext. + if (string.IsNullOrWhiteSpace(playPromptOperation.ClientContext)) + { + throw new ServiceException(new Error() + { + Message = "No call id provided in PlayPromptOperation.ClientContext.", + }); + } + else if (playPromptOperation.Status == OperationStatus.Completed) + { + // The operation has been completed, hang up the call + await this.BotHangupCallAsync(playPromptOperation.ClientContext, args.TenantId, args.ScenarioId).ConfigureAwait(false); + this.GraphLogger.Log(TraceLevel.Info, $"Disconnecting the call."); + } + } + } + + /// + /// Bot Hangs up the call. + /// + /// The call identifier to hang up. + /// The tenant identifier. + /// The scenario identifier. + /// + /// When the prompt has been played. + /// + private async Task BotHangupCallAsync(string callId, string tenantId, Guid scenarioId) + { + var hangupRequest = this.RequestBuilder.Communications.Calls[callId].Request(); + await this.GraphApiClient.SendAsync(hangupRequest, RequestType.Delete, tenantId, scenarioId).ConfigureAwait(false); + } + + /// + /// Get Events in next hour. + /// + /// The user object identifier. + /// The tenant identifier. + /// The scenario identifier. + /// The representing the event of calendar. + private async Task GetEventsInNextHour(string userObjectId, string tenantId, Guid scenarioId) + { + var listEvents = this.RequestBuilder.Users[userObjectId].Calendar.Events.Request() + .Select(e => new + { + e.Subject, + e.Body, + e.BodyPreview, + e.Organizer, + e.Attendees, + e.Start, + e.End, + e.Location + }); + + var calendarEventList = await this.GraphApiClient.SendAsync>(listEvents, RequestType.Get, tenantId, scenarioId).ConfigureAwait(false); + + foreach (var calendarEvent in calendarEventList) + { + var startTime = Convert.ToDateTime(calendarEvent.Start.DateTime); + if (startTime > DateTime.UtcNow && DateTime.UtcNow.Subtract(startTime) < TimeSpan.FromHours(1)) + { + var attendees = calendarEvent.Attendees; + foreach (var attendee in attendees) + { + var name = attendee.EmailAddress.Name.ToString(); + this.GraphLogger.Log(TraceLevel.Info, $"Attendee's name {name}"); + } + + var eventSubject = calendarEvent.Subject; + var time = calendarEvent.Start.DateTime; + this.GraphLogger.Log(TraceLevel.Info, $"Subject: {eventSubject}"); + this.GraphLogger.Log(TraceLevel.Info, $"Time: {time}"); + return calendarEvent; + } + } + return null; + + // if calendarEventList?.NextLinkUrl isn't null, then you should read the next page. + } + + /// + /// Bot play the given prompts + /// + /// The prompts to play. + /// The call identifier. + /// The tenant identifier. + /// The scenario identifier. + /// The . + private async Task BotPlayPromptAsync(string callId, string tenantId, Guid scenarioId) + { + var prompts = new Prompt[] { + new MediaPrompt + { + MediaInfo = new MediaInfo() + { + Uri = new Uri(this.botBaseUri, "audio/reminder.wav").ToString(), + ResourceId = Guid.NewGuid().ToString(), + }, + }, + }; + var playPromptRequest = this.RequestBuilder.Communications.Calls[callId].PlayPrompt( + prompts: prompts, + clientContext: callId).Request(); + await this.GraphApiClient.SendAsync(playPromptRequest, RequestType.Create, tenantId, scenarioId).ConfigureAwait(false); + } + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Bot/BotOptions.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Bot/BotOptions.cs new file mode 100644 index 00000000..c93af96d --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Bot/BotOptions.cs @@ -0,0 +1,35 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Bot +{ + using System; + + /// + /// The bot options class. + /// + public class BotOptions + { + /// + /// Gets or sets the application id. + /// + public string AppId { get; set; } + + /// + /// Gets or sets the application secret. + /// + public string AppSecret { get; set; } + + /// + /// Gets or sets the calls uri of the application. + /// + public Uri BotBaseUrl { get; set; } + + /// + /// Gets or sets the comms platform endpoint uri. + /// + public Uri PlaceCallEndpointUrl { get; set; } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/ControllerConstants.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/ControllerConstants.cs new file mode 100644 index 00000000..545d283c --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/ControllerConstants.cs @@ -0,0 +1,18 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Controller +{ + /// + /// Http route constants for routing requests. + /// + public class ControllerConstants + { + /// + /// Route prefix for all incoming requests. + /// + public const string CallbackPrefix = "/callback"; + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/HomeController.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/HomeController.cs new file mode 100644 index 00000000..acaaddca --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/HomeController.cs @@ -0,0 +1,89 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Controller +{ + using Microsoft.AspNetCore.Mvc; + using Sample.Common.Logging; + + /// + /// The home controller class. + /// + public class HomeController : Controller + { + private readonly SampleObserver observer; + + /// + /// Initializes a new instance of the class. + /// + /// The observer. + public HomeController(SampleObserver observer) + { + this.observer = observer; + } + + /// + /// Get the default content of home page. + /// + /// Default content. + [HttpGet("/")] + public string Get() + { + return "Home Page"; + } + + /// + /// Get the service logs. + /// + /// Skip specified lines. + /// Take specified lines. + /// The logs. + [HttpGet] + [Route("/logs")] + public IActionResult GetLogs( + [FromQuery] int skip = 0, + [FromQuery] int take = 1000) + { + this.AddRefreshHeader(3); + return this.Content( + this.observer.GetLogs(skip, take), + System.Net.Mime.MediaTypeNames.Text.Plain, + System.Text.Encoding.UTF8); + } + + /// + /// Get the service logs. + /// + /// The filter. + /// Skip specified lines. + /// Take specified lines. + /// + /// The logs. + /// + [HttpGet] + [Route("/logs/{filter}")] + public IActionResult GetLogs( + string filter, + [FromQuery] int skip = 0, + [FromQuery] int take = 1000) + { + this.AddRefreshHeader(3); + return this.Content( + this.observer.GetLogs(filter, skip, take), + System.Net.Mime.MediaTypeNames.Text.Plain, + System.Text.Encoding.UTF8); + } + + /// + /// Add refresh headers for browsers to download content. + /// + /// Refresh rate. + private void AddRefreshHeader(int seconds) + { + this.Response.Headers.Add("Cache-Control", "private,must-revalidate,post-check=1,pre-check=2,no-cache"); + this.Response.Headers.Add("Refresh", seconds.ToString()); + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/PlatformCallController.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/PlatformCallController.cs new file mode 100644 index 00000000..766ab374 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/PlatformCallController.cs @@ -0,0 +1,42 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Controller +{ + using System.Threading.Tasks; + using Microsoft.AspNetCore.Mvc; + using Microsoft.Graph.Communications.Common.Telemetry; + using Sample.ReminderBot.Bot; + + /// + /// Entry point for handling call-related web hook requests. + /// + public class PlatformCallController : Controller + { + private readonly IGraphLogger graphLogger; + private readonly Bot bot; + + /// + /// Initializes a new instance of the class. + /// + /// The bot. + public PlatformCallController(Bot bot) + { + this.bot = bot; + this.graphLogger = bot.GraphLogger.CreateShim(nameof(PlatformCallController)); + } + + /// + /// Handle call back for bot calls user case. + /// + /// returns when task is done. + [HttpPost] + [Route(ControllerConstants.CallbackPrefix)] + public async Task OnIncomingBotCallUserRequestAsync() + { + await this.bot.ProcessNotificationAsync(this.Request, this.Response).ConfigureAwait(false); + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/UsersController.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/UsersController.cs new file mode 100644 index 00000000..79251c75 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Controllers/UsersController.cs @@ -0,0 +1,59 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Controller +{ + using System; + using System.Threading.Tasks; + using Microsoft.AspNetCore.Mvc; + using Sample.ReminderBot.Bot; + using Sample.ReminderBot.Data; + using Sample.ReminderBot.Extensions; + using Microsoft.Graph.Communications.Common; + + /// + /// The incidents controller class. + /// + [Route("User")] + public class UsersController : Controller + { + private Bot bot; + + /// + /// Initializes a new instance of the class. + /// + /// The bot. + public UsersController(Bot bot) + { + this.bot = bot; + } + + /// + /// Raise a flow for reminding user. + /// + /// The user data. + /// The action result. + [HttpPost("raise")] + public async Task PostNotificationsAsync([FromBody] UserRequestData userRequestData) + { + try + { + Validator.NotNull(userRequestData, nameof(userRequestData),"UserRequestData is Null."); + Validator.NotNullOrWhitespace(userRequestData.ObjectId, nameof(userRequestData.ObjectId),"Object Id is Null or Whitespace."); + Validator.NotNullOrWhitespace(userRequestData.TenantId, nameof(userRequestData.TenantId),"Tenant Id is Null or Whitespace."); + + await this.bot.BotCallsUsersAsync(userRequestData).ConfigureAwait(false); + + return this.Ok("Bot got a notification to remind the user."); + } + catch (Exception e) + { + return this.Exception(e); + } + } + + + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Data/UserRequestData.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Data/UserRequestData.cs new file mode 100644 index 00000000..8b19a024 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Data/UserRequestData.cs @@ -0,0 +1,25 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Data +{ + using System; + + /// + /// The user request data. + /// + public class UserRequestData + { + /// + /// Gets or sets the user object id. + /// + public string ObjectId { get; set; } + + /// + /// Gets or sets the tenant id. + /// + public string TenantId { get; set; } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/BotBuilderExtensions.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/BotBuilderExtensions.cs new file mode 100644 index 00000000..78723163 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/BotBuilderExtensions.cs @@ -0,0 +1,39 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Microsoft.Extensions.DependencyInjection +{ + using System; + using Sample.ReminderBot.Bot; + + /// + /// The bot builder extensions class. + /// + public static class BotBuilderExtensions + { + /// + /// Add bot feature. + /// + /// The service collection. + /// The updated service collection. + public static IServiceCollection AddBot(this IServiceCollection services) + => services.AddBot(_ => { }); + + /// + /// Add bot feature. + /// + /// The service collection. + /// The action for bot options. + /// The updated service collection. + public static IServiceCollection AddBot(this IServiceCollection services, Action botOptionsAction) + { + var options = new BotOptions(); + botOptionsAction(options); + services.AddSingleton(options); + + return services.AddSingleton(); + } + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/ControllerExtentions.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/ControllerExtentions.cs new file mode 100644 index 00000000..3017095c --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/ControllerExtentions.cs @@ -0,0 +1,73 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Extensions +{ + using System; + using System.Linq; + using System.Net; + using System.Net.Http.Headers; + using Microsoft.AspNetCore.Http; + using Microsoft.AspNetCore.Mvc; + using Microsoft.Extensions.Primitives; + using Microsoft.Graph; + + /// + /// The controller exceptions. + /// + public static class ControllerExtentions + { + /// + /// Convert exception to action result. + /// + /// The controller. + /// The exception. + /// The action result. + public static IActionResult Exception(this Controller controller, Exception exception) + { + IActionResult result; + + if (exception is ServiceException e) + { + controller.HttpContext.Response.CopyHeaders(e.ResponseHeaders); + + int statusCode = (int)e.StatusCode; + + result = statusCode >= 300 + ? controller.StatusCode(statusCode, e.ToString()) + : controller.StatusCode((int)HttpStatusCode.InternalServerError, e.ToString()); + } + else + { + result = controller.StatusCode((int)HttpStatusCode.InternalServerError, exception.ToString()); + } + + return result; + } + + /// + /// Copy the response headers to controller.HttpContext.Response. + /// + /// The controller. + /// The headers. + private static void CopyHeaders(this HttpResponse response, HttpHeaders headers) + { + if (headers == null) + { + // do nothing as the source headers are null. + return; + } + + foreach (var header in headers) + { + var values = header.Value?.ToArray(); + if (values?.Any() == true) + { + response.Headers.Add(header.Key, new StringValues(values)); + } + } + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/HttpExtensions.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/HttpExtensions.cs new file mode 100644 index 00000000..8e01821b --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Extensions/HttpExtensions.cs @@ -0,0 +1,72 @@ +// +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT license. +// + +namespace Sample.ReminderBot.Extensions +{ + using System; + using System.Net.Http; + using System.Threading.Tasks; + using Microsoft.AspNetCore.Http; + using Microsoft.AspNetCore.Http.Extensions; + + /// + /// Extensions for ASP.NET HTTP request and response. + /// + public static class HttpExtensions + { + /// + /// Creates the request message asynchronous. + /// + /// The request. + /// The . + public static HttpRequestMessage CreateRequestMessage(this HttpRequest request) + { + var displayUri = request.GetDisplayUrl(); + var httpRequest = new HttpRequestMessage + { + RequestUri = new Uri(displayUri), + Method = new HttpMethod(request.Method), + }; + + if (request.ContentLength.HasValue && request.ContentLength.Value > 0) + { + httpRequest.Content = new StreamContent(request.Body); + } + + // Copy headers + foreach (var header in request.Headers) + { + httpRequest.Headers.TryAddWithoutValidation(header.Key, header.Value.ToArray()); + } + + return httpRequest; + } + + /// + /// Creates the HTTP response. + /// + /// The response. + /// The HTTP response. + /// The populated . + public static async Task CreateHttpResponseAsync(this HttpResponseMessage response, HttpResponse httpResponse) + { + httpResponse.StatusCode = (int)response.StatusCode; + + if (response.Content != null) + { + var content = await response.Content.ReadAsStringAsync().ConfigureAwait(false); + await httpResponse.WriteAsync(content).ConfigureAwait(false); + } + + // Copy headers + foreach (var header in response.Headers) + { + response.Headers.Add(header.Key, header.Value); + } + + return httpResponse; + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Program.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Program.cs new file mode 100644 index 00000000..acdfa5a9 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Program.cs @@ -0,0 +1,27 @@ +using Microsoft.AspNetCore; +using Microsoft.AspNetCore.Hosting; +using Microsoft.Extensions.Configuration; +using Microsoft.Extensions.Hosting; +using Microsoft.Extensions.Logging; + +namespace Sample.ReminderBot +{ + public class Program + { + public static void Main(string[] args) + { + CreateHostBuilder(args).Build().Run(); + } + + public static IWebHostBuilder CreateHostBuilder(string[] args) => + WebHost.CreateDefaultBuilder(args) + .ConfigureLogging((hostingContext, logging) => + { + logging.AddConfiguration(hostingContext.Configuration.GetSection("Logging")); + logging.AddDebug(); + logging.AddConsole(); + logging.AddAzureWebAppDiagnostics(); + }) + .UseStartup(); + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Properties/launchSettings.json b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Properties/launchSettings.json new file mode 100644 index 00000000..14002dd7 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Properties/launchSettings.json @@ -0,0 +1,28 @@ +{ + "$schema": "http://json.schemastore.org/launchsettings.json", + "iisSettings": { + "windowsAuthentication": false, + "anonymousAuthentication": true, + "iisExpress": { + "applicationUrl": "http://localhost:2404", + "sslPort": 44390 + } + }, + "profiles": { + "IIS Express": { + "commandName": "IISExpress", + "launchBrowser": true, + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + }, + "ReminderBot": { + "commandName": "Project", + "launchBrowser": true, + "applicationUrl": "https://localhost:5001;http://localhost:5000", + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/README.md b/Samples/V1.0Samples/StatelessSamples/ReminderBot/README.md new file mode 100644 index 00000000..a7f57636 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/README.md @@ -0,0 +1,98 @@ +# Introduction + The sample demostrates below flow- + 1. User uses the Reminder Bot which can access the user's calendar. + 2. User's outlook calendar has an appointment in the next hour. + 3. Reminder Bot looks up the user's calendar, calls the user and plays a prompt, alerting the user to the upcoming meeting. + +# Installation process + 1. Enable an Azure subscription to host web sites and bot services. + 2. Install Visual Studio 2017 + 3. Launch ReminderBot.sln in \Samples\V1.0Samples\StatelessSamples\ with Visual Studio 2017 (VS2017) + 4. Click menu Build/"Build Solution" to build the whole solution + 5. Create an BotService in an Azure subscription with Azure Portal (https://portal.azure.com), then enable both Teams & Skype channels on the Azure portal, and configure the calling Uri of the bot. + * Go to "Bot Services" resource type page, click "Add", select "Bot Channels Registration", click "Create", then follow the instructions. + - Write down the application ID **\{ApplicationId}** and **\{ApplicationSecret}** for next steps. + - Type "ReminderBot" in "Bot Handle" under "Bot Services", fill rest fields like Resource Group. Pricing Tier as per the requirement and click "Create". + * Under "Bot Services" click "ReminderBot", Click "Channels", Then select "Microsoft Teams" channel and enable it with next step. + - Click "Calling" tab, select "Enable calling" check box, then fill the "Webhook (for calling)" edit box with value "\{BotBaseUrl}/callback". Click "Save". + 6. Configure permissions for the Bot. + * Go to the Azure Portal (https://portal.azure.com). + * Select your registered bot application, in this case "ReminderBot", click "Settings" --> "Manage" and then click "API Permissions". + * Click "Add a Permission", click "Microsoft Graph" --> Application Permissions. + * Select permissions for "Calendars.Read" and Calls.Initiate.All etc. + * Click "Ok" and then "Save". + 7. Consent the permissions + * Go to "https://login.microsoftonline.com/common/adminconsent?client_id=&state=&redirect_uri=" + * Sign in with a tenant admin + * Consent for the whole tenant. + +# Getting Started (Azure Version) + 1. Installation process + * Create web site in Azure + - Right click V1.0Samples/StatelessSamples/ReminderBot/"Connected Services" and select "Add Connected Service" in project ReminderBot in VS2017, then select Publish tab, and click "Create new profile" to lauch a dialog + - Select "App Service" then click "Create New" radio button, then click "Publish" button to create a App Service and publish the code on. + - Write down the web site root uri **\{BotBaseUrl}** for next steps. + + * Update the following elements in appsettings.json file in project ReminderBot. + - Bot/AppId: "**\{ApplicationId}**" + - Bot/AppSecret: "**\{ApplicationSecret}**" + - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + + * Publish the application again. + - Right click ReminderBot/"Connected Services" and select "Add Connected Service" in project ReminderBot in VS2017, click "Publish" button. + + 2. Update process + * Update code properly. + * Publish the application again. + + 3. Software dependencies + * Nuget packages list are in \\Dependencies\Nuget in Solution Explorer of Visual Studio 2017 + + 4. API references + +# Getting Started (Local Run Version) + 1. Installation process + * Install Visual Studio 2017 + * Launch CommsSamples.sln in \Samples with Visual Studio 2017 (VS2017) + * Click menu Build/"Build Solution" to build the whole solution + * Setup ngrok. + - Sign up for a free ngrok account. Once signed up, go to the ngrok [dashboard](https://dashboard.ngrok.com/) and get your auth token. + - Create an ngrok configuration file `ngrok.yml` as follows: + ```yaml + authtoken: %replace_with_auth_token_from_dashboard% + tunnels: + signaling: + addr: 9442 + proto: http + media: + addr: 8445 + proto: tcp + ``` + - Start ngrok: `ngrok http https://localhost:44379 -host-header=localhost`. You will see an output like this: + ```ymal + Session Status online + Account YourName (Plan: Free) + Version x.x.xx + Region United States (us) + Web Interface http://127.0.0.1:4040 + Forwarding http://e6c2321a.ngrok.io -> https://localhost:44379 + Forwarding https://e6c2321a.ngrok.io -> https://localhost:44379 + ``` + - From **your** output, in line Forwarding (yours will be different) the first url`https://e6c2321a.ngrok.io` will be your bot base uri. Write down the bot base uri as **\{BotBaseUrl}** for next steps. + * Update the following elements in appsettings.json file in project ReminderBot. + - Bot/AppId: "**\{ApplicationId}**" + - Bot/AppSecret: "**\{ApplicationSecret}**" + - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + +# Build and Test + 1. Get the users' object IDs as \{UserObjectId-1} for the user, whose calendar has to be read. + + 2. Login to Teams client. + + 3. Open "Postman", create a Post request --> {BotBaseUrl}/user/raise and then add objectId and tenantId in Body (like mentioned below). Click on Send. + { + "objectId": "{UserObjectId-1}", + "tenantId": "{TenantId}" + } + + 4. Bot calls the user on Teams client if there is an appointment in next hour and plays a prompt, alerting the user to the upcoming meeting. diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/ReminderBot.csproj b/Samples/V1.0Samples/StatelessSamples/ReminderBot/ReminderBot.csproj new file mode 100644 index 00000000..847576cf --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/ReminderBot.csproj @@ -0,0 +1,26 @@ + + + + netcoreapp2.1 + + + + + + + + + + + + + + + + + + + + + + diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/Startup.cs b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Startup.cs new file mode 100644 index 00000000..db32367d --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/Startup.cs @@ -0,0 +1,61 @@ +using Microsoft.AspNetCore.Builder; +using Microsoft.AspNetCore.Hosting; +using Microsoft.AspNetCore.Mvc; +using Microsoft.Extensions.Configuration; +using Microsoft.Extensions.DependencyInjection; +using Microsoft.Extensions.Logging; +using Microsoft.Graph.Communications.Common.Telemetry; +using Sample.Common.Logging; + +namespace Sample.ReminderBot +{ + public class Startup + { + private readonly GraphLogger logger; + private readonly SampleObserver observer; + + public Startup(IConfiguration configuration) + { + this.Configuration = configuration; + this.logger = new GraphLogger(typeof(Startup).Assembly.GetName().Name); + this.observer = new SampleObserver(this.logger); + } + + public IConfiguration Configuration { get; } + + // This method gets called by the runtime. Use this method to add services to the container. + public void ConfigureServices(IServiceCollection services) + { + services + .AddSingleton(this.observer) + .AddSingleton(this.logger); + + services + .AddBot(options => this.Configuration.Bind("Bot", options)) + .AddMvc() + .SetCompatibilityVersion(CompatibilityVersion.Latest); + } + + /// + /// This method gets called by the runtime. Use this method to configure the HTTP request pipeline. + /// + /// App builder. + /// Hosting environment. + /// /// The logger of ILogger instance. + public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) + { + this.logger.BindToILoggerFactory(loggerFactory); + + if (env.IsDevelopment()) + { + app.UseDeveloperExceptionPage(); + } + + app.UseHttpsRedirection(); + app.UseStaticFiles(); + app.UseCookiePolicy(); + + app.UseMvc(); + } + } +} diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/appsettings.json b/Samples/V1.0Samples/StatelessSamples/ReminderBot/appsettings.json new file mode 100644 index 00000000..fa4119d8 --- /dev/null +++ b/Samples/V1.0Samples/StatelessSamples/ReminderBot/appsettings.json @@ -0,0 +1,16 @@ +{ + "Logging": { + "IncludeScopes": false, + "LogLevel": { + "Default": "Information", + "System": "Information", + "Microsoft": "Information" + } + }, + "Bot": { + "AppId": "%AppId%", + "AppSecret": "%AppSecret%", + "PlaceCallEndpointUrl": "https://graph.microsoft.com/v1.0", + "BotBaseUrl": "%ServiceDns%" + } +} \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/ReminderBot/wwwroot/audio/reminder.wav b/Samples/V1.0Samples/StatelessSamples/ReminderBot/wwwroot/audio/reminder.wav new file mode 100644 index 0000000000000000000000000000000000000000..7bf35047efb3610303ff002557aae4612091c4a2 GIT binary patch literal 189890 zcmeFaWpotD`^VcpJ?*DV2?(WXw?gR-C;+~m|yS3e7_kYg) zy}YmQVV;wjma2NHzFj@j)m_ggy*hX3aJK@1`nB%ce$1qqu`&pPU|>sHfQ5w+gg`QA z)Sol|+y&D7di_%1mjb^O_@%%v1%4^;OMzbs{8HeT0>2da|Dyu%|1|1VIGV?MEOC*#GX~IF@68vHz1FhENCxh5;`S^fTwrG&C@Z3xjv| z|2&}(4;c2Zo1c09E13oRf0o9A)D(C}z#bI%{8_*MYK}uBu%8|fhy~?^xgZw;9)9j8 zz#cv%0G|-phy0rog8ZBtr21JB&G|rT2&9ohLXgJGIlvYeq{F~Iio+lgs1w6^K@NuF zLE`^QbkO~GVT%fHINDfj2K{#4WU|~=Et~=+%wSf z1mM*RRFVKc8PFuC4QN*mC|d}{0zDpcufUP03#EfPzvaGg3g~yJD`?|8?m3qWj-;1+ z$o<2iPzR_t)E;;;1BLxu5y)=^s=em!a38rs;Ikgsp8-l_K-+>~-&>Hsf~yJr2{nU! z++FSNIU+Ps3>z`X~hNgyNWNea-qWYGR$ z&|pxbliWq1O@C-MQ0oS_ggeXK=S*BRC<1!Ht>O-YR&0QBpuM2A?}5S`*B$B$Jay*y zTrZ&NI?(!FTvO269S{lM0tzqW#)2L&16m4t(hHE|95)}7TEabmeuG~?>$ux&BG(bR z3ChT4@3EgbJvI`bL9h@f@xf4Ju2=tvQu6fS_)06lj@uc6`4IWB{n3;fx+ z$()C+&((p}!FuFRI31eCZQ0b0fNU9%!A_DATy1-3l&2PI4S#r zS;c#x$T^fO=Jt1?kvmnVrDSAn8wUdHk#WHy!BmJiOR zSfm8Ih1<~tWD8su5u#6#wUC$LGd89T(5@!)G`u@>E4-9GN1vlILS*n;@EJ9MsZCV` zhWV!k!XW`QDs&=X@-Gh_q=wKf>C5y1#?1zyA;@9m4|EI4A_I`I$OaV0YZDwH=Y8gl z;@=UZ3AYQH3swpy3XbvDlYj6=66>%9@Ly~*W;>e=?Lly4GM7h>q1uF(g+2#n`0BbB zJFYq)SJ?H$bJ$nu>*ychd+n*`ZS0Hn?sfHd;;t^@?C49t?5ef=lFk#u1dQo1)Aa7V$Ejt9@Q~rrL2ZHkxvpeu?ENus0lm>YsIU? zAHc2Y;$W}9e&0Wyna-6Kdqs`X9sURY7gTh|dwQe!Kd-VxRP}D9q;*ix3|) z8O}qhqupQ+Q%DV^-_mcwhkaptx@k#SLTU5jIfV}ji;HKMQDyVX&X+Z+*zIh`8i;;m z6Y`Y6De55-@|R+xp~u{OC#|iFWT-eo@PwRB zP9tv;}A#s0nSX0~O`ozc7W3*~J{6S9^*;q&+>(r4H{>|yQ!I*P~_oK?Km&X0T@r;mRc8Lb&9TOint zS>Vg?H`t9#MGD!*l!W?7MTP4Huln19etFy3-+JEItNdoEqBxjyJ?m&z^P)og_V96@ zLWd?!N;z7sli{#vD>9Pa=8ts^bg{wvjF)N2wMX{wXUYd?dq*WF+)6T3YZ$p)`MYR3 zeidp2exar!UoanLf&5hC(7wP}{}pe%_lTGC7~HwG`c*qC-j%c}sPS#)$In^wiW@lg zu^;93_+iy=S07w0NwG}sj_E1yJ zAUM(yi_%Wk5!Wz9FO*Q++5qLaV+*@-1Fyn2L$UN{=n(c%$f=5>nlU6RbjrLb(g!P-df&C?mXud$7V}yBU;h7#PPl7hj|~{7Rnrc zuB*b6fY!QDt5)huT^#A9zPP8`)9r`7!^6A74};F&Va9_U6U|dUjG38A*33@b5O-F4 zP&@*!V7t;?7#zw4-?JT94O1H487TC=_YU{(^3`%rwr5#RR5hyXRMEf8mp$%-;`7cT zrDH6sRO*wP)cH~ON!oNnOP((D*~wHXEajd%;bdkiV`Tnee}fI=ZJFKBF3FL8CjCv~ zs7PA2A5+tNf^$PV=@{q`+zPUQZ_>jb%8H8dMUKzzccHIm zDqJ2fc1b^``uKXA>$FL^ryhpA58iWBGo3NnJ#kcdcpN3+w!?Lh+PqqFRph$F#2PJX z_!199c2cw?66nQ2S*RW5p&PJ6I3QO{g2H?5Pt89pIUYP(!sTv6i83_oQ$u+fke{fItB7YSn2_SmT8 zvebgqR|(Pj3~@YK8om(d9BM&*qWUt6xF{A0Q@(8Pd~XkTZP!)D3i~N5TD8u2wL+hN zha5+L&xy zP`*9q@~1{$lZ)S)nLq<^pV;KI!kUNE<*{QWi;>Nt!S)eVcU4lb`rfk)Hi4eO!wQ|sZNJ|ifygA zpE1M8R(SHhXKnnxxv)p&Fn3F$uGSTEEx9BuF}7HCi1!^5`6_HB-XPtSn+c6W|G<dhr%@39Je zFn>0`CQc&*&{*swzJ%;69wOhayrmkh>ZgFD2Zagz?!+`S1=)qnK>4TacnnILRRPUOWv7OET> z&ELyP-^ptFw^r)z<=!sY;i4~0jpBF_N1OxbO_$pFB+`~~~96lA( zU`Mg1Xad}k)3Rfzb%D{|hweL$JaA^5E8kI&k<%-GRUuvwEV^p$;EHsg4t(ayp&{T( zC><3dWpDv+jChT7sM4=%7tzrG8wkUG?LyUhMO%5fbdn@S+(L9kxJuBQoJ?4;C&*B! z7I%<6zzk-(um{-*%whU29SwfVGJG36i=F$dwanuxZWq-nN-UNajw=Y2yKF=4@0|0( z_t@<4>Tq{(1wEE-54RE6gxf@yl*It>pi(gM&@msVwrmu1lpV`7Vmq@b6dp_n)by1&zuFYG$>t%YhYM;H&nlXfH=)39 z>}l_0D{?ib!gQ<9+3;ib6w{erjEv(y7BrD`&}2qXh9~;{k=rAC>3Hf~6{C8r=qr~i zy36lL8i8I*H}!)z;Zm++dXLb*QjTO_Cd7%7e+BN}Ty zs39$_+M`&bh*ZdAt;KHyNo0F8l2fq5nEF&^s6G9bbubA`U2x8b=++^3pp8G?Gu5@l zdBL7yO*6)peJSl;QdQ8taCqfL>v+p}$BNK!`cwc5TA5DF+RzwoJn0tP6#b(@qDDn( z4MmYnquUr@^(0kO?IYC^`B}vnRSShhG+J0)=)>Nzf3cC=B04X0kvRwt;qn*?xjIZLxj zuaqbXTNP+4-dMg_gpOhUF2Mm_yQf*;iT|aS4z)xfvY&9KVwhomWJ5!8#Qw<7`Z=0S z8oTzfW}AA0wn&?(dM0};ttRfki$){Rp~y_G8&?Pu=y%u%KSPYrbe6|1Vx*KP)Go9x zG$dg1MtLv0r4Dt~l(O$7dy2m2hx0F#>@-fS`pX*SzTk{>U8Jvc9x?FWL2Z1JYYC4!>J!Vh^|?&iXp6`f3-&6)OE zt_Wwo<1g1|*9BL!zdI|!29rxA$?E%hlRi^FD&l*@(1=%tmk}ePCPsy$4n?O%uG5`Y zcT?V#n86sOA2Ao(iQGW^=yP->l8#W&Lv}S&NI$3YLp#B*ez&02_t0Z<(|# zB%BfK7t9Lw2>kG_^UQTK4${`gQoHJ6+3F&Bv8QlPUaR~YrHRHPm5Qnf_Kl8I`x-|B zcWciAA47FP-|_;Y7fOc?kEk+OBlR(>qQ^wHiup74c&s;ONNhNoHPqInX~rlTi)Ztf zko}1lNGh@xSpfUFDd0XzH|7!5nSKpMYogHD(74c}K)Fxhd*+$#>g4Ed+hE}v<4ZS| z)GlsbFgw3r$<)e-${WTfwn9g_?T3Av+v8d99T~od@OV3fUliSS75WSMnvoBplu@gq zZbf&Ay&Ky)wq0yq^sNYk&aDc{=ZYuttCNR_H=r+WL53rnp-ga3E* zVn#D9sn4Nmp}v7i?;dxi^Nl^jI-zPwdCiiT;*7#i`PGVEm0hd&&3MQ%+dkV?-+tCr z-}Bbk|zJ4KEB)k*%X_k&B`)#@>u=6f-^A6q&B;qr5FAq*6hU zH;P=zW3T|a8S8=GfzQHS;oZ;|G$HQ5{PJx47i;M4kWLsw0ZNkeQ z6ei>s{!ryK$o-hJC2wo#L0gpflxMMLiZ9c9-eV8;M~3o`OY?Pb?8>-(u`w}{D3`{n zh}T;59U^K(#YVM^IH*QsvxKklG3X|&9$t&kkb?y$g}3IMGqIUft&+&>F;}n(nI6paU11!=dci%uiQJEW;XVh;+|OLu z!FqVIw1s+_Av#tYw>M&ma=+xM)Fl@wGZa5$on%AAM~V3~+N{5siP3Ijaf~Vk?f(wG3#91^KDZ>{CZ!7Hjhp}rCUsT%@^@nn~ zZ~?Z9oygqb79d?PAC6!{nFRsdm+CcnBSMq7t=KKzeo~0vWvd6j#lpfJ z*>irZ&Jz_4uN>ex%N^zyDNh@k8homaiaM$k&3VmzZCCwp?RMF2VrnqT{IsNAamNy< zbf;10S`+L*HKr;kKUbY>qFi8D8hx|c$<%i#HDcYWW5P$+6KE-Gqx9kF)P8DLu$%9s zcV%D~wHC_5$MBOx^&|sDtBA!=1NvB?x9g_4L*1@vso9|rt>G`w zA4y!6)~Ck(^ft*0b#sZ~A+>Lx|0`7&dIo#p=g2{*O(4Uu$oVBO9^NRZDZi|;tNJQl z3O;h<{34g%W-%E`6N`S&{rxp`Z|$>AdAl63NMqe^$?s}>sX--4G#!Zn{2%J$5s4A9 z$e@0Y;GXZdl2w`GUv7V&og}q{P~K&` zITNf+oss^E(93Y$kRfo~)7*Z?dd!=Js+5hQR>j?jAq@lM?}=_S<>UOlLnXe!whyI6 zKbC*Vdpqow|3c22Z=O<#IjVMzTJ?jq=citdu=D%Ce~B)|{7C4oTPvxFH+7H6z4E%? z$%j|p@*lf*Q%7kEP8A#?r7#Q2#d~7X>ojUKv3AddkZzFZU8sg>S*hOIKe(BBMyo>> z?|KjE$#z_I)@GyR1EaUZr^g)AH&j}ME~FsT)mQ90;@fE-U;I5Q_)(d;{_*u&S?@l$ z+RDboU98@vR;%isr1sGn(n_=uKR)7h{BG?v@&LWx)-t~=Gxv4N_s0r1`|g3e@DbcJ ztQt9#a1+}ld!uTk_pdj*Mvfs_bOpT_&TzOYW6Xy=n?lymUf)2+TF2HvBkmk363kPN zi~T!67FDXeE^1D`!e7C=!mGSXUCpe&7k&FQ`HlDO?#y~G);^~Tw_)!ht0!mHDz3Gx zdasl*ain4nW)rm6N9rz+d%|a2)5>dPxBY~F=#(|8{7o<$nFu+cQvP!(E-_15Xv$+3 zq-oMaacbFoBpfdB_O@nM_OXoeMN#L%eF91DGzptCcD?FAr;p4QzzW9-Z7S+#Gzm*GV%|}8)a_xa zBWdjF;7tFXFhYEjOjI7!wT(+jk;RKuw|INuXq7)tFbF_j%quSUe(-D>sG2bet-gI8hK9BnYoF4V9q(g@zocGn{U4IN{*@o-eF{u_RUS|d)9aL5 z1igjBWi|CwTwzR5aSHC|IbjdlJmwXaHvTFIC$GX#Y{IUzl}W>O zUr3s^1onimaCG2hz)c;c?z!5P3-W9~_xuVr2t1(k>We<3uK!Cqo!cueK{ioyk1g+(S5KBF~6bkK~_U}}r77}xQlgoJ8z zbf=i{s*&(YSEW^B`O~Dg{Sj)8{K2#EXQ5aK4R+;7-bL{|&4+ki+UBIqhC-1H8WDUN zDy1{%0~Ep9*>eG_6V3H@NcTe!>{qhSi z=<}t=eR9!fQ9kZOT7{>ZCzf_EPAu3|o*6PJ-b6;LzDUkXCXp|Z0<=5%M2bX;6KMS^ za%!NvW0v)Sack91uK}u0&Jpo>xuMIRtPqX#7A{nFj#->`BdvYh7x@i%K=54fG&37K z%iIGuMbeokt|b+>3#@sUidPxy+6V{boa-;MWMwV=uJ%-lX6ZX64Nq^I7&KTE_py5R zjMBfo8DfLtqDap#;lxf$IbM7+FQ;gvd#>0V;Z{wMVB&JTl8s|e!b|xwEgNTy3CRgo z<#yZGRP`{Pvt0>}Bi71!@(HLkaLLz-YKo5Iub1US)K6-cRzJRtd^;j#>ab^7AtMI& z_?|(d*mwTpmUCs+@@nQy_G`{pF2r-l_c~a|xjE-z_Hw65xK>*;`eK4O=7dhG+{zp3 znOQl+6DQ17d==IwFa!zyWQN|Qvhh1-y(K4(>Y@#Vbn#Zlhhg&$=O!5rZjQFpWsy)XQk>cTT?FT@W_ zU^OlxoudM`EL`Ooo88w1xgdEi?uNFd28YImPlPWqgUEPoS$vJ;E(uARndEkO2TM{H z1D&bOXfNIq>>)kPwa@sh^jqnH@|LD#dx=*a`Vn~VttjvRIVP9#PUH_(CdQ6W?UeX9 za+cx~veS01qGs^4Fiw^!EtSp}Twv-ubfx=py8lQi-^93tTlw9E4#{@11JsMshBiQH z@|>7HNh{*xR3FIS;5HuA*tYVlO&(l>RTpLQLhRFUY&bu-B|vZiu_8J)wNKjWYI}6C zqS070)(~Jlj_^nHHQohT8y@BAQ1z`$SDIQnykeQPuWwA~qOY6hFWdUuRbLU~HE6qd zuD&$oQfh}=i$B|j=6Zf8VW&3E}m{A;MIz1ZBvdd`^_V&Ox`C}<4S zoEs1t=})0GxKUOZDM(CAfvP=>$dxZ7{GqGvx85e9o=h|N1N?>Q;(u%Z(^$9In}4<_ zzp|%I@7m!Z{OvvQrRE=hRCWw8XpF2=3@_a)p^%22D%B3^0X+Z{KD; z?)b-hH25~0$fhCzZb`U4)fn1DluLH#F2_X2({XL1cWGh;IZVCaGyg3AwZPY~n)yaO z3yQpFt<}r>7O6`fmDwsjRXws7dyaag=1V2LO&5brQITksE-mJ8>~C>VvAvX;T)kiw z`vRXu%;Wzd_6eR4YHq9harwEN5jh2A<82$AXF@%BJH<+Aj<~*HBJVu8P25LmQm;^5 z*NoLqQ_dir%x2#J=UW?P8|XB-qy2v|Z;=_$V(_%qhJ3(PqL+%py7I`eF(;#qx{qQ7 z_KnRAd3?Y7_lBBNvDBa8=6=$lG0|n6OOF;$E*VvE$n0}8a`rP#s?2r1;hORuNhJD| z=+7~=;*>FA`BmgK8$j<6-?3K21oApQ9VWt=_9vx-bL-{xEGw<5v@Y`}p>n}iQJIJ* z8Y?u5Qe(TYBN4sJw!@eOzXaP)QTbu4tw@XrKKJGas*=osoHqC|(} z&oz4t3!_@ccq2`!j^e}QA!HBzA#^sF8_)&)0m|1HJfoabHPBeAd}hhck_Tm>%2$?p z=7kmgEOV%2UOy45T&fR6XrionqMB^1BIuAM?_C0ClpFejH;a~SHIryK$R}B^HxLK!ct#`Gu1A(CfJ{Y zevuP=K)r>kp|i2RypT|&aB2RD_$$^EGcMx1c9Qb4zy^PyC1Fc&c5rQQd{E|Z>rQa= zwzQ~NRs66hTof$6SDssS-}HB7H`^$B8KD+L$p`4VM zKC4bkuaiq*PbkeZ-QL4|$2{MWh9T0bYou4nnSw!*4AEh}N2n0h<8?u9P_JF3mHmpug{_OI!s;bo%(>ovlpg*< z)DcQ0#j+%oQPWpbs;P|l5FHzd>-%e9c`^S9l1jbz^t9coS_rPJaxFdV8J>#)A=QR$ z1*hSi`Fu&5a*O7L_N!hLSzx%KNmg_cA18<5qY)FkosxvE22}o3cNbf?s)H4YrI(84 z797gYDv%c><$o^iZQmaZL0<(Um0fhFBQ`}%1J8}0OW#U*$vR7O#ZJjLNn_DcG8aA& zEV3n+Q-w7O+T@MRn^HQ{vftB-+JWpRUyEKze^=~OB>c<39G z0GDH3$nSi$P%IfCucI2Q@n|3D4(U>~r&TRvsR9A^lI;^Z={aTJW}a!(Rz#G=mrN?s z7W(pAoVif{U&7(<*SdW&AI9i?HEt>pswZuuDbQP~*D98wMq z57-?os%Dk!%hToR@}CyDD?Z!y`-OegF%uZ?<- z{LUNAKOoGIpt9F8k9>nNTh&K%SsSf;s-7noitCd%;5%WDH`;l``j=&@HOaoyiF+G` zOw0!;2|a>O;H@X)1ZRYAMGDDA*>L4s)kM`OD2kAC`k2BuZ$~@j!x8img zRQ9d7P5$s)M}em7wef=eRp1Brm8X^6S2xr?RF|s|%}mX9)hFeAl|nUIS)w>Et;;vV zJE?oVYK}UlQ)P`yCztLo?_rYK*1Iivy|NXReK|mhQ=(-Qd~%(2$Ux#Msz&untw@BzawsD{3O;NwR> z#WmS%acBNx>;-oqywHEf^UArzHq$INJ*gN~R<{_=OaAdHZ$xRKX@>J@C=ux`_%1)G z-m5;RKx9K?_vEbXlZ>a_ph{M^R%40;;Rj?ACGp+2H#Mb}w=Zv9dAzE`w!|Il9~llgiizsu+A3X%R;1!fc>J~4UtA2;D7es{>AUJ*6DalH^DXri z`)36^hvF!VeFi5HnS!p8B5AVxfg+?-E4{K>(zoI%q7QR7$@39iSUfOo5}QIMh5GR;{Y@{IRD%6m$l^N*v2bge*tcX!+8sy8Oqw8QkL@lC~yGFxF{&W|6bi=C#k z&R3L;s4sb|?5K;xKc^a|$rFrxv?fTBN3k$~KkyswuYX z&Q9*Oo@{p=*Lv4rpE?|3YGTtw#<{?zx>z{(pkR1z&PkXmvCAxF=12&MGJ zIlo%JnLC@inl-k~?lFP-)H*1h=)}J(>?ElnYbZadK-3MiQ?+X~X7xeUTUm~fR? zihHKFX?<#scA@SfM@{=)N1>~h z?^^gKq7=?hlxc?>IK5PRSe37=RFun`DF!JUD;LSW2sQXL<`2Kv^~Dx#nOD`bYEjh~ z)8>i>rCp2i^9Q+e}AOpfH zyg~aR>udW3&nw?`*G@}rW!tj(rG`q5>eH;GS+y-n&3-f^NAT^TwbYIq$rSokk?k^ zsG{`iA_hg=)A^N$#65VsU?UwJ?hqUnXyQNQo@Nu9c9*>>9#M3qsBcN{(#u7GLYZ-% z?j~y^D+SeGS9hMI?>5Cs-;Sp(M2%^!s#ew06x2HKv>-i;*OYzVZ7K z>BxF!OmL$2H}`YL1#6=Dlj);zXywWB=H>C_Yl{BJn_E8CpNh61uL<*nyLe3qzu=&> zrpzHbrTHW3nPHjy0Qnt?r6z{EG0hlffakV3p4%T(t*vNc+-7O&3I~QWS==SAKXej5 zBm7O0Dz8+h>(A*6bZs?^{H+)hbryNSchf@dNI22o$aOjR zgtD15)WN$V>L?o{ucJ^YzQ|sH@njFh7`av&6dL%giREBU;YzkAl?I-EUG?5{b#zqN zmfG%HZ&{XE>Y5LirOG3h6_rOuV)=&DC{+pha&R3oe^cHvl{2nUd z+OhSx-_e5v&YMCkCs<+@?n4G60^|dj!{Q8P-Zrh#MEF;u|uF{ za0b!?oryL>GtdF(eDoWNU=nN$szMrp+0n1Lh1>}6e7`koVooxLna#{irak+OZOrWj zv-1tmT*w2Bf^Wc&;p1Qiczu`;vycmV1LjSS0JGi|Ac7$bq7y2?ocJQH49t8FgL&4! zUcVIhrNA!*ekt%vfnN&zQs9>YzZCeTz%K=UDey~yUkdzE;Fkiw6!@jUF9m)n@JoST z3j9*wmjb^O_@%%v1%4^;OMzbs{C`mZ0N%iJ_Mh)R*@i#={v#*;M@Ia~9{fr73;k}nj17P<71MMy#@!bWV|84ni>jRMP>A!iN zfpT5~d-boq{`dVY_W{^j;PKtROF!2#K`q{abk9M)pFV!F1g~+I0R`<0VC)?QB)tRN z9&QJ>3DD(M0V3a0z#^Cr*l@GB>D)9B2|o4T&*@-&4%ogJq}dK~oB;g1Yk&rLAC&wF zwDv1dr39$u0W`ax6vReQN5JD73HX2WpatL`3M__J0D|2D=x^vW6o8W9#&9n<1MUs~ z1^0y$VFLaFZ367T=71=OK_*b^e}IP#pe|Fm-W=eAa5z`YK4f>Z^VrdV9MytN1Cc&4 zY!cgu?aGd1m#~Kb(P#*$n2Q7zQK@zwRydN%tDI2u`qR3LrOM`$!Q7CVEPv6}dN{39Mqj39OrF9<7$&DQYbJTq~g7)?|oKH{Tr zKehm~q9f5lq&spJb^$72U+xdKC$pQ@(C4Wd)b#L@(A?m`03KNFuj^O&6a5|hQ~mq= zcl~z%j6lm^T*wkS8tzV6sg-nfCX*S>qCne`U_OfyP}$A`=HD?S4&8=^(J|O}tPVZ_ z-+|x2^KdQEnHUM!XKRT)#9873v5pu*R44rSGkiAA!`ERnItTS4Iax8ef(d1LwpjS$k*66&9}+7#dpBR^XK?O0b%HKXf{wQlUhT! zWjxGTb|%*b&>W-S_V8|4f}BKpp@o3w^A_ulUjaT};BLGVagHz&M* z@r!tK;wW*ISWO%tAl`i5S>9TnfVUW^w1d~3-&-(pS#f2+KqcYcqVxVdS7{Jd!zjY!GiF0 zsvB*lUolevXL2f>4c|mQpcApHm;@gUj?i7=D6gEC$&-+M$ra=_aydBw@ZkFJgZ$(C z6#hBV$Lr5a<^_l&L@6%E<(M38hn#?)0j}c;Hip?snS!nSfBVt`Q6UiFA6VhN==$b7 z>C(HOyIigvZnwL_ZSd^%6nSR^_J=poKWL26u>WxXz@JbT))1e9pTbRe7Qq94>yZdK zj(ktH=jZYn{z$_8YloU{^UI#haW&k!@am0Oa^WH8ND04 zn*Td$hf_rKM$uo$vCvW_fD(*7}xu%f0&oJE<$sEsVu_qBv^9 zCh%_XHwd2z8wooLIYF$jkFZ=&UGRv1n_tA&2r$7%GMcX@ zO@yC!giI#7Asn}nJwgu)PYe`zes|rm9x7W?gjY)JJDjy0>&=$(?iHOZDrZA?rguVM zU*Mwu3W#N+VXfe#BpbwF@8z8m{w|}Hqcr=~y_EIkjV1R*8zk%G-{n^E3GyHog~~xB zbAUIEoWuKu4L~lz4zwQ8lmM|FOt;YRz#w0OC+ym0M@rY__A7pFUgH?;>g~90JXU_% zTIA~LOQNrEKKfng&(LXl8TLUsOLIm}@z3yn@cT(B)j5W2ZA%#{@ZcGQTlA-5wDc4I zF8Y>v$!tbqd1FZfm`VH)va#n8C$CuWK)~T0Sp-ld%lvcv{D8(*n6n|fuJM&?r^nzO zW!+Xf#&pQt(fcQuo!t|y!#o5t>bgP?#E%Vxo-bjEPdrKttH($5iug-0R(yzm3~h`V zL>pyN(L1b=ZW?Gp8BjOg5I5kL;7&|ER)a3(`S@j|5P2GW>z(h54YUvLvWapta+X-K zy&XNTT)QkME7sY20`BD9&?NK(exEx^y`xLeE%J{M=QJ82$~z%c$RW)jLo@v$>2iLE z&|q1FPdr{yN!;faQ-bgiPKqbuYP26BgZ^O#LoabN86+JbvixyirGHqUHkc#%x#ID+ zfw{P?%=^Go>FjMXlwGs84o(iO#wqD_qcU9I8&N#u&kRD}`Mq6Vl_ z1XBnfUJDPB8mU!y26;%u1*e5o=o?-Wd#rZk3hWN{ za1P9g{xrVmt!s*}iMyLcTjD9hJU0Rp!bg$a_#-HXT26I9AIs}R4~^O{U5ZJ`WM!%0 zVf0M{C!H;bA#Y zfXLq-(FY@SYF6y!-9Rp3-9)Vv=Ouq4GlLubaf}|sSFOZ4!|m9Pj2b$CwIV0*ClWL} zCNRhQx36#TLGVD;r7Zo|x26I>2i@i#ZA>rDv)u8w3O;9*#1iZp)067M9^`G%#>KAJ zyd%$GsK~875OX>Dn|8i*H=qq6#CXYi)dcAUq7{=jB3kOU@#d+ zHXyDr+r7)&VlZc(3qCfT{QTfc!^)HHYd)d7j&V{kT-DiQ2;5`G61k|Gt{px=$MQOA zA4Q8anfzAdSZS7aOpGhGRENoG3M`n5*HHe4I!2a{5!8vmFeZW5mcIdO37w<6Q;Rt@ z)(*Gf_tE!M9q(Q@xnegR)DFPdo-+oQrQtD>GYje9}-6vj?e#z-%Kx z9Fz0LC=O|BDE*@IAU^A|W>VC^sD0Xa`5sZ0V1~#n{UmpZA>K^rIlY%FLR(=okV#Mv z)<}P+N3+iXcXu3nE_BZO&gFN(-eZva@`RpgWRF8#ocV6rGF= zg2po6sg~4bY8SJay+F4PZt*N~RNBY7cAI}M4CdV}A7NYRs_zt4)iE}4e(~o8Gr}}I z0G4Az5Q;0po=cLI26>|7u2=$M|F#-7=^E;KXeX&I$nDYwQkiU;ZiQ;N^pNDJJV_m^Ss^F**U=PAPi!SV z;VrN>$SkNKTaW%qA7mdeg`thUF776-i|#x}R{7gPYw1`JbIG|9?2SynRXwy(`V{ZHJm~uuO+{&e69K>Ybf*)a=a$d zoEJ?j#fs47NINLNhS*u)D%i^mpl$#XRJ^}|*Xlf6HL-k8<=+;gZL?#Zy|ZPa88pPP z!ZppeDo6$P`xgYr@DVnE^(NQzz5Fu40CBNwfLaGy*iG9+RU%(3pQ$*lm?f{0oD|IF zS%{1HVf+z(6l;hbMe8G-;W(r@`UOy*Q=sO|`%p%poBz4DhU2<v7u^$9{JYuhTon9~*Rs)$CB1LnDX(EPpz`cg?(M_mz6c+9ijPc#@^z~fx><8C{k3DxiuRYy7FWn=(x_~I82`j>f z!*{71dKq^IZi^Vu)#z6A6}lIjjQ0eihhg{$>~Cy0-WaoC2e2>rb?h6~9UFw*!YFJd zh)yj)7hsz(F>b;ZVb75U=mS^-wFPwaI$W4Z*?W{3tYK_`Rpf)+o5 zUBmidb@7SdDsCKJjt#{gqrK1rD2B$Ov(dibD*H0r5^e@f2Rwfdt7UD>B_@j=$Xucq z(-$ZQbv0}ZZwn8l9)xqLRun?psSfm75Oe&1&Sd5?8v)PzII{uNqyeV}y!V$}CUgzD z4WiF&@JFN=X^p-@#-c6IXJ|XLA=(JFp?!f@2fPJ6gjB&Yqyf?q{sCQq*8o0y3>b&r zWV>=BSQlWvPv>4Tjkx>FcMvV0Vc*a(;9ES2DW+F3%b7GlW9Y+>Y<=bfvykb{USTV_ zm0*�?SpY}uJMph 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 G2>c)QLi)=9 literal 0 HcmV?d00001 diff --git a/Samples/V1.0Samples/StatelessSamples/SimpleIvrBot/README.md b/Samples/V1.0Samples/StatelessSamples/SimpleIvrBot/README.md index 00b0ffb4..ea92dd3f 100644 --- a/Samples/V1.0Samples/StatelessSamples/SimpleIvrBot/README.md +++ b/Samples/V1.0Samples/StatelessSamples/SimpleIvrBot/README.md @@ -1,106 +1,103 @@ # Introduction -The sample demonstrates a playing a prompt with a simple IVR menu, subscribing to tones and call transfer to an agent. + The sample demonstrates a playing a prompt with a simple IVR menu, subscribing to tones and call transfer to an agent. # Sample status -1. user calls an app belonging to an auto dealership. -2. Bot answers the call. -3. Bot plays a prompt saying Press 1 for sales, Press 2 for service, Press 3 for other questions. -4. user selects 2 and gets transferred to an agent dealing with service. + 1. user calls an app belonging to an auto dealership. + 2. Bot answers the call. + 3. Bot plays a prompt saying Press 1 for sales, Press 2 for service, Press 3 for other questions. + 4. user selects 2 and gets transferred to an agent dealing with service. -# Getting Started -1. Installation process - * Enable an Azure subscription to host web sites and bot services. - * Install Visual Studio 2017 - * Launch CommsSamples.sln in \Samples with Visual Studio 2017 (VS2017) - * Click menu Build/"Build Solution" to build the whole solution - * Create an BotService in an Azure subscription with Azure Portal (https://portal.azure.com), then enable both Teams & Skype channels on the Azure portal, and configure the calling Uri of the bot. - - Go to "Bot Services" resource type page, click "Add", select "Bot Channels Registration", click "Create", then follow the instructions. - - Write down the application ID **\{ApplicationId}** and **\{ApplicationSecret}** for next steps. - - Type "SimpleIvrBot" in "Bot Services" resource type page, Click "Channels", Then select "Microsoft Teams" and "Skype" channels and enable both of them. - - Click "edit" button of "Skype" channel, click "Calling" tab, select "Enable calling" radio button, then select "IVR - 1:1 IVR audio calls", and fill the Webhook (for calling) edit box with value "\{BotBaseUrl}/callback". - * Configure permissions for the Bot. - - Go to Application Registration Portal (https://apps.dev.microsoft.com/). - - Select your registered bot application. - - Click "Add" under Microsoft Graph Permissions --> Application Permissions. - - Select all permissions starting with "Calls.", i.e. "Calls.AccessMedia.All", "Calls.Initiate.All", etc. - - Click "Ok" and then "Save" - * Consent the permissions - - Go to "https://login.microsoftonline.com/common/adminconsent?client_id=&state=&redirect_uri=" - - Sign in with a tenant admin - - Consent for the whole tenant. +# Installation process + 1. Enable an Azure subscription to host web sites and bot services. + 2. Install Visual Studio 2017 + 3. Launch SimpleIvrBot.sln in \Samples\V1.0Samples\StatelessSamples with Visual Studio 2017 (VS2017) + 4. Click menu Build/"Build Solution" to build the whole solution + 5. Create an BotService in an Azure subscription with Azure Portal (https://portal.azure.com), then enable Teams channel on the Azure portal and configure the calling Uri of the bot. + * Go to "Bot Services" resource type page, click "Add", select "Bot Channels Registration", click "Create", then follow the instructions. + - Write down the application ID **\{ApplicationId}** and **\{ApplicationSecret}** for next steps. + - Type "SimpleIvrBot" in "Bot Handle" under "Bot Services", fill rest fields like Resource Group. Pricing Tier as per the requirement and click "Create". + * Under "Bot Services" click "SimpleIvrBot", Click "Channels", Then select "Microsoft Teams" channel and enable it with next step. + - Click "Calling" tab, select "Enable calling" check box, then fill the "Webhook (for calling)" edit box with value "\{BotBaseUrl}/callback". Click "Save". + 6. Configure permissions for the Bot. + * Go to the Azure Portal (https://portal.azure.com). + * Select your registered bot application, in this case "SimpleIvrBot", click "Settings" --> "Manage" and then click "API Permissions". + * Click "Add a Permission", click "Microsoft Graph" --> Application Permissions. + * Select all permissions starting with "Calls.", i.e. "Calls.AccessMedia.All", "Calls.Initiate.All", etc. + * Click "Ok" and then "Save". + 7. Consent the permissions + * Go to "https://login.microsoftonline.com/common/adminconsent?client_id=&state=&redirect_uri=" + * Sign in with a tenant admin + * Consent for the whole tenant. # Getting Started (Azure Version) -1. Installation process - * Create web site in Azure - - Right click BetaSamples/StatelessSamples/SimpleIvrBot/"Connected Services" and select "Add Connected Service" in project SimpleIvrBot in VS2017, then select Publish tab, and click "Create new profile" to lauch a dialog - - Select "App Service" then click "Create New" radio button, then click "Publish" button to create a App Service and publish the code on. - - Write down the web site root uri **\{BotBaseUrl}** for next steps. + 1. Installation process + * Create web site in Azure + - Right click V1.0Samples/StatelessSamples/SimpleIvrBot/"Connected Services" and select "Add Connected Service" in project SimpleIvrBot in VS2017, then select Publish tab, and click "Create new profile" to lauch a dialog + - Select "App Service" then click "Create New" radio button, then click "Publish" button to create a App Service and publish the code on. + - Write down the web site root uri **\{BotBaseUrl}** for next steps. - * Update the following elements in appsettings.json file in project SimpleIvrBot. - - Bot/AppId: "**\{ApplicationId}**" - - Bot/AppSecret: "**\{ApplicationSecret}**" - - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + * Update the following elements in appsettings.json file in project SimpleIvrBot. + - Bot/AppId: "**\{ApplicationId}**" + - Bot/AppSecret: "**\{ApplicationSecret}**" + - Bot/BotBaseUrl: "**\{BotBaseUrl}**" - * Publish the application again. - - Right click SimpleIvrBot/"Connected Services" and select "Add Connected Service" in project SimpleIvrBot in VS2017, click "Publish" button. + * Publish the application again. + - Right click SimpleIvrBot/"Connected Services" and select "Add Connected Service" in project SimpleIvrBot in VS2017, click "Publish" button. -2. Update process - * Update code properly. - * Publish the application again. + 2. Update process + * Update code properly. + * Publish the application again. -3. Software dependencies - * Nuget packages list are in \\Dependencies\Nuget in Solution Explorer of Visual Studio 2017 - -4. API references + 3. Software dependencies + * Nuget packages list are in \\Dependencies\Nuget in Solution Explorer of Visual Studio 2017 + + 4. API references # Getting Started (Local Run Version) -1. Installation process - * Install Visual Studio 2017 - * Launch CommsSamples.sln in \Samples with Visual Studio 2017 (VS2017) - * Click menu Build/"Build Solution" to build the whole solution - * Setup ngrok. - - Sign up for a free ngrok account. Once signed up, go to the ngrok [dashboard](https://dashboard.ngrok.com/) and get your auth token. - - Create an ngrok configuration file `ngrok.yml` as follows: - ```yaml - authtoken: %replace_with_auth_token_from_dashboard% - tunnels: - signaling: - addr: 9442 - proto: http - media: - addr: 8445 - proto: tcp - ``` - - Start ngrok: `ngrok http https://localhost:44379 -host-header=localhost`. You will see an output like this: - ```ymal - Session Status online - Account YourName (Plan: Free) - Version x.x.xx - Region United States (us) - Web Interface http://127.0.0.1:4040 - Forwarding http://e6c2321a.ngrok.io -> https://localhost:44379 - Forwarding https://e6c2321a.ngrok.io -> https://localhost:44379 - ``` - - From **your** output, in line Forwarding (yours will be different) the first url`https://e6c2321a.ngrok.io` will be your bot base uri. Write down the bot base uri as **\{BotBaseUrl}** for next steps. - * Update the following elements in appsettings.json file in project SimpleIvrBot. - - Bot/AppId: "**\{ApplicationId}**" - - Bot/AppSecret: "**\{ApplicationSecret}**" - - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + 1. Installation process + * Install Visual Studio 2017 + * Launch CommsSamples.sln in \Samples with Visual Studio 2017 (VS2017) + * Click menu Build/"Build Solution" to build the whole solution + * Setup ngrok. + - Sign up for a free ngrok account. Once signed up, go to the ngrok [dashboard](https://dashboard.ngrok.com/) and get your auth token. + - Create an ngrok configuration file `ngrok.yml` as follows: + ```yaml + authtoken: %replace_with_auth_token_from_dashboard% + tunnels: + signaling: + addr: 9442 + proto: http + media: + addr: 8445 + proto: tcp + ``` + - Start ngrok: `ngrok http https://localhost:44379 -host-header=localhost`. You will see an output like this: + ```ymal + Session Status online + Account YourName (Plan: Free) + Version x.x.xx + Region United States (us) + Web Interface http://127.0.0.1:4040 + Forwarding http://e6c2321a.ngrok.io -> https://localhost:44379 + Forwarding https://e6c2321a.ngrok.io -> https://localhost:44379 + ``` + - From **your** output, in line Forwarding (yours will be different) the first url`https://e6c2321a.ngrok.io` will be your bot base uri. Write down the bot base uri as **\{BotBaseUrl}** for next steps. + * Update the following elements in appsettings.json file in project SimpleIvrBot. + - Bot/AppId: "**\{ApplicationId}**" + - Bot/AppSecret: "**\{ApplicationSecret}**" + - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + - Bot/objectIds: { + "First":"**\{objectId-1}**" + "Second":"**\{objectId-2}**" + "Third":"**\{objectId-3}**" + } # Build and Test -1. Create a tenant in O365, with Teams enabled. - -2. Create multiple users in O365, with Teams enabled. Get the objectIds of all. - * Update the following elements in appsettings.json file in project SimpleIvrBot. - - Bot/objectIds: { - "First":"**\{objectId-1}**" - "Second":"**\{objectId-2}**" - "Third":"**\{objectId-3}**" - } + 1. Login to Teams client. -3. Install Teams client. + 2. Install the SimpleIvrBot in the client using steps mentioned here: https://microsoftgraph.github.io/microsoft-graph-comms-samples/docs/articles/calls/register-calling-bot.html#register-bot-in-microsoft-teams -4. Login Teams with user as caller for the scenario in order to call the Bot. + 3. Bot plays a prompt with an IVR menu, and let the caller select a menu option using DTMF tones, then transfer the call to the selected menu option, as mentioned below. -5. Bot should play a prompt with an IVR menu, and let the caller select a menu option using DTMF tones, then transfer the call to the selected menu option. \ No newline at end of file + 4. On pressing key 1, call will be transferred to objectId-1, on 2 to objectId-2 and for any other key press it will transfer to objectId-3. \ No newline at end of file diff --git a/Samples/V1.0Samples/StatelessSamples/VoiceRecorderAndPlaybackBot/README.md b/Samples/V1.0Samples/StatelessSamples/VoiceRecorderAndPlaybackBot/README.md index 70945494..43d4381d 100644 --- a/Samples/V1.0Samples/StatelessSamples/VoiceRecorderAndPlaybackBot/README.md +++ b/Samples/V1.0Samples/StatelessSamples/VoiceRecorderAndPlaybackBot/README.md @@ -1,99 +1,90 @@ # Introduction -The sample demostrate a recording audio by user and playing back to user workflow. + The sample demostrate a recording audio by user and playing back to user workflow. # Sample status -1. The user will call bot and Bot will answer the call. -2. Bot plays audio prompt message, indicating it is ready to record. -3. Bot records what the user speaks, with maximum duration allowed 10 seconds. -4. Bot plays back the recorded message. -5. Bot hangs up the call. + 1. The user will call bot and Bot will answer the call. + 2. Bot plays audio prompt message, indicating it is ready to record. + 3. Bot records what the user speaks, with maximum duration allowed 10 seconds. + 4. Bot plays back the recorded message. + 5. Bot hangs up the call. -# Getting Started -1. Installation process - * Enable an Azure subscription to host web sites and bot services. - * Install Visual Studio 2017 - * Launch CommsSamples.sln in \Samples with Visual Studio 2017 (VS2017) - * Click menu Build/"Build Solution" to build the whole solution - * Create an BotService in an Azure subscription with Azure Portal (https://portal.azure.com), then enable both Teams & Skype channels on the Azure portal, and configure the calling Uri of the bot. - - Go to "Bot Services" resource type page, click "Add", select "Bot Channels Registration", click "Create", then follow the instructions. - - Write down the application ID **\{ApplicationId}** and **\{ApplicationSecret}** for next steps. - - Click "VoiceRecorderAndPlaybackBot" in "Bot Services" resource type page, Click "Channels", Then select "Microsoft Teams" and "Skype" channels and enable both of them. - - Click "edit" button of "Skype" channel, click "Calling" tab, select "Enable calling" radio button, then select "IVR - 1:1 IVR audio calls", and fill the Webhook (for calling) edit box with value "\{BotBaseUrl}/callback". - * Configure permissions for the Bot. - - This Bot doesnt need any permissions +# Installation process + 1. Enable an Azure subscription to host web sites and bot services. + 2. Install Visual Studio 2017 + 3. Launch VoiceRecorderAndPlaybackBot.sln in \Samples\V1.0Samples\StatelessSamples with Visual Studio 2017 (VS2017) + 4. Click menu Build/"Build Solution" to build the whole solution + 5. Create an BotService in an Azure subscription with Azure Portal (https://portal.azure.com), then enable both Teams & Skype channels on the Azure portal, and configure the calling Uri of the bot. + * Go to "Bot Services" resource type page, click "Add", select "Bot Channels Registration", click "Create", then follow the instructions. + - Write down the application ID **\{ApplicationId}** and **\{ApplicationSecret}** for next steps. + - Type "VoiceRecorderAndPlaybackBot" in "Bot Handle" under "Bot Services", fill rest fields like Resource Group. Pricing Tier as per the requirement and click "Create". + * Under "Bot Services" click "VoiceRecorderAndPlaybackBot", Click "Channels", Then select "Microsoft Teams" channel and enable it with next step. + - Click "Calling" tab, select "Enable calling" check box, then fill the "Webhook (for calling)" edit box with value "\{BotBaseUrl}/callback". Click "Save". + 6. Configure permissions for the Bot. + * This Bot doesnt need any permissions # Getting Started (Azure Version) -1. Installation process - * Create web site in Azure - - Right click 1.0Samples/StatelessSamples/VoiceRecorderAndPlaybackBot/"Connected Services" and select "Add Connected Service" in project VoiceRecorderAndPlaybackBot in VS2017, then select Publish tab, and click "Create new profile" to lauch a dialog - - Select "App Service" then click "Create New" radio button, then click "Publish" button to create a App Service and publish the code on. - - Write down the web site root uri **\{BotBaseUrl}** for next steps. + 1. Installation process + * Create web site in Azure + - Right click V1.0Samples/StatelessSamples/VoiceRecorderAndPlaybackBot/"Connected Services" and select "Add Connected Service" in project VoiceRecorderAndPlaybackBot in VS2017, then select Publish tab, and click "Create new profile" to lauch a dialog + - Select "App Service" then click "Create New" radio button, then click "Publish" button to create a App Service and publish the code on. + - Write down the web site root uri **\{BotBaseUrl}** for next steps. - * Update the following elements in appsettings.json file in project VoiceRecorderAndPlaybackBot. - - Bot/AppId: "**\{ApplicationId}**" - - Bot/AppSecret: "**\{ApplicationSecret}**" - - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + * Update the following elements in appsettings.json file in project VoiceRecorderAndPlaybackBot. + - Bot/AppId: "**\{ApplicationId}**" + - Bot/AppSecret: "**\{ApplicationSecret}**" + - Bot/BotBaseUrl: "**\{BotBaseUrl}**" - * Publish the application again. - - Right click VoiceRecorderAndPlaybackBot/"Connected Services" and select "Add Connected Service" in project NotificationBot in VS2017, click "Publish" button. + * Publish the application again. + - Right click VoiceRecorderAndPlaybackBot/"Connected Services" and select "Add Connected Service" in project NotificationBot in VS2017, click "Publish" button. -2. Update process - * Update code properly. - * Publish the application again. + 2. Update process + * Update code properly. + * Publish the application again. -3. Software dependencies - * .NET Framework 471 - * Nuget packages list are in \\Dependencies\Nuget in Solution Explorer of Visual Studio 2017 - -4. Latest releases - * version 0.2 + 3. Software dependencies + * Nuget packages list are in \\Dependencies\Nuget in Solution Explorer of Visual Studio 2017 -5. API references + 4. API references # Getting Started (Local Run Version) -1. Installation process - * Install Visual Studio 2017 - * Launch CommsSamples.sln in \Samples with Visual Studio 2017 (VS2017) - * Click menu Build/"Build Solution" to build the whole solution - * Setup ngrok. - - Sign up for a free ngrok account. Once signed up, go to the ngrok [dashboard](https://dashboard.ngrok.com/) and get your auth token. - - Create an ngrok configuration file `ngrok.yml` as follows: - ```yaml - authtoken: %replace_with_auth_token_from_dashboard% - tunnels: - signaling: - addr: 9442 - proto: http - media: - addr: 8445 - proto: tcp - ``` - - Start ngrok: `ngrok http https://localhost:44379 -host-header=localhost`. You will see an output like this: - ```ymal - Session Status online - Account YourName (Plan: Free) - Version x.x.xx - Region United States (us) - Web Interface http://127.0.0.1:4040 - Forwarding http://e6c2321a.ngrok.io -> https://localhost:44379 - Forwarding https://e6c2321a.ngrok.io -> https://localhost:44379 - ``` - - From **your** output, in line Forwarding (yours will be different) the first url`https://e6c2321a.ngrok.io` will be your bot base uri. Write down the bot base uri as **\{BotBaseUrl}** for next steps. - * Update the following elements in appsettings.json file in project NotificationBot. - - Bot/AppId: "**\{ApplicationId}**" - - Bot/AppSecret: "**\{ApplicationSecret}**" - - Bot/BotBaseUrl: "**\{BotBaseUrl}**" + 1. Installation process + * Install Visual Studio 2017 + * Launch CommsSamples.sln in \Samples with Visual Studio 2017 (VS2017) + * Click menu Build/"Build Solution" to build the whole solution + * Setup ngrok. + - Sign up for a free ngrok account. Once signed up, go to the ngrok [dashboard](https://dashboard.ngrok.com/) and get your auth token. + - Create an ngrok configuration file `ngrok.yml` as follows: + ```yaml + authtoken: %replace_with_auth_token_from_dashboard% + tunnels: + signaling: + addr: 9442 + proto: http + media: + addr: 8445 + proto: tcp + ``` + - Start ngrok: `ngrok http https://localhost:44379 -host-header=localhost`. You will see an output like this: + ```ymal + Session Status online + Account YourName (Plan: Free) + Version x.x.xx + Region United States (us) + Web Interface http://127.0.0.1:4040 + Forwarding http://e6c2321a.ngrok.io -> https://localhost:44379 + Forwarding https://e6c2321a.ngrok.io -> https://localhost:44379 + ``` + - From **your** output, in line Forwarding (yours will be different) the first url`https://e6c2321a.ngrok.io` will be your bot base uri. Write down the bot base uri as **\{BotBaseUrl}** for next steps. + * Update the following elements in appsettings.json file in project VoiceRecorderAndPlaybackBot. + - Bot/AppId: "**\{ApplicationId}**" + - Bot/AppSecret: "**\{ApplicationSecret}**" + - Bot/BotBaseUrl: "**\{BotBaseUrl}**" # Build and Test -1. Create a tenant in O365, with Teams enabled. + 1. Login to Teams client. -2. Create two users in O365, with Teams enabled. - * Write down the users' object IDs as \{UserObjectId-1} for user1 and \{UserObjectId-2} for user2 (optional). + 2. Install the VoiceRecorderAndPlaybackBot in the client using steps mentioned here: https://microsoftgraph.github.io/microsoft-graph-comms-samples/docs/articles/calls/register-calling-bot.html#register-bot-in-microsoft-teams -3. Install Teams client. + 3. Call VoiceRecorderAndPlaybackBot using the Teams client, and bot should play a audio prompt indicating it is ready to record the caller's audio. -4. Login to Teams - -5. Install the VoiceRecorderAndPlaybackBot in the client using steps mentioned here: https://microsoftgraph.github.io/microsoft-graph-comms-samples/docs/articles/calls/register-calling-bot.html#register-bot-in-microsoft-teams - -6. user1 should call VoiceRecorderAndPlaybackBot using the Teams client, and bot should play prompt indicating it is ready to record the user's audio. + 4. After recording the prompt, VoiceRecorderAndPlaybackBot will play back the recorded audio. diff --git a/docs/articles/Logging.html b/docs/articles/Logging.html index ea040ab3..0af612c7 100644 --- a/docs/articles/Logging.html +++ b/docs/articles/Logging.html @@ -79,8 +79,8 @@

Logging in SDK

-

The Graph SDK uses a custom logger named IGraphLogger which allows custom subscribers for log events. These events can be observed and logged as required by the bot developers.

-

You need to create an IObserver for log events (the LogEvent class).

+

The Graph SDK uses a custom logger named @Microsoft.Graph.Communications.Common.Telemetry.IGraphLogger which allows custom subscribers for log events. These events can be observed and logged as required by the bot developers.

+

You need to create an IObserver for log events (the @Microsoft.Graph.Communications.Common.Telemetry.LogEvent class).

private class LogObserver : IObserver<LogEvent>
 {
     private readonly LogEventFormatter formatter = new LogEventFormatter();
diff --git a/docs/articles/Testing.html b/docs/articles/Testing.html
index f721d5d9..9a77f226 100644
--- a/docs/articles/Testing.html
+++ b/docs/articles/Testing.html
@@ -133,7 +133,7 @@ 

Update Signaling

Important

Your local instance must be listening to http traffic on the signaling port. The requests made by Graph Platform will reach the bot as localhost http traffic when End to End encryption is not setup.

Update Media

-

Update your MediaPlatformSettings to the following.

+

Update your @Microsoft.Skype.Bots.Media.MediaPlatformSettings to the following.

var mediaPlatform = new MediaPlatformSettings 
 {
     ApplicationId = <Your application id>
diff --git a/docs/articles/calls/appHostedMediaCalls.html b/docs/articles/calls/appHostedMediaCalls.html
index b71dbb6c..9c395879 100644
--- a/docs/articles/calls/appHostedMediaCalls.html
+++ b/docs/articles/calls/appHostedMediaCalls.html
@@ -82,12 +82,12 @@ 

Application Hosted Media Calls

Application Hosted Media calls are those calls in which the bot manages the call's video and audio sockets. The bots send and receive raw audio and video data over the network.

Building a CommunicationsClient with Media Platform Settings

    -
  1. Create the an instance of the ICommunicationsClientBuilder.
  2. -
  3. Create an instance of MediaPlatformSettings and use MediaCommunicationsClientBuilderExtensions.SetMediaPlatformSettings method to pass the MediaPlatformSettings to build the ICommunicationsClient
  4. -
  5. Once the builder builds the ICommunicationsClient, a media session can be created using either MediaCommunicationsClientExtension.CreateMediaSession or MediaCommunicationsClientExtension.CreateMediaSession depending on how many video sockets are required.
  6. +
  7. Create the an instance of the @Microsoft.Graph.Communications.Client.ICommunicationsClientBuilder.
  8. +
  9. Create an instance of @Microsoft.Skype.Bots.Media.MediaPlatformSettings and use MediaCommunicationsClientBuilderExtensions.SetMediaPlatformSettings method to pass the @Microsoft.Skype.Bots.Media.MediaPlatformSettings to build the @Microsoft.Graph.Communications.Client.ICommunicationsClient
  10. +
  11. Once the builder builds the @Microsoft.Graph.Communications.Client.ICommunicationsClient, a media session can be created using either MediaCommunicationsClientExtension.CreateMediaSession or MediaCommunicationsClientExtension.CreateMediaSession depending on how many video sockets are required.
  12. When creating an object of the Call resource, MediaConfig needs to be set to AppHostedMediaConfig.
-
Important

When creating a new call that uses application hosted media, an instance of IMediaSession needs to be passed into CallCollectionExtensions.AddAsync

+
Important

When creating a new call that uses application hosted media, an instance of @Microsoft.Graph.Communications.Calls.IMediaSession needs to be passed into CallCollectionExtensions.AddAsync

diff --git a/docs/articles/calls/register-calling-bot.html b/docs/articles/calls/register-calling-bot.html index 4fafdc3f..66ab2f30 100644 --- a/docs/articles/calls/register-calling-bot.html +++ b/docs/articles/calls/register-calling-bot.html @@ -164,17 +164,26 @@

Register bot in Microsoft Teams

Create a new app

    -
  • In the App details tab, provide the basic information.
  • +
  • In the App details tab, provide the basic information. And make sure to update App Id correctly.
  • +
+

App Id

+
  • Navigate to the Capabilities section, and select the Bots tab. Then select Set Up in the right pane.

Set up bots

  • Fill in the desired bot name
  • -
  • Select the Select from one of my existing bots option, and find your bot from above in the dropdown.
  • +
  • Select the Select from one of my existing bots option, and find your bot from above in the dropdown.
  • +
+

Set up a bot

+
    +
  • If the drop down does not contains the App Id of the Bot (to be installed), Or if the Select from one of my existing bots option is disabled, select the Connect to a different bot id and paste same App id, provided in App details tab earlier
  • +
+

Connect to a bot id

+
  • Check all options under Calling Bot and Scope
  • Press Save
-

Set up a bot

diff --git a/docs/articles/index.html b/docs/articles/index.html index 1bb88168..9b0aa53c 100644 --- a/docs/articles/index.html +++ b/docs/articles/index.html @@ -84,7 +84,7 @@

Graph Core and Communication

Graph Communications Core SDK

The GraphServiceClient object is the entry point to the Graph Core SDK. The majority of the Graph Core SDK is automatically generated by the Graph SDK generator using the OData resource model. It reflects the REST-ful wire protocol provided by the Graph Communications service.

Graph Communications Stateful SDK and Client Builder

-

The ICommunicationsClient object is the entry point to the Graph Communications SDK and the Calling SDK. This SDK is designed for stateful services and provides additional support on top of the Graph Core SDK for resource state management and media management. The ICommunicationsClientBuilder is the object used to construct a new ICommunicationsClient with the desired settings.

+

The @Microsoft.Graph.Communications.Client.ICommunicationsClient object is the entry point to the Graph Communications SDK and the Calling SDK. This SDK is designed for stateful services and provides additional support on top of the Graph Core SDK for resource state management and media management. The @Microsoft.Graph.Communications.Client.ICommunicationsClientBuilder is the object used to construct a new ICommunicationsClient with the desired settings.

Building media bots has additional considerations which are further outlined in the media section.

Notification Dispatching

Notifications for root collections, such as the ICallCollection generated by ICommunicationsClient.Calls(), are handled in a single queue. Any root resource, such as the ICall, that has been added to the root collection is given it's own queue. Any child resources, of the root resource, such as the ICallParticipant use the same queue as the root resource.

@@ -95,7 +95,7 @@

Example Outgoing Calls

To illustrate functionality of the Graph Communications Calling SDK, the below examples demonstrate 2 common scenarios: how to make an outbound call to a Microsoft Teams user and how to join an existing Microsoft Teams meeting.

Making an Outbound Call

Assuming a bot has been properly registered and deployed, the ICommunicationsClient configured and built.

-

The bot needs to create the Call object with the corresponding parameters and pass the object to the CallCollectionExtensions.AddAsync method as follows:

+

The bot needs to create the Call object with the corresponding parameters and pass the object to the CallCollectionExtensions.AddAsync method as follows:

Call callResource = new Call
 {
   Subject = "**Subject**",
@@ -120,8 +120,8 @@ 

Making an Outbound Call

ICall call = await this.Client.Calls().AddAsync(callResource, mediaSession);

SDK will store the state of the call in memory after calling AddAsync. The returned call object above contains the call Id set by the service.

Making an Outbound Call to Join an Existing Microsoft Teams Meeting

-

The above example shows how to create an outbound call to single or multiple participants and create a new conversation. If the bot needs to join an existing conversation, the SDK provides an overload of AddAsync that takes JoinMeetingParameters as input.

-

The bot needs to create the JoinMeetingParameters object with the corresponding meeting parameters and pass the object to the CallCollectionExtensions.AddAsync method as follows:

+

The above example shows how to create an outbound call to single or multiple participants and create a new conversation. If the bot needs to join an existing conversation, the SDK provides an overload of AddAsync that takes @Microsoft.Graph.Communications.Calls.JoinMeetingParameters as input.

+

The bot needs to create the @Microsoft.Graph.Communications.Calls.JoinMeetingParameters object with the corresponding meeting parameters and pass the object to the CallCollectionExtensions.AddAsync method as follows:

ChatInfo chatInfo = new ChatInfo
 {
   MessageId = "**Message Id**",
@@ -158,7 +158,7 @@ 

Example Incoming Calls

Answering incoming call with application hosted media

First, subscribe to incoming calls.

this.Client.Calls().OnIncoming += this.CallsOnIncoming;
-

When incoming call comes, the bot needs to answer with an IMediaSession. This can be a media session created using the ICommunicationsClient.CreateMediaSession() extension or a custom IMediaSession.

+

When incoming call comes, the bot needs to answer with an IMediaSession. This can be a media session created using the ICommunicationsClient.CreateMediaSession() extension or a custom IMediaSession.

private void CallsOnIncoming(ICallCollection sender, CollectionEventArgs<ICall> collectionEventArgs)
 {
   IMediaSession mediaSession = this.Client.CreateMediaSession(
diff --git a/docs/index.html b/docs/index.html
index 0d7445d4..a32a6225 100644
--- a/docs/index.html
+++ b/docs/index.html
@@ -94,7 +94,7 @@ 

Concepts and Examples

  • Stateful bot using Service Hosted Media running on Azure App Service.
  • ICommunicationsClient and Extension Methods

    -

    The Stateful SDK is exposed using a single class ICommunicationsClient. This class is defined in the Microsoft.Graph.Communications.Client nuget and has no dependency on the Microsoft.Graph.Communications.Calls calling vertical nuget package. The different verticals therefore make heavy usage of extension methods on ICommunicationsClient rather than standalone functions or properties. The intention here is to add new verticals into the ICommunicationsClient using the same pattern without the ICommunicationsClient itself taking a dependency on the new vertical's nuget, which provides greater decoupling between future verticals we will support. For a usage example please see the ICommunicationsClient.Calls() extension method.

    +

    The Stateful SDK is exposed using a single class @Microsoft.Graph.Communications.Client.ICommunicationsClient. This class is defined in the Microsoft.Graph.Communications.Client nuget and has no dependency on the Microsoft.Graph.Communications.Calls calling vertical nuget package. The different verticals therefore make heavy usage of extension methods on ICommunicationsClient rather than standalone functions or properties. The intention here is to add new verticals into the ICommunicationsClient using the same pattern without the ICommunicationsClient itself taking a dependency on the new vertical's nuget, which provides greater decoupling between future verticals we will support. For a usage example please see the ICommunicationsClient.Calls() extension method.

    Accompanying Information

    Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution.

    diff --git a/docs/index.json b/docs/index.json index 69f2c38c..53e7b8a4 100644 --- a/docs/index.json +++ b/docs/index.json @@ -1,1527 +1,1527 @@ { - "bot_media/Microsoft.Skype.Bots.Media.AudioQualityOfExperienceData.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioQualityOfExperienceData.html", - "title": "Class AudioQualityOfExperienceData", - "keywords": "Class AudioQualityOfExperienceData Audio quality of experience data Inheritance Object MediaQualityOfExperienceData AudioQualityOfExperienceData Inherited Members MediaQualityOfExperienceData.NetworkMetrics MediaQualityOfExperienceData.TotalMediaDuration Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioQualityOfExperienceData : MediaQualityOfExperienceData Constructors AudioQualityOfExperienceData() AudioQualityOfExperienceData constructor Declaration public AudioQualityOfExperienceData() Properties AudioMetrics Audio-specific QoE metrics Declaration public AudioMetrics AudioMetrics { get; set; } Property Value Type Description AudioMetrics" + "client/Microsoft.Graph.Communications.Resources.IResourceBase.html": { + "href": "client/Microsoft.Graph.Communications.Resources.IResourceBase.html", + "title": "Interface IResourceBase", + "keywords": "Interface IResourceBase The resource base interface. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResourceBase : IDisposable Properties Client Gets the client. Declaration ICommunicationsClient Client { get; } Property Value Type Description ICommunicationsClient CreatedDateTime Gets the created date time of this resource. Declaration DateTimeOffset CreatedDateTime { get; } Property Value Type Description DateTimeOffset GraphClient Gets the graph client. Declaration IGraphClient GraphClient { get; } Property Value Type Description IGraphClient GraphLogger Gets the graph logger. Declaration IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger ResourcePath Gets the resource path for this collection. Declaration string ResourcePath { get; } Property Value Type Description String See Also IDisposable" }, - "bot_media/Microsoft.Skype.Bots.Media.IAudioSocket.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.IAudioSocket.html", - "title": "Interface IAudioSocket", - "keywords": "Interface IAudioSocket Interface to an AudioSocket. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IAudioSocket : IDisposable Methods GetQualityOfExperienceData() Get the Quality of Experience (QoE) data for the audio socket. Declaration AudioQualityOfExperienceData GetQualityOfExperienceData() Returns Type Description AudioQualityOfExperienceData Remarks The bot should fetch the QoE data no more than once every 30 seconds. To get accurate metrics, the bot should let media flow for at least 30 seconds before fetching the QoE data. Send(AudioMediaBuffer) Sends a frame of audio media, where a frame contains 20 milliseconds of audio content (PCM samples). Declaration void Send(AudioMediaBuffer buffer) Parameters Type Name Description AudioMediaBuffer buffer AudioMediaBuffer containing the frame of audio media to send. Remarks The application must create a concrete class which derives from the AudioMediaBuffer abstract class. The buffer object passed to the Send method is still potentially in-use after the method returns to the caller. The application must not free the buffer's frame data until the the buffer object's Dispose() method is invoked by the Media Platform. The application should be sending 50 frames of audio media per second with each frame containing 20 milliseconds of audio content. The AudioSocket must be enabled to send media via the AudioSocketSettings.StreamDirections property. SendDtmfTone(ToneId) Sends a DTMF tone. Declaration void SendDtmfTone(ToneId tone) Parameters Type Name Description ToneId tone The DTMF digit. Ranges from 0-16. Remarks Sending DTMF tone is only allowed if the AudioSocket is configured for sending media. SendDtmfTones(IEnumerable, Int32) Sends a sequence of DTMF tones with an optional delay between each tone. Declaration void SendDtmfTones(IEnumerable tones, int delayBetweenTonesInMilliseconds = -1) Parameters Type Name Description IEnumerable < ToneId > tones The list of DTMF digits to be sent. Ranges from 0-16. Int32 delayBetweenTonesInMilliseconds Delay (in milliseconds) between each DTMF tone sent. Remarks By default, the delay is set to -1 which picks a random time between 0 to 500 milliseconds. Events AudioMediaReceived If the application has configured the AudioSocket to receive media, this event is raised each time a frame of audio media is received, where a frame contains 20 milliseconds of audio content (PCM samples). Once the application has consumed the buffer, it must call the buffer's Dispose() method. Declaration event EventHandler AudioMediaReceived Event Type Type Description EventHandler < AudioMediaReceivedEventArgs > Remarks The application must be able to handle at least 50 incoming audio buffers per second. Events are serialized, so only one event at a time is raised to the app. The event handler should return as quickly as possible; any time-consuming per-frame processing should be performed asynchronously from the event handler. AudioSendStatusChanged If the application has configured the AudioSocket to send media, this event is raised to inform the application when it may begin sending media and when it should stop. The application cannot send media before receiving a MediaSendStatusChanged event indicating the SendStatus is Started. Declaration event EventHandler AudioSendStatusChanged Event Type Type Description EventHandler < AudioSendStatusChangedEventArgs > DominantSpeakerChanged This event is raised when there is a change in the dominant speaker in the conference. If there is no dominant speaker in the conference, the CurrentDominantSpeaker argument in the event will have the value None (0xFFFFFFFF). Declaration event EventHandler DominantSpeakerChanged Event Type Type Description EventHandler < DominantSpeakerChangedEventArgs > MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > ToneReceived This event is raised when the DTMF tone is received. ToneId enum in the event arguments indicates the tone value. Declaration event EventHandler ToneReceived Event Type Type Description EventHandler < ToneReceivedEventArgs >" + "common/Microsoft.Graph.Communications.Common.AutoClean-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.AutoClean-1.html", + "title": "Class AutoClean", + "keywords": "Class AutoClean Helper class to automatically cleanup but with associated state. Inheritance Object Disposable AutoClean AutoClean Implements IDisposable Inherited Members AutoClean.Dispose(Boolean) Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class AutoClean : AutoClean, IDisposable Type Parameters Name Description T State type. Constructors AutoClean(T, Action) Initializes a new instance of the AutoClean class. Declaration public AutoClean(T t, Action action) Parameters Type Name Description T t Instance of the custom data. Action action Cleanup action. Properties Data Gets the custom data. Declaration public T Data { get; } Property Value Type Description T Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.LowOnFramesEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.LowOnFramesEventArgs.html", - "title": "Class LowOnFramesEventArgs", - "keywords": "Class LowOnFramesEventArgs LowOnFrames event arguments Inheritance Object EventArgs LowOnFramesEventArgs AudioLowOnFramesEventArgs VideoLowOnFramesEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class LowOnFramesEventArgs : EventArgs Constructors LowOnFramesEventArgs() Declaration public LowOnFramesEventArgs() Properties MediaType MediaType of the low on frame event Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType RemainingMediaLengthInMS Remaining enqueued media length in MS Declaration public int RemainingMediaLengthInMS { get; set; } Property Value Type Description Int32" + "common/Microsoft.Graph.Communications.Common.AutoClean.html": { + "href": "common/Microsoft.Graph.Communications.Common.AutoClean.html", + "title": "Class AutoClean", + "keywords": "Class AutoClean Helper class to automatically cleanup. Inheritance Object Disposable AutoClean AutoClean Implements IDisposable Inherited Members Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class AutoClean : Disposable, IDisposable Constructors AutoClean(Action) Initializes a new instance of the AutoClean class. Declaration public AutoClean(Action action) Parameters Type Name Description Action action Cleanup action. Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformSettings.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformSettings.html", - "title": "Class MediaPlatformSettings", - "keywords": "Class MediaPlatformSettings Class that stores settings needed to initialize Bot Media Platform. Inheritance Object MediaPlatformSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class MediaPlatformSettings Constructors MediaPlatformSettings() Declaration public MediaPlatformSettings() Properties ApplicationId String that uniquely identifies the application that initializes the platform. Declaration public string ApplicationId { get; set; } Property Value Type Description String HostingEnvironmentConfiguration Specifies the HostingEnvironmentConfiguration to use for the MediaPlatform. In most cases, the default value is sufficient. Only in Azure Government clouds do different settings need to be applied. Declaration public HostingEnvironmentConfiguration HostingEnvironmentConfiguration { get; set; } Property Value Type Description HostingEnvironmentConfiguration MediaPlatformInstanceSettings The media platform instance settings. Declaration public MediaPlatformInstanceSettings MediaPlatformInstanceSettings { get; set; } Property Value Type Description MediaPlatformInstanceSettings MediaPlatformLogger Optional logger object to receive MediaPlatform traces. Declaration public IMediaPlatformLogger MediaPlatformLogger { get; set; } Property Value Type Description IMediaPlatformLogger RegionAffinity Reserved for the internal use. Declaration public string RegionAffinity { get; set; } Property Value Type Description String" + "client/Microsoft.Graph.Communications.Client.Notifications.FixedSizeQueue-1.html": { + "href": "client/Microsoft.Graph.Communications.Client.Notifications.FixedSizeQueue-1.html", + "title": "Class FixedSizeQueue", + "keywords": "Class FixedSizeQueue A class that implements a fixed size list. Inheritance Object FixedSizeQueue Implements IReadOnlyCollection IEnumerable IEnumerable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client.Notifications Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class FixedSizeQueue : IReadOnlyCollection, IEnumerable, IEnumerable Type Parameters Name Description T The generic type Constructors FixedSizeQueue(Int32) Initializes a new instance of the FixedSizeQueue class. Declaration public FixedSizeQueue(int maxSize) Parameters Type Name Description Int32 maxSize The maximum size. Properties Count Gets the number of elements in the collection. Declaration public int Count { get; } Property Value Type Description Int32 Methods Enqueue(T) Enqueues the item. Declaration public void Enqueue(T item) Parameters Type Name Description T item The object. GetEnumerator() Declaration public IEnumerator GetEnumerator() Returns Type Description IEnumerator Remove(T) Removes the specified item. Declaration public void Remove(T item) Parameters Type Name Description T item The item. Explicit Interface Implementations IEnumerable.GetEnumerator() Declaration IEnumerator IEnumerable.GetEnumerator() Returns Type Description IEnumerator Implements System.Collections.Generic.IReadOnlyCollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable See Also ICollection " }, - "bot_media/Microsoft.Skype.Bots.Media.VideoKeyFrameNeededEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoKeyFrameNeededEventArgs.html", - "title": "Class VideoKeyFrameNeededEventArgs", - "keywords": "Class VideoKeyFrameNeededEventArgs Event arguments of a VideoKeyFrameNeeded event. Inheritance Object EventArgs VideoKeyFrameNeededEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoKeyFrameNeededEventArgs : EventArgs Constructors VideoKeyFrameNeededEventArgs() Declaration public VideoKeyFrameNeededEventArgs() Properties MediaType MediaType of the video buffer. This could be Video or Vbss. Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType SocketId The 0-based ID of the socket that is raising this event. This socket ID can be used in multiview (ie. more than 1 video socket) to determine which video socket is raising this event. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the Microsoft.Skype.Bots.Media.MediaPlatform (or IMediaPlatform) API CreateMediaConfiguration. Eg. If the collection of IVideoSocket objects in the CreateMediaConfiguration API contains { socketA, socketB, socketC }, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Declaration public int SocketId { get; set; } Property Value Type Description Int32 VideoFormats VideoFormats for which keyframe is needed Declaration public VideoFormat[] VideoFormats { get; set; } Property Value Type Description VideoFormat []" + "common/Microsoft.Graph.Communications.Common.CollectionUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.CollectionUtils.html", + "title": "Class CollectionUtils", + "keywords": "Class CollectionUtils Collection Utilities Inheritance Object CollectionUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class CollectionUtils Methods AddRange(ICollection, IEnumerable) Adds the range of source values into target. Declaration public static void AddRange(this ICollection target, IEnumerable source) Parameters Type Name Description ICollection target The target. IEnumerable source The source. Type Parameters Name Description T The type of Collection ForEach(IEnumerable, Action) Analogous to IList.ForEach but for IEnumerable Declaration public static void ForEach(this IEnumerable enumerable, Action action) Parameters Type Name Description IEnumerable enumerable Enumeration Action action Action to invoke on each element Type Parameters Name Description T Element type. ForEachParallel(IEnumerable, Action, IGraphLogger) Analogous to IList.ForEach but for IEnumerable Declaration public static Exception ForEachParallel(this IEnumerable enumerable, Action action, IGraphLogger logger) Parameters Type Name Description IEnumerable enumerable Enumeration Action action Action to invoke on each element IGraphLogger logger Instance of the Logger Returns Type Description Exception Exception if any. Type Parameters Name Description T Element type GetValueOrDefault(IDictionary, TKey) Get Value or default Declaration public static TValue GetValueOrDefault(this IDictionary dictionary, TKey key) Parameters Type Name Description IDictionary dictionary Dictionary instance TKey key Key to lookup Returns Type Description TValue Value from dictionary or default value. Type Parameters Name Description TKey Type of the key TValue Type of the value GetValueOrDefault(IDictionary, TKey, TValue) Get Value or default Declaration public static TValue GetValueOrDefault(this IDictionary dictionary, TKey key, TValue defaultValue) Parameters Type Name Description IDictionary dictionary Dictionary instance TKey key Key to lookup TValue defaultValue The default value to be returned if it doesn't exist. Returns Type Description TValue Value from dictionary or default value. Type Parameters Name Description TKey Type of the key TValue Type of the value ToSortedList(IEnumerable, Func) Converts sequence to a sorted list. Declaration public static SortedList ToSortedList(this IEnumerable sequence, Func keySelector) Parameters Type Name Description IEnumerable sequence The sequence. Func keySelector The function selector which provides a key given the value. Returns Type Description SortedList Sorted list. Type Parameters Name Description TKey The type of the key. TValue The type of the value. TryRemoveAndDispose(ConcurrentDictionary, TKey) Try to remove key from concurrent dictionary and dispose the value. Declaration public static void TryRemoveAndDispose(this ConcurrentDictionary dictionary, TKey key) where TValue : IDisposable Parameters Type Name Description ConcurrentDictionary dictionary Dictionary to clean up TKey key Key to lookup Type Parameters Name Description TKey Key type TValue Value type" }, - "calls/Microsoft.Graph.Communications.Calls.JoinMeetingParameters.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.JoinMeetingParameters.html", - "title": "Class JoinMeetingParameters", - "keywords": "Class JoinMeetingParameters Class to define parameters required for joining a meeting. Inheritance Object JoinMeetingParameters Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public class JoinMeetingParameters Constructors JoinMeetingParameters(ChatInfo, MeetingInfo, IMediaSession) Initializes a new instance of the JoinMeetingParameters class. Use this constructor for app hosted media. Declaration public JoinMeetingParameters(ChatInfo chatInfo, MeetingInfo meetingInfo, IMediaSession mediaSession) Parameters Type Name Description ChatInfo chatInfo The chat information. MeetingInfo meetingInfo The meeting information. IMediaSession mediaSession The media session. JoinMeetingParameters(ChatInfo, MeetingInfo, IEnumerable, IEnumerable) Initializes a new instance of the JoinMeetingParameters class. Use this constructor for service hosted media. Declaration public JoinMeetingParameters(ChatInfo chatInfo, MeetingInfo meetingInfo, IEnumerable requestedModalities, IEnumerable prefetchPrompts = null) Parameters Type Name Description ChatInfo chatInfo The chat information. MeetingInfo meetingInfo The meeting information. IEnumerable < Modality > requestedModalities The list of modalities for the call IEnumerable < MediaInfo > prefetchPrompts The list of media files to prefetch Properties AdditionalData Gets or sets the additional data. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > AllowGuestToBypassLobby Gets or sets a value indicating whether to bypass lobby when joining a group call as guest. Declaration public bool? AllowGuestToBypassLobby { get; set; } Property Value Type Description Nullable < Boolean > ChatInfo Gets the chat information. Declaration public ChatInfo ChatInfo { get; } Property Value Type Description ChatInfo CorrelationId Gets or sets the correlation identifier. Declaration [Obsolete(\"Please use AddAsync(JoinMeetingParameters parameters, Guid scenarioId).\")] public Guid CorrelationId { get; set; } Property Value Type Description Guid GuestIdentity Gets or sets the guest identity. Declaration public Identity GuestIdentity { get; set; } Property Value Type Description Identity MediaSession Gets the media session. Declaration public IMediaSession MediaSession { get; } Property Value Type Description IMediaSession MeetingInfo Gets the meeting information. Declaration public MeetingInfo MeetingInfo { get; } Property Value Type Description MeetingInfo PrefetchPrompts Gets the list of media files to prefetch. Declaration public IEnumerable PrefetchPrompts { get; } Property Value Type Description IEnumerable < MediaInfo > RequestedModalities Gets the list of modalities to join the call with. Declaration public IEnumerable RequestedModalities { get; } Property Value Type Description IEnumerable < Modality > Subject Gets or sets the subject. Declaration public string Subject { get; set; } Property Value Type Description String TenantId Gets or sets the tenant id Declaration public string TenantId { get; set; } Property Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Disposable.html": { + "href": "common/Microsoft.Graph.Communications.Common.Disposable.html", + "title": "Class Disposable", + "keywords": "Class Disposable Common disposable pattern Inheritance Object Disposable AutoClean ObjectRootDisposable Observer SlimLock GraphLogger Implements IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class Disposable : IDisposable Constructors Disposable() Declaration public Disposable() Properties IsDisposed Gets a value indicating whether this instance is disposed. Declaration protected bool IsDisposed { get; } Property Value Type Description Boolean true if this instance is disposed; otherwise, false . Methods Dispose() Dispose resources. Declaration public void Dispose() Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected virtual void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Finalize() Finalizes an instance of the Disposable class. Declaration protected void Finalize() Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.Transport.Http.HttpUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.Http.HttpUtils.html", - "title": "Class HttpUtils", - "keywords": "Class HttpUtils Utilities for Http transport Inheritance Object HttpUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport.Http Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpUtils Methods GetRequestTypeForHttpMethod(String) Gets the type of the request for the given http method. Declaration public static RequestType GetRequestTypeForHttpMethod(string httpMethod) Parameters Type Name Description String httpMethod The HTTP method. Returns Type Description RequestType RequestType corresponding to the httpMethod Exceptions Type Condition InvalidOperationException Thrown if httpMethod has no corresponding RequestType" + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.ContentDispositionFilter.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.ContentDispositionFilter.html", + "title": "Class ContentDispositionFilter", + "keywords": "Class ContentDispositionFilter Does match of content disposition header. If content disposition matches filter then whole body is removed. Inheritance Object BaseFilter BaseFilter < String , String > ContentDispositionFilter Inherited Members BaseFilter.MatchableString BaseFilter.MatchEvaluator Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ContentDispositionFilter : BaseFilter Constructors ContentDispositionFilter(String, Func) Initializes a new instance of the ContentDispositionFilter class. Declaration public ContentDispositionFilter(string matchableString, Func matchEvaluator = null) Parameters Type Name Description String matchableString Name of the matchable content disposition. Func < String , String > matchEvaluator The match evaluator. Methods IsContentDispositionMatch(IEnumerable, HttpContent, out String) Determines whether [is content disposition match] [the specified filters]. Declaration public static bool IsContentDispositionMatch(IEnumerable filters, HttpContent content, out string outputMessage) Parameters Type Name Description IEnumerable < ContentDispositionFilter > filters The filters. HttpContent content The content. String outputMessage The output message. Returns Type Description Boolean true if [is content disposition match] [the specified filters]; otherwise, false . Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.Transport.Http.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.Http.html", - "title": "Namespace Microsoft.Graph.Communications.Common.Transport.Http", - "keywords": "Namespace Microsoft.Graph.Communications.Common.Transport.Http Classes HttpUtils Utilities for Http transport" + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.ContentTypeFilter.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.ContentTypeFilter.html", + "title": "Class ContentTypeFilter", + "keywords": "Class ContentTypeFilter Does match of content-type header. If content-type matches filter then whole body is removed. Inheritance Object BaseFilter BaseFilter < String , String > ContentTypeFilter Inherited Members BaseFilter.MatchableString BaseFilter.MatchEvaluator Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ContentTypeFilter : BaseFilter Constructors ContentTypeFilter(String, Func) Initializes a new instance of the ContentTypeFilter class. Declaration public ContentTypeFilter(string matchableContentTypeMediaType, Func matchEvaluator = null) Parameters Type Name Description String matchableContentTypeMediaType Type of the matchable content type media. Func < String , String > matchEvaluator The match evaluator. Methods IsContentTypeMatch(IEnumerable, HttpContent, out String) Determines whether [is content type match] [the specified filters]. Declaration public static bool IsContentTypeMatch(IEnumerable filters, HttpContent content, out string outputMessage) Parameters Type Name Description IEnumerable < ContentTypeFilter > filters The filters. HttpContent content The content. String outputMessage The output message. Returns Type Description Boolean true if [is content type match] [the specified filters]; otherwise, false . Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.Communications.Core.Notifications.FailedNotificationEventArgs.html": { - "href": "core/Microsoft.Graph.Communications.Core.Notifications.FailedNotificationEventArgs.html", - "title": "Class FailedNotificationEventArgs", - "keywords": "Class FailedNotificationEventArgs Event arguments used when exceptions are raised in callbacks. Inheritance Object FailedNotificationEventArgs Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class FailedNotificationEventArgs Constructors FailedNotificationEventArgs(NotificationEventArgs, Exception) Initializes a new instance of the FailedNotificationEventArgs class. Declaration public FailedNotificationEventArgs(NotificationEventArgs notification, Exception exception) Parameters Type Name Description NotificationEventArgs notification The NotificationEventArgs instance containing the event data. Exception exception The exception. Properties Exception Gets the exception being raised. Declaration public Exception Exception { get; } Property Value Type Description Exception Notification Gets the notification that was being processed while this callback failed. Declaration public NotificationEventArgs Notification { get; } Property Value Type Description NotificationEventArgs" + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.HeaderFilter.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.HeaderFilter.html", + "title": "Class HeaderFilter", + "keywords": "Class HeaderFilter Header filters act as whitelists. Inheritance Object BaseFilter BaseFilter < IEnumerable < String >, String > HeaderFilter Inherited Members BaseFilter, String>.MatchableString BaseFilter, String>.MatchEvaluator Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class HeaderFilter : BaseFilter, string> Constructors HeaderFilter(String) Initializes a new instance of the HeaderFilter class. Declaration public HeaderFilter(string matchableHeaderName) Parameters Type Name Description String matchableHeaderName Name of the matchable header. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.HighResolutionDateTime.html": { - "href": "common/Microsoft.Graph.Communications.Common.HighResolutionDateTime.html", - "title": "Class HighResolutionDateTime", - "keywords": "Class HighResolutionDateTime High resolution datetime Inheritance Object HighResolutionDateTime Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HighResolutionDateTime Properties IsAvailable Gets a value indicating whether high resolution datetime is available Declaration public static bool IsAvailable { get; } Property Value Type Description Boolean UtcNow Gets UTC now Declaration public static DateTime UtcNow { get; } Property Value Type Description DateTime" + "common/Microsoft.Graph.Communications.Common.Transport.GraphRequest.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphRequest.html", + "title": "Class GraphRequest", + "keywords": "Class GraphRequest Inheritance Object GraphRequest < NoContentMessage > GraphRequest Implements IGraphRequest IGraphRequest < NoContentMessage > IGraphExchange < NoContentMessage > IGraphExchange Inherited Members GraphRequest.ToString() GraphRequest.Content GraphRequest.Properties GraphRequest.Uri GraphRequest.RequestType Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphRequest : GraphRequest, IGraphRequest, IGraphRequest, IGraphExchange, IGraphExchange Constructors GraphRequest(IGraphRequest) Initializes a new instance of the GraphRequest class. Declaration public GraphRequest(IGraphRequest graphRequest) Parameters Type Name Description IGraphRequest < NoContentMessage > graphRequest The graph request. GraphRequest(Uri, RequestType) Initializes a new instance of the GraphRequest class. Create the graph request object Declaration public GraphRequest(Uri location, RequestType requestType) Parameters Type Name Description Uri location The uri location for the request. RequestType requestType Type of the request. Implements IGraphRequest IGraphRequest IGraphExchange IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphRequestExtensions.ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable)" }, - "bot_media/Microsoft.Skype.Bots.Media.VideoSendCapability.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSendCapability.html", - "title": "Class VideoSendCapability", - "keywords": "Class VideoSendCapability The Video Send Capability Inheritance Object VideoSendCapability Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoSendCapability Constructors VideoSendCapability() Declaration public VideoSendCapability() Properties MaxConcurrentSendStreams Maximum number of concurrent streams that can be sent. Declaration public uint MaxConcurrentSendStreams { get; set; } Property Value Type Description UInt32 SupportedSendVideoFormats The list of video formats the VideoSocket supports sending. Declaration public IList SupportedSendVideoFormats { get; set; } Property Value Type Description IList < VideoFormat > Remarks For the main-video modality ( MediaType.Video ), the following ten H264 send video formats are supported: H264_1920x1080_30Fps H264_1280x720_30Fps H264_960x540_30Fps H264_640x360_30Fps H264_640x360_15Fps H264_424x240_15Fps H264_320x180_15Fps H264_320x180_7_5Fps H264_320x180_3_75Fps H264_320x180_1_875Fps (If the SupportedSendVideoFormats list contains other H264 video formats for main-video, they will be ignored and not used.) At least one of the H264_320x180 video formats must be supported. For best video interoperability, the bot should support all the H264_320x180 formats. For the Vbss modality, all of the send formats must be of the same resolution. The resolution should best match the native resolution of the content to be shared. Downscaling the Vbss content to a lower resolution should be avoided (but may be necessary if the native content resolution is larger than 1080p). The bot should support as many different frame rates as possible. The 1.875 fps frame rate must be supported. Methods ToString() String representation of VideoSendCapability Declaration public override string ToString() Returns Type Description String Overrides Object.ToString()" + "common/Microsoft.Graph.Communications.Common.Transport.GraphResponse-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphResponse-1.html", + "title": "Class GraphResponse", + "keywords": "Class GraphResponse The base of the exchange of a IGraphRequest or IGraphResponse . Inheritance Object GraphResponse GraphResponse Implements IGraphResponse IGraphExchange IGraphExchange Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphResponse : IGraphResponse, IGraphExchange, IGraphExchange Type Parameters Name Description T Constructors GraphResponse(T, ResponseStatus) Initializes a new instance of the GraphResponse class. Create a new graph response Declaration public GraphResponse(T content, ResponseStatus status) Parameters Type Name Description T content The serialized content of the response. ResponseStatus status Status indicating success/failure/other for the response. GraphResponse(String, ResponseStatus, String) Initializes a new instance of the GraphResponse class. Declaration public GraphResponse(string errorContent, ResponseStatus status, string reasonPhrase) Parameters Type Name Description String errorContent Content of the error. ResponseStatus status The status. String reasonPhrase The reason phrase. Properties Content Declaration public T Content { get; set; } Property Value Type Description T ErrorContent Declaration public string ErrorContent { get; set; } Property Value Type Description String Properties Gets the properties of the exchange. Declaration public ICollection Properties { get; } Property Value Type Description ICollection < IGraphProperty > ReasonPhrase Declaration public string ReasonPhrase { get; set; } Property Value Type Description String Status Declaration public ResponseStatus Status { get; } Property Value Type Description ResponseStatus Methods ToString() Declaration public override string ToString() Returns Type Description String Overrides Object.ToString() Implements IGraphResponse IGraphExchange IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphResponseExtensions.ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable)" }, - "bot_media/Microsoft.Skype.Bots.Media.VideoSendStatusChangedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSendStatusChangedEventArgs.html", - "title": "Class VideoSendStatusChangedEventArgs", - "keywords": "Class VideoSendStatusChangedEventArgs Event arguments of a VideoSendStatusChanged event. Inheritance Object EventArgs VideoSendStatusChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoSendStatusChangedEventArgs : EventArgs Constructors VideoSendStatusChangedEventArgs() Declaration public VideoSendStatusChangedEventArgs() Properties MediaSendStatus The media send status. Declaration public MediaSendStatus MediaSendStatus { get; set; } Property Value Type Description MediaSendStatus MediaType MediaType of the video socket raising the event. This could be Video or Vbss. Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType PreferredEncodedVideoSourceFormats The preferred video source format if encoded video is sent. Declaration public VideoFormat[] PreferredEncodedVideoSourceFormats { get; set; } Property Value Type Description VideoFormat [] PreferredVideoSourceFormat The preferred video source format if raw video is sent. Declaration public VideoFormat PreferredVideoSourceFormat { get; set; } Property Value Type Description VideoFormat SocketId The 0-based ID of the socket that is raising this event. This socket ID can be used in multiview (ie. more than 1 video socket) to determine which video socket is raising this event. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the Microsoft.Skype.Bots.Media.MediaPlatform (or IMediaPlatform) API CreateMediaConfiguration. Eg. If the collection of IVideoSocket objects in the CreateMediaConfiguration API contains { socketA, socketB, socketC }, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Declaration public int SocketId { get; set; } Property Value Type Description Int32" + "common/Microsoft.Graph.Communications.Common.Transport.GraphResponse.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphResponse.html", + "title": "Class GraphResponse", + "keywords": "Class GraphResponse Inheritance Object GraphResponse < NoContentMessage > GraphResponse Implements IGraphResponse IGraphResponse < NoContentMessage > IGraphExchange < NoContentMessage > IGraphExchange Inherited Members GraphResponse.ToString() GraphResponse.Content GraphResponse.Properties GraphResponse.ReasonPhrase GraphResponse.ErrorContent GraphResponse.Status Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphResponse : GraphResponse, IGraphResponse, IGraphResponse, IGraphExchange, IGraphExchange Constructors GraphResponse(IGraphResponse) Initializes a new instance of the GraphResponse class. This is a copy constructor. Declaration public GraphResponse(IGraphResponse response) Parameters Type Name Description IGraphResponse < NoContentMessage > response The response to be used to create a new instance. GraphResponse(ResponseStatus) Initializes a new instance of the GraphResponse class. Create a new graph response Declaration public GraphResponse(ResponseStatus status) Parameters Type Name Description ResponseStatus status Status indicating success/failure/other for the response. GraphResponse(String, ResponseStatus, String) Initializes a new instance of the GraphResponse class. Declaration public GraphResponse(string errorContent, ResponseStatus status, string reasonPhrase) Parameters Type Name Description String errorContent Content of the error. ResponseStatus status The status. String reasonPhrase The reason phrase. Implements IGraphResponse IGraphResponse IGraphExchange IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphResponseExtensions.ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable)" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaSession.MediaProperties.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaSession.MediaProperties.html", - "title": "Class MediaSession.MediaProperties", - "keywords": "Class MediaSession.MediaProperties Gets the media properties. Inheritance Object MediaSession.MediaProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public class MediaProperties Constructors MediaProperties() Declaration public MediaProperties() Properties MediaSessionId Gets or sets the media session identifier. Declaration public Guid MediaSessionId { get; set; } Property Value Type Description Guid" + "core/Microsoft.Graph.Communications.Core.Exceptions.ServiceException.html": { + "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ServiceException.html", + "title": "Class ServiceException", + "keywords": "Class ServiceException A Service Exception. Inheritance Object ServiceException Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax [Obsolete(\"Deprecated, please use Microsoft.Graph.ServiceException instead.\")] public class ServiceException : ServiceException Constructors ServiceException(Error, Exception) Initializes a new instance of the ServiceException class. Declaration [Obsolete(\"Deprecated, please use Microsoft.Graph.ServiceException instead.\")] public ServiceException(Error error = null, Exception innerException = null) Parameters Type Name Description Error error The error. Exception innerException The inner exception. ServiceException(Error, HttpResponseHeaders, HttpStatusCode, Exception) Initializes a new instance of the ServiceException class. Declaration [Obsolete(\"Deprecated, please use Microsoft.Graph.ServiceException instead.\")] public ServiceException(Error error, HttpResponseHeaders responseHeaders, HttpStatusCode statusCode, Exception innerException = null) Parameters Type Name Description Error error The error. HttpResponseHeaders responseHeaders The response headers. HttpStatusCode statusCode The status code. Exception innerException The inner exception. See Also ServiceException" }, - "core/Microsoft.Graph.Communications.Core.GraphModelExtensions.html": { - "href": "core/Microsoft.Graph.Communications.Core.GraphModelExtensions.html", - "title": "Class GraphModelExtensions", - "keywords": "Class GraphModelExtensions Generic graph model extensions. Inheritance Object GraphModelExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class GraphModelExtensions Methods FixModel(Object) Fixes the model to match latest protocol. Declaration public static void FixModel(object object) Parameters Type Name Description Object object The object." + "articles/calls/calling-notifications.html": { + "href": "articles/calls/calling-notifications.html", + "title": "Notifications in Calling", + "keywords": "Notifications in Calling Refer to Registering a Calling Bot on how to register the callback URL. This callback is used for all incoming calls to the application. Protocol determination The incoming notification is provided in legacy format for compatibility with the previous protocol . In order to convert the call to the Microsoft Graph protocol, the bot must determine the notification is in legacy format and reply with: HTTP/1.1 204 No Content The application will again receive the notification but this time it will be in the Microsoft Graph protocol. You may configure the protocol your application supports and avoid receiving the initial callback in legacy format. The setting is available as a configuration option in the Skype Channel. Redirects for region affinity We will invoke your callback from the data-center hosting the call. The call may start in any data-center and does not take into account region affinities. The notification will be sent to your deployment depending on the GeoDNS resolution. If your application determines, by inspecting the initial notification payload or otherwise, that it needs to run in a different deployment, the application may reply with: HTTP/1.1 302 Found Location: your-new-location You may decide to pickup the call and answer . You can specify the callback URL to handle this particular call. This is useful for stateful instances where your call is handled by a particular partition and you want to embed this information on the callback URL for routing to the right instance. Authenticating the callback Application should inspect the token passed by on the notification to validate the request. Whenever the API raises a web hook event, the API gets an OAUTH token from us, with audience as the application's App ID and adds it in the Authorization header as a Bearer token. The application is expected to validate this token before accepting the callback request. POST https://bot.contoso.com/api/calls Content-Type: application/json Authentication: Bearer \"value\": [ \"subscriptionId\": \"2887CEE8344B47C291F1AF628599A93C\", \"subscriptionExpirationDateTime\": \"2016-11-20T18:23:45.9356913Z\", \"changeType\": \"updated\", \"resource\": \"/app/calls/8A934F51F25B4EE19613D4049491857B\", \"resourceData\": { \"@odata.type\": \"#microsoft.graph.call\", \"state\": \"Established\" } ] The OAUTH token would have values like the following, and will be signed by us. The openid configuration published at https://api.aps.skype.com/v1/.well-known/OpenIdConfiguration can be used to verify the token. { \"aud\": \"0efc74f7-41c3-47a4-8775-7259bfef4241\", \"iss\": \"https://api.botframework.com\", \"iat\": 1466741440, \"nbf\": 1466741440, \"exp\": 1466745340, \"tid\": \"1fdd12d0-4620-44ed-baec-459b611f84b2\" } aud audience is the App ID URI specified for the application. tid is the tenant id for contoso iss is the token issuer, https://api.botframework.com The listener interface on the web hook URL can validate the token, ensure it has not expired, checking whether it has been signed by our published openid configuration. You must also check whether audience matches your App ID before accepting the callback request. Sample shows how to validate inbound requests. Additional information You can read more about AAD tokens and Validation" }, - "calls/Microsoft.Graph.Communications.Calls.ParticipantExtensions.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.ParticipantExtensions.html", - "title": "Class ParticipantExtensions", - "keywords": "Class ParticipantExtensions Extensions for the stateful participant resource. Inheritance Object ParticipantExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public static class ParticipantExtensions Methods InviteAsync(IParticipantCollection, IdentitySet, String, CancellationToken) Invite a participant into the existing call. Declaration public static Task InviteAsync(this IParticipantCollection participantCollection, IdentitySet identitySet, string replacesCallId = null, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description IParticipantCollection participantCollection The participant collection into which a new participant is being invited. IdentitySet identitySet The identity set of the invited participant. String replacesCallId The replaces call identifier. This is an optional field used for consultative transfer. This is used to bring a participant from an existing call. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the participant has joined. Any updates on the participant collection will be delivered via notification and can be observed using IParticipantCollection.OnUpdated Exceptions Type Condition ArgumentNullException If IdentitySet is null." + "articles/calls/register-calling-bot.html": { + "href": "articles/calls/register-calling-bot.html", + "title": "Registering a calling bot", + "keywords": "Registering a calling bot In this topic you will learn how to register a new Calling Bot. Register your bot in the Azure Bot Service Complete the following steps: Register a bot by creating a Bot Channels Registration through Azure Bot Channel Registration . Once you complete the registration, take a note of the registered config values (Bot Name, Application Id, and Application Secret). You will need these values later in the code samples. In the resource blade, click Channels . Enable the Microsoft Teams channel and enable calling on the Calling tab. Fill in the Webhook (for calling) where you will receive incoming notifications. E.g. https://{your domain}/api/calls . Refer to Connect a bot to channels for more information on how to configure channels. Permissions Add Microsoft Graph permissions for calling to your bot Microsoft Graph exposes granular permissions controlling the access apps have to resources. As a developer, you decide which permissions for Microsoft Graph your app requests. The Microsoft Graph Communications Calling APIs support Application permissions, which are used by apps that run without a signed-in user present; for example, apps that run as background services or bots. Application permissions can only be consented by a tenant administrator. Calling bots and applications have some capabilties that will need tenant administrator consent. Below is a list of those permissions: Permission Display String Description Admin Consent Required Calls.Initiate.All Initiate outgoing 1:1 calls from the app (preview) Allows the app to place outbound calls to a single user and transfer calls to users in your organization's directory, without a signed-in user. Yes Calls.InitiateGroupCall.All Initiate outgoing group calls from the app (preview) Allows the app to place outbound calls to multiple users and add participants to meetings in your organization, without a signed-in user. Yes Calls.JoinGroupCall.All Join Group Calls and Meetings as an app (preview) Allows the app to join group calls and scheduled meetings in your organization, without a signed-in user. The app will be joined with the privileges of a directory user to meetings in your tenant. Yes Calls.JoinGroupCallasGuest.All Join Group Calls and Meetings as a guest (preview) Allows the app to anonymously join group calls and scheduled meetings in your organization, without a signed-in user. The app will be joined as a guest to meetings in your tenant. Yes Calls.AccessMedia.All *see below* Access media streams in a call as an app (preview) Allows the app to get direct access to participant media streams in a call, without a signed-in user. Yes Important: You may not use the Microsoft.Graph.Calls.Media API to record or otherwise persist media content from calls or meetings that your bot accesses. Assigning permissions You pre-configure the application permissions your app needs when you register your app. To add permissions from the Azure Bot Registration Portal: From the Settings blade, click Manage . This is the link appearing by the Microsoft App ID . This link will open a window where you can click on API permissions and then click Add a permission in the right pane. Select Microsoft Graph , choose Application Permissions and then select the permissions your app requires in the Select Permissions dialog. Getting administrator consent An administrator can either consent to these permissions using the Azure portal when your app is installed in their organization, or you can provide a sign-up experience in your app through which administrators can consent to the permissions you configured. Once administrator consent is recorded by Azure AD, your app can request tokens without having to request consent again. You can rely on an administrator to grant the permissions your app needs at the Azure portal , but often a better option is to provide a sign-up experience for administrators by using the Azure AD v2.0 /adminconsent endpoint. Please refer to the instructions on constructing an Admin Consent URL for more detail. Note : Constructing the Tenant Admin Consent URL requires a configured Redirect URI/Reply URL in the App Registration Portal . To add reply URLs for your bot, access your bot registration, choose Advanced Options > Edit Application Manifest. Add your Redirect URI to the field replyURLs. Important : Any time you make a change to the configured permissions, you must also repeat the Admin Consent process. Changes made in the app registration portal will not be reflected until consent has been reapplied by the tenant's administrator. Register bot in Microsoft Teams The code samples can be used in combination with a Microsoft Teams App Manifest settings to add the Calling and Video buttons for a 1:1 bot interaction. To develop calling bot, add 'supportsCalling' and 'supportsVideo' boolean properties to the bots section in the app manifest and the bot is all set to receive calls once installed (either to a personal context or a team). App Manifests can be uploaded through the App Studio in the Microsoft Teams client. In the Teams client, select Apps from the left pane and then select App Studio . From the top pane, click Manifest editor and then Create a new app from the left pane. In the App details tab, provide the basic information. And make sure to update App Id correctly. Navigate to the Capabilities section, and select the Bots tab. Then select Set Up in the right pane. Fill in the desired bot name Select the Select from one of my existing bots option, and find your bot from above in the dropdown. If the drop down does not contains the App Id of the Bot (to be installed), Or if the Select from one of my existing bots option is disabled, select the Connect to a different bot id and paste same App id, provided in App details tab earlier Check all options under Calling Bot and Scope Press Save" }, - "calls/Microsoft.Graph.Communications.Calls.PlayOperationResult.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.PlayOperationResult.html", - "title": "Class PlayOperationResult", - "keywords": "Class PlayOperationResult Class to define parameters required for joining a meeting. Inheritance Object PlayOperationResult Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public class PlayOperationResult Constructors PlayOperationResult(ResultInfo) Initializes a new instance of the PlayOperationResult class. Declaration public PlayOperationResult(ResultInfo resultInfo) Parameters Type Name Description ResultInfo resultInfo The result information. Properties ResultInfo Gets the result information. Declaration public ResultInfo ResultInfo { get; } Property Value Type Description ResultInfo The result information." + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.HashingObfuscationEngine.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.HashingObfuscationEngine.html", + "title": "Class HashingObfuscationEngine", + "keywords": "Class HashingObfuscationEngine Obfuscation engine that hashes PII using salt. Inheritance Object HashingObfuscationEngine Implements IObfuscationEngine Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class HashingObfuscationEngine : IObfuscationEngine Constructors HashingObfuscationEngine(Func) Initializes a new instance of the HashingObfuscationEngine class. Declaration public HashingObfuscationEngine(Func saltProvider) Parameters Type Name Description Func < Byte []> saltProvider The salt provider. Properties Enabled Gets a value indicating whether obfuscation is enabled. Declaration public bool Enabled { get; } Property Value Type Description Boolean HashAlgorithm Gets or sets the hash algorithm. Declaration public HashAlgorithm HashAlgorithm { get; set; } Property Value Type Description HashAlgorithm HashLength Gets or sets the length of the hashed payload. Set this to -1 for full salt. Declaration public int HashLength { get; set; } Property Value Type Description Int32 ObfuscationConfiguration Gets or sets the obfuscation configuration. This is also set when configuration is linked to an obfuscation engine. Declaration public ObfuscationConfiguration ObfuscationConfiguration { get; set; } Property Value Type Description ObfuscationConfiguration SaltProvider Gets or sets the salt provider. Declaration protected Func SaltProvider { get; set; } Property Value Type Description Func < Byte []> Methods Obfuscate(Object, ObfuscationTag) Obfuscates the specified payload. Declaration public string Obfuscate(object payload, ObfuscationTag obfuscationTag) Parameters Type Name Description Object payload The payload. ObfuscationTag obfuscationTag The obfuscation tag. Returns Type Description String Obfuscated data. Implements IObfuscationEngine Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "client/Microsoft.Graph.Communications.Resources.CollectionEventHandler-2.html": { - "href": "client/Microsoft.Graph.Communications.Resources.CollectionEventHandler-2.html", - "title": "Delegate CollectionEventHandler", - "keywords": "Delegate CollectionEventHandler The call collection event handler delegate. Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public delegate void CollectionEventHandler(TSender sender, CollectionEventArgs e); Parameters Type Name Description TSender sender The sender. CollectionEventArgs e The event arguments. Type Parameters Name Description TSender The type of the sender. TEntity The type of the arguments. Constructors CollectionEventHandler(Object, IntPtr) Declaration public CollectionEventHandler(object object, IntPtr method) Parameters Type Name Description Object object IntPtr method Methods BeginInvoke(TSender, CollectionEventArgs, AsyncCallback, Object) Declaration public virtual IAsyncResult BeginInvoke(TSender sender, CollectionEventArgs e, AsyncCallback callback, object object) Parameters Type Name Description TSender sender CollectionEventArgs e AsyncCallback callback Object object Returns Type Description IAsyncResult EndInvoke(IAsyncResult) Declaration public virtual void EndInvoke(IAsyncResult result) Parameters Type Name Description IAsyncResult result Invoke(TSender, CollectionEventArgs) Declaration public virtual void Invoke(TSender sender, CollectionEventArgs e) Parameters Type Name Description TSender sender CollectionEventArgs e" + "common/Microsoft.Graph.Communications.Common.Transport.IGraphProperty.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphProperty.html", + "title": "Interface IGraphProperty", + "keywords": "Interface IGraphProperty The graph property containing request or response data. Inherited Members IEquatable.Equals(IGraphProperty) Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphProperty : IEquatable Properties Key Gets the key. Declaration string Key { get; } Property Value Type Description String Type Gets the type of the property. Declaration string Type { get; } Property Value Type Description String Value Gets the value. Declaration object Value { get; } Property Value Type Description Object Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphProperty.ConvertProperty(IGraphProperty)" }, - "calls/Microsoft.Graph.Communications.Calls.IMediaSession.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.IMediaSession.html", - "title": "Interface IMediaSession", - "keywords": "Interface IMediaSession The IMediaSession interface. For local media scenarios, this session object represents the modalities and the media configuration. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface IMediaSession : IDisposable Properties MediaSessionId Gets the id of this media session. Declaration Guid MediaSessionId { get; } Property Value Type Description Guid Modalities Gets the supported modalities Declaration Modality[] Modalities { get; } Property Value Type Description Modality [] Methods GetMediaConfiguration() Get the media configuration Declaration JObject GetMediaConfiguration() Returns Type Description Newtonsoft.Json.Linq.JObject A Newtonsoft.Json.Linq.JObject produced by the Media library." + "common/Microsoft.Graph.Communications.Common.Transport.IGraphRequest-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphRequest-1.html", + "title": "Interface IGraphRequest", + "keywords": "Interface IGraphRequest The request object with content. Inherited Members IGraphExchange.Content IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphRequest : IGraphExchange, IGraphExchange Type Parameters Name Description T Type of data to be sent as part of request body. Properties RequestType Gets the type of the request. Declaration RequestType RequestType { get; } Property Value Type Description RequestType The type of the request. Uri Gets the URI location for the request. Declaration Uri Uri { get; } Property Value Type Description Uri The URI. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphRequestExtensions.ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable) See Also IGraphExchange " }, - "client/Microsoft.Graph.Communications.Client.Authentication.IRequestAuthenticationProvider.html": { - "href": "client/Microsoft.Graph.Communications.Client.Authentication.IRequestAuthenticationProvider.html", - "title": "Interface IRequestAuthenticationProvider", - "keywords": "Interface IRequestAuthenticationProvider The authentication provider interface. This is used to authenticate Inbound requests from Microsoft Graph. It validates the request was issued by Microsoft Graph. Outbound requests to Microsoft Graph. Tenant token is acquired to provide Microsoft Graph the permissions the bot has been consented by the tenant admin Namespace : Microsoft.Graph.Communications.Client.Authentication Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IRequestAuthenticationProvider Methods AuthenticateOutboundRequestAsync(HttpRequestMessage, String) Authenticates the specified request message. This method will be called any time there is an outbound request. This method should add any required headers for authentication (eg: Authorization). Declaration Task AuthenticateOutboundRequestAsync(HttpRequestMessage request, string tenant) Parameters Type Name Description HttpRequestMessage request The outbound http request object. String tenant The tenant for which this request belongs to. Returns Type Description Task The Task . SDK awaits on this task to make sure the bot has included the required headers. ValidateInboundRequestAsync(HttpRequestMessage) Validates the inbound request. This method will be called any time we have an incoming request. Returning IsValid false will result in a Forbidden response being created. SDK waits until a successful validation is returned along with tenant data in RequestValidationResult to fire any events. Declaration Task ValidateInboundRequestAsync(HttpRequestMessage request) Parameters Type Name Description HttpRequestMessage request The incoming request. Returns Type Description Task < RequestValidationResult > The RequestValidationResult structure." + "common/Microsoft.Graph.Communications.Common.Transport.IGraphRequest.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphRequest.html", + "title": "Interface IGraphRequest", + "keywords": "Interface IGraphRequest The request object used by the graph sdk. Inherited Members IGraphRequest.Uri IGraphRequest.RequestType IGraphExchange.Content IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphRequest : IGraphRequest, IGraphExchange, IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphRequestExtensions.ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable)" }, - "bot_media/Microsoft.Skype.Bots.Media.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.html", - "title": "Namespace Microsoft.Skype.Bots.Media", - "keywords": "Namespace Microsoft.Skype.Bots.Media Classes AudioLowOnFramesEventArgs Audio low on frame event args AudioMediaBuffer Represents an unmanaged buffer containing audio media data. AudioMediaReceivedEventArgs Event arguments of an AudioMediaReceived event. AudioMetrics Audio-specific QoE metrics AudioQualityOfExperienceData Audio quality of experience data AudioSendStatusChangedEventArgs Event arguments of an AudioSendStatusChanged event. AudioSettings Audio frame player settings AudioSocket Provides Send and Receive I/O access to an audio stream. AudioSocketSettings The settings to initialize the AudioSocket. AudioVideoFramePlayer AudioVideoFramePlayer is responsible for streaming real time audio and video buffers. This frame player will handle audio and video sync from the audio and video buffer's timestamps AudioVideoFramePlayerSettings AudioVideoFramePlayer settings. This will help configure the player settings. DataMediaBuffer Reserved for the internal use. DataMediaReceivedEventArgs Reserved for the internal use. DataSendStatusChangedEventArgs Reserved for the internal use. DataSocket Reserved for the internal use. DataSocketSettings Reserved for the internal use. DominantSpeakerChangedEventArgs Event arguments of the DominantSpeakerChanged event. LowOnFramesEventArgs LowOnFrames event arguments MediaPlatform This class represents the Skype Bots Media Platform. MediaPlatformFactory MediaPlatformFactory that is used to create IMediaPlatform. MediaPlatformHealthChangedEventArgs Event arguments of the MediaPlatformHealthChangedEvent providing the current and previous health status of the media platform. MediaPlatformInstanceSettings Class that stores the settings of the Azure instance hosting the Bot Media Platform. MediaPlatformSettings Class that stores settings needed to initialize Bot Media Platform. MediaQualityOfExperienceData Media quality of experience (QoE) data MediaStreamFailureEventArgs Event arguments of the MediaStreamFailure event. NetworkMetrics QoE network level metrics PerfCounterConfiguration Perf counter configuration PortRange The Port range SkypeMediaException Root class for the exceptions that are specific to the Skype Media Bots SDK, ie. exceptions other than the standard .NET Framework exceptions. ToneReceivedEventArgs Event arguments of the ToneReceived event. VideoFormat VideoFormat VideoKeyFrameNeededEventArgs Event arguments of a VideoKeyFrameNeeded event. VideoLowOnFramesEventArgs Video low on frame event args VideoMediaBuffer Represents an unmanaged buffer containing video media data. VideoMediaReceivedEventArgs Event arguments of a VideoMediaReceived event. VideoMediaStreamQualityChangedEventArgs Event arguments of the video media stream quality event. VideoMetrics Video-specific quality of experience metrics VideoQualityOfExperienceData Video quality of experience data VideoReceiveStatusChangedEventArgs Event arguments of a VideoReceiveStatusChanged event. VideoSendCapability The Video Send Capability VideoSendStatusChangedEventArgs Event arguments of a VideoSendStatusChanged event. VideoSettings Video Frame player settings VideoSocket Provides Send and Receive I/O access to a video stream. VideoSocketSettings The video socket settings. Structs UnmixedAudioBuffer Represents an unmanaged audio buffer containing unmixed data corresponding to a specific speaker in a conference. This structure contains a pointer to the unmanaged audio buffer, the length of the buffer and the ID of the audio source of the active speaker. Interfaces IAudioSocket Interface to an AudioSocket. IAudioVideoFramePlayer Interface for the AudioVideoFramePlayer responsible for streaming real time audio video IDataSocket Reserved for the internal use. IMediaPlatform Interface to the MediaPlatform. IMediaPlatformLogger Interface for collecting MediaPlatform logs from the Bots.Media library. IVideoSocket Interface to a VideoSocket. Enums AudioFormat The audio format. DataType Reserved for internal use. HostingEnvironmentConfiguration HostingEnvironmentConfiguration to use for the MediaPlatform. In most cases, the default value is correct. Only in Azure Government clouds do different settings need to be applied. LogLevel Specifies a current logging level for a log line. MediaPlatformHealthStatus Health status of the media platform MediaQualityState Indicates the media quality state MediaReceiveStatus Indicates if the VideoSocket is capable of receiving media. MediaSendStatus Indicates whether an AudioSocket or VideoSocket is capable of sending media. MediaType Indicates the media type of the socket. StreamDirection Stream directionality, from the point-of-view of the local media endpoint. ToneId DTMF Tone Id enum. VideoColorFormat VideoColorFormat VideoQualityType Type of the video media quality VideoResolution Video resolution for vbss and video VideoSinkEncodingFormat VideoSinkEncodingFormats" + "common/Microsoft.Graph.Communications.Common.Transport.IGraphResponse-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphResponse-1.html", + "title": "Interface IGraphResponse", + "keywords": "Interface IGraphResponse The response got in exchange of a IGraphRequest . Inherited Members IGraphExchange.Content IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphResponse : IGraphExchange, IGraphExchange Type Parameters Name Description T Type of the body of response. Properties ErrorContent Gets the content of the error. Declaration string ErrorContent { get; } Property Value Type Description String ReasonPhrase Gets the reason phrase. Declaration string ReasonPhrase { get; } Property Value Type Description String Status Gets the status of response. Declaration ResponseStatus Status { get; } Property Value Type Description ResponseStatus Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphResponseExtensions.ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable) See Also IGraphExchange " }, - "calls/Microsoft.Graph.Communications.Calls.RecordOperationResult.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.RecordOperationResult.html", - "title": "Class RecordOperationResult", - "keywords": "Class RecordOperationResult Class to define parameters required for joining a meeting. Inheritance Object RecordOperationResult Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public class RecordOperationResult Constructors RecordOperationResult(String, String, ResultInfo) Initializes a new instance of the RecordOperationResult class. Declaration public RecordOperationResult(string recordingLocation, string recordingAccessToken, ResultInfo resultInfo) Parameters Type Name Description String recordingLocation The location of the recording. String recordingAccessToken Token to access the recording. ResultInfo resultInfo The result information. Properties RecordingAccessToken Gets the recording access token required to retrieve the recording. Declaration public string RecordingAccessToken { get; } Property Value Type Description String RecordingLocation Gets the recording location. Link to the \"live raw stream as it is being recorded\" or \"recorded stream after it’s recorded\". Client need to call GET request on this link passing RecordingAccessToken as bearer token in order to download the stream. Declaration public string RecordingLocation { get; } Property Value Type Description String ResultInfo Gets the result information. Declaration public ResultInfo ResultInfo { get; } Property Value Type Description ResultInfo The result information." + "core/Microsoft.Graph.Communications.Core.Notifications.CollectionNotificationEventArgs.html": { + "href": "core/Microsoft.Graph.Communications.Core.Notifications.CollectionNotificationEventArgs.html", + "title": "Class CollectionNotificationEventArgs", + "keywords": "Class CollectionNotificationEventArgs The collection notification event args. Inheritance Object NotificationEventArgs CollectionNotificationEventArgs Inherited Members NotificationEventArgs.NotificationId NotificationEventArgs.CallbackUri NotificationEventArgs.Notification NotificationEventArgs.TenantId NotificationEventArgs.RequestId NotificationEventArgs.ScenarioId NotificationEventArgs.ChangeType NotificationEventArgs.AdditionalData Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class CollectionNotificationEventArgs : NotificationEventArgs Constructors CollectionNotificationEventArgs(Uri, CommsNotification, ChangeType, IReadOnlyList) Initializes a new instance of the CollectionNotificationEventArgs class. Declaration public CollectionNotificationEventArgs(Uri callbackUri, CommsNotification notification, ChangeType changeType, IReadOnlyList resourceData) Parameters Type Name Description Uri callbackUri The callback URI. CommsNotification notification The notification. ChangeType changeType Type of the change. IReadOnlyList < Object > resourceData The resource data. Properties ResourceData Gets the resource data object list. Declaration public IReadOnlyList ResourceData { get; } Property Value Type Description IReadOnlyList < Object > The resource data object list. See Also NotificationEventArgs" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.VideoSendBuffer.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.VideoSendBuffer.html", - "title": "Class VideoSendBuffer", - "keywords": "Class VideoSendBuffer Creates a Video Buffer for Send and also implements Dispose Inheritance Object VideoSendBuffer Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public class VideoSendBuffer : VideoMediaBuffer Constructors VideoSendBuffer(Byte[], UInt32, VideoFormat, Int64) Initializes a new instance of the VideoSendBuffer class. Declaration public VideoSendBuffer(byte[] buffer, uint length, VideoFormat format, long timeStamp = 0L) Parameters Type Name Description Byte [] buffer The buffer. UInt32 length The length. VideoFormat format The format. Int64 timeStamp The time stamp. VideoSendBuffer(IntPtr, Int64, VideoFormat, Int64) Initializes a new instance of the VideoSendBuffer class. Declaration public VideoSendBuffer(IntPtr data, long length, VideoFormat videoFormat, long timeStamp = 0L) Parameters Type Name Description IntPtr data The data. Int64 length The length. VideoFormat videoFormat The video format. Int64 timeStamp The time stamp. Methods Dispose(Boolean) Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing" + "core/Microsoft.Graph.Communications.Core.Notifications.INotificationProcessor.html": { + "href": "core/Microsoft.Graph.Communications.Core.Notifications.INotificationProcessor.html", + "title": "Interface INotificationProcessor", + "keywords": "Interface INotificationProcessor The notification processor interface. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public interface INotificationProcessor : IDisposable Properties AuthenticationProvider Gets the authentication provider. TODO: This should probably not be a part of the INotificationProcessor . Ideally the request is already validated prior to making it in here. This means that 1) Already sanitized by authentication provider and 2) The tenant/scenario id parameters extracted into the IGraphRequest. Declaration IAuthenticationProvider AuthenticationProvider { get; } Property Value Type Description IAuthenticationProvider The authentication provider. Methods ProcessNotifications(Uri, String, String, Guid, Guid, IEnumerable>) Processes the notifications and raise the required callbacks. This function should be called in order for the SDK to raise any required events and process state changes. Declaration void ProcessNotifications(Uri callbackUri, string content, string tenantId, Guid requestId, Guid scenarioId, IEnumerable> additionalData = null) Parameters Type Name Description Uri callbackUri The callback URI. String content The notifications content. String tenantId The tenant identifier. Guid requestId The request identifier. Guid scenarioId The scenario identifier. IEnumerable < KeyValuePair < String , Object >> additionalData Additional data associated with the notification. Events OnCollectionNotificationReceived Occurs when a collection notification is received. Declaration event Action OnCollectionNotificationReceived Event Type Type Description Action < CollectionNotificationEventArgs > OnNotificationReceived Occurs when a notification is received. This is a global hook for all notifications. Declaration event Action OnNotificationReceived Event Type Type Description Action < NotificationEventArgs > OnResourceNotificationReceived Occurs when a single resource notification is received. Declaration event Action OnResourceNotificationReceived Event Type Type Description Action < NotificationEventArgs > Extension Methods NotificationProcessorExtensions.ProcessNotificationAsync(INotificationProcessor, HttpRequestMessage)" }, - "common/Microsoft.Graph.Communications.Common.ExceptionUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.ExceptionUtils.html", - "title": "Class ExceptionUtils", - "keywords": "Class ExceptionUtils Exception utilities Inheritance Object ExceptionUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class ExceptionUtils Methods FindInnerException(Exception) Find the inner exception that caused the error. Declaration public static Exception FindInnerException(this Exception exception) Parameters Type Name Description Exception exception Top level exception. Returns Type Description Exception Inner exception causing the error. FormatException(Exception, Int32) Format the exception including up to depth inner exceptions. Includes stack trace of the last inner exception (up to depth ). Declaration public static string FormatException(this Exception exception, int depth = 4) Parameters Type Name Description Exception exception Top level exception. Int32 depth The depth of inner exceptions, valid range is [1..4]. 1 means that most top exception will be formatted. Returns Type Description String Formatted exception GetBaseException(Exception) Gets the base exception of an exception. If the exception is an AggregateException, then the inner exceptions are flattened before getting the base exception. Declaration public static Exception GetBaseException(Exception exception) Parameters Type Name Description Exception exception The exception Returns Type Description Exception Whether it's base exception" + "common/Microsoft.Graph.Communications.Common.OData.CamelCaseStringEnumConverter.html": { + "href": "common/Microsoft.Graph.Communications.Common.OData.CamelCaseStringEnumConverter.html", + "title": "Class CamelCaseStringEnumConverter", + "keywords": "Class CamelCaseStringEnumConverter Converts an System.Enum to and from its name string value. When converting to its string value it will use camelCase formatting. Inheritance Object CamelCaseStringEnumConverter Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class CamelCaseStringEnumConverter : StringEnumConverter Constructors CamelCaseStringEnumConverter() Initializes a new instance of the CamelCaseStringEnumConverter class. Declaration public CamelCaseStringEnumConverter() Properties CanWrite Declaration public override bool CanWrite { get; } Property Value Type Description Boolean Methods CanConvert(Type) Declaration public override bool CanConvert(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Boolean ReadJson(JsonReader, Type, Object, JsonSerializer) Declaration public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonReader reader Type objectType Object existingValue Newtonsoft.Json.JsonSerializer serializer Returns Type Description Object Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also Newtonsoft.Json.Converters.StringEnumConverter" }, - "common/Microsoft.Graph.Communications.Common.OData.ODataConstants.html": { - "href": "common/Microsoft.Graph.Communications.Common.OData.ODataConstants.html", - "title": "Class ODataConstants", - "keywords": "Class ODataConstants The OData constants. Inheritance Object ODataConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class ODataConstants Fields ODataType The OData type. Declaration public const string ODataType = \"@odata.type\" Field Value Type Description String" + "common/Microsoft.Graph.Communications.Common.TaskQueue.html": { + "href": "common/Microsoft.Graph.Communications.Common.TaskQueue.html", + "title": "Class TaskQueue", + "keywords": "Class TaskQueue Task queue to encapsulate chaining of tasks. Inheritance Object Disposable ObjectRootDisposable TaskQueue Implements IDisposable Inherited Members ObjectRootDisposable.GraphLogger Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class TaskQueue : ObjectRootDisposable, IDisposable Constructors TaskQueue(IGraphLogger, Task) Initializes a new instance of the TaskQueue class. Declaration public TaskQueue(IGraphLogger logger, Task antecedent = null) Parameters Type Name Description IGraphLogger logger Logger instance. Task antecedent Optional antecedent task. Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) EnqueueAsync(Func) Enqueue an operation Declaration public Task EnqueueAsync(Func operation) Parameters Type Name Description Func < Task , Task > operation Operation to queue. Returns Type Description Task A task that represents the queued operation. Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.ReflectionUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.ReflectionUtils.html", - "title": "Class ReflectionUtils", - "keywords": "Class ReflectionUtils Reflection utilities Inheritance Object ReflectionUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class ReflectionUtils Methods DerivesFrom(Type, Type) Check if the type derives from the base type Declaration public static bool DerivesFrom(this Type type, Type baseType) Parameters Type Name Description Type type Type to check Type baseType Base type Returns Type Description Boolean True if it is or derives from the base type DerivesFrom(Type) Check if the type derives from the T type. Declaration public static bool DerivesFrom(this Type type) Parameters Type Name Description Type type Type to check Returns Type Description Boolean True if it is or derives from the base type Type Parameters Name Description T The type to check. GetPropertyUsingReflection(Object, String) Get named property of an object Declaration public static object GetPropertyUsingReflection(this object obj, string name) Parameters Type Name Description Object obj Object to get property from. String name Name of the property. Returns Type Description Object Value of the property GetValueCached(PropertyInfo, Object) Gets the value using a cached delegate. Declaration public static object GetValueCached(this PropertyInfo propertyInfo, object object) Parameters Type Name Description PropertyInfo propertyInfo The property info to use. Object object The object containing the property. Returns Type Description Object The fetched object. Implements(Type, Type) Check if type is subclass of a generic type. Declaration public static bool Implements(this Type type, Type checkType) Parameters Type Name Description Type type Type to check. Type checkType Generic type. Returns Type Description Boolean True if it is a subclass. Implements(Type) Check if type is subclass of a generic type. Declaration public static bool Implements(this Type type) Parameters Type Name Description Type type Type to check. Returns Type Description Boolean True if it is a subclass. Type Parameters Name Description T The type to check. SetPropertyUsingReflection(Object, String, Object) Set named property of an object Declaration public static bool SetPropertyUsingReflection(this object obj, string name, object value) Parameters Type Name Description Object obj Object to get property from. String name Name of the property. Object value Value of the property. Returns Type Description Boolean true if the property was set successfully, false otherwise SetValueCached(PropertyInfo, Object, Object) Set the value using a cached delegate. Declaration public static void SetValueCached(this PropertyInfo propertyInfo, object object, object value) Parameters Type Name Description PropertyInfo propertyInfo The property info to use. Object object The object containing the property. Object value The value to be set." + "common/Microsoft.Graph.Communications.Common.Telemetry.LoggingExtensions.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LoggingExtensions.html", + "title": "Class LoggingExtensions", + "keywords": "Class LoggingExtensions Extensions class for logging. Inheritance Object LoggingExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class LoggingExtensions Methods BindToILoggerFactory(GraphLogger, ILoggerFactory, ILogEventFormatter) Bind to ILogger Declaration public static Observer BindToILoggerFactory(this GraphLogger graphLogger, ILoggerFactory loggerFactory, ILogEventFormatter formatter = null) Parameters Type Name Description GraphLogger graphLogger The graph logger ILoggerFactory loggerFactory The ILogger ILogEventFormatter formatter The message formatter Returns Type Description Observer < LogEvent > The observer of graph logger Concat(IReadOnlyDictionary, IEnumerable) Get the merged propertied. Declaration public static IReadOnlyDictionary Concat(this IReadOnlyDictionary properties, IEnumerable additionalProperties) Parameters Type Name Description IReadOnlyDictionary < Type , Object > properties The property collection. IEnumerable < Object > additionalProperties The additional property collection. Returns Type Description IReadOnlyDictionary < Type , Object > The merged property collection. CreateILogger(IGraphLogger, String, Guid, LogEventType, IEnumerable) Creates the ILogger interface from Logging abstractions. Declaration public static ILogger CreateILogger(this IGraphLogger logger, string component = null, Guid correlationId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null) Parameters Type Name Description IGraphLogger logger The logger. String component The component for which log is created. Guid correlationId The correlation identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event Returns Type Description ILogger The ILogger interface. CreateShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) Creates the shim graph logger. The shim IGraphLogger wraps this logger and appends the specified content to each log request. Declaration public static IGraphLogger CreateShim(this IGraphLogger logger, string component = null, Guid? correlationId = default(Guid? ), IEnumerable properties = null, ObfuscationConfiguration obfuscationConfiguration = null) Parameters Type Name Description IGraphLogger logger The logger. String component The component for which log is created. Nullable < Guid > correlationId The correlation identifier. IEnumerable < Object > properties Extra properties for the log event ObfuscationConfiguration obfuscationConfiguration The obfuscation configuration. Returns Type Description IGraphLogger The IGraphLogger shim. EnterMethod(IGraphLogger, Guid, String, String, Int32) Log for entering method. Declaration public static LogEvent EnterMethod(this IGraphLogger logger, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Error(IGraphLogger, Exception, String, String, Guid, String, String, Int32) Log exceptions with error level. Declaration public static LogEvent Error(this IGraphLogger logger, Exception exception, string message = \"\", string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. Exception exception Exception information. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Error(IGraphLogger, String, String, Guid, String, String, Int32) Log messages with error level. Declaration public static LogEvent Error(this IGraphLogger logger, string message, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Flatten(IReadOnlyDictionary, IEnumerable, IEnumerable) Get the flatten key-value pairs for the properties of LogEvent. Declaration public static IEnumerable> Flatten(this IReadOnlyDictionary properties, IEnumerable ignoreTypes = null, IEnumerable ignoreSubProperties = null) Parameters Type Name Description IReadOnlyDictionary < Type , Object > properties The properties IEnumerable < Type > ignoreTypes The types in this list will be ingored IEnumerable < PropertyInfo > ignoreSubProperties The property members of specific types in this list will be ingored Returns Type Description IEnumerable < KeyValuePair < String , Object >> The flattern result. Remarks The primitive types and types implemented IEnumerable (string, list, dictionary, etc) will keep original value. The flatten support one level property lookup only. GetHeaderText(IGraphLogger, IEnumerable>>) Logs the headers text. Declaration public static IEnumerable GetHeaderText(this IGraphLogger logger, IEnumerable>> headers) Parameters Type Name Description IGraphLogger logger The logger. IEnumerable < KeyValuePair < String , IEnumerable < String >>> headers The headers. Returns Type Description IEnumerable < String > Log Text GetTypedProperties(LogEvent, Type) Gets the client common properties from log event. Declaration public static object GetTypedProperties(this LogEvent logEvent, Type type) Parameters Type Name Description LogEvent logEvent The log event. Type type The type of the property. Returns Type Description Object The client common properties. GetTypedProperty(LogEvent) Gets the client common properties from log event. Declaration public static T GetTypedProperty(this LogEvent logEvent) where T : class Parameters Type Name Description LogEvent logEvent The log event. Returns Type Description T The client common properties. Type Parameters Name Description T The property type. Info(IGraphLogger, String, String, Guid, String, String, Int32) Log exceptions with info level. Declaration public static LogEvent Info(this IGraphLogger logger, string message, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. LeaveMethod(IGraphLogger, Guid, String, String, Int32) Log for leaving method. Declaration public static LogEvent LeaveMethod(this IGraphLogger logger, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Log(IGraphLogger, TraceLevel, Exception, String, String, Guid, String, String, Int32) Log exceptions. Declaration public static LogEvent Log(this IGraphLogger logger, TraceLevel level, Exception exception, string message = null, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. TraceLevel level The trace level. Exception exception Exception information. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. LogHttpMessage(IGraphLogger, TraceLevel, TransactionDirection, HttpTraceType, String, String, String, IEnumerable>>, Int32, String, Nullable, Guid, Guid, String, String, Int32) Logs the http message. Declaration public static LogEvent LogHttpMessage(this IGraphLogger logger, TraceLevel level, TransactionDirection direction, HttpTraceType traceType, string url, string method, string obfuscatedContent, IEnumerable>> headers, int responseCode = 200, string component = null, long? responseTime = default(long? ), Guid correlationId = default(Guid), Guid requestId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. TraceLevel level The trace level. TransactionDirection direction The direction for request. HttpTraceType traceType Type of the http trace. String url The URL. String method The method. String obfuscatedContent The obfuscatedContent. IEnumerable < KeyValuePair < String , IEnumerable < String >>> headers The headers. Int32 responseCode The response code. (used only if [traceType == HttpResponse]) String component The component in which log is created. Nullable < Int64 > responseTime The response time. (used only if [traceType == HttpResponse]) Guid correlationId The correlation identifier. Guid requestId The message identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object Metric(IGraphLogger, String, String, Int64, Dictionary, Boolean, String, Guid, String, String, Int32) Log metrics Declaration public static LogEvent Metric(this IGraphLogger logger, string metricNamespace, string metricName, long rawData, Dictionary dimensions, bool addDefaultDimension = true, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String metricNamespace Metric namespace String metricName Metric name Int64 rawData Raw data Dictionary < String , String > dimensions Dimension name-value dictionary Boolean addDefaultDimension Indicates whether adds default dimension String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Obfuscate(IGraphLogger, Object, ObfuscationTag) Obfuscates the specified payload with the tag. Declaration public static string Obfuscate(this IGraphLogger logger, object payload, ObfuscationTag obfuscationTag) Parameters Type Name Description IGraphLogger logger The logger. Object payload The payload. ObfuscationTag obfuscationTag The obfuscation tag. Returns Type Description String Obfuscated data SerializeAndObfuscate(IGraphLogger, Object, Formatting) Serializes the payload and obfuscates it. Declaration public static string SerializeAndObfuscate(this IGraphLogger logger, object payload, Formatting formatting) Parameters Type Name Description IGraphLogger logger The logger. Object payload The payload. Newtonsoft.Json.Formatting formatting The formatting. Returns Type Description String Obfuscated data. ToLogLevel(TraceLevel) Get log level from trace level. Declaration public static LogLevel ToLogLevel(this TraceLevel level) Parameters Type Name Description TraceLevel level The trace level Returns Type Description LogLevel The log level ToTraceLevel(LogLevel) Gets the tracelevel for log level. Declaration public static TraceLevel ToTraceLevel(this LogLevel logLevel) Parameters Type Name Description LogLevel logLevel The log level. Returns Type Description TraceLevel trace level Verbose(IGraphLogger, String, String, Guid, String, String, Int32) Log verbose level. Declaration public static LogEvent Verbose(this IGraphLogger logger, string message, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Warn(IGraphLogger, Exception, String, String, Guid, String, String, Int32) Log exceptions with warning level. Declaration public static LogEvent Warn(this IGraphLogger logger, Exception exception, string message = \"\", string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. Exception exception Exception information. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Warn(IGraphLogger, String, String, Guid, String, String, Int32) Log exceptions with warning level. Declaration public static LogEvent Warn(this IGraphLogger logger, string message, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object." }, - "common/Microsoft.Graph.Communications.Common.SafeNativeMethods.html": { - "href": "common/Microsoft.Graph.Communications.Common.SafeNativeMethods.html", - "title": "Class SafeNativeMethods", - "keywords": "Class SafeNativeMethods Contains p/invokes and associated wrappers for the Native methods Inheritance Object SafeNativeMethods Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class SafeNativeMethods Methods GetPreciseSystemTime() Gets precise system time Declaration public static DateTime GetPreciseSystemTime() Returns Type Description DateTime Precise system time" + "client/Microsoft.Graph.Communications.Client.Cache.ICache.html": { + "href": "client/Microsoft.Graph.Communications.Client.Cache.ICache.html", + "title": "Interface ICache", + "keywords": "Interface ICache The cache interface used to store and recover the data used by the SDK. Namespace : Microsoft.Graph.Communications.Client.Cache Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface ICache Methods GetDataAsync(IEnumerable, String, CancellationToken) Gets the serialized string of the data at the specified resource path asynchronously. Fetching data only happens in HA/DR scenarios, so could take longer. Declaration Task GetDataAsync(IEnumerable properties, string resourcePath, CancellationToken cancellationToken = default(CancellationToken)) where T : Entity Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < String > The recovered serialized data at the specified resource path. Type Parameters Name Description T The type of Entity to fetch. GetDataCollectionAsync(IEnumerable, String, CancellationToken) Gets the resource paths for the children of the collection with the specified resource path asynchronously. Fetching data only happens in HA/DR scenarios, so could take longer. Declaration Task> GetDataCollectionAsync(IEnumerable properties, string resourcePath, CancellationToken cancellationToken = default(CancellationToken)) where T : Entity Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IEnumerable < String >> The recovered collection or child resource paths. Type Parameters Name Description T The type of Entity contained in the collection. SetData(ChangeType, IResource, IEnumerable, String, Lazy) Sets the data under the specified resource path. These should be short running operations, as they block notification callbacks. Declaration void SetData(ChangeType change, IResource resource, IEnumerable properties, string resourcePath, Lazy serializedData) Parameters Type Name Description ChangeType change The type of change occuring. IResource resource The resource being serialized. IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. Lazy < String > serializedData The serialized data lazy string. For performance reasons the string is only serialized when requested." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.AadApplicationIdentity.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.AadApplicationIdentity.html", - "title": "Class AadApplicationIdentity", - "keywords": "Class AadApplicationIdentity The application identity in Azure AD. Inheritance Object AadApplicationIdentity Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class AadApplicationIdentity Remarks For better logging experience, all property names should be specific enough. Avoid using generic name such as Id, Name, etc. Constructors AadApplicationIdentity() Declaration public AadApplicationIdentity() Properties AppId Gets or sets the id of application. Declaration public string AppId { get; set; } Property Value Type Description String AppName Gets or sets the name of application. Declaration public string AppName { get; set; } Property Value Type Description String Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "client/Microsoft.Graph.Communications.Client.Cache.ServiceCache.html": { + "href": "client/Microsoft.Graph.Communications.Client.Cache.ServiceCache.html", + "title": "Class ServiceCache", + "keywords": "Class ServiceCache The cache that restores the data directly from the service. In this case there is no storage of data, as the service acts as the master. Inheritance Object ServiceCache Implements ICache Namespace : Microsoft.Graph.Communications.Client.Cache Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class ServiceCache : ObjectRootDisposable, ICache Constructors ServiceCache(IGraphLogger, IGraphClient, ISerializer, String) Initializes a new instance of the ServiceCache class. Declaration public ServiceCache(IGraphLogger logger, IGraphClient client, ISerializer serializer, string baseUri) Parameters Type Name Description IGraphLogger logger Logger instance. IGraphClient client The client. ISerializer serializer The serializer. String baseUri The base URI. Methods GetDataAsync(IEnumerable, String, CancellationToken) Gets the serialized string of the data at the specified resource path asynchronously. Fetching data only happens in HA/DR scenarios, so could take longer. Declaration public Task GetDataAsync(IEnumerable properties, string resourcePath, CancellationToken cancellationToken = default(CancellationToken)) where T : Entity Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < String > The recovered serialized data at the specified resource path. Type Parameters Name Description T The type of Entity to fetch. GetDataCollectionAsync(IEnumerable, String, CancellationToken) Gets the resource paths for the children of the collection with the specified resource path asynchronously. Fetching data only happens in HA/DR scenarios, so could take longer. Declaration public Task> GetDataCollectionAsync(IEnumerable properties, string resourcePath, CancellationToken cancellationToken = default(CancellationToken)) where T : Entity Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IEnumerable < String >> The recovered collection or child resource paths. Type Parameters Name Description T The type of Entity contained in the collection. SetData(ChangeType, IResource, IEnumerable, String, Lazy) Sets the data under the specified resource path. These should be short running operations, as they block notification callbacks. Declaration public void SetData(ChangeType change, IResource resource, IEnumerable properties, string resourcePath, Lazy serializedData) Parameters Type Name Description ChangeType change The type of change occuring. IResource resource The resource being serialized. IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. Lazy < String > serializedData The serialized data lazy string. For performance reasons the string is only serialized when requested. Implements ICache See Also ObjectRootDisposable ICache" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.HttpLogData.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.HttpLogData.html", - "title": "Class HttpLogData", - "keywords": "Class HttpLogData The log data for http trace. Inheritance Object HttpLogData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class HttpLogData Constructors HttpLogData() Declaration public HttpLogData() Properties Content Gets or sets the content. Declaration public string Content { get; set; } Property Value Type Description String Headers Gets or sets the headers. Declaration public IEnumerable Headers { get; set; } Property Value Type Description IEnumerable < String > HeadersString Gets the headers string. Declaration public string HeadersString { get; } Property Value Type Description String Method Gets or sets the method. Declaration public string Method { get; set; } Property Value Type Description String ResponseStatusCode Gets or sets the response status code. Declaration public int? ResponseStatusCode { get; set; } Property Value Type Description Nullable < Int32 > ResponseTime Gets or sets the response time in milliseconds. Declaration public long? ResponseTime { get; set; } Property Value Type Description Nullable < Int64 > TraceType Gets or sets the trace type. Declaration public HttpTraceType TraceType { get; set; } Property Value Type Description HttpTraceType TransactionDirection Gets or sets the transaction direction. Declaration public TransactionDirection TransactionDirection { get; set; } Property Value Type Description TransactionDirection Url Gets or sets the url. Declaration public string Url { get; set; } Property Value Type Description String Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "client/Microsoft.Graph.Communications.Client.Transport.GraphAuthClient.html": { + "href": "client/Microsoft.Graph.Communications.Client.Transport.GraphAuthClient.html", + "title": "Class GraphAuthClient", + "keywords": "Class GraphAuthClient The graph auth client. Inheritance Object GraphAuthClient Namespace : Microsoft.Graph.Communications.Client.Transport Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class GraphAuthClient : GraphHttpClient Constructors GraphAuthClient(IGraphLogger, JsonSerializerSettings, HttpClient, IRequestAuthenticationProvider, ProductInfoHeaderValue, IEnumerable) Initializes a new instance of the GraphAuthClient class. Declaration public GraphAuthClient(IGraphLogger logger, JsonSerializerSettings jsonSerializerSettings, HttpClient httpClient, IRequestAuthenticationProvider authenticationProvider, ProductInfoHeaderValue userAgent, IEnumerable defaultProperties) Parameters Type Name Description IGraphLogger logger The logger. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. HttpClient httpClient The HTTP client. IRequestAuthenticationProvider authenticationProvider The authentication provider. ProductInfoHeaderValue userAgent The user agent. IEnumerable < IGraphProperty > defaultProperties The default properties. Exceptions Type Condition ArgumentNullException If the authentication provider is null. Methods SendHttpRequestAsync(IGraphRequest, CancellationToken) Declaration protected override Task> SendHttpRequestAsync(IGraphRequest graphRequest, CancellationToken cancellationToken) where T1 : class where T2 : class Parameters Type Name Description IGraphRequest graphRequest CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T1 T2 See Also GraphHttpClient" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.HttpObfuscationHelpers.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.HttpObfuscationHelpers.html", - "title": "Class HttpObfuscationHelpers", - "keywords": "Class HttpObfuscationHelpers Static class that provides helper functions for HTTP Logging. Inheritance Object HttpObfuscationHelpers Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpObfuscationHelpers Methods GetUrlText(Uri, Boolean, IEnumerable, IObfuscationEngine) Converts the URL to its representation depending on the filters. Declaration public static string GetUrlText(Uri url, bool obfuscationEnabled, IEnumerable uriFilters = null, IObfuscationEngine engine = null) Parameters Type Name Description Uri url The URL. Boolean obfuscationEnabled if set to true [filter pii]. IEnumerable < UriFilter > uriFilters The URI filters. IObfuscationEngine engine Custom obfuscation engine. If null, use (redacted) Returns Type Description String String representation LogHeaderText(ObfuscationConfiguration, IEnumerable>>) Logs the header text. Declaration public static IEnumerable LogHeaderText(this ObfuscationConfiguration configuration, IEnumerable>> headers) Parameters Type Name Description ObfuscationConfiguration configuration The configuration. IEnumerable < KeyValuePair < String , IEnumerable < String >>> headers The headers. Returns Type Description IEnumerable < String > The obfuscated header and value pairs. LogHeaderText(ObfuscationConfiguration, String, IEnumerable) Logs the header text. Declaration public static string LogHeaderText(this ObfuscationConfiguration configuration, string headerName, IEnumerable headerValues) Parameters Type Name Description ObfuscationConfiguration configuration The configuration. String headerName Name of the header. IEnumerable < String > headerValues The header values. Returns Type Description String The obfuscated header and value pair." + "client/Microsoft.Graph.Communications.Client.Transport.GraphAuthClientFactory.html": { + "href": "client/Microsoft.Graph.Communications.Client.Transport.GraphAuthClientFactory.html", + "title": "Class GraphAuthClientFactory", + "keywords": "Class GraphAuthClientFactory The HTTP graph client factory. Inheritance Object GraphAuthClientFactory Implements IGraphClientFactory Namespace : Microsoft.Graph.Communications.Client.Transport Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class GraphAuthClientFactory : ObjectRoot, IGraphClientFactory Constructors GraphAuthClientFactory(IGraphLogger, JsonSerializerSettings, IRequestAuthenticationProvider, ProductInfoHeaderValue, IEnumerable, HttpClient) Initializes a new instance of the GraphAuthClientFactory class. Declaration public GraphAuthClientFactory(IGraphLogger logger, JsonSerializerSettings jsonSerializerSettings, IRequestAuthenticationProvider authenticationProvider, ProductInfoHeaderValue userAgent, IEnumerable defaultProperties, HttpClient httpClient = null) Parameters Type Name Description IGraphLogger logger Logger instance. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. IRequestAuthenticationProvider authenticationProvider The authentication provider. ProductInfoHeaderValue userAgent The user agent. IEnumerable < IGraphProperty > defaultProperties The default properties. HttpClient httpClient The HTTP client. Properties AuthenticationProvider Gets the authentication provider. Declaration public IRequestAuthenticationProvider AuthenticationProvider { get; } Property Value Type Description IRequestAuthenticationProvider The authentication provider. GraphLogger Gets the graph logger. Declaration public IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Methods Create(IGraphLogger) Creates a new IGraphClient . Declaration public IGraphClient Create(IGraphLogger logger = null) Parameters Type Name Description IGraphLogger logger An optional IGraphLogger logger to be used in the new IGraphClient . Returns Type Description IGraphClient The IGraphClient . Implements IGraphClientFactory See Also ObjectRoot IGraphClientFactory" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.IObfuscationEngine.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.IObfuscationEngine.html", - "title": "Interface IObfuscationEngine", - "keywords": "Interface IObfuscationEngine Obfuscation engine that can obfuscate data. Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IObfuscationEngine Properties Enabled Gets a value indicating whether obfuscation is enabled. Declaration bool Enabled { get; } Property Value Type Description Boolean ObfuscationConfiguration Gets or sets the obfuscation configuration. This is also set when configuration is linked to an obfuscation engine. Declaration ObfuscationConfiguration ObfuscationConfiguration { get; set; } Property Value Type Description ObfuscationConfiguration Methods Obfuscate(Object, ObfuscationTag) Obfuscates the specified payload. Declaration string Obfuscate(object payload, ObfuscationTag obfuscationTag) Parameters Type Name Description Object payload The payload. ObfuscationTag obfuscationTag The obfuscation tag. Returns Type Description String Obfuscated data. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "client/Microsoft.Graph.Communications.Resources.IResource.html": { + "href": "client/Microsoft.Graph.Communications.Resources.IResource.html", + "title": "Interface IResource", + "keywords": "Interface IResource The stateful resource interface. Inherited Members IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResource : IResourceBase, IDisposable Properties Id Gets the identifier. Declaration string Id { get; } Property Value Type Description String ModifiedDateTime Gets the last modified date time of this resource. Declaration DateTimeOffset ModifiedDateTime { get; } Property Value Type Description DateTimeOffset Resource Gets the resource. Declaration object Resource { get; } Property Value Type Description Object See Also IResourceBase" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.CallerInfo.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.CallerInfo.html", - "title": "Class CallerInfo", - "keywords": "Class CallerInfo Class that encapsulates the caller's (creator's) information Inheritance Object CallerInfo Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class CallerInfo Constructors CallerInfo(String, String, Int32) Initializes a new instance of the CallerInfo class. Declaration public CallerInfo(string memberName = \"\", string filePath = \"\", int lineNumber = 0) Parameters Type Name Description String memberName Name of the member. String filePath The file path. Int32 lineNumber The line number. Methods GetHashCode() Returns a hash code for this instance. Declaration public override int GetHashCode() Returns Type Description Int32 A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. Overrides Object.GetHashCode() ToString() Returns a String that represents the caller info. Declaration public override string ToString() Returns Type Description String A String that represents the caller info. Overrides Object.ToString() Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.Extensions.html": { + "href": "common/Microsoft.Graph.Communications.Common.Extensions.html", + "title": "Class Extensions", + "keywords": "Class Extensions Defines Extensions. Inheritance Object Extensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class Extensions Methods ChangeType(Object, Type) Returns an object of the specified type and whose value is equivalent to the specified object. Declaration public static object ChangeType(this object value, Type conversionType) Parameters Type Name Description Object value An object that implements the IConvertible interface. Type conversionType The type of object to return. Returns Type Description Object Converted object Exceptions Type Condition InvalidCastException This conversion is not supported. -or- value is null and conversionType is a value conversionType.-or- value does not implement the IConvertible interface. FormatException value is not in a format recognized by conversionType . OverflowException value represents a number that is out of the range of conversionType . ArgumentNullException conversionType is null. ChangeType(Object) Convert conversionType of an object Declaration public static T ChangeType(this object value) Parameters Type Name Description Object value An object that implements the IConvertible interface. Returns Type Description T Converted object Type Parameters Name Description T Type requested Exceptions Type Condition InvalidCastException This conversion is not supported. -or- value is null and is a value conversionType.-or- value does not implement the IConvertible interface. FormatException value is not in a format recognized by . OverflowException value represents a number that is out of the range of . ArgumentNullException is null. CreateObserver(IObservable, Action, Action, Action) Create observer Declaration public static Observer CreateObserver(this IObservable observable, Action onNext, Action onError = null, Action onCompleted = null) Parameters Type Name Description IObservable observable Object providing the events. Action onNext Callback for data. Action < Exception > onError Callback for errors. Action onCompleted Callback for completion. Returns Type Description Observer New observer object Type Parameters Name Description T Type of the observer. GetDeterministicHashCode(String) Gets deterministic hash code of the given string. Using FNV-1a hash: https://en.wikipedia.org/wiki/Fowler%E2%80%93Noll%E2%80%93Vo_hash_function Declaration public static uint GetDeterministicHashCode(this string str) Parameters Type Name Description String str The string. Returns Type Description UInt32 The unsigned hash code. Lock(Mutex) Lock mutex Declaration public static IDisposable Lock(this Mutex mutex) Parameters Type Name Description Mutex mutex Mutex to enter. Returns Type Description IDisposable Disposable cleanup to release mutex. Pin(Object) Pin object memory. Declaration public static AutoClean Pin(this object obj) Parameters Type Name Description Object obj Object to pin. Returns Type Description AutoClean < IntPtr > Disposable cleanup to release pinned memory. PushDir(String) Push directory and restore when done. Declaration public static IDisposable PushDir(string directory) Parameters Type Name Description String directory New directory to change to. Returns Type Description IDisposable Disposable to restore to previous directory. Read(ReaderWriterLockSlim) Automatic cleanup of entering read lock. Declaration public static IDisposable Read(this ReaderWriterLockSlim lockSlim) Parameters Type Name Description ReaderWriterLockSlim lockSlim Lock instance. Returns Type Description IDisposable Disposable cleanup instance. ReplaceFirst(String, String, String) Replaces the first occurence of search string with replace string. Declaration public static string ReplaceFirst(this string text, string search, string replace) Parameters Type Name Description String text The source text. String search The search string. String replace String to be replaced. Returns Type Description String Updated soruce text. ReplaceScheme(Uri, String, String) Replace URI scheme. Declaration public static Uri ReplaceScheme(this Uri uri, string find, string replace) Parameters Type Name Description Uri uri Subject URI String find Find string. String replace Replace string. Returns Type Description Uri New URI. SafeWait(SemaphoreSlim) Safe wait on semaphore Declaration public static IDisposable SafeWait(this SemaphoreSlim semaphoreSlim) Parameters Type Name Description SemaphoreSlim semaphoreSlim The semaphore to wait on. Returns Type Description IDisposable Disposable cleanup to release semaphore. SafeWaitAsync(SemaphoreSlim) Safe wait on semaphore Declaration public static Task SafeWaitAsync(this SemaphoreSlim semaphoreSlim) Parameters Type Name Description SemaphoreSlim semaphoreSlim The semaphore to wait on. Returns Type Description Task < IDisposable > Disposable cleanup to release semaphore. TrapErrors(Action, IGraphLogger, TraceLevel, String, String, String, Int32) Trap exceptions from action. Declaration public static Exception TrapErrors(this Action action, IGraphLogger logger, TraceLevel level, string component = \"\", string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description Action action Action to run. IGraphLogger logger Logger to log exception data. TraceLevel level Trace level. String component The component in which this log is created. String memberName Calling function. String filePath Filename where code is located. Int32 lineNumber Line number where code is located. Returns Type Description Exception Task containing exception if any. TrapErrors(Action, TKey, IGraphLogger, TraceLevel, String, String, String, Int32) Trap exceptions from action. Declaration public static Exception TrapErrors(this Action action, TKey key, IGraphLogger logger, TraceLevel level, string component = \"\", string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description Action action Action to run. TKey key Key for the action. IGraphLogger logger Logger to log exception data. TraceLevel level Trace level. String component The component in which this log is created. String memberName Calling function. String filePath Filename where code is located. Int32 lineNumber Line number where code is located. Returns Type Description Exception Task containing exception if any. Type Parameters Name Description TKey Action key type. TrapErrorsAsync(Task, IGraphLogger, TraceLevel, String, String, String, Int32) Trap exceptions from antecedent task. Declaration public static Task TrapErrorsAsync(this Task task, IGraphLogger logger, TraceLevel level, string component = \"\", string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description Task task Antecedent task. IGraphLogger logger Logger to log exception data. TraceLevel level Trace level. String component The component in which this log is created. String memberName Calling function. String filePath Filename where code is located. Int32 lineNumber Line number where code is located. Returns Type Description Task < Exception > Task containing exception if any. TryDispose(Object, IGraphLogger) Try and dispose the object if it supports the right interface. Declaration public static void TryDispose(this object obj, IGraphLogger logger = null) Parameters Type Name Description Object obj Object to dispose. IGraphLogger logger Logger instance. UpgradeableRead(ReaderWriterLockSlim) Automatic cleanup of entering read lock. Declaration public static IDisposable UpgradeableRead(this ReaderWriterLockSlim lockSlim) Parameters Type Name Description ReaderWriterLockSlim lockSlim Lock instance. Returns Type Description IDisposable Disposable cleanup instance. WaitAsync(Task, Int32) Waits for the Task to complete execution within a specified number of milliseconds. Traps errors on the task to avoid unobserved task exceptions. Declaration public static Task WaitAsync(this Task task, int millisecondsTimeout = -1) Parameters Type Name Description Task task Task to wait. Int32 millisecondsTimeout The number of milliseconds to wait, or Infinite (-1) to wait indefinitely. Returns Type Description Task < Boolean > true if the Task completed execution within the allotted time; otherwise, false. Write(ReaderWriterLockSlim) Automatic cleanup of entering write lock. Declaration public static IDisposable Write(this ReaderWriterLockSlim lockSlim) Parameters Type Name Description ReaderWriterLockSlim lockSlim Lock instance. Returns Type Description IDisposable Disposable cleanup instance." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.ClientLogEventId.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.ClientLogEventId.html", - "title": "Enum ClientLogEventId", - "keywords": "Enum ClientLogEventId Event ids for client logs Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum ClientLogEventId Fields Name Description ClientHttpTrace The event id for client HTTP trace. ClientTrace The event id for client trace Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(ClientLogEventId, String, String) Validator.Equals(ClientLogEventId, String) Validator.NotEquals(ClientLogEventId, String, String)" + "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaSession.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaSession.html", + "title": "Class MediaSession", + "keywords": "Class MediaSession Inheritance Object MediaSession Implements ILocalMediaSession IMediaSession IDisposable Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public class MediaSession : ObjectRootDisposable, ILocalMediaSession, IMediaSession, IDisposable Constructors MediaSession(IGraphLogger, Guid, AudioSocketSettings, VideoSocketSettings, VideoSocketSettings, DataSocketSettings) Initializes a new instance of the MediaSession class. Declaration public MediaSession(IGraphLogger logger, Guid mediaSessionId, AudioSocketSettings audioSocketSettings, VideoSocketSettings videoSocketSettings, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null) Parameters Type Name Description IGraphLogger logger The logger. Guid mediaSessionId The media session id. AudioSocketSettings audioSocketSettings The audio socket settings. VideoSocketSettings videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Exceptions Type Condition ArgumentException When no media session id or no valid socket settings have been specified. MediaSession(IGraphLogger, Guid, AudioSocketSettings, IEnumerable, VideoSocketSettings, DataSocketSettings) Initializes a new instance of the MediaSession class. Declaration public MediaSession(IGraphLogger logger, Guid mediaSessionId, AudioSocketSettings audioSocketSettings, IEnumerable videoSocketSettings = null, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null) Parameters Type Name Description IGraphLogger logger The logger. Guid mediaSessionId The media session id. AudioSocketSettings audioSocketSettings The audio socket settings. IEnumerable < VideoSocketSettings > videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Exceptions Type Condition ArgumentException When no media session id or no valid socket settings have been specified. Properties AudioSocket Gets the audio socket associated with this media session. Declaration public IAudioSocket AudioSocket { get; } Property Value Type Description IAudioSocket DataSocket Gets the data socket associated with this media session. Declaration public IDataSocket DataSocket { get; } Property Value Type Description IDataSocket MediaSessionId Declaration public Guid MediaSessionId { get; } Property Value Type Description Guid Modalities Declaration public Modality[] Modalities { get; } Property Value Type Description Modality [] VbssSocket Gets the VBSS socket associated with this media session. Declaration public IVideoSocket VbssSocket { get; } Property Value Type Description IVideoSocket VideoSocket Gets the video socket associated with this media session. If current media session contains multiple sockets, this will return the first one in the list. Declaration public IVideoSocket VideoSocket { get; } Property Value Type Description IVideoSocket VideoSockets Gets the list of video socket associated with this media session. Declaration public IReadOnlyList VideoSockets { get; } Property Value Type Description IReadOnlyList < IVideoSocket > Methods Dispose(Boolean) Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing GetMediaConfiguration() Declaration public JObject GetMediaConfiguration() Returns Type Description Newtonsoft.Json.Linq.JObject Implements ILocalMediaSession IMediaSession System.IDisposable" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.MetricLogData.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.MetricLogData.html", - "title": "Class MetricLogData", - "keywords": "Class MetricLogData The metric of Geneva Instrumentation Framework (Ifx). Inheritance Object MetricLogData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class MetricLogData Constructors MetricLogData() Declaration public MetricLogData() Properties AddDefaultDimension Gets or sets a value indicating whether the default dimensions are included. Declaration public bool AddDefaultDimension { get; set; } Property Value Type Description Boolean Dimensions Gets or sets the dimensions. Declaration public Dictionary Dimensions { get; set; } Property Value Type Description Dictionary < String , String > Name Gets or sets the name. Declaration public string Name { get; set; } Property Value Type Description String Namespace Gets or sets the namespace. Declaration public string Namespace { get; set; } Property Value Type Description String RawData Gets or sets the raw data. Declaration public long RawData { get; set; } Property Value Type Description Int64 Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "core/Microsoft.Graph.Communications.Core.Exceptions.html": { + "href": "core/Microsoft.Graph.Communications.Core.Exceptions.html", + "title": "Namespace Microsoft.Graph.Communications.Core.Exceptions", + "keywords": "Namespace Microsoft.Graph.Communications.Core.Exceptions Classes ClientException Class for client error exception. ErrorConstants Error Constants ErrorConstants.Codes Error Codes ErrorConstants.Messages Error Messages ServiceException A Service Exception." }, - "bot_media/Microsoft.Skype.Bots.Media.ToneId.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.ToneId.html", - "title": "Enum ToneId", - "keywords": "Enum ToneId DTMF Tone Id enum. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum ToneId Fields Name Description A Tone A B Tone B C Tone C D Tone D Flash Tone flash Pound Pound tone Star Star tone Tone0 Tone 0 Tone1 Tone 1 Tone2 Tone 2 Tone3 Tone 3 Tone4 Tone 4 Tone5 Tone 5 Tone6 Tone 6 Tone7 Tone 7 Tone8 Tone 8 Tone9 Tone 9" + "calls/Microsoft.Graph.Communications.Calls.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.html", + "title": "Namespace Microsoft.Graph.Communications.Calls", + "keywords": "Namespace Microsoft.Graph.Communications.Calls Classes CallCollectionExtensions Extensions for call collections. CallExtensions Extensions for calls. CommunicationsClientExtensions Extensions for stateful client. JoinMeetingParameters Class to define parameters required for joining a meeting. ParticipantExtensions Extensions for the stateful participant resource. PlayOperationResult Class to define parameters required for joining a meeting. RecordOperationResult Class to define parameters required for joining a meeting. Interfaces ICall The stateful call interface. ICallCollection The stateful call collection interface. IMediaSession The IMediaSession interface. For local media scenarios, this session object represents the modalities and the media configuration. IParticipant The stateful participant interface. This represents a single participant in a call. IParticipantCollection The stateful participant collection interface." }, - "bot_media/Microsoft.Skype.Bots.Media.VideoQualityOfExperienceData.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoQualityOfExperienceData.html", - "title": "Class VideoQualityOfExperienceData", - "keywords": "Class VideoQualityOfExperienceData Video quality of experience data Inheritance Object MediaQualityOfExperienceData VideoQualityOfExperienceData Inherited Members MediaQualityOfExperienceData.NetworkMetrics MediaQualityOfExperienceData.TotalMediaDuration Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoQualityOfExperienceData : MediaQualityOfExperienceData Constructors VideoQualityOfExperienceData() VideoQualityOfExperienceData constructor Declaration public VideoQualityOfExperienceData() Properties VideoMetrics Video-specific quality of experience metrics Declaration public VideoMetrics VideoMetrics { get; set; } Property Value Type Description VideoMetrics" + "calls/Microsoft.Graph.Communications.Calls.ICall.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.ICall.html", + "title": "Interface ICall", + "keywords": "Interface ICall The stateful call interface. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface ICall : IResource, IResource, IResourceBase, IDisposable Properties CorrelationId Gets the correlation identifier. Declaration [Obsolete(\"Please use ScenarioId instead.\")] Guid CorrelationId { get; } Property Value Type Description Guid MediaSession Gets the media session, if any. This is used only for Local Media Scenarios. Declaration IMediaSession MediaSession { get; } Property Value Type Description IMediaSession Participants Gets the Participants collection for this call. Declaration IParticipantCollection Participants { get; } Property Value Type Description IParticipantCollection Resource Gets the call resource. Declaration Call Resource { get; } Property Value Type Description Call ScenarioId Gets the scenario identifier. Declaration Guid ScenarioId { get; } Property Value Type Description Guid TenantId Gets the tenant identifier. Declaration string TenantId { get; } Property Value Type Description String Methods AnswerAsync(MediaConfig, IEnumerable, String, Guid, CancellationToken) Answer an incoming call asynchronously. Declaration Task AnswerAsync(MediaConfig mediaConfig, IEnumerable acceptedModalities = null, string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description MediaConfig mediaConfig The MediaConfig . IEnumerable < Modality > acceptedModalities The accepted list of Modality . String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated ChangeScreenSharingRoleAsync(ScreenSharingRole, CancellationToken) Changes own sharing role in a vbss session. Declaration Task ChangeScreenSharingRoleAsync(ScreenSharingRole role, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ScreenSharingRole role The role to change to. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. DeleteAsync(Boolean, CancellationToken) Deletes this call asynchronously. Declaration Task DeleteAsync(bool handleHttpNotFoundInternally = false, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description Boolean handleHttpNotFoundInternally If the ICall is already gone, whether to handle the exception gracefully or not. CancellationToken cancellationToken The CancellationToken for the request. Returns Type Description Task The Task that completes after the request has been sent. The completion of this task does not guarantee deletion. Confirmation of deletion comes as a notification and can be subscribed by ICall.OnUpdated and ICallCollection.OnUpdated KeepAliveAsync(CancellationToken) Send heartbeat to keep call alive. Declaration Task KeepAliveAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. MuteAsync(CancellationToken) Mutes the self participant asynchronously. Declaration Task MuteAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The mute notification will come in on IParticipant.OnUpdated PlayPromptAsync(IEnumerable, Action, CancellationToken) Plays the specified media prompts. Declaration Task PlayPromptAsync(IEnumerable prompts, Action promptsQueued = null, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description IEnumerable < MediaPrompt > prompts The list of MediaPrompt to play Action promptsQueued A callback indicating when the prompts have been queued, but have not yet completed playing. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < PlayOperationResult > The PlayOperationResult with information on how the play operation completed. Exceptions Type Condition ServiceException An error has occurred when playing the prompt. RedirectAsync(IEnumerable, Nullable, String, Guid, CancellationToken) Redirects the incoming call asynchronously. Declaration Task RedirectAsync(IEnumerable targets, int? timeout = default(int? ), string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description IEnumerable < InvitationParticipantInfo > targets The targets to whom the call should be redirected to. Nullable < Int32 > timeout The timeout after which the redirect is canceled. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. RejectAsync(Nullable, String, Guid, CancellationToken) Rejects the incoming call asynchronously. Declaration Task RejectAsync(RejectReason? rejectReason = default(RejectReason? ), string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description Nullable < RejectReason > rejectReason The reason for call rejection. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. SubscribeToToneAsync(CancellationToken) Subscribe to DTMF (dual-tone multi-frequency signaling). This allows you to be notified when the user presses keys on a \"touchtone\" phone. Declaration Task SubscribeToToneAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The DTMF notifications will come on ICall.OnUpdated TransferAsync(InvitationParticipantInfo, CancellationToken) Transfer a call to a given target. Declaration Task TransferAsync(InvitationParticipantInfo target, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description InvitationParticipantInfo target The target to transfer the call to. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated UnmuteAsync(CancellationToken) Unmutes the self participant asynchronously. Declaration Task UnmuteAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The unmute notification will come in on IParticipant.OnUpdated Extension Methods CallExtensions.AnswerAsync(ICall, IMediaSession, String, Guid, CancellationToken) CallExtensions.AnswerAsync(ICall, IEnumerable, IEnumerable, String, Guid, CancellationToken) CallExtensions.AnswerAsync(ICall, IEnumerable, String, Guid, CancellationToken)" }, - "calls/Microsoft.Graph.Communications.Calls.CallCollectionExtensions.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.CallCollectionExtensions.html", - "title": "Class CallCollectionExtensions", - "keywords": "Class CallCollectionExtensions Extensions for call collections. Inheritance Object CallCollectionExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public static class CallCollectionExtensions Methods AddAsync(ICallCollection, JoinMeetingParameters, Guid, CancellationToken) Join a new meeting with the provided parameters Declaration public static Task AddAsync(this ICallCollection callCollection, JoinMeetingParameters parameters, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ICallCollection callCollection The call collection. JoinMeetingParameters parameters The join meeting parameters. Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < ICall > The stateful call object once the call is joined." + "calls/Microsoft.Graph.Communications.Calls.CommunicationsClientExtensions.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.CommunicationsClientExtensions.html", + "title": "Class CommunicationsClientExtensions", + "keywords": "Class CommunicationsClientExtensions Extensions for stateful client. Inheritance Object CommunicationsClientExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public static class CommunicationsClientExtensions Methods Calls(ICommunicationsClient, Boolean) Gets the call collection. This is the main entry point for the calling SDK. The return value of this function can be cached by the clients as required. Declaration public static ICallCollection Calls(this ICommunicationsClient client, bool maintainState = true) Parameters Type Name Description ICommunicationsClient client The stateful client. Boolean maintainState If set to true the resulting IResourceCollection will hold all IResource instances it creates unless explicitly deleted (either by the service or by the developer). If set to false no IResource generated by the IResourceCollection or its children will be stored by the ICommunicationsClient , instead it is the developers responsibility to control the lifetime of the generated instances. Returns Type Description ICallCollection The root singleton ICallCollection node. Multiple invocations of this method will return the same ICallCollection ." }, - "client/Microsoft.Graph.Communications.Client.Authentication.html": { - "href": "client/Microsoft.Graph.Communications.Client.Authentication.html", - "title": "Namespace Microsoft.Graph.Communications.Client.Authentication", - "keywords": "Namespace Microsoft.Graph.Communications.Client.Authentication Structs RequestValidationResult The result of the request validation. Interfaces IRequestAuthenticationProvider The authentication provider interface. This is used to authenticate Inbound requests from Microsoft Graph. It validates the request was issued by Microsoft Graph. Outbound requests to Microsoft Graph. Tenant token is acquired to provide Microsoft Graph the permissions the bot has been consented by the tenant admin" + "common/Microsoft.Graph.Communications.Common.Transport.HttpRequestMessageExtensions.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.HttpRequestMessageExtensions.html", + "title": "Class HttpRequestMessageExtensions", + "keywords": "Class HttpRequestMessageExtensions Extensions for HttpRequestMessage . Inheritance Object HttpRequestMessageExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpRequestMessageExtensions Methods Add(HttpHeaders, IGraphProperty) Adds the header. Declaration public static void Add(this HttpHeaders headers, IGraphProperty property) Parameters Type Name Description HttpHeaders headers The headers. IGraphProperty property The property. CloneHttpRequestMessageAsync(HttpRequestMessage) Clones the HTTP request message. Declaration public static Task CloneHttpRequestMessageAsync(this HttpRequestMessage req) Parameters Type Name Description HttpRequestMessage req The req. Returns Type Description Task < HttpRequestMessage > Cloned request message GetHttpAndContentHeaders(HttpRequestMessage) Gets headers from the http request and the content. Declaration public static IEnumerable>> GetHttpAndContentHeaders(this HttpRequestMessage message) Parameters Type Name Description HttpRequestMessage message The message. Returns Type Description IEnumerable < KeyValuePair < String , IEnumerable < String >>> The list of http and content headers. ToGraphRequestAsync(HttpRequestMessage) Converts a HttpRequestMessage into a IGraphRequest . Declaration public static Task ToGraphRequestAsync(this HttpRequestMessage httpRequest) Parameters Type Name Description HttpRequestMessage httpRequest HttpRequestMessage to be converted. Returns Type Description Task < IGraphRequest > IGraphRequest object corresponding to httpRequest ToGraphRequestAsync(HttpRequestMessage, JsonSerializerSettings) Converts a HttpRequestMessage into a IGraphRequest . Declaration public static Task> ToGraphRequestAsync(this HttpRequestMessage httpRequest, JsonSerializerSettings serializerSettings = null) Parameters Type Name Description HttpRequestMessage httpRequest HttpRequestMessage to be converted. Newtonsoft.Json.JsonSerializerSettings serializerSettings Json serializer settings. Returns Type Description Task < IGraphRequest > IGraphRequest object corresponding to httpRequest Type Parameters Name Description T Type of the content present in httpRequest ToRequestType(HttpMethod) Convert HttpMethod to the type of the request. Declaration public static RequestType ToRequestType(this HttpMethod httpMethod) Parameters Type Name Description HttpMethod httpMethod The HTTP method. Returns Type Description RequestType RequestType corresponding to the httpMethod Exceptions Type Condition InvalidOperationException Thrown if httpMethod has no corresponding RequestType" }, - "core/Microsoft.Graph.Routing.CloudNamespace.html": { - "href": "core/Microsoft.Graph.Routing.CloudNamespace.html", - "title": "Enum CloudNamespace", - "keywords": "Enum CloudNamespace Enumeration defining various cloud environment type Namespace : Microsoft.Graph.Routing Assembly : Microsoft.Graph.Communications.Core.dll Syntax public enum CloudNamespace Fields Name Description DoD Represents a service running on the DoD cloud installation of NGC or a user homed on the DoD cloud. GCCH Represents a service running on the GCCH cloud installation of NGC or a user homed on the GCCH cloud. NotApplicable Used for users like 'teamsvisitor' or on premise sfb user for whom cloud namespace is not applicable Public Represents a service running on the public cloud installation of NGC or a user homed on the public cloud." + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.html", + "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters", + "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Classes BaseFilter Non generic base filter. BaseFilter Base filter. ContentDispositionFilter Does match of content disposition header. If content disposition matches filter then whole body is removed. ContentTypeFilter Does match of content-type header. If content-type matches filter then whole body is removed. GraphUriFilters Uri filters to filter PII in graph urls. HeaderFilter Header filters act as whitelists. UriFilter URI Filter. Any group matches from REGEX are obfuscated." }, - "core/Microsoft.Graph.Routing.html": { - "href": "core/Microsoft.Graph.Routing.html", - "title": "Namespace Microsoft.Graph.Routing", - "keywords": "Namespace Microsoft.Graph.Routing Enums CloudNamespace Enumeration defining various cloud environment type" + "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCommunicationsClientBuilderExtensions.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCommunicationsClientBuilderExtensions.html", + "title": "Class MediaCommunicationsClientBuilderExtensions", + "keywords": "Class MediaCommunicationsClientBuilderExtensions The stateful client builder extension. Inheritance Object MediaCommunicationsClientBuilderExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public static class MediaCommunicationsClientBuilderExtensions Methods SetMediaPlatformSettings(ICommunicationsClientBuilder, MediaPlatformSettings) Set the local media platform settings. This function also initializes the local media platform. Declaration public static ICommunicationsClientBuilder SetMediaPlatformSettings(this ICommunicationsClientBuilder statefulClientBuilder, MediaPlatformSettings mediaSettings) Parameters Type Name Description ICommunicationsClientBuilder statefulClientBuilder The stateful client builder. MediaPlatformSettings mediaSettings The media settings. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ClientException When something fails while initializing the media platform. TerminateAsync(ICommunicationsClient, Boolean, TimeSpan) Stops the specified stateful client. This would end all the calls and shuts down the media platform. This should only be used during shutdown. Declaration public static Task TerminateAsync(this ICommunicationsClient statefulClient, bool onlyMedia, TimeSpan timeout = default(TimeSpan)) Parameters Type Name Description ICommunicationsClient statefulClient The stateful client. Boolean onlyMedia if set to true terminate only the media platform. TimeSpan timeout The timeout. Returns Type Description Task < Boolean > True if all instances were terminated, false otherwise." }, - "core/Microsoft.Graph.html": { - "href": "core/Microsoft.Graph.html", - "title": "Namespace Microsoft.Graph", - "keywords": "Namespace Microsoft.Graph Classes ContractsConstants OData Model Constants ContractsConstants.AuthConstants Various constants used by the AuthZ layer ContractsConstants.CallProperties Call properties constants ContractsConstants.EntityContainerNames Singleton/EntitySet constants ContractsConstants.IdentityProperties Identity properties constants ContractsConstants.NotificationProperties Notification properties constants ContractsConstants.Signature Signature for Assembly visibility. IdentityExtensions Extensions for graph api contracts IdentitySetExtensions Extentions for graph api contracts NotificationsExtensions Communications notifications extensions." + "calls/Microsoft.Graph.Communications.Calls.CallExtensions.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.CallExtensions.html", + "title": "Class CallExtensions", + "keywords": "Class CallExtensions Extensions for calls. Inheritance Object CallExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public static class CallExtensions Methods AnswerAsync(ICall, IMediaSession, String, Guid, CancellationToken) Answers a call with locally hosted media configuration. Declaration public static Task AnswerAsync(this ICall call, IMediaSession mediaSession, string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ICall call The call to be answered. IMediaSession mediaSession The media session object which defines the media configuration. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated Exceptions Type Condition ArgumentNullException When mediaSession is not specified. AnswerAsync(ICall, IEnumerable, IEnumerable, String, Guid, CancellationToken) Answers a call with service hosted media configuration. Declaration public static Task AnswerAsync(this ICall call, IEnumerable preFetchMedia, IEnumerable acceptedModalities, string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ICall call The call to be answered. IEnumerable < MediaInfo > preFetchMedia List of media files that service will cache, so that when playing these media files; the latency is lower. IEnumerable < Modality > acceptedModalities The modalities to accept. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated Exceptions Type Condition ArgumentNullException When pre-fetch media is null. AnswerAsync(ICall, IEnumerable, String, Guid, CancellationToken) Answers a call with service hosted media configuration. Declaration public static Task AnswerAsync(this ICall call, IEnumerable acceptedModalities, string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ICall call The call to be answered. IEnumerable < Modality > acceptedModalities The modalities to accept. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated SetOutgoingCallOptions(Call, Nullable) Set outgoing call options for the call. Declaration public static void SetOutgoingCallOptions(this Call call, bool? allowGuestToBypassLobby) Parameters Type Name Description Call call The call. Nullable < Boolean > allowGuestToBypassLobby Enable bypass lobby when joining a group call as guest." }, - "bot_media/Microsoft.Skype.Bots.Media.AudioMetrics.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioMetrics.html", - "title": "Class AudioMetrics", - "keywords": "Class AudioMetrics Audio-specific QoE metrics Inheritance Object AudioMetrics Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioMetrics Constructors AudioMetrics() Declaration public AudioMetrics() Properties AverageInboundNetworkJitter Average network jitter on the inbound media stream Declaration public TimeSpan AverageInboundNetworkJitter { get; set; } Property Value Type Description TimeSpan MaximumInboundNetworkJitter Maximum network jitter on the inbound media stream Declaration public TimeSpan MaximumInboundNetworkJitter { get; set; } Property Value Type Description TimeSpan" + "common/Microsoft.Graph.Communications.Common.Observable-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Observable-1.html", + "title": "Class Observable", + "keywords": "Class Observable Observable Base class Inheritance Object ObjectRoot Observable Implements IObservable IObserver INotifyCollectionChanged Inherited Members ObjectRoot.GraphLogger Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class Observable : ObjectRoot, IObservable, IObserver, INotifyCollectionChanged Type Parameters Name Description T Type of the value being observed. Constructors Observable(IGraphLogger) Initializes a new instance of the Observable class. Declaration public Observable(IGraphLogger logger) Parameters Type Name Description IGraphLogger logger Logger instance. Properties Observers Gets the observers. Declaration public ICollection> Observers { get; } Property Value Type Description ICollection < IObserver > Methods OnCompleted() Notify observers of completion. Declaration public void OnCompleted() OnError(Exception) Notify observers of error. Declaration public void OnError(Exception error) Parameters Type Name Description Exception error Exception information. OnNext(T) Notify observers. Declaration public void OnNext(T value) Parameters Type Name Description T value Value to observers. OnNext(T, IEnumerable>) Notify observers. Declaration public void OnNext(T value, IEnumerable> observersSubset) Parameters Type Name Description T value Value to observers. IEnumerable < IObserver > observersSubset Subset of observers to notify. Subscribe(IObserver) Notifies the provider that an observer is to receive notifications. Declaration public virtual IDisposable Subscribe(IObserver observer) Parameters Type Name Description IObserver observer The object that is to receive notifications. Returns Type Description IDisposable A reference to an interface that allows observers to stop receiving notifications before the provider has finished sending them. Events CollectionChanged Collection changed event. Declaration public event NotifyCollectionChangedEventHandler CollectionChanged Event Type Type Description NotifyCollectionChangedEventHandler Implements System.IObservable System.IObserver System.Collections.Specialized.INotifyCollectionChanged Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.AudioVideoFramePlayerSettings.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioVideoFramePlayerSettings.html", - "title": "Class AudioVideoFramePlayerSettings", - "keywords": "Class AudioVideoFramePlayerSettings AudioVideoFramePlayer settings. This will help configure the player settings. Inheritance Object AudioVideoFramePlayerSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioVideoFramePlayerSettings Constructors AudioVideoFramePlayerSettings(AudioSettings, VideoSettings, UInt32) Constructor Declaration public AudioVideoFramePlayerSettings(AudioSettings audioSettings, VideoSettings videoSettings, uint minEnqueuedMediaLengthInMs) Parameters Type Name Description AudioSettings audioSettings BufferSize needs to be set to the size of AudioMediaBuffer to be sent VideoSettings videoSettings UInt32 minEnqueuedMediaLengthInMs Properties AudioSettings Audio settings Declaration public AudioSettings AudioSettings { get; set; } Property Value Type Description AudioSettings MinEnqueuedMediaLengthInMs The minimum length after which the player will raise the LowOnFrames event Declaration public uint MinEnqueuedMediaLengthInMs { get; set; } Property Value Type Description UInt32 VideoSettings Video Settings Declaration public VideoSettings VideoSettings { get; set; } Property Value Type Description VideoSettings" + "common/Microsoft.Graph.Communications.Common.Transport.IGraphResponse.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphResponse.html", + "title": "Interface IGraphResponse", + "keywords": "Interface IGraphResponse The response got in exchange of a IGraphRequest . Inherited Members IGraphResponse.Status IGraphResponse.ReasonPhrase IGraphResponse.ErrorContent IGraphExchange.Content IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphResponse : IGraphResponse, IGraphExchange, IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphResponseExtensions.ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable)" + }, + "common/Microsoft.Graph.Communications.Common.ObjectRootDisposable.html": { + "href": "common/Microsoft.Graph.Communications.Common.ObjectRootDisposable.html", + "title": "Class ObjectRootDisposable", + "keywords": "Class ObjectRootDisposable Base object. Inheritance Object Disposable ObjectRootDisposable TaskQueue Implements IDisposable Inherited Members Disposable.Dispose() Disposable.Dispose(Boolean) Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public abstract class ObjectRootDisposable : Disposable, IDisposable Constructors ObjectRootDisposable(IGraphLogger) Initializes a new instance of the ObjectRootDisposable class. Declaration protected ObjectRootDisposable(IGraphLogger logger) Parameters Type Name Description IGraphLogger logger Logger instance. Properties GraphLogger Gets the logger. Declaration protected IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + }, + "client/Microsoft.Graph.Communications.Client.ICommunicationsClient.html": { + "href": "client/Microsoft.Graph.Communications.Client.ICommunicationsClient.html", + "title": "Interface ICommunicationsClient", + "keywords": "Interface ICommunicationsClient The CommunicationsClient interface. This is the entry point of the SDK and a reference to this instance must be held for the duration of the session. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface ICommunicationsClient : IDisposable Properties AppId Gets the application identifier. Declaration string AppId { get; } Property Value Type Description String AppName Gets the name of the application. Declaration string AppName { get; } Property Value Type Description String AuthenticationProvider Gets the authentication provider used to authenticate both inbound and outbound requests. Declaration IRequestAuthenticationProvider AuthenticationProvider { get; } Property Value Type Description IRequestAuthenticationProvider BaseUrl Gets the Graph service's base URL. Declaration string BaseUrl { get; } Property Value Type Description String GraphClient Gets the graph client. This is the Client used to communicate with the service. Declaration IGraphClient GraphClient { get; } Property Value Type Description IGraphClient GraphLogger Gets the graph logger. This is the logger used within the SDK. Declaration IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Id Gets the client identifier. Declaration Guid Id { get; } Property Value Type Description Guid Serializer Gets the serializer Declaration ISerializer Serializer { get; } Property Value Type Description ISerializer Methods ProcessNotifications(Uri, CommsNotifications, String, Guid, Guid, IDictionary) Processes the notifications and raise the required callbacks. This function should be called in order for the SDK to raise any required events and process state changes. Declaration void ProcessNotifications(Uri callbackUri, CommsNotifications notifications, string tenantId, Guid requestId, Guid scenarioId, IDictionary additionalData = null) Parameters Type Name Description Uri callbackUri The callback URI. CommsNotifications notifications The notifications. String tenantId The tenant identifier. Guid requestId The request identifier. Guid scenarioId The scenario identifier. IDictionary < String , Object > additionalData Additional data associated with the notification. RehydrateAsync(String, String, Guid) Re-hydrates the resource at the specified path asynchronously. Declaration Task RehydrateAsync(string resourcePath, string tenantId, Guid scenarioId = default(Guid)) Parameters Type Name Description String resourcePath The resource path. String tenantId The tenant identifier. Guid scenarioId The scenario identifier. Returns Type Description Task The Task . TerminateAsync(TimeSpan) Terminates this client asynchronously. This terminates all the calls, waits for dispose events, and disposes everything. Declaration Task TerminateAsync(TimeSpan timeout = default(TimeSpan)) Parameters Type Name Description TimeSpan timeout The timeout. Returns Type Description Task < Boolean > True if all instances terminated successfully, false otherwise. Events OnNotificationException Occurs when exceptions are raised on notification callbacks. Declaration event Action OnNotificationException Event Type Type Description Action < FailedNotificationEventArgs > OnNotificationProcessed Occurs when the notification has been processed by all callbacks. Declaration event Action OnNotificationProcessed Event Type Type Description Action < NotificationEventArgs > OnNotificationQueued Occurs when the notification has been queued into the backlog. Declaration event Action OnNotificationQueued Event Type Type Description Action < NotificationEventArgs > Extension Methods CommunicationsClientExtensions.ProcessNotificationAsync(ICommunicationsClient, HttpRequestMessage) CommunicationsClientExtensions.LogAndCreateResponse(ICommunicationsClient, HttpRequestMessage, Guid, Guid, CommsNotifications, HttpStatusCode, Stopwatch, Exception) CommunicationsClientExtensions.CreateResponse(ICommunicationsClient, HttpStatusCode, Guid, Guid, Object)" + }, + "client/Microsoft.Graph.Communications.Common.Telemetry.CommsLogEventFormatter.html": { + "href": "client/Microsoft.Graph.Communications.Common.Telemetry.CommsLogEventFormatter.html", + "title": "Class CommsLogEventFormatter", + "keywords": "Class CommsLogEventFormatter Test log formatter. Inheritance Object CommsLogEventFormatter Implements ILogEventFormatter Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class CommsLogEventFormatter : ILogEventFormatter Constructors CommsLogEventFormatter() Declaration public CommsLogEventFormatter() Methods Format(LogEvent) Declaration public string Format(LogEvent logEvent) Parameters Type Name Description LogEvent logEvent Returns Type Description String Implements ILogEventFormatter" + }, + "common/Microsoft.Graph.Communications.Common.html": { + "href": "common/Microsoft.Graph.Communications.Common.html", + "title": "Namespace Microsoft.Graph.Communications.Common", + "keywords": "Namespace Microsoft.Graph.Communications.Common Classes AutoClean Helper class to automatically cleanup. AutoClean Helper class to automatically cleanup but with associated state. CertUtils Certificates utilities CollectionUtils Collection Utilities Disposable Common disposable pattern EnumUtils Enum Utilities ExceptionUtils Exception utilities Extensions Defines Extensions. GuidUtils Guid Utils HighResolutionDateTime High resolution datetime HttpConstants The constant values for http. HttpConstants.HeaderNames The header names. JsonUtils Json Utils MathUtils Various math utilities MetricUtils The metric utils class ObjectRoot Base object. ObjectRootDisposable Base object. Observable Observable Base class Observer Observer class. ReflectionUtils Reflection utilities SafeNativeMethods Contains p/invokes and associated wrappers for the Native methods SecureStringUtils SecureString Utilities SlimLock A SemaphoreSlim based lock implementation StateMachine Lockfree enum-based state machine. Transitions are O(1). StateMachine.Transition Single transition from Source to Targets StringUtils String Utils TaskExtension Extensions for Task TaskQueue Task queue to encapsulate chaining of tasks. Utilities Utilities class. Validator Helper class with various condition validation utilities. WeakKey Wrapping a weak reference and recording hash code. Note: It is the responsibility of the client to clean up the collection entry in the finalizer of the object. Otherwise the key will not match for subsequent lookups. WeakKeyDictionary Dictionary with weak reference for the key." + }, + "common/Microsoft.Graph.Communications.Common.Transport.IGraphClientFactory.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphClientFactory.html", + "title": "Interface IGraphClientFactory", + "keywords": "Interface IGraphClientFactory Interface for factory of IGraphClient . Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphClientFactory Methods Create(IGraphLogger) Creates a new IGraphClient . Declaration IGraphClient Create(IGraphLogger logger = null) Parameters Type Name Description IGraphLogger logger An optional IGraphLogger logger to be used in the new IGraphClient . Returns Type Description IGraphClient The IGraphClient . Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + }, + "common/Microsoft.Graph.Communications.Common.Transport.GraphResponseExtensions.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphResponseExtensions.html", + "title": "Class GraphResponseExtensions", + "keywords": "Class GraphResponseExtensions Extensions for IGraphResponse class. Inheritance Object GraphResponseExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class GraphResponseExtensions Methods ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable) Converts IGraphResponse into a HttpResponseMessage . Declaration public static HttpResponseMessage ToHttpResponseMessage(this IGraphResponse graphResponse, JsonSerializerSettings jsonSerializerSettings = null, IEnumerable defaultProperties = null) Parameters Type Name Description IGraphResponse graphResponse The graph response to be converted. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. IEnumerable < IGraphProperty > defaultProperties The default properties. Returns Type Description HttpResponseMessage HttpResponseMessage corresponding to graphResponse . Type Parameters Name Description T Type of content available in the response. ToHttpStatus(ResponseStatus) Convert ResponseStatus to it's corresponding HttpStatusCode . Declaration public static HttpStatusCode ToHttpStatus(this ResponseStatus status) Parameters Type Name Description ResponseStatus status The status. Returns Type Description HttpStatusCode HttpStatusCode for the ResponseStatus" }, - "bot_media/Microsoft.Skype.Bots.Media.DataType.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.DataType.html", - "title": "Enum DataType", - "keywords": "Enum DataType Reserved for internal use. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum DataType Fields Name Description MultichannelAudio Reserved for internal use. Transcript Reserved for internal use." + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationConfiguration.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationConfiguration.html", + "title": "Class ObfuscationConfiguration", + "keywords": "Class ObfuscationConfiguration Configuration for obfuscation of different parts. Inheritance Object ObfuscationConfiguration HashingObfuscationConfiguration Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ObfuscationConfiguration Constructors ObfuscationConfiguration(IObfuscationEngine, IEnumerable, Boolean, ObfuscationMember[]) Initializes a new instance of the ObfuscationConfiguration class. Declaration public ObfuscationConfiguration(IObfuscationEngine engine, IEnumerable filters = null, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IObfuscationEngine engine The obfuscation engine. IEnumerable < BaseFilter > filters The filters. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . ObfuscationConfiguration(IObfuscationEngine, IEnumerable, IEnumerable, IEnumerable, Boolean, ObfuscationMember[]) Initializes a new instance of the ObfuscationConfiguration class. Declaration public ObfuscationConfiguration(IObfuscationEngine engine, IEnumerable headerFilters, IEnumerable contentDispositionFilters, IEnumerable contentTypeFilters, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IObfuscationEngine engine The obfuscation engine. IEnumerable < HeaderFilter > headerFilters The header filters. IEnumerable < ContentDispositionFilter > contentDispositionFilters The content disposition filters. IEnumerable < ContentTypeFilter > contentTypeFilters The content type filters. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . Properties ContentDispositionFilters Gets the content disposition filters. Declaration public IEnumerable ContentDispositionFilters { get; } Property Value Type Description IEnumerable < ContentDispositionFilter > ContentTypeFilters Gets the content type filters. Declaration public IEnumerable ContentTypeFilters { get; } Property Value Type Description IEnumerable < ContentTypeFilter > DefaultContentDispositionFilters Gets the default content disposition filters. Declaration public static IEnumerable DefaultContentDispositionFilters { get; } Property Value Type Description IEnumerable < ContentDispositionFilter > DefaultContentTypeFilters Gets the default content type filters. Declaration public static IEnumerable DefaultContentTypeFilters { get; } Property Value Type Description IEnumerable < ContentTypeFilter > DefaultHeaderFilters Gets the default header filters. Transfer-Encoding: (redacted) OData-Version: (redacted) Duration: (redacted) Strict-Transport-Security: (redacted) Cache-Control: (redacted) Date: (redacted) Location: (redacted) x-ms-ags-diagnostic: (redacted) scenario-id: (redacted) request-id: (redacted) client-request-id: (redacted) X-Microsoft-Skype-Chain-ID: (redacted) X-Microsoft-Skype-Caller-Region: (redacted) X-Microsoft-Skype-Callee-Region: (redacted) X-Microsoft-Skype-Message-ID: (redacted) X-Microsoft-Skype-Original-Message-ID: (redacted) Declaration public static IEnumerable DefaultHeaderFilters { get; } Property Value Type Description IEnumerable < HeaderFilter > DefaultUriFilters Gets the default header filters. Declaration public static IEnumerable DefaultUriFilters { get; } Property Value Type Description IEnumerable < UriFilter > HeaderFilters Gets the header filters. Declaration public IEnumerable HeaderFilters { get; } Property Value Type Description IEnumerable < HeaderFilter > ObfuscationEngine Gets the obfuscation engine. Declaration public IObfuscationEngine ObfuscationEngine { get; } Property Value Type Description IObfuscationEngine ObfuscationMembers Gets the obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . This can be used to cache obfuscation attributes, but it can also be used in cases where original contracts are not redily available (such as in SDK). Declaration public ObfuscationMember[] ObfuscationMembers { get; } Property Value Type Description ObfuscationMember [] ObfuscationSerializerSettings Gets the obfuscation serializer settings. Declaration public JsonSerializerSettings ObfuscationSerializerSettings { get; } Property Value Type Description Newtonsoft.Json.JsonSerializerSettings UriFilters Gets the URI filters. Declaration public IEnumerable UriFilters { get; } Property Value Type Description IEnumerable < UriFilter > Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) HttpObfuscationHelpers.LogHeaderText(ObfuscationConfiguration, IEnumerable>>) HttpObfuscationHelpers.LogHeaderText(ObfuscationConfiguration, String, IEnumerable)" }, - "bot_media/Microsoft.Skype.Bots.Media.IMediaPlatformLogger.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.IMediaPlatformLogger.html", - "title": "Interface IMediaPlatformLogger", - "keywords": "Interface IMediaPlatformLogger Interface for collecting MediaPlatform logs from the Bots.Media library. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IMediaPlatformLogger Methods WriteLog(LogLevel, String) Log a trace statement Declaration void WriteLog(LogLevel level, string logStatement) Parameters Type Name Description LogLevel level Level of log String logStatement The log itself." + "common/Microsoft.Graph.Communications.Common.OData.html": { + "href": "common/Microsoft.Graph.Communications.Common.OData.html", + "title": "Namespace Microsoft.Graph.Communications.Common.OData", + "keywords": "Namespace Microsoft.Graph.Communications.Common.OData Classes CamelCaseStringEnumConverter Converts an System.Enum to and from its name string value. When converting to its string value it will use camelCase formatting. ODataConfiguration OData Configuration object to be used for different classes. ODataConstants The OData constants. ODataJsonConverter Handles resolving interfaces to the correct derived class during serialization/deserialization. ODataResolver Contract resolver that allows us to create OData json payloads with type information. ODataSerializeAsTypeAttribute Specify how a given object should be written/read on the wire. ODataTimeSpanConverter Custom json converter for TimeSpans." }, - "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformFactory.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformFactory.html", - "title": "Class MediaPlatformFactory", - "keywords": "Class MediaPlatformFactory MediaPlatformFactory that is used to create IMediaPlatform. Inheritance Object MediaPlatformFactory Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public static class MediaPlatformFactory Methods CreateMediaPlatform() Creates the Media Platform for bots. The platform has to be initialized before it is used. Declaration public static IMediaPlatform CreateMediaPlatform() Returns Type Description IMediaPlatform The interface to the Media Platform." + "common/Microsoft.Graph.Communications.Common.CertUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.CertUtils.html", + "title": "Class CertUtils", + "keywords": "Class CertUtils Certificates utilities Inheritance Object CertUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class CertUtils Methods GetCertificate(String, StoreLocation) Get certificate from the certificate store, throw exception if not found. Declaration public static X509Certificate2 GetCertificate(string thumbprint, StoreLocation location) Parameters Type Name Description String thumbprint The thumbprint. StoreLocation location The certificate store location. Returns Type Description X509Certificate2 True if the certificate is found. HasPrivateKeyAccess(X509Certificate2, IGraphLogger) Verifies the private key access on a given certificate. If a logger is provided, the cert Common name and any errors are printed out. Declaration public static bool HasPrivateKeyAccess(this X509Certificate2 certificate, IGraphLogger logger = null) Parameters Type Name Description X509Certificate2 certificate The certificate. IGraphLogger logger The logger. Returns Type Description Boolean True if private key can be accessed, false otherwise. TryGetCertificate(String, StoreLocation) Tries to the get certificate from the certificate store. Declaration public static X509Certificate2 TryGetCertificate(string thumbprint, StoreLocation location) Parameters Type Name Description String thumbprint The thumbprint. StoreLocation location The certificate store location. Returns Type Description X509Certificate2 True if the certificate is found. TryGetCertificate(String, String, StoreLocation) Tries to the get certificate from the certificate store. Declaration public static X509Certificate2 TryGetCertificate(string issuer, string enhancedKeyUsage, StoreLocation location) Parameters Type Name Description String issuer The issuer. String enhancedKeyUsage Enhanced key usage. StoreLocation location The certificate store location. Returns Type Description X509Certificate2 True if the certificate is found. TryGetCertificateWithCommonName(String, StoreLocation) Tries to get certificate with common name from the certificate store. Declaration public static X509Certificate2 TryGetCertificateWithCommonName(string commonName, StoreLocation location) Parameters Type Name Description String commonName Name of the common. StoreLocation location The location. Returns Type Description X509Certificate2 The certificate. null if not found." }, - "bot_media/Microsoft.Skype.Bots.Media.VideoLowOnFramesEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoLowOnFramesEventArgs.html", - "title": "Class VideoLowOnFramesEventArgs", - "keywords": "Class VideoLowOnFramesEventArgs Video low on frame event args Inheritance Object EventArgs LowOnFramesEventArgs VideoLowOnFramesEventArgs Inherited Members LowOnFramesEventArgs.MediaType LowOnFramesEventArgs.RemainingMediaLengthInMS EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoLowOnFramesEventArgs : LowOnFramesEventArgs Constructors VideoLowOnFramesEventArgs() Declaration public VideoLowOnFramesEventArgs() Properties VideoFormat The video format for the low on frame event Declaration public VideoFormat VideoFormat { get; set; } Property Value Type Description VideoFormat" + "core/Microsoft.Graph.Communications.Core.Notifications.NotificationEventArgs.html": { + "href": "core/Microsoft.Graph.Communications.Core.Notifications.NotificationEventArgs.html", + "title": "Class NotificationEventArgs", + "keywords": "Class NotificationEventArgs Notification event arguments class. Inheritance Object NotificationEventArgs CollectionNotificationEventArgs Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class NotificationEventArgs Constructors NotificationEventArgs(Uri, CommsNotification, ChangeType, Object) Initializes a new instance of the NotificationEventArgs class. Declaration public NotificationEventArgs(Uri callbackUri, CommsNotification notification, ChangeType changeType, object resourceData) Parameters Type Name Description Uri callbackUri The callback URI. CommsNotification notification The notification. ChangeType changeType Type of the change. Object resourceData The resource data. Properties AdditionalData Gets or sets the additional data. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > CallbackUri Gets the callback URI. Declaration public Uri CallbackUri { get; } Property Value Type Description Uri ChangeType Gets the type of the change. Declaration public ChangeType ChangeType { get; } Property Value Type Description ChangeType Notification Gets the notification. Declaration public CommsNotification Notification { get; } Property Value Type Description CommsNotification NotificationId Gets the notification identifier. Declaration public Guid NotificationId { get; } Property Value Type Description Guid RequestId Gets or sets the request identifier. Declaration public Guid RequestId { get; set; } Property Value Type Description Guid ResourceData Gets the resource data. Declaration public object ResourceData { get; } Property Value Type Description Object ScenarioId Gets or sets the scenario identifier. Declaration public Guid ScenarioId { get; set; } Property Value Type Description Guid TenantId Gets or sets the tenant. Declaration public string TenantId { get; set; } Property Value Type Description String" }, - "bot_media/Microsoft.Skype.Bots.Media.VideoMediaBuffer.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoMediaBuffer.html", - "title": "Class VideoMediaBuffer", - "keywords": "Class VideoMediaBuffer Represents an unmanaged buffer containing video media data. Inheritance Object VideoMediaBuffer Implements IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public abstract class VideoMediaBuffer : IDisposable Constructors VideoMediaBuffer() Declaration protected VideoMediaBuffer() Properties Data Pointer to the unmanaged media buffer. Declaration public IntPtr Data { get; protected set; } Property Value Type Description IntPtr Remarks For the H264 video format, Data points to the start code of the first NALU of the frame and the whole buffer contains all the NALUs of the frame in sequence separated by their start codes. The frame data is an unencrypted depacketized H.264 elementary stream. B frames and SEI messages are not supported. Supported NALU types are 7 (SPS), 8 (PPS), 5 (IDR), and 1 (non-IDR). NALU start code prefixes can be either 0x000001 (3 bytes) or 0x00000001 (4 bytes). Fragmentation and packetization of NALUs is automatically handled by the platform. When receiving video in the H264 format, the platform ensures the application always receives decodable, full frames. Length The length of data in the media buffer. Declaration public long Length { get; protected set; } Property Value Type Description Int64 MediaSourceId MediaSourceId (MSI) of the video buffer. Within group or conference video calls, the MSI value identifies the video media source. This property is populated by the Real-Time Media Platform for Bots on received video buffers. When sending buffers via the IVideoSocket.Send API, this property is unused. Declaration public uint MediaSourceId { get; protected set; } Property Value Type Description UInt32 OriginalVideoFormat Original VideoFormat of the buffer when it was sourced. It is only used when receiving video buffers via the IVideoSocket.VideoMediaReceived event handler, in which case the VideoMediaBuffer.VideoFormat property may have different Width and Height values than the OriginalVideoFormat property, which represents the original format of the buffer. The reason is that the buffer may have been resized before being transmitted, so the original Width and Height may have been resized. If the Width and Height properties of OriginalVideoFormat differ from the VideoFormat property, the consumer of the VideoMediaBuffer raised in the VideoMediaReceived event should resize the buffer to fit the OriginalVideoFormat size. When sending buffers via the IVideoSocket.Send API, this property should always be null. Declaration public VideoFormat OriginalVideoFormat { get; protected set; } Property Value Type Description VideoFormat Stride Stride of the video buffer. This property is optional when sourcing video buffers that are sent via the IVideoSocket.Send API. Stride (also called pitch) represents the number of bytes it takes to read one row of pixels in memory. It may differ from the width depending on the color format. Declaration public int Stride { get; protected set; } Property Value Type Description Int32 Timestamp Timestamp of when the media content was sourced, in 100-ns units. When sourcing media buffers, this property should be set using the value from the MediaPlatform.GetCurrentTimestamp() API. Declaration public long Timestamp { get; protected set; } Property Value Type Description Int64 VideoFormat VideoFormat of the video media buffer. Declaration public VideoFormat VideoFormat { get; protected set; } Property Value Type Description VideoFormat Methods Dispose() Disposes the object. Declaration public void Dispose() Dispose(Boolean) Releases unmanaged resources held by the buffer object. Must be implemented in the derived class. Declaration protected abstract void Dispose(bool disposing) Parameters Type Name Description Boolean disposing If true, both managed and unmanaged resources can be disposed. If false, only unmanaged resources can be disposed. Implements System.IDisposable" + "common/Microsoft.Graph.Communications.Common.Exceptions.html": { + "href": "common/Microsoft.Graph.Communications.Common.Exceptions.html", + "title": "Namespace Microsoft.Graph.Communications.Common.Exceptions", + "keywords": "Namespace Microsoft.Graph.Communications.Common.Exceptions Classes ConfigurationException Configuration is bad. Mandatory configuration setting is missing. Or raw (string) setting value can not be converted to property type. InvalidStateTransitionException Exception to throw when a invalid transition is requested RoutingBadRequestException Indicate there's a bad request RoutingException Generic routing exception" }, - "bot_media/Microsoft.Skype.Bots.Media.VideoSocketSettings.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSocketSettings.html", - "title": "Class VideoSocketSettings", - "keywords": "Class VideoSocketSettings The video socket settings. Inheritance Object VideoSocketSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoSocketSettings Constructors VideoSocketSettings() Initializes a VideoSocketSettings object. Declaration public VideoSocketSettings() Properties CallId An alphanumeric string that uniquely identifies a call. Declaration public string CallId { get; set; } Property Value Type Description String MaxConcurrentSendStreams The maximum number of concurrent (simulcast) streams that can be sent. Declaration public uint MaxConcurrentSendStreams { get; set; } Property Value Type Description UInt32 Remarks This setting applies only if the VideoSocket uses H264 encoded video formats. MediaType Specifies the media type of the VideoSocket. Valid types are: MediaType.Video and MediaType.Vbss Declaration public MediaType? MediaType { get; set; } Property Value Type Description Nullable < MediaType > ReceiveColorFormat What color format should received video be delivered in. Currently only NV12 and H264 are allowed. Declaration public VideoColorFormat ReceiveColorFormat { get; set; } Property Value Type Description VideoColorFormat StreamDirections The directionality of the media stream. This indicates whether it is enabled to both send and receive media, or only send or only receive media. Declaration public StreamDirection StreamDirections { get; set; } Property Value Type Description StreamDirection SupportedSendVideoFormats The list of video formats the VideoSocket supports sending. Declaration public IList SupportedSendVideoFormats { get; set; } Property Value Type Description IList < VideoFormat > Remarks For the main-video modality ( MediaType.Video ), the following ten H264 send video formats are supported: H264_1920x1080_30Fps H264_1280x720_30Fps H264_960x540_30Fps H264_640x360_30Fps H264_640x360_15Fps H264_424x240_15Fps H264_320x180_15Fps H264_320x180_7_5Fps H264_320x180_3_75Fps H264_320x180_1_875Fps (If the SupportedSendVideoFormats list contains other H264 video formats for main-video, they will be ignored and not used.) At least one of the H264_320x180 video formats must be supported. For best video interoperability, the bot should support all the H264_320x180 formats. For the Vbss modality, all of the send formats must be of the same resolution. The resolution should best match the native resolution of the content to be shared. Downscaling the Vbss content to a lower resolution should be avoided (but may be necessary if the native content resolution is larger than 1080p). The bot should support as many different frame rates as possible. The 1.875 fps frame rate must be supported." + "client/Microsoft.Graph.Communications.Client.Transport.html": { + "href": "client/Microsoft.Graph.Communications.Client.Transport.html", + "title": "Namespace Microsoft.Graph.Communications.Client.Transport", + "keywords": "Namespace Microsoft.Graph.Communications.Client.Transport Classes GraphAuthClient The graph auth client. GraphAuthClientFactory The HTTP graph client factory. GraphClientContext The context for the graph client wrapper. GraphClientWrapper The graph client wrapper." }, - "bot_media/Microsoft.Skype.Bots.Media.MediaType.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaType.html", - "title": "Enum MediaType", - "keywords": "Enum MediaType Indicates the media type of the socket. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaType Fields Name Description Audio Audio Data Reserved for internal use. Vbss Video-based screen sharing (VBSS) Video Video" + "client/Microsoft.Graph.Communications.Client.Cache.html": { + "href": "client/Microsoft.Graph.Communications.Client.Cache.html", + "title": "Namespace Microsoft.Graph.Communications.Client.Cache", + "keywords": "Namespace Microsoft.Graph.Communications.Client.Cache Classes ServiceCache The cache that restores the data directly from the service. In this case there is no storage of data, as the service acts as the master. Structs CacheContext The stored cache context Interfaces ICache The cache interface used to store and recover the data used by the SDK." }, - "bot_media/Microsoft.Skype.Bots.Media.VideoFormat.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoFormat.html", - "title": "Class VideoFormat", - "keywords": "Class VideoFormat VideoFormat Inheritance Object VideoFormat Implements IEquatable < VideoFormat > Inherited Members Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoFormat : IEquatable Fields H264_1280x720_1_875Fps H264 1280x720 1.875fps video format Declaration public static readonly VideoFormat H264_1280x720_1_875Fps Field Value Type Description VideoFormat H264_1280x720_15Fps H264 1280x720 15fps video format Declaration public static readonly VideoFormat H264_1280x720_15Fps Field Value Type Description VideoFormat H264_1280x720_3_75Fps H264 1280x720 3.75fps video format Declaration public static readonly VideoFormat H264_1280x720_3_75Fps Field Value Type Description VideoFormat H264_1280x720_30Fps H264 1280x720 30fps video format Declaration public static readonly VideoFormat H264_1280x720_30Fps Field Value Type Description VideoFormat H264_1280x720_7_5Fps H264 1280x720 7.5fps video format Declaration public static readonly VideoFormat H264_1280x720_7_5Fps Field Value Type Description VideoFormat H264_1920x1080_1_875Fps H264 1920x1080 1.875fps video format Declaration public static readonly VideoFormat H264_1920x1080_1_875Fps Field Value Type Description VideoFormat H264_1920x1080_15Fps H264 1920x1080 15fps video format Declaration public static readonly VideoFormat H264_1920x1080_15Fps Field Value Type Description VideoFormat H264_1920x1080_3_75Fps H264 1920x1080 3.75fps video format Declaration public static readonly VideoFormat H264_1920x1080_3_75Fps Field Value Type Description VideoFormat H264_1920x1080_30Fps H264 1920x1080 30fps video format Declaration public static readonly VideoFormat H264_1920x1080_30Fps Field Value Type Description VideoFormat H264_1920x1080_7_5Fps H264 1920x1080 7.5fps video format Declaration public static readonly VideoFormat H264_1920x1080_7_5Fps Field Value Type Description VideoFormat H264_320x180_1_875Fps H264 320x180 1.875fps video format Declaration public static readonly VideoFormat H264_320x180_1_875Fps Field Value Type Description VideoFormat H264_320x180_15Fps H264 320x180 15fps video format Declaration public static readonly VideoFormat H264_320x180_15Fps Field Value Type Description VideoFormat H264_320x180_3_75Fps H264 320x180 3.75fps video format Declaration public static readonly VideoFormat H264_320x180_3_75Fps Field Value Type Description VideoFormat H264_320x180_7_5Fps H264 320x180 7.5fps video format Declaration public static readonly VideoFormat H264_320x180_7_5Fps Field Value Type Description VideoFormat H264_424x240_15Fps H264 424x240 15fps video format Declaration public static readonly VideoFormat H264_424x240_15Fps Field Value Type Description VideoFormat H264_640x360_15Fps H264 640x360 15fps video format Declaration public static readonly VideoFormat H264_640x360_15Fps Field Value Type Description VideoFormat H264_640x360_30Fps H264 640x360 30fps video format Declaration public static readonly VideoFormat H264_640x360_30Fps Field Value Type Description VideoFormat H264_960x540_30Fps H264 960x540 30fps video format Declaration public static readonly VideoFormat H264_960x540_30Fps Field Value Type Description VideoFormat NV12_1080x1920_30Fps NV12 1080x1920 30fps video format Declaration public static readonly VideoFormat NV12_1080x1920_30Fps Field Value Type Description VideoFormat NV12_1280x720_1_875Fps NV12 1280x720 1.875fps video format Declaration public static readonly VideoFormat NV12_1280x720_1_875Fps Field Value Type Description VideoFormat NV12_1280x720_15Fps NV12 1280x720 15fps video format Declaration public static readonly VideoFormat NV12_1280x720_15Fps Field Value Type Description VideoFormat NV12_1280x720_3_75Fps NV12 1280x720 3.75fps video format Declaration public static readonly VideoFormat NV12_1280x720_3_75Fps Field Value Type Description VideoFormat NV12_1280x720_30Fps NV12 1280x720 30fps video format Declaration public static readonly VideoFormat NV12_1280x720_30Fps Field Value Type Description VideoFormat NV12_1280x720_7_5Fps NV12 1280x720 7.5fps video format Declaration public static readonly VideoFormat NV12_1280x720_7_5Fps Field Value Type Description VideoFormat NV12_180x320_30Fps NV12 180x320 15fps video format Declaration public static readonly VideoFormat NV12_180x320_30Fps Field Value Type Description VideoFormat NV12_1920x1080_1_875Fps NV12 1920x1080 1.875fps video format Declaration public static readonly VideoFormat NV12_1920x1080_1_875Fps Field Value Type Description VideoFormat NV12_1920x1080_15Fps NV12 1920x1080 15fps video format Declaration public static readonly VideoFormat NV12_1920x1080_15Fps Field Value Type Description VideoFormat NV12_1920x1080_3_75Fps NV12 1920x1080 3.75fps video format Declaration public static readonly VideoFormat NV12_1920x1080_3_75Fps Field Value Type Description VideoFormat NV12_1920x1080_30Fps NV12 1920x1080 30fps video format Declaration public static readonly VideoFormat NV12_1920x1080_30Fps Field Value Type Description VideoFormat NV12_1920x1080_7_5Fps NV12 1920x1080 7.5fps video format Declaration public static readonly VideoFormat NV12_1920x1080_7_5Fps Field Value Type Description VideoFormat NV12_240x424_15Fps NV12 240x424 15fps video format Declaration public static readonly VideoFormat NV12_240x424_15Fps Field Value Type Description VideoFormat NV12_270x480_15Fps NV12 270x480 15fps video format Declaration public static readonly VideoFormat NV12_270x480_15Fps Field Value Type Description VideoFormat NV12_320x180_15Fps NV12 320x180 15fps video format Declaration public static readonly VideoFormat NV12_320x180_15Fps Field Value Type Description VideoFormat NV12_360x640_15Fps NV12 360x640 15fps video format Declaration public static readonly VideoFormat NV12_360x640_15Fps Field Value Type Description VideoFormat NV12_360x640_30Fps NV12 360x640 30fps video format Declaration public static readonly VideoFormat NV12_360x640_30Fps Field Value Type Description VideoFormat NV12_424x240_15Fps NV12 424x240 15fps video format Declaration public static readonly VideoFormat NV12_424x240_15Fps Field Value Type Description VideoFormat NV12_480x270_15Fps NV12 480x270 15fps video format Declaration public static readonly VideoFormat NV12_480x270_15Fps Field Value Type Description VideoFormat NV12_480x848_30Fps NV12 480x848 30fps video format Declaration public static readonly VideoFormat NV12_480x848_30Fps Field Value Type Description VideoFormat NV12_540x960_30Fps NV12 540x960 30fps video format Declaration public static readonly VideoFormat NV12_540x960_30Fps Field Value Type Description VideoFormat NV12_640x360_15Fps NV12 640x360 15fps video format Declaration public static readonly VideoFormat NV12_640x360_15Fps Field Value Type Description VideoFormat NV12_640x360_30Fps NV12 640x360 30fps video format Declaration public static readonly VideoFormat NV12_640x360_30Fps Field Value Type Description VideoFormat NV12_720x1280_30Fps NV12 720x1280 30fps video format Declaration public static readonly VideoFormat NV12_720x1280_30Fps Field Value Type Description VideoFormat NV12_848x480_30Fps NV12 848x480 30fps video format Declaration public static readonly VideoFormat NV12_848x480_30Fps Field Value Type Description VideoFormat NV12_960x540_30Fps NV12 960x540 30fps video format Declaration public static readonly VideoFormat NV12_960x540_30Fps Field Value Type Description VideoFormat Rgb24_1080x1920_30Fps Rgb24 1080x1920 30fps video format Declaration public static readonly VideoFormat Rgb24_1080x1920_30Fps Field Value Type Description VideoFormat Rgb24_1280x720_1_875Fps Rgb24 1280x720 1.875fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_1_875Fps Field Value Type Description VideoFormat Rgb24_1280x720_15Fps Rgb24 1280x720 15fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_15Fps Field Value Type Description VideoFormat Rgb24_1280x720_3_75Fps Rgb24 1280x720 3.75fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_3_75Fps Field Value Type Description VideoFormat Rgb24_1280x720_30Fps Rgb24 1280x720 30fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_30Fps Field Value Type Description VideoFormat Rgb24_1280x720_7_5Fps Rgb24 1280x720 7.5fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_7_5Fps Field Value Type Description VideoFormat Rgb24_180x320_30Fps Rgb24 180x320 15fps video format Declaration public static readonly VideoFormat Rgb24_180x320_30Fps Field Value Type Description VideoFormat Rgb24_1920x1080_1_875Fps Rgb24 1920x1080 1.875fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_1_875Fps Field Value Type Description VideoFormat Rgb24_1920x1080_15Fps Rgb24 1920x1080 15fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_15Fps Field Value Type Description VideoFormat Rgb24_1920x1080_3_75Fps Rgb24 1920x1080 3.75fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_3_75Fps Field Value Type Description VideoFormat Rgb24_1920x1080_30Fps Rgb24 1920x1080 30fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_30Fps Field Value Type Description VideoFormat Rgb24_1920x1080_7_5Fps Rgb24 1920x1080 7.5fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_7_5Fps Field Value Type Description VideoFormat Rgb24_240x424_15Fps Rgb24 240x424 15fps video format Declaration public static readonly VideoFormat Rgb24_240x424_15Fps Field Value Type Description VideoFormat Rgb24_270x480_15Fps Rgb24 270x480 15fps video format Declaration public static readonly VideoFormat Rgb24_270x480_15Fps Field Value Type Description VideoFormat Rgb24_320x180_15Fps Rgb24 320x180 15fps video format Declaration public static readonly VideoFormat Rgb24_320x180_15Fps Field Value Type Description VideoFormat Rgb24_360x640_15Fps Rgb24 360x640 15fps video format Declaration public static readonly VideoFormat Rgb24_360x640_15Fps Field Value Type Description VideoFormat Rgb24_360x640_30Fps Rgb24 360x640 30fps video format Declaration public static readonly VideoFormat Rgb24_360x640_30Fps Field Value Type Description VideoFormat Rgb24_424x240_15Fps Rgb24 424x240 15fps video format Declaration public static readonly VideoFormat Rgb24_424x240_15Fps Field Value Type Description VideoFormat Rgb24_480x270_15Fps Rgb24 480x270 15fps video format Declaration public static readonly VideoFormat Rgb24_480x270_15Fps Field Value Type Description VideoFormat Rgb24_480x848_30Fps Rgb24 480x848 30fps video format Declaration public static readonly VideoFormat Rgb24_480x848_30Fps Field Value Type Description VideoFormat Rgb24_540x960_30Fps Rgb24 540x960 30fps video format Declaration public static readonly VideoFormat Rgb24_540x960_30Fps Field Value Type Description VideoFormat Rgb24_640x360_15Fps Rgb24 640x360 15fps video format Declaration public static readonly VideoFormat Rgb24_640x360_15Fps Field Value Type Description VideoFormat Rgb24_640x360_30Fps Rgb24 640x360 30fps video format Declaration public static readonly VideoFormat Rgb24_640x360_30Fps Field Value Type Description VideoFormat Rgb24_720x1280_30Fps Rgb24 720x1280 30fps video format Declaration public static readonly VideoFormat Rgb24_720x1280_30Fps Field Value Type Description VideoFormat Rgb24_848x480_30Fps Rgb24 848x480 30fps video format Declaration public static readonly VideoFormat Rgb24_848x480_30Fps Field Value Type Description VideoFormat Rgb24_960x540_30Fps Rgb24 960x540 30fps video format Declaration public static readonly VideoFormat Rgb24_960x540_30Fps Field Value Type Description VideoFormat Yuy2_1080x1920_30Fps YUY2 1080x1920 30fps video format Declaration public static readonly VideoFormat Yuy2_1080x1920_30Fps Field Value Type Description VideoFormat Yuy2_1280x720_1_875Fps YUY2 1280x720 1.875fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_1_875Fps Field Value Type Description VideoFormat Yuy2_1280x720_15Fps YUY2 1280x720 15fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_15Fps Field Value Type Description VideoFormat Yuy2_1280x720_3_75Fps YUY2 1280x720 3.75fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_3_75Fps Field Value Type Description VideoFormat Yuy2_1280x720_30Fps YUY2 1280x720 30fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_30Fps Field Value Type Description VideoFormat Yuy2_1280x720_7_5Fps YUY2 1280x720 7.5fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_7_5Fps Field Value Type Description VideoFormat Yuy2_180x320_30Fps YUY2 180x320 15fps video format Declaration public static readonly VideoFormat Yuy2_180x320_30Fps Field Value Type Description VideoFormat Yuy2_1920x1080_1_875Fps YUY2 1920x1080 1.875fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_1_875Fps Field Value Type Description VideoFormat Yuy2_1920x1080_15Fps YUY2 1920x1080 15fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_15Fps Field Value Type Description VideoFormat Yuy2_1920x1080_3_75Fps YUY2 1920x1080 3.75fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_3_75Fps Field Value Type Description VideoFormat Yuy2_1920x1080_30Fps YUY2 1920x1080 30fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_30Fps Field Value Type Description VideoFormat Yuy2_1920x1080_7_5Fps YUY2 1920x1080 7.5fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_7_5Fps Field Value Type Description VideoFormat Yuy2_240x424_15Fps YUY2 240x424 15fps video format Declaration public static readonly VideoFormat Yuy2_240x424_15Fps Field Value Type Description VideoFormat Yuy2_270x480_15Fps YUY2 270x480 15fps video format Declaration public static readonly VideoFormat Yuy2_270x480_15Fps Field Value Type Description VideoFormat Yuy2_320x180_15Fps YUY2 320x180 15fps video format Declaration public static readonly VideoFormat Yuy2_320x180_15Fps Field Value Type Description VideoFormat Yuy2_360x640_15Fps YUY2 360x640 15fps video format Declaration public static readonly VideoFormat Yuy2_360x640_15Fps Field Value Type Description VideoFormat Yuy2_360x640_30Fps YUY2 360x640 30fps video format Declaration public static readonly VideoFormat Yuy2_360x640_30Fps Field Value Type Description VideoFormat Yuy2_424x240_15Fps YUY2 424x240 15fps video format Declaration public static readonly VideoFormat Yuy2_424x240_15Fps Field Value Type Description VideoFormat Yuy2_480x270_15Fps YUY2 480x270 15fps video format Declaration public static readonly VideoFormat Yuy2_480x270_15Fps Field Value Type Description VideoFormat Yuy2_480x848_30Fps YUY2 480x848 30fps video format Declaration public static readonly VideoFormat Yuy2_480x848_30Fps Field Value Type Description VideoFormat Yuy2_540x960_30Fps YUY2 540x960 30fps video format Declaration public static readonly VideoFormat Yuy2_540x960_30Fps Field Value Type Description VideoFormat Yuy2_640x360_15Fps YUY2 640x360 15fps video format Declaration public static readonly VideoFormat Yuy2_640x360_15Fps Field Value Type Description VideoFormat Yuy2_640x360_30Fps YUY2 640x360 30fps video format Declaration public static readonly VideoFormat Yuy2_640x360_30Fps Field Value Type Description VideoFormat Yuy2_720x1280_30Fps YUY2 720x1280 30fps video format Declaration public static readonly VideoFormat Yuy2_720x1280_30Fps Field Value Type Description VideoFormat Yuy2_848x480_30Fps YUY2 848x480 30fps video format Declaration public static readonly VideoFormat Yuy2_848x480_30Fps Field Value Type Description VideoFormat Yuy2_960x540_30Fps YUY2 960x540 30fps video format Declaration public static readonly VideoFormat Yuy2_960x540_30Fps Field Value Type Description VideoFormat Properties BitRate Bit rate Declaration public uint BitRate { get; } Property Value Type Description UInt32 FrameRate Frame rate Declaration public float FrameRate { get; } Property Value Type Description Single Height Height Declaration public int Height { get; } Property Value Type Description Int32 VideoColorFormat VideoColorFormat Declaration public VideoColorFormat VideoColorFormat { get; } Property Value Type Description VideoColorFormat Width Width Declaration public int Width { get; } Property Value Type Description Int32 Methods Equals(VideoFormat) Equals to compare videoformat objects Declaration public bool Equals(VideoFormat videoFormat) Parameters Type Name Description VideoFormat videoFormat Returns Type Description Boolean Equals(Object) Overrides base Equals to compare objects Declaration public override bool Equals(object obj) Parameters Type Name Description Object obj Returns Type Description Boolean Overrides Object.Equals(Object) GetHashCode() Custom GetHashCode implementation Declaration public override int GetHashCode() Returns Type Description Int32 Overrides Object.GetHashCode() ToString() Provides video format details by overriding the default ToString(). Declaration public override string ToString() Returns Type Description String Details of VideoFormat. Overrides Object.ToString() Operators Equality(VideoFormat, VideoFormat) Overload == operator to do VideoFormat comparison Declaration public static bool operator ==(VideoFormat a, VideoFormat b) Parameters Type Name Description VideoFormat a VideoFormat b Returns Type Description Boolean Inequality(VideoFormat, VideoFormat) Overload != operator to do VideoFormat comparison Declaration public static bool operator !=(VideoFormat a, VideoFormat b) Parameters Type Name Description VideoFormat a VideoFormat b Returns Type Description Boolean Implements System.IEquatable" + "common/Microsoft.Graph.Communications.Common.Transport.IGraphExchange.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphExchange.html", + "title": "Interface IGraphExchange", + "keywords": "Interface IGraphExchange The base of the exchange of a IGraphRequest or IGraphResponse . Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphExchange Properties Properties Gets the properties of the exchange. Declaration ICollection Properties { get; } Property Value Type Description ICollection < IGraphProperty > Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "articles/Testing.html": { - "href": "articles/Testing.html", - "title": "Testing of Bots", - "keywords": "Testing of Bots This document describes how to setup the Graph Communications Calling SDK to run on your localhost, run tests against it against the Graph Platform. Caution Do not use this testing setup for production traffic. Please limit it to debugging your bot locally with test traffic because of security concerns. Prerequisites The testing setup requires ngrok to create tunnels to localhost. Go to ngrok and sign up for a free account. Once you signed up, go to the dashboard and get your authtoken. Create an ngrok configuration file ngrok.yml with the following data authtoken: Tip Free ngrok account does not provide static tunnels. Tunnels change everytime a tunnel is created. So, if using free account, it is recommended to not close ngrok until it's use is completed. Tip Ngrok does not require sign up if you do not use TCP tunnels. Setting up Signaling In order for the platform to talk to your bot, the bot needs to be reached over the internet. So, an ngrok tunnel is created in http mode with an address pointing to a port on your localhost. Add the following lines to your ngrok config tunnels: signaling: addr: proto: http Setting up Application Hosted Media Note This section is only required for Application Hosted Media bots and can be skipped if you do not host media yourself. Application Hosted Media uses certificates and TCP tunnels to properly work. The following steps are required in order for proper media establishment. Ngrok's public TCP endpoints have fixed urls. They are 0.tcp.ngrok.io , 1.tcp.ngrok.io , etc. You should have a dns CNAME entry for your service that points to these urls. In this example, let's say 0.bot.contoso.com is pointing to 0.tcp.ngrok.io , and similarly for other urls. Now you require an SSL certificate for the url you own. To make it easy, use an SSL certificate issued to a wild card domain. In this case, it would be *.bot.contoso.com . This ssl certificate is validated by Media flow so should match your media flow's public url. Note down the thumbprint and install the certificate in your machine certificates. Now, we setup a TCP tunnel to forward the traffic to localhost. Write the following lines into your ngrok config. media: addr: proto: tcp Important Because ngrok's tcp urls can be same for multiple users (just differing in ports), it is possible for a third party to look like your service. This is a security issue. Therefore this document should be followed only for testing and also using a separate domain that is not linked to your production services. Start Ngok Now that ngrok configuration is ready, start it up. Download the ngrok executable and run the following command ngrok.exe start -all -config This would start ngrok and provide you the public urls which provide the tunnels to your localhost. The output looks like the following Forwarding http://signal.ngrok.io -> localhost:12345 Forwarding https://signal.ngrok.io -> localhost:12345 Forwarding tcp://1.tcp.ngrok.io:12332 -> localhost:8445 Here, 12345 is my signaling port, 8445 is the local media port and 12332 is the remote media port exposed by ngrok. Note that we have a forwarding from 1.bot.contoso.com to 1.tcp.ngrok.io . This will be used as the media url for bot. Update Code Once ngrok is up and running, we update the code to use the config we just setup. Update Signaling In the builder, change the NotficationUrl to the signaling url provided by ngrok. clientBuilder.SetNotificationUrl( new Uri(\"https://signal.ngrok.io/notificationEndpoint\")) Important Replace signal with the one provided by ngrok and the NotificationEndpoint with the controller path that receives notification. Important The url in SetNotificationUrl must be HTTPS. Important Your local instance must be listening to http traffic on the signaling port. The requests made by Graph Platform will reach the bot as localhost http traffic when End to End encryption is not setup. Update Media Update your MediaPlatformSettings to the following. var mediaPlatform = new MediaPlatformSettings { ApplicationId = MediaPlatformInstanceSettings = new MediaPlatformInstanceSettings { CertificateThumbprint = , InstanceInternalPort = , InstancePublicPort = , InstancePublicIPAddress = new IPAddress(0x0), ServiceFqdn = , }, } Caution The Certificate Thumbprint provided above should match the Service FQDN. That is why the DNS entries are required. Caveats The free accounts of ngrok do NOT provide End to End encryption. The HTTPS data ends at the ngrok url and the data flows unencrypted from ngrok to localhost. You require paid ngrok account and configuration update to use End to End encryption. See ngrok docs for steps on setting up secure E2E tunnels. Because the bot callback url is dynamic, incoming call scenarios won't work as they are part of bot registration and they are static. One way to fix this is to use a paid ngrok account which provides fixed subdomains to which you can point your bot and the platform." + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.html", + "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry.Obfuscation", + "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Classes GraphObfuscationAttribute Attribute used for decoration of data objects. This is used for obfuscation for logging. GraphObfuscationContractResolver Newtonsoft JSON resolver that uses Graph Obfuscation attribute to serialize data for logging purposes. HashingObfuscationConfiguration The hashing obfuscation configuration. This configurations is preconfigured to use the HashingObfuscationEngine and provides logic to automatically generate a salt which resets daily. HashingObfuscationEngine Obfuscation engine that hashes PII using salt. ObfuscatedValueProvider Newtonsoft JSONs value provider for obfuscated data. ObfuscationConfiguration Configuration for obfuscation of different parts. ObfuscationSerializer The obfuscation serializer can be used to serialize and de-serialize an obfuscation schema, as well as generate a schema from specified assemblies. Structs ObfuscationMember The obfuscation member. This struct is used to generate an obfuscation schema for any class type or it's members. It can be passed into the GraphObfuscationContractResolver which will cache the schema when resolving object and member obfuscation. Interfaces IObfuscationEngine Obfuscation engine that can obfuscate data. Enums ObfuscationTag Tag used to provide a hint for the type of obfuscation to perform." }, - "articles/calls/IVR.html": { - "href": "articles/calls/IVR.html", - "title": "Interactive Voice Response (IVR)", - "keywords": "Interactive Voice Response (IVR) Graph Communications Calling SDK and Core SDK can be used to make and manage IVR calls. Features Join exiting calls Answer incoming calls Subscribe to tones Transfer call Play media Record Cancel media operations Calling SDK Snippets Join Existing Call and Answer Incoming Call Please refer to the concept articles Redirect and Transfer In order to do a redirect or transfer, you need to create an invitation object. This invitation target is the transferee in blind transfer and the original caller in consultative transfer. var target = new InvitationParticipantInfo { Identity = new IdentitySet { User = new Identity { Id = \"**The Target's AAD ID**\", DisplayName = \"**(optional) The Target's Display Name**\", } } }; ICall call = this.GetIncomingCall(); await call.RedirectAsync(new[] { target }).ConfigureAwait(false); Blind transfer To make a blind transfer, only the target needs to be specified. ICall oritinalCall = this.Client.Calls()[\"*call id to transfer*\"]; await oritinalCall.TransferAsync(target).ConfigureAwait(false); Consultative transfer ICall newCall = this.Client.Calls()[\"*call id of second call*\"]; await newCall.TransferAsync(target, \"*id of the original call*\").ConfigureAwait(false); Subscribe to tones ICall call = this.Client.Calls()[\"*id of the call*\"]; await call.SubscribeToToneAsync().ConfigureAwait(false); Any tones that are received are sent as part of a call update in ToneInfo property of the call resource. Play media prompts ICall call = this.Client.Calls()[\"*id of the call*\"]; await call.PlayPromptAsync(*A list of media prompts to play*).ConfigureAwait(false); Record ICall call = this.Client.Calls()[\"*id of the call*\"]; HttpClient httpClient = this.HttpClient; RecordOperationResult result = await call.RecordAsync(*record options*).ConfigureAwait(false); string location = result.RecordResourceLocation; string token = result.RecordResourceAccessToken; // Stream the content of the recording somewhere. using (var outputStream = new MemoryStream()) using (var request = new HttpRequestMessage(HttpMethod.Get, new Uri(location))) { // Set the authorization header. request.Headers.Authorization = new AuthenticationHeaderValue(\"Bearer\", token); using(var response = await httpClient.SendAsync(request).ConfigureAwait(false)) using(var content = await response.Content.ReadAsStreamAsync().ConfigureAwait(false)) { await content.CopyToAsync(outputStream); outputStream?.Seek(0, SeekOrigin.Begin); // Do something with stream. } } Cancel media processing This API will cancel all prompts that are queued to be played. ICall call = this.Client.Calls()[\"*id of the call*\"]; await call.CancelMediaProcessingAsync().ConfigureAwait(false);" + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationMember.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationMember.html", + "title": "Struct ObfuscationMember", + "keywords": "Struct ObfuscationMember The obfuscation member. This struct is used to generate an obfuscation schema for any class type or it's members. It can be passed into the GraphObfuscationContractResolver which will cache the schema when resolving object and member obfuscation. Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() ValueType.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public struct ObfuscationMember Properties Members Gets or sets the members belonging to this member. Declaration public ObfuscationMember[] Members { get; set; } Property Value Type Description ObfuscationMember [] Name Gets or sets the name of the member. For classes this should be type full name, for members this should be the member name. Declaration public string Name { get; set; } Property Value Type Description String Tag Gets or sets the obfuscation tag. Specifies how this member should be obfuscated. Declaration public ObfuscationTag? Tag { get; set; } Property Value Type Description Nullable < ObfuscationTag > Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "articles/calls/MultipleAppSupport.html": { - "href": "articles/calls/MultipleAppSupport.html", - "title": "Supporting Multiple Applications Within Single Code Base", - "keywords": "Supporting Multiple Applications Within Single Code Base Some developers may wish to support multiple applications from within the same application code. With very little effort, this can be done using multiple instances of ICommunicationsClient . There are some steps that should be taken to ensure that we make outbound requests with the right application, and we forward incoming notifications to the right application. This writeup will demonstrate how to alter the existing samples to add multiple application support. We have not created a sample of this scenario explicitly given that it is not a standard way to use the Graph SDK. Create multiple communications clients First, each application instance requires it's own ICommunicationsClient instance, given that it supports a single IRequestAuthenticationProvider Let's change the Bot ICommunicationsClient Client to an IDictionary Clients and create our clients. /// /// Prevents a default instance of the class from being created. /// private Bot() { this.AddClient( Service.Instance.Configuration.MicrosoftAppId, Service.Instance.Configuration.MicrosoftAppPassword); this.AddClient( Service.Instance.Configuration.MicrosoftApp2Id, Service.Instance.Configuration.MicrosoftApp2Password); } private void AddClient(string appId, string appSecret) { // Create a unique notification uri for first app instance // This appends the app id to the callback uri so we get // https://base.uri/callbacks/{appId} var notificationUri = new Uri( Service.Instance.Configuration.CallControlBaseUrl, appId); var builder = new CommunicationsClientBuilder(\"AudioVideoPlaybackBot\", appId); builder .SetAuthenticationProvider( new AuthenticationProvider( appId, appSecret, Service.Instance.Configuration.TokenAudienceResourceLink)) .SetNotificationUrl(notificationUri) .SetMediaPlatformSettings(Service.Instance.Configuration.MediaPlatformSettings) .SetServiceBaseUrl(Service.Instance.Configuration.PlaceCallEndpointUrl); var client = builder.Build(); this.Clients.Add(appId, client); client.Calls().OnIncoming += this.CallsOnIncoming; client.Calls().OnUpdated += this.CallsOnUpdated; } /// /// Gets the contained app clients /// public IDictionary Clients { get; } Let's also add a reference to the ICallCollection to the call handler for ease of access. This will allow us to reference the correct collection/client from any given call id. /// /// Initializes a new instance of the class. /// /// The call collection. /// The call. public CallHandler(ICallCollection callCollection, ICall call); /// /// Gets the call collection /// public ICallCollection CallCollection { get; } /// /// Gets the call /// public ICall Call { get; } Handle notifications Next we need to adjust the incoming call controller to forward the notifications to the right client. If there is no need to handle incoming call, then the above configuration will automatically route the the correct apps endpoint. If we need to handle incoming call, we can either have a default app process all those scenarios, or the callback URI of each app can contain the app id. For example, if our service URI is https://base.uri/callback , we can set all our bots to use this URI directly, but then we lose knowledge of which app is receiving the incoming call. If we change each app's callback URI to https://base.uri/callback/{appId} (example: https://base.uri/callback/9ecd52e5-6592-42b7-b562-093f37f13bde , where the appId is 9ecd52e5-6592-42b7-b562-093f37f13bde) then we have the app context when an incoming call occurs. Of course there are other ways to get the app ID, like from the auth token or the payload, but this is one simple option. To handle the app id in the URI the controllers for callbacks need to be changed to the following: /// /// Gets a reference to singleton sample bot/client instance /// private IDictionary Clients => Bot.Instance.Clients; /// /// Handle a callback for an incoming call. /// Here we don't know what application is receiving the callback. /// /// /// The . /// [HttpPost] [Route(\"\")] public Task OnIncomingRequestAsync() { // Pick some app id to handle this call. var appId = this.Clients.Keys.First(); return this.OnIncomingRequestAsync(appId); } /// /// Handle a callback for an incoming call or notification. /// Here we've added the application id to the callback URI. /// /// /// The . /// [HttpPost] [Route(\"{appId}\")] public async Task OnIncomingRequestAsync(string appId) { Log.Info(new CallerInfo(), LogContext.FrontEnd, $\"Received HTTP {this.Request.Method}, {this.Request.RequestUri}\"); // Pass the incoming message to the sdk. The sdk takes care of what to do with it. var client = this.Clients[appId]; var response = await client.ProcessNotificationAsync(this.Request).ConfigureAwait(false); // Enforce the connection close to ensure that requests are evenly load balanced so // calls do no stick to one instance of the worker role. response.Headers.ConnectionClose = true; return response; } Additional notes There are a few items not addressed here. For instance, when a VTC joins a meeting, which app should it use? This has been purposefuly excluded from this guide given that it is unique business logic. Some may want a different bot configuration for each client, others may associate unique permissions to each bot and use depending on action being performed." + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.BaseFilter.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.BaseFilter.html", + "title": "Class BaseFilter", + "keywords": "Class BaseFilter Non generic base filter. Inheritance Object BaseFilter BaseFilter Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public abstract class BaseFilter Constructors BaseFilter() Declaration protected BaseFilter() Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "calls/index.html": { - "href": "calls/index.html", - "title": "Graph Communications Calling SDK", - "keywords": "Graph Communications Calling SDK The Calling components can be found in the Microsoft.Graph.Communications.Calls namespace. State Management The Graph Communications Calling SDK exposes a different set of APIs to manage states of resources in memory. Bots built using this SDK need to register event handlers for each newly created resource in order to be informed of any changes happening on that resource. The strengths and limitations of each are further explained in the State Management article. Media Session For calls with locally hosted media the ICallCollection has an extended AddAsync method which expects an IMediaSession object. This object contains the IAudioSocket and IVideoSocket composition. The IMediaSession also knows how to construct the MediaConfiguration required by the back end services to enable the AV stream to flow through the call instance. A Media Extension SDK has been added on top of this SDK to support locally hosted media scenarios. To use this extension the ICommunicationsClient must be built with MediaCommunicationsClientBuilderExtensions.SetMediaPlatformSettings . The MediaCommunicationsClientExtensions.CreateMediaSession extension method facilitates the creation of IMediaSession objects. Please see the calls with locally hosted media article for more information on the IMediaSession object. Select a class on the left to dive into the reference docs Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." + "client/Microsoft.Graph.Communications.Client.Notifications.html": { + "href": "client/Microsoft.Graph.Communications.Client.Notifications.html", + "title": "Namespace Microsoft.Graph.Communications.Client.Notifications", + "keywords": "Namespace Microsoft.Graph.Communications.Client.Notifications Classes FixedSizeQueue A class that implements a fixed size list." }, - "calls_media/index.html": { - "href": "calls_media/index.html", - "title": "Graph Communications Media SDK", - "keywords": "Graph Communications Media SDK The Media components can be found in the Microsoft.Graph.Communications.Calls.Media namespace. More information of utilizing Real-time Media Calling functionality in bots can be found here This is presented as an extension on top of the Graph Communications Calling SDK to provide extra functionalities with Microsoft.Skype.Bots.Media library. IMediaSession The Media SDK provides very light integration with the Microsoft.Skype.Bots.Media library. There are only a few pieces of data that the signaling SDK requires to integrate with the media libraries. As a convenience the Media SDK provides an IMediaSession generator . For greater customization of media libraries developers are welcome to exclude this package and implement their own IMediaSession . Media Requirements The Communications SDK is quite flexible, however, the media library has it's own set of Requirements . Local Testing Local testing of Application Hosted Media scenarios is possible in some environments. Please refer to the testing guide to enable local testing. Select a class on the left to dive into the reference docs Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." + "common/Microsoft.Graph.Communications.Common.Transport.ResponseStatus.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.ResponseStatus.html", + "title": "Enum ResponseStatus", + "keywords": "Enum ResponseStatus Different status of IGraphResponse . Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum ResponseStatus Fields Name Description Accepted The request was successfully accepted. BadRequest The request was semantically/syntactically invalid. Conflict There was a conflict in processing the request. Created The request resource was successfully created. Forbidden The request was forbidden. InternalServerError The request resulted in an internal server error. MultiStatus The multi status response. NoContent There was no content in the response. NotFound The requested resource was not found. NotImplemented The not implemented Ok The request was successfully processed. RequestTimeout Client did not send a request within the time the server was expecting the request. ServiceUnavailable The server is temporarily unavailable. TooManyRequests Too many requests were tried. Unauthorized The request was not authorized by the callee. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(ResponseStatus, String, String) Validator.Equals(ResponseStatus, String) Validator.NotEquals(ResponseStatus, String, String) GraphResponseExtensions.ToHttpStatus()" }, - "common/index.html": { - "href": "common/index.html", - "title": "Graph Common Utilities Documentation", - "keywords": "Graph Common Utilities Documentation This is the documentation for Microsoft.Graph.Communications.Common nuget package. This is the nuget containing all the utilities used throughout the Communications SDK. It contains telemetry, http, obfuscation support along with helper methods. For more information on logging please see the graph logger guide Select a class on the left to dive into the reference docs" + "common/Microsoft.Graph.Communications.Common.Transport.NoContentMessage.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.NoContentMessage.html", + "title": "Class NoContentMessage", + "keywords": "Class NoContentMessage IGraphClient requires type parameters for functionality. This is a marked Type/class to make function calls to IGraphClient indicating we have request/response with no body. The sole purpose of this class's existence is to reduce code duplicacy. Inheritance Object NoContentMessage Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class NoContentMessage Constructors NoContentMessage() Declaration public NoContentMessage() Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "articles/calls/calling-notifications.html": { - "href": "articles/calls/calling-notifications.html", - "title": "Notifications in Calling", - "keywords": "Notifications in Calling Refer to Registering a Calling Bot on how to register the callback URL. This callback is used for all incoming calls to the application. Protocol determination The incoming notification is provided in legacy format for compatibility with the previous protocol . In order to convert the call to the Microsoft Graph protocol, the bot must determine the notification is in legacy format and reply with: HTTP/1.1 204 No Content The application will again receive the notification but this time it will be in the Microsoft Graph protocol. You may configure the protocol your application supports and avoid receiving the initial callback in legacy format. The setting is available as a configuration option in the Skype Channel. Redirects for region affinity We will invoke your callback from the data-center hosting the call. The call may start in any data-center and does not take into account region affinities. The notification will be sent to your deployment depending on the GeoDNS resolution. If your application determines, by inspecting the initial notification payload or otherwise, that it needs to run in a different deployment, the application may reply with: HTTP/1.1 302 Found Location: your-new-location You may decide to pickup the call and answer . You can specify the callback URL to handle this particular call. This is useful for stateful instances where your call is handled by a particular partition and you want to embed this information on the callback URL for routing to the right instance. Authenticating the callback Application should inspect the token passed by on the notification to validate the request. Whenever the API raises a web hook event, the API gets an OAUTH token from us, with audience as the application's App ID and adds it in the Authorization header as a Bearer token. The application is expected to validate this token before accepting the callback request. POST https://bot.contoso.com/api/calls Content-Type: application/json Authentication: Bearer \"value\": [ \"subscriptionId\": \"2887CEE8344B47C291F1AF628599A93C\", \"subscriptionExpirationDateTime\": \"2016-11-20T18:23:45.9356913Z\", \"changeType\": \"updated\", \"resource\": \"/app/calls/8A934F51F25B4EE19613D4049491857B\", \"resourceData\": { \"@odata.type\": \"#microsoft.graph.call\", \"state\": \"Established\" } ] The OAUTH token would have values like the following, and will be signed by us. The openid configuration published at https://api.aps.skype.com/v1/.well-known/OpenIdConfiguration can be used to verify the token. { \"aud\": \"0efc74f7-41c3-47a4-8775-7259bfef4241\", \"iss\": \"https://api.botframework.com\", \"iat\": 1466741440, \"nbf\": 1466741440, \"exp\": 1466745340, \"tid\": \"1fdd12d0-4620-44ed-baec-459b611f84b2\" } aud audience is the App ID URI specified for the application. tid is the tenant id for contoso iss is the token issuer, https://api.botframework.com The listener interface on the web hook URL can validate the token, ensure it has not expired, checking whether it has been signed by our published openid configuration. You must also check whether audience matches your App ID before accepting the callback request. Sample shows how to validate inbound requests. Additional information You can read more about AAD tokens and Validation" + "common/Microsoft.Graph.Communications.Common.Telemetry.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.html", + "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry", + "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry Classes AadApplicationIdentity The application identity in Azure AD. CallerInfo Class that encapsulates the caller's (creator's) information ClientEtwLogger Logger for client that publishes to ETW. GraphLogger Logging portion of graph. GraphLoggerShim The graph logger shim. This wrapper on the IGraphLogger attaches some extra data to each log request. GraphLoggerWrapper The ILogger wrapper for IGraphLogger. JsonConverters Json converters. JsonConverters.TypedPropertiesConverter The json converter for Type. LogEvent Log data LogEventFormatter The log event formatter LoggingConstants Constants used for logging that are common between server and client. LoggingExtensions Extensions class for logging. MetricLogData The metric of Geneva Instrumentation Framework (Ifx). Interfaces IGraphLogger The logger interface used by Graph Services. This logger emits logs that can be observed by different observers. ILogEventFormatter Interface to format log event. Enums ClientLogEventId Event ids for client logs HttpTraceType Trace used for HTTP traces. LogEventFormatterFlags The log event formatter enums LogEventType Log event type that describes what type of LogEvent this is. TransactionDirection Direction for request message." }, - "articles/calls/register-calling-bot.html": { - "href": "articles/calls/register-calling-bot.html", - "title": "Registering a calling bot", - "keywords": "Registering a calling bot In this topic you will learn how to register a new Calling Bot. Register your bot in the Azure Bot Service Complete the following steps: Register a bot by creating a Bot Channels Registration through Azure Bot Channel Registration . Once you complete the registration, take a note of the registered config values (Bot Name, Application Id, and Application Secret). You will need these values later in the code samples. In the resource blade, click Channels . Enable the Microsoft Teams channel and enable calling on the Calling tab. Fill in the Webhook (for calling) where you will receive incoming notifications. E.g. https://{your domain}/api/calls . Refer to Connect a bot to channels for more information on how to configure channels. Permissions Add Microsoft Graph permissions for calling to your bot Microsoft Graph exposes granular permissions controlling the access apps have to resources. As a developer, you decide which permissions for Microsoft Graph your app requests. The Microsoft Graph Communications Calling APIs support Application permissions, which are used by apps that run without a signed-in user present; for example, apps that run as background services or bots. Application permissions can only be consented by a tenant administrator. Calling bots and applications have some capabilties that will need tenant administrator consent. Below is a list of those permissions: Permission Display String Description Admin Consent Required Calls.Initiate.All Initiate outgoing 1:1 calls from the app (preview) Allows the app to place outbound calls to a single user and transfer calls to users in your organization's directory, without a signed-in user. Yes Calls.InitiateGroupCall.All Initiate outgoing group calls from the app (preview) Allows the app to place outbound calls to multiple users and add participants to meetings in your organization, without a signed-in user. Yes Calls.JoinGroupCall.All Join Group Calls and Meetings as an app (preview) Allows the app to join group calls and scheduled meetings in your organization, without a signed-in user. The app will be joined with the privileges of a directory user to meetings in your tenant. Yes Calls.JoinGroupCallasGuest.All Join Group Calls and Meetings as a guest (preview) Allows the app to anonymously join group calls and scheduled meetings in your organization, without a signed-in user. The app will be joined as a guest to meetings in your tenant. Yes Calls.AccessMedia.All *see below* Access media streams in a call as an app (preview) Allows the app to get direct access to participant media streams in a call, without a signed-in user. Yes Important: You may not use the Microsoft.Graph.Calls.Media API to record or otherwise persist media content from calls or meetings that your bot accesses. Assigning permissions You pre-configure the application permissions your app needs when you register your app. To add permissions from the Azure Bot Registration Portal: From the Settings blade, click Manage . This is the link appearing by the Microsoft App ID . This link will open a window where you can click on API permissions and then click Add a permission in the right pane. Select Microsoft Graph , choose Application Permissions and then select the permissions your app requires in the Select Permissions dialog. Getting administrator consent An administrator can either consent to these permissions using the Azure portal when your app is installed in their organization, or you can provide a sign-up experience in your app through which administrators can consent to the permissions you configured. Once administrator consent is recorded by Azure AD, your app can request tokens without having to request consent again. You can rely on an administrator to grant the permissions your app needs at the Azure portal , but often a better option is to provide a sign-up experience for administrators by using the Azure AD v2.0 /adminconsent endpoint. Please refer to the instructions on constructing an Admin Consent URL for more detail. Note : Constructing the Tenant Admin Consent URL requires a configured Redirect URI/Reply URL in the App Registration Portal . To add reply URLs for your bot, access your bot registration, choose Advanced Options > Edit Application Manifest. Add your Redirect URI to the field replyURLs. Important : Any time you make a change to the configured permissions, you must also repeat the Admin Consent process. Changes made in the app registration portal will not be reflected until consent has been reapplied by the tenant's administrator. Register bot in Microsoft Teams The code samples can be used in combination with a Microsoft Teams App Manifest settings to add the Calling and Video buttons for a 1:1 bot interaction. To develop calling bot, add 'supportsCalling' and 'supportsVideo' boolean properties to the bots section in the app manifest and the bot is all set to receive calls once installed (either to a personal context or a team). App Manifests can be uploaded through the App Studio in the Microsoft Teams client. In the Teams client, select Apps from the left pane and then select App Studio . From the top pane, click Manifest editor and then Create a new app from the left pane. In the App details tab, provide the basic information. Navigate to the Capabilities section, and select the Bots tab. Then select Set Up in the right pane. Fill in the desired bot name Select the Select from one of my existing bots option, and find your bot from above in the dropdown. Check all options under Calling Bot and Scope Press Save" + "common/Microsoft.Graph.Communications.Common.ObjectRoot.html": { + "href": "common/Microsoft.Graph.Communications.Common.ObjectRoot.html", + "title": "Class ObjectRoot", + "keywords": "Class ObjectRoot Base object. Inheritance Object ObjectRoot Observable GraphLoggerShim GraphHttpClient GraphHttpClientFactory Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public abstract class ObjectRoot Constructors ObjectRoot(IGraphLogger) Initializes a new instance of the ObjectRoot class. Declaration protected ObjectRoot(IGraphLogger logger) Parameters Type Name Description IGraphLogger logger Logger instance. Properties GraphLogger Gets the logger. Declaration protected IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "articles/calls/serviceHostedMediaCalls.html": { - "href": "articles/calls/serviceHostedMediaCalls.html", - "title": "Service Hosted Media Calls", - "keywords": "Service Hosted Media Calls Service Hosted Media calls are those calls in which the bot offloads the media to the Microsoft infrastructure. This makes the bot much more lightweight, but it cannot access the raw audio/video streams. Creating a Service Hosted Media Call When creating an object of the Call resource, MediaConfig needs to be set to ServiceHostedMediaConfig ." + "client/Microsoft.Graph.Communications.Resources.html": { + "href": "client/Microsoft.Graph.Communications.Resources.html", + "title": "Namespace Microsoft.Graph.Communications.Resources", + "keywords": "Namespace Microsoft.Graph.Communications.Resources Classes CollectionEventArgs The collection event arguments. ResourceEventArgs The resource event arguments. Interfaces IResource The stateful resource interface. IResource The stateful resource interface. IResourceBase The resource base interface. IResourceCollection The resource collection interface. IResourceCollection The resource collection interface. IResourceCollection The resource collection interface. Delegates CollectionEventHandler The call collection event handler delegate. ResourceEventHandler The resource event handler delegate." }, - "articles/calls/StateManagement.html": { - "href": "articles/calls/StateManagement.html", - "title": "State Management", - "keywords": "State Management All states of resources associated with a Call in the Graph Communications Calling SDK are handled internally. The notifications and events for a particular ICall or a particular resource contained in ICall are always received on a single application instance. This means that the instance should be maintaining the state of a call in memory and a single ICall object exists throughout the duration of the call. These are called Stateful calls and the bots are called Stateful bots. The notification or events for any call can hit any instance of the application. This means that everytime a notification comes to an instance, a new Call object is created by the Graph Communications Calling Core SDK and is destroyed once the notification/event has been handled. Any state required for the call should be maintained by the bot logic. These type of bots are called Stateless bots signifying that the Graph Communications Calling Core SDK itself does not maintain any state for the bot. Differences Between Stateless and Stateful Bots The major difference between Stateless and Stateful bots is that maintaining Stateful bots requires that the bot instance would not go down when a call is in progress. If the instance goes down, the call object is lost and no notifications or events are received by the Graph Communications Calling SDK and the calls gets dropped by the server. On the contrast, in Stateless bots, even if the bot instance goes down, the events and notifications go to the other instances of the bot and the bot can continue its logic. Important In Application Hosted Media Calls , the media is handled by a single instance of the bot. Therefore, all the notifications should reach the same instance of the bot for signaling of the media to be properly handled. Thus stateless scenarios for Application Hosted Media bots are not supported." + "client/Microsoft.Graph.Communications.Client.html": { + "href": "client/Microsoft.Graph.Communications.Client.html", + "title": "Namespace Microsoft.Graph.Communications.Client", + "keywords": "Namespace Microsoft.Graph.Communications.Client Classes CommunicationsClientBuilder The class the provides the builder for stateful client. CommunicationsClientExtensions Extensions for Stateful Client. GraphLoggerExtensions The graph logger extensions for the communications client. PagedList An object that contains paginated list of the generic type T. StateManager The state manager implementation. Interfaces ICommunicationsClient The CommunicationsClient interface. This is the entry point of the SDK and a reference to this instance must be held for the duration of the session. ICommunicationsClientBuilder The builder object that builds the ICommunicationsClient . Use this class to setup the SDK's configuration. IPagedList The paged list interface. IStateManager The state manager interface. This object is responsible for storing the resources in memory." }, - "bot_media/index.html": { - "href": "bot_media/index.html", - "title": "Graph Communications Bot Media SDK", - "keywords": "Graph Communications Bot Media SDK The Real-time Media Platform enables bots to interact with Microsoft Teams calls and meetings using real-time voice, video and screen sharing. This is an advanced capability which allows the bot to send and receive voice and video content frame by frame. The bot has \"raw\" access to the voice, video and screen sharing media streams. (Bots which process media themselves are called application-hosted media bots, as opposed to simpler service-hosted media bots that rely on the Real-time Media platform for all media processing.) For example, in a 1:1 call with a bot, as the user speaks, the bot will receive 50 audio frames per second, with each frame containing 20 milliseconds (ms) of audio. An application-hosted media bot can perform real-time speech recognition as the audio frames are received, rather than having to wait for a recording after the user has stopped speaking. The bot can also send and receive high-definition-resolution video, including video-based screen sharing content. The platform provides a simple \"socket\"-like API for the bot to send and receive media, and handles the real-time encoding and decoding of audio/video packets, using codecs such as SILK and G.722 for audio and H.264 for video. The platform also handles all media packet encryption/decryption and packet network transmission automatically, so the bot just needs to concern itself with the actual audio/video content. A real-time media bot may participate in 1:1 calls as well as meetings with multiple participants. Microsoft Real-Time Media Platform for Bots API (\"Media Access API\") Accompanying Documentation The Media Access API is offered under the terms of the Microsoft APIs Terms of Use ( https://docs.microsoft.com/en-us/legal/microsoft-apis/terms-of-use ) and this accompanying documentation. \"Media Access API\" means (i) any form of machine accessible application programming interface that Microsoft makes publicly available which provides access to a Microsoft Offering that includes media content (e.g., audio or video), including all associated tools, elements, components and executables therein, (ii) any Microsoft sample code that enables interactions with a Microsoft Offering, and (iii) documentation that Microsoft makes available to help enable your access to the Media Access API. Additional Restriction : You may NOT use the Media Access API to record or otherwise persist media content from calls or meetings that your Application accesses, or data derived from that media content. Select a class on the left to dive into the reference docs" + "client/Microsoft.Graph.Communications.Client.ICommunicationsClientBuilder.html": { + "href": "client/Microsoft.Graph.Communications.Client.ICommunicationsClientBuilder.html", + "title": "Interface ICommunicationsClientBuilder", + "keywords": "Interface ICommunicationsClientBuilder The builder object that builds the ICommunicationsClient . Use this class to setup the SDK's configuration. Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface ICommunicationsClientBuilder Properties Id Gets the client id. Declaration Guid Id { get; } Property Value Type Description Guid Methods Build() Build and return the stateful client object. Declaration ICommunicationsClient Build() Returns Type Description ICommunicationsClient The ICommunicationsClient . Exceptions Type Condition ArgumentException Cannot build the client without setting the required parameters. SetAuthenticationProvider(IRequestAuthenticationProvider) Sets the custom authentication provider. The authentication provider would add authentication to outbound requests and validates any inbound requests. See IRequestAuthenticationProvider Declaration ICommunicationsClientBuilder SetAuthenticationProvider(IRequestAuthenticationProvider provider) Parameters Type Name Description IRequestAuthenticationProvider provider The authentication provider. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the provider is null . SetCacheStrategy(ICache) Sets the cache strategy. Declaration ICommunicationsClientBuilder SetCacheStrategy(ICache cacheStrategy) Parameters Type Name Description ICache cacheStrategy The cache strategy. Returns Type Description ICommunicationsClientBuilder This ICommunicationsClientBuilder object. Exceptions Type Condition ArgumentNullException If the cacheStrategy strategy is null . SetHttpClient(HttpClient, IEnumerable>) Sets the http client. Use a custom HTTP Client instead of the one generated by the SDK. Declaration ICommunicationsClientBuilder SetHttpClient(HttpClient httpClient, IEnumerable> defaultHeaders = null) Parameters Type Name Description HttpClient httpClient The place call endpoint URL. IEnumerable < KeyValuePair < String , String >> defaultHeaders The default headers. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the httpClient is null . SetNotificationUrl(Uri) Set the notification uri for your bot. This is the default notification url for the bot. This can be overriden on a per-resource basis depending on the API support. Declaration ICommunicationsClientBuilder SetNotificationUrl(Uri notificationUrl) Parameters Type Name Description Uri notificationUrl The callback Url. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the notificationUrl is null . ArgumentException URI must be https. SetServiceBaseUrl(Uri) Sets the service base URL. This set's the Endpoint URL for the service. Declaration ICommunicationsClientBuilder SetServiceBaseUrl(Uri serviceBaseUrl) Parameters Type Name Description Uri serviceBaseUrl The place call endpoint URL. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the serviceBaseUrl is null . ArgumentException URI must be https." }, - "README.Internal.html": { - "href": "README.Internal.html", - "title": "How to generate docs", - "keywords": "How to generate docs Download and unzip docfx.zip from https://github.com/dotnet/docfx/releases , extract it to a local folder, and add it to PATH so you can run it anywhere. Install Visual STUDIO 2017 Developer tools v15.0 and later After installation, open a X64 Native Tools Command Prompt for VS 2017. Run docfx in the docs folder, this will generate a _site folder Pack the _site folder with the project level README.md that explains how to go through the docs. How to serve the docs Download and unzip docfx.zip from https://github.com/dotnet/docfx/releases , extract it to a local folder, and add it to PATH so you can run it anywhere. Open a console window and cd to the directory which contains the _site folder Serve the docs site using docfx serve .\\_site command Goto http://localhost:8080 in your browser to view the documentation." + "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCommunicationsClientExtensions.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCommunicationsClientExtensions.html", + "title": "Class MediaCommunicationsClientExtensions", + "keywords": "Class MediaCommunicationsClientExtensions The stateful client extension. Inheritance Object MediaCommunicationsClientExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public static class MediaCommunicationsClientExtensions Methods CreateMediaSession(ICommunicationsClient, AudioSocketSettings, VideoSocketSettings, VideoSocketSettings, DataSocketSettings, Guid) Creates a local media session for the provided communications client with a given socket configuration. Declaration public static ILocalMediaSession CreateMediaSession(this ICommunicationsClient statefulClient, AudioSocketSettings audioSocketSettings, VideoSocketSettings videoSocketSettings, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null, Guid mediaSessionId = default(Guid)) Parameters Type Name Description ICommunicationsClient statefulClient The stateful client. AudioSocketSettings audioSocketSettings The audio socket settings. VideoSocketSettings videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Guid mediaSessionId The id for the media session. Returns Type Description ILocalMediaSession A ILocalMediaSession . Exceptions Type Condition ArgumentNullException If the communications client has not been specified. ArgumentException If the client does not have a valid identifier. CreateMediaSession(ICommunicationsClient, AudioSocketSettings, IEnumerable, VideoSocketSettings, DataSocketSettings, Guid) Creates a local media session for the provided communications client with a given socket configuration. Declaration public static ILocalMediaSession CreateMediaSession(this ICommunicationsClient client, AudioSocketSettings audioSocketSettings, IEnumerable videoSocketSettings = null, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null, Guid mediaSessionId = default(Guid)) Parameters Type Name Description ICommunicationsClient client The communications client. AudioSocketSettings audioSocketSettings The audio socket settings. IEnumerable < VideoSocketSettings > videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Guid mediaSessionId The id for the media session. Returns Type Description ILocalMediaSession A ILocalMediaSession . Exceptions Type Condition ArgumentNullException If the communications client has not been specified. ArgumentException If the client does not have a valid identifier." }, - "README.html": { - "href": "README.html", - "title": "Get started", - "keywords": "Get started Review the documentation to understand the concepts behind using our SDK (which is also used by the samples). Get started quickly with our samples ." + "calls/Microsoft.Graph.Communications.Calls.IParticipant.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.IParticipant.html", + "title": "Interface IParticipant", + "keywords": "Interface IParticipant The stateful participant interface. This represents a single participant in a call. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface IParticipant : IResource, IResource, IResourceBase, IDisposable Properties Resource Gets the stateful participant resource. Declaration Participant Resource { get; } Property Value Type Description Participant Methods DeleteAsync(Boolean, CancellationToken) Deletes this participant asynchronously. Declaration Task DeleteAsync(bool handleHttpNotFoundInternally = false, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description Boolean handleHttpNotFoundInternally If the IParticipant is already gone, whether to handle the exception gracefully or not. CancellationToken cancellationToken The CancellationToken for the request. Returns Type Description Task The Task that completes after the request has been sent. The completion of this task does not guarantee deletion. Confirmation of deletion comes as a notification and can be subscribed by IParticipant.OnUpdated and IParticipantCollection.OnUpdated MuteAsync(CancellationToken) Performs the mute operation asynchronously. Declaration Task MuteAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The mute notification will come in on IParticipant.OnUpdated See Also IResource" }, - "core/index.html": { - "href": "core/index.html", - "title": "Graph Communications Core SDK", - "keywords": "Graph Communications Core SDK This library contains the common contracts and helpers not present in Microsoft.Graph SDK . The Core components can be found in the Microsoft.Graph namespace. Select a class on the left to dive into the reference docs Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." + "common/Microsoft.Graph.Communications.Common.Transport.GraphRequestExtensions.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphRequestExtensions.html", + "title": "Class GraphRequestExtensions", + "keywords": "Class GraphRequestExtensions Extensions for IGraphRequest class. Inheritance Object GraphRequestExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class GraphRequestExtensions Methods ToHttpMethod(RequestType) Convert RequestType to the corresponding HTTP method. Declaration public static HttpMethod ToHttpMethod(this RequestType requestType) Parameters Type Name Description RequestType requestType Type of the request. Returns Type Description HttpMethod HttpMethod for the RequestType ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable) Converts IGraphRequest into a HttpRequestMessage . Declaration public static HttpRequestMessage ToHttpRequestMessage(this IGraphRequest graphRequest, JsonSerializerSettings jsonSerializerSettings = null, IEnumerable defaultProperties = null) Parameters Type Name Description IGraphRequest graphRequest The graph request to be converted. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. IEnumerable < IGraphProperty > defaultProperties The default properties. Returns Type Description HttpRequestMessage HttpRequestMessage corresponding to graphRequest . Type Parameters Name Description T Type of content available in the request." }, - "common/Microsoft.Graph.Communications.Common.HttpConstants.HeaderNames.html": { - "href": "common/Microsoft.Graph.Communications.Common.HttpConstants.HeaderNames.html", - "title": "Class HttpConstants.HeaderNames", - "keywords": "Class HttpConstants.HeaderNames The header names. Inheritance Object HttpConstants.HeaderNames Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HeaderNames Fields Accept The accept header. Declaration public const string Accept = \"Accept\" Field Value Type Description String AccessControlAllowCredentials Access-Control-Allow-Credentials Declaration public const string AccessControlAllowCredentials = \"Access-Control-Allow-Credentials\" Field Value Type Description String AccessControlAllowHeaders Access-Control-Allow-Headers Declaration public const string AccessControlAllowHeaders = \"Access-Control-Allow-Headers\" Field Value Type Description String AccessControlAllowOrigin Access-Control-Allow-Origin Declaration public const string AccessControlAllowOrigin = \"Access-Control-Allow-Origin\" Field Value Type Description String AccessControlMaxAge Access-Control-Max-Age Declaration public const string AccessControlMaxAge = \"Access-Control-Max-Age\" Field Value Type Description String AccessControlRequestHeaders Access-Control-Request-Headers Declaration public const string AccessControlRequestHeaders = \"Access-Control-Request-Headers\" Field Value Type Description String AccessControlRequestMethod Access-Control-Request-Method Declaration public const string AccessControlRequestMethod = \"Access-Control-Request-Method\" Field Value Type Description String Authorization The authorization header. Declaration public const string Authorization = \"Authorization\" Field Value Type Description String CacheControl The cache control header. Declaration public const string CacheControl = \"Cache-Control\" Field Value Type Description String CalleeRegion The callee region header. Declaration public const string CalleeRegion = \"X-Microsoft-Skype-Callee-Region\" Field Value Type Description String CallerRegion The caller region header. Declaration public const string CallerRegion = \"X-Microsoft-Skype-Caller-Region\" Field Value Type Description String ChainId The chain identifier header. This header is used to correlate requests to each other within the NGC stack. Declaration public const string ChainId = \"X-Microsoft-Skype-Chain-ID\" Field Value Type Description String ClientRequestId The client request identifier header. This header is used to track individual requests between the client and SF services. Declaration public const string ClientRequestId = \"Client-Request-Id\" Field Value Type Description String Connection The connection header. Declaration public const string Connection = \"Connection\" Field Value Type Description String ContentLength The content length header. Declaration public const string ContentLength = \"Content-Length\" Field Value Type Description String ContentType The content type header. Declaration public const string ContentType = \"Content-Type\" Field Value Type Description String ContextId The context identifier header. Declaration public const string ContextId = \"ContextId\" Field Value Type Description String Date The date header. Declaration public const string Date = \"Date\" Field Value Type Description String Duration The duration header. Declaration public const string Duration = \"Duration\" Field Value Type Description String GatewayServiceRootHeader the header that graph adds to the proxied request to PMA Declaration public const string GatewayServiceRootHeader = \"x-ms-gateway-serviceRoot\" Field Value Type Description String Host The host header. Declaration public const string Host = \"Host\" Field Value Type Description String Location The location header. Declaration public const string Location = \"Location\" Field Value Type Description String MessageId The message identifier header. This header is used to track individual requests within the NGC stack. Declaration public const string MessageId = \"X-Microsoft-Skype-Message-ID\" Field Value Type Description String MsAttribution X-MS-Attribution. Declaration public const string MsAttribution = \"X-MS-Attribution\" Field Value Type Description String MsDiagnostics The microsoft graph diagnostics header. Declaration public const string MsDiagnostics = \"x-ms-ags-diagnostic\" Field Value Type Description String MsParticipants X-MS-Participants. Declaration public const string MsParticipants = \"X-MS-Participants\" Field Value Type Description String ODataVersion The odata version header. Declaration public const string ODataVersion = \"OData-Version\" Field Value Type Description String Origin Origin Declaration public const string Origin = \"Origin\" Field Value Type Description String OriginalMessageId The original message identifier header. Declaration public const string OriginalMessageId = \"X-Microsoft-Skype-Original-Message-ID\" Field Value Type Description String PmaInstanceUrl The pma instance URL. Used to retarget PSA to a particular PMA instance. Declaration public const string PmaInstanceUrl = \"X-Microsoft-Pma-Instance\" Field Value Type Description String RedirectDu The redirect du header. Declaration public const string RedirectDu = \"X-Plat-Redirect-Du\" Field Value Type Description String RedirectRegion The redirect region header. Declaration public const string RedirectRegion = \"X-Plat-Redirect-Region\" Field Value Type Description String RequestId The request identifier header. This header is returned by graph to identify the specific request. Declaration public const string RequestId = \"Request-Id\" Field Value Type Description String RoutingTargetRegion The Routing-Target-Region header. Declaration public const string RoutingTargetRegion = \"Routing-Target-Region\" Field Value Type Description String ScenarioId The scenario identifier header. This header is used to correlate requests to each other between client and SF services. Declaration public const string ScenarioId = \"Scenario-Id\" Field Value Type Description String SchedulingServiceTelemetryId Scheduling service telemetry header. This header is used to correlate requests with SS service. Declaration public const string SchedulingServiceTelemetryId = \"X-MS-Skype-MLC-Telemetry-Id\" Field Value Type Description String Skypetoken X-Skypetoken Declaration public const string Skypetoken = \"X-Skypetoken\" Field Value Type Description String StrictTransportSecurity The strict transport security header. Declaration public const string StrictTransportSecurity = \"Strict-Transport-Security\" Field Value Type Description String Tenant The tenant header Declaration public const string Tenant = \"X-Microsoft-Tenant\" Field Value Type Description String TenantRegion The tenant region header. Declaration public const string TenantRegion = \"Tenant-Region\" Field Value Type Description String ThrowSite The throw site header. Declaration public const string ThrowSite = \"X-ThrowSite\" Field Value Type Description String TransferEncoding The transfer encoding header. Declaration public const string TransferEncoding = \"Transfer-Encoding\" Field Value Type Description String UserAgent The user agent header. Declaration public const string UserAgent = \"User-Agent\" Field Value Type Description String WebhooksResource Webhooks-WorkloadResource Declaration public const string WebhooksResource = \"Webhooks-WorkloadResource\" Field Value Type Description String XMsClientUserAgent Client User Agent header. This header has the user agent in requests. Used in requests to presence service at the moment. Declaration public const string XMsClientUserAgent = \"X-Ms-Client-User-Agent\" Field Value Type Description String XMsClientVersion The client version header. This header has the client version in requests. Used in requests to presence service at the moment. Declaration public const string XMsClientVersion = \"X-Ms-Client-Version\" Field Value Type Description String XMsCorrelationId the correlation id header. This header is used to correlate requests with presence service at the moment. Declaration public const string XMsCorrelationId = \"X-Ms-Correlation-Id\" Field Value Type Description String" + "client/Microsoft.Graph.Communications.Resources.CollectionEventArgs-1.html": { + "href": "client/Microsoft.Graph.Communications.Resources.CollectionEventArgs-1.html", + "title": "Class CollectionEventArgs", + "keywords": "Class CollectionEventArgs The collection event arguments. Inheritance Object CollectionEventArgs Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class CollectionEventArgs Type Parameters Name Description TEntity The containing stateful resource type. IResource Constructors CollectionEventArgs(String, ICollection, ICollection, ICollection) Initializes a new instance of the CollectionEventArgs class. Declaration public CollectionEventArgs(string resourcePath, ICollection addedResources = null, ICollection updatedResources = null, ICollection removedResources = null) Parameters Type Name Description String resourcePath The resource path. ICollection addedResources The added resources. ICollection updatedResources The updated resources. ICollection removedResources The removed resources. Properties AddedResources Gets the added resources. Declaration public ICollection AddedResources { get; } Property Value Type Description ICollection AdditionalData Gets or sets the additional data for the event. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > RemovedResources Gets the removed resources. Declaration public ICollection RemovedResources { get; } Property Value Type Description ICollection ResourcePath Gets the resource path for the collection. Declaration public string ResourcePath { get; } Property Value Type Description String UpdatedResources Gets the updated resource. Declaration public ICollection UpdatedResources { get; } Property Value Type Description ICollection " }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.html", - "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry.HttpLogging", - "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry.HttpLogging Classes HttpLogData The log data for http trace. HttpObfuscationHelpers Static class that provides helper functions for HTTP Logging." + "client/Microsoft.Graph.Communications.Common.Telemetry.html": { + "href": "client/Microsoft.Graph.Communications.Common.Telemetry.html", + "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry", + "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry Classes CommsLogEventFormatter Test log formatter. LogProperties The log properties. LogProperties.CallData Call data. LogProperties.ChatData Chat data." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpTraceType.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpTraceType.html", - "title": "Enum HttpTraceType", - "keywords": "Enum HttpTraceType Trace used for HTTP traces. Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum HttpTraceType Fields Name Description HttpRequest The HTTP request type HttpResponse The HTTP response type. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(HttpTraceType, String, String) Validator.Equals(HttpTraceType, String) Validator.NotEquals(HttpTraceType, String, String)" + "client/Microsoft.Graph.Communications.Resources.ResourceEventArgs-1.html": { + "href": "client/Microsoft.Graph.Communications.Resources.ResourceEventArgs-1.html", + "title": "Class ResourceEventArgs", + "keywords": "Class ResourceEventArgs The resource event arguments. Inheritance Object ResourceEventArgs Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class ResourceEventArgs where TEntity : Entity Type Parameters Name Description TEntity The containing NewResource type. NewResource Constructors ResourceEventArgs(TEntity, TEntity, String) Initializes a new instance of the ResourceEventArgs class. Declaration public ResourceEventArgs(TEntity oldResource, TEntity newResource, string resourcePath) Parameters Type Name Description TEntity oldResource The old resource. TEntity newResource The new resource. String resourcePath The resource path. Properties AdditionalData Gets or sets the additional data for the event. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > NewResource Gets the new resource. Declaration public TEntity NewResource { get; } Property Value Type Description TEntity OldResource Gets the old resource. Declaration public TEntity OldResource { get; } Property Value Type Description TEntity ResourcePath Gets the resource path for this resource. Declaration public string ResourcePath { get; } Property Value Type Description String" }, - "bot_media/Microsoft.Skype.Bots.Media.SkypeMediaException.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.SkypeMediaException.html", - "title": "Class SkypeMediaException", - "keywords": "Class SkypeMediaException Root class for the exceptions that are specific to the Skype Media Bots SDK, ie. exceptions other than the standard .NET Framework exceptions. Inheritance Object Exception SkypeMediaException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class SkypeMediaException : Exception, ISerializable, _Exception Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception" + "client/Microsoft.Graph.Communications.Resources.ResourceEventHandler-2.html": { + "href": "client/Microsoft.Graph.Communications.Resources.ResourceEventHandler-2.html", + "title": "Delegate ResourceEventHandler", + "keywords": "Delegate ResourceEventHandler The resource event handler delegate. Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public delegate void ResourceEventHandler(TSender sender, ResourceEventArgs e) where TEntity : Entity; Parameters Type Name Description TSender sender The sender. ResourceEventArgs e The event arguments. Type Parameters Name Description TSender The type of the resource. IResource TEntity The containing resource type. Entity Constructors ResourceEventHandler(Object, IntPtr) Declaration public ResourceEventHandler(object object, IntPtr method) Parameters Type Name Description Object object IntPtr method Methods BeginInvoke(TSender, ResourceEventArgs, AsyncCallback, Object) Declaration public virtual IAsyncResult BeginInvoke(TSender sender, ResourceEventArgs e, AsyncCallback callback, object object) Parameters Type Name Description TSender sender ResourceEventArgs e AsyncCallback callback Object object Returns Type Description IAsyncResult EndInvoke(IAsyncResult) Declaration public virtual void EndInvoke(IAsyncResult result) Parameters Type Name Description IAsyncResult result Invoke(TSender, ResourceEventArgs) Declaration public virtual void Invoke(TSender sender, ResourceEventArgs e) Parameters Type Name Description TSender sender ResourceEventArgs e" }, - "bot_media/Microsoft.Skype.Bots.Media.VideoMediaReceivedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoMediaReceivedEventArgs.html", - "title": "Class VideoMediaReceivedEventArgs", - "keywords": "Class VideoMediaReceivedEventArgs Event arguments of a VideoMediaReceived event. Inheritance Object EventArgs VideoMediaReceivedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoMediaReceivedEventArgs : EventArgs Constructors VideoMediaReceivedEventArgs() Declaration public VideoMediaReceivedEventArgs() Properties Buffer The received video media buffer. Declaration public VideoMediaBuffer Buffer { get; set; } Property Value Type Description VideoMediaBuffer MediaType MediaType of the video socket. This could be Video or Vbss. The MediaType is set after the socket is passed to the CreateMediaConfiguration API. It may also be set via the VideoSocketSettings during socket creation. Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType SocketId The 0-based ID of the socket that is raising this event. This socket ID can be used in multiview (ie. more than 1 video socket) to determine which video socket is raising this event. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the Microsoft.Skype.Bots.Media.MediaPlatform (or IMediaPlatform) API CreateMediaConfiguration. Eg. If the collection of IVideoSocket objects in the CreateMediaConfiguration API contains { socketA, socketB, socketC }, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Declaration public int SocketId { get; set; } Property Value Type Description Int32" + "common/Microsoft.Graph.Communications.Common.Exceptions.InvalidStateTransitionException.html": { + "href": "common/Microsoft.Graph.Communications.Common.Exceptions.InvalidStateTransitionException.html", + "title": "Class InvalidStateTransitionException", + "keywords": "Class InvalidStateTransitionException Exception to throw when a invalid transition is requested Inheritance Object Exception InvalidStateTransitionException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Exceptions Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class InvalidStateTransitionException : Exception, ISerializable, _Exception Constructors InvalidStateTransitionException(String) Initializes a new instance of the InvalidStateTransitionException class. Declaration public InvalidStateTransitionException(string message) Parameters Type Name Description String message the exception message Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "calls/Microsoft.Graph.Communications.Calls.IParticipantCollection.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.IParticipantCollection.html", - "title": "Interface IParticipantCollection", - "keywords": "Interface IParticipantCollection The stateful participant collection interface. Inherited Members IDisposable.Dispose() IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface IParticipantCollection : IResourceCollection, IResourceCollection, IResourceCollection, IResourceBase, IDisposable, IReadOnlyCollection, IEnumerable, IEnumerable Methods GetAsync(String, CancellationToken) Gets the participant from the collection. Declaration Task GetAsync(string participantId, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description String participantId The participant identifier. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IParticipant > The found IParticipant . Exceptions Type Condition ServiceException If the specified participant was not found. InviteAsync(IEnumerable, CancellationToken) Invites a list of participants given their identities. Declaration Task InviteAsync(IEnumerable participants, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description IEnumerable < InvitationParticipantInfo > participants The list of InvitationParticipantInfo to invite. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The invite updates will come in on IParticipantCollection.OnUpdated Extension Methods ParticipantExtensions.InviteAsync(IParticipantCollection, IdentitySet, String, CancellationToken)" + "common/Microsoft.Graph.Communications.Common.Transport.IGraphExchange-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphExchange-1.html", + "title": "Interface IGraphExchange", + "keywords": "Interface IGraphExchange The base of the exchange of a IGraphRequest or IGraphResponse . Inherited Members IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphExchange : IGraphExchange Type Parameters Name Description T Type of the body of exchange. Properties Content Gets or sets the content of the exchange. Declaration T Content { get; set; } Property Value Type Description T Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.ContractsConstants.NotificationProperties.html": { - "href": "core/Microsoft.Graph.ContractsConstants.NotificationProperties.html", - "title": "Class ContractsConstants.NotificationProperties", - "keywords": "Class ContractsConstants.NotificationProperties Notification properties constants Inheritance Object ContractsConstants.NotificationProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class NotificationProperties Fields ResourceData The resource data Declaration public const string ResourceData = \"resourceData\" Field Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Transport.IGraphHttpClient.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphHttpClient.html", + "title": "Interface IGraphHttpClient", + "keywords": "Interface IGraphHttpClient Interface for Http transport client. Gives us a way to work with different instances of GraphClient through Dependency Injection. Inherited Members IGraphClient.SendAsync(IGraphRequest, CancellationToken) IGraphClient.SendAsync(IGraphRequest, CancellationToken) IGraphClient.GraphLogger IGraphClient.DefaultProperties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphHttpClient : IGraphClient Properties CustomRedirectUriGenerator Gets or sets the custom redirect URI generator. This is called in case of a redirect (3XX) response from the request. Clients can use this to read the response and give the new redirect url to call in the next request. Declaration Func CustomRedirectUriGenerator { get; set; } Property Value Type Description Func < HttpResponseMessage , Uri > The custom redirect URI generator. Methods Clone(HttpClient) Clones this instance with optional overrides. Declaration IGraphHttpClient Clone(HttpClient httpClient = null) Parameters Type Name Description HttpClient httpClient The HTTP client to replace the original. Returns Type Description IGraphHttpClient Cloned client with the updated properties. SendRawHttpRequestAsync(HttpRequestMessage, CancellationToken) Send a Http request as an asynchronous operation. The content sent using this is not parsed or logged. Declaration Task SendRawHttpRequestAsync(HttpRequestMessage httpRequest, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description HttpRequestMessage httpRequest The http request message to send. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < HttpResponseMessage > The task object representing the asynchronous operation. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also IGraphClient" }, - "core/Microsoft.Graph.ContractsConstants.Signature.html": { - "href": "core/Microsoft.Graph.ContractsConstants.Signature.html", - "title": "Class ContractsConstants.Signature", - "keywords": "Class ContractsConstants.Signature Signature for Assembly visibility. Inheritance Object ContractsConstants.Signature Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Signature Fields VisibleToCastle Visible to property added to InternalsVisibleTo Castle signed builds. Declaration public const string VisibleToCastle = \", PublicKey=0024000004800000940000000602000000240000525341310004000001000100c547cac37abd99c8db225ef2f6c8a3602f3b3606cc9891605d02baa56104f4cfc0734aa39b93bf7852f7d9266654753cc297e7d2edfe0bac1cdcf9f717241550e0a7b191195b7667bb4f64bcb8e2121380fd1d9d46ad2d92d2d15605093924cceaf74c4861eff62abf69b9291ed0a340e113be11e6a7d3113e92484cf7045cc7\" Field Value Type Description String VisibleToMicrosoft Visible to property added to InternalsVisibleTo Microsoft signed builds. Declaration public const string VisibleToMicrosoft = \", PublicKey=0024000004800000940000000602000000240000525341310004000001000100b5fc90e7027f67871e773a8fde8938c81dd402ba65b9201d60593e96c492651e889cc13f1415ebb53fac1131ae0bd333c5ee6021672d9718ea31a8aebd0da0072f25d87dba6fc90ffd598ed4da35e44c398c454307e8e33b8426143daec9f596836f97c8f74750e5975c64e2189f45def46b2a2b1247adc3652bf5c308055da9\" Field Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Transport.IGraphProperty-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphProperty-1.html", + "title": "Interface IGraphProperty", + "keywords": "Interface IGraphProperty Inherited Members IGraphProperty.Key IGraphProperty.Type IEquatable.Equals(IGraphProperty) Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphProperty : IGraphProperty, IEquatable Type Parameters Name Description T The type of content contained in this property. Properties Value Gets the value. Declaration T Value { get; } Property Value Type Description T Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphProperty.ConvertProperty(IGraphProperty)" }, - "common/Microsoft.Graph.Communications.Common.Transport.RequestType.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.RequestType.html", - "title": "Enum RequestType", - "keywords": "Enum RequestType Type of request that we want to issue on the transport Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum RequestType Fields Name Description Create Request to create a resource Delete Request to delete a resource Get Request to get a resource Replace Request to replace a resource Update Request to update a resource Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(RequestType, String, String) Validator.Equals(RequestType, String) Validator.NotEquals(RequestType, String, String) GraphRequestExtensions.ToHttpMethod()" + "client/Microsoft.Graph.Communications.Client.CommunicationsClientBuilder.html": { + "href": "client/Microsoft.Graph.Communications.Client.CommunicationsClientBuilder.html", + "title": "Class CommunicationsClientBuilder", + "keywords": "Class CommunicationsClientBuilder The class the provides the builder for stateful client. Inheritance Object CommunicationsClientBuilder Implements ICommunicationsClientBuilder Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class CommunicationsClientBuilder : ICommunicationsClientBuilder Constructors CommunicationsClientBuilder(String, String, IGraphLogger, ObfuscationMember[]) Initializes a new instance of the CommunicationsClientBuilder class. Declaration public CommunicationsClientBuilder(string appName, string appId, IGraphLogger logger = null, ObfuscationMember[] additionalObfuscationMembers = null) Parameters Type Name Description String appName Name of the application. String appId The application identifier. IGraphLogger logger The logger ObfuscationMember [] additionalObfuscationMembers Additional members to obfuscate. Properties Id Gets the client id. Declaration public Guid Id { get; } Property Value Type Description Guid Methods Build() Build and return the stateful client object. Declaration public ICommunicationsClient Build() Returns Type Description ICommunicationsClient The ICommunicationsClient . Exceptions Type Condition ArgumentException Cannot build the client without setting the required parameters. SetAuthenticationProvider(IRequestAuthenticationProvider) Sets the custom authentication provider. The authentication provider would add authentication to outbound requests and validates any inbound requests. See IRequestAuthenticationProvider Declaration public ICommunicationsClientBuilder SetAuthenticationProvider(IRequestAuthenticationProvider authenticationProvider) Parameters Type Name Description IRequestAuthenticationProvider authenticationProvider Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the provider is null . SetCacheStrategy(ICache) Sets the cache strategy. Declaration public ICommunicationsClientBuilder SetCacheStrategy(ICache cacheStrategy) Parameters Type Name Description ICache cacheStrategy The cache strategy. Returns Type Description ICommunicationsClientBuilder This ICommunicationsClientBuilder object. Exceptions Type Condition ArgumentNullException If the cacheStrategy strategy is null . SetHttpClient(HttpClient, IEnumerable>) Sets the http client. Use a custom HTTP Client instead of the one generated by the SDK. Declaration public ICommunicationsClientBuilder SetHttpClient(HttpClient httpClient, IEnumerable> defaultHeaders = null) Parameters Type Name Description HttpClient httpClient The place call endpoint URL. IEnumerable < KeyValuePair < String , String >> defaultHeaders The default headers. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the httpClient is null . SetNotificationUrl(Uri) Set the notification uri for your bot. This is the default notification url for the bot. This can be overriden on a per-resource basis depending on the API support. Declaration public ICommunicationsClientBuilder SetNotificationUrl(Uri notificationUrlInput) Parameters Type Name Description Uri notificationUrlInput Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the notificationUrl is null . ArgumentException URI must be https. SetServiceBaseUrl(Uri) Sets the service base URL. This set's the Endpoint URL for the service. Declaration public ICommunicationsClientBuilder SetServiceBaseUrl(Uri serviceBaseUrlInput) Parameters Type Name Description Uri serviceBaseUrlInput Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the serviceBaseUrl is null . ArgumentException URI must be https. Implements ICommunicationsClientBuilder" }, - "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.html": { - "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.html", - "title": "Class ErrorConstants", - "keywords": "Class ErrorConstants Error Constants Inheritance Object ErrorConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class ErrorConstants" + "client/Microsoft.Graph.Communications.Client.Transport.GraphClientWrapper.html": { + "href": "client/Microsoft.Graph.Communications.Client.Transport.GraphClientWrapper.html", + "title": "Class GraphClientWrapper", + "keywords": "Class GraphClientWrapper The graph client wrapper. Inheritance Object GraphClientWrapper Implements IGraphClient Namespace : Microsoft.Graph.Communications.Client.Transport Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class GraphClientWrapper : ObjectRoot, IGraphClient Constructors GraphClientWrapper(IGraphClient, GraphClientContext) Initializes a new instance of the GraphClientWrapper class. Declaration public GraphClientWrapper(IGraphClient client, GraphClientContext context) Parameters Type Name Description IGraphClient client The client. GraphClientContext context The context. Properties Context Gets the context. Declaration public GraphClientContext Context { get; } Property Value Type Description GraphClientContext DefaultProperties Gets the default properties. Declaration public IEnumerable DefaultProperties { get; } Property Value Type Description IEnumerable < IGraphProperty > GraphLogger Declaration public IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Methods SendAsync(IGraphRequest, CancellationToken) Declaration public Task SendAsync(IGraphRequest request, CancellationToken cancellationToken = default(CancellationToken)) where T : class Parameters Type Name Description IGraphRequest request CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T SendAsync(IGraphRequest, CancellationToken) Declaration public Task> SendAsync(IGraphRequest request, CancellationToken cancellationToken = default(CancellationToken)) where T1 : class where T2 : class Parameters Type Name Description IGraphRequest request CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T1 T2 Implements IGraphClient" }, - "bot_media/Microsoft.Skype.Bots.Media.IDataSocket.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.IDataSocket.html", - "title": "Interface IDataSocket", - "keywords": "Interface IDataSocket Reserved for the internal use. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IDataSocket : IDisposable Methods Send(DataMediaBuffer, UInt32[]) Reserved for the internal use. Declaration void Send(DataMediaBuffer buffer, uint[] recipientIds) Parameters Type Name Description DataMediaBuffer buffer UInt32 [] recipientIds Events DataMediaReceived Reserved for the internal use. Declaration event EventHandler DataMediaReceived Event Type Type Description EventHandler < DataMediaReceivedEventArgs > DataSendStatusChanged Reserved for the internal use. Declaration event EventHandler DataSendStatusChanged Event Type Type Description EventHandler < DataSendStatusChangedEventArgs > MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs >" + "common/Microsoft.Graph.Communications.Common.Exceptions.RoutingException.html": { + "href": "common/Microsoft.Graph.Communications.Common.Exceptions.RoutingException.html", + "title": "Class RoutingException", + "keywords": "Class RoutingException Generic routing exception Inheritance Object Exception RoutingException RoutingBadRequestException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Exceptions Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class RoutingException : Exception, ISerializable, _Exception Constructors RoutingException(String) Initializes a new instance of the RoutingException class. Declaration public RoutingException(string message) Parameters Type Name Description String message message RoutingException(String, Exception) Initializes a new instance of the RoutingException class. Declaration public RoutingException(string message, Exception innerException) Parameters Type Name Description String message message Exception innerException inner exception Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.MediaPlatform.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatform.html", - "title": "Class MediaPlatform", - "keywords": "Class MediaPlatform This class represents the Skype Bots Media Platform. Inheritance Object MediaPlatform Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public static class MediaPlatform Fields DefaultMaxMediaPort The default maximum media port. Declaration public const uint DefaultMaxMediaPort = 65535U Field Value Type Description UInt32 DefaultMinMediaPort The default minimum media port. Declaration public const uint DefaultMinMediaPort = 49152U Field Value Type Description UInt32 MaxNumberOfConcurrentSendVideoSocketsPerPlatform The maximum number of send video/vbss sockets allowed by the media plaform. Declaration public const int MaxNumberOfConcurrentSendVideoSocketsPerPlatform = 1000 Field Value Type Description Int32 MaxNumberOfVideoSocketsPerCall The maximum number of video sockets that can be passed to the CreateMediaConfiguration API. Declaration public const int MaxNumberOfVideoSocketsPerCall = 10 Field Value Type Description Int32 MinNumberOfCoresRequired The minimum number of cores that the Media Platform requires. Declaration public const int MinNumberOfCoresRequired = 2 Field Value Type Description Int32 Name Name of the Bots Media Platform Declaration public const string Name = \"SkypeBotsMediaPlatform\" Field Value Type Description String Properties CurrentHealth The current health status of the media platform. Declaration public static MediaPlatformHealthStatus CurrentHealth { get; } Property Value Type Description MediaPlatformHealthStatus Methods CreateMediaConfiguration(IAudioSocket) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for the audio modality. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IDataSocket) Reserved for the internal use. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IDataSocket dataSocket) Parameters Type Name Description IAudioSocket audioSocket IDataSocket dataSocket Returns Type Description Newtonsoft.Json.Linq.JObject CreateMediaConfiguration(IAudioSocket, IVideoSocket) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for each modality. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IVideoSocket videoSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IVideoSocket videoSocket Socket that handles video. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for each modality. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IList < IVideoSocket > videoSockets Ordered list of video sockets. The order in which the sockets are provided maps to the order of the streams exposed by MediaPaaS (eg. the first video socket in the list will correspond to the first video stream exposed in the list of MediaStreams in MediaPaaS' MediaFlow resource). If multiview sockets are provided, only the first one can have a send direction (ie. send only or send receive) and all the sockets should have a receive direction. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList, IVideoSocket) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for each modality. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets, IVideoSocket vbssSocket) Parameters Type Name Description IAudioSocket audioSocket IList < IVideoSocket > videoSockets Ordered list of video sockets. The order in which the sockets are provided maps to the order of the streams exposed by MediaPaaS (eg. the first video socket in the list will correspond to the first video stream exposed in the list of MediaStreams in MediaPaaS' MediaFlow resource). If multiview sockets are provided, only the first one can have a send direction (ie. send only or send receive) and all the sockets should have a receive direction. IVideoSocket vbssSocket Video socket for the video-based screen sharing (VBSS) modality. Socket must be configured as RecvOnly. Returns Type Description Newtonsoft.Json.Linq.JObject Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized, or a vbssSocket is configured to be sendonly or sendrecv. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList, IVideoSocket, IDataSocket) Reserved for the internal use. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets, IVideoSocket vbssSocket, IDataSocket dataSocket) Parameters Type Name Description IAudioSocket audioSocket IList < IVideoSocket > videoSockets IVideoSocket vbssSocket IDataSocket dataSocket Returns Type Description Newtonsoft.Json.Linq.JObject CreateMediaConfiguration(IVideoSocket) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for each modality. Declaration public static JObject CreateMediaConfiguration(IVideoSocket vbssSocket) Parameters Type Name Description IVideoSocket vbssSocket Video socket for the video-based screen sharing (VBSS) modality. Socket must be configured as RecvOnly. Returns Type Description Newtonsoft.Json.Linq.JObject Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized, or a vbssSocket is configured to be sendonly or sendrecv. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. GetCurrentTimestamp() Get a current timestamp, in 100-ns units. To be used when sourcing media buffers. Declaration public static long GetCurrentTimestamp() Returns Type Description Int64 Initialize(MediaPlatformSettings) Initializes the Media Platform for Bot. Declaration public static void Initialize(MediaPlatformSettings settings) Parameters Type Name Description MediaPlatformSettings settings Settings to initialize the Bot Media Platform. Shutdown() Shuts down the Bot Media Platform. Declaration public static void Shutdown() Events MediaPlatformHealthChanged Raised when there is a change in the media platform's health status. The event arguments report the current and previous platform health conditions. Declaration public static event EventHandler MediaPlatformHealthChanged Event Type Type Description EventHandler < MediaPlatformHealthChangedEventArgs > Remarks A bot application which may handle very high call volumes or perform complex real-time media processing should monitor this event for changes in the media platform health status. When the event reports the platform health status has become HeavilyLoaded, the application should avoid starting new bot calls on the machine instance until the health status returns back to Normal." + "common/Microsoft.Graph.Communications.Common.OData.ODataSerializeAsTypeAttribute.html": { + "href": "common/Microsoft.Graph.Communications.Common.OData.ODataSerializeAsTypeAttribute.html", + "title": "Class ODataSerializeAsTypeAttribute", + "keywords": "Class ODataSerializeAsTypeAttribute Specify how a given object should be written/read on the wire. Inheritance Object Attribute ODataSerializeAsTypeAttribute Implements _Attribute Inherited Members Attribute.GetCustomAttributes(MemberInfo, Type) Attribute.GetCustomAttributes(MemberInfo, Type, Boolean) Attribute.GetCustomAttributes(MemberInfo) Attribute.GetCustomAttributes(MemberInfo, Boolean) Attribute.IsDefined(MemberInfo, Type) Attribute.IsDefined(MemberInfo, Type, Boolean) Attribute.GetCustomAttribute(MemberInfo, Type) Attribute.GetCustomAttribute(MemberInfo, Type, Boolean) Attribute.GetCustomAttributes(ParameterInfo) Attribute.GetCustomAttributes(ParameterInfo, Type) Attribute.GetCustomAttributes(ParameterInfo, Type, Boolean) Attribute.GetCustomAttributes(ParameterInfo, Boolean) Attribute.IsDefined(ParameterInfo, Type) Attribute.IsDefined(ParameterInfo, Type, Boolean) Attribute.GetCustomAttribute(ParameterInfo, Type) Attribute.GetCustomAttribute(ParameterInfo, Type, Boolean) Attribute.GetCustomAttributes(Module, Type) Attribute.GetCustomAttributes(Module) Attribute.GetCustomAttributes(Module, Boolean) Attribute.GetCustomAttributes(Module, Type, Boolean) Attribute.IsDefined(Module, Type) Attribute.IsDefined(Module, Type, Boolean) Attribute.GetCustomAttribute(Module, Type) Attribute.GetCustomAttribute(Module, Type, Boolean) Attribute.GetCustomAttributes(Assembly, Type) Attribute.GetCustomAttributes(Assembly, Type, Boolean) Attribute.GetCustomAttributes(Assembly) Attribute.GetCustomAttributes(Assembly, Boolean) Attribute.IsDefined(Assembly, Type) Attribute.IsDefined(Assembly, Type, Boolean) Attribute.GetCustomAttribute(Assembly, Type) Attribute.GetCustomAttribute(Assembly, Type, Boolean) Attribute.Equals(Object) Attribute.GetHashCode() Attribute.Match(Object) Attribute.IsDefaultAttribute() Attribute._Attribute.GetTypeInfoCount(UInt32) Attribute._Attribute.GetTypeInfo(UInt32, UInt32, IntPtr) Attribute._Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr) Attribute._Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr) Attribute.TypeId Object.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax [AttributeUsage(AttributeTargets.Class, AllowMultiple = false, Inherited = false)] public class ODataSerializeAsTypeAttribute : Attribute, _Attribute Constructors ODataSerializeAsTypeAttribute(String, Boolean) Initializes a new instance of the ODataSerializeAsTypeAttribute class. Declaration public ODataSerializeAsTypeAttribute(string name, bool renameWhenSerialized = true) Parameters Type Name Description String name The name of the class. Boolean renameWhenSerialized If set to true use the Name to serialize the class. Properties Name Gets the name of the class. Declaration public string Name { get; } Property Value Type Description String RenameWhenSerialized Gets a value indicating whether to rename when serializing this object. When true, the object will be serialized to Name , otherwise the object will be serialized as the actual object name. Declaration public bool RenameWhenSerialized { get; } Property Value Type Description Boolean Implements System.Runtime.InteropServices._Attribute Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also Attribute" }, - "bot_media/Microsoft.Skype.Bots.Media.MediaQualityOfExperienceData.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaQualityOfExperienceData.html", - "title": "Class MediaQualityOfExperienceData", - "keywords": "Class MediaQualityOfExperienceData Media quality of experience (QoE) data Inheritance Object MediaQualityOfExperienceData AudioQualityOfExperienceData VideoQualityOfExperienceData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public abstract class MediaQualityOfExperienceData Constructors MediaQualityOfExperienceData() MediaQualityOfExperienceData constructor Declaration public MediaQualityOfExperienceData() Properties NetworkMetrics QoE network level metrics Declaration public NetworkMetrics NetworkMetrics { get; set; } Property Value Type Description NetworkMetrics TotalMediaDuration Total duration of the media stream Declaration public TimeSpan TotalMediaDuration { get; set; } Property Value Type Description TimeSpan" + "common/Microsoft.Graph.Communications.Common.OData.ODataTimeSpanConverter.html": { + "href": "common/Microsoft.Graph.Communications.Common.OData.ODataTimeSpanConverter.html", + "title": "Class ODataTimeSpanConverter", + "keywords": "Class ODataTimeSpanConverter Custom json converter for TimeSpans. Inheritance Object ODataTimeSpanConverter Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ODataTimeSpanConverter : JsonConverter Constructors ODataTimeSpanConverter() Declaration public ODataTimeSpanConverter() Properties CanWrite Declaration public override bool CanWrite { get; } Property Value Type Description Boolean Methods CanConvert(Type) Declaration public override bool CanConvert(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Boolean ReadJson(JsonReader, Type, Object, JsonSerializer) Deserializes the object to the correct type. Declaration public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonReader reader The Newtonsoft.Json.JsonReader to read from. Type objectType The interface type. Object existingValue The existing value of the object being read. Newtonsoft.Json.JsonSerializer serializer The Newtonsoft.Json.JsonSerializer for deserialization. Returns Type Description Object The deserialized object WriteJson(JsonWriter, Object, JsonSerializer) Declaration public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonWriter writer Object value Newtonsoft.Json.JsonSerializer serializer Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.NetworkMetrics.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.NetworkMetrics.html", - "title": "Class NetworkMetrics", - "keywords": "Class NetworkMetrics QoE network level metrics Inheritance Object NetworkMetrics Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class NetworkMetrics Constructors NetworkMetrics() Declaration public NetworkMetrics() Properties AverageInboundPacketLossRateInPercentage Average packet loss rate on the inbound media stream Declaration public double AverageInboundPacketLossRateInPercentage { get; set; } Property Value Type Description Double AverageInboundRoundTripDelay Average round trip delay on the inbound media stream Declaration public TimeSpan AverageInboundRoundTripDelay { get; set; } Property Value Type Description TimeSpan AverageOutboundPacketLossRateInPercentage Average packet loss rate on the outbound media stream Declaration public double AverageOutboundPacketLossRateInPercentage { get; set; } Property Value Type Description Double AverageOutboundRoundTripDelay Average round trip delay on the outbound media stream Declaration public TimeSpan AverageOutboundRoundTripDelay { get; set; } Property Value Type Description TimeSpan MaximumInboundPacketLossRateInPercentage Maximum packet loss rate on the inbound media stream Declaration public double MaximumInboundPacketLossRateInPercentage { get; set; } Property Value Type Description Double MaximumInboundRoundTripDelay Maximum round trip delay on the inbound media stream Declaration public TimeSpan MaximumInboundRoundTripDelay { get; set; } Property Value Type Description TimeSpan MaximumOutboundPacketLossRateInPercentage Maximum packet loss rate on the outbound media stream Declaration public double MaximumOutboundPacketLossRateInPercentage { get; set; } Property Value Type Description Double MaximumOutboundRoundTripDelay Maximum round trip delay on the outbound media stream Declaration public TimeSpan MaximumOutboundRoundTripDelay { get; set; } Property Value Type Description TimeSpan TotalInboundPackets Total number of packets received on the inbound media stream Declaration public uint TotalInboundPackets { get; set; } Property Value Type Description UInt32 TotalOutboundPackets Total number of packets sent on the outbound media stream Declaration public uint TotalOutboundPackets { get; set; } Property Value Type Description UInt32" + "common/Microsoft.Graph.Communications.Common.StateMachine-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.StateMachine-1.html", + "title": "Class StateMachine", + "keywords": "Class StateMachine Lockfree enum-based state machine. Transitions are O(1). Inheritance Object StateMachine Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class StateMachine where TStateEnum : struct, IComparable, IFormattable, IConvertible Type Parameters Name Description TStateEnum The enum type which represents state. Constructors StateMachine(TStateEnum, StateMachine.Transition[]) Initializes a new instance of the StateMachine class. Declaration public StateMachine(TStateEnum initalState, StateMachine.Transition[] transitions) Parameters Type Name Description TStateEnum initalState State of the inital. StateMachine.Transition <>[] transitions The transitions. Properties State Gets the state. Declaration public TStateEnum State { get; } Property Value Type Description TStateEnum The state. Methods ToString() Returns a String that represents this instance. Declaration public override string ToString() Returns Type Description String A String that represents this instance. Overrides Object.ToString() TransitionState(TStateEnum) Transition to next state. Transition to same state is not allowed. Non valid transition throws exception. Declaration public TStateEnum TransitionState(TStateEnum newState) Parameters Type Name Description TStateEnum newState The new state. Returns Type Description TStateEnum Previous state Exceptions Type Condition Exception If transition is not allow, exception is thrown. TransitionStateSafe(TStateEnum) Transition to the next state. Transition to same state has to be allowed via transitions. Non valid transition returns null. Declaration public TStateEnum? TransitionStateSafe(TStateEnum newState) Parameters Type Name Description TStateEnum newState The new state. Returns Type Description Nullable Previous state or null; if transition is not valid. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.UnmixedAudioBuffer.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.UnmixedAudioBuffer.html", - "title": "Struct UnmixedAudioBuffer", - "keywords": "Struct UnmixedAudioBuffer Represents an unmanaged audio buffer containing unmixed data corresponding to a specific speaker in a conference. This structure contains a pointer to the unmanaged audio buffer, the length of the buffer and the ID of the audio source of the active speaker. Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() ValueType.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public struct UnmixedAudioBuffer Properties ActiveSpeakerId The ID of the audio source of the active speaker. Declaration public uint ActiveSpeakerId { get; } Property Value Type Description UInt32 Data Pointer to the unmanaged media buffer. Declaration public IntPtr Data { get; } Property Value Type Description IntPtr Length The length in bytes of the media buffer. Declaration public long Length { get; } Property Value Type Description Int64 OriginalSenderTimestamp Original timestamp of the unmixed audio buffer as it was sourced, in 100-ns units. This property may differ from AudioMediaBuffer.Timestamp, which represents the timestamp of when the media content was received by the bot. Declaration public long OriginalSenderTimestamp { get; } Property Value Type Description Int64 Remarks The OriginalSenderTimestamp can have a value of 0 under various circumstances, eg. in the first 4-5 seconds of the call, or during various media events (media reconnects, sample rate changes, etc)." + "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLogger.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLogger.html", + "title": "Class GraphLogger", + "keywords": "Class GraphLogger Logging portion of graph. Inheritance Object Disposable GraphLogger Implements IDisposable IGraphLogger IObservable < LogEvent > Inherited Members Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphLogger : Disposable, IDisposable, IGraphLogger, IObservable Constructors GraphLogger(String, IEnumerable, Boolean, ObfuscationConfiguration) Initializes a new instance of the GraphLogger class. Declaration public GraphLogger(string component = null, IEnumerable properties = null, bool redirectToTrace = false, ObfuscationConfiguration obfuscationConfiguration = null) Parameters Type Name Description String component The component in which log is createdThe component in which this logger is created. IEnumerable < Object > properties Common properties to be set on each event Boolean redirectToTrace if set to true [redirect to trace]. ObfuscationConfiguration obfuscationConfiguration The obfuscation configuration Fields StartupLoggerNameSuffix The startup logger name prefix Declaration public const string StartupLoggerNameSuffix = \"_Startup\" Field Value Type Description String Properties Component Gets or the component of logger. Declaration public string Component { get; } Property Value Type Description String CorrelationId Gets or sets the correlation identifier. This is used to track correlation between multiple requests for one scenario. Declaration public Guid CorrelationId { get; set; } Property Value Type Description Guid DiagnosticLevel Gets or sets the diagnostic level for the logger. Declaration public TraceLevel DiagnosticLevel { get; set; } Property Value Type Description TraceLevel LogicalThreadId Gets or sets the logical thread identifier. This id is used for tracking the flow of one request throughout the lifetime until it ends. Declaration public uint LogicalThreadId { get; set; } Property Value Type Description UInt32 ObfuscationConfiguration Gets the obfuscation configuration. Declaration public ObfuscationConfiguration ObfuscationConfiguration { get; } Property Value Type Description ObfuscationConfiguration Properties Gets the common properties for each event. Declaration public IReadOnlyDictionary Properties { get; } Property Value Type Description IReadOnlyDictionary < Type , Object > Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) Log(TraceLevel, String, String, Guid, Guid, LogEventType, IEnumerable, String, String, Int32) Log messages classified as the provided trace level. Declaration public LogEvent Log(TraceLevel level, string message, string component = null, Guid correlationId = default(Guid), Guid requestId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The trace level. String message A composite format string that includes one or more format items. String component The component in which log is created Guid correlationId The correlation identifier. Guid requestId The request identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Subscribe(IObserver) Create a subscription for logging events. Declaration public IDisposable Subscribe(IObserver observer) Parameters Type Name Description IObserver < LogEvent > observer The object that is to receive notifications. Returns Type Description IDisposable A reference to an interface that allows observers to stop receiving notifications before the provider has finished sending them. Implements System.IDisposable IGraphLogger System.IObservable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.CreateObserver(IObservable, Action, Action, Action) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) LoggingExtensions.Log(IGraphLogger, TraceLevel, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Info(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Verbose(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.LogHttpMessage(IGraphLogger, TraceLevel, TransactionDirection, HttpTraceType, String, String, String, IEnumerable>>, Int32, String, Nullable, Guid, Guid, String, String, Int32) LoggingExtensions.Metric(IGraphLogger, String, String, Int64, Dictionary, Boolean, String, Guid, String, String, Int32) LoggingExtensions.SerializeAndObfuscate(IGraphLogger, Object, Formatting) LoggingExtensions.Obfuscate(IGraphLogger, Object, ObfuscationTag) LoggingExtensions.GetHeaderText(IGraphLogger, IEnumerable>>) LoggingExtensions.CreateShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) LoggingExtensions.CreateILogger(IGraphLogger, String, Guid, LogEventType, IEnumerable) LoggingExtensions.BindToILoggerFactory(GraphLogger, ILoggerFactory, ILogEventFormatter) LoggingExtensions.EnterMethod(IGraphLogger, Guid, String, String, Int32) LoggingExtensions.LeaveMethod(IGraphLogger, Guid, String, String, Int32)" }, - "bot_media/Microsoft.Skype.Bots.Media.VideoQualityType.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoQualityType.html", - "title": "Enum VideoQualityType", - "keywords": "Enum VideoQualityType Type of the video media quality Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum VideoQualityType Fields Name Description ReceiveFreeze Video freeze for the received stream" + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscatedValueProvider.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscatedValueProvider.html", + "title": "Class ObfuscatedValueProvider", + "keywords": "Class ObfuscatedValueProvider Newtonsoft JSONs value provider for obfuscated data. Inheritance Object ObfuscatedValueProvider Implements Newtonsoft.Json.Serialization.IValueProvider Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ObfuscatedValueProvider : IValueProvider Constructors ObfuscatedValueProvider(MemberInfo, IObfuscationEngine, ObfuscationTag) Initializes a new instance of the ObfuscatedValueProvider class. Declaration public ObfuscatedValueProvider(MemberInfo memberInfo, IObfuscationEngine obfuscationEngine, ObfuscationTag obfuscationTag) Parameters Type Name Description MemberInfo memberInfo The member information. IObfuscationEngine obfuscationEngine The obfuscation engine. ObfuscationTag obfuscationTag The obfuscation tag. Methods GetValue(Object) Declaration public object GetValue(object target) Parameters Type Name Description Object target Returns Type Description Object SetValue(Object, Object) Sets the value. Declaration public void SetValue(object target, object value) Parameters Type Name Description Object target The target to set the value on. Object value The value to set on the target. Implements Newtonsoft.Json.Serialization.IValueProvider Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.VideoReceiveStatusChangedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoReceiveStatusChangedEventArgs.html", - "title": "Class VideoReceiveStatusChangedEventArgs", - "keywords": "Class VideoReceiveStatusChangedEventArgs Event arguments of a VideoReceiveStatusChanged event. Inheritance Object EventArgs VideoReceiveStatusChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoReceiveStatusChangedEventArgs : EventArgs Constructors VideoReceiveStatusChangedEventArgs() Declaration public VideoReceiveStatusChangedEventArgs() Properties MediaReceiveStatus The media receive status. Declaration public MediaReceiveStatus MediaReceiveStatus { get; set; } Property Value Type Description MediaReceiveStatus MediaType MediaType of the video socket raising the event. This could be Video or Vbss. Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType SocketId Socket Id associated with the video receive event Declaration public int SocketId { get; set; } Property Value Type Description Int32" + "common/Microsoft.Graph.Communications.Common.Transport.GraphResponseException.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphResponseException.html", + "title": "Class GraphResponseException", + "keywords": "Class GraphResponseException Class representing GraphResponseException Inheritance Object Exception GraphResponseException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphResponseException : Exception, ISerializable, _Exception Constructors GraphResponseException(IGraphResponse) Initializes a new instance of the GraphResponseException class. Declaration public GraphResponseException(IGraphResponse errorResponse) Parameters Type Name Description IGraphResponse errorResponse The error response. Properties Response Gets the response. Declaration public IGraphResponse Response { get; } Property Value Type Description IGraphResponse The response. Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also Exception" }, - "calls/Microsoft.Graph.Communications.Calls.ICallCollection.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.ICallCollection.html", - "title": "Interface ICallCollection", - "keywords": "Interface ICallCollection The stateful call collection interface. Inherited Members IDisposable.Dispose() IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface ICallCollection : IResourceCollection, IResourceCollection, IResourceCollection, IResourceBase, IDisposable, IReadOnlyCollection, IEnumerable, IEnumerable Methods AddAsync(Call, IMediaSession, Guid, CancellationToken) Create a new call and add to the collection. Declaration Task AddAsync(Call resource, IMediaSession mediaSession = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description Call resource The call resource to be added. IMediaSession mediaSession The media session object, if any. This is valid only for application hosted media scenarios. Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < ICall > The ICall that has been created. This call has not yet been established and those notifications will fire on ICall.OnUpdated Events OnIncoming The incoming call event. This event is triggered when a new call is being received by the bot. Declaration event CollectionEventHandler OnIncoming Event Type Type Description CollectionEventHandler < ICallCollection , ICall > Extension Methods CallCollectionExtensions.AddAsync(ICallCollection, JoinMeetingParameters, Guid, CancellationToken)" + "client/Microsoft.Graph.Communications.Client.PagedList-1.html": { + "href": "client/Microsoft.Graph.Communications.Client.PagedList-1.html", + "title": "Class PagedList", + "keywords": "Class PagedList An object that contains paginated list of the generic type T. Inheritance Object PagedList Implements IPagedList IReadOnlyList IReadOnlyCollection IEnumerable IEnumerable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class PagedList : IPagedList, IReadOnlyList, IReadOnlyCollection, IEnumerable, IEnumerable Type Parameters Name Description T The type of Paged List. Constructors PagedList() Declaration public PagedList() Properties AdditionalData Gets or sets the additional data. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > Count Declaration public int Count { get; } Property Value Type Description Int32 Item[Int32] Declaration public T this[int index] { get; } Parameters Type Name Description Int32 index Property Value Type Description T NextLinkUrl Gets the next link URL taken from @odata.nextLink. Declaration public Uri NextLinkUrl { get; } Property Value Type Description Uri Value Gets or sets the value in the current page of the list. Declaration public IList Value { get; set; } Property Value Type Description IList Methods GetEnumerator() Declaration public IEnumerator GetEnumerator() Returns Type Description IEnumerator Explicit Interface Implementations IEnumerable.GetEnumerator() Declaration IEnumerator IEnumerable.GetEnumerator() Returns Type Description IEnumerator Implements IPagedList System.Collections.Generic.IReadOnlyList System.Collections.Generic.IReadOnlyCollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable" }, - "core/Microsoft.Graph.Communications.Core.html": { - "href": "core/Microsoft.Graph.Communications.Core.html", - "title": "Namespace Microsoft.Graph.Communications.Core", - "keywords": "Namespace Microsoft.Graph.Communications.Core Classes CommsConstants The communications constants. CommsConstants.HttpPropertyNames Constants used for HTTP property names CommsGeneratedErrorConstants The generated error constants. CommsGeneratedErrorConstants.Codes The codes CommsGeneratedErrorConstants.Messages The messages. GraphModelExtensions Generic graph model extensions." + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.UriFilter.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.UriFilter.html", + "title": "Class UriFilter", + "keywords": "Class UriFilter URI Filter. Any group matches from REGEX are obfuscated. Inheritance Object BaseFilter BaseFilter < Uri , Regex > UriFilter Inherited Members BaseFilter.MatchableString BaseFilter.MatchEvaluator Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class UriFilter : BaseFilter Constructors UriFilter(Regex) Initializes a new instance of the UriFilter class. Declaration public UriFilter(Regex matchableSubtring) Parameters Type Name Description Regex matchableSubtring The matchable REGEX. Use captures for obfuscation. Use obfuscation tag names as group names for specific object Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.ContractsConstants.AuthConstants.html": { - "href": "core/Microsoft.Graph.ContractsConstants.AuthConstants.html", - "title": "Class ContractsConstants.AuthConstants", - "keywords": "Class ContractsConstants.AuthConstants Various constants used by the AuthZ layer Inheritance Object ContractsConstants.AuthConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class AuthConstants Fields ConsumerTenantIds list of tenant ids that are considered as skype consumer tenants Declaration public static readonly ICollection ConsumerTenantIds Field Value Type Description ICollection < String >" + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.GraphObfuscationAttribute.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.GraphObfuscationAttribute.html", + "title": "Class GraphObfuscationAttribute", + "keywords": "Class GraphObfuscationAttribute Attribute used for decoration of data objects. This is used for obfuscation for logging. Inheritance Object Attribute GraphObfuscationAttribute Implements _Attribute Inherited Members Attribute.GetCustomAttributes(MemberInfo, Type) Attribute.GetCustomAttributes(MemberInfo, Type, Boolean) Attribute.GetCustomAttributes(MemberInfo) Attribute.GetCustomAttributes(MemberInfo, Boolean) Attribute.IsDefined(MemberInfo, Type) Attribute.IsDefined(MemberInfo, Type, Boolean) Attribute.GetCustomAttribute(MemberInfo, Type) Attribute.GetCustomAttribute(MemberInfo, Type, Boolean) Attribute.GetCustomAttributes(ParameterInfo) Attribute.GetCustomAttributes(ParameterInfo, Type) Attribute.GetCustomAttributes(ParameterInfo, Type, Boolean) Attribute.GetCustomAttributes(ParameterInfo, Boolean) Attribute.IsDefined(ParameterInfo, Type) Attribute.IsDefined(ParameterInfo, Type, Boolean) Attribute.GetCustomAttribute(ParameterInfo, Type) Attribute.GetCustomAttribute(ParameterInfo, Type, Boolean) Attribute.GetCustomAttributes(Module, Type) Attribute.GetCustomAttributes(Module) Attribute.GetCustomAttributes(Module, Boolean) Attribute.GetCustomAttributes(Module, Type, Boolean) Attribute.IsDefined(Module, Type) Attribute.IsDefined(Module, Type, Boolean) Attribute.GetCustomAttribute(Module, Type) Attribute.GetCustomAttribute(Module, Type, Boolean) Attribute.GetCustomAttributes(Assembly, Type) Attribute.GetCustomAttributes(Assembly, Type, Boolean) Attribute.GetCustomAttributes(Assembly) Attribute.GetCustomAttributes(Assembly, Boolean) Attribute.IsDefined(Assembly, Type) Attribute.IsDefined(Assembly, Type, Boolean) Attribute.GetCustomAttribute(Assembly, Type) Attribute.GetCustomAttribute(Assembly, Type, Boolean) Attribute.Equals(Object) Attribute.GetHashCode() Attribute.Match(Object) Attribute.IsDefaultAttribute() Attribute._Attribute.GetTypeInfoCount(UInt32) Attribute._Attribute.GetTypeInfo(UInt32, UInt32, IntPtr) Attribute._Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr) Attribute._Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr) Attribute.TypeId Object.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax [AttributeUsage(AttributeTargets.Class | AttributeTargets.Enum | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)] public class GraphObfuscationAttribute : Attribute, _Attribute Constructors GraphObfuscationAttribute() Declaration public GraphObfuscationAttribute() Properties Tag Gets or sets the tag. Declaration public ObfuscationTag Tag { get; set; } Property Value Type Description ObfuscationTag Implements System.Runtime.InteropServices._Attribute Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also Attribute" }, - "core/Microsoft.Graph.ContractsConstants.CallProperties.html": { - "href": "core/Microsoft.Graph.ContractsConstants.CallProperties.html", - "title": "Class ContractsConstants.CallProperties", - "keywords": "Class ContractsConstants.CallProperties Call properties constants Inheritance Object ContractsConstants.CallProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class CallProperties Fields AllowGuestToBypassLobby The lobbyBypass value for group call join. Declaration public const string AllowGuestToBypassLobby = \"allowGuestToBypassLobby\" Field Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventFormatter.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventFormatter.html", + "title": "Class LogEventFormatter", + "keywords": "Class LogEventFormatter The log event formatter Inheritance Object LogEventFormatter Implements ILogEventFormatter Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class LogEventFormatter : ILogEventFormatter Constructors LogEventFormatter(LogEventFormatterFlags, String, String) Initializes a new instance of the LogEventFormatter class. Declaration public LogEventFormatter(LogEventFormatterFlags flags = LogEventFormatterFlags.ForDefault, string inlineSeparator = \" \", string timestampFormat = \"yyyy-MM-ddTHH:mm:ss.ffffZ\") Parameters Type Name Description LogEventFormatterFlags flags The formatter flags to control which will be shown in output message. String inlineSeparator The inline separator for logging fields String timestampFormat The default timestamp format Fields DefaultTimestampFormat The default timestamp format. Declaration public const string DefaultTimestampFormat = \"yyyy-MM-ddTHH:mm:ss.ffffZ\" Field Value Type Description String Methods Format(LogEvent) Format the log event. Declaration public string Format(LogEvent logEvent) Parameters Type Name Description LogEvent logEvent The log event Returns Type Description String The formatted text. Implements ILogEventFormatter Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.AudioSettings.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioSettings.html", - "title": "Class AudioSettings", - "keywords": "Class AudioSettings Audio frame player settings Inheritance Object AudioSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioSettings Constructors AudioSettings(UInt32) Default constructor Declaration public AudioSettings(uint buffersizeInMs) Parameters Type Name Description UInt32 buffersizeInMs Properties BufferSizeInMs Audio buffer length in ms Declaration public uint BufferSizeInMs { get; set; } Property Value Type Description UInt32" + "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClientFactory.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClientFactory.html", + "title": "Class GraphHttpClientFactory", + "keywords": "Class GraphHttpClientFactory The HTTP graph client factory. Inheritance Object ObjectRoot GraphHttpClientFactory Implements IGraphClientFactory Inherited Members ObjectRoot.GraphLogger Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphHttpClientFactory : ObjectRoot, IGraphClientFactory Constructors GraphHttpClientFactory(IGraphLogger, JsonSerializerSettings, HttpClient, String) Initializes a new instance of the GraphHttpClientFactory class. Declaration public GraphHttpClientFactory(IGraphLogger logger, JsonSerializerSettings serializerSettings, HttpClient httpClient = null, string correlationIdHeader = null) Parameters Type Name Description IGraphLogger logger Logger instance. Newtonsoft.Json.JsonSerializerSettings serializerSettings The serializer settings. HttpClient httpClient The HTTP client. String correlationIdHeader The correlation identifier header. Methods Create(IGraphLogger) Creates a new IGraphClient . Declaration public IGraphClient Create(IGraphLogger logger = null) Parameters Type Name Description IGraphLogger logger An optional IGraphLogger logger to be used in the new IGraphClient . Returns Type Description IGraphClient The IGraphClient . Implements IGraphClientFactory Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also ObjectRoot IGraphClientFactory" }, - "bot_media/Microsoft.Skype.Bots.Media.DataMediaReceivedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.DataMediaReceivedEventArgs.html", - "title": "Class DataMediaReceivedEventArgs", - "keywords": "Class DataMediaReceivedEventArgs Reserved for the internal use. Inheritance Object EventArgs DataMediaReceivedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class DataMediaReceivedEventArgs : EventArgs Constructors DataMediaReceivedEventArgs() Declaration public DataMediaReceivedEventArgs() Properties Buffer Reserved for the internal use. Declaration public DataMediaBuffer Buffer { get; } Property Value Type Description DataMediaBuffer" + "common/Microsoft.Graph.Communications.Common.Transport.GraphProperty-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphProperty-1.html", + "title": "Struct GraphProperty", + "keywords": "Struct GraphProperty Implements IGraphProperty IGraphProperty IEquatable < IGraphProperty > Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public struct GraphProperty : IGraphProperty, IGraphProperty, IEquatable Type Parameters Name Description T Constructors GraphProperty(IGraphProperty) Initializes a new instance of the GraphProperty struct. Declaration public GraphProperty(IGraphProperty property) Parameters Type Name Description IGraphProperty property The property. GraphProperty(String, T, String) Initializes a new instance of the GraphProperty struct. Declaration public GraphProperty(string key, T value, string type = null) Parameters Type Name Description String key The key. T value The value. String type The type. Properties Key Gets the key. Declaration public string Key { get; } Property Value Type Description String Type Gets the type of the property. Declaration public string Type { get; } Property Value Type Description String Value Declaration public T Value { get; } Property Value Type Description T Methods Equals(IGraphProperty) Declaration public bool Equals(IGraphProperty other) Parameters Type Name Description IGraphProperty other Returns Type Description Boolean ToString() Declaration public override string ToString() Returns Type Description String Overrides ValueType.ToString() Explicit Interface Implementations IGraphProperty.Value Gets the value. Declaration object IGraphProperty.Value { get; } Returns Type Description Object Implements IGraphProperty IGraphProperty System.IEquatable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphProperty.ConvertProperty(IGraphProperty)" }, - "bot_media/Microsoft.Skype.Bots.Media.DominantSpeakerChangedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.DominantSpeakerChangedEventArgs.html", - "title": "Class DominantSpeakerChangedEventArgs", - "keywords": "Class DominantSpeakerChangedEventArgs Event arguments of the DominantSpeakerChanged event. Inheritance Object EventArgs DominantSpeakerChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class DominantSpeakerChangedEventArgs : EventArgs Constructors DominantSpeakerChangedEventArgs() Declaration public DominantSpeakerChangedEventArgs() Fields None Constant value which indicates there is no dominant speaker in the conference. Declaration public const uint None = 4294967295U Field Value Type Description UInt32 Properties CurrentDominantSpeaker Current dominant speaker in the conference. The value is the MediaSourceId (MSI) of the dominant speaker in the conference. If there is no dominant speaker in the conference this value will be None (0xFFFFFFFF). Declaration public uint CurrentDominantSpeaker { get; set; } Property Value Type Description UInt32 DominantSpeakerHistory History of the dominant speakers. However, DominantSpeakerHistory won't contain any element to indicate the absence of dominant speaker in the conference. Declaration public uint[] DominantSpeakerHistory { get; set; } Property Value Type Description UInt32 []" + "common/Microsoft.Graph.Communications.Common.Exceptions.RoutingBadRequestException.html": { + "href": "common/Microsoft.Graph.Communications.Common.Exceptions.RoutingBadRequestException.html", + "title": "Class RoutingBadRequestException", + "keywords": "Class RoutingBadRequestException Indicate there's a bad request Inheritance Object Exception RoutingException RoutingBadRequestException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Exceptions Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class RoutingBadRequestException : RoutingException, ISerializable, _Exception Constructors RoutingBadRequestException(String) Initializes a new instance of the RoutingBadRequestException class. Declaration public RoutingBadRequestException(string message) Parameters Type Name Description String message message RoutingBadRequestException(String, Exception) Initializes a new instance of the RoutingBadRequestException class. Declaration public RoutingBadRequestException(string message, Exception innerException) Parameters Type Name Description String message message Exception innerException inner exception Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.IVideoSocket.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.IVideoSocket.html", - "title": "Interface IVideoSocket", - "keywords": "Interface IVideoSocket Interface to a VideoSocket. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IVideoSocket : IDisposable Properties MediaType MediaType of the video socket. This could be Video or Vbss. The MediaType is set after the socket is passed to the CreateMediaConfiguration API Declaration MediaType MediaType { get; } Property Value Type Description MediaType SocketId The 0-based ID of the socket. This socket ID is useful to identify a socket in a multiview (ie. more than 1 video socket) call. The same ID is used in the event args of the VideoMediaReceived and VideoSendStatusChanged events that this class may raise. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the CreateMediaConfiguration API. Eg., if the collection of IVideoSocket objects in the CreateMediaConfiguration API contains {socketA, socketB, socketC}, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Before the call to CreateMediaConfiguration, the SocketId has a value of -1. Declaration int SocketId { get; } Property Value Type Description Int32 Methods GetQualityOfExperienceData() Get the Quality of Experience (QoE) data for the video socket. Declaration VideoQualityOfExperienceData GetQualityOfExperienceData() Returns Type Description VideoQualityOfExperienceData Remarks The bot should fetch the QoE data no more than once every 30 seconds. RequestKeyFrame() Allows the application to request for key frame. Only valid for sockets with the ReceiveColorFormat as H264 Declaration void RequestKeyFrame() Send(VideoMediaBuffer) Sends a frame of video media. Declaration void Send(VideoMediaBuffer buffer) Parameters Type Name Description VideoMediaBuffer buffer VideoMediaBuffer containing the frame of video media to send. Remarks The application must create a concrete class which derives from the VideoMediaBuffer abstract class. The buffer object passed to the Send method is still potentially in-use after the method returns to the caller. The application must not free the buffer's data until the the buffer object's Dispose() method is invoked by the Media Platform. The application should be sending up to 30 video frames per second. The VideoSocket must be enabled to send media via the VideoSocketSettings.StreamDirections property. SetReceiveBandwidthLimit(UInt32) Sets the bandwidth limit on the receive stream of the VideoSocket. This is only supported if the socket supports receiving H264 video format. It is recommended to wait for the VideoReceiveStatusChanged event with MediaReceiveStatus Active state during the initial call setup before applying the receive bandwidth limit on the socket. Bandwidth range (in bits per second) for various resolutions and frame rates per media type: Media type: Video 1000000 - 4000000 1080p at 30 fps 550000 - 2500000 720p at 30 fps 375000 - 1500000 540p at 30 fps 200000 - 800000 360p at 30 fps 150000 - 250000 360p at 15 fps 120000 - 220000 240p at 15 fps 60000 - 200000 180p at 15 fps 20000 - 100000 180p at 7.5 fps 10000 - 25000 180p at 3.75 fps 1000 - 12500 180p at 1.875 fps Media type: Vbss Resolution: 1080p 2000000 - 4000000 at 30 fps 600000 - 3000000 at 15 fps 300000 - 700000 at 7.5 fps 150000 - 350000 at 3.75 fps 70000 - 200000 at 1.875 fps Declaration void SetReceiveBandwidthLimit(uint bitsPerSecond) Parameters Type Name Description UInt32 bitsPerSecond The receive bitrate SetSendBandwidthLimit(UInt32) Sets the bandwidth limit on the send stream of the VideoSocket. This is only supported if the socket supports sending H264 video formats. It is recommended to wait for the VideoSendStatusChanged event with MediaSendStatus Active state during the initial call setup before applying the send bandwidth limit on the socket. Bandwidth range (in bits per second) for various resolutions and frame rates per media type: Media type: Video 1000000 - 4000000 1080p at 30 fps 550000 - 2500000 720p at 30 fps 375000 - 1500000 540p at 30 fps 200000 - 800000 360p at 30 fps 150000 - 250000 360p at 15 fps 120000 - 220000 240p at 15 fps 60000 - 200000 180p at 15 fps 20000 - 100000 180p at 7.5 fps 10000 - 25000 180p at 3.75 fps 1000 - 12500 180p at 1.875 fps Media type: Vbss Resolution: 1080p 2000000 - 4000000 at 30 fps 600000 - 3000000 at 15 fps 300000 - 700000 at 7.5 fps 150000 - 350000 at 3.75 fps 70000 - 200000 at 1.875 fps Declaration void SetSendBandwidthLimit(uint bitsPerSecond) Parameters Type Name Description UInt32 bitsPerSecond The send bitrate Subscribe(VideoResolution) Request to receive the video of the peer in a 1:1 call. No need to specify a MediaSourceId. The bot cannot subscribe to a video source unless the VideoReceiveStatusChanged event is raised indicating the VideoSocket's MediaReceiveStatus is Active . Declaration void Subscribe(VideoResolution preferredVideoResolution) Parameters Type Name Description VideoResolution preferredVideoResolution The requested video resolution. The received video frames should have this resolution if the bandwidth constraints and sender capabilities allow, however the bot may receive video frames at a resolution lower than requested. Subscribe(VideoResolution, UInt32) Request to receive the video source of a participant in a meeting or group call. The video source must be identified by its MediaSourceId available from the roster. The bot cannot subscribe to a video source unless the VideoReceiveStatusChanged event is raised indicating the VideoSocket's MediaReceiveStatus is Active . Declaration void Subscribe(VideoResolution preferredVideoResolution, uint MediaSourceId) Parameters Type Name Description VideoResolution preferredVideoResolution The requested video resolution. The received video frames should have this resolution if the bandwidth constraints and sender capabilities allow, however the bot may receive video frames at a resolution lower than requested. UInt32 MediaSourceId Media source identifier of the video source to be received Exceptions Type Condition ObjectDisposedException Thrown if the VideoSocket is disposed. InvalidOperationException Thrown if the subscription is invalid. SkypeMediaException Thrown if an internal media failure occurs. Unsubscribe() Stops the current video subscription on the VideoSocket. The VideoMediaReceived events will stop raising video buffers. Declaration void Unsubscribe() UpdateVideoSendCapability(VideoSendCapability) Updates the send capabilities (such as SupportedSendVideoFormats or MaxConcurrentSendStreams) of the video socket, allowing the bot to add and remove video formats mid-call. Declaration void UpdateVideoSendCapability(VideoSendCapability capability) Parameters Type Name Description VideoSendCapability capability Events MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > Remarks Note: this event can be raised even if there is no active video subscription; i.e., the VideoSocket is \"idle\" and not receiving media. MediaStreamQualityChanged The event is raised if a media stream quality change was detected Declaration event EventHandler MediaStreamQualityChanged Event Type Type Description EventHandler < VideoMediaStreamQualityChangedEventArgs > VideoKeyFrameNeeded If the application has configured the VideoSocket to receive encoded media, this event is raised each time a key frame is needed. Events are serialized, so only one event at a time is raised to the app. Declaration event EventHandler VideoKeyFrameNeeded Event Type Type Description EventHandler < VideoKeyFrameNeededEventArgs > VideoMediaReceived If the application has configured the VideoSocket to receive media, this event is raised each time a frame of video media is received. Once the application has consumed the buffer, it must call the buffer's Dispose() method. Declaration event EventHandler VideoMediaReceived Event Type Type Description EventHandler < VideoMediaReceivedEventArgs > Remarks The incoming video frame rate is variable. The frame rate can vary between 1.875 frames per second (fps) up to 30 fps. The application must be able to receive up to 30 video buffers per second. Events are serialized, so only one event at a time is raised to the app. The event handler should return as quickly as possible; any time-consuming per-frame processing should be performed asynchronously from the event handler. VideoReceiveStatusChanged If the application has configured the VideoSocket to receive media, this event is raised to inform the application when it is ready to receive media. When the status is active the application can subscribe to a video source, when inactive video subscription won't be allowed Declaration event EventHandler VideoReceiveStatusChanged Event Type Type Description EventHandler < VideoReceiveStatusChangedEventArgs > VideoSendStatusChanged If the application has configured the VideoSocket to send media, this event is raised to inform the application when it may begin sending media and when it should stop. The application cannot send media before receiving a VideoMediaSendStatusChanged event indicating the SendStatus is Active, such media will be discarded. Declaration event EventHandler VideoSendStatusChanged Event Type Type Description EventHandler < VideoSendStatusChangedEventArgs >" + "common/Microsoft.Graph.Communications.Common.OData.ODataJsonConverter.html": { + "href": "common/Microsoft.Graph.Communications.Common.OData.ODataJsonConverter.html", + "title": "Class ODataJsonConverter", + "keywords": "Class ODataJsonConverter Handles resolving interfaces to the correct derived class during serialization/deserialization. Inheritance Object ODataJsonConverter Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class ODataJsonConverter : JsonConverter Constructors ODataJsonConverter(Assembly[]) Initializes a new instance of the ODataJsonConverter class. Declaration public ODataJsonConverter(params Assembly[] typeAssemblies) Parameters Type Name Description Assembly [] typeAssemblies The type assemblies. Properties CanWrite Declaration public override bool CanWrite { get; } Property Value Type Description Boolean Methods CanConvert(Type) Declaration public override bool CanConvert(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Boolean ReadJson(JsonReader, Type, Object, JsonSerializer) Deserializes the object to the correct type. Declaration public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonReader reader The Newtonsoft.Json.JsonReader to read from. Type objectType The interface type. Object existingValue The existing value of the object being read. Newtonsoft.Json.JsonSerializer serializer The Newtonsoft.Json.JsonSerializer for deserialization. Returns Type Description Object The deserialized object WriteJson(JsonWriter, Object, JsonSerializer) Declaration public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonWriter writer Object value Newtonsoft.Json.JsonSerializer serializer Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformHealthChangedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformHealthChangedEventArgs.html", - "title": "Class MediaPlatformHealthChangedEventArgs", - "keywords": "Class MediaPlatformHealthChangedEventArgs Event arguments of the MediaPlatformHealthChangedEvent providing the current and previous health status of the media platform. Inheritance Object EventArgs MediaPlatformHealthChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class MediaPlatformHealthChangedEventArgs : EventArgs Constructors MediaPlatformHealthChangedEventArgs() Declaration public MediaPlatformHealthChangedEventArgs() Properties CurrentHealth The current health status. Declaration public MediaPlatformHealthStatus CurrentHealth { get; set; } Property Value Type Description MediaPlatformHealthStatus PreviousHealth The previous health status. Declaration public MediaPlatformHealthStatus PreviousHealth { get; set; } Property Value Type Description MediaPlatformHealthStatus" + "common/Microsoft.Graph.Communications.Common.OData.ODataResolver.html": { + "href": "common/Microsoft.Graph.Communications.Common.OData.ODataResolver.html", + "title": "Class ODataResolver", + "keywords": "Class ODataResolver Contract resolver that allows us to create OData json payloads with type information. Inheritance Object ODataResolver GraphObfuscationContractResolver Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ODataResolver : CamelCasePropertyNamesContractResolver Constructors ODataResolver(Boolean, Assembly[]) Initializes a new instance of the ODataResolver class which can be used to serialize/deserialize classes present in typeAssemblies . Declaration public ODataResolver(bool addOdataType, params Assembly[] typeAssemblies) Parameters Type Name Description Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. Assembly [] typeAssemblies Assemblies in which the OData object exist. Methods CreateProperties(Type, MemberSerialization) Declaration protected override IList CreateProperties(Type type, MemberSerialization memberSerialization) Parameters Type Name Description Type type Newtonsoft.Json.MemberSerialization memberSerialization Returns Type Description IList < Newtonsoft.Json.Serialization.JsonProperty > ResolveContractConverter(Type) Declaration protected override JsonConverter ResolveContractConverter(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Newtonsoft.Json.JsonConverter Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.MediaQualityState.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaQualityState.html", - "title": "Enum MediaQualityState", - "keywords": "Enum MediaQualityState Indicates the media quality state Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaQualityState Fields Name Description Detected Detected Recovered Recovered" + "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLoggerShim.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLoggerShim.html", + "title": "Class GraphLoggerShim", + "keywords": "Class GraphLoggerShim The graph logger shim. This wrapper on the IGraphLogger attaches some extra data to each log request. Inheritance Object ObjectRoot GraphLoggerShim Implements IGraphLogger IObservable < LogEvent > Inherited Members ObjectRoot.GraphLogger Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphLoggerShim : ObjectRoot, IGraphLogger, IObservable Constructors GraphLoggerShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) Initializes a new instance of the GraphLoggerShim class. Declaration public GraphLoggerShim(IGraphLogger graphLogger, string component = null, Guid? correlationId = default(Guid? ), IEnumerable properties = null, ObfuscationConfiguration obfuscationConfiguration = null) Parameters Type Name Description IGraphLogger graphLogger The graph logger. String component The component. Nullable < Guid > correlationId The correlation identifier. If null, shim will use the correlationId from GraphLogger IEnumerable < Object > properties The properties. ObfuscationConfiguration obfuscationConfiguration The obfuscation configuration. Properties CorrelationId Gets or sets the correlation identifier. This is used to track correlation between multiple requests for one scenario. Declaration public Guid CorrelationId { get; set; } Property Value Type Description Guid DiagnosticLevel Gets or sets the diagnostic level for the logger. Declaration public TraceLevel DiagnosticLevel { get; set; } Property Value Type Description TraceLevel LogicalThreadId Gets or sets the logical thread identifier. This id is used for tracking the flow of one request throughout the lifetime until it ends. Declaration public uint LogicalThreadId { get; set; } Property Value Type Description UInt32 ObfuscationConfiguration Gets the obfuscation configuration. This is used to obfuscate PII and other data. Declaration public ObfuscationConfiguration ObfuscationConfiguration { get; } Property Value Type Description ObfuscationConfiguration Properties Gets the properties of the logger. Declaration public IReadOnlyDictionary Properties { get; } Property Value Type Description IReadOnlyDictionary < Type , Object > Methods Log(TraceLevel, String, String, Guid, Guid, LogEventType, IEnumerable, String, String, Int32) Log messages classified as the provided trace level. Declaration public LogEvent Log(TraceLevel level, string message, string component = null, Guid correlationId = default(Guid), Guid requestId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The trace level. String message A composite format string that includes one or more format items. String component The component in which log is created Guid correlationId The correlation identifier. Guid requestId The request identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Subscribe(IObserver) Declaration public IDisposable Subscribe(IObserver observer) Parameters Type Name Description IObserver < LogEvent > observer Returns Type Description IDisposable Implements IGraphLogger System.IObservable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.CreateObserver(IObservable, Action, Action, Action) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) LoggingExtensions.Log(IGraphLogger, TraceLevel, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Info(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Verbose(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.LogHttpMessage(IGraphLogger, TraceLevel, TransactionDirection, HttpTraceType, String, String, String, IEnumerable>>, Int32, String, Nullable, Guid, Guid, String, String, Int32) LoggingExtensions.Metric(IGraphLogger, String, String, Int64, Dictionary, Boolean, String, Guid, String, String, Int32) LoggingExtensions.SerializeAndObfuscate(IGraphLogger, Object, Formatting) LoggingExtensions.Obfuscate(IGraphLogger, Object, ObfuscationTag) LoggingExtensions.GetHeaderText(IGraphLogger, IEnumerable>>) LoggingExtensions.CreateShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) LoggingExtensions.CreateILogger(IGraphLogger, String, Guid, LogEventType, IEnumerable) LoggingExtensions.EnterMethod(IGraphLogger, Guid, String, String, Int32) LoggingExtensions.LeaveMethod(IGraphLogger, Guid, String, String, Int32) See Also ObjectRoot IGraphLogger" }, - "bot_media/Microsoft.Skype.Bots.Media.PerfCounterConfiguration.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.PerfCounterConfiguration.html", - "title": "Class PerfCounterConfiguration", - "keywords": "Class PerfCounterConfiguration Perf counter configuration Inheritance Object PerfCounterConfiguration Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class PerfCounterConfiguration Constructors PerfCounterConfiguration() Constructor Declaration public PerfCounterConfiguration() Properties UseMPAzureAppHostPerfCounterProvider If set to true, will use MPAzureAppHost's default perf counter provider which uses the registered win32 perf counters Otherwise, will use the in-memory MPPerfCounterProvider that doesn't load win32 perf counters Declaration public bool UseMPAzureAppHostPerfCounterProvider { get; set; } Property Value Type Description Boolean VerifyPerfCounterConfiguration Default is true If set to false, will not verify the perf counter configuration of the bot (MediaPerf.dll and/or MP perf counters) Declaration public bool VerifyPerfCounterConfiguration { get; set; } Property Value Type Description Boolean Methods IsValidConfiguration(PerfCounterConfiguration) Checks if the config is valid Declaration public static bool IsValidConfiguration(PerfCounterConfiguration perfConfig) Parameters Type Name Description PerfCounterConfiguration perfConfig Returns Type Description Boolean ToString() ToString override Declaration public override string ToString() Returns Type Description String Overrides Object.ToString()" + "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLoggerWrapper.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLoggerWrapper.html", + "title": "Class GraphLoggerWrapper", + "keywords": "Class GraphLoggerWrapper The ILogger wrapper for IGraphLogger. Inheritance Object GraphLoggerWrapper Implements ILogger Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphLoggerWrapper : ILogger Constructors GraphLoggerWrapper(IGraphLogger, String, Guid, LogEventType, IEnumerable) Initializes a new instance of the GraphLoggerWrapper class. Declaration public GraphLoggerWrapper(IGraphLogger graphLogger, string component = null, Guid correlationId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null) Parameters Type Name Description IGraphLogger graphLogger Graph logger instance String component The component in which log is created Guid correlationId The correlation identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event Methods BeginScope(TState) Declaration public IDisposable BeginScope(TState state) Parameters Type Name Description TState state Returns Type Description IDisposable Type Parameters Name Description TState IsEnabled(LogLevel) Declaration public bool IsEnabled(LogLevel logLevel) Parameters Type Name Description LogLevel logLevel Returns Type Description Boolean Log(LogLevel, EventId, TState, Exception, Func) Declaration public void Log(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func formatter) Parameters Type Name Description LogLevel logLevel EventId eventId TState state Exception exception Func formatter Type Parameters Name Description TState Implements Microsoft.Extensions.Logging.ILogger Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.ToneReceivedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.ToneReceivedEventArgs.html", - "title": "Class ToneReceivedEventArgs", - "keywords": "Class ToneReceivedEventArgs Event arguments of the ToneReceived event. Inheritance Object EventArgs ToneReceivedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class ToneReceivedEventArgs : EventArgs Constructors ToneReceivedEventArgs() Declaration public ToneReceivedEventArgs() Properties Tone Tone id Declaration public ToneId Tone { get; set; } Property Value Type Description ToneId" + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.BaseFilter-2.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.BaseFilter-2.html", + "title": "Class BaseFilter", + "keywords": "Class BaseFilter Base filter. Inheritance Object BaseFilter BaseFilter ContentDispositionFilter ContentTypeFilter HeaderFilter UriFilter Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public abstract class BaseFilter : BaseFilter Type Parameters Name Description T1 Type of input for the filter. T2 Return value for the evaluator. Constructors BaseFilter() Declaration protected BaseFilter() Properties MatchableString Gets or sets the string for which this filter is a match. Declaration public T2 MatchableString { get; protected set; } Property Value Type Description T2 MatchEvaluator Gets or sets the match evaluator that converts the input value to target value. Declaration public Func MatchEvaluator { get; protected set; } Property Value Type Description Func Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.MathUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.MathUtils.html", - "title": "Class MathUtils", - "keywords": "Class MathUtils Various math utilities Inheritance Object MathUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class MathUtils Methods CeilingRound(Int32, Int32) Gets the ceiling value after rounding. Declaration public static int CeilingRound(this int n, int round) Parameters Type Name Description Int32 n Value to round up. Int32 round Rounding increment. Returns Type Description Int32 Ceiling value." + "client/Microsoft.Graph.Communications.Resources.IResourceCollection-2.html": { + "href": "client/Microsoft.Graph.Communications.Resources.IResourceCollection-2.html", + "title": "Interface IResourceCollection", + "keywords": "Interface IResourceCollection The resource collection interface. Inherited Members IResourceCollection.TerminateAsync(TimeSpan) IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResourceCollection : IResourceCollection, IResourceBase, IDisposable, IReadOnlyCollection, IEnumerable, IEnumerable where TResource : IResource where TEntity : Entity Type Parameters Name Description TResource The containing resource type. IResource TEntity The containing resource type. Entity Properties Item[String] The resource with the specified identifier. Declaration TResource this[string id] { get; } Parameters Type Name Description String id The identifier. Property Value Type Description TResource The IResource . Methods TryForceRemove(String, out TResource) Attempts to remove and return the value that has the specified id from the IResourceCollection . This will force remove the object, if for whatever reason it cannot be removed by the service. It should only be used as a last resort to clean up stale resources. Declaration bool TryForceRemove(string id, out TResource resource) Parameters Type Name Description String id The identifier. TResource resource The resource. Returns Type Description Boolean true if the object was removed successfully; otherwise, false. See Also IResourceCollection IReadOnlyCollection " }, - "common/Microsoft.Graph.Communications.Common.MetricUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.MetricUtils.html", - "title": "Class MetricUtils", - "keywords": "Class MetricUtils The metric utils class Inheritance Object MetricUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class MetricUtils Methods MeasureDurationAsync(Func, Action) Mesure the duration of task. Declaration public static Task MeasureDurationAsync(Func task, Action setMetricTask) Parameters Type Name Description Func < Task > task The task to measure Action < Int64 > setMetricTask The task to set metric Returns Type Description Task The task for wait" + "client/Microsoft.Graph.Communications.Resources.IResourceCollection-3.html": { + "href": "client/Microsoft.Graph.Communications.Resources.IResourceCollection-3.html", + "title": "Interface IResourceCollection", + "keywords": "Interface IResourceCollection The resource collection interface. Inherited Members IResourceCollection.TryForceRemove(String, TResource) IResourceCollection.Item[String] IResourceCollection.TerminateAsync(TimeSpan) IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResourceCollection : IResourceCollection, IResourceCollection, IResourceBase, IDisposable, IReadOnlyCollection, IEnumerable, IEnumerable where TSelf : IResourceCollection where TResource : IResource where TEntity : Entity Type Parameters Name Description TSelf The self type of the collection. TResource The containing resource type. IResource TEntity The containing resource type. Entity Events OnUpdated Event triggered whenever a resource is updated from the collection. Declaration event CollectionEventHandler OnUpdated Event Type Type Description CollectionEventHandler See Also IResourceCollection " }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.GraphUriFilters.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.GraphUriFilters.html", - "title": "Class GraphUriFilters", - "keywords": "Class GraphUriFilters Uri filters to filter PII in graph urls. Inheritance Object GraphUriFilters Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphUriFilters Constructors GraphUriFilters() Declaration public GraphUriFilters() Properties ChatUriFilters Gets the chat URI filters. Declaration public static List ChatUriFilters { get; } Property Value Type Description List < UriFilter > Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "client/Microsoft.Graph.Communications.Resources.IResourceCollection.html": { + "href": "client/Microsoft.Graph.Communications.Resources.IResourceCollection.html", + "title": "Interface IResourceCollection", + "keywords": "Interface IResourceCollection The resource collection interface. Inherited Members IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResourceCollection : IResourceBase, IDisposable Methods TerminateAsync(TimeSpan) Performs collection specific terminate tasks. Declaration Task TerminateAsync(TimeSpan timeout = default(TimeSpan)) Parameters Type Name Description TimeSpan timeout The timeout. Returns Type Description Task < Boolean > True if all instances terminated successfully, false otherwise. See Also IResourceBase" }, - "bot_media/Microsoft.Skype.Bots.Media.LogLevel.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.LogLevel.html", - "title": "Enum LogLevel", - "keywords": "Enum LogLevel Specifies a current logging level for a log line. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum LogLevel Fields Name Description Error Error Log Level Information Information Log Level Verbose Verbose Log Level Warning Warning Log Level" + "common/Microsoft.Graph.Communications.Common.Telemetry.JsonConverters.TypedPropertiesConverter.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.JsonConverters.TypedPropertiesConverter.html", + "title": "Class JsonConverters.TypedPropertiesConverter", + "keywords": "Class JsonConverters.TypedPropertiesConverter The json converter for Type. Inheritance Object JsonConverters.TypedPropertiesConverter Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class TypedPropertiesConverter : JsonConverter Constructors TypedPropertiesConverter() Declaration public TypedPropertiesConverter() Properties CanRead Declaration public override bool CanRead { get; } Property Value Type Description Boolean Methods CanConvert(Type) Declaration public override bool CanConvert(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Boolean ReadJson(JsonReader, Type, Object, JsonSerializer) Declaration public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonReader reader Type objectType Object existingValue Newtonsoft.Json.JsonSerializer serializer Returns Type Description Object WriteJson(JsonWriter, Object, JsonSerializer) Declaration public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonWriter writer Object value Newtonsoft.Json.JsonSerializer serializer Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformInstanceSettings.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformInstanceSettings.html", - "title": "Class MediaPlatformInstanceSettings", - "keywords": "Class MediaPlatformInstanceSettings Class that stores the settings of the Azure instance hosting the Bot Media Platform. Inheritance Object MediaPlatformInstanceSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class MediaPlatformInstanceSettings Constructors MediaPlatformInstanceSettings() Declaration public MediaPlatformInstanceSettings() Properties CertificateThumbprint Thumbprint of a local server certificate to support MTLS authentication of the Media Platform with the Microsoft Skype/Teams calling services. Declaration public string CertificateThumbprint { get; set; } Property Value Type Description String InstanceInternalPort Provides Instance InputEndpoint internal port. Declaration public int InstanceInternalPort { get; set; } Property Value Type Description Int32 InstancePublicIPAddress Provides Instance-Level Public IP address. Declaration public IPAddress InstancePublicIPAddress { get; set; } Property Value Type Description IPAddress InstancePublicPort Provides Instance InputEndpoint public port. Declaration public int InstancePublicPort { get; set; } Property Value Type Description Int32 MediaPortRange The media port range to be allocated for bot calls. Specifying media ports is optional. Declaration public PortRange MediaPortRange { get; set; } Property Value Type Description PortRange ServiceFqdn The FQDN of the Azure service hosting the Media Platform. Declaration public string ServiceFqdn { get; set; } Property Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Transport.GraphRequest-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphRequest-1.html", + "title": "Class GraphRequest", + "keywords": "Class GraphRequest The base of the exchange of a IGraphRequest or IGraphResponse . Inheritance Object GraphRequest GraphRequest Implements IGraphRequest IGraphExchange IGraphExchange Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphRequest : IGraphRequest, IGraphExchange, IGraphExchange Type Parameters Name Description T Constructors GraphRequest(Uri, T, RequestType) Initializes a new instance of the GraphRequest class. Create the graph request object Declaration public GraphRequest(Uri location, T content, RequestType requestType) Parameters Type Name Description Uri location The uri location for the request. T content Content to be sent as part of the request. RequestType requestType Type of the request. Properties Content Declaration public T Content { get; set; } Property Value Type Description T Properties Gets the properties of the exchange. Declaration public ICollection Properties { get; } Property Value Type Description ICollection < IGraphProperty > RequestType Declaration public RequestType RequestType { get; } Property Value Type Description RequestType Uri Declaration public Uri Uri { get; } Property Value Type Description Uri Methods ToString() Declaration public override string ToString() Returns Type Description String Overrides Object.ToString() Implements IGraphRequest IGraphExchange IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphRequestExtensions.ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable)" }, - "bot_media/Microsoft.Skype.Bots.Media.MediaStreamFailureEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaStreamFailureEventArgs.html", - "title": "Class MediaStreamFailureEventArgs", - "keywords": "Class MediaStreamFailureEventArgs Event arguments of the MediaStreamFailure event. Inheritance Object EventArgs MediaStreamFailureEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class MediaStreamFailureEventArgs : EventArgs Constructors MediaStreamFailureEventArgs() Declaration public MediaStreamFailureEventArgs()" + "common/Microsoft.Graph.Communications.Common.Utilities.html": { + "href": "common/Microsoft.Graph.Communications.Common.Utilities.html", + "title": "Class Utilities", + "keywords": "Class Utilities Utilities class. Inheritance Object Utilities Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class Utilities Methods CombineHashCodes(Object[]) Combine several hash codes into a single hash code Declaration public static int CombineHashCodes(params object[] args) Parameters Type Name Description Object [] args Objects to combine into a single hash. Returns Type Description Int32 Combined hash code. DecodeReplacesContextFromBase64(String) Decodes the replaces context for consultative call transfer scenario. Declaration public static Uri DecodeReplacesContextFromBase64(this string replacesContext) Parameters Type Name Description String replacesContext The replaces context. Returns Type Description Uri The decoded replaces URI. Exceptions Type Condition InvalidOperationException Replaces context provided for consultative transfer is invalid. EncodeReplacesUriToBase64(Uri) Base64 Encodes the replaces URI for consultative call transfer scenario. Declaration public static string EncodeReplacesUriToBase64(this Uri replacesUri) Parameters Type Name Description Uri replacesUri The replaces URI. Returns Type Description String The encoded replaces context. SafeDispose(ref T, IGraphLogger) Safely dispose members. Declaration public static void SafeDispose(ref T t, IGraphLogger logger = null) where T : class, IDisposable Parameters Type Name Description T t Reference to member. IGraphLogger logger Logger instance. Type Parameters Name Description T Type of the member." }, - "bot_media/Microsoft.Skype.Bots.Media.StreamDirection.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.StreamDirection.html", - "title": "Enum StreamDirection", - "keywords": "Enum StreamDirection Stream directionality, from the point-of-view of the local media endpoint. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum StreamDirection Fields Name Description Inactive Media cannot be sent nor received Recvonly Media can be received but not sent Sendonly Media can be sent but not received Sendrecv Media can be sent and received" + "common/Microsoft.Graph.Communications.Common.Validator.html": { + "href": "common/Microsoft.Graph.Communications.Common.Validator.html", + "title": "Class Validator", + "keywords": "Class Validator Helper class with various condition validation utilities. Inheritance Object Validator Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class Validator Methods Any(IEnumerable) Determines whether a sequence contains any elements. Declaration public static bool Any(this IEnumerable source) Parameters Type Name Description IEnumerable source The IEnumerable to check for emptiness. Returns Type Description Boolean true if the source sequence contains any elements; otherwise, false . Equals(T, T, IComparer, String, String) Throw if value > is not equal to expected Declaration public static T Equals(T value, T expected, IComparer comparer, string paramName = null, string message = null) Parameters Type Name Description T value value T expected expected IComparer comparer comparer String paramName paramName String message Optional message. Returns Type Description T The input value if validation succeeded. Type Parameters Name Description T Type of the input value Exceptions Type Condition ArgumentException The argument value should match the expected value. Equals(T, T, String, String) Throw if value > is not equal to expected Declaration public static T Equals(this T value, T expected, string paramName = null, string message = null) Parameters Type Name Description T value value T expected expected String paramName paramName String message Optional message. Returns Type Description T The input value if validation succeeded. Type Parameters Name Description T Type of the input value Exceptions Type Condition ArgumentException The argument value should match the expected value. Equals(T, T, String) Throws the TE if value > is not equal to expected Declaration public static T Equals(this T value, T expected, string message = null) where TE : Exception Parameters Type Name Description T value value T expected expected String message Optional message. Returns Type Description T The input value if validation succeeded. Type Parameters Name Description T Type of the input value TE The type of Exception to throw FirstObject(IEnumerable) Gets the first object in the enumerable. Declaration public static object FirstObject(this IEnumerable source) Parameters Type Name Description IEnumerable source The IEnumerable to check for object. Returns Type Description Object langword_csharp_object if the source sequence contains an element; otherwise, null . FirstObject(IEnumerable, Func) Gets the first object in the enumerable that matches the specified predicate. Declaration public static object FirstObject(this IEnumerable source, Func predicate) Parameters Type Name Description IEnumerable source The IEnumerable to check for object. Func < Object , Boolean > predicate The Func used to match the object. Returns Type Description Object langword_csharp_object if the source sequence contains the matching element; otherwise, null . InRange(T, T, T, String) Throws ArgumentOutOfRangeException if value is not in the given range defined by minValue and maxValue Declaration public static void InRange(this T value, T minValue, T maxValue, string paramName = null) where T : IComparable Parameters Type Name Description T value value to verify T minValue Minimum range value T maxValue Maximum range value String paramName Variable name. Type Parameters Name Description T Comparable Exceptions Type Condition ArgumentOutOfRangeException If the value is out of range. IsEnum(Type) Throws the ArgumentException if given type is not Enum Declaration public static void IsEnum(this Type type) Parameters Type Name Description Type type The type IsFalse(Boolean, String, String) Throw ArgumentException condition is not false Declaration public static void IsFalse(this bool condition, string paramName = null, string message = null) Parameters Type Name Description Boolean condition Condition to check. String paramName Optional variable name. String message Optional message. IsFalse(Boolean, String) Throw T exception if condition is not false Declaration public static void IsFalse(this bool condition, string message = null) where T : Exception Parameters Type Name Description Boolean condition Condition to check. String message Optional message. Type Parameters Name Description T Exception type to raise IsNull(Object, String, String) Throw ArgumentException if obj is not null. Declaration public static void IsNull(this object obj, string paramName = null, string message = null) Parameters Type Name Description Object obj The object to check. String paramName Optional variable name. String message Optional message. IsTrue(Boolean, String, String) Throw ArgumentException condition is not true Declaration public static void IsTrue(this bool condition, string paramName = null, string message = null) Parameters Type Name Description Boolean condition Condition to check. String paramName Optional variable name. String message Optional message. IsTrue(Boolean, String) Throw T exception if condition is not true Declaration public static void IsTrue(this bool condition, string message = null) where T : Exception Parameters Type Name Description Boolean condition Condition to check. String message Optional message. Type Parameters Name Description T Exception type to raise NotEmpty(T, String, String) Throw ArgumentNullException if obj is null. Declaration public static T NotEmpty(this T obj, string paramName = null, string message = null) where T : IEnumerable Parameters Type Name Description T obj The object to check. String paramName Variable name. String message Optional message. Returns Type Description T The validated IEnumerable . Type Parameters Name Description T Enumerable type Exceptions Type Condition ArgumentNullException If the object is null. ArgumentException If the object is empty. NotEquals(T, T, String, String) Throw if value > is equal to unexpected Declaration public static T NotEquals(this T value, T unexpected, string paramName = null, string message = null) Parameters Type Name Description T value The value to compare. T unexpected The unexpected value. String paramName the parameter name. String message Optional message. Returns Type Description T The input value if validation succeeded. Type Parameters Name Description T Type of the input value Exceptions Type Condition ArgumentException The argument value should not match the expected value. NotNull(T, String, String) Throw ArgumentNullException if obj is null. Declaration public static T NotNull(this T obj, string paramName = null, string message = null) Parameters Type Name Description T obj The object. String paramName Name of the parameter. String message The message. Returns Type Description T The validated object. Type Parameters Name Description T The type of the object to validate. Exceptions Type Condition ArgumentException If the object is null. NotNullOrWhitespace(String, String, String) Throws the ArgumentException if string is null or whitespace. Declaration public static string NotNullOrWhitespace(this string value, string paramName = null, string message = null) Parameters Type Name Description String value value to check String paramName Variable name. String message Optional message. Returns Type Description String The validated String . Exceptions Type Condition ArgumentException If the string is null or whitespace. VerifyContains(IEnumerable, T) Throws the ArgumentException if collection does not contains the specified value Declaration public static void VerifyContains(this IEnumerable enumerable, T value) Parameters Type Name Description IEnumerable enumerable The enumerable. T value The value. Type Parameters Name Description T Type of value VerifyContainsKey(IDictionary, TK) Throws the ArgumentException if collection does not contain the specified key Declaration public static void VerifyContainsKey(this IDictionary dictionary, TK key) Parameters Type Name Description IDictionary dictionary The dictionary. TK key The key. Type Parameters Name Description TK Key type TV Value type VerifyContainsKey(IReadOnlyDictionary, TK) Throws the ArgumentException if collection does not contain the specified key Declaration public static void VerifyContainsKey(this IReadOnlyDictionary dictionary, TK key) Parameters Type Name Description IReadOnlyDictionary dictionary The dictionary. TK key The key. Type Parameters Name Description TK Key type TV Value type VerifyNotContainsKey(IDictionary, TK) Throws the ArgumentException if collection contains the specified key Declaration public static void VerifyNotContainsKey(this IDictionary dictionary, TK key) Parameters Type Name Description IDictionary dictionary The dictionary. TK key The key. Type Parameters Name Description TK Key type TV Value type" }, - "common/Microsoft.Graph.Communications.Common.HttpConstants.html": { - "href": "common/Microsoft.Graph.Communications.Common.HttpConstants.html", - "title": "Class HttpConstants", - "keywords": "Class HttpConstants The constant values for http. Inheritance Object HttpConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpConstants Fields GraphV1Prefixes Expected values of x-ms-gateway-serviceRoot header in the requests coming in to PMA from GraphV1 endpoints Declaration public static readonly IEnumerable GraphV1Prefixes Field Value Type Description IEnumerable < String >" + "common/Microsoft.Graph.Communications.Common.WeakKey-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.WeakKey-1.html", + "title": "Class WeakKey", + "keywords": "Class WeakKey Wrapping a weak reference and recording hash code. Note: It is the responsibility of the client to clean up the collection entry in the finalizer of the object. Otherwise the key will not match for subsequent lookups. Inheritance Object WeakKey Inherited Members Object.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class WeakKey where T : class Type Parameters Name Description T Type of the key to be used in a lookup. Constructors WeakKey(T) Initializes a new instance of the WeakKey class. Declaration public WeakKey(T t) Parameters Type Name Description T t Underlying object. WeakKey(WeakReference) Initializes a new instance of the WeakKey class. Declaration public WeakKey(WeakReference weak) Parameters Type Name Description WeakReference weak Underlying object wrapped in weak reference. Properties Unwrapped Gets the target. Declaration public T Unwrapped { get; } Property Value Type Description T Value Gets the weak reference to the underlying object. Declaration public WeakReference Value { get; } Property Value Type Description WeakReference Methods Equals(Object) Determines whether the specified object is equal to the current object. Declaration public override bool Equals(object obj) Parameters Type Name Description Object obj The object to compare with the current object. Returns Type Description Boolean true if the specified object is equal to the current object. Overrides Object.Equals(Object) GetHashCode() Overrides hash code to hand out the underlying object's hash code. Declaration public override int GetHashCode() Returns Type Description Int32 Hash code of underlying object. Overrides Object.GetHashCode() Operators Implicit(T to WeakKey) Implicit cast operator to weak key. Declaration public static implicit operator WeakKey(T t) Parameters Type Name Description T t Wrap with weak key. Returns Type Description WeakKey Implicit(WeakKey to T) Implicit type cast operator. Declaration public static implicit operator T(WeakKey key) Parameters Type Name Description WeakKey key Extract underlying object. Returns Type Description T Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.JsonUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.JsonUtils.html", - "title": "Class JsonUtils", - "keywords": "Class JsonUtils Json Utils Inheritance Object JsonUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class JsonUtils Fields JsonContentType Json content type Declaration public const string JsonContentType = \"application/json\" Field Value Type Description String" + "core/Microsoft.Graph.Communications.Core.Notifications.NotificationProcessor.html": { + "href": "core/Microsoft.Graph.Communications.Core.Notifications.NotificationProcessor.html", + "title": "Class NotificationProcessor", + "keywords": "Class NotificationProcessor The notification processor class. Inheritance Object NotificationProcessor Implements INotificationProcessor IDisposable Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class NotificationProcessor : Disposable, INotificationProcessor, IDisposable Constructors NotificationProcessor(IAuthenticationProvider, ISerializer) Initializes a new instance of the NotificationProcessor class. Declaration public NotificationProcessor(IAuthenticationProvider authenticationProvider, ISerializer serializer) Parameters Type Name Description IAuthenticationProvider authenticationProvider The authentication provider. ISerializer serializer The serializer. Exceptions Type Condition ArgumentNullException If the authentication provider is null. Properties AuthenticationProvider Gets the authentication provider. TODO: This should probably not be a part of the INotificationProcessor . Ideally the request is already validated prior to making it in here. This means that 1) Already sanitized by authentication provider and 2) The tenant/scenario id parameters extracted into the IGraphRequest. Declaration public IAuthenticationProvider AuthenticationProvider { get; } Property Value Type Description IAuthenticationProvider The authentication provider. Methods ExtractNotifications(String, ISerializer) Extracts the notifications from the specified content string. Declaration public static CommsNotifications ExtractNotifications(string content, ISerializer serializer) Parameters Type Name Description String content The content. ISerializer serializer The serializer. Returns Type Description CommsNotifications The deserialized CommsNotifications . Exceptions Type Condition ServiceException If the specified content is invalid. ProcessNotifications(Uri, String, String, Guid, Guid, IEnumerable>) Processes the notifications and raise the required callbacks. This function should be called in order for the SDK to raise any required events and process state changes. Declaration public void ProcessNotifications(Uri callbackUri, string content, string tenantId, Guid requestId, Guid scenarioId, IEnumerable> additionalData = null) Parameters Type Name Description Uri callbackUri The callback URI. String content The notifications content. String tenantId The tenant identifier. Guid requestId The request identifier. Guid scenarioId The scenario identifier. IEnumerable < KeyValuePair < String , Object >> additionalData Additional data associated with the notification. Events OnCollectionNotificationReceived Occurs when a collection notification is received. Declaration public event Action OnCollectionNotificationReceived Event Type Type Description Action < CollectionNotificationEventArgs > OnNotificationReceived Occurs when a notification is received. This is a global hook for all notifications. Declaration public event Action OnNotificationReceived Event Type Type Description Action < NotificationEventArgs > OnResourceNotificationReceived Occurs when a single resource notification is received. Declaration public event Action OnResourceNotificationReceived Event Type Type Description Action < NotificationEventArgs > Implements INotificationProcessor System.IDisposable See Also INotificationProcessor" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.TransactionDirection.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.TransactionDirection.html", - "title": "Enum TransactionDirection", - "keywords": "Enum TransactionDirection Direction for request message. Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum TransactionDirection Fields Name Description Incoming The incoming request message. Outgoing The outgoing request message. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(TransactionDirection, String, String) Validator.Equals(TransactionDirection, String) Validator.NotEquals(TransactionDirection, String, String)" + "core/Microsoft.Graph.Communications.Core.Serialization.CommsSerializer.html": { + "href": "core/Microsoft.Graph.Communications.Core.Serialization.CommsSerializer.html", + "title": "Class CommsSerializer", + "keywords": "Class CommsSerializer An interface for serializing and deserializing JSON objects. This serializer is used throughout the Communications workload to provide extra functionality. Specifically it supports more robust serialization/deserialization of @odata.type property and deserialization of open type additional data. Inheritance Object CommsSerializer Implements ISerializer Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Serialization Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class CommsSerializer : ISerializer Constructors CommsSerializer(Boolean) Initializes a new instance of the CommsSerializer class. Declaration public CommsSerializer(bool pretty = false) Parameters Type Name Description Boolean pretty If set to true make the formatting pretty. CommsSerializer(Boolean, Assembly[]) Initializes a new instance of the CommsSerializer class. Declaration public CommsSerializer(bool pretty = false, params Assembly[] assemblies) Parameters Type Name Description Boolean pretty If set to true make the formatting pretty. Assembly [] assemblies The assemblies to use for deserialization. The CommsSerializer searches through the specified assemblies in order specified to find the @odata.type in the json payload. Properties CoreAssemblies Gets the list of core Assembly detected. Declaration public Assembly[] CoreAssemblies { get; } Property Value Type Description Assembly [] JsonSerializerSettings Gets the JSON serializer settings. Declaration public JsonSerializerSettings JsonSerializerSettings { get; } Property Value Type Description Newtonsoft.Json.JsonSerializerSettings Methods DeserializeObject(Stream) Declaration public T DeserializeObject(Stream stream) Parameters Type Name Description Stream stream Returns Type Description T Type Parameters Name Description T DeserializeObject(String) Declaration public T DeserializeObject(string inputString) Parameters Type Name Description String inputString Returns Type Description T Type Parameters Name Description T SerializeObject(Object) Declaration public string SerializeObject(object serializeableObject) Parameters Type Name Description Object serializeableObject Returns Type Description String Implements Microsoft.Graph.ISerializer See Also ISerializer" }, - "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.Messages.html": { - "href": "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.Messages.html", - "title": "Class CommsGeneratedErrorConstants.Messages", - "keywords": "Class CommsGeneratedErrorConstants.Messages The messages. Inheritance Object CommsGeneratedErrorConstants.Messages Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Messages Fields ResponseObjectUsedForUpdate Response object used for update error message. Declaration public const string ResponseObjectUsedForUpdate = \"Do not use objects returned in a response for updating an object in Microsoft Graph. Create a new {0} object and only set the updated properties on it.\" Field Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Telemetry.ClientEtwLogger.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.ClientEtwLogger.html", + "title": "Class ClientEtwLogger", + "keywords": "Class ClientEtwLogger Logger for client that publishes to ETW. Inheritance Object EventSource ClientEtwLogger Implements IDisposable Inherited Members EventSource.IsEnabled() EventSource.IsEnabled(EventLevel, EventKeywords) EventSource.IsEnabled(EventLevel, EventKeywords, EventChannel) EventSource.GetGuid(Type) EventSource.GetName(Type) EventSource.GenerateManifest(Type, String) EventSource.GenerateManifest(Type, String, EventManifestOptions) EventSource.GetSources() EventSource.SendCommand(EventSource, EventCommand, IDictionary) EventSource.SetCurrentThreadActivityId(Guid) EventSource.SetCurrentThreadActivityId(Guid, Guid) EventSource.GetTrait(String) EventSource.ToString() EventSource.OnEventCommand(EventCommandEventArgs) EventSource.WriteEvent(Int32) EventSource.WriteEvent(Int32, Int32) EventSource.WriteEvent(Int32, Int32, Int32) EventSource.WriteEvent(Int32, Int32, Int32, Int32) EventSource.WriteEvent(Int32, Int64) EventSource.WriteEvent(Int32, Int64, Int64) EventSource.WriteEvent(Int32, Int64, Int64, Int64) EventSource.WriteEvent(Int32, String) EventSource.WriteEvent(Int32, String, String) EventSource.WriteEvent(Int32, String, String, String) EventSource.WriteEvent(Int32, String, Int32) EventSource.WriteEvent(Int32, String, Int32, Int32) EventSource.WriteEvent(Int32, String, Int64) EventSource.WriteEvent(Int32, Int64, String) EventSource.WriteEvent(Int32, Int32, String) EventSource.WriteEvent(Int32, Byte[]) EventSource.WriteEvent(Int32, Int64, Byte[]) EventSource.WriteEventCore(Int32, Int32, EventSource.EventData*) EventSource.WriteEventWithRelatedActivityIdCore(Int32, Guid*, Int32, EventSource.EventData*) EventSource.WriteEvent(Int32, Object[]) EventSource.WriteEventWithRelatedActivityId(Int32, Guid, Object[]) EventSource.Dispose() EventSource.Dispose(Boolean) EventSource.Write(String) EventSource.Write(String, EventSourceOptions) EventSource.Write(String, T) EventSource.Write(String, EventSourceOptions, T) EventSource.Write(String, EventSourceOptions, T) EventSource.Write(String, EventSourceOptions, Guid, Guid, T) EventSource.Name EventSource.Guid EventSource.Settings EventSource.CurrentThreadActivityId EventSource.ConstructionException EventSource.EventCommandExecuted Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax [EventSource(Name = \"Microsoft-Graph-Telemetry-Client\")] public class ClientEtwLogger : EventSource, IDisposable Constructors ClientEtwLogger(IGraphLogger) Initializes a new instance of the ClientEtwLogger class. Declaration public ClientEtwLogger(IGraphLogger logger) Parameters Type Name Description IGraphLogger logger The logger. Methods HttpTrace(Guid, String, String, String, String, String, String, String, Int32, String, String, String, String, String, String) Trace for client's http calls. Declaration [Event(100, Level = EventLevel.Informational, Message = \"{5}\")] public void HttpTrace(Guid correlationId, string component, string traceLevel, string url, string transactionDirection, string message, string appName, string appId, int mtid, string callingLine, string traceType, string headers, string method, string responseCode, string responseTime) Parameters Type Name Description Guid correlationId The correlation identifier. String component The component. String traceLevel The trace level. String url The URL for the request. String transactionDirection The direction of the request this request/response corresponds to. String message The body for the request/response. String appName Name of the application. String appId The application identifier. Int32 mtid The managed tid. String callingLine The line in which log is produced. String traceType Denote whether this is request/response. String headers The headers. String method The method for the request. String responseCode The response code from response. String responseTime Time taken to process the request. Trace(Guid, String, String, String, String, String, Int32, String) Trace for client's normal trace calls. Declaration [Event(101, Level = EventLevel.Informational, Message = \"{3}\")] public void Trace(Guid correlationId, string component, string traceLevel, string message, string appName, string appId, int mtid, string callingLine) Parameters Type Name Description Guid correlationId The correlation identifier. String component The component. String traceLevel The trace level. String message The message. String appName Name of the application. String appId The application identifier. Int32 mtid The managed tid. String callingLine The line in which log is produced. Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.ContractsConstants.html": { - "href": "core/Microsoft.Graph.ContractsConstants.html", - "title": "Class ContractsConstants", - "keywords": "Class ContractsConstants OData Model Constants Inheritance Object ContractsConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class ContractsConstants" + "common/Microsoft.Graph.Communications.Common.Telemetry.IGraphLogger.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.IGraphLogger.html", + "title": "Interface IGraphLogger", + "keywords": "Interface IGraphLogger The logger interface used by Graph Services. This logger emits logs that can be observed by different observers. Inherited Members IObservable.Subscribe(IObserver) Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphLogger : IObservable Properties CorrelationId Gets or sets the correlation identifier. This is used to track correlation between multiple requests for one scenario. Declaration Guid CorrelationId { get; set; } Property Value Type Description Guid DiagnosticLevel Gets or sets the diagnostic level for the logger. Declaration TraceLevel DiagnosticLevel { get; set; } Property Value Type Description TraceLevel LogicalThreadId Gets or sets the logical thread identifier. This id is used for tracking the flow of one request throughout the lifetime until it ends. Declaration uint LogicalThreadId { get; set; } Property Value Type Description UInt32 ObfuscationConfiguration Gets the obfuscation configuration. This is used to obfuscate PII and other data. Declaration ObfuscationConfiguration ObfuscationConfiguration { get; } Property Value Type Description ObfuscationConfiguration Properties Gets the properties of the logger. Declaration IReadOnlyDictionary Properties { get; } Property Value Type Description IReadOnlyDictionary < Type , Object > Methods Log(TraceLevel, String, String, Guid, Guid, LogEventType, IEnumerable, String, String, Int32) Log messages classified as the provided trace level. Declaration LogEvent Log(TraceLevel level, string message, string component = null, Guid correlationId = default(Guid), Guid requestId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The trace level. String message A composite format string that includes one or more format items. String component The component in which log is created Guid correlationId The correlation identifier. Guid requestId The request identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.CreateObserver(IObservable, Action, Action, Action) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) LoggingExtensions.Log(IGraphLogger, TraceLevel, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Info(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Verbose(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.LogHttpMessage(IGraphLogger, TraceLevel, TransactionDirection, HttpTraceType, String, String, String, IEnumerable>>, Int32, String, Nullable, Guid, Guid, String, String, Int32) LoggingExtensions.Metric(IGraphLogger, String, String, Int64, Dictionary, Boolean, String, Guid, String, String, Int32) LoggingExtensions.SerializeAndObfuscate(IGraphLogger, Object, Formatting) LoggingExtensions.Obfuscate(IGraphLogger, Object, ObfuscationTag) LoggingExtensions.GetHeaderText(IGraphLogger, IEnumerable>>) LoggingExtensions.CreateShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) LoggingExtensions.CreateILogger(IGraphLogger, String, Guid, LogEventType, IEnumerable) LoggingExtensions.EnterMethod(IGraphLogger, Guid, String, String, Int32) LoggingExtensions.LeaveMethod(IGraphLogger, Guid, String, String, Int32)" }, - "core/Microsoft.Graph.IdentityExtensions.html": { - "href": "core/Microsoft.Graph.IdentityExtensions.html", - "title": "Class IdentityExtensions", - "keywords": "Class IdentityExtensions Extensions for graph api contracts Inheritance Object IdentityExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class IdentityExtensions Methods GetApplicationInstance(IdentitySet) Gets the application instance identity from identity set. This is part of additional data. Declaration public static Identity GetApplicationInstance(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Identity GetEncrypted(IdentitySet) Get the encrypted identity part of the additional data This identity must be retrieved when other identities are not listed Declaration public static Identity GetEncrypted(this IdentitySet identity) Parameters Type Name Description IdentitySet identity The identity Returns Type Description Identity The encrypted identity GetGuest(IdentitySet) Gets the guest identity from identity set. This is part of additional data. Declaration public static Identity GetGuest(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Identity GetIdentityProvider(Identity) Gets the identity provider. Declaration public static string GetIdentityProvider(this Identity identity) Parameters Type Name Description Identity identity The identity. Returns Type Description String The identity provider string. GetOnPremises(IdentitySet) Gets the on-premises identity from identity set. This is part of additional data. Declaration public static Identity GetOnPremises(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Identity GetPhone(IdentitySet) Gets the phone identity from identity set. This is part of additional data. Declaration public static Identity GetPhone(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Identity GetTenantId(Identity) Gets the tenant identifier. Declaration public static string GetTenantId(this Identity identity) Parameters Type Name Description Identity identity The identity. Returns Type Description String The tenant identifier string. SetApplicationInstance(IdentitySet, Identity) Sets the application instance identity in identity set. This is part of additional data. Declaration public static void SetApplicationInstance(this IdentitySet identitySet, Identity identity) Parameters Type Name Description IdentitySet identitySet The identity set. Identity identity The identity. SetEncrypted(IdentitySet, Identity) Sets the encrypted identity to the additional data This identity must be retrieved when other identities are not listed Declaration public static void SetEncrypted(this IdentitySet identitySet, Identity identity) Parameters Type Name Description IdentitySet identitySet The identity set. Identity identity The identity SetGuest(IdentitySet, Identity) Sets the guest identity in identity set. This is part of additional data. Declaration public static void SetGuest(this IdentitySet identitySet, Identity identity) Parameters Type Name Description IdentitySet identitySet The identity set. Identity identity The identity. SetIdentityProvider(Identity, String) Sets the identity provider. Declaration public static void SetIdentityProvider(this Identity identity, string identityProvider) Parameters Type Name Description Identity identity The identity. String identityProvider The identity provider. SetPhone(IdentitySet, Identity) Sets the phone identity in identity set. This is part of additional data. Declaration public static void SetPhone(this IdentitySet identitySet, Identity identity) Parameters Type Name Description IdentitySet identitySet The identity set. Identity identity The identity. SetTenantId(Identity, String) Sets the tenant identifier. Declaration public static void SetTenantId(this Identity identity, string tenantId) Parameters Type Name Description Identity identity The identity. String tenantId The tenant identifier." + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.GraphObfuscationContractResolver.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.GraphObfuscationContractResolver.html", + "title": "Class GraphObfuscationContractResolver", + "keywords": "Class GraphObfuscationContractResolver Newtonsoft JSON resolver that uses Graph Obfuscation attribute to serialize data for logging purposes. Inheritance Object ODataResolver GraphObfuscationContractResolver Inherited Members ODataResolver.ResolveContractConverter(Type) ODataResolver.CreateProperties(Type, MemberSerialization) Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphObfuscationContractResolver : ODataResolver Constructors GraphObfuscationContractResolver(IObfuscationEngine, Boolean, ObfuscationMember[]) Initializes a new instance of the GraphObfuscationContractResolver class. Declaration public GraphObfuscationContractResolver(IObfuscationEngine engine, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IObfuscationEngine engine The obfuscation engine. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified this GraphObfuscationContractResolver will cache the members and check the cache for the ObfuscationTag . Methods CreateMemberValueProvider(MemberInfo) Declaration protected override IValueProvider CreateMemberValueProvider(MemberInfo member) Parameters Type Name Description MemberInfo member Returns Type Description Newtonsoft.Json.Serialization.IValueProvider ResolveContract(Type) Declaration public override JsonContract ResolveContract(Type type) Parameters Type Name Description Type type Returns Type Description Newtonsoft.Json.Serialization.JsonContract Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.IdentitySetExtensions.html": { - "href": "core/Microsoft.Graph.IdentitySetExtensions.html", - "title": "Class IdentitySetExtensions", - "keywords": "Class IdentitySetExtensions Extentions for graph api contracts Inheritance Object IdentitySetExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class IdentitySetExtensions Fields DodAppParticipantPrefix The application participant prefix for dod cloud Declaration public const string DodAppParticipantPrefix = \"28:dod-global:\" Field Value Type Description String DodDirectoryAppParticipantPrefix The directory application participant prefix for dod cloud Declaration public const string DodDirectoryAppParticipantPrefix = \"28:dod:\" Field Value Type Description String DodDirectoryParticipantPrefix The directory participant prefix for DoD cloud Declaration public const string DodDirectoryParticipantPrefix = \"8:dod:\" Field Value Type Description String DodOnPremisesParticipantPrefix The external prefix for DoD cloud Declaration public const string DodOnPremisesParticipantPrefix = \"8:dod-sfb:\" Field Value Type Description String EncryptedParticipantPrefix The encrypted participant prefix Declaration public const string EncryptedParticipantPrefix = \"29:\" Field Value Type Description String GcchAppParticipantPrefix The application participant prefix for gcch cloud Declaration public const string GcchAppParticipantPrefix = \"28:gcch-global:\" Field Value Type Description String GcchDirectoryAppParticipantPrefix The directory application participant prefix for gcch cloud Declaration public const string GcchDirectoryAppParticipantPrefix = \"28:gcch:\" Field Value Type Description String GcchDirectoryParticipantPrefix The directory participant prefix for GCCH cloud Declaration public const string GcchDirectoryParticipantPrefix = \"8:gcch:\" Field Value Type Description String GcchOnPremisesParticipantPrefix The external prefix for GCCH cloud Declaration public const string GcchOnPremisesParticipantPrefix = \"8:gcch-sfb:\" Field Value Type Description String PhoneParticipantPrefix The phone participant prefix Declaration public const string PhoneParticipantPrefix = \"4:\" Field Value Type Description String PublicAppParticipantPrefix The application participant prefix Declaration public const string PublicAppParticipantPrefix = \"28:\" Field Value Type Description String PublicDirectoryAppParticipantPrefix The directory application participant prefix for public cloud Declaration public const string PublicDirectoryAppParticipantPrefix = \"28:orgid:\" Field Value Type Description String PublicDirectoryParticipantPrefix The directory participant prefix for public cloud Declaration public const string PublicDirectoryParticipantPrefix = \"8:orgid:\" Field Value Type Description String PublicOnPremisesParticipantPrefix The external prefix for public cloud Declaration public const string PublicOnPremisesParticipantPrefix = \"8:sfb:\" Field Value Type Description String SkypeParticipantPrefix The skype participant prefix Declaration public const string SkypeParticipantPrefix = \"8:\" Field Value Type Description String TeamsVisitorParticipantPrefix The teams visitor participant prefix For anonymous users we need to support 8:teamsvisitor:objectId Declaration public const string TeamsVisitorParticipantPrefix = \"8:teamsvisitor:\" Field Value Type Description String Methods CreateIdentitySetByMri(String, String, String) Creates participant from MRI if possible. For chat service thread mris we return null Declaration public static IdentitySet CreateIdentitySetByMri(string mri, string tenantId, string displayName) Parameters Type Name Description String mri Participant MRI String tenantId The tenant identifier. String displayName The display name. Returns Type Description IdentitySet Created identity set Exceptions Type Condition ArgumentOutOfRangeException mri GetAppParticipantPrefix(CloudNamespace) Gets app participant prefix for the provided CloudNamespace . Declaration public static string GetAppParticipantPrefix(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace The cloud where the app participant belongs Returns Type Description String Prefix to be used to construct the MRI GetDirectoryAppParticipantEnv(CloudNamespace) Returns the env differentiator part of the app participant prefix corresponding to cloudNamespace . This differentiator doesn't have participant prefix (8:, 4:, 28: or 29:) in it. Declaration public static string GetDirectoryAppParticipantEnv(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace Cloud environment where the identity set belongs Returns Type Description String Env differentiator part of the app participant prefix corresponding to cloudNamespace GetDirectoryAppParticipantPrefix(CloudNamespace) Gets directory app participant prefix for the provided CloudNamespace . Declaration public static string GetDirectoryAppParticipantPrefix(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace The cloud where the directory app participant belongs Returns Type Description String Prefix to be used to construct the MRI GetDirectoryParticipantPrefix(CloudNamespace) Gets a user prefix for the provided CloudNamespace . Declaration public static string GetDirectoryParticipantPrefix(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace The cloud where the user belongs Returns Type Description String Prefix to be used to construct the MRI GetEnumerator(IdentitySet) Enumerates through all the Identity objects found in this IdentitySet Declaration public static IEnumerable> GetEnumerator(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description IEnumerable < KeyValuePair < String , Identity >> The IEnumerable{KeyValuePair{string, Identity}} for the specified IdentitySet . GetMri(IdentitySet, CloudNamespace) Gets participant MRI The priority order is: User, Guest, Encrypted, Application Instance, Application, Phone Declaration public static string GetMri(this IdentitySet identitySet, CloudNamespace cloudNamespace) Parameters Type Name Description IdentitySet identitySet Participant identity set CloudNamespace cloudNamespace Cloud environment where the identity set belongs Returns Type Description String Participant MRI GetObjectIdForAppParticipant(String) Get the object id for an app Declaration public static string GetObjectIdForAppParticipant(string mri) Parameters Type Name Description String mri participant mri Returns Type Description String The object id of the participant> GetObjectIdForDirectoryAppParticipant(String) Get the object id for a directory app participant Declaration public static string GetObjectIdForDirectoryAppParticipant(string mri) Parameters Type Name Description String mri participant mri Returns Type Description String The object id of the participant> GetObjectIdForDirectoryParticipant(String) /Get the object id for a directory participant Declaration public static string GetObjectIdForDirectoryParticipant(string mri) Parameters Type Name Description String mri participant mri Returns Type Description String The object id of the participant> GetObjectIdForOnPremisesParticipant(String) /Get the object id for an external participant Declaration public static string GetObjectIdForOnPremisesParticipant(string mri) Parameters Type Name Description String mri participant mri Returns Type Description String The object id of the participant> GetOnPremisesParticipantPrefix(CloudNamespace) Gets an external prefix for the provided CloudNamespace . Declaration public static string GetOnPremisesParticipantPrefix(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace The cloud where the user belongs Returns Type Description String Prefix to be used to construct the MRI GetPrimaryIdentity(IdentitySet) Gets the primary identity from the specified IdentitySet . The priority order is: User, Guest, Phone, Encrypted, OnPremises, Application Instance, Application Declaration public static Identity GetPrimaryIdentity(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Primary Identity IsConsumer(IdentitySet) Indicates whether this identity set is a consumer identity. Declaration public static bool IsConsumer(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Boolean true if the identity is a consumer identity, false otherwise. MriHasAppParticipantPrefix(String) Returns whether a MRI is a directory participant prefix or not. Declaration public static bool MriHasAppParticipantPrefix(string mri) Parameters Type Name Description String mri Participant MRI Returns Type Description Boolean true if mri is a valid directory participant prefix MriHasDirectoryAppParticipantPrefix(String) Returns whether a MRI is a directory participant prefix or not. Declaration public static bool MriHasDirectoryAppParticipantPrefix(string mri) Parameters Type Name Description String mri Participant MRI Returns Type Description Boolean true if mri is a valid directory participant prefix MriHasDirectoryParticipantPrefix(String) Returns whether a MRI is a directory participant prefix or not. Declaration public static bool MriHasDirectoryParticipantPrefix(string mri) Parameters Type Name Description String mri Participant MRI Returns Type Description Boolean true if mri is a valid directory participant prefix MriHasOnPremisesParticipantPrefix(String) Returns whether a MRI is an external participant prefix or not. Declaration public static bool MriHasOnPremisesParticipantPrefix(string mri) Parameters Type Name Description String mri Participant MRI Returns Type Description Boolean true if mri is a valid external participant prefix" + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.HashingObfuscationConfiguration.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.HashingObfuscationConfiguration.html", + "title": "Class HashingObfuscationConfiguration", + "keywords": "Class HashingObfuscationConfiguration The hashing obfuscation configuration. This configurations is preconfigured to use the HashingObfuscationEngine and provides logic to automatically generate a salt which resets daily. Inheritance Object ObfuscationConfiguration HashingObfuscationConfiguration Inherited Members ObfuscationConfiguration.DefaultUriFilters ObfuscationConfiguration.DefaultContentTypeFilters ObfuscationConfiguration.DefaultContentDispositionFilters ObfuscationConfiguration.DefaultHeaderFilters ObfuscationConfiguration.ObfuscationEngine ObfuscationConfiguration.ObfuscationMembers ObfuscationConfiguration.ObfuscationSerializerSettings ObfuscationConfiguration.ContentDispositionFilters ObfuscationConfiguration.ContentTypeFilters ObfuscationConfiguration.HeaderFilters ObfuscationConfiguration.UriFilters Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class HashingObfuscationConfiguration : ObfuscationConfiguration Constructors HashingObfuscationConfiguration(IEnumerable, Boolean, ObfuscationMember[]) Initializes a new instance of the HashingObfuscationConfiguration class. Declaration public HashingObfuscationConfiguration(IEnumerable filters = null, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IEnumerable < BaseFilter > filters The filters. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . HashingObfuscationConfiguration(IEnumerable, IEnumerable, IEnumerable, Boolean, ObfuscationMember[]) Initializes a new instance of the HashingObfuscationConfiguration class. Declaration public HashingObfuscationConfiguration(IEnumerable headerFilters, IEnumerable contentDispositionFilters, IEnumerable contentTypeFilters, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IEnumerable < HeaderFilter > headerFilters The header filters. IEnumerable < ContentDispositionFilter > contentDispositionFilters The content disposition filters. IEnumerable < ContentTypeFilter > contentTypeFilters The content type filters. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) HttpObfuscationHelpers.LogHeaderText(ObfuscationConfiguration, IEnumerable>>) HttpObfuscationHelpers.LogHeaderText(ObfuscationConfiguration, String, IEnumerable) See Also ObfuscationConfiguration" }, - "core/Microsoft.Graph.NotificationsExtensions.html": { - "href": "core/Microsoft.Graph.NotificationsExtensions.html", - "title": "Class NotificationsExtensions", - "keywords": "Class NotificationsExtensions Communications notifications extensions. Inheritance Object NotificationsExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class NotificationsExtensions Methods GetResourceData(CommsNotification) Gets the resource data. Declaration public static object GetResourceData(this CommsNotification notification) Parameters Type Name Description CommsNotification notification The notification. Returns Type Description Object The resource data object for the specified notification. GetResourceData(CommsNotification) Gets the resource data. Declaration public static T GetResourceData(this CommsNotification notification) Parameters Type Name Description CommsNotification notification The notification. Returns Type Description T The resource data T object for the specified notification. Type Parameters Name Description T The expected resource data type. SetResourceData(CommsNotification, Object) Sets the resource data. Declaration public static void SetResourceData(this CommsNotification notification, object data) Parameters Type Name Description CommsNotification notification The notification. Object data The data." + "common/Microsoft.Graph.Communications.Common.Transport.IGraphClient.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphClient.html", + "title": "Interface IGraphClient", + "keywords": "Interface IGraphClient This class abstracts any communication with different services. This client acts at an object level rather than wire level and thus providing richer experience when working with complex objects. Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphClient Properties DefaultProperties Gets the default properties. Declaration IEnumerable DefaultProperties { get; } Property Value Type Description IEnumerable < IGraphProperty > GraphLogger Gets the graph logger. Declaration IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Methods SendAsync(IGraphRequest, CancellationToken) Send a request as an asynchronous operation. Declaration Task SendAsync(IGraphRequest request, CancellationToken cancellationToken = default(CancellationToken)) where TRequest : class Parameters Type Name Description IGraphRequest request The request message to send. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IGraphResponse > The task object representing the asynchronous operation. Type Parameters Name Description TRequest Type of the content present in the request. SendAsync(IGraphRequest, CancellationToken) Send a request as an asynchronous operation. Declaration Task> SendAsync(IGraphRequest request, CancellationToken cancellationToken = default(CancellationToken)) where TRequest : class where TResponse : class Parameters Type Name Description IGraphRequest request The request message to send. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IGraphResponse > The task object representing the asynchronous operation. Type Parameters Name Description TRequest Type of the content present in the request. TResponse Type of the expected content in response. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.AudioSendStatusChangedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioSendStatusChangedEventArgs.html", - "title": "Class AudioSendStatusChangedEventArgs", - "keywords": "Class AudioSendStatusChangedEventArgs Event arguments of an AudioSendStatusChanged event. Inheritance Object EventArgs AudioSendStatusChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioSendStatusChangedEventArgs : EventArgs Constructors AudioSendStatusChangedEventArgs() Declaration public AudioSendStatusChangedEventArgs() Properties MediaSendStatus Status if socket is ready to send media. Declaration public MediaSendStatus MediaSendStatus { get; set; } Property Value Type Description MediaSendStatus" + "common/Microsoft.Graph.Communications.Common.WeakKeyDictionary-2.html": { + "href": "common/Microsoft.Graph.Communications.Common.WeakKeyDictionary-2.html", + "title": "Class WeakKeyDictionary", + "keywords": "Class WeakKeyDictionary Dictionary with weak reference for the key. Inheritance Object ConcurrentDictionary < WeakKey , TValue> WeakKeyDictionary Implements IDictionary < WeakKey , TValue> ICollection < KeyValuePair < WeakKey , TValue>> IDictionary ICollection IReadOnlyDictionary < WeakKey , TValue> IReadOnlyCollection < KeyValuePair < WeakKey , TValue>> IEnumerable < KeyValuePair < WeakKey , TValue>> IEnumerable Inherited Members ConcurrentDictionary, TValue>.TryAdd(WeakKey, TValue) ConcurrentDictionary, TValue>.ContainsKey(WeakKey) ConcurrentDictionary, TValue>.TryRemove(WeakKey, TValue) ConcurrentDictionary, TValue>.TryGetValue(WeakKey, TValue) ConcurrentDictionary, TValue>.TryUpdate(WeakKey, TValue, TValue) ConcurrentDictionary, TValue>.Clear() System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.CopyTo(System.Collections.Generic.KeyValuePair, TValue>[], System.Int32) ConcurrentDictionary, TValue>.ToArray() ConcurrentDictionary, TValue>.GetEnumerator() ConcurrentDictionary, TValue>.GetOrAdd(WeakKey, Func, TValue>) ConcurrentDictionary, TValue>.GetOrAdd(WeakKey, TValue) ConcurrentDictionary, TValue>.GetOrAdd(WeakKey, Func, TArg, TValue>, TArg) ConcurrentDictionary, TValue>.AddOrUpdate(WeakKey, Func, TArg, TValue>, Func, TValue, TArg, TValue>, TArg) ConcurrentDictionary, TValue>.AddOrUpdate(WeakKey, Func, TValue>, Func, TValue, TValue>) ConcurrentDictionary, TValue>.AddOrUpdate(WeakKey, TValue, Func, TValue, TValue>) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.IDictionary, TValue>.Add(Microsoft.Graph.Communications.Common.WeakKey, TValue) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.IDictionary, TValue>.Remove(Microsoft.Graph.Communications.Common.WeakKey) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.Add(System.Collections.Generic.KeyValuePair, TValue>) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.Contains(System.Collections.Generic.KeyValuePair, TValue>) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.Remove(System.Collections.Generic.KeyValuePair, TValue>) ConcurrentDictionary, TValue>.IEnumerable.GetEnumerator() ConcurrentDictionary, TValue>.IDictionary.Add(Object, Object) ConcurrentDictionary, TValue>.IDictionary.Contains(Object) ConcurrentDictionary, TValue>.IDictionary.GetEnumerator() ConcurrentDictionary, TValue>.IDictionary.Remove(Object) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.IDictionary.get_Item(System.Object) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.IDictionary.set_Item(System.Object, System.Object) ConcurrentDictionary, TValue>.ICollection.CopyTo(Array, Int32) ConcurrentDictionary, TValue>.Item[WeakKey] ConcurrentDictionary, TValue>.Count ConcurrentDictionary, TValue>.IsEmpty ConcurrentDictionary, TValue>.Keys System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.IReadOnlyDictionary, TValue>.Keys ConcurrentDictionary, TValue>.Values System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.IReadOnlyDictionary, TValue>.Values System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.IsReadOnly ConcurrentDictionary, TValue>.IDictionary.IsFixedSize ConcurrentDictionary, TValue>.IDictionary.IsReadOnly ConcurrentDictionary, TValue>.IDictionary.Keys ConcurrentDictionary, TValue>.IDictionary.Values ConcurrentDictionary, TValue>.IDictionary.Item[Object] ConcurrentDictionary, TValue>.ICollection.IsSynchronized ConcurrentDictionary, TValue>.ICollection.SyncRoot Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class WeakKeyDictionary : ConcurrentDictionary, TValue>, IDictionary, TValue>, ICollection, TValue>>, IDictionary, ICollection, IReadOnlyDictionary, TValue>, IReadOnlyCollection, TValue>>, IEnumerable, TValue>>, IEnumerable where TKey : class Type Parameters Name Description TKey Key type which must be a reference type. TValue Value type. Constructors WeakKeyDictionary() Declaration public WeakKeyDictionary() Methods Cleanup() Cleans keys where the weak references have been garbage collected. Declaration public void Cleanup() Implements System.Collections.Generic.IDictionary System.Collections.Generic.ICollection System.Collections.IDictionary System.Collections.ICollection System.Collections.Generic.IReadOnlyDictionary System.Collections.Generic.IReadOnlyCollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) CollectionUtils.ForEach(IEnumerable, Action) CollectionUtils.ForEachParallel(IEnumerable, Action, IGraphLogger) CollectionUtils.GetValueOrDefault(IDictionary, TKey) CollectionUtils.GetValueOrDefault(IDictionary, TKey, TValue) CollectionUtils.AddRange(ICollection, IEnumerable) CollectionUtils.ToSortedList(IEnumerable, Func) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.Any(IEnumerable) Validator.FirstObject(IEnumerable, Func) Validator.FirstObject(IEnumerable) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.NotEmpty(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) Validator.VerifyNotContainsKey(IDictionary, TK) Validator.VerifyContainsKey(IDictionary, TK) Validator.VerifyContainsKey(IReadOnlyDictionary, TK) Validator.VerifyContains(IEnumerable, T)" }, - "bot_media/Microsoft.Skype.Bots.Media.AudioVideoFramePlayer.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioVideoFramePlayer.html", - "title": "Class AudioVideoFramePlayer", - "keywords": "Class AudioVideoFramePlayer AudioVideoFramePlayer is responsible for streaming real time audio and video buffers. This frame player will handle audio and video sync from the audio and video buffer's timestamps Inheritance Object AudioVideoFramePlayer Implements IAudioVideoFramePlayer Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioVideoFramePlayer : IAudioVideoFramePlayer Constructors AudioVideoFramePlayer(AudioSocket, VideoSocket, AudioVideoFramePlayerSettings) Constructor for the audio video frame player. Declaration public AudioVideoFramePlayer(AudioSocket audioSocket, VideoSocket videoSocket, AudioVideoFramePlayerSettings audioVideoFramePlayerSettings) Parameters Type Name Description AudioSocket audioSocket VideoSocket videoSocket AudioVideoFramePlayerSettings audioVideoFramePlayerSettings Methods ClearAsync(Boolean, List) Clear the enqueued buffers. This will also invoke Dispose() on the buffers still in the queue. Declaration public Task ClearAsync(bool clearAudio = true, List videoFormats = null) Parameters Type Name Description Boolean clearAudio true will clear the audio buffers, Default value is set to true List < VideoFormat > videoFormats list of video formats to clear, default is null Returns Type Description Task EnqueueBuffersAsync(IList, IList) Enqueue the audio and video media buffers. Usage should be to enqueue the same audio and video length, if audio and video sockets are active. Declaration public Task EnqueueBuffersAsync(IList audioMediaBuffers, IList videoMediaBuffers) Parameters Type Name Description IList < AudioMediaBuffer > audioMediaBuffers IList < VideoMediaBuffer > videoMediaBuffers Returns Type Description Task ShutdownAsync() Shuts down the player and releases allocated resources Declaration public Task ShutdownAsync() Returns Type Description Task Events LowOnFrames Event to signal the player is low on frames Declaration public event EventHandler LowOnFrames Event Type Type Description EventHandler < LowOnFramesEventArgs > Implements IAudioVideoFramePlayer" + "core/Microsoft.Graph.Communications.Core.Exceptions.ClientException.html": { + "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ClientException.html", + "title": "Class ClientException", + "keywords": "Class ClientException Class for client error exception. Inheritance Object ClientException Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax [Obsolete(\"Deprecated, please use Microsoft.Graph.ClientException instead.\")] public class ClientException : ClientException Constructors ClientException(Error, Exception) Initializes a new instance of the ClientException class. Declaration [Obsolete(\"Deprecated, please use Microsoft.Graph.ClientException instead.\")] public ClientException(Error error, Exception innerException = null) Parameters Type Name Description Error error The Error to wrap. Exception innerException The Exception to wrap." }, - "bot_media/Microsoft.Skype.Bots.Media.DataSocket.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.DataSocket.html", - "title": "Class DataSocket", - "keywords": "Class DataSocket Reserved for the internal use. Inheritance Object DataSocket Implements IDataSocket IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public sealed class DataSocket : IDataSocket, IDisposable, IInternalSocket Constructors DataSocket(DataSocketSettings) Reserverd for internal use. Declaration public DataSocket(DataSocketSettings settings) Parameters Type Name Description DataSocketSettings settings Methods Dispose() Reserved for the internal use. Declaration public void Dispose() Send(DataMediaBuffer, UInt32[]) Reserved for the internal use. Declaration public void Send(DataMediaBuffer buffer, uint[] recipientIds) Parameters Type Name Description DataMediaBuffer buffer UInt32 [] recipientIds Events DataMediaReceived Reserved for the internal use. Declaration public event EventHandler DataMediaReceived Event Type Type Description EventHandler < DataMediaReceivedEventArgs > DataSendStatusChanged Reserved for the internal use. Declaration public event EventHandler DataSendStatusChanged Event Type Type Description EventHandler < DataSendStatusChangedEventArgs > MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration public event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > Implements IDataSocket System.IDisposable" + "client/Microsoft.Graph.Communications.Client.Cache.CacheContext-1.html": { + "href": "client/Microsoft.Graph.Communications.Client.Cache.CacheContext-1.html", + "title": "Struct CacheContext", + "keywords": "Struct CacheContext The stored cache context Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() ValueType.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Graph.Communications.Client.Cache Assembly : Microsoft.Graph.Communications.Client.dll Syntax public struct CacheContext where TEntity : Entity Type Parameters Name Description TEntity The type of the entity. Properties Id Gets or sets the context identifier. Declaration public string Id { get; set; } Property Value Type Description String Resource Gets or sets the resource. Declaration public TEntity Resource { get; set; } Property Value Type Description TEntity ScenarioId Gets or sets the scenario identifier associated with this resource. Declaration public Guid ScenarioId { get; set; } Property Value Type Description Guid TenantId Gets or sets the tenant identifier associated with this resource. Declaration public string TenantId { get; set; } Property Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.ILogEventFormatter.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.ILogEventFormatter.html", - "title": "Interface ILogEventFormatter", - "keywords": "Interface ILogEventFormatter Interface to format log event. Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface ILogEventFormatter Methods Format(LogEvent) Format the log event. Declaration string Format(LogEvent logEvent) Parameters Type Name Description LogEvent logEvent The log event Returns Type Description String The formatted text. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.Exceptions.ConfigurationException.html": { + "href": "common/Microsoft.Graph.Communications.Common.Exceptions.ConfigurationException.html", + "title": "Class ConfigurationException", + "keywords": "Class ConfigurationException Configuration is bad. Mandatory configuration setting is missing. Or raw (string) setting value can not be converted to property type. Inheritance Object Exception ConfigurationException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Exceptions Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ConfigurationException : Exception, ISerializable, _Exception Constructors ConfigurationException(String) Initializes a new instance of the ConfigurationException class. Declaration public ConfigurationException(string message) Parameters Type Name Description String message The message that describes the error. ConfigurationException(String, Exception) Initializes a new instance of the ConfigurationException class. Declaration public ConfigurationException(string message, Exception innerException) Parameters Type Name Description String message The error message that explains the reason for the exception. Exception innerException The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified. Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.OData.ODataConfiguration.html": { - "href": "common/Microsoft.Graph.Communications.Common.OData.ODataConfiguration.html", - "title": "Class ODataConfiguration", - "keywords": "Class ODataConfiguration OData Configuration object to be used for different classes. Inheritance Object ODataConfiguration Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ODataConfiguration Constructors ODataConfiguration(Boolean, Assembly[]) Initializes a new instance of the ODataConfiguration class. Declaration public ODataConfiguration(bool addOdataType, params Assembly[] odataAssemblies) Parameters Type Name Description Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. Assembly [] odataAssemblies The OData assemblies. Properties JsonSerializerSettingsForOData Gets json serializer settings for OData. Declaration public JsonSerializerSettings JsonSerializerSettingsForOData { get; } Property Value Type Description Newtonsoft.Json.JsonSerializerSettings Newtonsoft.Json.JsonSerializerSettings for serializing/deserializing OData objects. Methods FillODataJsonSerializerSettings(Boolean, JsonSerializerSettings) Fills the json serializer settings. Declaration public JsonSerializerSettings FillODataJsonSerializerSettings(bool addOdataType, JsonSerializerSettings settings) Parameters Type Name Description Boolean addOdataType If true, attach the @odata.type property to each object, otherwise only attach this property if it's already present. Newtonsoft.Json.JsonSerializerSettings settings The settings. Returns Type Description Newtonsoft.Json.JsonSerializerSettings Serialization settings. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "client/Microsoft.Graph.Communications.Client.StateManager-2.html": { + "href": "client/Microsoft.Graph.Communications.Client.StateManager-2.html", + "title": "Class StateManager", + "keywords": "Class StateManager The state manager implementation. Inheritance Object StateManager Implements IStateManager ICollection IEnumerable IEnumerable IDisposable Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class StateManager : Disposable, IStateManager, ICollection, IEnumerable, IEnumerable, IDisposable where TResource : IResource where TEntity : Entity Type Parameters Name Description TResource The type of the resource. TEntity The type of the entity. Constructors StateManager(ISerializer, ICache) Initializes a new instance of the StateManager class. Declaration public StateManager(ISerializer serializer, ICache cache) Parameters Type Name Description ISerializer serializer The serializer. ICache cache The cache. Properties Count Declaration public int Count { get; } Property Value Type Description Int32 IsReadOnly Declaration public bool IsReadOnly { get; } Property Value Type Description Boolean Item[String] Declaration public TResource this[string id] { get; } Parameters Type Name Description String id Property Value Type Description TResource Methods Add(TResource) Adds an item to the ICollection . Declaration public void Add(TResource item) Parameters Type Name Description TResource item The object to add to the ICollection . Exceptions Type Condition ServiceException If the resource already exists in the collection. Clear() Declaration public void Clear() Contains(TResource) Declaration public bool Contains(TResource item) Parameters Type Name Description TResource item Returns Type Description Boolean CopyContent() Declaration public ICollection CopyContent() Returns Type Description ICollection CopyTo(TResource[], Int32) Declaration public void CopyTo(TResource[] array, int arrayIndex) Parameters Type Name Description TResource[] array Int32 arrayIndex Dispose(Boolean) Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing GetEnumerator() Declaration public IEnumerator GetEnumerator() Returns Type Description IEnumerator GetOrAdd(String, Func) Declaration public TResource GetOrAdd(string id, Func resourceFactory) Parameters Type Name Description String id Func resourceFactory Returns Type Description TResource GetOrAddAsync(String, Func>) Declaration public Task GetOrAddAsync(string id, Func> resourceFactory) Parameters Type Name Description String id Func < Task > resourceFactory Returns Type Description Task Remove(TResource) Removes the occurrence of a specific object from the IStateManager . Declaration public bool Remove(TResource item) Parameters Type Name Description TResource item The object to remove from the IStateManager . Returns Type Description Boolean true if item was successfully removed from the IStateManager . Exceptions Type Condition ServiceException If the resource does not exist in the collection. Remove(String) Removes the occurrence of a specific object from the IStateManager . Declaration public TResource Remove(string id) Parameters Type Name Description String id The identifier of the object to remove from the IStateManager . Returns Type Description TResource The IResource that was removed. Exceptions Type Condition ServiceException If the resource does not exist in the collection. TryRemove(String, out TResource) Declaration public bool TryRemove(string id, out TResource resource) Parameters Type Name Description String id TResource resource Returns Type Description Boolean Explicit Interface Implementations IEnumerable.GetEnumerator() Declaration IEnumerator IEnumerable.GetEnumerator() Returns Type Description IEnumerator Implements IStateManager System.Collections.Generic.ICollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable System.IDisposable See Also IStateManager " }, - "common/Microsoft.Graph.Communications.Common.StateMachine-1.Transition.html": { - "href": "common/Microsoft.Graph.Communications.Common.StateMachine-1.Transition.html", - "title": "Class StateMachine.Transition", - "keywords": "Class StateMachine.Transition Single transition from Source to Targets Inheritance Object StateMachine.Transition Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class Transition Constructors Transition(TStateEnum, TStateEnum[]) Initializes a new instance of the StateMachine.Transition class. Declaration public Transition(TStateEnum source, params TStateEnum[] targets) Parameters Type Name Description TStateEnum source The source. TStateEnum[] targets The targets. Properties Source Gets the source state. Declaration public TStateEnum Source { get; } Property Value Type Description TStateEnum The source. Targets Gets the target states. Declaration public TStateEnum[] Targets { get; } Property Value Type Description TStateEnum[] The targets. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.Observer-1.html": { + "href": "common/Microsoft.Graph.Communications.Common.Observer-1.html", + "title": "Class Observer", + "keywords": "Class Observer Observer class. Inheritance Object Disposable Observer Implements IDisposable IObserver Inherited Members Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class Observer : Disposable, IDisposable, IObserver Type Parameters Name Description T Type of the value the observer returns. Constructors Observer(IObservable, Action, Action, Action) Initializes a new instance of the Observer class. Declaration public Observer(IObservable observable, Action onNext, Action onError = null, Action onCompleted = null) Parameters Type Name Description IObservable observable Observable object. Action onNext Callback for next. Action < Exception > onError Callback for error. Action onCompleted Callback for completed. Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) Explicit Interface Implementations IObserver.OnCompleted() Callback when observer has no more data. Declaration void IObserver.OnCompleted() IObserver.OnError(Exception) Callback when observer hits an error. Declaration void IObserver.OnError(Exception error) Parameters Type Name Description Exception error Exception info. IObserver.OnNext(T) Callback when data arrives. Declaration void IObserver.OnNext(T value) Parameters Type Name Description T value Observed value. Implements System.IDisposable System.IObserver Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.AudioLowOnFramesEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioLowOnFramesEventArgs.html", - "title": "Class AudioLowOnFramesEventArgs", - "keywords": "Class AudioLowOnFramesEventArgs Audio low on frame event args Inheritance Object EventArgs LowOnFramesEventArgs AudioLowOnFramesEventArgs Inherited Members LowOnFramesEventArgs.MediaType LowOnFramesEventArgs.RemainingMediaLengthInMS EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioLowOnFramesEventArgs : LowOnFramesEventArgs Constructors AudioLowOnFramesEventArgs() Declaration public AudioLowOnFramesEventArgs()" + "common/Microsoft.Graph.Communications.Common.Transport.HttpResponseMessageExtensions.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.HttpResponseMessageExtensions.html", + "title": "Class HttpResponseMessageExtensions", + "keywords": "Class HttpResponseMessageExtensions Extensions for HttpResponseMessage class. Inheritance Object HttpResponseMessageExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpResponseMessageExtensions Methods GetHttpAndContentHeaders(HttpResponseMessage) Gets headers from the http response and the content. Declaration public static IEnumerable>> GetHttpAndContentHeaders(this HttpResponseMessage message) Parameters Type Name Description HttpResponseMessage message The message. Returns Type Description IEnumerable < KeyValuePair < String , IEnumerable < String >>> The list of http and content headers. GetOutcomeFromResponseOrException(Nullable, Exception) Try extracting outcome outcome from HTTP response status code or exception Declaration public static string GetOutcomeFromResponseOrException(int? statusCode, Exception exception) Parameters Type Name Description Nullable < Int32 > statusCode HTTP response status code Exception exception The exception Returns Type Description String Outcome string ToGraphResponseAsync(HttpResponseMessage) Converts HttpResponseMessage to an instance of IGraphResponse . Declaration public static Task ToGraphResponseAsync(this HttpResponseMessage httpResponse) Parameters Type Name Description HttpResponseMessage httpResponse HTTP response to be converted. Returns Type Description Task < IGraphResponse > IGraphResponse corresponding to httpResponse . ToGraphResponseAsync(HttpResponseMessage, JsonSerializerSettings) Converts HttpResponseMessage to an instance of IGraphResponse . Declaration public static Task> ToGraphResponseAsync(this HttpResponseMessage httpResponse, JsonSerializerSettings serializerSettings = null) where T : class Parameters Type Name Description HttpResponseMessage httpResponse HTTP response to be converted. Newtonsoft.Json.JsonSerializerSettings serializerSettings Add serializer that can serialize the content. Returns Type Description Task < IGraphResponse > IGraphResponse corresponding to httpResponse . Type Parameters Name Description T Type of the expected response." }, - "bot_media/Microsoft.Skype.Bots.Media.VideoSocket.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSocket.html", - "title": "Class VideoSocket", - "keywords": "Class VideoSocket Provides Send and Receive I/O access to a video stream. Inheritance Object VideoSocket Implements IVideoSocket IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public sealed class VideoSocket : IVideoSocket, IDisposable, IInternalVideoSocket, IInternalSocket Constructors VideoSocket(VideoSocketSettings) Initializes a new VideoSocket object. Declaration public VideoSocket(VideoSocketSettings settings) Parameters Type Name Description VideoSocketSettings settings Configuration settings for the VideoSocket Properties MediaType MediaType of the video socket. This could be Video or Vbss. The MediaType is set after the socket is passed to the CreateMediaConfiguration API. It may also be set via the VideoSocketSettings during socket creation. Declaration public MediaType MediaType { get; } Property Value Type Description MediaType ReceiveColorFormat VideoColorFormat to receive Declaration public VideoColorFormat ReceiveColorFormat { get; } Property Value Type Description VideoColorFormat SocketId The 0-based ID of the socket. This socket ID is useful to identify a socket in a multiview (ie. more than 1 video socket) call. The same ID is used in the event args of the VideoMediaReceived and VideoSendStatusChanged events that this class may raise. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the CreateMediaConfiguration API. Eg., if the collection of IVideoSocket objects in the CreateMediaConfiguration API contains {socketA, socketB, socketC}, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Before the call to CreateMediaConfiguration, the SocketId has a value of -1. Declaration public int SocketId { get; } Property Value Type Description Int32 Methods Dispose() Disposes the object. Declaration public void Dispose() GetQualityOfExperienceData() Get the Quality of Experience (QoE) data for the audio socket. Declaration public VideoQualityOfExperienceData GetQualityOfExperienceData() Returns Type Description VideoQualityOfExperienceData Remarks The bot should fetch the QoE data no more than once every 30 seconds. To get accurate metrics, the bot should let media flow for at least 30 seconds before fetching the QoE data. RequestKeyFrame() Allows the application to request for key frame. Only valid for sockets with the ReceiveColorFormat as H264 Declaration public void RequestKeyFrame() Send(VideoMediaBuffer) Sends a frame of video media. Declaration public void Send(VideoMediaBuffer buffer) Parameters Type Name Description VideoMediaBuffer buffer VideoMediaBuffer containing the frame of video media to send. Remarks The application must create a concrete class which derives from the VideoMediaBuffer abstract class. The buffer object passed to the Send method is still potentially in-use after the method returns to the caller. The application must not free the buffer's data until the the buffer object's Dispose() method is invoked by the Media Platform. The application should be sending up to 30 video frames per second. The VideoSocket must be enabled to send media via the VideoSocketSettings.StreamDirections property. SetReceiveBandwidthLimit(UInt32) Sets the bandwidth limit on the receive stream of the VideoSocket. This is only supported if the socket supports receiving H264 video format. It is recommended to wait for the VideoReceiveStatusChanged event with MediaReceiveStatus Active state during the initial call setup before applying the receive bandwidth limit on the socket. Bandwidth range (in bits per second) for various resolutions and frame rates per media type: Media type: Video 1000000 - 4000000 1080p at 30 fps 550000 - 2500000 720p at 30 fps 375000 - 1500000 540p at 30 fps 200000 - 800000 360p at 30 fps 150000 - 250000 360p at 15 fps 120000 - 220000 240p at 15 fps 60000 - 200000 180p at 15 fps 20000 - 100000 180p at 7.5 fps 10000 - 25000 180p at 3.75 fps 1000 - 12500 180p at 1.875 fps Media type: Vbss Resolution: 1080p 2000000 - 4000000 at 30 fps 600000 - 3000000 at 15 fps 300000 - 700000 at 7.5 fps 150000 - 350000 at 3.75 fps 70000 - 200000 at 1.875 fps Declaration public void SetReceiveBandwidthLimit(uint bitsPerSecond) Parameters Type Name Description UInt32 bitsPerSecond The receive bitrate SetSendBandwidthLimit(UInt32) Sets the bandwidth limit on the send stream of the VideoSocket. This is only supported if the socket supports sending H264 video formats. It is recommended to wait for the VideoSendStatusChanged event with MediaSendStatus Active state during the initial call setup before applying the send bandwidth limit on the socket. Bandwidth range (in bits per second) for various resolutions and frame rates per media type: Media type: Video 1000000 - 4000000 1080p at 30 fps 550000 - 2500000 720p at 30 fps 375000 - 1500000 540p at 30 fps 200000 - 800000 360p at 30 fps 150000 - 250000 360p at 15 fps 120000 - 220000 240p at 15 fps 60000 - 200000 180p at 15 fps 20000 - 100000 180p at 7.5 fps 10000 - 25000 180p at 3.75 fps 1000 - 12500 180p at 1.875 fps Media type: Vbss Resolution: 1080p 2000000 - 4000000 at 30 fps 600000 - 3000000 at 15 fps 300000 - 700000 at 7.5 fps 150000 - 350000 at 3.75 fps 70000 - 200000 at 1.875 fps Declaration public void SetSendBandwidthLimit(uint bitsPerSecond) Parameters Type Name Description UInt32 bitsPerSecond The send bitrate Subscribe(VideoResolution) Request to receive the video of the peer in a 1:1 call. No need to specify a MediaSourceId. The bot cannot subscribe to a video source unless the VideoReceiveStatusChanged event is raised indicating the VideoSocket's MediaReceiveStatus is Active . Declaration public void Subscribe(VideoResolution preferredVideoResolution) Parameters Type Name Description VideoResolution preferredVideoResolution The requested video resolution. The received video frames should have this resolution if the bandwidth constraints and sender capabilities allow, however the bot may receive video frames at a resolution lower than requested. Subscribe(VideoResolution, UInt32) Request to receive the video source of a participant in a meeting or group call. The video source must be identified by its MediaSourceId available from the roster. The bot cannot subscribe to a video source unless the VideoReceiveStatusChanged event is raised indicating the VideoSocket's MediaReceiveStatus is Active . Declaration public void Subscribe(VideoResolution preferredVideoResolution, uint MediaSourceId) Parameters Type Name Description VideoResolution preferredVideoResolution The requested video resolution. The received video frames should have this resolution if the bandwidth constraints and sender capabilities allow, however the bot may receive video frames at a resolution lower than requested. UInt32 MediaSourceId Media source identifier of the video source to be received Exceptions Type Condition ObjectDisposedException Thrown if the VideoSocket is disposed. InvalidOperationException Thrown if the subscription is invalid. SkypeMediaException Thrown if an internal media failure occurs. Unsubscribe() Stops the current video subscription on the VideoSocket. The VideoMediaReceived events will stop raising video buffers. Declaration public void Unsubscribe() UpdateVideoSendCapability(VideoSendCapability) Allows the application to update dynamically the send capability (such as SupportedSendVideoFormats or MaxConcurrentSendStreams) of the video socket. The purpose of this API is to allow the application to communicate changes in VideoSocket's send capability to the platform during the call. Declaration public void UpdateVideoSendCapability(VideoSendCapability capability) Parameters Type Name Description VideoSendCapability capability Events MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration public event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > Remarks Note: this event can be raised even if there is no active video subscription; i.e., the VideoSocket is \"idle\" and not receiving media. MediaStreamQualityChanged The event is raised if a media stream quality change was detected Declaration public event EventHandler MediaStreamQualityChanged Event Type Type Description EventHandler < VideoMediaStreamQualityChangedEventArgs > VideoKeyFrameNeeded If the application has configured the VideoSocket to receive encoded media, this event is raised each time a key frame is needed. Events are serialized, so only one event at a time is raised to the app. Declaration public event EventHandler VideoKeyFrameNeeded Event Type Type Description EventHandler < VideoKeyFrameNeededEventArgs > VideoMediaReceived If the application has configured the VideoSocket to receive media, this event is raised each time a frame of video media is received. Once the application has consumed the buffer, it must call the buffer's Dispose() method. Declaration public event EventHandler VideoMediaReceived Event Type Type Description EventHandler < VideoMediaReceivedEventArgs > Remarks The incoming video frame rate is variable. The frame rate can vary between 1.875 frames per second (fps) up to 30 fps. The application must be able to receive up to 30 video buffers per second. Events are serialized, so only one event at a time is raised to the app. The event handler should return as quickly as possible; any time-consuming per-frame processing should be performed asynchronously from the event handler. VideoReceiveStatusChanged If the application has configured the VideoSocket to receive media, this event is raised to inform the application when it is ready to receive media. When the status is active the application can subscribe to a video source, when inactive video subscription won't be allowed Declaration public event EventHandler VideoReceiveStatusChanged Event Type Type Description EventHandler < VideoReceiveStatusChangedEventArgs > VideoSendStatusChanged If the application has configured the VideoSocket to send media, this event is raised to inform the application when it may begin sending media and when it should stop. The application cannot send media before receiving a VideoMediaSendStatusChanged event indicating the SendStatus is Active, such media will be discarded. Declaration public event EventHandler VideoSendStatusChanged Event Type Type Description EventHandler < VideoSendStatusChangedEventArgs > Implements IVideoSocket System.IDisposable" + "client/Microsoft.Graph.Communications.Client.IPagedList-1.html": { + "href": "client/Microsoft.Graph.Communications.Client.IPagedList-1.html", + "title": "Interface IPagedList", + "keywords": "Interface IPagedList The paged list interface. Inherited Members IReadOnlyList.Item[Int32] IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IPagedList : IReadOnlyList, IReadOnlyCollection, IEnumerable, IEnumerable Type Parameters Name Description T The type of object to page. Properties AdditionalData Gets or sets the additional data. Declaration IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > NextLinkUrl Gets the next link URL taken from @odata.nextLink. Declaration Uri NextLinkUrl { get; } Property Value Type Description Uri Value Gets or sets the value in the current page of the list. Declaration IList Value { get; set; } Property Value Type Description IList See Also IList " }, - "common/Microsoft.Graph.Communications.Common.SecureStringUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.SecureStringUtils.html", - "title": "Class SecureStringUtils", - "keywords": "Class SecureStringUtils SecureString Utilities Inheritance Object SecureStringUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class SecureStringUtils Methods ConvertToUnsecureString(SecureString) Converts a SecureString into a managed string for consumption Declaration public static string ConvertToUnsecureString(this SecureString secureString) Parameters Type Name Description SecureString secureString The SecureString to convert into a managed string Returns Type Description String String representation of the SecureString" + "client/Microsoft.Graph.Communications.Client.IStateManager-1.html": { + "href": "client/Microsoft.Graph.Communications.Client.IStateManager-1.html", + "title": "Interface IStateManager", + "keywords": "Interface IStateManager The state manager interface. This object is responsible for storing the resources in memory. Inherited Members ICollection.Add(TResource) ICollection.Clear() ICollection.Contains(TResource) ICollection.CopyTo(TResource[], Int32) ICollection.Remove(TResource) ICollection.Count ICollection.IsReadOnly IEnumerable.GetEnumerator() IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IStateManager : ICollection, IEnumerable, IEnumerable, IDisposable where TResource : IResource Type Parameters Name Description TResource The type of the resource. Properties Item[String] Gets the IResource with the specified identifier. Declaration TResource this[string id] { get; } Parameters Type Name Description String id The identifier. Property Value Type Description TResource The IResource . Methods CopyContent() Copies the content contained by this instance. Declaration ICollection CopyContent() Returns Type Description ICollection The copied ICollection GetOrAdd(String, Func) Gets the resource with the specified id if it exists in the collection, otherwise executes the resource factory to create the resource. State manager does not guarantee that the resource factory is executed only once, so operations must be idempotent (I.E. GET, PUT, etc...). Declaration TResource GetOrAdd(string id, Func resourceFactory) Parameters Type Name Description String id The identifier. Func resourceFactory The resource factory. Returns Type Description TResource The IResource that was found or created. GetOrAddAsync(String, Func>) Gets the resource with the specified id if it exists in the collection, otherwise executes the resource factory to create the resource. State manager does not guarantee that the resource factory is executed only once, so operations must be idempotent (I.E. GET, PUT, etc...). This method supports asynchronously creating the resource. Declaration Task GetOrAddAsync(string id, Func> resourceFactory) Parameters Type Name Description String id The identifier. Func < Task > resourceFactory The resource factory. Returns Type Description Task The IResource that was found or created. Remove(String) Removes the resource with the specified id from the state manager. Declaration TResource Remove(string id) Parameters Type Name Description String id The identifier. Returns Type Description TResource The IResource that was removed. TryRemove(String, out TResource) Tries to remove the resource with the specified id. Declaration bool TryRemove(string id, out TResource resource) Parameters Type Name Description String id The identifier. TResource resource The resource. Returns Type Description Boolean true if the IResource was removed, false otherwise." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationSerializer.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationSerializer.html", - "title": "Class ObfuscationSerializer", - "keywords": "Class ObfuscationSerializer The obfuscation serializer can be used to serialize and de-serialize an obfuscation schema, as well as generate a schema from specified assemblies. Inheritance Object ObfuscationSerializer Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ObfuscationSerializer Constructors ObfuscationSerializer() Declaration public ObfuscationSerializer() Properties Members Gets or sets the members belonging to the class. Declaration public ObfuscationMember[] Members { get; set; } Property Value Type Description ObfuscationMember [] Methods ExtractFromAssemblies(Assembly[]) Extracts the obfuscation members from the specified assemblies. Declaration public ObfuscationMember[] ExtractFromAssemblies(params Assembly[] assemblies) Parameters Type Name Description Assembly [] assemblies The assemblies. Returns Type Description ObfuscationMember [] The list of ObfuscationMember stucts extracted from the specified assemblies. GenerateSchema(ObfuscationMember[]) Generates the schema from the specified obfuscation members. Declaration public string GenerateSchema(params ObfuscationMember[] members) Parameters Type Name Description ObfuscationMember [] members The obfuscation classes. Returns Type Description String The schema associated with the specified classes. LoadFromSchema(String) Loads the obfuscations classes from the specified schema. Declaration public ObfuscationMember[] LoadFromSchema(string schema) Parameters Type Name Description String schema The schema. Returns Type Description ObfuscationMember [] The loaded obfuscation classes. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.html": { + "href": "common/Microsoft.Graph.html", + "title": "Namespace Microsoft.Graph", + "keywords": "Namespace Microsoft.Graph Classes AdditionalDataExtensions The identity set extensions" }, - "bot_media/Microsoft.Skype.Bots.Media.MediaReceiveStatus.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaReceiveStatus.html", - "title": "Enum MediaReceiveStatus", - "keywords": "Enum MediaReceiveStatus Indicates if the VideoSocket is capable of receiving media. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaReceiveStatus Fields Name Description Active Media can be received, video subscription is allowed Inactive Media cannot be received. Video subscription is not allowed" + "common/Microsoft.Graph.Communications.Common.SlimLock.html": { + "href": "common/Microsoft.Graph.Communications.Common.SlimLock.html", + "title": "Class SlimLock", + "keywords": "Class SlimLock A SemaphoreSlim based lock implementation Inheritance Object Disposable SlimLock Implements IDisposable Inherited Members Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class SlimLock : Disposable, IDisposable Constructors SlimLock() Declaration public SlimLock() Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) Lock() Acquire a disposable lock Declaration public IDisposable Lock() Returns Type Description IDisposable Disposable cleanup to release semaphore. LockAsync() Acquire a disposable lock Declaration public Task LockAsync() Returns Type Description Task < IDisposable > Disposable cleanup to release semaphore. Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.PortRange.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.PortRange.html", - "title": "Class PortRange", - "keywords": "Class PortRange The Port range Inheritance Object PortRange Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class PortRange Constructors PortRange(UInt32, UInt32) The PortRange constructor Declaration public PortRange(uint minPort, uint maxPort) Parameters Type Name Description UInt32 minPort The minimum port. UInt32 maxPort The maximum port. Properties MaxPort The maximum port. Declaration public uint MaxPort { get; } Property Value Type Description UInt32 MinPort The minimum port. Declaration public uint MinPort { get; } Property Value Type Description UInt32" + "core/Microsoft.Graph.Communications.Core.Notifications.html": { + "href": "core/Microsoft.Graph.Communications.Core.Notifications.html", + "title": "Namespace Microsoft.Graph.Communications.Core.Notifications", + "keywords": "Namespace Microsoft.Graph.Communications.Core.Notifications Classes CollectionNotificationEventArgs The collection notification event args. FailedNotificationEventArgs Event arguments used when exceptions are raised in callbacks. NotificationEventArgs Notification event arguments class. NotificationProcessor The notification processor class. NotificationProcessorExtensions Extensions for container client. Interfaces INotificationProcessor The notification processor interface." }, - "bot_media/Microsoft.Skype.Bots.Media.VideoColorFormat.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoColorFormat.html", - "title": "Enum VideoColorFormat", - "keywords": "Enum VideoColorFormat VideoColorFormat Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum VideoColorFormat Fields Name Description H264 H264 NV12 NV12 Rgb24 RGB24 Yuy2 YUY2" + "core/Microsoft.Graph.Communications.Core.Notifications.NotificationProcessorExtensions.html": { + "href": "core/Microsoft.Graph.Communications.Core.Notifications.NotificationProcessorExtensions.html", + "title": "Class NotificationProcessorExtensions", + "keywords": "Class NotificationProcessorExtensions Extensions for container client. Inheritance Object NotificationProcessorExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class NotificationProcessorExtensions Methods ExtractResouceData(CommsNotification) Extracts the resource data from the specified notification. Declaration public static object ExtractResouceData(this CommsNotification notification) Parameters Type Name Description CommsNotification notification The notification. Returns Type Description Object The resource data notification content. Exceptions Type Condition ServiceException If the specified notification is invalid. ProcessNotificationAsync(INotificationProcessor, HttpRequestMessage) Processes the notification sent from the server to the client. This overload accepts the type of HttpRequest. Declaration public static Task ProcessNotificationAsync(this INotificationProcessor processor, HttpRequestMessage request) Parameters Type Name Description INotificationProcessor processor The processor. HttpRequestMessage request The request. Returns Type Description Task < HttpResponseMessage > Response to be sent back. SanitizeResource(String, String) Gets the model URI. Declaration public static string SanitizeResource(this string resource, string baseUrl = null) Parameters Type Name Description String resource The resource. String baseUrl The base URL. Returns Type Description String The model uri string. Exceptions Type Condition ArgumentNullException If the resource string is null or whitespace. TryGetGuid(HttpHeaders, String, out Guid) Tries to get the GUID value for the specifed header. Declaration public static bool TryGetGuid(this HttpHeaders headers, string header, out Guid guid) Parameters Type Name Description HttpHeaders headers The headers collection. String header The header to look at. Guid guid The found guid Returns Type Description Boolean True if the specified header is a valid guid, false otherwise." }, - "bot_media/Microsoft.Skype.Bots.Media.VideoMediaStreamQualityChangedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoMediaStreamQualityChangedEventArgs.html", - "title": "Class VideoMediaStreamQualityChangedEventArgs", - "keywords": "Class VideoMediaStreamQualityChangedEventArgs Event arguments of the video media stream quality event. Inheritance Object EventArgs VideoMediaStreamQualityChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoMediaStreamQualityChangedEventArgs : EventArgs Constructors VideoMediaStreamQualityChangedEventArgs() Declaration public VideoMediaStreamQualityChangedEventArgs() Properties MediaQualityState Indicates the media quality state of the mediaStream quality changed event Declaration public MediaQualityState MediaQualityState { get; set; } Property Value Type Description MediaQualityState SocketId Socket id associated with the event Declaration public int SocketId { get; set; } Property Value Type Description Int32 VideoQualityType Indicates the media quality type of the media stream quality changed event Declaration public VideoQualityType VideoQualityType { get; set; } Property Value Type Description VideoQualityType" + "common/Microsoft.Graph.Communications.Common.Transport.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.html", + "title": "Namespace Microsoft.Graph.Communications.Common.Transport", + "keywords": "Namespace Microsoft.Graph.Communications.Common.Transport Classes GraphHttpClient Graph client that handles transport over http. GraphHttpClientContainer This class is used to handle multiple http clients within one service. This class extends the concurrent dictionary and contains a mapping from a key for the client to the http client itself. GraphHttpClientFactory The HTTP graph client factory. GraphProperty The IGraphProperty helpers and extensions. GraphRequest GraphRequest The base of the exchange of a IGraphRequest or IGraphResponse . GraphRequestExtensions Extensions for IGraphRequest class. GraphResponse GraphResponse The base of the exchange of a IGraphRequest or IGraphResponse . GraphResponseException Class representing GraphResponseException GraphResponseExtensions Extensions for IGraphResponse class. HttpRequestMessageExtensions Extensions for HttpRequestMessage . HttpResponseMessageExtensions Extensions for HttpResponseMessage class. NoContentMessage IGraphClient requires type parameters for functionality. This is a marked Type/class to make function calls to IGraphClient indicating we have request/response with no body. The sole purpose of this class's existence is to reduce code duplicacy. Structs GraphProperty Interfaces IGraphClient This class abstracts any communication with different services. This client acts at an object level rather than wire level and thus providing richer experience when working with complex objects. IGraphClientFactory Interface for factory of IGraphClient . IGraphExchange The base of the exchange of a IGraphRequest or IGraphResponse . IGraphExchange The base of the exchange of a IGraphRequest or IGraphResponse . IGraphHttpClient Interface for Http transport client. Gives us a way to work with different instances of GraphClient through Dependency Injection. IGraphProperty The graph property containing request or response data. IGraphProperty IGraphRequest The request object used by the graph sdk. IGraphRequest The request object with content. IGraphResponse The response got in exchange of a IGraphRequest . IGraphResponse The response got in exchange of a IGraphRequest . Enums RequestType Type of request that we want to issue on the transport ResponseStatus Different status of IGraphResponse ." }, - "bot_media/Microsoft.Skype.Bots.Media.VideoMetrics.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoMetrics.html", - "title": "Class VideoMetrics", - "keywords": "Class VideoMetrics Video-specific quality of experience metrics Inheritance Object VideoMetrics Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoMetrics Constructors VideoMetrics() Declaration public VideoMetrics() Properties AverageInboundBitRatePerSecond Average bit rate on the inbound video stream, expressed in bits per second Declaration public uint AverageInboundBitRatePerSecond { get; set; } Property Value Type Description UInt32 AverageInboundFrameRatePerSecond Average frame rate on the inbound video stream, expressed in frames per second Declaration public double AverageInboundFrameRatePerSecond { get; set; } Property Value Type Description Double AverageOutboundBitRatePerSecond Average bit rate on the outbound video stream, expressed in bits per second Declaration public uint AverageOutboundBitRatePerSecond { get; set; } Property Value Type Description UInt32 AverageOutboundFrameRatePerSecond Average frame rate on the outbound video stream, expressed in frames per second Declaration public double AverageOutboundFrameRatePerSecond { get; set; } Property Value Type Description Double" + "common/Microsoft.Graph.Communications.Common.Transport.GraphProperty.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphProperty.html", + "title": "Class GraphProperty", + "keywords": "Class GraphProperty The IGraphProperty helpers and extensions. Inheritance Object GraphProperty Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class GraphProperty Fields ContentType The content type Declaration public const string ContentType = \"content\" Field Value Type Description String RequestType The request type Declaration public const string RequestType = \"request\" Field Value Type Description String Methods Add(ICollection, String, Object, String) Adds the property to the exchange. Declaration public static IGraphProperty Add(this ICollection properties, string key, object value, string type = null) Parameters Type Name Description ICollection < IGraphProperty > properties The properties. String key The key. Object value The value. String type The type. Returns Type Description IGraphProperty The added IGraphProperty . Add(ICollection, String, T, String) Adds the property to the exchange. Declaration public static IGraphProperty Add(this ICollection properties, string key, T value, string type = null) Parameters Type Name Description ICollection < IGraphProperty > properties The properties. String key The key. T value The value. String type The type. Returns Type Description IGraphProperty The added IGraphProperty . Type Parameters Name Description T The expected type of the property. Contains(IEnumerable, String) Finds the property in the given exchange. Declaration public static bool Contains(this IEnumerable properties, string key) Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String key The key. Returns Type Description Boolean The found IGraphProperty . ContentProperty(String, Object) Creates the property of content type. Declaration public static IGraphProperty ContentProperty(string key, object value) Parameters Type Name Description String key The key. Object value The values. Returns Type Description IGraphProperty The content IGraphProperty . ContentProperty(String, T) Creates the property of content type. Declaration public static IGraphProperty ContentProperty(string key, T value) Parameters Type Name Description String key The key. T value The values. Returns Type Description IGraphProperty The content IGraphProperty . Type Parameters Name Description T The type of the property to create. ConvertProperty(IGraphProperty) Converts the property. Declaration public static IGraphProperty ConvertProperty(this IGraphProperty property) Parameters Type Name Description IGraphProperty property The property. Returns Type Description IGraphProperty The IGraphProperty with the expected generic type if the types match, null otherwise. Type Parameters Name Description T The type of value expected. Find(IEnumerable, String) Finds the property in the given exchange. Declaration public static IGraphProperty Find(this IEnumerable properties, string key) Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String key The key. Returns Type Description IGraphProperty The found IGraphProperty . Find(IEnumerable, String) Finds the property in the given exchange. Declaration public static IGraphProperty Find(this IEnumerable properties, string key) Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String key The key. Returns Type Description IGraphProperty The found IGraphProperty . Type Parameters Name Description T The expected type of the property. Property(String, Object, String) Creates a property of the specified type. Declaration public static IGraphProperty Property(string key, object value, string type = null) Parameters Type Name Description String key The key. Object value The values. String type The type. Returns Type Description IGraphProperty The created IGraphProperty . Property(String, T, String) Creates a property of the specified type. Declaration public static IGraphProperty Property(string key, T value, string type = null) Parameters Type Name Description String key The key. T value The value. String type The type. Returns Type Description IGraphProperty The created IGraphProperty . Type Parameters Name Description T The type of the property to create. RequestProperty(String, Object) Creates the property of request type. Declaration public static IGraphProperty RequestProperty(string key, object value) Parameters Type Name Description String key The key. Object value The value. Returns Type Description IGraphProperty The request IGraphProperty . RequestProperty(String, T) Creates the property of request type. Declaration public static IGraphProperty RequestProperty(string key, T value) Parameters Type Name Description String key The key. T value The value. Returns Type Description IGraphProperty The request IGraphProperty . Type Parameters Name Description T The type of the property to create. See Also IGraphProperty IGraphProperty" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.LogEvent.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LogEvent.html", - "title": "Class LogEvent", - "keywords": "Class LogEvent Log data Inheritance Object LogEvent Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class LogEvent Constructors LogEvent() Declaration public LogEvent() Properties CallerInfo Gets or sets the caller information Declaration public CallerInfo CallerInfo { get; set; } Property Value Type Description CallerInfo CallerInfoString Gets the caller information string. Declaration public string CallerInfoString { get; } Property Value Type Description String Component Gets or sets the component in which the log is created. Declaration public string Component { get; set; } Property Value Type Description String CorrelationId Gets or sets the correlation id Declaration public Guid CorrelationId { get; set; } Property Value Type Description Guid EventType Gets or sets the type of the event. Declaration public LogEventType EventType { get; set; } Property Value Type Description LogEventType Level Gets or sets the trace level of the event. Declaration public TraceLevel Level { get; set; } Property Value Type Description TraceLevel LogicalThreadId Gets or sets the logical thread identifier. Declaration public uint LogicalThreadId { get; set; } Property Value Type Description UInt32 ManagedThreadId Gets or sets the thread ID. Declaration public int ManagedThreadId { get; set; } Property Value Type Description Int32 Message Gets or sets the Description of the event. Declaration public string Message { get; set; } Property Value Type Description String ProcessId Gets or sets the process ID. Declaration public int ProcessId { get; set; } Property Value Type Description Int32 Properties Gets or sets the Custom properties for the event. Declaration public IReadOnlyDictionary Properties { get; set; } Property Value Type Description IReadOnlyDictionary < Type , Object > PropertiesString Gets the custom properties in string format. Declaration public string PropertiesString { get; } Property Value Type Description String RequestId Gets or sets the request identifier. Declaration public Guid RequestId { get; set; } Property Value Type Description Guid Timestamp Gets or sets the Timestamp of the event. Declaration public DateTime Timestamp { get; set; } Property Value Type Description DateTime Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) LoggingExtensions.GetTypedProperties(LogEvent, Type) LoggingExtensions.GetTypedProperty(LogEvent)" + "client/Microsoft.Graph.Communications.Client.GraphLoggerExtensions.html": { + "href": "client/Microsoft.Graph.Communications.Client.GraphLoggerExtensions.html", + "title": "Class GraphLoggerExtensions", + "keywords": "Class GraphLoggerExtensions The graph logger extensions for the communications client. Inheritance Object GraphLoggerExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public static class GraphLoggerExtensions Methods LogHttpRequest(IGraphLogger, HttpRequestMessage, HttpStatusCode, Object, Exception, String, String, Int32) Logs the request message. Declaration public static TraceLevel LogHttpRequest(this IGraphLogger logger, HttpRequestMessage request, HttpStatusCode statusCode, object requestContent = null, Exception exception = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. HttpRequestMessage request The request. HttpStatusCode statusCode The status code. Object requestContent The request content. Exception exception The exception. String memberName The member name. String filePath The file path. Int32 lineNumber The line number. Returns Type Description TraceLevel The trace level of the logged request message. LogHttpResponse(IGraphLogger, TraceLevel, HttpRequestMessage, HttpResponseMessage, Int64, Object, String, String, Int32) Logs the http response message. Declaration public static void LogHttpResponse(this IGraphLogger logger, TraceLevel level, HttpRequestMessage request, HttpResponseMessage response, long responseTime, object responseContent = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. TraceLevel level The log level. HttpRequestMessage request The request. HttpResponseMessage response The response. Int64 responseTime The response time in milliseconds. Object responseContent The response content. String memberName The member name. String filePath The file path. Int32 lineNumber The line number. ParseRequestId(IGraphLogger, HttpRequestMessage) Parses the request identifier. Declaration public static Guid ParseRequestId(this IGraphLogger logger, HttpRequestMessage request) Parameters Type Name Description IGraphLogger logger The logger. HttpRequestMessage request The request. Returns Type Description Guid The message id. ParseScenarioId(IGraphLogger, HttpRequestMessage) Parses the scenario identifier. Declaration public static Guid ParseScenarioId(this IGraphLogger logger, HttpRequestMessage request) Parameters Type Name Description IGraphLogger logger The logger. HttpRequestMessage request The request. Returns Type Description Guid The scenario id." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventFormatterFlags.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventFormatterFlags.html", - "title": "Enum LogEventFormatterFlags", - "keywords": "Enum LogEventFormatterFlags The log event formatter enums Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum LogEventFormatterFlags Fields Name Description ForDefault For default case, which includes all fields. ForILoggerFactory For ILoggerFactory binding format, which doesn't include component and level, as these fields are set in ILogger outside of message. IncludeManagedThreadId Managed thread ID IncludeProcessId Process ID IncludesCallInfo Call info IncludesComponent Component IncludesCorrelationId Correlation ID IncludesLevel Level IncludesProperties Properties IncludesTimestamp Timestamp Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(LogEventFormatterFlags, String, String) Validator.Equals(LogEventFormatterFlags, String) Validator.NotEquals(LogEventFormatterFlags, String, String)" + "client/Microsoft.Graph.Communications.Client.CommunicationsClientExtensions.html": { + "href": "client/Microsoft.Graph.Communications.Client.CommunicationsClientExtensions.html", + "title": "Class CommunicationsClientExtensions", + "keywords": "Class CommunicationsClientExtensions Extensions for Stateful Client. Inheritance Object CommunicationsClientExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public static class CommunicationsClientExtensions Methods CreateResponse(ICommunicationsClient, HttpStatusCode, Guid, Guid, Object) Creates the response. Declaration public static HttpResponseMessage CreateResponse(this ICommunicationsClient client, HttpStatusCode statusCode, Guid requestId, Guid scenarioId, object responseContent = null) Parameters Type Name Description ICommunicationsClient client The client. HttpStatusCode statusCode The status code. Guid requestId The request identifier. Guid scenarioId The scenario identifier. Object responseContent The response content. Returns Type Description HttpResponseMessage The HTTP response. LogAndCreateResponse(ICommunicationsClient, HttpRequestMessage, Guid, Guid, CommsNotifications, HttpStatusCode, Stopwatch, Exception) Logs the request, creates the response, and logs the response. Declaration public static HttpResponseMessage LogAndCreateResponse(this ICommunicationsClient client, HttpRequestMessage request, Guid requestId, Guid scenarioId, CommsNotifications notifications, HttpStatusCode statusCode, Stopwatch stopwatch, Exception exception = null) Parameters Type Name Description ICommunicationsClient client The client. HttpRequestMessage request The request. Guid requestId The request identifier. Guid scenarioId The scenario identifier. CommsNotifications notifications The notifications that were extracted. HttpStatusCode statusCode The status code. Stopwatch stopwatch The stopwatch tracking how long the request is taking. Exception exception Any exceptions raised. Returns Type Description HttpResponseMessage The response for the associated request. ProcessNotificationAsync(ICommunicationsClient, HttpRequestMessage) Processes the notifications and raises the required callbacks. This function should be called in order for the SDK to raise any required events and process state changes. Declaration public static Task ProcessNotificationAsync(this ICommunicationsClient client, HttpRequestMessage request) Parameters Type Name Description ICommunicationsClient client The stateful client. HttpRequestMessage request The http request that is incoming from service. Returns Type Description Task < HttpResponseMessage > Http Response Message after processed by the SDK. This has to be returned to the server." }, - "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.html": { - "href": "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.html", - "title": "Class CommsGeneratedErrorConstants", - "keywords": "Class CommsGeneratedErrorConstants The generated error constants. Inheritance Object CommsGeneratedErrorConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class CommsGeneratedErrorConstants" + "calls_media/Microsoft.Graph.Communications.Calls.Media.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.html", + "title": "Namespace Microsoft.Graph.Communications.Calls.Media", + "keywords": "Namespace Microsoft.Graph.Communications.Calls.Media Classes AudioSendBuffer Creates an Audio Buffer for Send and also implements Dispose MediaCallExtensions Stateful call media extensions MediaCommunicationsClientBuilderExtensions The stateful client builder extension. MediaCommunicationsClientExtensions The stateful client extension. MediaSession MediaSession.MediaProperties Gets the media properties. VideoSendBuffer Creates a Video Buffer for Send and also implements Dispose Interfaces ILocalMediaSession" }, - "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.Codes.html": { - "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.Codes.html", - "title": "Class ErrorConstants.Codes", - "keywords": "Class ErrorConstants.Codes Error Codes Inheritance Object ErrorConstants.Codes Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Codes Fields BridgeGone Error code indicating the bridge is gone/deleted from the server. Declaration public const string BridgeGone = \"BridgeGone\" Field Value Type Description String ChatGone Error code indicating the chat is gone/deleted from the server. Declaration public const string ChatGone = \"ChatGone\" Field Value Type Description String ClientCallbackError The client callback error code. Declaration public const string ClientCallbackError = \"clientCallbackError\" Field Value Type Description String ClientContextMissing The client context missing error code. Declaration public const string ClientContextMissing = \"clientContextIsMissing\" Field Value Type Description String GeneralException The general exception error code. Declaration public const string GeneralException = \"generalException\" Field Value Type Description String InvalidRequest The invalid request error code. Declaration public const string InvalidRequest = \"invalidRequest\" Field Value Type Description String ItemNotFound The item not found error code. Declaration public const string ItemNotFound = \"itemNotFound\" Field Value Type Description String MismatchedCompletedOperation The mismatched completed operation error code. Declaration public const string MismatchedCompletedOperation = \"mismatchedCompletedOperation\" Field Value Type Description String NotAllowed The not allowed error code. Declaration public const string NotAllowed = \"notAllowed\" Field Value Type Description String OperationFailed The operation failed error code. Declaration public const string OperationFailed = \"operationFailed\" Field Value Type Description String RehydrationFailedWithEmptyResource The re-hydration failed with empty resource error code. Declaration public const string RehydrationFailedWithEmptyResource = \"rehydrationFailedWithEmptyResource\" Field Value Type Description String RehydrationFailedWithNotFound The re-hydration failed with not found error code. Declaration public const string RehydrationFailedWithNotFound = \"rehydrationFailedWithNotFound\" Field Value Type Description String Timeout The timeout error code. Declaration public const string Timeout = \"timeout\" Field Value Type Description String TooManyRedirects The too many redirects error code. Declaration public const string TooManyRedirects = \"tooManyRedirects\" Field Value Type Description String" + "core/Microsoft.Graph.Communications.Core.Serialization.html": { + "href": "core/Microsoft.Graph.Communications.Core.Serialization.html", + "title": "Namespace Microsoft.Graph.Communications.Core.Serialization", + "keywords": "Namespace Microsoft.Graph.Communications.Core.Serialization Classes CommsSerializer An interface for serializing and deserializing JSON objects. This serializer is used throughout the Communications workload to provide extra functionality. Specifically it supports more robust serialization/deserialization of @odata.type property and deserialization of open type additional data." }, - "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.Messages.html": { - "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.Messages.html", - "title": "Class ErrorConstants.Messages", - "keywords": "Class ErrorConstants.Messages Error Messages Inheritance Object ErrorConstants.Messages Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Messages Fields AuthenticationProviderMissing The authentication provider missing Declaration public const string AuthenticationProviderMissing = \"Authentication provider is required before sending a request.\" Field Value Type Description String BaseUrlMissing The base URL missing Declaration public const string BaseUrlMissing = \"Base URL cannot be null or empty.\" Field Value Type Description String ClientErrorAuthenticatingRequest The client error processing notifications Declaration public const string ClientErrorAuthenticatingRequest = \"Unexpected exception happened on client when authenticating request.\" Field Value Type Description String ClientErrorProcessingNotifications The client error processing notifications Declaration public const string ClientErrorProcessingNotifications = \"Unexpected exception happened on client when processing notification.\" Field Value Type Description String InvalidTypeForDateConverter The invalid type for date converter Declaration public const string InvalidTypeForDateConverter = \"DateConverter can only serialize objects of type Date.\" Field Value Type Description String LocationHeaderNotSetOnRedirect The location header not set on redirect Declaration public const string LocationHeaderNotSetOnRedirect = \"Location header not present in redirection response.\" Field Value Type Description String MessageContentIsEmpty The message content is empty Declaration public const string MessageContentIsEmpty = \"Unexpected empty message content.\" Field Value Type Description String NotificationChangeTypeIsEmpty The notification change type is empty Declaration public const string NotificationChangeTypeIsEmpty = \"No change type specified for the incoming notification.\" Field Value Type Description String NotificationResourceDataIsEmpty The notification resource data is empty Declaration public const string NotificationResourceDataIsEmpty = \"No resource data specified for the incoming notification.\" Field Value Type Description String NotificationResourceNotRecognized The notification resource is not recognized Declaration public const string NotificationResourceNotRecognized = \"Resource in notification is not recognized.\" Field Value Type Description String NotificationResourcePathIsEmpty The notification resource path is empty Declaration public const string NotificationResourcePathIsEmpty = \"No resource path specified for the incoming notification.\" Field Value Type Description String NotificationsAreEmpty The notifications are empty Declaration public const string NotificationsAreEmpty = \"Notifications received from server are empty.\" Field Value Type Description String NotificationUriNotSet The notification URI not set Declaration public const string NotificationUriNotSet = \"Notification URI is not set for the resource.\" Field Value Type Description String OverallTimeoutCannotBeSet The overall timeout cannot be set Declaration public const string OverallTimeoutCannotBeSet = \"Overall timeout cannot be set after the first request is sent.\" Field Value Type Description String RehydrationFailedNotFound The re-hydration failed not found Declaration public const string RehydrationFailedNotFound = \"Rehydration is performed on a resource that doesn't exist.\" Field Value Type Description String RehydrationFailedWithEmptyResource The re-hydration failed with empty resource Declaration public const string RehydrationFailedWithEmptyResource = \"Rehydration failed since service returned an empty resource.\" Field Value Type Description String RequestTimedOut The request timed out Declaration public const string RequestTimedOut = \"The request timed out.\" Field Value Type Description String RequestUrlMissing The request URL missing Declaration public const string RequestUrlMissing = \"Request URL is required to send a request.\" Field Value Type Description String TooManyRedirectsFormatString The too many redirects format string Declaration public const string TooManyRedirectsFormatString = \"More than {0} redirects encountered while sending the request.\" Field Value Type Description String UnableToCreateInstanceOfTypeFormatString The unable to create instance of type format string Declaration public const string UnableToCreateInstanceOfTypeFormatString = \"Unable to create an instance of type {0}.\" Field Value Type Description String UnableToDeserializeNotification The unable to deserialize notification Declaration public const string UnableToDeserializeNotification = \"Unable to deserialize the notification.\" Field Value Type Description String UnexpectedExceptionOnSend The unexpected exception on send Declaration public const string UnexpectedExceptionOnSend = \"An error occurred sending the request.\" Field Value Type Description String UnexpectedExceptionResponse The unexpected exception response Declaration public const string UnexpectedExceptionResponse = \"Unexpected exception returned from the service.\" Field Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClient.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClient.html", + "title": "Class GraphHttpClient", + "keywords": "Class GraphHttpClient Graph client that handles transport over http. Inheritance Object ObjectRoot GraphHttpClient Implements IGraphHttpClient IGraphClient Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphHttpClient : ObjectRoot, IGraphHttpClient, IGraphClient Constructors GraphHttpClient(IGraphLogger, JsonSerializerSettings, HttpClient, Int32, String, ProductInfoHeaderValue, IEnumerable, String) Initializes a new instance of the GraphHttpClient class. Declaration public GraphHttpClient(IGraphLogger logger, JsonSerializerSettings jsonSerializerSettings = null, HttpClient httpClient = null, int numberOfRetries = 3, string correlationIdHeader = null, ProductInfoHeaderValue userAgent = null, IEnumerable defaultProperties = null, string metricName = \"PartnerHttpRequests\") Parameters Type Name Description IGraphLogger logger The logger. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. HttpClient httpClient The HTTP client. Int32 numberOfRetries The number of retries. String correlationIdHeader The correlation identifier header. ProductInfoHeaderValue userAgent The user agent. IEnumerable < IGraphProperty > defaultProperties The default properties. String metricName The metric name. Properties CustomRedirectUriGenerator Gets or sets the custom redirect URI generator. This is called in case of a redirect (3XX) response from the request. Clients can use this to read the response and give the new redirect url to call in the next request. Declaration public Func CustomRedirectUriGenerator { get; set; } Property Value Type Description Func < HttpResponseMessage , Uri > The custom redirect URI generator. DefaultProperties Gets the default properties. Declaration public IEnumerable DefaultProperties { get; } Property Value Type Description IEnumerable < IGraphProperty > GraphLogger Gets the graph logger. Declaration public IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger SerializerSettings Gets the serializer settings. Declaration public JsonSerializerSettings SerializerSettings { get; } Property Value Type Description Newtonsoft.Json.JsonSerializerSettings Methods Clone(HttpClient) Clones this instance with optional overrides. Declaration public IGraphHttpClient Clone(HttpClient httpClient = null) Parameters Type Name Description HttpClient httpClient The HTTP client to replace the original. Returns Type Description IGraphHttpClient Cloned client with the updated properties. InitializeServicePointSettings() Initializes global service point settings. Declaration public static void InitializeServicePointSettings() LogRequest(TraceLevel, HttpRequestMessage, Object, String, String, Int32) Logs the request message. Declaration protected void LogRequest(TraceLevel level, HttpRequestMessage httpRequest, object content = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The level. HttpRequestMessage httpRequest The http request to log. Object content The response time. String memberName Name of the member. String filePath The file path. Int32 lineNumber The line number. LogResponse(TraceLevel, HttpRequestMessage, Int64, HttpResponseMessage, Object, Exception, String, String, Int32) Logs the response message. Declaration protected void LogResponse(TraceLevel level, HttpRequestMessage httpRequest, long responseTime, HttpResponseMessage httpResponse = null, object content = null, Exception exception = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The level. HttpRequestMessage httpRequest The http request to log. Int64 responseTime The response time. HttpResponseMessage httpResponse The http response to log. Object content The content to log. Exception exception The exception to log. String memberName Name of the member. String filePath The file path. Int32 lineNumber The line number. SendAsync(IGraphRequest, CancellationToken) Declaration public Task SendAsync(IGraphRequest graphRequest, CancellationToken cancellationToken = default(CancellationToken)) where T : class Parameters Type Name Description IGraphRequest graphRequest CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T SendAsync(IGraphRequest, CancellationToken) Declaration public Task> SendAsync(IGraphRequest graphRequest, CancellationToken cancellationToken = default(CancellationToken)) where T1 : class where T2 : class Parameters Type Name Description IGraphRequest graphRequest CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T1 T2 SendHttpRequestAsync(IGraphRequest, CancellationToken) Sends the request asynchronously. We only retry if the Http request fails with an exception. We do not retry in case of error response returned from the request. Declaration protected virtual Task> SendHttpRequestAsync(IGraphRequest graphRequest, CancellationToken cancellationToken) where T1 : class where T2 : class Parameters Type Name Description IGraphRequest graphRequest The request to be sent out. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IGraphResponse > HttpResponseMessage received for the graphRequest . Type Parameters Name Description T1 Type of the content present in the request. T2 Type of the expected content in response. SendRawHttpRequestAsync(HttpRequestMessage, CancellationToken) Send a Http request as an asynchronous operation. The content sent using this is not parsed or logged. Declaration public Task SendRawHttpRequestAsync(HttpRequestMessage httpRequest, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description HttpRequestMessage httpRequest The http request message to send. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < HttpResponseMessage > The task object representing the asynchronous operation. Implements IGraphHttpClient IGraphClient Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also IGraphHttpClient" }, - "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.CallData.html": { - "href": "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.CallData.html", - "title": "Class LogProperties.CallData", - "keywords": "Class LogProperties.CallData Call data. Inheritance Object LogProperties.CallData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class CallData Constructors CallData() Declaration public CallData() Properties CallId Gets or sets the call identifier. Declaration public string CallId { get; set; } Property Value Type Description String TenantId Gets or sets the tenant identifier. Declaration public string TenantId { get; set; } Property Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClientContainer.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClientContainer.html", + "title": "Class GraphHttpClientContainer", + "keywords": "Class GraphHttpClientContainer This class is used to handle multiple http clients within one service. This class extends the concurrent dictionary and contains a mapping from a key for the client to the http client itself. Inheritance Object ConcurrentDictionary < String , IGraphHttpClient > GraphHttpClientContainer Implements IDictionary < String , IGraphHttpClient > ICollection < KeyValuePair < String , IGraphHttpClient >> IDictionary ICollection IReadOnlyDictionary < String , IGraphHttpClient > IReadOnlyCollection < KeyValuePair < String , IGraphHttpClient >> IEnumerable < KeyValuePair < String , IGraphHttpClient >> IEnumerable Inherited Members ConcurrentDictionary.TryAdd(String, IGraphHttpClient) ConcurrentDictionary.ContainsKey(String) ConcurrentDictionary.TryRemove(String, IGraphHttpClient) ConcurrentDictionary.TryGetValue(String, IGraphHttpClient) ConcurrentDictionary.TryUpdate(String, IGraphHttpClient, IGraphHttpClient) ConcurrentDictionary.Clear() System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.CopyTo(System.Collections.Generic.KeyValuePair[], System.Int32) ConcurrentDictionary.ToArray() ConcurrentDictionary.GetEnumerator() ConcurrentDictionary.GetOrAdd(String, Func) ConcurrentDictionary.GetOrAdd(String, IGraphHttpClient) ConcurrentDictionary.GetOrAdd(String, Func, TArg) ConcurrentDictionary.AddOrUpdate(String, Func, Func, TArg) ConcurrentDictionary.AddOrUpdate(String, Func, Func) ConcurrentDictionary.AddOrUpdate(String, IGraphHttpClient, Func) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.IDictionary.Add(System.String, Microsoft.Graph.Communications.Common.Transport.IGraphHttpClient) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.IDictionary.Remove(System.String) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.Add(System.Collections.Generic.KeyValuePair) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.Contains(System.Collections.Generic.KeyValuePair) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.Remove(System.Collections.Generic.KeyValuePair) ConcurrentDictionary.IEnumerable.GetEnumerator() ConcurrentDictionary.IDictionary.Add(Object, Object) ConcurrentDictionary.IDictionary.Contains(Object) ConcurrentDictionary.IDictionary.GetEnumerator() ConcurrentDictionary.IDictionary.Remove(Object) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.IDictionary.get_Item(System.Object) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.IDictionary.set_Item(System.Object, System.Object) ConcurrentDictionary.ICollection.CopyTo(Array, Int32) ConcurrentDictionary.Item[String] ConcurrentDictionary.Count ConcurrentDictionary.IsEmpty ConcurrentDictionary.Keys System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.IReadOnlyDictionary.Keys ConcurrentDictionary.Values System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.IReadOnlyDictionary.Values System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.IsReadOnly ConcurrentDictionary.IDictionary.IsFixedSize ConcurrentDictionary.IDictionary.IsReadOnly ConcurrentDictionary.IDictionary.Keys ConcurrentDictionary.IDictionary.Values ConcurrentDictionary.IDictionary.Item[Object] ConcurrentDictionary.ICollection.IsSynchronized ConcurrentDictionary.ICollection.SyncRoot Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphHttpClientContainer : ConcurrentDictionary, IDictionary, ICollection>, IDictionary, ICollection, IReadOnlyDictionary, IReadOnlyCollection>, IEnumerable>, IEnumerable Constructors GraphHttpClientContainer(IGraphHttpClient) Initializes a new instance of the GraphHttpClientContainer class. Declaration public GraphHttpClientContainer(IGraphHttpClient defaultGraphHttpClient) Parameters Type Name Description IGraphHttpClient defaultGraphHttpClient The default graph HTTP client. Properties DefaultGraphHttpClient Gets the default graph HTTP client. Declaration public IGraphHttpClient DefaultGraphHttpClient { get; } Property Value Type Description IGraphHttpClient Implements System.Collections.Generic.IDictionary System.Collections.Generic.ICollection System.Collections.IDictionary System.Collections.ICollection System.Collections.Generic.IReadOnlyDictionary System.Collections.Generic.IReadOnlyCollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) CollectionUtils.ForEach(IEnumerable, Action) CollectionUtils.ForEachParallel(IEnumerable, Action, IGraphLogger) CollectionUtils.GetValueOrDefault(IDictionary, TKey) CollectionUtils.GetValueOrDefault(IDictionary, TKey, TValue) CollectionUtils.AddRange(ICollection, IEnumerable) CollectionUtils.ToSortedList(IEnumerable, Func) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.Any(IEnumerable) Validator.FirstObject(IEnumerable, Func) Validator.FirstObject(IEnumerable) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.NotEmpty(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) Validator.VerifyNotContainsKey(IDictionary, TK) Validator.VerifyContainsKey(IDictionary, TK) Validator.VerifyContainsKey(IReadOnlyDictionary, TK) Validator.VerifyContains(IEnumerable, T)" }, - "common/Microsoft.Graph.AdditionalDataExtensions.html": { - "href": "common/Microsoft.Graph.AdditionalDataExtensions.html", - "title": "Class AdditionalDataExtensions", - "keywords": "Class AdditionalDataExtensions The identity set extensions Inheritance Object AdditionalDataExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class AdditionalDataExtensions Methods GetValue(IDictionary, String, T) Gets the object using the key from additional data. Declaration public static T GetValue(this IDictionary additionalData, string key, T default = null) Parameters Type Name Description IDictionary < String , Object > additionalData The additional data. String key The key. T default The default value if value could not be parsed. Returns Type Description T /// The converted value. Type Parameters Name Description T The expected type for the specified key. SetInAdditionalData(Object, String, Object) Sets the object with given key in additional data. Declaration public static void SetInAdditionalData(this object obj, string key, object value) Parameters Type Name Description Object obj The identity. String key The key. Object value The value." + "client/Microsoft.Graph.Communications.Resources.IResource-2.html": { + "href": "client/Microsoft.Graph.Communications.Resources.IResource-2.html", + "title": "Interface IResource", + "keywords": "Interface IResource The stateful resource interface. Inherited Members IResource.Id IResource.ModifiedDateTime IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResource : IResource, IResourceBase, IDisposable where TSelf : IResource where TEntity : Entity Type Parameters Name Description TSelf The self type of the resource. TEntity The containing Entity type. Properties Resource Gets the resource. Declaration TEntity Resource { get; } Property Value Type Description TEntity Events OnUpdated Event fired when this resource has been updated. Declaration event ResourceEventHandler OnUpdated Event Type Type Description ResourceEventHandler See Also IResource" }, - "bot_media/Microsoft.Skype.Bots.Media.AudioMediaReceivedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioMediaReceivedEventArgs.html", - "title": "Class AudioMediaReceivedEventArgs", - "keywords": "Class AudioMediaReceivedEventArgs Event arguments of an AudioMediaReceived event. Inheritance Object EventArgs AudioMediaReceivedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioMediaReceivedEventArgs : EventArgs Constructors AudioMediaReceivedEventArgs() Declaration public AudioMediaReceivedEventArgs() Properties Buffer The received audio media buffer. Declaration public AudioMediaBuffer Buffer { get; set; } Property Value Type Description AudioMediaBuffer" + "common/Microsoft.Graph.Communications.Common.EnumUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.EnumUtils.html", + "title": "Class EnumUtils", + "keywords": "Class EnumUtils Enum Utilities Inheritance Object EnumUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class EnumUtils Methods GetDescription(Enum) Gets the enum's description attribute. Declaration public static string GetDescription(this Enum value) Parameters Type Name Description Enum value The value. Returns Type Description String Enum's description Parse(String) Parses the string into enum Declaration public static TEnum Parse(string value) where TEnum : struct, IComparable, IFormattable, IConvertible Parameters Type Name Description String value input string Returns Type Description TEnum Enum's parsed value Type Parameters Name Description TEnum Enum's type to output" }, - "bot_media/Microsoft.Skype.Bots.Media.DataMediaBuffer.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.DataMediaBuffer.html", - "title": "Class DataMediaBuffer", - "keywords": "Class DataMediaBuffer Reserved for the internal use. Inheritance Object DataMediaBuffer Implements IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public abstract class DataMediaBuffer : IDisposable Constructors DataMediaBuffer() Declaration protected DataMediaBuffer() Properties Data Reserved for the internal use. Declaration public byte[] Data { get; protected set; } Property Value Type Description Byte [] MediaSourceId Reserved for the internal use. Declaration public uint MediaSourceId { get; protected set; } Property Value Type Description UInt32 Methods Dispose() Reserved for the internal use. Declaration public void Dispose() Dispose(Boolean) Reserved for the internal use. Declaration protected abstract void Dispose(bool disposing) Parameters Type Name Description Boolean disposing Implements System.IDisposable" + "index.html": { + "href": "index.html", + "title": "Graph Communications Calling SDK", + "keywords": "Graph Communications Calling SDK Introduction The Graph Communications Calling SDK simplifies the creation of calling and meetings bots that use the Cloud Communications APIs . The SDK provides the functionality to manage states of resources in memory and simplify tasks like call setup and media session establishment. It provides interfaces for bot's service-to-service interactions with calls and meetings, including an optional Media Extension SDK that enables a bot developer to host media on their machines and gain access to low level Audio/Video sockets and media streams. SDK The Graph Communications Calling SDK is built on top of the Microsoft Graph API and distributed as NuGet packages. The Core Concepts article is designed to better explain all the constructs used by the SDKs. To dive right in and deploy a Calling Bot refer to the documentation in each sample for further instructions. The SDK is divided into multiple nuget packages each described as below. Microsoft.Graph.Communications.Common ( nuget ): This is the nuget containing all the utilities used throughout the Stateful SDK. It contains telemetry, http, obfuscation support along with helper methods. Microsoft.Graph.Communications.Core ( nuget ): This library contains the serialization and notification for the communications APIs. Microsoft.Graph.Communications.Client ( nuget ): This is the base client for the Stateful SDK. This implements all the common SDK features used within different verticals like calling, etc. Microsoft.Graph.Communications.Calls ( nuget ): This is the SDK that implements calling APIs. This supports making, receiving, and joining calls with Microsoft Teams users, and creating voice and video enabled bots. Microsoft.Graph.Communications.Calls.Media ( nuget ): This library allows developers to use the Microsoft.Graph.Communications.Calls SDK and gain direct access to the audio, video, screen sharing, and data streams. This is an optional library on top of Microsoft.Graph.Communications.Calls Microsoft.Skype.Bots.Media ( nuget ): The Real-Time Media Platform for Bots adds a new dimension to how bots can interact with users: by enabling real-time voice, video and screen sharing modalities. Concepts and Examples For more details on concepts used by the SDK and examples on joining calls and receiving calls please refer to the concepts and examples page. You can find samples using the following service: Stateful bot using Application Hosted Media on Azure Cloud Service Stateful bot using Application Hosted Media on Azure Service Fabric Stateful bot using Service Hosted Media running on Azure App Service . ICommunicationsClient and Extension Methods The Stateful SDK is exposed using a single class @Microsoft.Graph.Communications.Client.ICommunicationsClient. This class is defined in the Microsoft.Graph.Communications.Client nuget and has no dependency on the Microsoft.Graph.Communications.Calls calling vertical nuget package. The different verticals therefore make heavy usage of extension methods on ICommunicationsClient rather than standalone functions or properties. The intention here is to add new verticals into the ICommunicationsClient using the same pattern without the ICommunicationsClient itself taking a dependency on the new vertical's nuget, which provides greater decoupling between future verticals we will support. For a usage example please see the ICommunicationsClient.Calls() extension method. Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." }, - "bot_media/Microsoft.Skype.Bots.Media.DataSocketSettings.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.DataSocketSettings.html", - "title": "Class DataSocketSettings", - "keywords": "Class DataSocketSettings Reserved for the internal use. Inheritance Object DataSocketSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class DataSocketSettings Constructors DataSocketSettings() Reserved for the internal use. Declaration public DataSocketSettings() Properties CallId Reserved for the internal use. Declaration public string CallId { get; set; } Property Value Type Description String ReceiveDataType Reserved for the internal use. Declaration public DataType ReceiveDataType { get; set; } Property Value Type Description DataType SendDataType Reserved for the internal use. Declaration public DataType SendDataType { get; set; } Property Value Type Description DataType StreamDirections Reserved for the internal use. Declaration public StreamDirection StreamDirections { get; set; } Property Value Type Description StreamDirection" + "articles/index.html": { + "href": "articles/index.html", + "title": "Graph Core and Communications SDK Concepts", + "keywords": "Graph Core and Communications SDK Concepts The Graph signaling SDK is quite flexible and can run in multiple environments, and support both stateful and stateless architectures. It can run on Azure Cloud Service , Azure Service Fabric , and Azure App Service . Furthermore, because the SDK supports both .net framework 4.6.1+ and netstandard 2.0 it is cross platform . This article describes the key concepts in order to effectively utilize the Graph Core SDK and the Graph Communications SDK including the Calling SDK. Graph Communications Core SDK The GraphServiceClient object is the entry point to the Graph Core SDK. The majority of the Graph Core SDK is automatically generated by the Graph SDK generator using the OData resource model. It reflects the REST-ful wire protocol provided by the Graph Communications service. Graph Communications Stateful SDK and Client Builder The @Microsoft.Graph.Communications.Client.ICommunicationsClient object is the entry point to the Graph Communications SDK and the Calling SDK. This SDK is designed for stateful services and provides additional support on top of the Graph Core SDK for resource state management and media management. The @Microsoft.Graph.Communications.Client.ICommunicationsClientBuilder is the object used to construct a new ICommunicationsClient with the desired settings. Building media bots has additional considerations which are further outlined in the media section . Notification Dispatching Notifications for root collections, such as the ICallCollection generated by ICommunicationsClient.Calls() , are handled in a single queue. Any root resource, such as the ICall , that has been added to the root collection is given it's own queue. Any child resources, of the root resource, such as the ICallParticipant use the same queue as the root resource. Each queue will delivered event callbacks to the developer sequentially. The SDK will wait to deliver the next event callbacks until all the callbacks for the current event have been processed. This has been done as to help developers avoid concurrency issues and will in the future support resource versioning and jitter buffers. Important It is important for all event handlers to be non-blocking, and any long running operations need to be offloaded to another thread. Long running operations in any event will block further operations from being raised for the given resource. Example Outgoing Calls To illustrate functionality of the Graph Communications Calling SDK, the below examples demonstrate 2 common scenarios: how to make an outbound call to a Microsoft Teams user and how to join an existing Microsoft Teams meeting. Making an Outbound Call Assuming a bot has been properly registered and deployed, the ICommunicationsClient configured and built. The bot needs to create the Call object with the corresponding parameters and pass the object to the CallCollectionExtensions.AddAsync method as follows: Call callResource = new Call { Subject = \"**Subject**\", Targets = new List { new InvitationParticipantInfo { Identity = new IdentitySet { User = new Identity { Id = \"**Target's AAD ObjectId GUID**\" }, }, } }, TenantId = \"**The id of the tenant that will host the meeting**\" }; IMediaSession mediaSession = this.Client.CreateMediaSession(**media session settings**); ICall call = await this.Client.Calls().AddAsync(callResource, mediaSession); SDK will store the state of the call in memory after calling AddAsync . The returned call object above contains the call Id set by the service. Making an Outbound Call to Join an Existing Microsoft Teams Meeting The above example shows how to create an outbound call to single or multiple participants and create a new conversation. If the bot needs to join an existing conversation, the SDK provides an overload of AddAsync that takes @Microsoft.Graph.Communications.Calls.JoinMeetingParameters as input. The bot needs to create the @Microsoft.Graph.Communications.Calls.JoinMeetingParameters object with the corresponding meeting parameters and pass the object to the CallCollectionExtensions.AddAsync method as follows: ChatInfo chatInfo = new ChatInfo { MessageId = \"**Message Id**\", ThreadId = \"**Thread Id**\", ReplyChainMessageId = \"**Reply Chain Message Id**\" }; OrganizerMeetingInfo meetingInfo = new OrganizerMeetingInfo { Organizer = new IdentitySet { User = new Identity { Id = \"**Meeting Organizer's AAD ObjectId GUID**\" }, } }; meetingInfo.Organizer.User.SetTenantId(\"**TenantId Guid**\"); IMediaSession mediaSession = this.Client.CreateMediaSession(**media session settings**); JoinMeetingParameters joinCallParameters = new JoinMeetingParameters( chatInfo, meetingInfo, mediaSession); ICall call = await this.Client.Calls().AddAsync(joinCallParameters); SDK will store the state of the call in memory after calling AddAsync . The returned call object above contains the callId set by the service. Example Incoming Calls Any time another user or bot places a call to your bot, you will receive a notification to the global application endpoint specified when registering your bot. Incoming call scenarios are supported with both Service Hosted Media and App Hosted Media configurations. Important For all incoming call scenarios, the initial incoming call notification will still be received using the BotBuilder protocol. The Graph SDK automatically returns 204 No Content to the initial notification to invoke the new Graph protocol. Answering incoming call with application hosted media First, subscribe to incoming calls. this.Client.Calls().OnIncoming += this.CallsOnIncoming; When incoming call comes, the bot needs to answer with an IMediaSession . This can be a media session created using the ICommunicationsClient.CreateMediaSession() extension or a custom IMediaSession . private void CallsOnIncoming(ICallCollection sender, CollectionEventArgs collectionEventArgs) { IMediaSession mediaSession = this.Client.CreateMediaSession( new AudioSocketSettings { StreamDirections = StreamDirection.Recvonly, SupportedAudioFormat = AudioFormat.Pcm16K }, new VideoSocketSettings { StreamDirections = StreamDirection.Sendrecv, ReceiveColorFormat = VideoColorFormat.NV12, SupportedSendVideoFormats = new List { VideoFormat.NV12_720x1280_30Fps, VideoFormat.NV12_1280x720_30Fps } } ); // Run async as not to block subsequent notifications. Task.Run(async () => { await collectionEventArgs .AddedResources .FirstOrDefault() .AnswerAsync(mediaSession) .ConfigureAwait(false); }); } Answer incoming call with service hosted media First subscribe to incoming calls. this.Client.Calls().OnIncoming += this.CallsOnIncoming; When incoming call comes, the bot will answer with a ServiceHostedMediaConfig . private void CallsOnIncoming(ICallCollection sender, CollectionEventArgs collectionEventArgs) { // Run async as not to block subsequent notifications. Task.Run(async () => { await collectionEventArgs .AddedResources .FirstOrDefault() .AnswerAsync(new Modality[] { Modality.Audio }) .ConfigureAwait(false); }); } State Management Graph Communications SDK can be used to store state of all resources in memory. This has 2 implications: The instance hosting the call needs to be up throughout the lifetime of a call. Any subsequent asynchronous notifications delivered by the service need to be redirected to the instance hosting the call. Any bot that hosts its own media stack should to be built using the Graph Communications SDK given that the media stream has a requirement that it needs to persist in memory throughout the lifetime of the call. More details can be found in the State Management article." }, - "bot_media/Microsoft.Skype.Bots.Media.IAudioVideoFramePlayer.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.IAudioVideoFramePlayer.html", - "title": "Interface IAudioVideoFramePlayer", - "keywords": "Interface IAudioVideoFramePlayer Interface for the AudioVideoFramePlayer responsible for streaming real time audio video Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IAudioVideoFramePlayer Methods ClearAsync(Boolean, List) Clears media buffers from the param settings, if nothing is specified it will clear all the audio and video buffers that are in the queue Declaration Task ClearAsync(bool clearAudio = true, List videoFormats = null) Parameters Type Name Description Boolean clearAudio true will clear the audio buffers, default value is set to true List < VideoFormat > videoFormats list of video formats to clear, default value is null Returns Type Description Task EnqueueBuffersAsync(IList, IList) Enqueue the audio and video media buffers. Usage should be to enqueue the same audio and video length, if audio and video socket are active. Declaration Task EnqueueBuffersAsync(IList audioMediaBuffers, IList videoMediaBuffers) Parameters Type Name Description IList < AudioMediaBuffer > audioMediaBuffers IList < VideoMediaBuffer > videoMediaBuffers Returns Type Description Task ShutdownAsync() This will shutdown the player and clean the associated resources Declaration Task ShutdownAsync() Returns Type Description Task Events LowOnFrames This event will be raised if the player is low on frames Declaration event EventHandler LowOnFrames Event Type Type Description EventHandler < LowOnFramesEventArgs >" + "README.Internal.html": { + "href": "README.Internal.html", + "title": "How to generate docs", + "keywords": "How to generate docs Download and unzip docfx.zip from https://github.com/dotnet/docfx/releases , extract it to a local folder, and add it to PATH so you can run it anywhere. Install Visual STUDIO 2017 Developer tools v15.0 and later After installation, open a X64 Native Tools Command Prompt for VS 2017. Run docfx in the docs folder, this will generate a _site folder Pack the _site folder with the project level README.md that explains how to go through the docs. How to serve the docs Download and unzip docfx.zip from https://github.com/dotnet/docfx/releases , extract it to a local folder, and add it to PATH so you can run it anywhere. Open a console window and cd to the directory which contains the _site folder Serve the docs site using docfx serve .\\_site command Goto http://localhost:8080 in your browser to view the documentation." }, - "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformHealthStatus.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformHealthStatus.html", - "title": "Enum MediaPlatformHealthStatus", - "keywords": "Enum MediaPlatformHealthStatus Health status of the media platform Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaPlatformHealthStatus Fields Name Description HeavilyLoaded The media platform is under heavy load and the application should avoid allowing the current call volume to increase Normal The media platform is operating normally Overloaded The media platform is overloaded and new calls may be rejected" + "articles/Logging.html": { + "href": "articles/Logging.html", + "title": "Logging in SDK", + "keywords": "Logging in SDK The Graph SDK uses a custom logger named @Microsoft.Graph.Communications.Common.Telemetry.IGraphLogger which allows custom subscribers for log events. These events can be observed and logged as required by the bot developers. You need to create an IObserver for log events (the @Microsoft.Graph.Communications.Common.Telemetry.LogEvent class). private class LogObserver : IObserver { private readonly LogEventFormatter formatter = new LogEventFormatter(); /// /// Provides the observer with new data. /// /// The current notification information. public void OnNext(LogEvent logEvent) { // Log event. // Event Severity: logEvent.Level // Http trace: logEvent.EventType == LogEventType.HttpTrace // Log trace: logEvent.EventType == LogEventType.Trace var logString = this.formatter.Format(logEvent); MyLogger.Log(logEvent.Level, logString) } /// /// Notifies the observer that the provider has experienced an error condition. /// /// An object that provides additional information about the error. public void OnError(Exception error) { // Error occurred with the logger, not with the SDK. } /// /// Notifies the observer that the provider has finished sending push-based notifications. /// public void OnCompleted() { // Graph Logger has completed logging (shutdown). } } After a class is ready, you need to subscribe to the log events. ICommunicationsClient client; // Substitute this with the instance of the SDK. var observer = new LogObserver(); var disposableSubsription = client.GraphLogger.Subscribe(observer); Note The disposableSubscription object should be persisted, otherwise logging will not work once it is garbage collected." }, - "bot_media/Microsoft.Skype.Bots.Media.MediaSendStatus.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.MediaSendStatus.html", - "title": "Enum MediaSendStatus", - "keywords": "Enum MediaSendStatus Indicates whether an AudioSocket or VideoSocket is capable of sending media. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaSendStatus Fields Name Description Active Media can be sent Inactive Media cannot be sent" + "articles/calls/IVR.html": { + "href": "articles/calls/IVR.html", + "title": "Interactive Voice Response (IVR)", + "keywords": "Interactive Voice Response (IVR) Graph Communications Calling SDK and Core SDK can be used to make and manage IVR calls. Features Join exiting calls Answer incoming calls Subscribe to tones Transfer call Play media Record Cancel media operations Calling SDK Snippets Join Existing Call and Answer Incoming Call Please refer to the concept articles Redirect and Transfer In order to do a redirect or transfer, you need to create an invitation object. This invitation target is the transferee in blind transfer and the original caller in consultative transfer. var target = new InvitationParticipantInfo { Identity = new IdentitySet { User = new Identity { Id = \"**The Target's AAD ID**\", DisplayName = \"**(optional) The Target's Display Name**\", } } }; ICall call = this.GetIncomingCall(); await call.RedirectAsync(new[] { target }).ConfigureAwait(false); Blind transfer To make a blind transfer, only the target needs to be specified. ICall oritinalCall = this.Client.Calls()[\"*call id to transfer*\"]; await oritinalCall.TransferAsync(target).ConfigureAwait(false); Consultative transfer ICall newCall = this.Client.Calls()[\"*call id of second call*\"]; await newCall.TransferAsync(target, \"*id of the original call*\").ConfigureAwait(false); Subscribe to tones ICall call = this.Client.Calls()[\"*id of the call*\"]; await call.SubscribeToToneAsync().ConfigureAwait(false); Any tones that are received are sent as part of a call update in ToneInfo property of the call resource. Play media prompts ICall call = this.Client.Calls()[\"*id of the call*\"]; await call.PlayPromptAsync(*A list of media prompts to play*).ConfigureAwait(false); Record ICall call = this.Client.Calls()[\"*id of the call*\"]; HttpClient httpClient = this.HttpClient; RecordOperationResult result = await call.RecordAsync(*record options*).ConfigureAwait(false); string location = result.RecordResourceLocation; string token = result.RecordResourceAccessToken; // Stream the content of the recording somewhere. using (var outputStream = new MemoryStream()) using (var request = new HttpRequestMessage(HttpMethod.Get, new Uri(location))) { // Set the authorization header. request.Headers.Authorization = new AuthenticationHeaderValue(\"Bearer\", token); using(var response = await httpClient.SendAsync(request).ConfigureAwait(false)) using(var content = await response.Content.ReadAsStreamAsync().ConfigureAwait(false)) { await content.CopyToAsync(outputStream); outputStream?.Seek(0, SeekOrigin.Begin); // Do something with stream. } } Cancel media processing This API will cancel all prompts that are queued to be played. ICall call = this.Client.Calls()[\"*id of the call*\"]; await call.CancelMediaProcessingAsync().ConfigureAwait(false);" }, - "bot_media/Microsoft.Skype.Bots.Media.VideoResolution.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoResolution.html", - "title": "Enum VideoResolution", - "keywords": "Enum VideoResolution Video resolution for vbss and video Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum VideoResolution Fields Name Description HD1080p 1920 X 1080 HD720p 1280 X 720 SD180p 320 X 180 SD240p 424 X 240 SD360p 640 X 360 SD540p 960 X 540" + "README.html": { + "href": "README.html", + "title": "Get started", + "keywords": "Get started Review the documentation to understand the concepts behind using our SDK (which is also used by the samples). Get started quickly with our samples ." }, - "bot_media/Microsoft.Skype.Bots.Media.VideoSinkEncodingFormat.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSinkEncodingFormat.html", - "title": "Enum VideoSinkEncodingFormat", - "keywords": "Enum VideoSinkEncodingFormat VideoSinkEncodingFormats Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum VideoSinkEncodingFormat Fields Name Description H264 H264 Yuv Yuv" + "articles/calls/StateManagement.html": { + "href": "articles/calls/StateManagement.html", + "title": "State Management", + "keywords": "State Management All states of resources associated with a Call in the Graph Communications Calling SDK are handled internally. The notifications and events for a particular ICall or a particular resource contained in ICall are always received on a single application instance. This means that the instance should be maintaining the state of a call in memory and a single ICall object exists throughout the duration of the call. These are called Stateful calls and the bots are called Stateful bots. The notification or events for any call can hit any instance of the application. This means that everytime a notification comes to an instance, a new Call object is created by the Graph Communications Calling Core SDK and is destroyed once the notification/event has been handled. Any state required for the call should be maintained by the bot logic. These type of bots are called Stateless bots signifying that the Graph Communications Calling Core SDK itself does not maintain any state for the bot. Differences Between Stateless and Stateful Bots The major difference between Stateless and Stateful bots is that maintaining Stateful bots requires that the bot instance would not go down when a call is in progress. If the instance goes down, the call object is lost and no notifications or events are received by the Graph Communications Calling SDK and the calls gets dropped by the server. On the contrast, in Stateless bots, even if the bot instance goes down, the events and notifications go to the other instances of the bot and the bot can continue its logic. Important In Application Hosted Media Calls , the media is handled by a single instance of the bot. Therefore, all the notifications should reach the same instance of the bot for signaling of the media to be properly handled. Thus stateless scenarios for Application Hosted Media bots are not supported." + }, + "articles/calls/MultipleAppSupport.html": { + "href": "articles/calls/MultipleAppSupport.html", + "title": "Supporting Multiple Applications Within Single Code Base", + "keywords": "Supporting Multiple Applications Within Single Code Base Some developers may wish to support multiple applications from within the same application code. With very little effort, this can be done using multiple instances of ICommunicationsClient . There are some steps that should be taken to ensure that we make outbound requests with the right application, and we forward incoming notifications to the right application. This writeup will demonstrate how to alter the existing samples to add multiple application support. We have not created a sample of this scenario explicitly given that it is not a standard way to use the Graph SDK. Create multiple communications clients First, each application instance requires it's own ICommunicationsClient instance, given that it supports a single IRequestAuthenticationProvider Let's change the Bot ICommunicationsClient Client to an IDictionary Clients and create our clients. /// /// Prevents a default instance of the class from being created. /// private Bot() { this.AddClient( Service.Instance.Configuration.MicrosoftAppId, Service.Instance.Configuration.MicrosoftAppPassword); this.AddClient( Service.Instance.Configuration.MicrosoftApp2Id, Service.Instance.Configuration.MicrosoftApp2Password); } private void AddClient(string appId, string appSecret) { // Create a unique notification uri for first app instance // This appends the app id to the callback uri so we get // https://base.uri/callbacks/{appId} var notificationUri = new Uri( Service.Instance.Configuration.CallControlBaseUrl, appId); var builder = new CommunicationsClientBuilder(\"AudioVideoPlaybackBot\", appId); builder .SetAuthenticationProvider( new AuthenticationProvider( appId, appSecret, Service.Instance.Configuration.TokenAudienceResourceLink)) .SetNotificationUrl(notificationUri) .SetMediaPlatformSettings(Service.Instance.Configuration.MediaPlatformSettings) .SetServiceBaseUrl(Service.Instance.Configuration.PlaceCallEndpointUrl); var client = builder.Build(); this.Clients.Add(appId, client); client.Calls().OnIncoming += this.CallsOnIncoming; client.Calls().OnUpdated += this.CallsOnUpdated; } /// /// Gets the contained app clients /// public IDictionary Clients { get; } Let's also add a reference to the ICallCollection to the call handler for ease of access. This will allow us to reference the correct collection/client from any given call id. /// /// Initializes a new instance of the class. /// /// The call collection. /// The call. public CallHandler(ICallCollection callCollection, ICall call); /// /// Gets the call collection /// public ICallCollection CallCollection { get; } /// /// Gets the call /// public ICall Call { get; } Handle notifications Next we need to adjust the incoming call controller to forward the notifications to the right client. If there is no need to handle incoming call, then the above configuration will automatically route the the correct apps endpoint. If we need to handle incoming call, we can either have a default app process all those scenarios, or the callback URI of each app can contain the app id. For example, if our service URI is https://base.uri/callback , we can set all our bots to use this URI directly, but then we lose knowledge of which app is receiving the incoming call. If we change each app's callback URI to https://base.uri/callback/{appId} (example: https://base.uri/callback/9ecd52e5-6592-42b7-b562-093f37f13bde , where the appId is 9ecd52e5-6592-42b7-b562-093f37f13bde) then we have the app context when an incoming call occurs. Of course there are other ways to get the app ID, like from the auth token or the payload, but this is one simple option. To handle the app id in the URI the controllers for callbacks need to be changed to the following: /// /// Gets a reference to singleton sample bot/client instance /// private IDictionary Clients => Bot.Instance.Clients; /// /// Handle a callback for an incoming call. /// Here we don't know what application is receiving the callback. /// /// /// The . /// [HttpPost] [Route(\"\")] public Task OnIncomingRequestAsync() { // Pick some app id to handle this call. var appId = this.Clients.Keys.First(); return this.OnIncomingRequestAsync(appId); } /// /// Handle a callback for an incoming call or notification. /// Here we've added the application id to the callback URI. /// /// /// The . /// [HttpPost] [Route(\"{appId}\")] public async Task OnIncomingRequestAsync(string appId) { Log.Info(new CallerInfo(), LogContext.FrontEnd, $\"Received HTTP {this.Request.Method}, {this.Request.RequestUri}\"); // Pass the incoming message to the sdk. The sdk takes care of what to do with it. var client = this.Clients[appId]; var response = await client.ProcessNotificationAsync(this.Request).ConfigureAwait(false); // Enforce the connection close to ensure that requests are evenly load balanced so // calls do no stick to one instance of the worker role. response.Headers.ConnectionClose = true; return response; } Additional notes There are a few items not addressed here. For instance, when a VTC joins a meeting, which app should it use? This has been purposefuly excluded from this guide given that it is unique business logic. Some may want a different bot configuration for each client, others may associate unique permissions to each bot and use depending on action being performed." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.JsonConverters.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.JsonConverters.html", - "title": "Class JsonConverters", - "keywords": "Class JsonConverters Json converters. Inheritance Object JsonConverters Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class JsonConverters" + "articles/calls/appHostedMediaCalls.html": { + "href": "articles/calls/appHostedMediaCalls.html", + "title": "Application Hosted Media Calls", + "keywords": "Application Hosted Media Calls Application Hosted Media calls are those calls in which the bot manages the call's video and audio sockets. The bots send and receive raw audio and video data over the network. Building a CommunicationsClient with Media Platform Settings Create the an instance of the @Microsoft.Graph.Communications.Client.ICommunicationsClientBuilder. Create an instance of @Microsoft.Skype.Bots.Media.MediaPlatformSettings and use MediaCommunicationsClientBuilderExtensions.SetMediaPlatformSettings method to pass the @Microsoft.Skype.Bots.Media.MediaPlatformSettings to build the @Microsoft.Graph.Communications.Client.ICommunicationsClient Once the builder builds the @Microsoft.Graph.Communications.Client.ICommunicationsClient, a media session can be created using either MediaCommunicationsClientExtension.CreateMediaSession or MediaCommunicationsClientExtension.CreateMediaSession depending on how many video sockets are required. When creating an object of the Call resource, MediaConfig needs to be set to AppHostedMediaConfig . Important When creating a new call that uses application hosted media, an instance of @Microsoft.Graph.Communications.Calls.IMediaSession needs to be passed into CallCollectionExtensions.AddAsync" }, - "core/Microsoft.Graph.Communications.Core.CommsConstants.HttpPropertyNames.html": { - "href": "core/Microsoft.Graph.Communications.Core.CommsConstants.HttpPropertyNames.html", - "title": "Class CommsConstants.HttpPropertyNames", - "keywords": "Class CommsConstants.HttpPropertyNames Constants used for HTTP property names Inheritance Object CommsConstants.HttpPropertyNames Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class HttpPropertyNames Fields ResponseHeaders The Response Headers string Declaration public const string ResponseHeaders = \"responseHeaders\" Field Value Type Description String StatusCode The Status Code string Declaration public const string StatusCode = \"statusCode\" Field Value Type Description String" + "articles/Testing.html": { + "href": "articles/Testing.html", + "title": "Testing of Bots", + "keywords": "Testing of Bots This document describes how to setup the Graph Communications Calling SDK to run on your localhost, run tests against it against the Graph Platform. Caution Do not use this testing setup for production traffic. Please limit it to debugging your bot locally with test traffic because of security concerns. Prerequisites The testing setup requires ngrok to create tunnels to localhost. Go to ngrok and sign up for a free account. Once you signed up, go to the dashboard and get your authtoken. Create an ngrok configuration file ngrok.yml with the following data authtoken: Tip Free ngrok account does not provide static tunnels. Tunnels change everytime a tunnel is created. So, if using free account, it is recommended to not close ngrok until it's use is completed. Tip Ngrok does not require sign up if you do not use TCP tunnels. Setting up Signaling In order for the platform to talk to your bot, the bot needs to be reached over the internet. So, an ngrok tunnel is created in http mode with an address pointing to a port on your localhost. Add the following lines to your ngrok config tunnels: signaling: addr: proto: http Setting up Application Hosted Media Note This section is only required for Application Hosted Media bots and can be skipped if you do not host media yourself. Application Hosted Media uses certificates and TCP tunnels to properly work. The following steps are required in order for proper media establishment. Ngrok's public TCP endpoints have fixed urls. They are 0.tcp.ngrok.io , 1.tcp.ngrok.io , etc. You should have a dns CNAME entry for your service that points to these urls. In this example, let's say 0.bot.contoso.com is pointing to 0.tcp.ngrok.io , and similarly for other urls. Now you require an SSL certificate for the url you own. To make it easy, use an SSL certificate issued to a wild card domain. In this case, it would be *.bot.contoso.com . This ssl certificate is validated by Media flow so should match your media flow's public url. Note down the thumbprint and install the certificate in your machine certificates. Now, we setup a TCP tunnel to forward the traffic to localhost. Write the following lines into your ngrok config. media: addr: proto: tcp Important Because ngrok's tcp urls can be same for multiple users (just differing in ports), it is possible for a third party to look like your service. This is a security issue. Therefore this document should be followed only for testing and also using a separate domain that is not linked to your production services. Start Ngok Now that ngrok configuration is ready, start it up. Download the ngrok executable and run the following command ngrok.exe start -all -config This would start ngrok and provide you the public urls which provide the tunnels to your localhost. The output looks like the following Forwarding http://signal.ngrok.io -> localhost:12345 Forwarding https://signal.ngrok.io -> localhost:12345 Forwarding tcp://1.tcp.ngrok.io:12332 -> localhost:8445 Here, 12345 is my signaling port, 8445 is the local media port and 12332 is the remote media port exposed by ngrok. Note that we have a forwarding from 1.bot.contoso.com to 1.tcp.ngrok.io . This will be used as the media url for bot. Update Code Once ngrok is up and running, we update the code to use the config we just setup. Update Signaling In the builder, change the NotficationUrl to the signaling url provided by ngrok. clientBuilder.SetNotificationUrl( new Uri(\"https://signal.ngrok.io/notificationEndpoint\")) Important Replace signal with the one provided by ngrok and the NotificationEndpoint with the controller path that receives notification. Important The url in SetNotificationUrl must be HTTPS. Important Your local instance must be listening to http traffic on the signaling port. The requests made by Graph Platform will reach the bot as localhost http traffic when End to End encryption is not setup. Update Media Update your @Microsoft.Skype.Bots.Media.MediaPlatformSettings to the following. var mediaPlatform = new MediaPlatformSettings { ApplicationId = MediaPlatformInstanceSettings = new MediaPlatformInstanceSettings { CertificateThumbprint = , InstanceInternalPort = , InstancePublicPort = , InstancePublicIPAddress = new IPAddress(0x0), ServiceFqdn = , }, } Caution The Certificate Thumbprint provided above should match the Service FQDN. That is why the DNS entries are required. Caveats The free accounts of ngrok do NOT provide End to End encryption. The HTTPS data ends at the ngrok url and the data flows unencrypted from ngrok to localhost. You require paid ngrok account and configuration update to use End to End encryption. See ngrok docs for steps on setting up secure E2E tunnels. Because the bot callback url is dynamic, incoming call scenarios won't work as they are part of bot registration and they are static. One way to fix this is to use a paid ngrok account which provides fixed subdomains to which you can point your bot and the platform." }, - "core/Microsoft.Graph.Communications.Core.CommsConstants.html": { - "href": "core/Microsoft.Graph.Communications.Core.CommsConstants.html", - "title": "Class CommsConstants", - "keywords": "Class CommsConstants The communications constants. Inheritance Object CommsConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class CommsConstants" + "articles/calls/serviceHostedMediaCalls.html": { + "href": "articles/calls/serviceHostedMediaCalls.html", + "title": "Service Hosted Media Calls", + "keywords": "Service Hosted Media Calls Service Hosted Media calls are those calls in which the bot offloads the media to the Microsoft infrastructure. This makes the bot much more lightweight, but it cannot access the raw audio/video streams. Creating a Service Hosted Media Call When creating an object of the Call resource, MediaConfig needs to be set to ServiceHostedMediaConfig ." }, - "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.Codes.html": { - "href": "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.Codes.html", - "title": "Class CommsGeneratedErrorConstants.Codes", - "keywords": "Class CommsGeneratedErrorConstants.Codes The codes Inheritance Object CommsGeneratedErrorConstants.Codes Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Codes Fields NotAllowed Not allowed error code. Declaration public const string NotAllowed = \"notAllowed\" Field Value Type Description String" + "bot_media/Microsoft.Skype.Bots.Media.MediaReceiveStatus.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaReceiveStatus.html", + "title": "Enum MediaReceiveStatus", + "keywords": "Enum MediaReceiveStatus Indicates if the VideoSocket is capable of receiving media. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaReceiveStatus Fields Name Description Active Media can be received, video subscription is allowed Inactive Media cannot be received. Video subscription is not allowed" }, - "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.ChatData.html": { - "href": "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.ChatData.html", - "title": "Class LogProperties.ChatData", - "keywords": "Class LogProperties.ChatData Chat data. Inheritance Object LogProperties.ChatData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class ChatData Constructors ChatData() Declaration public ChatData() Properties ChatId Gets or sets the chat identifier. Declaration public string ChatId { get; set; } Property Value Type Description String TenantId Gets or sets the tenant identifier. Declaration public string TenantId { get; set; } Property Value Type Description String" + "core/Microsoft.Graph.Routing.html": { + "href": "core/Microsoft.Graph.Routing.html", + "title": "Namespace Microsoft.Graph.Routing", + "keywords": "Namespace Microsoft.Graph.Routing Enums CloudNamespace Enumeration defining various cloud environment type" }, - "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.html": { - "href": "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.html", - "title": "Class LogProperties", - "keywords": "Class LogProperties The log properties. Inheritance Object LogProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Client.dll Syntax public static class LogProperties Remarks For better logging experience, all property names should be specific enough. Avoid using generic name such as Id, Name, etc." + "core/Microsoft.Graph.Routing.CloudNamespace.html": { + "href": "core/Microsoft.Graph.Routing.CloudNamespace.html", + "title": "Enum CloudNamespace", + "keywords": "Enum CloudNamespace Enumeration defining various cloud environment type Namespace : Microsoft.Graph.Routing Assembly : Microsoft.Graph.Communications.Core.dll Syntax public enum CloudNamespace Fields Name Description DoD Represents a service running on the DoD cloud installation of NGC or a user homed on the DoD cloud. GCCH Represents a service running on the GCCH cloud installation of NGC or a user homed on the GCCH cloud. NotApplicable Used for users like 'teamsvisitor' or on premise sfb user for whom cloud namespace is not applicable Public Represents a service running on the public cloud installation of NGC or a user homed on the public cloud." }, - "bot_media/Microsoft.Skype.Bots.Media.IMediaPlatform.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.IMediaPlatform.html", - "title": "Interface IMediaPlatform", - "keywords": "Interface IMediaPlatform Interface to the MediaPlatform. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IMediaPlatform : IDisposable Properties CurrentHealth The current health status of the media platform. Declaration MediaPlatformHealthStatus CurrentHealth { get; } Property Value Type Description MediaPlatformHealthStatus Methods CreateMediaConfiguration(IAudioSocket) Returns a serialized MediaConfiguration object representing the socket so that the Skype calling cloud can establish an audio/video call to the bot. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IDataSocket) Reserved for the internal use. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IDataSocket dataSocket) Parameters Type Name Description IAudioSocket audioSocket IDataSocket dataSocket Returns Type Description Newtonsoft.Json.Linq.JObject CreateMediaConfiguration(IAudioSocket, IVideoSocket) Returns a serialized MediaConfiguration object representing the sockets so that the Skype calling cloud can establish an audio/video call to the bot. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IVideoSocket videoSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IVideoSocket videoSocket Socket that handles video. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList) Returns a serialized MediaConfiguration object representing the sockets so that the Skype calling cloud can establish an audio/video call to the bot. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IList < IVideoSocket > videoSockets Ordered list of video sockets. If multiview sockets are provided, only the first one can have a send direction (ie. send only or send receive) and all the sockets should have a receive direction. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList, IVideoSocket) Returns a serialized MediaConfiguration object representing the sockets so that the Skype calling cloud can establish an audio/video/video-based screen sharing call to the bot. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets, IVideoSocket vbssSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IList < IVideoSocket > videoSockets Ordered list of video sockets. If multiview sockets are provided, only the first one can have a send direction (ie. send only or send receive) and all the sockets should have a receive direction. IVideoSocket vbssSocket Video socket for the video-based screen sharing (VBSS) modality. Socket must be configured as RecvOnly. Returns Type Description Newtonsoft.Json.Linq.JObject Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized, or a vbssSocket is configured to be sendonly or sendrecv. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList, IVideoSocket, IDataSocket) Reserved for the internal use. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets, IVideoSocket vbssSocket, IDataSocket dataSocket) Parameters Type Name Description IAudioSocket audioSocket IList < IVideoSocket > videoSockets IVideoSocket vbssSocket IDataSocket dataSocket Returns Type Description Newtonsoft.Json.Linq.JObject CreateMediaConfiguration(IVideoSocket) Returns a serialized mediaConfiguration object representing the socket so that the Skype calling cloud can establish a video-based screen sharing call to the bot. Declaration JObject CreateMediaConfiguration(IVideoSocket vbssSocket) Parameters Type Name Description IVideoSocket vbssSocket Video socket for the video-based screen sharing (VBSS) modality. Socket must be configured as RecvOnly. Returns Type Description Newtonsoft.Json.Linq.JObject Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized, or a vbssSocket is configured to be sendonly or sendrecv. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. GetCurrentTimestamp() Get a current timestamp, in 100-ns units. To be used when sourcing media buffers. Declaration long GetCurrentTimestamp() Returns Type Description Int64 Initialize(MediaPlatformSettings) Initializes the Media Platform for Bot. Declaration void Initialize(MediaPlatformSettings settings) Parameters Type Name Description MediaPlatformSettings settings Settings to initialize the Bot Media Platform. Events MediaPlatformHealthChanged Raised when there is a change in the media platform's health status. The event arguments report the current and previous platform health conditions. Declaration event EventHandler MediaPlatformHealthChanged Event Type Type Description EventHandler < MediaPlatformHealthChangedEventArgs > Remarks A bot application which may handle very high call volumes or perform complex real-time media processing should monitor this event for changes in the media platform health status. When the event reports the platform health status has become HeavilyLoaded, the application should avoid starting new bot calls on the machine instance until the health status returns back to Normal." + "common/Microsoft.Graph.Communications.Common.Telemetry.MetricLogData.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.MetricLogData.html", + "title": "Class MetricLogData", + "keywords": "Class MetricLogData The metric of Geneva Instrumentation Framework (Ifx). Inheritance Object MetricLogData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class MetricLogData Constructors MetricLogData() Declaration public MetricLogData() Properties AddDefaultDimension Gets or sets a value indicating whether the default dimensions are included. Declaration public bool AddDefaultDimension { get; set; } Property Value Type Description Boolean Dimensions Gets or sets the dimensions. Declaration public Dictionary Dimensions { get; set; } Property Value Type Description Dictionary < String , String > Name Gets or sets the name. Declaration public string Name { get; set; } Property Value Type Description String Namespace Gets or sets the namespace. Declaration public string Namespace { get; set; } Property Value Type Description String RawData Gets or sets the raw data. Declaration public long RawData { get; set; } Property Value Type Description Int64 Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.AudioSendBuffer.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.AudioSendBuffer.html", - "title": "Class AudioSendBuffer", - "keywords": "Class AudioSendBuffer Creates an Audio Buffer for Send and also implements Dispose Inheritance Object AudioSendBuffer Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public class AudioSendBuffer : AudioMediaBuffer Constructors AudioSendBuffer(IntPtr, Int64, AudioFormat, Int64) Initializes a new instance of the AudioSendBuffer class. Declaration public AudioSendBuffer(IntPtr data, long length, AudioFormat audioFormat, long timeStamp = 0L) Parameters Type Name Description IntPtr data The buffer data. Int64 length The length of the buffer. AudioFormat audioFormat The audio format. Int64 timeStamp The time stamp. Methods Dispose(Boolean) Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing" + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpTraceType.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpTraceType.html", + "title": "Enum HttpTraceType", + "keywords": "Enum HttpTraceType Trace used for HTTP traces. Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum HttpTraceType Fields Name Description HttpRequest The HTTP request type HttpResponse The HTTP response type. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(HttpTraceType, String, String) Validator.Equals(HttpTraceType, String) Validator.NotEquals(HttpTraceType, String, String)" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.ILocalMediaSession.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.ILocalMediaSession.html", - "title": "Interface ILocalMediaSession", - "keywords": "Interface ILocalMediaSession Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public interface ILocalMediaSession : IMediaSession, IDisposable Properties AudioSocket Gets the audio socket associated with this media session. Declaration IAudioSocket AudioSocket { get; } Property Value Type Description IAudioSocket DataSocket Gets the data socket associated with this media session. Declaration IDataSocket DataSocket { get; } Property Value Type Description IDataSocket VbssSocket Gets the VBSS socket associated with this media session. Declaration IVideoSocket VbssSocket { get; } Property Value Type Description IVideoSocket VideoSocket Gets the video socket associated with this media session. If current media session contains multiple sockets, this will return the first one in the list. Declaration IVideoSocket VideoSocket { get; } Property Value Type Description IVideoSocket VideoSockets Gets the list of video socket associated with this media session. Declaration IReadOnlyList VideoSockets { get; } Property Value Type Description IReadOnlyList < IVideoSocket >" + "bot_media/Microsoft.Skype.Bots.Media.AudioMetrics.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioMetrics.html", + "title": "Class AudioMetrics", + "keywords": "Class AudioMetrics Audio-specific QoE metrics Inheritance Object AudioMetrics Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioMetrics Constructors AudioMetrics() Declaration public AudioMetrics() Properties AverageInboundNetworkJitter Average network jitter on the inbound media stream Declaration public TimeSpan AverageInboundNetworkJitter { get; set; } Property Value Type Description TimeSpan MaximumInboundNetworkJitter Maximum network jitter on the inbound media stream Declaration public TimeSpan MaximumInboundNetworkJitter { get; set; } Property Value Type Description TimeSpan" }, - "client/Microsoft.Graph.Communications.Client.Transport.GraphClientContext.html": { - "href": "client/Microsoft.Graph.Communications.Client.Transport.GraphClientContext.html", - "title": "Class GraphClientContext", - "keywords": "Class GraphClientContext The context for the graph client wrapper. Inheritance Object GraphClientContext Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client.Transport Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class GraphClientContext Constructors GraphClientContext() Declaration public GraphClientContext() Properties ScenarioId Gets or sets the scenario identifier. Declaration public Guid ScenarioId { get; set; } Property Value Type Description Guid TenantId Gets or sets the tenant. Declaration public string TenantId { get; set; } Property Value Type Description String" + "core/Microsoft.Graph.IdentityExtensions.html": { + "href": "core/Microsoft.Graph.IdentityExtensions.html", + "title": "Class IdentityExtensions", + "keywords": "Class IdentityExtensions Extensions for graph api contracts Inheritance Object IdentityExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class IdentityExtensions Methods GetApplicationInstance(IdentitySet) Gets the application instance identity from identity set. This is part of additional data. Declaration public static Identity GetApplicationInstance(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Identity GetEncrypted(IdentitySet) Get the encrypted identity part of the additional data This identity must be retrieved when other identities are not listed Declaration public static Identity GetEncrypted(this IdentitySet identity) Parameters Type Name Description IdentitySet identity The identity Returns Type Description Identity The encrypted identity GetGuest(IdentitySet) Gets the guest identity from identity set. This is part of additional data. Declaration public static Identity GetGuest(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Identity GetIdentityProvider(Identity) Gets the identity provider. Declaration public static string GetIdentityProvider(this Identity identity) Parameters Type Name Description Identity identity The identity. Returns Type Description String The identity provider string. GetOnPremises(IdentitySet) Gets the on-premises identity from identity set. This is part of additional data. Declaration public static Identity GetOnPremises(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Identity GetPhone(IdentitySet) Gets the phone identity from identity set. This is part of additional data. Declaration public static Identity GetPhone(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Identity GetTenantId(Identity) Gets the tenant identifier. Declaration public static string GetTenantId(this Identity identity) Parameters Type Name Description Identity identity The identity. Returns Type Description String The tenant identifier string. SetApplicationInstance(IdentitySet, Identity) Sets the application instance identity in identity set. This is part of additional data. Declaration public static void SetApplicationInstance(this IdentitySet identitySet, Identity identity) Parameters Type Name Description IdentitySet identitySet The identity set. Identity identity The identity. SetEncrypted(IdentitySet, Identity) Sets the encrypted identity to the additional data This identity must be retrieved when other identities are not listed Declaration public static void SetEncrypted(this IdentitySet identitySet, Identity identity) Parameters Type Name Description IdentitySet identitySet The identity set. Identity identity The identity SetGuest(IdentitySet, Identity) Sets the guest identity in identity set. This is part of additional data. Declaration public static void SetGuest(this IdentitySet identitySet, Identity identity) Parameters Type Name Description IdentitySet identitySet The identity set. Identity identity The identity. SetIdentityProvider(Identity, String) Sets the identity provider. Declaration public static void SetIdentityProvider(this Identity identity, string identityProvider) Parameters Type Name Description Identity identity The identity. String identityProvider The identity provider. SetPhone(IdentitySet, Identity) Sets the phone identity in identity set. This is part of additional data. Declaration public static void SetPhone(this IdentitySet identitySet, Identity identity) Parameters Type Name Description IdentitySet identitySet The identity set. Identity identity The identity. SetTenantId(Identity, String) Sets the tenant identifier. Declaration public static void SetTenantId(this Identity identity, string tenantId) Parameters Type Name Description Identity identity The identity. String tenantId The tenant identifier." }, - "bot_media/Microsoft.Skype.Bots.Media.AudioFormat.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioFormat.html", - "title": "Enum AudioFormat", - "keywords": "Enum AudioFormat The audio format. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum AudioFormat Fields Name Description Pcm16K PCM 16K Pcm44KStereo PCM 44.1K Stereo" + "core/Microsoft.Graph.ContractsConstants.html": { + "href": "core/Microsoft.Graph.ContractsConstants.html", + "title": "Class ContractsConstants", + "keywords": "Class ContractsConstants OData Model Constants Inheritance Object ContractsConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class ContractsConstants" }, - "bot_media/Microsoft.Skype.Bots.Media.AudioSocketSettings.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioSocketSettings.html", - "title": "Class AudioSocketSettings", - "keywords": "Class AudioSocketSettings The settings to initialize the AudioSocket. Inheritance Object AudioSocketSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioSocketSettings Constructors AudioSocketSettings() Initializes an AudioSocketSettings object. Declaration public AudioSocketSettings() Properties CallId An alphanumeric string that uniquely identifies a call Declaration public string CallId { get; set; } Property Value Type Description String ReceiveUnmixedMeetingAudio Allows the bot to receive separate unmixed audio buffers for individual speakers in a meeting. When set to true, up to four audio buffers, each corresponding to the top four active speakers, will be received at a time. In UnmixedMeetingAudio mode, the bot will receive only unmixed audio and not both unmixed and mixed. Declaration public bool ReceiveUnmixedMeetingAudio { get; set; } Property Value Type Description Boolean Remarks Unmixed audio is optimized for machine cognition (e.g., speech recognition) rather than for human perception (such as call recording and playback). Certain error concealment treatment (e.g., to mitigate packet loss) is not applied to the received audio stream in unmixed mode. In order to receive both mixed and unmixed audio simultaneously, the bot must establish two separate calls into the meeting. StreamDirections The directionality of the media stream. This indicates whether it is enabled to both send and receive media, or only send or only receive media. Declaration public StreamDirection StreamDirections { get; set; } Property Value Type Description StreamDirection SupportedAudioFormat The supported send/receive audio format. Declaration public AudioFormat SupportedAudioFormat { get; set; } Property Value Type Description AudioFormat" + "common/Microsoft.Graph.AdditionalDataExtensions.html": { + "href": "common/Microsoft.Graph.AdditionalDataExtensions.html", + "title": "Class AdditionalDataExtensions", + "keywords": "Class AdditionalDataExtensions The identity set extensions Inheritance Object AdditionalDataExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class AdditionalDataExtensions Methods GetValue(IDictionary, String, T) Gets the object using the key from additional data. Declaration public static T GetValue(this IDictionary additionalData, string key, T default = null) Parameters Type Name Description IDictionary < String , Object > additionalData The additional data. String key The key. T default The default value if value could not be parsed. Returns Type Description T /// The converted value. Type Parameters Name Description T The expected type for the specified key. SetInAdditionalData(Object, String, Object) Sets the object with given key in additional data. Declaration public static void SetInAdditionalData(this object obj, string key, object value) Parameters Type Name Description Object obj The identity. String key The key. Object value The value." }, - "bot_media/Microsoft.Skype.Bots.Media.DataSendStatusChangedEventArgs.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.DataSendStatusChangedEventArgs.html", - "title": "Class DataSendStatusChangedEventArgs", - "keywords": "Class DataSendStatusChangedEventArgs Reserved for the internal use. Inheritance Object EventArgs DataSendStatusChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class DataSendStatusChangedEventArgs : EventArgs Constructors DataSendStatusChangedEventArgs() Declaration public DataSendStatusChangedEventArgs() Properties MediaSendStatus Reserved for the internal use. Declaration public MediaSendStatus MediaSendStatus { get; set; } Property Value Type Description MediaSendStatus" + "bot_media/Microsoft.Skype.Bots.Media.VideoMetrics.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoMetrics.html", + "title": "Class VideoMetrics", + "keywords": "Class VideoMetrics Video-specific quality of experience metrics Inheritance Object VideoMetrics Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoMetrics Constructors VideoMetrics() Declaration public VideoMetrics() Properties AverageInboundBitRatePerSecond Average bit rate on the inbound video stream, expressed in bits per second Declaration public uint AverageInboundBitRatePerSecond { get; set; } Property Value Type Description UInt32 AverageInboundFrameRatePerSecond Average frame rate on the inbound video stream, expressed in frames per second Declaration public double AverageInboundFrameRatePerSecond { get; set; } Property Value Type Description Double AverageOutboundBitRatePerSecond Average bit rate on the outbound video stream, expressed in bits per second Declaration public uint AverageOutboundBitRatePerSecond { get; set; } Property Value Type Description UInt32 AverageOutboundFrameRatePerSecond Average frame rate on the outbound video stream, expressed in frames per second Declaration public double AverageOutboundFrameRatePerSecond { get; set; } Property Value Type Description Double" }, "bot_media/Microsoft.Skype.Bots.Media.HostingEnvironmentConfiguration.html": { "href": "bot_media/Microsoft.Skype.Bots.Media.HostingEnvironmentConfiguration.html", "title": "Enum HostingEnvironmentConfiguration", "keywords": "Enum HostingEnvironmentConfiguration HostingEnvironmentConfiguration to use for the MediaPlatform. In most cases, the default value is correct. Only in Azure Government clouds do different settings need to be applied. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum HostingEnvironmentConfiguration Fields Name Description AzureGovernment Configuration specifically for hosting the platform in the Azure Government Cloud. AzureGovernmentDoD Configuration specificially for hosting the platform in the Azure Government DoD cloud. Default The default HostingEnvironmentConfiguration for the platform." }, - "common/Microsoft.Graph.Communications.Common.GuidUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.GuidUtils.html", - "title": "Class GuidUtils", - "keywords": "Class GuidUtils Guid Utils Inheritance Object GuidUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class GuidUtils Methods EnsureNotEmpty(Guid) Ensures Guid is not empty by generating a random guid if it is empty Declaration public static Guid EnsureNotEmpty(this Guid guid) Parameters Type Name Description Guid guid input guid Returns Type Description Guid A guaranteed guid that is not empty EnsureNotEmpty(Nullable) Ensures Guid is not empty by generating a random guid if it is empty Declaration public static Guid EnsureNotEmpty(this Guid? guid) Parameters Type Name Description Nullable < Guid > guid input guid Returns Type Description Guid A guaranteed guid that is not empty ParseOrNew(String) Parse and return the guid if valid else return new guid Declaration public static Guid ParseOrNew(string input) Parameters Type Name Description String input input Returns Type Description Guid Guid of input or new guid" - }, - "bot_media/Microsoft.Skype.Bots.Media.AudioSocket.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioSocket.html", - "title": "Class AudioSocket", - "keywords": "Class AudioSocket Provides Send and Receive I/O access to an audio stream. Inheritance Object AudioSocket Implements IAudioSocket IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public sealed class AudioSocket : IAudioSocket, IDisposable, IInternalAudioSocket, IInternalSocket Constructors AudioSocket(AudioSocketSettings) Initializes a new AudioSocket object. Declaration public AudioSocket(AudioSocketSettings settings) Parameters Type Name Description AudioSocketSettings settings Configuration settings for the AudioSocket Methods Dispose() Disposes the object Declaration public void Dispose() GetQualityOfExperienceData() Get the Quality of Experience (QoE) data for the audio socket. Declaration public AudioQualityOfExperienceData GetQualityOfExperienceData() Returns Type Description AudioQualityOfExperienceData Remarks The bot should fetch the QoE data no more than once every 30 seconds. To get accurate metrics, the bot should let media flow for at least 30 seconds before fetching the QoE data. Send(AudioMediaBuffer) Sends a frame of audio media, where a frame contains 20 milliseconds of audio content (PCM samples). Declaration public void Send(AudioMediaBuffer buffer) Parameters Type Name Description AudioMediaBuffer buffer AudioMediaBuffer containing the frame of audio media to send. Remarks The application must create a concrete class which derives from the AudioMediaBuffer abstract class. The buffer object passed to the Send method is still potentially in-use after the method returns to the caller. The application must not free the buffer's frame data until the the buffer object's Dispose() method is invoked by the Media Platform. The application should be sending 50 frames of audio media per second with each frame containing 20 milliseconds of audio content. The AudioSocket must be enabled to send media via the AudioSocketSettings.StreamDirections property. SendDtmfTone(ToneId) Sends a DTMF tone. Declaration public void SendDtmfTone(ToneId tone) Parameters Type Name Description ToneId tone The DTMF digit. Ranges from 0-16. Remarks Sending DTMF tone is only allowed if the AudioSocket is configured for sending media. SendDtmfTones(IEnumerable, Int32) Sends a sequence of DTMF tones with an optional delay between each tone. Declaration public void SendDtmfTones(IEnumerable tones, int delayBetweenTonesInMilliseconds = -1) Parameters Type Name Description IEnumerable < ToneId > tones The list of DTMF digits to be sent. Ranges from 0-16. Int32 delayBetweenTonesInMilliseconds Delay (in milliseconds) between each DTMF digit sent. Remarks By default, the delay is set to -1 which picks a random time between 0 to 500 milliseconds. Events AudioMediaReceived If the application has configured the AudioSocket to receive media, this event is raised each time a frame of audio media is received, where a frame contains 20 milliseconds of audio content (PCM samples). Once the application has consumed the buffer, it must call the buffer's Dispose() method. Declaration public event EventHandler AudioMediaReceived Event Type Type Description EventHandler < AudioMediaReceivedEventArgs > Remarks The application must be able to handle at least 50 incoming audio buffers per second. Events are serialized, so only one event at a time is raised to the app. The event handler should return as quickly as possible; any time-consuming per-frame processing should be performed asynchronously from the event handler. AudioSendStatusChanged If the application has configured the AudioSocket to send media, this event is raised to inform the application when it may begin sending media and when it should stop. The application cannot send media before receiving a MediaSendStatusChanged event indicating the SendStatus is Active, such media will be discarded. Declaration public event EventHandler AudioSendStatusChanged Event Type Type Description EventHandler < AudioSendStatusChangedEventArgs > DominantSpeakerChanged This event is raised when there is a change in the dominant speaker in the conference. If there is no dominant speaker in the conference the CurrentDominantSpeaker argument in the event will have the value None (0xFFFFFFFF). Declaration public event EventHandler DominantSpeakerChanged Event Type Type Description EventHandler < DominantSpeakerChangedEventArgs > MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration public event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > ToneReceived This event is raised when the DTMF tone is received. ToneId enum indicates the tone value. Declaration public event EventHandler ToneReceived Event Type Type Description EventHandler < ToneReceivedEventArgs > Implements IAudioSocket System.IDisposable" - }, - "client/Microsoft.Graph.Communications.Client.Authentication.RequestValidationResult.html": { - "href": "client/Microsoft.Graph.Communications.Client.Authentication.RequestValidationResult.html", - "title": "Struct RequestValidationResult", - "keywords": "Struct RequestValidationResult The result of the request validation. Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() ValueType.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Graph.Communications.Client.Authentication Assembly : Microsoft.Graph.Communications.Client.dll Syntax public struct RequestValidationResult Fields IsValid Indicates whether the request is valid. Declaration public bool IsValid Field Value Type Description Boolean TenantId The tenant id for the incoming request. Declaration public string TenantId Field Value Type Description String" - }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationTag.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationTag.html", - "title": "Enum ObfuscationTag", - "keywords": "Enum ObfuscationTag Tag used to provide a hint for the type of obfuscation to perform. Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum ObfuscationTag Fields Name Description Fqdn FQDN that needs to be obfuscated. An example would be \"lyncfrontend.lync.com\" Generic A generic blob containing sensitive data that must be obfuscated completely. Guid A guid type that has to be obfuscated. Identity The subject of some information whose data needs to be obfuscated. An example would be \"The user {coolgal} is attempting to to perform some action\". MRIs are also considered identities. IpAddress IP address that needs to be obfuscated. An example would be \"187.23.33.1\" Pstn PSTN related information. An example would be a telephone number like \"+10005559999\". Uri Uri that needs to be obfuscated. This can have any scheme like http, https, etc. An example would be \" https://cheatdays.com/fitguy" ; This could be either absolute or relative uri. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(ObfuscationTag, String, String) Validator.Equals(ObfuscationTag, String) Validator.NotEquals(ObfuscationTag, String, String)" - }, "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventType.html": { "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventType.html", "title": "Enum LogEventType", "keywords": "Enum LogEventType Log event type that describes what type of LogEvent this is. Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum LogEventType Fields Name Description HttpTrace The event used to track HTTP Calls. Metric The event used to track metrics Trace The event used to track Traces. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(LogEventType, String, String) Validator.Equals(LogEventType, String) Validator.NotEquals(LogEventType, String, String)" }, - "bot_media/Microsoft.Skype.Bots.Media.AudioMediaBuffer.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.AudioMediaBuffer.html", - "title": "Class AudioMediaBuffer", - "keywords": "Class AudioMediaBuffer Represents an unmanaged buffer containing audio media data. Inheritance Object AudioMediaBuffer Implements IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public abstract class AudioMediaBuffer : IDisposable Constructors AudioMediaBuffer() Declaration protected AudioMediaBuffer() Properties ActiveSpeakers Current active speakers in the conference. Declaration public uint[] ActiveSpeakers { get; protected set; } Property Value Type Description UInt32 [] Remarks The value is the IDs (MediaSourceIds) of the audio source of the active speakers in the conference and does not include bot's own MediaSourceId. If there is no active speaker, or there is just silence in the conference, the value is an empty array. AudioFormat The audio format. Declaration public AudioFormat AudioFormat { get; protected set; } Property Value Type Description AudioFormat Data Pointer to the unmanaged media buffer. Declaration public IntPtr Data { get; protected set; } Property Value Type Description IntPtr IsSilence Indicates if the received audio media buffer contains only silence. This property is set automatically for received audio buffers. When sending buffers via the Send method, this property is unused. Declaration public bool IsSilence { get; protected set; } Property Value Type Description Boolean Length The length in bytes of the data in the media buffer. Declaration public long Length { get; protected set; } Property Value Type Description Int64 Timestamp Timestamp of when the media content was received by the bot, or if the bot is sending media, the timestamp of when the media was sourced. It is in 100-ns units. When sourcing media buffers, this property should be set using the value from the MediaPlatform.GetCurrentTimestamp() API. Declaration public long Timestamp { get; protected set; } Property Value Type Description Int64 UnmixedAudioBuffers Contains the list of received unmixed audio buffers (up to four at a time). Declaration public UnmixedAudioBuffer[] UnmixedAudioBuffers { get; protected set; } Property Value Type Description UnmixedAudioBuffer [] Remarks This is useful for advanced meeting scenarios, such as being able to receive separate audio buffers for individual speakers. This value is set only on the receive side when the AudioSocketSetting.ReceiveUnmixedMeetingAudio property is set to true. Creating unmixed audio buffers and sending it on the AudioSocket is not supported. This property is null when unmixed buffers are not requested. Methods Dispose() Disposes the object. Declaration public void Dispose() Dispose(Boolean) Releases unmanaged resources held by the buffer object. Must be implemented in the derived class. Declaration protected abstract void Dispose(bool disposing) Parameters Type Name Description Boolean disposing If true, both managed and unmanaged resources can be disposed. If false, only unmanaged resources can be disposed. Implements System.IDisposable" - }, - "bot_media/Microsoft.Skype.Bots.Media.VideoSettings.html": { - "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSettings.html", - "title": "Class VideoSettings", - "keywords": "Class VideoSettings Video Frame player settings Inheritance Object VideoSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoSettings Constructors VideoSettings() Declaration public VideoSettings()" - }, - "common/Microsoft.Graph.Communications.Common.StringUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.StringUtils.html", - "title": "Class StringUtils", - "keywords": "Class StringUtils String Utils Inheritance Object StringUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class StringUtils Methods ConvertOrDefault(String, T) Convert string to type or return default Declaration public static T ConvertOrDefault(string value, T defaultValue = null) Parameters Type Name Description String value input value T defaultValue default value Returns Type Description T result of the conversion Type Parameters Name Description T Type of return value EqualsIgnoreCase(String, String) Case insensitive string comparison Declaration public static bool EqualsIgnoreCase(this string valueA, string valueB) Parameters Type Name Description String valueA Input string A String valueB Input string B Returns Type Description Boolean Value indicating whether strings are equal in a case insensitive comparision FromBase64(String) Converts the specified string, which encodes binary data as base-64 digits, to an equivalent 8-bit unsigned integer array. Declaration public static byte[] FromBase64(this string data) Parameters Type Name Description String data The string to convert. Returns Type Description Byte [] An array of 8-bit unsigned integers. FromBase64Url(String) Converts the specified string, which encodes binary data as base-64 digits, to an equivalent 8-bit unsigned integer array. Declaration public static byte[] FromBase64Url(this string data) Parameters Type Name Description String data The string to convert. Returns Type Description Byte [] An array of 8-bit unsigned integers. GetSHA256Hash(String) Creates a SHA256 hash of the passed string. Declaration public static string GetSHA256Hash(this string input) Parameters Type Name Description String input The input string. Returns Type Description String The SHA256 hash. Join(IEnumerable, String) Concatenates the members of a constructed IEnumerable collection of type String , using the specified separator between each member. Declaration public static string Join(this IEnumerable values, string separator) Parameters Type Name Description IEnumerable < String > values A collection that contains the strings to concatenate. String separator The string to use as a separator. separator is included in the returned string only if values has more than one element. Returns Type Description String A string that consists of the members of values delimited by the separator string. If values has no members, the method returns Empty . NamespaceInCamelCase(String) Returns a namespace in camel case. Declaration public static string NamespaceInCamelCase(this string value) Parameters Type Name Description String value Value to convert. Returns Type Description String The namespace string in camel case. NamespaceInPascalCase(String) Returns a namespace in pascal case. Declaration public static string NamespaceInPascalCase(this string value) Parameters Type Name Description String value Value to convert. Returns Type Description String The namespace string in pascal case. SafeFormat(String, Object[]) Format a string with arguments. Declaration public static string SafeFormat(this string text, params object[] args) Parameters Type Name Description String text Format string. Object [] args Optional arguments. Returns Type Description String Formatted string. ToBase64(ArraySegment, Nullable, Nullable) Convert array segment to base 64 representation. Declaration public static string ToBase64(this ArraySegment data, int? offset = default(int? ), int? count = default(int? )) Parameters Type Name Description ArraySegment < Byte > data Data to convert. Nullable < Int32 > offset Optional override offset. Nullable < Int32 > count Optional override count. Returns Type Description String Base 64 encoded string. ToBase64(Byte[]) Convert byte array to base64. Declaration public static string ToBase64(this byte[] data) Parameters Type Name Description Byte [] data The data. Returns Type Description String Base64 representation. ToBase64Url(ArraySegment, Nullable, Nullable) Convert array segment to base 64 URL representation. Declaration public static string ToBase64Url(this ArraySegment data, int? offset = default(int? ), int? count = default(int? )) Parameters Type Name Description ArraySegment < Byte > data Data to convert. Nullable < Int32 > offset Optional override offset. Nullable < Int32 > count Optional override count. Returns Type Description String Base 64 encoded string. ToCamelCase(String) Converts value to camel casing. Declaration public static string ToCamelCase(this string value) Parameters Type Name Description String value Value to convert. Returns Type Description String Returns string in camel case. ToPascalCase(String) Converts value to pascal casing. Declaration public static string ToPascalCase(this string value) Parameters Type Name Description String value Value to convert. Returns Type Description String Returns string in pascal case. TrimEnd(String, String) Remove a substring from the end of a given string. This is called iteratively. Declaration public static string TrimEnd(this string target, string trimString) Parameters Type Name Description String target The target. String trimString The trim string. Returns Type Description String The string after being trimmed. TrimStart(String, String) Remove a substring from the beginning of a given string. This is called iteratively. Declaration public static string TrimStart(this string target, string trimString) Parameters Type Name Description String target The target. String trimString The trim string. Returns Type Description String The string after being trimmed." - }, - "common/Microsoft.Graph.Communications.Common.TaskExtension.html": { - "href": "common/Microsoft.Graph.Communications.Common.TaskExtension.html", - "title": "Class TaskExtension", - "keywords": "Class TaskExtension Extensions for Task Inheritance Object TaskExtension Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class TaskExtension Methods ExpectExceptionAsync(Task, Type) Except an exception Declaration public static Task ExpectExceptionAsync(this Task task, Type expectedEx) Parameters Type Name Description Task task task Type expectedEx expected exception Returns Type Description Task Task representing completion ExpectExceptionAsync(Task, Type) Except an exception Declaration public static Task ExpectExceptionAsync(this Task task, Type expectedEx) Parameters Type Name Description Task task task Type expectedEx expected exception Returns Type Description Task Task representing completion Type Parameters Name Description T type IgnoreExceptionAsync(Task, Type) Ignore exception Declaration public static Task IgnoreExceptionAsync(this Task task, Type exceptionType) Parameters Type Name Description Task task task Type exceptionType exception type Returns Type Description Task Task representing completion IgnoreExceptionAsync(Task, Type) Ignore exception Declaration public static Task IgnoreExceptionAsync(this Task task, Type exceptionType) Parameters Type Name Description Task task task Type exceptionType exception type Returns Type Description Task Task representing completion Type Parameters Name Description T type" + "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventFormatterFlags.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventFormatterFlags.html", + "title": "Enum LogEventFormatterFlags", + "keywords": "Enum LogEventFormatterFlags The log event formatter enums Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum LogEventFormatterFlags Fields Name Description ForDefault For default case, which includes all fields. ForILoggerFactory For ILoggerFactory binding format, which doesn't include component and level, as these fields are set in ILogger outside of message. IncludeManagedThreadId Managed thread ID IncludeProcessId Process ID IncludesCallInfo Call info IncludesComponent Component IncludesCorrelationId Correlation ID IncludesLevel Level IncludesProperties Properties IncludesTimestamp Timestamp Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(LogEventFormatterFlags, String, String) Validator.Equals(LogEventFormatterFlags, String) Validator.NotEquals(LogEventFormatterFlags, String, String)" }, "common/Microsoft.Graph.Communications.Common.Telemetry.LoggingConstants.html": { "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LoggingConstants.html", "title": "Class LoggingConstants", "keywords": "Class LoggingConstants Constants used for logging that are common between server and client. Inheritance Object LoggingConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class LoggingConstants Fields ActivityTrackingLatencySeconds The activity tracking latency in seconds Declaration public const string ActivityTrackingLatencySeconds = \"ActivityTrackingLatencySeconds\" Field Value Type Description String AppId AppId constant. Declaration public const string AppId = \"AppId\" Field Value Type Description String ChatId Chat Id. Declaration public const string ChatId = \"ChatId\" Field Value Type Description String ChatInactivityTrackingExceedingInterval The chat inactivity tracking that exceeds the expected interval Declaration public const string ChatInactivityTrackingExceedingInterval = \"ChatInactivityTrackingExceedingInterval\" Field Value Type Description String CosmosDBCollection The name of CosmosDB collection Declaration public const string CosmosDBCollection = \"CosmosDBCollection\" Field Value Type Description String CosmosDBRequestCharge The metric name of CosmosDB request charge Declaration public const string CosmosDBRequestCharge = \"CosmosDBRequestCharge\" Field Value Type Description String CosmosDBRequestLatency The metric name of CosmosDB request latency in milliseconds Declaration public const string CosmosDBRequestLatency = \"CosmosDBRequestLatency\" Field Value Type Description String CosmosDBRequestType The CosmosDB request type, read/create/update/upsert/delete/query Declaration public const string CosmosDBRequestType = \"CosmosDBRequestType\" Field Value Type Description String ErrorCode The error code. Declaration public const string ErrorCode = \"ErrorCode\" Field Value Type Description String FailedBridgedMessages Failed bridged messages constant. Declaration public const string FailedBridgedMessages = \"FailedBridgedMessages\" Field Value Type Description String FailedChatInactivityTracking The failed chat inactivity tracking Declaration public const string FailedChatInactivityTracking = \"FailedChatInactivityTracking\" Field Value Type Description String FailedChatInactivityTrackingSum The failed chat inactivity tracking sum Declaration public const string FailedChatInactivityTrackingSum = \"FailedChatInactivityTrackingSum\" Field Value Type Description String FailedChatNotifications The failed chat notifications Declaration public const string FailedChatNotifications = \"FailedChatNotifications\" Field Value Type Description String FailedRoutingCacheRequests The failed routing cache requests. Declaration public const string FailedRoutingCacheRequests = \"FailedRoutingCacheRequests\" Field Value Type Description String HTTPMetrics The namespace of HTTP metrics Declaration public const string HTTPMetrics = \"HTTPMetrics\" Field Value Type Description String InstanceId Instance ID. Declaration public const string InstanceId = \"InstanceId\" Field Value Type Description String JsonSerializationMaxDepth Max depth of json serializer in case the json serializer settings is configured as ReferenceLoopHandling.Serialize Declaration public const int JsonSerializationMaxDepth = 10 Field Value Type Description Int32 Method Method dimension name. Declaration public const string Method = \"Method\" Field Value Type Description String ObjectId UserId constant. Declaration public const string ObjectId = \"ObjectId\" Field Value Type Description String Operation Operation dimension name. Declaration public const string Operation = \"Operation\" Field Value Type Description String OutgoingChatMessageLatency The time taken to send outgoing message. Declaration public const string OutgoingChatMessageLatency = \"OutgoingChatMessageLatency\" Field Value Type Description String PartitionKey Partition Id. Declaration public const string PartitionKey = \"PartitionKey\" Field Value Type Description String Partner Partner dimension name. Declaration public const string Partner = \"Partner\" Field Value Type Description String PropertyDoesNotExist Property does not exist error message Declaration public const string PropertyDoesNotExist = \"Property doesn't exist in LogEvent Properties dictionary.\" Field Value Type Description String ReplaceId The constant pointing to the replace id to be used for Api Path. Declaration public const string ReplaceId = \"\" Field Value Type Description String RequestId The request ID (used to identify request-response pair) Declaration public const string RequestId = \"RequestId\" Field Value Type Description String RequestPath Request path dimension name. Declaration public const string RequestPath = \"RequestPath\" Field Value Type Description String ResponseTimeInMilliseconds The metric name of HTTP response time Declaration public const string ResponseTimeInMilliseconds = \"Response time in milli-seconds\" Field Value Type Description String Result The result. Declaration public const string Result = \"Result\" Field Value Type Description String RoutingCacheRequests The routing cache requests. Declaration public const string RoutingCacheRequests = \"RoutingCacheRequests\" Field Value Type Description String StatusCode StatusCode dimension name. Declaration public const string StatusCode = \"StatusCode\" Field Value Type Description String SuccessfulBridgedMessages Successful bridged messages constant. Declaration public const string SuccessfulBridgedMessages = \"SuccessfulBridgedMessages\" Field Value Type Description String SuccessfulChatInactivityTracking The successful chat inactivity tracking Declaration public const string SuccessfulChatInactivityTracking = \"SuccessfulChatInactivityTracking\" Field Value Type Description String SuccessfulChatInactivityTrackingSum The successful chat inactivity tracking sum. Declaration public const string SuccessfulChatInactivityTrackingSum = \"SuccessfulChatInactivityTrackingSum\" Field Value Type Description String SuccessfulChatNotifications The successful chat notifications Declaration public const string SuccessfulChatNotifications = \"SuccessfulChatNotifications\" Field Value Type Description String TenantId Tenant Id constant. Declaration public const string TenantId = \"TenantId\" Field Value Type Description String TotalChatInactivityTracking The total chat inactivity tracking Declaration public const string TotalChatInactivityTracking = \"TotalChatInactivityTracking\" Field Value Type Description String UserAgent UserAgent dimension name. Declaration public const string UserAgent = \"UserAgent\" Field Value Type Description String" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCallExtensions.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCallExtensions.html", - "title": "Class MediaCallExtensions", - "keywords": "Class MediaCallExtensions Stateful call media extensions Inheritance Object MediaCallExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public static class MediaCallExtensions Methods CreateMediaSession(ICall, AudioSocketSettings, VideoSocketSettings, VideoSocketSettings, DataSocketSettings, Guid) Creates a local media session for the provided call with a given socket configuration. Declaration public static ILocalMediaSession CreateMediaSession(this ICall call, AudioSocketSettings audioSocketSettings, VideoSocketSettings videoSocketSettings, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null, Guid mediaSessionId = default(Guid)) Parameters Type Name Description ICall call The call. AudioSocketSettings audioSocketSettings The audio socket settings. VideoSocketSettings videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Guid mediaSessionId The id for the media session. Returns Type Description ILocalMediaSession A ILocalMediaSession . Exceptions Type Condition ArgumentNullException If the call has not been specified. ArgumentException If the call does not have a valid identifier. CreateMediaSession(ICall, AudioSocketSettings, IEnumerable, VideoSocketSettings, DataSocketSettings, Guid) Creates a local media session for the provided call with a given socket configuration. Declaration public static ILocalMediaSession CreateMediaSession(this ICall call, AudioSocketSettings audioSocketSettings, IEnumerable videoSocketSettings = null, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null, Guid mediaSessionId = default(Guid)) Parameters Type Name Description ICall call The call. AudioSocketSettings audioSocketSettings The audio socket settings. IEnumerable < VideoSocketSettings > videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Guid mediaSessionId The id for the media session. Returns Type Description ILocalMediaSession A ILocalMediaSession . Exceptions Type Condition ArgumentNullException If the call has not been specified. ArgumentException If the call does not have a valid identifier. GetLocalMediaSession(ICall) Gets the local media session for this call object. Declaration public static ILocalMediaSession GetLocalMediaSession(this ICall call) Parameters Type Name Description ICall call The call. Returns Type Description ILocalMediaSession Local media session object Exceptions Type Condition InvalidCastException This call does not have a valid ILocalMediaSession object." + "common/Microsoft.Graph.Communications.Common.SafeNativeMethods.html": { + "href": "common/Microsoft.Graph.Communications.Common.SafeNativeMethods.html", + "title": "Class SafeNativeMethods", + "keywords": "Class SafeNativeMethods Contains p/invokes and associated wrappers for the Native methods Inheritance Object SafeNativeMethods Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class SafeNativeMethods Methods GetPreciseSystemTime() Gets precise system time Declaration public static DateTime GetPreciseSystemTime() Returns Type Description DateTime Precise system time" }, - "common/Microsoft.Graph.html": { - "href": "common/Microsoft.Graph.html", - "title": "Namespace Microsoft.Graph", - "keywords": "Namespace Microsoft.Graph Classes AdditionalDataExtensions The identity set extensions" + "common/Microsoft.Graph.Communications.Common.ReflectionUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.ReflectionUtils.html", + "title": "Class ReflectionUtils", + "keywords": "Class ReflectionUtils Reflection utilities Inheritance Object ReflectionUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class ReflectionUtils Methods DerivesFrom(Type, Type) Check if the type derives from the base type Declaration public static bool DerivesFrom(this Type type, Type baseType) Parameters Type Name Description Type type Type to check Type baseType Base type Returns Type Description Boolean True if it is or derives from the base type DerivesFrom(Type) Check if the type derives from the T type. Declaration public static bool DerivesFrom(this Type type) Parameters Type Name Description Type type Type to check Returns Type Description Boolean True if it is or derives from the base type Type Parameters Name Description T The type to check. GetPropertyUsingReflection(Object, String) Get named property of an object Declaration public static object GetPropertyUsingReflection(this object obj, string name) Parameters Type Name Description Object obj Object to get property from. String name Name of the property. Returns Type Description Object Value of the property GetValueCached(PropertyInfo, Object) Gets the value using a cached delegate. Declaration public static object GetValueCached(this PropertyInfo propertyInfo, object object) Parameters Type Name Description PropertyInfo propertyInfo The property info to use. Object object The object containing the property. Returns Type Description Object The fetched object. Implements(Type, Type) Check if type is subclass of a generic type. Declaration public static bool Implements(this Type type, Type checkType) Parameters Type Name Description Type type Type to check. Type checkType Generic type. Returns Type Description Boolean True if it is a subclass. Implements(Type) Check if type is subclass of a generic type. Declaration public static bool Implements(this Type type) Parameters Type Name Description Type type Type to check. Returns Type Description Boolean True if it is a subclass. Type Parameters Name Description T The type to check. SetPropertyUsingReflection(Object, String, Object) Set named property of an object Declaration public static bool SetPropertyUsingReflection(this object obj, string name, object value) Parameters Type Name Description Object obj Object to get property from. String name Name of the property. Object value Value of the property. Returns Type Description Boolean true if the property was set successfully, false otherwise SetValueCached(PropertyInfo, Object, Object) Set the value using a cached delegate. Declaration public static void SetValueCached(this PropertyInfo propertyInfo, object object, object value) Parameters Type Name Description PropertyInfo propertyInfo The property info to use. Object object The object containing the property. Object value The value to be set." }, - "core/Microsoft.Graph.ContractsConstants.EntityContainerNames.html": { - "href": "core/Microsoft.Graph.ContractsConstants.EntityContainerNames.html", - "title": "Class ContractsConstants.EntityContainerNames", - "keywords": "Class ContractsConstants.EntityContainerNames Singleton/EntitySet constants Inheritance Object ContractsConstants.EntityContainerNames Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class EntityContainerNames Fields Application The application singleton root. Compatible for old path. Declaration public const string Application = \"app\" Field Value Type Description String CallRecords The \"callRecords\" Declaration public const string CallRecords = \"callRecords\" Field Value Type Description String Communications The communications singleton for v1. Declaration public const string Communications = \"communications\" Field Value Type Description String Me The \"me\" Declaration public const string Me = \"me\" Field Value Type Description String Presence The \"presence\" Declaration public const string Presence = \"presence\" Field Value Type Description String Users The users Declaration public const string Users = \"users\" Field Value Type Description String" + "common/Microsoft.Graph.Communications.Common.MetricUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.MetricUtils.html", + "title": "Class MetricUtils", + "keywords": "Class MetricUtils The metric utils class Inheritance Object MetricUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class MetricUtils Methods MeasureDurationAsync(Func, Action) Mesure the duration of task. Declaration public static Task MeasureDurationAsync(Func task, Action setMetricTask) Parameters Type Name Description Func < Task > task The task to measure Action < Int64 > setMetricTask The task to set metric Returns Type Description Task The task for wait" }, - "core/Microsoft.Graph.ContractsConstants.IdentityProperties.html": { - "href": "core/Microsoft.Graph.ContractsConstants.IdentityProperties.html", - "title": "Class ContractsConstants.IdentityProperties", - "keywords": "Class ContractsConstants.IdentityProperties Identity properties constants Inheritance Object ContractsConstants.IdentityProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class IdentityProperties Fields ApplicationInstance The application instance identity. Declaration public const string ApplicationInstance = \"applicationInstance\" Field Value Type Description String Encrypted The encrypted identity. Declaration public const string Encrypted = \"encrypted\" Field Value Type Description String Guest The guest identity. Declaration public const string Guest = \"guest\" Field Value Type Description String Hidden The hidden identity. Declaration public const string Hidden = \"hidden\" Field Value Type Description String IdentityProvider The identity provider TODO: Deprecated Declaration public const string IdentityProvider = \"identityProvider\" Field Value Type Description String IdentityProviderAAD The AAD identity provider TODO: Deprecated Declaration public const string IdentityProviderAAD = \"AAD\" Field Value Type Description String IdentityProviderMSA The MSA identity provider TODO: Deprecated Declaration public const string IdentityProviderMSA = \"MSA\" Field Value Type Description String IdentityProviderNone The None identity provider TODO: Deprecated Declaration public const string IdentityProviderNone = \"None\" Field Value Type Description String OnPremises The on-premises identity. Declaration public const string OnPremises = \"onPremises\" Field Value Type Description String Phone The phone identity. Declaration public const string Phone = \"phone\" Field Value Type Description String TenantId The tenant identity. Declaration public const string TenantId = \"tenantId\" Field Value Type Description String" + "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.CallData.html": { + "href": "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.CallData.html", + "title": "Class LogProperties.CallData", + "keywords": "Class LogProperties.CallData Call data. Inheritance Object LogProperties.CallData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class CallData Constructors CallData() Declaration public CallData() Properties CallId Gets or sets the call identifier. Declaration public string CallId { get; set; } Property Value Type Description String TenantId Gets or sets the tenant identifier. Declaration public string TenantId { get; set; } Property Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphRequest.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphRequest.html", - "title": "Interface IGraphRequest", - "keywords": "Interface IGraphRequest The request object used by the graph sdk. Inherited Members IGraphRequest.Uri IGraphRequest.RequestType IGraphExchange.Content IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphRequest : IGraphRequest, IGraphExchange, IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphRequestExtensions.ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable)" + "calls/Microsoft.Graph.Communications.Calls.CallCollectionExtensions.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.CallCollectionExtensions.html", + "title": "Class CallCollectionExtensions", + "keywords": "Class CallCollectionExtensions Extensions for call collections. Inheritance Object CallCollectionExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public static class CallCollectionExtensions Methods AddAsync(ICallCollection, JoinMeetingParameters, Guid, CancellationToken) Join a new meeting with the provided parameters Declaration public static Task AddAsync(this ICallCollection callCollection, JoinMeetingParameters parameters, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ICallCollection callCollection The call collection. JoinMeetingParameters parameters The join meeting parameters. Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < ICall > The stateful call object once the call is joined." }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphRequest-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphRequest-1.html", - "title": "Interface IGraphRequest", - "keywords": "Interface IGraphRequest The request object with content. Inherited Members IGraphExchange.Content IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphRequest : IGraphExchange, IGraphExchange Type Parameters Name Description T Type of data to be sent as part of request body. Properties RequestType Gets the type of the request. Declaration RequestType RequestType { get; } Property Value Type Description RequestType The type of the request. Uri Gets the URI location for the request. Declaration Uri Uri { get; } Property Value Type Description Uri The URI. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphRequestExtensions.ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable) See Also IGraphExchange " + "bot_media/Microsoft.Skype.Bots.Media.IDataSocket.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.IDataSocket.html", + "title": "Interface IDataSocket", + "keywords": "Interface IDataSocket Reserved for the internal use. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IDataSocket : IDisposable Methods Send(DataMediaBuffer, UInt32[]) Reserved for the internal use. Declaration void Send(DataMediaBuffer buffer, uint[] recipientIds) Parameters Type Name Description DataMediaBuffer buffer UInt32 [] recipientIds Events DataMediaReceived Reserved for the internal use. Declaration event EventHandler DataMediaReceived Event Type Type Description EventHandler < DataMediaReceivedEventArgs > DataSendStatusChanged Reserved for the internal use. Declaration event EventHandler DataSendStatusChanged Event Type Type Description EventHandler < DataSendStatusChangedEventArgs > MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs >" }, - "common/Microsoft.Graph.Communications.Common.TaskQueue.html": { - "href": "common/Microsoft.Graph.Communications.Common.TaskQueue.html", - "title": "Class TaskQueue", - "keywords": "Class TaskQueue Task queue to encapsulate chaining of tasks. Inheritance Object Disposable ObjectRootDisposable TaskQueue Implements IDisposable Inherited Members ObjectRootDisposable.GraphLogger Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class TaskQueue : ObjectRootDisposable, IDisposable Constructors TaskQueue(IGraphLogger, Task) Initializes a new instance of the TaskQueue class. Declaration public TaskQueue(IGraphLogger logger, Task antecedent = null) Parameters Type Name Description IGraphLogger logger Logger instance. Task antecedent Optional antecedent task. Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) EnqueueAsync(Func) Enqueue an operation Declaration public Task EnqueueAsync(Func operation) Parameters Type Name Description Func < Task , Task > operation Operation to queue. Returns Type Description Task A task that represents the queued operation. Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.LowOnFramesEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.LowOnFramesEventArgs.html", + "title": "Class LowOnFramesEventArgs", + "keywords": "Class LowOnFramesEventArgs LowOnFrames event arguments Inheritance Object EventArgs LowOnFramesEventArgs AudioLowOnFramesEventArgs VideoLowOnFramesEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class LowOnFramesEventArgs : EventArgs Constructors LowOnFramesEventArgs() Declaration public LowOnFramesEventArgs() Properties MediaType MediaType of the low on frame event Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType RemainingMediaLengthInMS Remaining enqueued media length in MS Declaration public int RemainingMediaLengthInMS { get; set; } Property Value Type Description Int32" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.IGraphLogger.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.IGraphLogger.html", - "title": "Interface IGraphLogger", - "keywords": "Interface IGraphLogger The logger interface used by Graph Services. This logger emits logs that can be observed by different observers. Inherited Members IObservable.Subscribe(IObserver) Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphLogger : IObservable Properties CorrelationId Gets or sets the correlation identifier. This is used to track correlation between multiple requests for one scenario. Declaration Guid CorrelationId { get; set; } Property Value Type Description Guid DiagnosticLevel Gets or sets the diagnostic level for the logger. Declaration TraceLevel DiagnosticLevel { get; set; } Property Value Type Description TraceLevel LogicalThreadId Gets or sets the logical thread identifier. This id is used for tracking the flow of one request throughout the lifetime until it ends. Declaration uint LogicalThreadId { get; set; } Property Value Type Description UInt32 ObfuscationConfiguration Gets the obfuscation configuration. This is used to obfuscate PII and other data. Declaration ObfuscationConfiguration ObfuscationConfiguration { get; } Property Value Type Description ObfuscationConfiguration Properties Gets the properties of the logger. Declaration IReadOnlyDictionary Properties { get; } Property Value Type Description IReadOnlyDictionary < Type , Object > Methods Log(TraceLevel, String, String, Guid, Guid, LogEventType, IEnumerable, String, String, Int32) Log messages classified as the provided trace level. Declaration LogEvent Log(TraceLevel level, string message, string component = null, Guid correlationId = default(Guid), Guid requestId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The trace level. String message A composite format string that includes one or more format items. String component The component in which log is created Guid correlationId The correlation identifier. Guid requestId The request identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.CreateObserver(IObservable, Action, Action, Action) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) LoggingExtensions.Log(IGraphLogger, TraceLevel, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Info(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Verbose(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.LogHttpMessage(IGraphLogger, TraceLevel, TransactionDirection, HttpTraceType, String, String, String, IEnumerable>>, Int32, String, Nullable, Guid, Guid, String, String, Int32) LoggingExtensions.Metric(IGraphLogger, String, String, Int64, Dictionary, Boolean, String, Guid, String, String, Int32) LoggingExtensions.SerializeAndObfuscate(IGraphLogger, Object, Formatting) LoggingExtensions.Obfuscate(IGraphLogger, Object, ObfuscationTag) LoggingExtensions.GetHeaderText(IGraphLogger, IEnumerable>>) LoggingExtensions.CreateShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) LoggingExtensions.CreateILogger(IGraphLogger, String, Guid, LogEventType, IEnumerable) LoggingExtensions.EnterMethod(IGraphLogger, Guid, String, String, Int32) LoggingExtensions.LeaveMethod(IGraphLogger, Guid, String, String, Int32)" + "bot_media/Microsoft.Skype.Bots.Media.DominantSpeakerChangedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.DominantSpeakerChangedEventArgs.html", + "title": "Class DominantSpeakerChangedEventArgs", + "keywords": "Class DominantSpeakerChangedEventArgs Event arguments of the DominantSpeakerChanged event. Inheritance Object EventArgs DominantSpeakerChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class DominantSpeakerChangedEventArgs : EventArgs Constructors DominantSpeakerChangedEventArgs() Declaration public DominantSpeakerChangedEventArgs() Fields None Constant value which indicates there is no dominant speaker in the conference. Declaration public const uint None = 4294967295U Field Value Type Description UInt32 Properties CurrentDominantSpeaker Current dominant speaker in the conference. The value is the MediaSourceId (MSI) of the dominant speaker in the conference. If there is no dominant speaker in the conference this value will be None (0xFFFFFFFF). Declaration public uint CurrentDominantSpeaker { get; set; } Property Value Type Description UInt32 DominantSpeakerHistory History of the dominant speakers. However, DominantSpeakerHistory won't contain any element to indicate the absence of dominant speaker in the conference. Declaration public uint[] DominantSpeakerHistory { get; set; } Property Value Type Description UInt32 []" }, - "common/Microsoft.Graph.Communications.Common.OData.ODataTimeSpanConverter.html": { - "href": "common/Microsoft.Graph.Communications.Common.OData.ODataTimeSpanConverter.html", - "title": "Class ODataTimeSpanConverter", - "keywords": "Class ODataTimeSpanConverter Custom json converter for TimeSpans. Inheritance Object ODataTimeSpanConverter Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ODataTimeSpanConverter : JsonConverter Constructors ODataTimeSpanConverter() Declaration public ODataTimeSpanConverter() Properties CanWrite Declaration public override bool CanWrite { get; } Property Value Type Description Boolean Methods CanConvert(Type) Declaration public override bool CanConvert(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Boolean ReadJson(JsonReader, Type, Object, JsonSerializer) Deserializes the object to the correct type. Declaration public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonReader reader The Newtonsoft.Json.JsonReader to read from. Type objectType The interface type. Object existingValue The existing value of the object being read. Newtonsoft.Json.JsonSerializer serializer The Newtonsoft.Json.JsonSerializer for deserialization. Returns Type Description Object The deserialized object WriteJson(JsonWriter, Object, JsonSerializer) Declaration public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonWriter writer Object value Newtonsoft.Json.JsonSerializer serializer Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.GuidUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.GuidUtils.html", + "title": "Class GuidUtils", + "keywords": "Class GuidUtils Guid Utils Inheritance Object GuidUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class GuidUtils Methods EnsureNotEmpty(Guid) Ensures Guid is not empty by generating a random guid if it is empty Declaration public static Guid EnsureNotEmpty(this Guid guid) Parameters Type Name Description Guid guid input guid Returns Type Description Guid A guaranteed guid that is not empty EnsureNotEmpty(Nullable) Ensures Guid is not empty by generating a random guid if it is empty Declaration public static Guid EnsureNotEmpty(this Guid? guid) Parameters Type Name Description Nullable < Guid > guid input guid Returns Type Description Guid A guaranteed guid that is not empty ParseOrNew(String) Parse and return the guid if valid else return new guid Declaration public static Guid ParseOrNew(string input) Parameters Type Name Description String input input Returns Type Description Guid Guid of input or new guid" }, - "common/Microsoft.Graph.Communications.Common.OData.ODataSerializeAsTypeAttribute.html": { - "href": "common/Microsoft.Graph.Communications.Common.OData.ODataSerializeAsTypeAttribute.html", - "title": "Class ODataSerializeAsTypeAttribute", - "keywords": "Class ODataSerializeAsTypeAttribute Specify how a given object should be written/read on the wire. Inheritance Object Attribute ODataSerializeAsTypeAttribute Implements _Attribute Inherited Members Attribute.GetCustomAttributes(MemberInfo, Type) Attribute.GetCustomAttributes(MemberInfo, Type, Boolean) Attribute.GetCustomAttributes(MemberInfo) Attribute.GetCustomAttributes(MemberInfo, Boolean) Attribute.IsDefined(MemberInfo, Type) Attribute.IsDefined(MemberInfo, Type, Boolean) Attribute.GetCustomAttribute(MemberInfo, Type) Attribute.GetCustomAttribute(MemberInfo, Type, Boolean) Attribute.GetCustomAttributes(ParameterInfo) Attribute.GetCustomAttributes(ParameterInfo, Type) Attribute.GetCustomAttributes(ParameterInfo, Type, Boolean) Attribute.GetCustomAttributes(ParameterInfo, Boolean) Attribute.IsDefined(ParameterInfo, Type) Attribute.IsDefined(ParameterInfo, Type, Boolean) Attribute.GetCustomAttribute(ParameterInfo, Type) Attribute.GetCustomAttribute(ParameterInfo, Type, Boolean) Attribute.GetCustomAttributes(Module, Type) Attribute.GetCustomAttributes(Module) Attribute.GetCustomAttributes(Module, Boolean) Attribute.GetCustomAttributes(Module, Type, Boolean) Attribute.IsDefined(Module, Type) Attribute.IsDefined(Module, Type, Boolean) Attribute.GetCustomAttribute(Module, Type) Attribute.GetCustomAttribute(Module, Type, Boolean) Attribute.GetCustomAttributes(Assembly, Type) Attribute.GetCustomAttributes(Assembly, Type, Boolean) Attribute.GetCustomAttributes(Assembly) Attribute.GetCustomAttributes(Assembly, Boolean) Attribute.IsDefined(Assembly, Type) Attribute.IsDefined(Assembly, Type, Boolean) Attribute.GetCustomAttribute(Assembly, Type) Attribute.GetCustomAttribute(Assembly, Type, Boolean) Attribute.Equals(Object) Attribute.GetHashCode() Attribute.Match(Object) Attribute.IsDefaultAttribute() Attribute._Attribute.GetTypeInfoCount(UInt32) Attribute._Attribute.GetTypeInfo(UInt32, UInt32, IntPtr) Attribute._Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr) Attribute._Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr) Attribute.TypeId Object.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax [AttributeUsage(AttributeTargets.Class, AllowMultiple = false, Inherited = false)] public class ODataSerializeAsTypeAttribute : Attribute, _Attribute Constructors ODataSerializeAsTypeAttribute(String, Boolean) Initializes a new instance of the ODataSerializeAsTypeAttribute class. Declaration public ODataSerializeAsTypeAttribute(string name, bool renameWhenSerialized = true) Parameters Type Name Description String name The name of the class. Boolean renameWhenSerialized If set to true use the Name to serialize the class. Properties Name Gets the name of the class. Declaration public string Name { get; } Property Value Type Description String RenameWhenSerialized Gets a value indicating whether to rename when serializing this object. When true, the object will be serialized to Name , otherwise the object will be serialized as the actual object name. Declaration public bool RenameWhenSerialized { get; } Property Value Type Description Boolean Implements System.Runtime.InteropServices._Attribute Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also Attribute" + "bot_media/Microsoft.Skype.Bots.Media.VideoSettings.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSettings.html", + "title": "Class VideoSettings", + "keywords": "Class VideoSettings Video Frame player settings Inheritance Object VideoSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoSettings Constructors VideoSettings() Declaration public VideoSettings()" }, - "client/Microsoft.Graph.Communications.Client.PagedList-1.html": { - "href": "client/Microsoft.Graph.Communications.Client.PagedList-1.html", - "title": "Class PagedList", - "keywords": "Class PagedList An object that contains paginated list of the generic type T. Inheritance Object PagedList Implements IPagedList IReadOnlyList IReadOnlyCollection IEnumerable IEnumerable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class PagedList : IPagedList, IReadOnlyList, IReadOnlyCollection, IEnumerable, IEnumerable Type Parameters Name Description T The type of Paged List. Constructors PagedList() Declaration public PagedList() Properties AdditionalData Gets or sets the additional data. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > Count Declaration public int Count { get; } Property Value Type Description Int32 Item[Int32] Declaration public T this[int index] { get; } Parameters Type Name Description Int32 index Property Value Type Description T NextLinkUrl Gets the next link URL taken from @odata.nextLink. Declaration public Uri NextLinkUrl { get; } Property Value Type Description Uri Value Gets or sets the value in the current page of the list. Declaration public IList Value { get; set; } Property Value Type Description IList Methods GetEnumerator() Declaration public IEnumerator GetEnumerator() Returns Type Description IEnumerator Explicit Interface Implementations IEnumerable.GetEnumerator() Declaration IEnumerator IEnumerable.GetEnumerator() Returns Type Description IEnumerator Implements IPagedList System.Collections.Generic.IReadOnlyList System.Collections.Generic.IReadOnlyCollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable" + "bot_media/Microsoft.Skype.Bots.Media.StreamDirection.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.StreamDirection.html", + "title": "Enum StreamDirection", + "keywords": "Enum StreamDirection Stream directionality, from the point-of-view of the local media endpoint. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum StreamDirection Fields Name Description Inactive Media cannot be sent nor received Recvonly Media can be received but not sent Sendonly Media can be sent but not received Sendrecv Media can be sent and received" }, - "client/Microsoft.Graph.Communications.Client.Cache.CacheContext-1.html": { - "href": "client/Microsoft.Graph.Communications.Client.Cache.CacheContext-1.html", - "title": "Struct CacheContext", - "keywords": "Struct CacheContext The stored cache context Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() ValueType.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Graph.Communications.Client.Cache Assembly : Microsoft.Graph.Communications.Client.dll Syntax public struct CacheContext where TEntity : Entity Type Parameters Name Description TEntity The type of the entity. Properties Id Gets or sets the context identifier. Declaration public string Id { get; set; } Property Value Type Description String Resource Gets or sets the resource. Declaration public TEntity Resource { get; set; } Property Value Type Description TEntity ScenarioId Gets or sets the scenario identifier associated with this resource. Declaration public Guid ScenarioId { get; set; } Property Value Type Description Guid TenantId Gets or sets the tenant identifier associated with this resource. Declaration public string TenantId { get; set; } Property Value Type Description String" + "common/Microsoft.Graph.Communications.Common.Telemetry.TransactionDirection.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.TransactionDirection.html", + "title": "Enum TransactionDirection", + "keywords": "Enum TransactionDirection Direction for request message. Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum TransactionDirection Fields Name Description Incoming The incoming request message. Outgoing The outgoing request message. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(TransactionDirection, String, String) Validator.Equals(TransactionDirection, String) Validator.NotEquals(TransactionDirection, String, String)" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.BaseFilter-2.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.BaseFilter-2.html", - "title": "Class BaseFilter", - "keywords": "Class BaseFilter Base filter. Inheritance Object BaseFilter BaseFilter ContentDispositionFilter ContentTypeFilter HeaderFilter UriFilter Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public abstract class BaseFilter : BaseFilter Type Parameters Name Description T1 Type of input for the filter. T2 Return value for the evaluator. Constructors BaseFilter() Declaration protected BaseFilter() Properties MatchableString Gets or sets the string for which this filter is a match. Declaration public T2 MatchableString { get; protected set; } Property Value Type Description T2 MatchEvaluator Gets or sets the match evaluator that converts the input value to target value. Declaration public Func MatchEvaluator { get; protected set; } Property Value Type Description Func Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationTag.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationTag.html", + "title": "Enum ObfuscationTag", + "keywords": "Enum ObfuscationTag Tag used to provide a hint for the type of obfuscation to perform. Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum ObfuscationTag Fields Name Description Fqdn FQDN that needs to be obfuscated. An example would be \"lyncfrontend.lync.com\" Generic A generic blob containing sensitive data that must be obfuscated completely. Guid A guid type that has to be obfuscated. Identity The subject of some information whose data needs to be obfuscated. An example would be \"The user {coolgal} is attempting to to perform some action\". MRIs are also considered identities. IpAddress IP address that needs to be obfuscated. An example would be \"187.23.33.1\" Pstn PSTN related information. An example would be a telephone number like \"+10005559999\". Uri Uri that needs to be obfuscated. This can have any scheme like http, https, etc. An example would be \" https://cheatdays.com/fitguy" ; This could be either absolute or relative uri. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(ObfuscationTag, String, String) Validator.Equals(ObfuscationTag, String) Validator.NotEquals(ObfuscationTag, String, String)" }, - "client/Microsoft.Graph.Communications.Resources.ResourceEventHandler-2.html": { - "href": "client/Microsoft.Graph.Communications.Resources.ResourceEventHandler-2.html", - "title": "Delegate ResourceEventHandler", - "keywords": "Delegate ResourceEventHandler The resource event handler delegate. Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public delegate void ResourceEventHandler(TSender sender, ResourceEventArgs e) where TEntity : Entity; Parameters Type Name Description TSender sender The sender. ResourceEventArgs e The event arguments. Type Parameters Name Description TSender The type of the resource. IResource TEntity The containing resource type. Entity Constructors ResourceEventHandler(Object, IntPtr) Declaration public ResourceEventHandler(object object, IntPtr method) Parameters Type Name Description Object object IntPtr method Methods BeginInvoke(TSender, ResourceEventArgs, AsyncCallback, Object) Declaration public virtual IAsyncResult BeginInvoke(TSender sender, ResourceEventArgs e, AsyncCallback callback, object object) Parameters Type Name Description TSender sender ResourceEventArgs e AsyncCallback callback Object object Returns Type Description IAsyncResult EndInvoke(IAsyncResult) Declaration public virtual void EndInvoke(IAsyncResult result) Parameters Type Name Description IAsyncResult result Invoke(TSender, ResourceEventArgs) Declaration public virtual void Invoke(TSender sender, ResourceEventArgs e) Parameters Type Name Description TSender sender ResourceEventArgs e" + "bot_media/Microsoft.Skype.Bots.Media.DataSocket.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.DataSocket.html", + "title": "Class DataSocket", + "keywords": "Class DataSocket Reserved for the internal use. Inheritance Object DataSocket Implements IDataSocket IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public sealed class DataSocket : IDataSocket, IDisposable, IInternalSocket Constructors DataSocket(DataSocketSettings) Reserverd for internal use. Declaration public DataSocket(DataSocketSettings settings) Parameters Type Name Description DataSocketSettings settings Methods Dispose() Reserved for the internal use. Declaration public void Dispose() Send(DataMediaBuffer, UInt32[]) Reserved for the internal use. Declaration public void Send(DataMediaBuffer buffer, uint[] recipientIds) Parameters Type Name Description DataMediaBuffer buffer UInt32 [] recipientIds Events DataMediaReceived Reserved for the internal use. Declaration public event EventHandler DataMediaReceived Event Type Type Description EventHandler < DataMediaReceivedEventArgs > DataSendStatusChanged Reserved for the internal use. Declaration public event EventHandler DataSendStatusChanged Event Type Type Description EventHandler < DataSendStatusChangedEventArgs > MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration public event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > Implements IDataSocket System.IDisposable" }, - "calls/Microsoft.Graph.Communications.Calls.CallExtensions.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.CallExtensions.html", - "title": "Class CallExtensions", - "keywords": "Class CallExtensions Extensions for calls. Inheritance Object CallExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public static class CallExtensions Methods AnswerAsync(ICall, IMediaSession, String, Guid, CancellationToken) Answers a call with locally hosted media configuration. Declaration public static Task AnswerAsync(this ICall call, IMediaSession mediaSession, string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ICall call The call to be answered. IMediaSession mediaSession The media session object which defines the media configuration. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated Exceptions Type Condition ArgumentNullException When mediaSession is not specified. AnswerAsync(ICall, IEnumerable, IEnumerable, String, Guid, CancellationToken) Answers a call with service hosted media configuration. Declaration public static Task AnswerAsync(this ICall call, IEnumerable preFetchMedia, IEnumerable acceptedModalities, string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ICall call The call to be answered. IEnumerable < MediaInfo > preFetchMedia List of media files that service will cache, so that when playing these media files; the latency is lower. IEnumerable < Modality > acceptedModalities The modalities to accept. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated Exceptions Type Condition ArgumentNullException When pre-fetch media is null. AnswerAsync(ICall, IEnumerable, String, Guid, CancellationToken) Answers a call with service hosted media configuration. Declaration public static Task AnswerAsync(this ICall call, IEnumerable acceptedModalities, string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ICall call The call to be answered. IEnumerable < Modality > acceptedModalities The modalities to accept. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated SetOutgoingCallOptions(Call, Nullable) Set outgoing call options for the call. Declaration public static void SetOutgoingCallOptions(this Call call, bool? allowGuestToBypassLobby) Parameters Type Name Description Call call The call. Nullable < Boolean > allowGuestToBypassLobby Enable bypass lobby when joining a group call as guest." + "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.html": { + "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.html", + "title": "Class ErrorConstants", + "keywords": "Class ErrorConstants Error Constants Inheritance Object ErrorConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class ErrorConstants" }, - "calls/Microsoft.Graph.Communications.Calls.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.html", - "title": "Namespace Microsoft.Graph.Communications.Calls", - "keywords": "Namespace Microsoft.Graph.Communications.Calls Classes CallCollectionExtensions Extensions for call collections. CallExtensions Extensions for calls. CommunicationsClientExtensions Extensions for stateful client. JoinMeetingParameters Class to define parameters required for joining a meeting. ParticipantExtensions Extensions for the stateful participant resource. PlayOperationResult Class to define parameters required for joining a meeting. RecordOperationResult Class to define parameters required for joining a meeting. Interfaces ICall The stateful call interface. ICallCollection The stateful call collection interface. IMediaSession The IMediaSession interface. For local media scenarios, this session object represents the modalities and the media configuration. IParticipant The stateful participant interface. This represents a single participant in a call. IParticipantCollection The stateful participant collection interface." + "core/Microsoft.Graph.Communications.Core.Notifications.FailedNotificationEventArgs.html": { + "href": "core/Microsoft.Graph.Communications.Core.Notifications.FailedNotificationEventArgs.html", + "title": "Class FailedNotificationEventArgs", + "keywords": "Class FailedNotificationEventArgs Event arguments used when exceptions are raised in callbacks. Inheritance Object FailedNotificationEventArgs Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class FailedNotificationEventArgs Constructors FailedNotificationEventArgs(NotificationEventArgs, Exception) Initializes a new instance of the FailedNotificationEventArgs class. Declaration public FailedNotificationEventArgs(NotificationEventArgs notification, Exception exception) Parameters Type Name Description NotificationEventArgs notification The NotificationEventArgs instance containing the event data. Exception exception The exception. Properties Exception Gets the exception being raised. Declaration public Exception Exception { get; } Property Value Type Description Exception Notification Gets the notification that was being processed while this callback failed. Declaration public NotificationEventArgs Notification { get; } Property Value Type Description NotificationEventArgs" }, - "client/Microsoft.Graph.Communications.Client.Notifications.html": { - "href": "client/Microsoft.Graph.Communications.Client.Notifications.html", - "title": "Namespace Microsoft.Graph.Communications.Client.Notifications", - "keywords": "Namespace Microsoft.Graph.Communications.Client.Notifications Classes FixedSizeQueue A class that implements a fixed size list." + "calls_media/Microsoft.Graph.Communications.Calls.Media.ILocalMediaSession.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.ILocalMediaSession.html", + "title": "Interface ILocalMediaSession", + "keywords": "Interface ILocalMediaSession Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public interface ILocalMediaSession : IMediaSession, IDisposable Properties AudioSocket Gets the audio socket associated with this media session. Declaration IAudioSocket AudioSocket { get; } Property Value Type Description IAudioSocket DataSocket Gets the data socket associated with this media session. Declaration IDataSocket DataSocket { get; } Property Value Type Description IDataSocket VbssSocket Gets the VBSS socket associated with this media session. Declaration IVideoSocket VbssSocket { get; } Property Value Type Description IVideoSocket VideoSocket Gets the video socket associated with this media session. If current media session contains multiple sockets, this will return the first one in the list. Declaration IVideoSocket VideoSocket { get; } Property Value Type Description IVideoSocket VideoSockets Gets the list of video socket associated with this media session. Declaration IReadOnlyList VideoSockets { get; } Property Value Type Description IReadOnlyList < IVideoSocket >" }, - "client/Microsoft.Graph.Communications.Common.Telemetry.html": { - "href": "client/Microsoft.Graph.Communications.Common.Telemetry.html", - "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry", - "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry Classes CommsLogEventFormatter Test log formatter. LogProperties The log properties. LogProperties.CallData Call data. LogProperties.ChatData Chat data." + "calls_media/Microsoft.Graph.Communications.Calls.Media.AudioSendBuffer.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.AudioSendBuffer.html", + "title": "Class AudioSendBuffer", + "keywords": "Class AudioSendBuffer Creates an Audio Buffer for Send and also implements Dispose Inheritance Object AudioSendBuffer Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public class AudioSendBuffer : AudioMediaBuffer Constructors AudioSendBuffer(IntPtr, Int64, AudioFormat, Int64) Initializes a new instance of the AudioSendBuffer class. Declaration public AudioSendBuffer(IntPtr data, long length, AudioFormat audioFormat, long timeStamp = 0L) Parameters Type Name Description IntPtr data The buffer data. Int64 length The length of the buffer. AudioFormat audioFormat The audio format. Int64 timeStamp The time stamp. Methods Dispose(Boolean) Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing" }, - "client/Microsoft.Graph.Communications.Resources.CollectionEventArgs-1.html": { - "href": "client/Microsoft.Graph.Communications.Resources.CollectionEventArgs-1.html", - "title": "Class CollectionEventArgs", - "keywords": "Class CollectionEventArgs The collection event arguments. Inheritance Object CollectionEventArgs Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class CollectionEventArgs Type Parameters Name Description TEntity The containing stateful resource type. IResource Constructors CollectionEventArgs(String, ICollection, ICollection, ICollection) Initializes a new instance of the CollectionEventArgs class. Declaration public CollectionEventArgs(string resourcePath, ICollection addedResources = null, ICollection updatedResources = null, ICollection removedResources = null) Parameters Type Name Description String resourcePath The resource path. ICollection addedResources The added resources. ICollection updatedResources The updated resources. ICollection removedResources The removed resources. Properties AddedResources Gets the added resources. Declaration public ICollection AddedResources { get; } Property Value Type Description ICollection AdditionalData Gets or sets the additional data for the event. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > RemovedResources Gets the removed resources. Declaration public ICollection RemovedResources { get; } Property Value Type Description ICollection ResourcePath Gets the resource path for the collection. Declaration public string ResourcePath { get; } Property Value Type Description String UpdatedResources Gets the updated resource. Declaration public ICollection UpdatedResources { get; } Property Value Type Description ICollection " + "bot_media/Microsoft.Skype.Bots.Media.VideoMediaStreamQualityChangedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoMediaStreamQualityChangedEventArgs.html", + "title": "Class VideoMediaStreamQualityChangedEventArgs", + "keywords": "Class VideoMediaStreamQualityChangedEventArgs Event arguments of the video media stream quality event. Inheritance Object EventArgs VideoMediaStreamQualityChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoMediaStreamQualityChangedEventArgs : EventArgs Constructors VideoMediaStreamQualityChangedEventArgs() Declaration public VideoMediaStreamQualityChangedEventArgs() Properties MediaQualityState Indicates the media quality state of the mediaStream quality changed event Declaration public MediaQualityState MediaQualityState { get; set; } Property Value Type Description MediaQualityState SocketId Socket id associated with the event Declaration public int SocketId { get; set; } Property Value Type Description Int32 VideoQualityType Indicates the media quality type of the media stream quality changed event Declaration public VideoQualityType VideoQualityType { get; set; } Property Value Type Description VideoQualityType" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.html", - "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters", - "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Classes BaseFilter Non generic base filter. BaseFilter Base filter. ContentDispositionFilter Does match of content disposition header. If content disposition matches filter then whole body is removed. ContentTypeFilter Does match of content-type header. If content-type matches filter then whole body is removed. GraphUriFilters Uri filters to filter PII in graph urls. HeaderFilter Header filters act as whitelists. UriFilter URI Filter. Any group matches from REGEX are obfuscated." + "bot_media/Microsoft.Skype.Bots.Media.VideoMediaReceivedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoMediaReceivedEventArgs.html", + "title": "Class VideoMediaReceivedEventArgs", + "keywords": "Class VideoMediaReceivedEventArgs Event arguments of a VideoMediaReceived event. Inheritance Object EventArgs VideoMediaReceivedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoMediaReceivedEventArgs : EventArgs Constructors VideoMediaReceivedEventArgs() Declaration public VideoMediaReceivedEventArgs() Properties Buffer The received video media buffer. Declaration public VideoMediaBuffer Buffer { get; set; } Property Value Type Description VideoMediaBuffer MediaType MediaType of the video socket. This could be Video or Vbss. The MediaType is set after the socket is passed to the CreateMediaConfiguration API. It may also be set via the VideoSocketSettings during socket creation. Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType SocketId The 0-based ID of the socket that is raising this event. This socket ID can be used in multiview (ie. more than 1 video socket) to determine which video socket is raising this event. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the Microsoft.Skype.Bots.Media.MediaPlatform (or IMediaPlatform) API CreateMediaConfiguration. Eg. If the collection of IVideoSocket objects in the CreateMediaConfiguration API contains { socketA, socketB, socketC }, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Declaration public int SocketId { get; set; } Property Value Type Description Int32" }, - "index.html": { - "href": "index.html", - "title": "Graph Communications Calling SDK", - "keywords": "Graph Communications Calling SDK Introduction The Graph Communications Calling SDK simplifies the creation of calling and meetings bots that use the Cloud Communications APIs . The SDK provides the functionality to manage states of resources in memory and simplify tasks like call setup and media session establishment. It provides interfaces for bot's service-to-service interactions with calls and meetings, including an optional Media Extension SDK that enables a bot developer to host media on their machines and gain access to low level Audio/Video sockets and media streams. SDK The Graph Communications Calling SDK is built on top of the Microsoft Graph API and distributed as NuGet packages. The Core Concepts article is designed to better explain all the constructs used by the SDKs. To dive right in and deploy a Calling Bot refer to the documentation in each sample for further instructions. The SDK is divided into multiple nuget packages each described as below. Microsoft.Graph.Communications.Common ( nuget ): This is the nuget containing all the utilities used throughout the Stateful SDK. It contains telemetry, http, obfuscation support along with helper methods. Microsoft.Graph.Communications.Core ( nuget ): This library contains the serialization and notification for the communications APIs. Microsoft.Graph.Communications.Client ( nuget ): This is the base client for the Stateful SDK. This implements all the common SDK features used within different verticals like calling, etc. Microsoft.Graph.Communications.Calls ( nuget ): This is the SDK that implements calling APIs. This supports making, receiving, and joining calls with Microsoft Teams users, and creating voice and video enabled bots. Microsoft.Graph.Communications.Calls.Media ( nuget ): This library allows developers to use the Microsoft.Graph.Communications.Calls SDK and gain direct access to the audio, video, screen sharing, and data streams. This is an optional library on top of Microsoft.Graph.Communications.Calls Microsoft.Skype.Bots.Media ( nuget ): The Real-Time Media Platform for Bots adds a new dimension to how bots can interact with users: by enabling real-time voice, video and screen sharing modalities. Concepts and Examples For more details on concepts used by the SDK and examples on joining calls and receiving calls please refer to the concepts and examples page. You can find samples using the following service: Stateful bot using Application Hosted Media on Azure Cloud Service Stateful bot using Application Hosted Media on Azure Service Fabric Stateful bot using Service Hosted Media running on Azure App Service . ICommunicationsClient and Extension Methods The Stateful SDK is exposed using a single class ICommunicationsClient . This class is defined in the Microsoft.Graph.Communications.Client nuget and has no dependency on the Microsoft.Graph.Communications.Calls calling vertical nuget package. The different verticals therefore make heavy usage of extension methods on ICommunicationsClient rather than standalone functions or properties. The intention here is to add new verticals into the ICommunicationsClient using the same pattern without the ICommunicationsClient itself taking a dependency on the new vertical's nuget, which provides greater decoupling between future verticals we will support. For a usage example please see the ICommunicationsClient.Calls() extension method. Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." + "core/index.html": { + "href": "core/index.html", + "title": "Graph Communications Core SDK", + "keywords": "Graph Communications Core SDK This library contains the common contracts and helpers not present in Microsoft.Graph SDK . The Core components can be found in the Microsoft.Graph namespace. Select a class on the left to dive into the reference docs Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." }, - "articles/index.html": { - "href": "articles/index.html", - "title": "Graph Core and Communications SDK Concepts", - "keywords": "Graph Core and Communications SDK Concepts The Graph signaling SDK is quite flexible and can run in multiple environments, and support both stateful and stateless architectures. It can run on Azure Cloud Service , Azure Service Fabric , and Azure App Service . Furthermore, because the SDK supports both .net framework 4.6.1+ and netstandard 2.0 it is cross platform . This article describes the key concepts in order to effectively utilize the Graph Core SDK and the Graph Communications SDK including the Calling SDK. Graph Communications Core SDK The GraphServiceClient object is the entry point to the Graph Core SDK. The majority of the Graph Core SDK is automatically generated by the Graph SDK generator using the OData resource model. It reflects the REST-ful wire protocol provided by the Graph Communications service. Graph Communications Stateful SDK and Client Builder The ICommunicationsClient object is the entry point to the Graph Communications SDK and the Calling SDK. This SDK is designed for stateful services and provides additional support on top of the Graph Core SDK for resource state management and media management. The ICommunicationsClientBuilder is the object used to construct a new ICommunicationsClient with the desired settings. Building media bots has additional considerations which are further outlined in the media section . Notification Dispatching Notifications for root collections, such as the ICallCollection generated by ICommunicationsClient.Calls() , are handled in a single queue. Any root resource, such as the ICall , that has been added to the root collection is given it's own queue. Any child resources, of the root resource, such as the ICallParticipant use the same queue as the root resource. Each queue will delivered event callbacks to the developer sequentially. The SDK will wait to deliver the next event callbacks until all the callbacks for the current event have been processed. This has been done as to help developers avoid concurrency issues and will in the future support resource versioning and jitter buffers. Important It is important for all event handlers to be non-blocking, and any long running operations need to be offloaded to another thread. Long running operations in any event will block further operations from being raised for the given resource. Example Outgoing Calls To illustrate functionality of the Graph Communications Calling SDK, the below examples demonstrate 2 common scenarios: how to make an outbound call to a Microsoft Teams user and how to join an existing Microsoft Teams meeting. Making an Outbound Call Assuming a bot has been properly registered and deployed, the ICommunicationsClient configured and built. The bot needs to create the Call object with the corresponding parameters and pass the object to the CallCollectionExtensions.AddAsync method as follows: Call callResource = new Call { Subject = \"**Subject**\", Targets = new List { new InvitationParticipantInfo { Identity = new IdentitySet { User = new Identity { Id = \"**Target's AAD ObjectId GUID**\" }, }, } }, TenantId = \"**The id of the tenant that will host the meeting**\" }; IMediaSession mediaSession = this.Client.CreateMediaSession(**media session settings**); ICall call = await this.Client.Calls().AddAsync(callResource, mediaSession); SDK will store the state of the call in memory after calling AddAsync . The returned call object above contains the call Id set by the service. Making an Outbound Call to Join an Existing Microsoft Teams Meeting The above example shows how to create an outbound call to single or multiple participants and create a new conversation. If the bot needs to join an existing conversation, the SDK provides an overload of AddAsync that takes JoinMeetingParameters as input. The bot needs to create the JoinMeetingParameters object with the corresponding meeting parameters and pass the object to the CallCollectionExtensions.AddAsync method as follows: ChatInfo chatInfo = new ChatInfo { MessageId = \"**Message Id**\", ThreadId = \"**Thread Id**\", ReplyChainMessageId = \"**Reply Chain Message Id**\" }; OrganizerMeetingInfo meetingInfo = new OrganizerMeetingInfo { Organizer = new IdentitySet { User = new Identity { Id = \"**Meeting Organizer's AAD ObjectId GUID**\" }, } }; meetingInfo.Organizer.User.SetTenantId(\"**TenantId Guid**\"); IMediaSession mediaSession = this.Client.CreateMediaSession(**media session settings**); JoinMeetingParameters joinCallParameters = new JoinMeetingParameters( chatInfo, meetingInfo, mediaSession); ICall call = await this.Client.Calls().AddAsync(joinCallParameters); SDK will store the state of the call in memory after calling AddAsync . The returned call object above contains the callId set by the service. Example Incoming Calls Any time another user or bot places a call to your bot, you will receive a notification to the global application endpoint specified when registering your bot. Incoming call scenarios are supported with both Service Hosted Media and App Hosted Media configurations. Important For all incoming call scenarios, the initial incoming call notification will still be received using the BotBuilder protocol. The Graph SDK automatically returns 204 No Content to the initial notification to invoke the new Graph protocol. Answering incoming call with application hosted media First, subscribe to incoming calls. this.Client.Calls().OnIncoming += this.CallsOnIncoming; When incoming call comes, the bot needs to answer with an IMediaSession . This can be a media session created using the ICommunicationsClient.CreateMediaSession() extension or a custom IMediaSession . private void CallsOnIncoming(ICallCollection sender, CollectionEventArgs collectionEventArgs) { IMediaSession mediaSession = this.Client.CreateMediaSession( new AudioSocketSettings { StreamDirections = StreamDirection.Recvonly, SupportedAudioFormat = AudioFormat.Pcm16K }, new VideoSocketSettings { StreamDirections = StreamDirection.Sendrecv, ReceiveColorFormat = VideoColorFormat.NV12, SupportedSendVideoFormats = new List { VideoFormat.NV12_720x1280_30Fps, VideoFormat.NV12_1280x720_30Fps } } ); // Run async as not to block subsequent notifications. Task.Run(async () => { await collectionEventArgs .AddedResources .FirstOrDefault() .AnswerAsync(mediaSession) .ConfigureAwait(false); }); } Answer incoming call with service hosted media First subscribe to incoming calls. this.Client.Calls().OnIncoming += this.CallsOnIncoming; When incoming call comes, the bot will answer with a ServiceHostedMediaConfig . private void CallsOnIncoming(ICallCollection sender, CollectionEventArgs collectionEventArgs) { // Run async as not to block subsequent notifications. Task.Run(async () => { await collectionEventArgs .AddedResources .FirstOrDefault() .AnswerAsync(new Modality[] { Modality.Audio }) .ConfigureAwait(false); }); } State Management Graph Communications SDK can be used to store state of all resources in memory. This has 2 implications: The instance hosting the call needs to be up throughout the lifetime of a call. Any subsequent asynchronous notifications delivered by the service need to be redirected to the instance hosting the call. Any bot that hosts its own media stack should to be built using the Graph Communications SDK given that the media stream has a requirement that it needs to persist in memory throughout the lifetime of the call. More details can be found in the State Management article." + "bot_media/index.html": { + "href": "bot_media/index.html", + "title": "Graph Communications Bot Media SDK", + "keywords": "Graph Communications Bot Media SDK The Real-time Media Platform enables bots to interact with Microsoft Teams calls and meetings using real-time voice, video and screen sharing. This is an advanced capability which allows the bot to send and receive voice and video content frame by frame. The bot has \"raw\" access to the voice, video and screen sharing media streams. (Bots which process media themselves are called application-hosted media bots, as opposed to simpler service-hosted media bots that rely on the Real-time Media platform for all media processing.) For example, in a 1:1 call with a bot, as the user speaks, the bot will receive 50 audio frames per second, with each frame containing 20 milliseconds (ms) of audio. An application-hosted media bot can perform real-time speech recognition as the audio frames are received, rather than having to wait for a recording after the user has stopped speaking. The bot can also send and receive high-definition-resolution video, including video-based screen sharing content. The platform provides a simple \"socket\"-like API for the bot to send and receive media, and handles the real-time encoding and decoding of audio/video packets, using codecs such as SILK and G.722 for audio and H.264 for video. The platform also handles all media packet encryption/decryption and packet network transmission automatically, so the bot just needs to concern itself with the actual audio/video content. A real-time media bot may participate in 1:1 calls as well as meetings with multiple participants. Microsoft Real-Time Media Platform for Bots API (\"Media Access API\") Accompanying Documentation The Media Access API is offered under the terms of the Microsoft APIs Terms of Use ( https://docs.microsoft.com/en-us/legal/microsoft-apis/terms-of-use ) and this accompanying documentation. \"Media Access API\" means (i) any form of machine accessible application programming interface that Microsoft makes publicly available which provides access to a Microsoft Offering that includes media content (e.g., audio or video), including all associated tools, elements, components and executables therein, (ii) any Microsoft sample code that enables interactions with a Microsoft Offering, and (iii) documentation that Microsoft makes available to help enable your access to the Media Access API. Additional Restriction : You may NOT use the Media Access API to record or otherwise persist media content from calls or meetings that your Application accesses, or data derived from that media content. Select a class on the left to dive into the reference docs" }, - "articles/Logging.html": { - "href": "articles/Logging.html", - "title": "Logging in SDK", - "keywords": "Logging in SDK The Graph SDK uses a custom logger named IGraphLogger which allows custom subscribers for log events. These events can be observed and logged as required by the bot developers. You need to create an IObserver for log events (the LogEvent class). private class LogObserver : IObserver { private readonly LogEventFormatter formatter = new LogEventFormatter(); /// /// Provides the observer with new data. /// /// The current notification information. public void OnNext(LogEvent logEvent) { // Log event. // Event Severity: logEvent.Level // Http trace: logEvent.EventType == LogEventType.HttpTrace // Log trace: logEvent.EventType == LogEventType.Trace var logString = this.formatter.Format(logEvent); MyLogger.Log(logEvent.Level, logString) } /// /// Notifies the observer that the provider has experienced an error condition. /// /// An object that provides additional information about the error. public void OnError(Exception error) { // Error occurred with the logger, not with the SDK. } /// /// Notifies the observer that the provider has finished sending push-based notifications. /// public void OnCompleted() { // Graph Logger has completed logging (shutdown). } } After a class is ready, you need to subscribe to the log events. ICommunicationsClient client; // Substitute this with the instance of the SDK. var observer = new LogObserver(); var disposableSubsription = client.GraphLogger.Subscribe(observer); Note The disposableSubscription object should be persisted, otherwise logging will not work once it is garbage collected." + "calls/index.html": { + "href": "calls/index.html", + "title": "Graph Communications Calling SDK", + "keywords": "Graph Communications Calling SDK The Calling components can be found in the Microsoft.Graph.Communications.Calls namespace. State Management The Graph Communications Calling SDK exposes a different set of APIs to manage states of resources in memory. Bots built using this SDK need to register event handlers for each newly created resource in order to be informed of any changes happening on that resource. The strengths and limitations of each are further explained in the State Management article. Media Session For calls with locally hosted media the ICallCollection has an extended AddAsync method which expects an IMediaSession object. This object contains the IAudioSocket and IVideoSocket composition. The IMediaSession also knows how to construct the MediaConfiguration required by the back end services to enable the AV stream to flow through the call instance. A Media Extension SDK has been added on top of this SDK to support locally hosted media scenarios. To use this extension the ICommunicationsClient must be built with MediaCommunicationsClientBuilderExtensions.SetMediaPlatformSettings . The MediaCommunicationsClientExtensions.CreateMediaSession extension method facilitates the creation of IMediaSession objects. Please see the calls with locally hosted media article for more information on the IMediaSession object. Select a class on the left to dive into the reference docs Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." }, - "articles/calls/appHostedMediaCalls.html": { - "href": "articles/calls/appHostedMediaCalls.html", - "title": "Application Hosted Media Calls", - "keywords": "Application Hosted Media Calls Application Hosted Media calls are those calls in which the bot manages the call's video and audio sockets. The bots send and receive raw audio and video data over the network. Building a CommunicationsClient with Media Platform Settings Create the an instance of the ICommunicationsClientBuilder . Create an instance of MediaPlatformSettings and use MediaCommunicationsClientBuilderExtensions.SetMediaPlatformSettings method to pass the MediaPlatformSettings to build the ICommunicationsClient Once the builder builds the ICommunicationsClient , a media session can be created using either MediaCommunicationsClientExtension.CreateMediaSession or MediaCommunicationsClientExtension.CreateMediaSession depending on how many video sockets are required. When creating an object of the Call resource, MediaConfig needs to be set to AppHostedMediaConfig . Important When creating a new call that uses application hosted media, an instance of IMediaSession needs to be passed into CallCollectionExtensions.AddAsync" + "calls_media/index.html": { + "href": "calls_media/index.html", + "title": "Graph Communications Media SDK", + "keywords": "Graph Communications Media SDK The Media components can be found in the Microsoft.Graph.Communications.Calls.Media namespace. More information of utilizing Real-time Media Calling functionality in bots can be found here This is presented as an extension on top of the Graph Communications Calling SDK to provide extra functionalities with Microsoft.Skype.Bots.Media library. IMediaSession The Media SDK provides very light integration with the Microsoft.Skype.Bots.Media library. There are only a few pieces of data that the signaling SDK requires to integrate with the media libraries. As a convenience the Media SDK provides an IMediaSession generator . For greater customization of media libraries developers are welcome to exclude this package and implement their own IMediaSession . Media Requirements The Communications SDK is quite flexible, however, the media library has it's own set of Requirements . Local Testing Local testing of Application Hosted Media scenarios is possible in some environments. Please refer to the testing guide to enable local testing. Select a class on the left to dive into the reference docs Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." }, "client/index.html": { "href": "client/index.html", "title": "Graph Communications SDK", "keywords": "Graph Communications SDK This SDK is the core component of Communications SDK. This contains all the standard features and functionality available in the Graph Stateful SDK. Authentication Provider All calls made and received by the SDK must be authenticated by the bot developers. The SDK requires the developers to implement the IRequestAuthenticationProvider interface and specify it when building the ICommunicationsClient . There are two parts to the interface. AuthenticateOutboundRequestAsync : This method should add the Authorization header to the outbound HTTP requests from the SDK. AuthenticateOutboundRequestAsync : This method should validate the Authorization header for incoming HTTP requests from Graph, extract the Tenant ID from that header and provide it to the SDK. Examples of the Authentication Provider can be found in samples . Notification Handling The Graph Platform sends out notifications via HTTP that need to be handled by the Bot Developers. The Platform sends out notifications on the notification url, and the bot developers should listen to HTTP messages on that url. Once the HTTP message has been received by the developer, they need to forward the message to ICommunicationsClient using the ProcessNotificationAsync method. The SDK processes the notification, calls the IRequestAuthenticationProvider and raises any corresponding events asynchronously. The SDK then returns a HttpResponseMessage that needs to be sent out as a response to the Graph Platform. Note Developers using ASP.NET Core should convert the HttpRequest object into HttpRequestMessage before passing it to the SDK. Also, they need to convert the resulting HttpResponseMessage into HttpResponse . Select a class on the left to dive into the reference docs Accompanying Information Accessing the Microsoft Teams Service through a Microsoft API Cloud Video Interop (CVI) partners and contact centers may integrate with Microsoft Teams to aid their solution. Contact centers may route calls to Microsoft Teams but may not build a separate or independent communications related solution while using Microsoft Teams as a base for the solution." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLoggerWrapper.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLoggerWrapper.html", - "title": "Class GraphLoggerWrapper", - "keywords": "Class GraphLoggerWrapper The ILogger wrapper for IGraphLogger. Inheritance Object GraphLoggerWrapper Implements ILogger Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphLoggerWrapper : ILogger Constructors GraphLoggerWrapper(IGraphLogger, String, Guid, LogEventType, IEnumerable) Initializes a new instance of the GraphLoggerWrapper class. Declaration public GraphLoggerWrapper(IGraphLogger graphLogger, string component = null, Guid correlationId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null) Parameters Type Name Description IGraphLogger graphLogger Graph logger instance String component The component in which log is created Guid correlationId The correlation identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event Methods BeginScope(TState) Declaration public IDisposable BeginScope(TState state) Parameters Type Name Description TState state Returns Type Description IDisposable Type Parameters Name Description TState IsEnabled(LogLevel) Declaration public bool IsEnabled(LogLevel logLevel) Parameters Type Name Description LogLevel logLevel Returns Type Description Boolean Log(LogLevel, EventId, TState, Exception, Func) Declaration public void Log(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func formatter) Parameters Type Name Description LogLevel logLevel EventId eventId TState state Exception exception Func formatter Type Parameters Name Description TState Implements Microsoft.Extensions.Logging.ILogger Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/index.html": { + "href": "common/index.html", + "title": "Graph Common Utilities Documentation", + "keywords": "Graph Common Utilities Documentation This is the documentation for Microsoft.Graph.Communications.Common nuget package. This is the nuget containing all the utilities used throughout the Communications SDK. It contains telemetry, http, obfuscation support along with helper methods. For more information on logging please see the graph logger guide Select a class on the left to dive into the reference docs" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLoggerShim.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLoggerShim.html", - "title": "Class GraphLoggerShim", - "keywords": "Class GraphLoggerShim The graph logger shim. This wrapper on the IGraphLogger attaches some extra data to each log request. Inheritance Object ObjectRoot GraphLoggerShim Implements IGraphLogger IObservable < LogEvent > Inherited Members ObjectRoot.GraphLogger Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphLoggerShim : ObjectRoot, IGraphLogger, IObservable Constructors GraphLoggerShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) Initializes a new instance of the GraphLoggerShim class. Declaration public GraphLoggerShim(IGraphLogger graphLogger, string component = null, Guid? correlationId = default(Guid? ), IEnumerable properties = null, ObfuscationConfiguration obfuscationConfiguration = null) Parameters Type Name Description IGraphLogger graphLogger The graph logger. String component The component. Nullable < Guid > correlationId The correlation identifier. If null, shim will use the correlationId from GraphLogger IEnumerable < Object > properties The properties. ObfuscationConfiguration obfuscationConfiguration The obfuscation configuration. Properties CorrelationId Gets or sets the correlation identifier. This is used to track correlation between multiple requests for one scenario. Declaration public Guid CorrelationId { get; set; } Property Value Type Description Guid DiagnosticLevel Gets or sets the diagnostic level for the logger. Declaration public TraceLevel DiagnosticLevel { get; set; } Property Value Type Description TraceLevel LogicalThreadId Gets or sets the logical thread identifier. This id is used for tracking the flow of one request throughout the lifetime until it ends. Declaration public uint LogicalThreadId { get; set; } Property Value Type Description UInt32 ObfuscationConfiguration Gets the obfuscation configuration. This is used to obfuscate PII and other data. Declaration public ObfuscationConfiguration ObfuscationConfiguration { get; } Property Value Type Description ObfuscationConfiguration Properties Gets the properties of the logger. Declaration public IReadOnlyDictionary Properties { get; } Property Value Type Description IReadOnlyDictionary < Type , Object > Methods Log(TraceLevel, String, String, Guid, Guid, LogEventType, IEnumerable, String, String, Int32) Log messages classified as the provided trace level. Declaration public LogEvent Log(TraceLevel level, string message, string component = null, Guid correlationId = default(Guid), Guid requestId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The trace level. String message A composite format string that includes one or more format items. String component The component in which log is created Guid correlationId The correlation identifier. Guid requestId The request identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Subscribe(IObserver) Declaration public IDisposable Subscribe(IObserver observer) Parameters Type Name Description IObserver < LogEvent > observer Returns Type Description IDisposable Implements IGraphLogger System.IObservable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.CreateObserver(IObservable, Action, Action, Action) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) LoggingExtensions.Log(IGraphLogger, TraceLevel, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Info(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Verbose(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.LogHttpMessage(IGraphLogger, TraceLevel, TransactionDirection, HttpTraceType, String, String, String, IEnumerable>>, Int32, String, Nullable, Guid, Guid, String, String, Int32) LoggingExtensions.Metric(IGraphLogger, String, String, Int64, Dictionary, Boolean, String, Guid, String, String, Int32) LoggingExtensions.SerializeAndObfuscate(IGraphLogger, Object, Formatting) LoggingExtensions.Obfuscate(IGraphLogger, Object, ObfuscationTag) LoggingExtensions.GetHeaderText(IGraphLogger, IEnumerable>>) LoggingExtensions.CreateShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) LoggingExtensions.CreateILogger(IGraphLogger, String, Guid, LogEventType, IEnumerable) LoggingExtensions.EnterMethod(IGraphLogger, Guid, String, String, Int32) LoggingExtensions.LeaveMethod(IGraphLogger, Guid, String, String, Int32) See Also ObjectRoot IGraphLogger" + "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.html": { + "href": "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.html", + "title": "Class CommsGeneratedErrorConstants", + "keywords": "Class CommsGeneratedErrorConstants The generated error constants. Inheritance Object CommsGeneratedErrorConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class CommsGeneratedErrorConstants" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLogger.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.GraphLogger.html", - "title": "Class GraphLogger", - "keywords": "Class GraphLogger Logging portion of graph. Inheritance Object Disposable GraphLogger Implements IDisposable IGraphLogger IObservable < LogEvent > Inherited Members Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphLogger : Disposable, IDisposable, IGraphLogger, IObservable Constructors GraphLogger(String, IEnumerable, Boolean, ObfuscationConfiguration) Initializes a new instance of the GraphLogger class. Declaration public GraphLogger(string component = null, IEnumerable properties = null, bool redirectToTrace = false, ObfuscationConfiguration obfuscationConfiguration = null) Parameters Type Name Description String component The component in which log is createdThe component in which this logger is created. IEnumerable < Object > properties Common properties to be set on each event Boolean redirectToTrace if set to true [redirect to trace]. ObfuscationConfiguration obfuscationConfiguration The obfuscation configuration Fields StartupLoggerNameSuffix The startup logger name prefix Declaration public const string StartupLoggerNameSuffix = \"_Startup\" Field Value Type Description String Properties Component Gets or the component of logger. Declaration public string Component { get; } Property Value Type Description String CorrelationId Gets or sets the correlation identifier. This is used to track correlation between multiple requests for one scenario. Declaration public Guid CorrelationId { get; set; } Property Value Type Description Guid DiagnosticLevel Gets or sets the diagnostic level for the logger. Declaration public TraceLevel DiagnosticLevel { get; set; } Property Value Type Description TraceLevel LogicalThreadId Gets or sets the logical thread identifier. This id is used for tracking the flow of one request throughout the lifetime until it ends. Declaration public uint LogicalThreadId { get; set; } Property Value Type Description UInt32 ObfuscationConfiguration Gets the obfuscation configuration. Declaration public ObfuscationConfiguration ObfuscationConfiguration { get; } Property Value Type Description ObfuscationConfiguration Properties Gets the common properties for each event. Declaration public IReadOnlyDictionary Properties { get; } Property Value Type Description IReadOnlyDictionary < Type , Object > Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) Log(TraceLevel, String, String, Guid, Guid, LogEventType, IEnumerable, String, String, Int32) Log messages classified as the provided trace level. Declaration public LogEvent Log(TraceLevel level, string message, string component = null, Guid correlationId = default(Guid), Guid requestId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The trace level. String message A composite format string that includes one or more format items. String component The component in which log is created Guid correlationId The correlation identifier. Guid requestId The request identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Subscribe(IObserver) Create a subscription for logging events. Declaration public IDisposable Subscribe(IObserver observer) Parameters Type Name Description IObserver < LogEvent > observer The object that is to receive notifications. Returns Type Description IDisposable A reference to an interface that allows observers to stop receiving notifications before the provider has finished sending them. Implements System.IDisposable IGraphLogger System.IObservable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.CreateObserver(IObservable, Action, Action, Action) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) LoggingExtensions.Log(IGraphLogger, TraceLevel, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Error(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Info(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, Exception, String, String, Guid, String, String, Int32) LoggingExtensions.Warn(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.Verbose(IGraphLogger, String, String, Guid, String, String, Int32) LoggingExtensions.LogHttpMessage(IGraphLogger, TraceLevel, TransactionDirection, HttpTraceType, String, String, String, IEnumerable>>, Int32, String, Nullable, Guid, Guid, String, String, Int32) LoggingExtensions.Metric(IGraphLogger, String, String, Int64, Dictionary, Boolean, String, Guid, String, String, Int32) LoggingExtensions.SerializeAndObfuscate(IGraphLogger, Object, Formatting) LoggingExtensions.Obfuscate(IGraphLogger, Object, ObfuscationTag) LoggingExtensions.GetHeaderText(IGraphLogger, IEnumerable>>) LoggingExtensions.CreateShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) LoggingExtensions.CreateILogger(IGraphLogger, String, Guid, LogEventType, IEnumerable) LoggingExtensions.BindToILoggerFactory(GraphLogger, ILoggerFactory, ILogEventFormatter) LoggingExtensions.EnterMethod(IGraphLogger, Guid, String, String, Int32) LoggingExtensions.LeaveMethod(IGraphLogger, Guid, String, String, Int32)" + "common/Microsoft.Graph.Communications.Common.Transport.RequestType.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.RequestType.html", + "title": "Enum RequestType", + "keywords": "Enum RequestType Type of request that we want to issue on the transport Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum RequestType Fields Name Description Create Request to create a resource Delete Request to delete a resource Get Request to get a resource Replace Request to replace a resource Update Request to update a resource Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(RequestType, String, String) Validator.Equals(RequestType, String) Validator.NotEquals(RequestType, String, String) GraphRequestExtensions.ToHttpMethod()" }, - "common/Microsoft.Graph.Communications.Common.OData.CamelCaseStringEnumConverter.html": { - "href": "common/Microsoft.Graph.Communications.Common.OData.CamelCaseStringEnumConverter.html", - "title": "Class CamelCaseStringEnumConverter", - "keywords": "Class CamelCaseStringEnumConverter Converts an System.Enum to and from its name string value. When converting to its string value it will use camelCase formatting. Inheritance Object CamelCaseStringEnumConverter Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class CamelCaseStringEnumConverter : StringEnumConverter Constructors CamelCaseStringEnumConverter() Initializes a new instance of the CamelCaseStringEnumConverter class. Declaration public CamelCaseStringEnumConverter() Properties CanWrite Declaration public override bool CanWrite { get; } Property Value Type Description Boolean Methods CanConvert(Type) Declaration public override bool CanConvert(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Boolean ReadJson(JsonReader, Type, Object, JsonSerializer) Declaration public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonReader reader Type objectType Object existingValue Newtonsoft.Json.JsonSerializer serializer Returns Type Description Object Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also Newtonsoft.Json.Converters.StringEnumConverter" + "bot_media/Microsoft.Skype.Bots.Media.PortRange.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.PortRange.html", + "title": "Class PortRange", + "keywords": "Class PortRange The Port range Inheritance Object PortRange Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class PortRange Constructors PortRange(UInt32, UInt32) The PortRange constructor Declaration public PortRange(uint minPort, uint maxPort) Parameters Type Name Description UInt32 minPort The minimum port. UInt32 maxPort The maximum port. Properties MaxPort The maximum port. Declaration public uint MaxPort { get; } Property Value Type Description UInt32 MinPort The minimum port. Declaration public uint MinPort { get; } Property Value Type Description UInt32" }, - "client/Microsoft.Graph.Communications.Client.IPagedList-1.html": { - "href": "client/Microsoft.Graph.Communications.Client.IPagedList-1.html", - "title": "Interface IPagedList", - "keywords": "Interface IPagedList The paged list interface. Inherited Members IReadOnlyList.Item[Int32] IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IPagedList : IReadOnlyList, IReadOnlyCollection, IEnumerable, IEnumerable Type Parameters Name Description T The type of object to page. Properties AdditionalData Gets or sets the additional data. Declaration IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > NextLinkUrl Gets the next link URL taken from @odata.nextLink. Declaration Uri NextLinkUrl { get; } Property Value Type Description Uri Value Gets or sets the value in the current page of the list. Declaration IList Value { get; set; } Property Value Type Description IList See Also IList " + "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformSettings.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformSettings.html", + "title": "Class MediaPlatformSettings", + "keywords": "Class MediaPlatformSettings Class that stores settings needed to initialize Bot Media Platform. Inheritance Object MediaPlatformSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class MediaPlatformSettings Constructors MediaPlatformSettings() Declaration public MediaPlatformSettings() Properties ApplicationId String that uniquely identifies the application that initializes the platform. Declaration public string ApplicationId { get; set; } Property Value Type Description String HostingEnvironmentConfiguration Specifies the HostingEnvironmentConfiguration to use for the MediaPlatform. In most cases, the default value is sufficient. Only in Azure Government clouds do different settings need to be applied. Declaration public HostingEnvironmentConfiguration HostingEnvironmentConfiguration { get; set; } Property Value Type Description HostingEnvironmentConfiguration MediaPlatformInstanceSettings The media platform instance settings. Declaration public MediaPlatformInstanceSettings MediaPlatformInstanceSettings { get; set; } Property Value Type Description MediaPlatformInstanceSettings MediaPlatformLogger Optional logger object to receive MediaPlatform traces. Declaration public IMediaPlatformLogger MediaPlatformLogger { get; set; } Property Value Type Description IMediaPlatformLogger RegionAffinity Reserved for the internal use. Declaration public string RegionAffinity { get; set; } Property Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Observable-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Observable-1.html", - "title": "Class Observable", - "keywords": "Class Observable Observable Base class Inheritance Object ObjectRoot Observable Implements IObservable IObserver INotifyCollectionChanged Inherited Members ObjectRoot.GraphLogger Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class Observable : ObjectRoot, IObservable, IObserver, INotifyCollectionChanged Type Parameters Name Description T Type of the value being observed. Constructors Observable(IGraphLogger) Initializes a new instance of the Observable class. Declaration public Observable(IGraphLogger logger) Parameters Type Name Description IGraphLogger logger Logger instance. Properties Observers Gets the observers. Declaration public ICollection> Observers { get; } Property Value Type Description ICollection < IObserver > Methods OnCompleted() Notify observers of completion. Declaration public void OnCompleted() OnError(Exception) Notify observers of error. Declaration public void OnError(Exception error) Parameters Type Name Description Exception error Exception information. OnNext(T) Notify observers. Declaration public void OnNext(T value) Parameters Type Name Description T value Value to observers. OnNext(T, IEnumerable>) Notify observers. Declaration public void OnNext(T value, IEnumerable> observersSubset) Parameters Type Name Description T value Value to observers. IEnumerable < IObserver > observersSubset Subset of observers to notify. Subscribe(IObserver) Notifies the provider that an observer is to receive notifications. Declaration public virtual IDisposable Subscribe(IObserver observer) Parameters Type Name Description IObserver observer The object that is to receive notifications. Returns Type Description IDisposable A reference to an interface that allows observers to stop receiving notifications before the provider has finished sending them. Events CollectionChanged Collection changed event. Declaration public event NotifyCollectionChangedEventHandler CollectionChanged Event Type Type Description NotifyCollectionChangedEventHandler Implements System.IObservable System.IObserver System.Collections.Specialized.INotifyCollectionChanged Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.IVideoSocket.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.IVideoSocket.html", + "title": "Interface IVideoSocket", + "keywords": "Interface IVideoSocket Interface to a VideoSocket. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IVideoSocket : IDisposable Properties MediaType MediaType of the video socket. This could be Video or Vbss. The MediaType is set after the socket is passed to the CreateMediaConfiguration API Declaration MediaType MediaType { get; } Property Value Type Description MediaType SocketId The 0-based ID of the socket. This socket ID is useful to identify a socket in a multiview (ie. more than 1 video socket) call. The same ID is used in the event args of the VideoMediaReceived and VideoSendStatusChanged events that this class may raise. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the CreateMediaConfiguration API. Eg., if the collection of IVideoSocket objects in the CreateMediaConfiguration API contains {socketA, socketB, socketC}, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Before the call to CreateMediaConfiguration, the SocketId has a value of -1. Declaration int SocketId { get; } Property Value Type Description Int32 Methods GetQualityOfExperienceData() Get the Quality of Experience (QoE) data for the video socket. Declaration VideoQualityOfExperienceData GetQualityOfExperienceData() Returns Type Description VideoQualityOfExperienceData Remarks The bot should fetch the QoE data no more than once every 30 seconds. RequestKeyFrame() Allows the application to request for key frame. Only valid for sockets with the ReceiveColorFormat as H264 Declaration void RequestKeyFrame() Send(VideoMediaBuffer) Sends a frame of video media. Declaration void Send(VideoMediaBuffer buffer) Parameters Type Name Description VideoMediaBuffer buffer VideoMediaBuffer containing the frame of video media to send. Remarks The application must create a concrete class which derives from the VideoMediaBuffer abstract class. The buffer object passed to the Send method is still potentially in-use after the method returns to the caller. The application must not free the buffer's data until the the buffer object's Dispose() method is invoked by the Media Platform. The application should be sending up to 30 video frames per second. The VideoSocket must be enabled to send media via the VideoSocketSettings.StreamDirections property. SetReceiveBandwidthLimit(UInt32) Sets the bandwidth limit on the receive stream of the VideoSocket. This is only supported if the socket supports receiving H264 video format. It is recommended to wait for the VideoReceiveStatusChanged event with MediaReceiveStatus Active state during the initial call setup before applying the receive bandwidth limit on the socket. Bandwidth range (in bits per second) for various resolutions and frame rates per media type: Media type: Video 1000000 - 4000000 1080p at 30 fps 550000 - 2500000 720p at 30 fps 375000 - 1500000 540p at 30 fps 200000 - 800000 360p at 30 fps 150000 - 250000 360p at 15 fps 120000 - 220000 240p at 15 fps 60000 - 200000 180p at 15 fps 20000 - 100000 180p at 7.5 fps 10000 - 25000 180p at 3.75 fps 1000 - 12500 180p at 1.875 fps Media type: Vbss Resolution: 1080p 2000000 - 4000000 at 30 fps 600000 - 3000000 at 15 fps 300000 - 700000 at 7.5 fps 150000 - 350000 at 3.75 fps 70000 - 200000 at 1.875 fps Declaration void SetReceiveBandwidthLimit(uint bitsPerSecond) Parameters Type Name Description UInt32 bitsPerSecond The receive bitrate SetSendBandwidthLimit(UInt32) Sets the bandwidth limit on the send stream of the VideoSocket. This is only supported if the socket supports sending H264 video formats. It is recommended to wait for the VideoSendStatusChanged event with MediaSendStatus Active state during the initial call setup before applying the send bandwidth limit on the socket. Bandwidth range (in bits per second) for various resolutions and frame rates per media type: Media type: Video 1000000 - 4000000 1080p at 30 fps 550000 - 2500000 720p at 30 fps 375000 - 1500000 540p at 30 fps 200000 - 800000 360p at 30 fps 150000 - 250000 360p at 15 fps 120000 - 220000 240p at 15 fps 60000 - 200000 180p at 15 fps 20000 - 100000 180p at 7.5 fps 10000 - 25000 180p at 3.75 fps 1000 - 12500 180p at 1.875 fps Media type: Vbss Resolution: 1080p 2000000 - 4000000 at 30 fps 600000 - 3000000 at 15 fps 300000 - 700000 at 7.5 fps 150000 - 350000 at 3.75 fps 70000 - 200000 at 1.875 fps Declaration void SetSendBandwidthLimit(uint bitsPerSecond) Parameters Type Name Description UInt32 bitsPerSecond The send bitrate Subscribe(VideoResolution) Request to receive the video of the peer in a 1:1 call. No need to specify a MediaSourceId. The bot cannot subscribe to a video source unless the VideoReceiveStatusChanged event is raised indicating the VideoSocket's MediaReceiveStatus is Active . Declaration void Subscribe(VideoResolution preferredVideoResolution) Parameters Type Name Description VideoResolution preferredVideoResolution The requested video resolution. The received video frames should have this resolution if the bandwidth constraints and sender capabilities allow, however the bot may receive video frames at a resolution lower than requested. Subscribe(VideoResolution, UInt32) Request to receive the video source of a participant in a meeting or group call. The video source must be identified by its MediaSourceId available from the roster. The bot cannot subscribe to a video source unless the VideoReceiveStatusChanged event is raised indicating the VideoSocket's MediaReceiveStatus is Active . Declaration void Subscribe(VideoResolution preferredVideoResolution, uint MediaSourceId) Parameters Type Name Description VideoResolution preferredVideoResolution The requested video resolution. The received video frames should have this resolution if the bandwidth constraints and sender capabilities allow, however the bot may receive video frames at a resolution lower than requested. UInt32 MediaSourceId Media source identifier of the video source to be received Exceptions Type Condition ObjectDisposedException Thrown if the VideoSocket is disposed. InvalidOperationException Thrown if the subscription is invalid. SkypeMediaException Thrown if an internal media failure occurs. Unsubscribe() Stops the current video subscription on the VideoSocket. The VideoMediaReceived events will stop raising video buffers. Declaration void Unsubscribe() UpdateVideoSendCapability(VideoSendCapability) Updates the send capabilities (such as SupportedSendVideoFormats or MaxConcurrentSendStreams) of the video socket, allowing the bot to add and remove video formats mid-call. Declaration void UpdateVideoSendCapability(VideoSendCapability capability) Parameters Type Name Description VideoSendCapability capability Events MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > Remarks Note: this event can be raised even if there is no active video subscription; i.e., the VideoSocket is \"idle\" and not receiving media. MediaStreamQualityChanged The event is raised if a media stream quality change was detected Declaration event EventHandler MediaStreamQualityChanged Event Type Type Description EventHandler < VideoMediaStreamQualityChangedEventArgs > VideoKeyFrameNeeded If the application has configured the VideoSocket to receive encoded media, this event is raised each time a key frame is needed. Events are serialized, so only one event at a time is raised to the app. Declaration event EventHandler VideoKeyFrameNeeded Event Type Type Description EventHandler < VideoKeyFrameNeededEventArgs > VideoMediaReceived If the application has configured the VideoSocket to receive media, this event is raised each time a frame of video media is received. Once the application has consumed the buffer, it must call the buffer's Dispose() method. Declaration event EventHandler VideoMediaReceived Event Type Type Description EventHandler < VideoMediaReceivedEventArgs > Remarks The incoming video frame rate is variable. The frame rate can vary between 1.875 frames per second (fps) up to 30 fps. The application must be able to receive up to 30 video buffers per second. Events are serialized, so only one event at a time is raised to the app. The event handler should return as quickly as possible; any time-consuming per-frame processing should be performed asynchronously from the event handler. VideoReceiveStatusChanged If the application has configured the VideoSocket to receive media, this event is raised to inform the application when it is ready to receive media. When the status is active the application can subscribe to a video source, when inactive video subscription won't be allowed Declaration event EventHandler VideoReceiveStatusChanged Event Type Type Description EventHandler < VideoReceiveStatusChangedEventArgs > VideoSendStatusChanged If the application has configured the VideoSocket to send media, this event is raised to inform the application when it may begin sending media and when it should stop. The application cannot send media before receiving a VideoMediaSendStatusChanged event indicating the SendStatus is Active, such media will be discarded. Declaration event EventHandler VideoSendStatusChanged Event Type Type Description EventHandler < VideoSendStatusChangedEventArgs >" }, - "common/Microsoft.Graph.Communications.Common.Exceptions.InvalidStateTransitionException.html": { - "href": "common/Microsoft.Graph.Communications.Common.Exceptions.InvalidStateTransitionException.html", - "title": "Class InvalidStateTransitionException", - "keywords": "Class InvalidStateTransitionException Exception to throw when a invalid transition is requested Inheritance Object Exception InvalidStateTransitionException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Exceptions Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class InvalidStateTransitionException : Exception, ISerializable, _Exception Constructors InvalidStateTransitionException(String) Initializes a new instance of the InvalidStateTransitionException class. Declaration public InvalidStateTransitionException(string message) Parameters Type Name Description String message the exception message Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.DataType.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.DataType.html", + "title": "Enum DataType", + "keywords": "Enum DataType Reserved for internal use. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum DataType Fields Name Description MultichannelAudio Reserved for internal use. Transcript Reserved for internal use." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.UriFilter.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.UriFilter.html", - "title": "Class UriFilter", - "keywords": "Class UriFilter URI Filter. Any group matches from REGEX are obfuscated. Inheritance Object BaseFilter BaseFilter < Uri , Regex > UriFilter Inherited Members BaseFilter.MatchableString BaseFilter.MatchEvaluator Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class UriFilter : BaseFilter Constructors UriFilter(Regex) Initializes a new instance of the UriFilter class. Declaration public UriFilter(Regex matchableSubtring) Parameters Type Name Description Regex matchableSubtring The matchable REGEX. Use captures for obfuscation. Use obfuscation tag names as group names for specific object Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.AudioVideoFramePlayer.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioVideoFramePlayer.html", + "title": "Class AudioVideoFramePlayer", + "keywords": "Class AudioVideoFramePlayer AudioVideoFramePlayer is responsible for streaming real time audio and video buffers. This frame player will handle audio and video sync from the audio and video buffer's timestamps Inheritance Object AudioVideoFramePlayer Implements IAudioVideoFramePlayer Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioVideoFramePlayer : IAudioVideoFramePlayer Constructors AudioVideoFramePlayer(AudioSocket, VideoSocket, AudioVideoFramePlayerSettings) Constructor for the audio video frame player. Declaration public AudioVideoFramePlayer(AudioSocket audioSocket, VideoSocket videoSocket, AudioVideoFramePlayerSettings audioVideoFramePlayerSettings) Parameters Type Name Description AudioSocket audioSocket VideoSocket videoSocket AudioVideoFramePlayerSettings audioVideoFramePlayerSettings Methods ClearAsync(Boolean, List) Clear the enqueued buffers. This will also invoke Dispose() on the buffers still in the queue. Declaration public Task ClearAsync(bool clearAudio = true, List videoFormats = null) Parameters Type Name Description Boolean clearAudio true will clear the audio buffers, Default value is set to true List < VideoFormat > videoFormats list of video formats to clear, default is null Returns Type Description Task EnqueueBuffersAsync(IList, IList) Enqueue the audio and video media buffers. Usage should be to enqueue the same audio and video length, if audio and video sockets are active. Declaration public Task EnqueueBuffersAsync(IList audioMediaBuffers, IList videoMediaBuffers) Parameters Type Name Description IList < AudioMediaBuffer > audioMediaBuffers IList < VideoMediaBuffer > videoMediaBuffers Returns Type Description Task ShutdownAsync() Shuts down the player and releases allocated resources Declaration public Task ShutdownAsync() Returns Type Description Task Events LowOnFrames Event to signal the player is low on frames Declaration public event EventHandler LowOnFrames Event Type Type Description EventHandler < LowOnFramesEventArgs > Implements IAudioVideoFramePlayer" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.HeaderFilter.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.HeaderFilter.html", - "title": "Class HeaderFilter", - "keywords": "Class HeaderFilter Header filters act as whitelists. Inheritance Object BaseFilter BaseFilter < IEnumerable < String >, String > HeaderFilter Inherited Members BaseFilter, String>.MatchableString BaseFilter, String>.MatchEvaluator Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class HeaderFilter : BaseFilter, string> Constructors HeaderFilter(String) Initializes a new instance of the HeaderFilter class. Declaration public HeaderFilter(string matchableHeaderName) Parameters Type Name Description String matchableHeaderName Name of the matchable header. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.AudioQualityOfExperienceData.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioQualityOfExperienceData.html", + "title": "Class AudioQualityOfExperienceData", + "keywords": "Class AudioQualityOfExperienceData Audio quality of experience data Inheritance Object MediaQualityOfExperienceData AudioQualityOfExperienceData Inherited Members MediaQualityOfExperienceData.NetworkMetrics MediaQualityOfExperienceData.TotalMediaDuration Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioQualityOfExperienceData : MediaQualityOfExperienceData Constructors AudioQualityOfExperienceData() AudioQualityOfExperienceData constructor Declaration public AudioQualityOfExperienceData() Properties AudioMetrics Audio-specific QoE metrics Declaration public AudioMetrics AudioMetrics { get; set; } Property Value Type Description AudioMetrics" }, - "common/Microsoft.Graph.Communications.Common.EnumUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.EnumUtils.html", - "title": "Class EnumUtils", - "keywords": "Class EnumUtils Enum Utilities Inheritance Object EnumUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class EnumUtils Methods GetDescription(Enum) Gets the enum's description attribute. Declaration public static string GetDescription(this Enum value) Parameters Type Name Description Enum value The value. Returns Type Description String Enum's description Parse(String) Parses the string into enum Declaration public static TEnum Parse(string value) where TEnum : struct, IComparable, IFormattable, IConvertible Parameters Type Name Description String value input string Returns Type Description TEnum Enum's parsed value Type Parameters Name Description TEnum Enum's type to output" + "bot_media/Microsoft.Skype.Bots.Media.ToneReceivedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.ToneReceivedEventArgs.html", + "title": "Class ToneReceivedEventArgs", + "keywords": "Class ToneReceivedEventArgs Event arguments of the ToneReceived event. Inheritance Object EventArgs ToneReceivedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class ToneReceivedEventArgs : EventArgs Constructors ToneReceivedEventArgs() Declaration public ToneReceivedEventArgs() Properties Tone Tone id Declaration public ToneId Tone { get; set; } Property Value Type Description ToneId" }, - "common/Microsoft.Graph.Communications.Common.WeakKeyDictionary-2.html": { - "href": "common/Microsoft.Graph.Communications.Common.WeakKeyDictionary-2.html", - "title": "Class WeakKeyDictionary", - "keywords": "Class WeakKeyDictionary Dictionary with weak reference for the key. Inheritance Object ConcurrentDictionary < WeakKey , TValue> WeakKeyDictionary Implements IDictionary < WeakKey , TValue> ICollection < KeyValuePair < WeakKey , TValue>> IDictionary ICollection IReadOnlyDictionary < WeakKey , TValue> IReadOnlyCollection < KeyValuePair < WeakKey , TValue>> IEnumerable < KeyValuePair < WeakKey , TValue>> IEnumerable Inherited Members ConcurrentDictionary, TValue>.TryAdd(WeakKey, TValue) ConcurrentDictionary, TValue>.ContainsKey(WeakKey) ConcurrentDictionary, TValue>.TryRemove(WeakKey, TValue) ConcurrentDictionary, TValue>.TryGetValue(WeakKey, TValue) ConcurrentDictionary, TValue>.TryUpdate(WeakKey, TValue, TValue) ConcurrentDictionary, TValue>.Clear() System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.CopyTo(System.Collections.Generic.KeyValuePair, TValue>[], System.Int32) ConcurrentDictionary, TValue>.ToArray() ConcurrentDictionary, TValue>.GetEnumerator() ConcurrentDictionary, TValue>.GetOrAdd(WeakKey, Func, TValue>) ConcurrentDictionary, TValue>.GetOrAdd(WeakKey, TValue) ConcurrentDictionary, TValue>.GetOrAdd(WeakKey, Func, TArg, TValue>, TArg) ConcurrentDictionary, TValue>.AddOrUpdate(WeakKey, Func, TArg, TValue>, Func, TValue, TArg, TValue>, TArg) ConcurrentDictionary, TValue>.AddOrUpdate(WeakKey, Func, TValue>, Func, TValue, TValue>) ConcurrentDictionary, TValue>.AddOrUpdate(WeakKey, TValue, Func, TValue, TValue>) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.IDictionary, TValue>.Add(Microsoft.Graph.Communications.Common.WeakKey, TValue) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.IDictionary, TValue>.Remove(Microsoft.Graph.Communications.Common.WeakKey) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.Add(System.Collections.Generic.KeyValuePair, TValue>) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.Contains(System.Collections.Generic.KeyValuePair, TValue>) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.Remove(System.Collections.Generic.KeyValuePair, TValue>) ConcurrentDictionary, TValue>.IEnumerable.GetEnumerator() ConcurrentDictionary, TValue>.IDictionary.Add(Object, Object) ConcurrentDictionary, TValue>.IDictionary.Contains(Object) ConcurrentDictionary, TValue>.IDictionary.GetEnumerator() ConcurrentDictionary, TValue>.IDictionary.Remove(Object) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.IDictionary.get_Item(System.Object) System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.IDictionary.set_Item(System.Object, System.Object) ConcurrentDictionary, TValue>.ICollection.CopyTo(Array, Int32) ConcurrentDictionary, TValue>.Item[WeakKey] ConcurrentDictionary, TValue>.Count ConcurrentDictionary, TValue>.IsEmpty ConcurrentDictionary, TValue>.Keys System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.IReadOnlyDictionary, TValue>.Keys ConcurrentDictionary, TValue>.Values System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.IReadOnlyDictionary, TValue>.Values System.Collections.Concurrent.ConcurrentDictionary, TValue>.System.Collections.Generic.ICollection, TValue>>.IsReadOnly ConcurrentDictionary, TValue>.IDictionary.IsFixedSize ConcurrentDictionary, TValue>.IDictionary.IsReadOnly ConcurrentDictionary, TValue>.IDictionary.Keys ConcurrentDictionary, TValue>.IDictionary.Values ConcurrentDictionary, TValue>.IDictionary.Item[Object] ConcurrentDictionary, TValue>.ICollection.IsSynchronized ConcurrentDictionary, TValue>.ICollection.SyncRoot Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class WeakKeyDictionary : ConcurrentDictionary, TValue>, IDictionary, TValue>, ICollection, TValue>>, IDictionary, ICollection, IReadOnlyDictionary, TValue>, IReadOnlyCollection, TValue>>, IEnumerable, TValue>>, IEnumerable where TKey : class Type Parameters Name Description TKey Key type which must be a reference type. TValue Value type. Constructors WeakKeyDictionary() Declaration public WeakKeyDictionary() Methods Cleanup() Cleans keys where the weak references have been garbage collected. Declaration public void Cleanup() Implements System.Collections.Generic.IDictionary System.Collections.Generic.ICollection System.Collections.IDictionary System.Collections.ICollection System.Collections.Generic.IReadOnlyDictionary System.Collections.Generic.IReadOnlyCollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) CollectionUtils.ForEach(IEnumerable, Action) CollectionUtils.ForEachParallel(IEnumerable, Action, IGraphLogger) CollectionUtils.GetValueOrDefault(IDictionary, TKey) CollectionUtils.GetValueOrDefault(IDictionary, TKey, TValue) CollectionUtils.AddRange(ICollection, IEnumerable) CollectionUtils.ToSortedList(IEnumerable, Func) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.Any(IEnumerable) Validator.FirstObject(IEnumerable, Func) Validator.FirstObject(IEnumerable) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.NotEmpty(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) Validator.VerifyNotContainsKey(IDictionary, TK) Validator.VerifyContainsKey(IDictionary, TK) Validator.VerifyContainsKey(IReadOnlyDictionary, TK) Validator.VerifyContains(IEnumerable, T)" + "bot_media/Microsoft.Skype.Bots.Media.MediaType.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaType.html", + "title": "Enum MediaType", + "keywords": "Enum MediaType Indicates the media type of the socket. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaType Fields Name Description Audio Audio Data Reserved for internal use. Vbss Video-based screen sharing (VBSS) Video Video" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphProperty-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphProperty-1.html", - "title": "Struct GraphProperty", - "keywords": "Struct GraphProperty Implements IGraphProperty IGraphProperty IEquatable < IGraphProperty > Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public struct GraphProperty : IGraphProperty, IGraphProperty, IEquatable Type Parameters Name Description T Constructors GraphProperty(IGraphProperty) Initializes a new instance of the GraphProperty struct. Declaration public GraphProperty(IGraphProperty property) Parameters Type Name Description IGraphProperty property The property. GraphProperty(String, T, String) Initializes a new instance of the GraphProperty struct. Declaration public GraphProperty(string key, T value, string type = null) Parameters Type Name Description String key The key. T value The value. String type The type. Properties Key Gets the key. Declaration public string Key { get; } Property Value Type Description String Type Gets the type of the property. Declaration public string Type { get; } Property Value Type Description String Value Declaration public T Value { get; } Property Value Type Description T Methods Equals(IGraphProperty) Declaration public bool Equals(IGraphProperty other) Parameters Type Name Description IGraphProperty other Returns Type Description Boolean ToString() Declaration public override string ToString() Returns Type Description String Overrides ValueType.ToString() Explicit Interface Implementations IGraphProperty.Value Gets the value. Declaration object IGraphProperty.Value { get; } Returns Type Description Object Implements IGraphProperty IGraphProperty System.IEquatable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphProperty.ConvertProperty(IGraphProperty)" + "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformInstanceSettings.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformInstanceSettings.html", + "title": "Class MediaPlatformInstanceSettings", + "keywords": "Class MediaPlatformInstanceSettings Class that stores the settings of the Azure instance hosting the Bot Media Platform. Inheritance Object MediaPlatformInstanceSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class MediaPlatformInstanceSettings Constructors MediaPlatformInstanceSettings() Declaration public MediaPlatformInstanceSettings() Properties CertificateThumbprint Thumbprint of a local server certificate to support MTLS authentication of the Media Platform with the Microsoft Skype/Teams calling services. Declaration public string CertificateThumbprint { get; set; } Property Value Type Description String InstanceInternalPort Provides Instance InputEndpoint internal port. Declaration public int InstanceInternalPort { get; set; } Property Value Type Description Int32 InstancePublicIPAddress Provides Instance-Level Public IP address. Declaration public IPAddress InstancePublicIPAddress { get; set; } Property Value Type Description IPAddress InstancePublicPort Provides Instance InputEndpoint public port. Declaration public int InstancePublicPort { get; set; } Property Value Type Description Int32 MediaPortRange The media port range to be allocated for bot calls. Specifying media ports is optional. Declaration public PortRange MediaPortRange { get; set; } Property Value Type Description PortRange ServiceFqdn The FQDN of the Azure service hosting the Media Platform. Declaration public string ServiceFqdn { get; set; } Property Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClientFactory.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClientFactory.html", - "title": "Class GraphHttpClientFactory", - "keywords": "Class GraphHttpClientFactory The HTTP graph client factory. Inheritance Object ObjectRoot GraphHttpClientFactory Implements IGraphClientFactory Inherited Members ObjectRoot.GraphLogger Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphHttpClientFactory : ObjectRoot, IGraphClientFactory Constructors GraphHttpClientFactory(IGraphLogger, JsonSerializerSettings, HttpClient, String) Initializes a new instance of the GraphHttpClientFactory class. Declaration public GraphHttpClientFactory(IGraphLogger logger, JsonSerializerSettings serializerSettings, HttpClient httpClient = null, string correlationIdHeader = null) Parameters Type Name Description IGraphLogger logger Logger instance. Newtonsoft.Json.JsonSerializerSettings serializerSettings The serializer settings. HttpClient httpClient The HTTP client. String correlationIdHeader The correlation identifier header. Methods Create(IGraphLogger) Creates a new IGraphClient . Declaration public IGraphClient Create(IGraphLogger logger = null) Parameters Type Name Description IGraphLogger logger An optional IGraphLogger logger to be used in the new IGraphClient . Returns Type Description IGraphClient The IGraphClient . Implements IGraphClientFactory Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also ObjectRoot IGraphClientFactory" + "bot_media/Microsoft.Skype.Bots.Media.IMediaPlatform.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.IMediaPlatform.html", + "title": "Interface IMediaPlatform", + "keywords": "Interface IMediaPlatform Interface to the MediaPlatform. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IMediaPlatform : IDisposable Properties CurrentHealth The current health status of the media platform. Declaration MediaPlatformHealthStatus CurrentHealth { get; } Property Value Type Description MediaPlatformHealthStatus Methods CreateMediaConfiguration(IAudioSocket) Returns a serialized MediaConfiguration object representing the socket so that the Skype calling cloud can establish an audio/video call to the bot. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IDataSocket) Reserved for the internal use. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IDataSocket dataSocket) Parameters Type Name Description IAudioSocket audioSocket IDataSocket dataSocket Returns Type Description Newtonsoft.Json.Linq.JObject CreateMediaConfiguration(IAudioSocket, IVideoSocket) Returns a serialized MediaConfiguration object representing the sockets so that the Skype calling cloud can establish an audio/video call to the bot. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IVideoSocket videoSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IVideoSocket videoSocket Socket that handles video. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList) Returns a serialized MediaConfiguration object representing the sockets so that the Skype calling cloud can establish an audio/video call to the bot. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IList < IVideoSocket > videoSockets Ordered list of video sockets. If multiview sockets are provided, only the first one can have a send direction (ie. send only or send receive) and all the sockets should have a receive direction. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList, IVideoSocket) Returns a serialized MediaConfiguration object representing the sockets so that the Skype calling cloud can establish an audio/video/video-based screen sharing call to the bot. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets, IVideoSocket vbssSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IList < IVideoSocket > videoSockets Ordered list of video sockets. If multiview sockets are provided, only the first one can have a send direction (ie. send only or send receive) and all the sockets should have a receive direction. IVideoSocket vbssSocket Video socket for the video-based screen sharing (VBSS) modality. Socket must be configured as RecvOnly. Returns Type Description Newtonsoft.Json.Linq.JObject Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized, or a vbssSocket is configured to be sendonly or sendrecv. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList, IVideoSocket, IDataSocket) Reserved for the internal use. Declaration JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets, IVideoSocket vbssSocket, IDataSocket dataSocket) Parameters Type Name Description IAudioSocket audioSocket IList < IVideoSocket > videoSockets IVideoSocket vbssSocket IDataSocket dataSocket Returns Type Description Newtonsoft.Json.Linq.JObject CreateMediaConfiguration(IVideoSocket) Returns a serialized mediaConfiguration object representing the socket so that the Skype calling cloud can establish a video-based screen sharing call to the bot. Declaration JObject CreateMediaConfiguration(IVideoSocket vbssSocket) Parameters Type Name Description IVideoSocket vbssSocket Video socket for the video-based screen sharing (VBSS) modality. Socket must be configured as RecvOnly. Returns Type Description Newtonsoft.Json.Linq.JObject Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized, or a vbssSocket is configured to be sendonly or sendrecv. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. GetCurrentTimestamp() Get a current timestamp, in 100-ns units. To be used when sourcing media buffers. Declaration long GetCurrentTimestamp() Returns Type Description Int64 Initialize(MediaPlatformSettings) Initializes the Media Platform for Bot. Declaration void Initialize(MediaPlatformSettings settings) Parameters Type Name Description MediaPlatformSettings settings Settings to initialize the Bot Media Platform. Events MediaPlatformHealthChanged Raised when there is a change in the media platform's health status. The event arguments report the current and previous platform health conditions. Declaration event EventHandler MediaPlatformHealthChanged Event Type Type Description EventHandler < MediaPlatformHealthChangedEventArgs > Remarks A bot application which may handle very high call volumes or perform complex real-time media processing should monitor this event for changes in the media platform health status. When the event reports the platform health status has become HeavilyLoaded, the application should avoid starting new bot calls on the machine instance until the health status returns back to Normal." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.LoggingExtensions.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LoggingExtensions.html", - "title": "Class LoggingExtensions", - "keywords": "Class LoggingExtensions Extensions class for logging. Inheritance Object LoggingExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class LoggingExtensions Methods BindToILoggerFactory(GraphLogger, ILoggerFactory, ILogEventFormatter) Bind to ILogger Declaration public static Observer BindToILoggerFactory(this GraphLogger graphLogger, ILoggerFactory loggerFactory, ILogEventFormatter formatter = null) Parameters Type Name Description GraphLogger graphLogger The graph logger ILoggerFactory loggerFactory The ILogger ILogEventFormatter formatter The message formatter Returns Type Description Observer < LogEvent > The observer of graph logger Concat(IReadOnlyDictionary, IEnumerable) Get the merged propertied. Declaration public static IReadOnlyDictionary Concat(this IReadOnlyDictionary properties, IEnumerable additionalProperties) Parameters Type Name Description IReadOnlyDictionary < Type , Object > properties The property collection. IEnumerable < Object > additionalProperties The additional property collection. Returns Type Description IReadOnlyDictionary < Type , Object > The merged property collection. CreateILogger(IGraphLogger, String, Guid, LogEventType, IEnumerable) Creates the ILogger interface from Logging abstractions. Declaration public static ILogger CreateILogger(this IGraphLogger logger, string component = null, Guid correlationId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable properties = null) Parameters Type Name Description IGraphLogger logger The logger. String component The component for which log is created. Guid correlationId The correlation identifier. LogEventType eventType Log event type IEnumerable < Object > properties Extra properties for the log event Returns Type Description ILogger The ILogger interface. CreateShim(IGraphLogger, String, Nullable, IEnumerable, ObfuscationConfiguration) Creates the shim graph logger. The shim IGraphLogger wraps this logger and appends the specified content to each log request. Declaration public static IGraphLogger CreateShim(this IGraphLogger logger, string component = null, Guid? correlationId = default(Guid? ), IEnumerable properties = null, ObfuscationConfiguration obfuscationConfiguration = null) Parameters Type Name Description IGraphLogger logger The logger. String component The component for which log is created. Nullable < Guid > correlationId The correlation identifier. IEnumerable < Object > properties Extra properties for the log event ObfuscationConfiguration obfuscationConfiguration The obfuscation configuration. Returns Type Description IGraphLogger The IGraphLogger shim. EnterMethod(IGraphLogger, Guid, String, String, Int32) Log for entering method. Declaration public static LogEvent EnterMethod(this IGraphLogger logger, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Error(IGraphLogger, Exception, String, String, Guid, String, String, Int32) Log exceptions with error level. Declaration public static LogEvent Error(this IGraphLogger logger, Exception exception, string message = \"\", string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. Exception exception Exception information. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Error(IGraphLogger, String, String, Guid, String, String, Int32) Log messages with error level. Declaration public static LogEvent Error(this IGraphLogger logger, string message, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Flatten(IReadOnlyDictionary, IEnumerable, IEnumerable) Get the flatten key-value pairs for the properties of LogEvent. Declaration public static IEnumerable> Flatten(this IReadOnlyDictionary properties, IEnumerable ignoreTypes = null, IEnumerable ignoreSubProperties = null) Parameters Type Name Description IReadOnlyDictionary < Type , Object > properties The properties IEnumerable < Type > ignoreTypes The types in this list will be ingored IEnumerable < PropertyInfo > ignoreSubProperties The property members of specific types in this list will be ingored Returns Type Description IEnumerable < KeyValuePair < String , Object >> The flattern result. Remarks The primitive types and types implemented IEnumerable (string, list, dictionary, etc) will keep original value. The flatten support one level property lookup only. GetHeaderText(IGraphLogger, IEnumerable>>) Logs the headers text. Declaration public static IEnumerable GetHeaderText(this IGraphLogger logger, IEnumerable>> headers) Parameters Type Name Description IGraphLogger logger The logger. IEnumerable < KeyValuePair < String , IEnumerable < String >>> headers The headers. Returns Type Description IEnumerable < String > Log Text GetTypedProperties(LogEvent, Type) Gets the client common properties from log event. Declaration public static object GetTypedProperties(this LogEvent logEvent, Type type) Parameters Type Name Description LogEvent logEvent The log event. Type type The type of the property. Returns Type Description Object The client common properties. GetTypedProperty(LogEvent) Gets the client common properties from log event. Declaration public static T GetTypedProperty(this LogEvent logEvent) where T : class Parameters Type Name Description LogEvent logEvent The log event. Returns Type Description T The client common properties. Type Parameters Name Description T The property type. Info(IGraphLogger, String, String, Guid, String, String, Int32) Log exceptions with info level. Declaration public static LogEvent Info(this IGraphLogger logger, string message, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. LeaveMethod(IGraphLogger, Guid, String, String, Int32) Log for leaving method. Declaration public static LogEvent LeaveMethod(this IGraphLogger logger, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Log(IGraphLogger, TraceLevel, Exception, String, String, Guid, String, String, Int32) Log exceptions. Declaration public static LogEvent Log(this IGraphLogger logger, TraceLevel level, Exception exception, string message = null, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. TraceLevel level The trace level. Exception exception Exception information. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. LogHttpMessage(IGraphLogger, TraceLevel, TransactionDirection, HttpTraceType, String, String, String, IEnumerable>>, Int32, String, Nullable, Guid, Guid, String, String, Int32) Logs the http message. Declaration public static LogEvent LogHttpMessage(this IGraphLogger logger, TraceLevel level, TransactionDirection direction, HttpTraceType traceType, string url, string method, string obfuscatedContent, IEnumerable>> headers, int responseCode = 200, string component = null, long? responseTime = default(long? ), Guid correlationId = default(Guid), Guid requestId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. TraceLevel level The trace level. TransactionDirection direction The direction for request. HttpTraceType traceType Type of the http trace. String url The URL. String method The method. String obfuscatedContent The obfuscatedContent. IEnumerable < KeyValuePair < String , IEnumerable < String >>> headers The headers. Int32 responseCode The response code. (used only if [traceType == HttpResponse]) String component The component in which log is created. Nullable < Int64 > responseTime The response time. (used only if [traceType == HttpResponse]) Guid correlationId The correlation identifier. Guid requestId The message identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object Metric(IGraphLogger, String, String, Int64, Dictionary, Boolean, String, Guid, String, String, Int32) Log metrics Declaration public static LogEvent Metric(this IGraphLogger logger, string metricNamespace, string metricName, long rawData, Dictionary dimensions, bool addDefaultDimension = true, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String metricNamespace Metric namespace String metricName Metric name Int64 rawData Raw data Dictionary < String , String > dimensions Dimension name-value dictionary Boolean addDefaultDimension Indicates whether adds default dimension String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Obfuscate(IGraphLogger, Object, ObfuscationTag) Obfuscates the specified payload with the tag. Declaration public static string Obfuscate(this IGraphLogger logger, object payload, ObfuscationTag obfuscationTag) Parameters Type Name Description IGraphLogger logger The logger. Object payload The payload. ObfuscationTag obfuscationTag The obfuscation tag. Returns Type Description String Obfuscated data SerializeAndObfuscate(IGraphLogger, Object, Formatting) Serializes the payload and obfuscates it. Declaration public static string SerializeAndObfuscate(this IGraphLogger logger, object payload, Formatting formatting) Parameters Type Name Description IGraphLogger logger The logger. Object payload The payload. Newtonsoft.Json.Formatting formatting The formatting. Returns Type Description String Obfuscated data. ToLogLevel(TraceLevel) Get log level from trace level. Declaration public static LogLevel ToLogLevel(this TraceLevel level) Parameters Type Name Description TraceLevel level The trace level Returns Type Description LogLevel The log level ToTraceLevel(LogLevel) Gets the tracelevel for log level. Declaration public static TraceLevel ToTraceLevel(this LogLevel logLevel) Parameters Type Name Description LogLevel logLevel The log level. Returns Type Description TraceLevel trace level Verbose(IGraphLogger, String, String, Guid, String, String, Int32) Log verbose level. Declaration public static LogEvent Verbose(this IGraphLogger logger, string message, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Warn(IGraphLogger, Exception, String, String, Guid, String, String, Int32) Log exceptions with warning level. Declaration public static LogEvent Warn(this IGraphLogger logger, Exception exception, string message = \"\", string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. Exception exception Exception information. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object. Warn(IGraphLogger, String, String, Guid, String, String, Int32) Log exceptions with warning level. Declaration public static LogEvent Warn(this IGraphLogger logger, string message, string component = null, Guid correlationId = default(Guid), string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. String message The message. String component The component in which log is created Guid correlationId The correlation identifier. String memberName Calling function. String filePath File name where code is located. Int32 lineNumber Line number where code is located. Returns Type Description LogEvent Log Event object." + "bot_media/Microsoft.Skype.Bots.Media.AudioSocketSettings.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioSocketSettings.html", + "title": "Class AudioSocketSettings", + "keywords": "Class AudioSocketSettings The settings to initialize the AudioSocket. Inheritance Object AudioSocketSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioSocketSettings Constructors AudioSocketSettings() Initializes an AudioSocketSettings object. Declaration public AudioSocketSettings() Properties CallId An alphanumeric string that uniquely identifies a call Declaration public string CallId { get; set; } Property Value Type Description String ReceiveUnmixedMeetingAudio Allows the bot to receive separate unmixed audio buffers for individual speakers in a meeting. When set to true, up to four audio buffers, each corresponding to the top four active speakers, will be received at a time. In UnmixedMeetingAudio mode, the bot will receive only unmixed audio and not both unmixed and mixed. Declaration public bool ReceiveUnmixedMeetingAudio { get; set; } Property Value Type Description Boolean Remarks Unmixed audio is optimized for machine cognition (e.g., speech recognition) rather than for human perception (such as call recording and playback). Certain error concealment treatment (e.g., to mitigate packet loss) is not applied to the received audio stream in unmixed mode. In order to receive both mixed and unmixed audio simultaneously, the bot must establish two separate calls into the meeting. StreamDirections The directionality of the media stream. This indicates whether it is enabled to both send and receive media, or only send or only receive media. Declaration public StreamDirection StreamDirections { get; set; } Property Value Type Description StreamDirection SupportedAudioFormat The supported send/receive audio format. Declaration public AudioFormat SupportedAudioFormat { get; set; } Property Value Type Description AudioFormat" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.ContentTypeFilter.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.ContentTypeFilter.html", - "title": "Class ContentTypeFilter", - "keywords": "Class ContentTypeFilter Does match of content-type header. If content-type matches filter then whole body is removed. Inheritance Object BaseFilter BaseFilter < String , String > ContentTypeFilter Inherited Members BaseFilter.MatchableString BaseFilter.MatchEvaluator Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ContentTypeFilter : BaseFilter Constructors ContentTypeFilter(String, Func) Initializes a new instance of the ContentTypeFilter class. Declaration public ContentTypeFilter(string matchableContentTypeMediaType, Func matchEvaluator = null) Parameters Type Name Description String matchableContentTypeMediaType Type of the matchable content type media. Func < String , String > matchEvaluator The match evaluator. Methods IsContentTypeMatch(IEnumerable, HttpContent, out String) Determines whether [is content type match] [the specified filters]. Declaration public static bool IsContentTypeMatch(IEnumerable filters, HttpContent content, out string outputMessage) Parameters Type Name Description IEnumerable < ContentTypeFilter > filters The filters. HttpContent content The content. String outputMessage The output message. Returns Type Description Boolean true if [is content type match] [the specified filters]; otherwise, false . Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.AudioMediaReceivedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioMediaReceivedEventArgs.html", + "title": "Class AudioMediaReceivedEventArgs", + "keywords": "Class AudioMediaReceivedEventArgs Event arguments of an AudioMediaReceived event. Inheritance Object EventArgs AudioMediaReceivedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioMediaReceivedEventArgs : EventArgs Constructors AudioMediaReceivedEventArgs() Declaration public AudioMediaReceivedEventArgs() Properties Buffer The received audio media buffer. Declaration public AudioMediaBuffer Buffer { get; set; } Property Value Type Description AudioMediaBuffer" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.ContentDispositionFilter.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.ContentDispositionFilter.html", - "title": "Class ContentDispositionFilter", - "keywords": "Class ContentDispositionFilter Does match of content disposition header. If content disposition matches filter then whole body is removed. Inheritance Object BaseFilter BaseFilter < String , String > ContentDispositionFilter Inherited Members BaseFilter.MatchableString BaseFilter.MatchEvaluator Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ContentDispositionFilter : BaseFilter Constructors ContentDispositionFilter(String, Func) Initializes a new instance of the ContentDispositionFilter class. Declaration public ContentDispositionFilter(string matchableString, Func matchEvaluator = null) Parameters Type Name Description String matchableString Name of the matchable content disposition. Func < String , String > matchEvaluator The match evaluator. Methods IsContentDispositionMatch(IEnumerable, HttpContent, out String) Determines whether [is content disposition match] [the specified filters]. Declaration public static bool IsContentDispositionMatch(IEnumerable filters, HttpContent content, out string outputMessage) Parameters Type Name Description IEnumerable < ContentDispositionFilter > filters The filters. HttpContent content The content. String outputMessage The output message. Returns Type Description Boolean true if [is content disposition match] [the specified filters]; otherwise, false . Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.Messages.html": { + "href": "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.Messages.html", + "title": "Class CommsGeneratedErrorConstants.Messages", + "keywords": "Class CommsGeneratedErrorConstants.Messages The messages. Inheritance Object CommsGeneratedErrorConstants.Messages Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Messages Fields ResponseObjectUsedForUpdate Response object used for update error message. Declaration public const string ResponseObjectUsedForUpdate = \"Do not use objects returned in a response for updating an object in Microsoft Graph. Create a new {0} object and only set the updated properties on it.\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.ObjectRootDisposable.html": { - "href": "common/Microsoft.Graph.Communications.Common.ObjectRootDisposable.html", - "title": "Class ObjectRootDisposable", - "keywords": "Class ObjectRootDisposable Base object. Inheritance Object Disposable ObjectRootDisposable TaskQueue Implements IDisposable Inherited Members Disposable.Dispose() Disposable.Dispose(Boolean) Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public abstract class ObjectRootDisposable : Disposable, IDisposable Constructors ObjectRootDisposable(IGraphLogger) Initializes a new instance of the ObjectRootDisposable class. Declaration protected ObjectRootDisposable(IGraphLogger logger) Parameters Type Name Description IGraphLogger logger Logger instance. Properties GraphLogger Gets the logger. Declaration protected IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.Codes.html": { + "href": "core/Microsoft.Graph.Communications.Core.CommsGeneratedErrorConstants.Codes.html", + "title": "Class CommsGeneratedErrorConstants.Codes", + "keywords": "Class CommsGeneratedErrorConstants.Codes The codes Inheritance Object CommsGeneratedErrorConstants.Codes Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Codes Fields NotAllowed Not allowed error code. Declaration public const string NotAllowed = \"notAllowed\" Field Value Type Description String" }, - "client/Microsoft.Graph.Communications.Client.ICommunicationsClient.html": { - "href": "client/Microsoft.Graph.Communications.Client.ICommunicationsClient.html", - "title": "Interface ICommunicationsClient", - "keywords": "Interface ICommunicationsClient The CommunicationsClient interface. This is the entry point of the SDK and a reference to this instance must be held for the duration of the session. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface ICommunicationsClient : IDisposable Properties AppId Gets the application identifier. Declaration string AppId { get; } Property Value Type Description String AppName Gets the name of the application. Declaration string AppName { get; } Property Value Type Description String AuthenticationProvider Gets the authentication provider used to authenticate both inbound and outbound requests. Declaration IRequestAuthenticationProvider AuthenticationProvider { get; } Property Value Type Description IRequestAuthenticationProvider BaseUrl Gets the Graph service's base URL. Declaration string BaseUrl { get; } Property Value Type Description String GraphClient Gets the graph client. This is the Client used to communicate with the service. Declaration IGraphClient GraphClient { get; } Property Value Type Description IGraphClient GraphLogger Gets the graph logger. This is the logger used within the SDK. Declaration IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Id Gets the client identifier. Declaration Guid Id { get; } Property Value Type Description Guid Serializer Gets the serializer Declaration ISerializer Serializer { get; } Property Value Type Description ISerializer Methods ProcessNotifications(Uri, CommsNotifications, String, Guid, Guid, IDictionary) Processes the notifications and raise the required callbacks. This function should be called in order for the SDK to raise any required events and process state changes. Declaration void ProcessNotifications(Uri callbackUri, CommsNotifications notifications, string tenantId, Guid requestId, Guid scenarioId, IDictionary additionalData = null) Parameters Type Name Description Uri callbackUri The callback URI. CommsNotifications notifications The notifications. String tenantId The tenant identifier. Guid requestId The request identifier. Guid scenarioId The scenario identifier. IDictionary < String , Object > additionalData Additional data associated with the notification. RehydrateAsync(String, String, Guid) Re-hydrates the resource at the specified path asynchronously. Declaration Task RehydrateAsync(string resourcePath, string tenantId, Guid scenarioId = default(Guid)) Parameters Type Name Description String resourcePath The resource path. String tenantId The tenant identifier. Guid scenarioId The scenario identifier. Returns Type Description Task The Task . TerminateAsync(TimeSpan) Terminates this client asynchronously. This terminates all the calls, waits for dispose events, and disposes everything. Declaration Task TerminateAsync(TimeSpan timeout = default(TimeSpan)) Parameters Type Name Description TimeSpan timeout The timeout. Returns Type Description Task < Boolean > True if all instances terminated successfully, false otherwise. Events OnNotificationException Occurs when exceptions are raised on notification callbacks. Declaration event Action OnNotificationException Event Type Type Description Action < FailedNotificationEventArgs > OnNotificationProcessed Occurs when the notification has been processed by all callbacks. Declaration event Action OnNotificationProcessed Event Type Type Description Action < NotificationEventArgs > OnNotificationQueued Occurs when the notification has been queued into the backlog. Declaration event Action OnNotificationQueued Event Type Type Description Action < NotificationEventArgs > Extension Methods CommunicationsClientExtensions.ProcessNotificationAsync(ICommunicationsClient, HttpRequestMessage) CommunicationsClientExtensions.LogAndCreateResponse(ICommunicationsClient, HttpRequestMessage, Guid, Guid, CommsNotifications, HttpStatusCode, Stopwatch, Exception) CommunicationsClientExtensions.CreateResponse(ICommunicationsClient, HttpStatusCode, Guid, Guid, Object)" + "common/Microsoft.Graph.Communications.Common.Telemetry.JsonConverters.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.JsonConverters.html", + "title": "Class JsonConverters", + "keywords": "Class JsonConverters Json converters. Inheritance Object JsonConverters Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class JsonConverters" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphRequest-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphRequest-1.html", - "title": "Class GraphRequest", - "keywords": "Class GraphRequest The base of the exchange of a IGraphRequest or IGraphResponse . Inheritance Object GraphRequest GraphRequest Implements IGraphRequest IGraphExchange IGraphExchange Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphRequest : IGraphRequest, IGraphExchange, IGraphExchange Type Parameters Name Description T Constructors GraphRequest(Uri, T, RequestType) Initializes a new instance of the GraphRequest class. Create the graph request object Declaration public GraphRequest(Uri location, T content, RequestType requestType) Parameters Type Name Description Uri location The uri location for the request. T content Content to be sent as part of the request. RequestType requestType Type of the request. Properties Content Declaration public T Content { get; set; } Property Value Type Description T Properties Gets the properties of the exchange. Declaration public ICollection Properties { get; } Property Value Type Description ICollection < IGraphProperty > RequestType Declaration public RequestType RequestType { get; } Property Value Type Description RequestType Uri Declaration public Uri Uri { get; } Property Value Type Description Uri Methods ToString() Declaration public override string ToString() Returns Type Description String Overrides Object.ToString() Implements IGraphRequest IGraphExchange IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphRequestExtensions.ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable)" + "bot_media/Microsoft.Skype.Bots.Media.LogLevel.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.LogLevel.html", + "title": "Enum LogLevel", + "keywords": "Enum LogLevel Specifies a current logging level for a log line. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum LogLevel Fields Name Description Error Error Log Level Information Information Log Level Verbose Verbose Log Level Warning Warning Log Level" }, - "core/Microsoft.Graph.Communications.Core.Notifications.INotificationProcessor.html": { - "href": "core/Microsoft.Graph.Communications.Core.Notifications.INotificationProcessor.html", - "title": "Interface INotificationProcessor", - "keywords": "Interface INotificationProcessor The notification processor interface. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public interface INotificationProcessor : IDisposable Properties AuthenticationProvider Gets the authentication provider. TODO: This should probably not be a part of the INotificationProcessor . Ideally the request is already validated prior to making it in here. This means that 1) Already sanitized by authentication provider and 2) The tenant/scenario id parameters extracted into the IGraphRequest. Declaration IAuthenticationProvider AuthenticationProvider { get; } Property Value Type Description IAuthenticationProvider The authentication provider. Methods ProcessNotifications(Uri, String, String, Guid, Guid, IEnumerable>) Processes the notifications and raise the required callbacks. This function should be called in order for the SDK to raise any required events and process state changes. Declaration void ProcessNotifications(Uri callbackUri, string content, string tenantId, Guid requestId, Guid scenarioId, IEnumerable> additionalData = null) Parameters Type Name Description Uri callbackUri The callback URI. String content The notifications content. String tenantId The tenant identifier. Guid requestId The request identifier. Guid scenarioId The scenario identifier. IEnumerable < KeyValuePair < String , Object >> additionalData Additional data associated with the notification. Events OnCollectionNotificationReceived Occurs when a collection notification is received. Declaration event Action OnCollectionNotificationReceived Event Type Type Description Action < CollectionNotificationEventArgs > OnNotificationReceived Occurs when a notification is received. This is a global hook for all notifications. Declaration event Action OnNotificationReceived Event Type Type Description Action < NotificationEventArgs > OnResourceNotificationReceived Occurs when a single resource notification is received. Declaration event Action OnResourceNotificationReceived Event Type Type Description Action < NotificationEventArgs > Extension Methods NotificationProcessorExtensions.ProcessNotificationAsync(INotificationProcessor, HttpRequestMessage)" + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.GraphUriFilters.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.GraphUriFilters.html", + "title": "Class GraphUriFilters", + "keywords": "Class GraphUriFilters Uri filters to filter PII in graph urls. Inheritance Object GraphUriFilters Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphUriFilters Constructors GraphUriFilters() Declaration public GraphUriFilters() Properties ChatUriFilters Gets the chat URI filters. Declaration public static List ChatUriFilters { get; } Property Value Type Description List < UriFilter > Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.Communications.Core.Notifications.CollectionNotificationEventArgs.html": { - "href": "core/Microsoft.Graph.Communications.Core.Notifications.CollectionNotificationEventArgs.html", - "title": "Class CollectionNotificationEventArgs", - "keywords": "Class CollectionNotificationEventArgs The collection notification event args. Inheritance Object NotificationEventArgs CollectionNotificationEventArgs Inherited Members NotificationEventArgs.NotificationId NotificationEventArgs.CallbackUri NotificationEventArgs.Notification NotificationEventArgs.TenantId NotificationEventArgs.RequestId NotificationEventArgs.ScenarioId NotificationEventArgs.ChangeType NotificationEventArgs.AdditionalData Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class CollectionNotificationEventArgs : NotificationEventArgs Constructors CollectionNotificationEventArgs(Uri, CommsNotification, ChangeType, IReadOnlyList) Initializes a new instance of the CollectionNotificationEventArgs class. Declaration public CollectionNotificationEventArgs(Uri callbackUri, CommsNotification notification, ChangeType changeType, IReadOnlyList resourceData) Parameters Type Name Description Uri callbackUri The callback URI. CommsNotification notification The notification. ChangeType changeType Type of the change. IReadOnlyList < Object > resourceData The resource data. Properties ResourceData Gets the resource data object list. Declaration public IReadOnlyList ResourceData { get; } Property Value Type Description IReadOnlyList < Object > The resource data object list. See Also NotificationEventArgs" + "common/Microsoft.Graph.Communications.Common.HttpConstants.HeaderNames.html": { + "href": "common/Microsoft.Graph.Communications.Common.HttpConstants.HeaderNames.html", + "title": "Class HttpConstants.HeaderNames", + "keywords": "Class HttpConstants.HeaderNames The header names. Inheritance Object HttpConstants.HeaderNames Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HeaderNames Fields Accept The accept header. Declaration public const string Accept = \"Accept\" Field Value Type Description String AccessControlAllowCredentials Access-Control-Allow-Credentials Declaration public const string AccessControlAllowCredentials = \"Access-Control-Allow-Credentials\" Field Value Type Description String AccessControlAllowHeaders Access-Control-Allow-Headers Declaration public const string AccessControlAllowHeaders = \"Access-Control-Allow-Headers\" Field Value Type Description String AccessControlAllowOrigin Access-Control-Allow-Origin Declaration public const string AccessControlAllowOrigin = \"Access-Control-Allow-Origin\" Field Value Type Description String AccessControlMaxAge Access-Control-Max-Age Declaration public const string AccessControlMaxAge = \"Access-Control-Max-Age\" Field Value Type Description String AccessControlRequestHeaders Access-Control-Request-Headers Declaration public const string AccessControlRequestHeaders = \"Access-Control-Request-Headers\" Field Value Type Description String AccessControlRequestMethod Access-Control-Request-Method Declaration public const string AccessControlRequestMethod = \"Access-Control-Request-Method\" Field Value Type Description String Authorization The authorization header. Declaration public const string Authorization = \"Authorization\" Field Value Type Description String CacheControl The cache control header. Declaration public const string CacheControl = \"Cache-Control\" Field Value Type Description String CalleeRegion The callee region header. Declaration public const string CalleeRegion = \"X-Microsoft-Skype-Callee-Region\" Field Value Type Description String CallerRegion The caller region header. Declaration public const string CallerRegion = \"X-Microsoft-Skype-Caller-Region\" Field Value Type Description String ChainId The chain identifier header. This header is used to correlate requests to each other within the NGC stack. Declaration public const string ChainId = \"X-Microsoft-Skype-Chain-ID\" Field Value Type Description String ClientRequestId The client request identifier header. This header is used to track individual requests between the client and SF services. Declaration public const string ClientRequestId = \"Client-Request-Id\" Field Value Type Description String Connection The connection header. Declaration public const string Connection = \"Connection\" Field Value Type Description String ContentLength The content length header. Declaration public const string ContentLength = \"Content-Length\" Field Value Type Description String ContentType The content type header. Declaration public const string ContentType = \"Content-Type\" Field Value Type Description String ContextId The context identifier header. Declaration public const string ContextId = \"ContextId\" Field Value Type Description String Date The date header. Declaration public const string Date = \"Date\" Field Value Type Description String Duration The duration header. Declaration public const string Duration = \"Duration\" Field Value Type Description String GatewayServiceRootHeader the header that graph adds to the proxied request to PMA Declaration public const string GatewayServiceRootHeader = \"x-ms-gateway-serviceRoot\" Field Value Type Description String Host The host header. Declaration public const string Host = \"Host\" Field Value Type Description String Location The location header. Declaration public const string Location = \"Location\" Field Value Type Description String MessageId The message identifier header. This header is used to track individual requests within the NGC stack. Declaration public const string MessageId = \"X-Microsoft-Skype-Message-ID\" Field Value Type Description String MsAttribution X-MS-Attribution. Declaration public const string MsAttribution = \"X-MS-Attribution\" Field Value Type Description String MsDiagnostics The microsoft graph diagnostics header. Declaration public const string MsDiagnostics = \"x-ms-ags-diagnostic\" Field Value Type Description String MsParticipants X-MS-Participants. Declaration public const string MsParticipants = \"X-MS-Participants\" Field Value Type Description String ODataVersion The odata version header. Declaration public const string ODataVersion = \"OData-Version\" Field Value Type Description String Origin Origin Declaration public const string Origin = \"Origin\" Field Value Type Description String OriginalMessageId The original message identifier header. Declaration public const string OriginalMessageId = \"X-Microsoft-Skype-Original-Message-ID\" Field Value Type Description String PmaInstanceUrl The pma instance URL. Used to retarget PSA to a particular PMA instance. Declaration public const string PmaInstanceUrl = \"X-Microsoft-Pma-Instance\" Field Value Type Description String RedirectDu The redirect du header. Declaration public const string RedirectDu = \"X-Plat-Redirect-Du\" Field Value Type Description String RedirectRegion The redirect region header. Declaration public const string RedirectRegion = \"X-Plat-Redirect-Region\" Field Value Type Description String RequestId The request identifier header. This header is returned by graph to identify the specific request. Declaration public const string RequestId = \"Request-Id\" Field Value Type Description String RoutingTargetRegion The Routing-Target-Region header. Declaration public const string RoutingTargetRegion = \"Routing-Target-Region\" Field Value Type Description String ScenarioId The scenario identifier header. This header is used to correlate requests to each other between client and SF services. Declaration public const string ScenarioId = \"Scenario-Id\" Field Value Type Description String SchedulingServiceTelemetryId Scheduling service telemetry header. This header is used to correlate requests with SS service. Declaration public const string SchedulingServiceTelemetryId = \"X-MS-Skype-MLC-Telemetry-Id\" Field Value Type Description String Skypetoken X-Skypetoken Declaration public const string Skypetoken = \"X-Skypetoken\" Field Value Type Description String StrictTransportSecurity The strict transport security header. Declaration public const string StrictTransportSecurity = \"Strict-Transport-Security\" Field Value Type Description String Tenant The tenant header Declaration public const string Tenant = \"X-Microsoft-Tenant\" Field Value Type Description String TenantRegion The tenant region header. Declaration public const string TenantRegion = \"Tenant-Region\" Field Value Type Description String ThrowSite The throw site header. Declaration public const string ThrowSite = \"X-ThrowSite\" Field Value Type Description String TransferEncoding The transfer encoding header. Declaration public const string TransferEncoding = \"Transfer-Encoding\" Field Value Type Description String UserAgent The user agent header. Declaration public const string UserAgent = \"User-Agent\" Field Value Type Description String WebhooksResource Webhooks-WorkloadResource Declaration public const string WebhooksResource = \"Webhooks-WorkloadResource\" Field Value Type Description String XMsClientUserAgent Client User Agent header. This header has the user agent in requests. Used in requests to presence service at the moment. Declaration public const string XMsClientUserAgent = \"X-Ms-Client-User-Agent\" Field Value Type Description String XMsClientVersion The client version header. This header has the client version in requests. Used in requests to presence service at the moment. Declaration public const string XMsClientVersion = \"X-Ms-Client-Version\" Field Value Type Description String XMsCorrelationId the correlation id header. This header is used to correlate requests with presence service at the moment. Declaration public const string XMsCorrelationId = \"X-Ms-Correlation-Id\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphResponse-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphResponse-1.html", - "title": "Interface IGraphResponse", - "keywords": "Interface IGraphResponse The response got in exchange of a IGraphRequest . Inherited Members IGraphExchange.Content IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphResponse : IGraphExchange, IGraphExchange Type Parameters Name Description T Type of the body of response. Properties ErrorContent Gets the content of the error. Declaration string ErrorContent { get; } Property Value Type Description String ReasonPhrase Gets the reason phrase. Declaration string ReasonPhrase { get; } Property Value Type Description String Status Gets the status of response. Declaration ResponseStatus Status { get; } Property Value Type Description ResponseStatus Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphResponseExtensions.ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable) See Also IGraphExchange " + "common/Microsoft.Graph.Communications.Common.HighResolutionDateTime.html": { + "href": "common/Microsoft.Graph.Communications.Common.HighResolutionDateTime.html", + "title": "Class HighResolutionDateTime", + "keywords": "Class HighResolutionDateTime High resolution datetime Inheritance Object HighResolutionDateTime Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HighResolutionDateTime Properties IsAvailable Gets a value indicating whether high resolution datetime is available Declaration public static bool IsAvailable { get; } Property Value Type Description Boolean UtcNow Gets UTC now Declaration public static DateTime UtcNow { get; } Property Value Type Description DateTime" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscatedValueProvider.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscatedValueProvider.html", - "title": "Class ObfuscatedValueProvider", - "keywords": "Class ObfuscatedValueProvider Newtonsoft JSONs value provider for obfuscated data. Inheritance Object ObfuscatedValueProvider Implements Newtonsoft.Json.Serialization.IValueProvider Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ObfuscatedValueProvider : IValueProvider Constructors ObfuscatedValueProvider(MemberInfo, IObfuscationEngine, ObfuscationTag) Initializes a new instance of the ObfuscatedValueProvider class. Declaration public ObfuscatedValueProvider(MemberInfo memberInfo, IObfuscationEngine obfuscationEngine, ObfuscationTag obfuscationTag) Parameters Type Name Description MemberInfo memberInfo The member information. IObfuscationEngine obfuscationEngine The obfuscation engine. ObfuscationTag obfuscationTag The obfuscation tag. Methods GetValue(Object) Declaration public object GetValue(object target) Parameters Type Name Description Object target Returns Type Description Object SetValue(Object, Object) Sets the value. Declaration public void SetValue(object target, object value) Parameters Type Name Description Object target The target to set the value on. Object value The value to set on the target. Implements Newtonsoft.Json.Serialization.IValueProvider Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.AudioFormat.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioFormat.html", + "title": "Enum AudioFormat", + "keywords": "Enum AudioFormat The audio format. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum AudioFormat Fields Name Description Pcm16K PCM 16K Pcm44KStereo PCM 44.1K Stereo" }, - "client/Microsoft.Graph.Communications.Resources.IResourceCollection-3.html": { - "href": "client/Microsoft.Graph.Communications.Resources.IResourceCollection-3.html", - "title": "Interface IResourceCollection", - "keywords": "Interface IResourceCollection The resource collection interface. Inherited Members IResourceCollection.TryForceRemove(String, TResource) IResourceCollection.Item[String] IResourceCollection.TerminateAsync(TimeSpan) IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResourceCollection : IResourceCollection, IResourceCollection, IResourceBase, IDisposable, IReadOnlyCollection, IEnumerable, IEnumerable where TSelf : IResourceCollection where TResource : IResource where TEntity : Entity Type Parameters Name Description TSelf The self type of the collection. TResource The containing resource type. IResource TEntity The containing resource type. Entity Events OnUpdated Event triggered whenever a resource is updated from the collection. Declaration event CollectionEventHandler OnUpdated Event Type Type Description CollectionEventHandler See Also IResourceCollection " + "bot_media/Microsoft.Skype.Bots.Media.UnmixedAudioBuffer.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.UnmixedAudioBuffer.html", + "title": "Struct UnmixedAudioBuffer", + "keywords": "Struct UnmixedAudioBuffer Represents an unmanaged audio buffer containing unmixed data corresponding to a specific speaker in a conference. This structure contains a pointer to the unmanaged audio buffer, the length of the buffer and the ID of the audio source of the active speaker. Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() ValueType.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public struct UnmixedAudioBuffer Properties ActiveSpeakerId The ID of the audio source of the active speaker. Declaration public uint ActiveSpeakerId { get; } Property Value Type Description UInt32 Data Pointer to the unmanaged media buffer. Declaration public IntPtr Data { get; } Property Value Type Description IntPtr Length The length in bytes of the media buffer. Declaration public long Length { get; } Property Value Type Description Int64 OriginalSenderTimestamp Original timestamp of the unmixed audio buffer as it was sourced, in 100-ns units. This property may differ from AudioMediaBuffer.Timestamp, which represents the timestamp of when the media content was received by the bot. Declaration public long OriginalSenderTimestamp { get; } Property Value Type Description Int64 Remarks The OriginalSenderTimestamp can have a value of 0 under various circumstances, eg. in the first 4-5 seconds of the call, or during various media events (media reconnects, sample rate changes, etc)." }, - "client/Microsoft.Graph.Communications.Resources.IResourceCollection-2.html": { - "href": "client/Microsoft.Graph.Communications.Resources.IResourceCollection-2.html", - "title": "Interface IResourceCollection", - "keywords": "Interface IResourceCollection The resource collection interface. Inherited Members IResourceCollection.TerminateAsync(TimeSpan) IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResourceCollection : IResourceCollection, IResourceBase, IDisposable, IReadOnlyCollection, IEnumerable, IEnumerable where TResource : IResource where TEntity : Entity Type Parameters Name Description TResource The containing resource type. IResource TEntity The containing resource type. Entity Properties Item[String] The resource with the specified identifier. Declaration TResource this[string id] { get; } Parameters Type Name Description String id The identifier. Property Value Type Description TResource The IResource . Methods TryForceRemove(String, out TResource) Attempts to remove and return the value that has the specified id from the IResourceCollection . This will force remove the object, if for whatever reason it cannot be removed by the service. It should only be used as a last resort to clean up stale resources. Declaration bool TryForceRemove(string id, out TResource resource) Parameters Type Name Description String id The identifier. TResource resource The resource. Returns Type Description Boolean true if the object was removed successfully; otherwise, false. See Also IResourceCollection IReadOnlyCollection " + "bot_media/Microsoft.Skype.Bots.Media.NetworkMetrics.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.NetworkMetrics.html", + "title": "Class NetworkMetrics", + "keywords": "Class NetworkMetrics QoE network level metrics Inheritance Object NetworkMetrics Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class NetworkMetrics Constructors NetworkMetrics() Declaration public NetworkMetrics() Properties AverageInboundPacketLossRateInPercentage Average packet loss rate on the inbound media stream Declaration public double AverageInboundPacketLossRateInPercentage { get; set; } Property Value Type Description Double AverageInboundRoundTripDelay Average round trip delay on the inbound media stream Declaration public TimeSpan AverageInboundRoundTripDelay { get; set; } Property Value Type Description TimeSpan AverageOutboundPacketLossRateInPercentage Average packet loss rate on the outbound media stream Declaration public double AverageOutboundPacketLossRateInPercentage { get; set; } Property Value Type Description Double AverageOutboundRoundTripDelay Average round trip delay on the outbound media stream Declaration public TimeSpan AverageOutboundRoundTripDelay { get; set; } Property Value Type Description TimeSpan MaximumInboundPacketLossRateInPercentage Maximum packet loss rate on the inbound media stream Declaration public double MaximumInboundPacketLossRateInPercentage { get; set; } Property Value Type Description Double MaximumInboundRoundTripDelay Maximum round trip delay on the inbound media stream Declaration public TimeSpan MaximumInboundRoundTripDelay { get; set; } Property Value Type Description TimeSpan MaximumOutboundPacketLossRateInPercentage Maximum packet loss rate on the outbound media stream Declaration public double MaximumOutboundPacketLossRateInPercentage { get; set; } Property Value Type Description Double MaximumOutboundRoundTripDelay Maximum round trip delay on the outbound media stream Declaration public TimeSpan MaximumOutboundRoundTripDelay { get; set; } Property Value Type Description TimeSpan TotalInboundPackets Total number of packets received on the inbound media stream Declaration public uint TotalInboundPackets { get; set; } Property Value Type Description UInt32 TotalOutboundPackets Total number of packets sent on the outbound media stream Declaration public uint TotalOutboundPackets { get; set; } Property Value Type Description UInt32" }, - "client/Microsoft.Graph.Communications.Client.Transport.GraphClientWrapper.html": { - "href": "client/Microsoft.Graph.Communications.Client.Transport.GraphClientWrapper.html", - "title": "Class GraphClientWrapper", - "keywords": "Class GraphClientWrapper The graph client wrapper. Inheritance Object GraphClientWrapper Implements IGraphClient Namespace : Microsoft.Graph.Communications.Client.Transport Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class GraphClientWrapper : ObjectRoot, IGraphClient Constructors GraphClientWrapper(IGraphClient, GraphClientContext) Initializes a new instance of the GraphClientWrapper class. Declaration public GraphClientWrapper(IGraphClient client, GraphClientContext context) Parameters Type Name Description IGraphClient client The client. GraphClientContext context The context. Properties Context Gets the context. Declaration public GraphClientContext Context { get; } Property Value Type Description GraphClientContext DefaultProperties Gets the default properties. Declaration public IEnumerable DefaultProperties { get; } Property Value Type Description IEnumerable < IGraphProperty > GraphLogger Declaration public IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Methods SendAsync(IGraphRequest, CancellationToken) Declaration public Task SendAsync(IGraphRequest request, CancellationToken cancellationToken = default(CancellationToken)) where T : class Parameters Type Name Description IGraphRequest request CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T SendAsync(IGraphRequest, CancellationToken) Declaration public Task> SendAsync(IGraphRequest request, CancellationToken cancellationToken = default(CancellationToken)) where T1 : class where T2 : class Parameters Type Name Description IGraphRequest request CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T1 T2 Implements IGraphClient" + "bot_media/Microsoft.Skype.Bots.Media.MediaQualityOfExperienceData.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaQualityOfExperienceData.html", + "title": "Class MediaQualityOfExperienceData", + "keywords": "Class MediaQualityOfExperienceData Media quality of experience (QoE) data Inheritance Object MediaQualityOfExperienceData AudioQualityOfExperienceData VideoQualityOfExperienceData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public abstract class MediaQualityOfExperienceData Constructors MediaQualityOfExperienceData() MediaQualityOfExperienceData constructor Declaration public MediaQualityOfExperienceData() Properties NetworkMetrics QoE network level metrics Declaration public NetworkMetrics NetworkMetrics { get; set; } Property Value Type Description NetworkMetrics TotalMediaDuration Total duration of the media stream Declaration public TimeSpan TotalMediaDuration { get; set; } Property Value Type Description TimeSpan" }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphProperty.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphProperty.html", - "title": "Interface IGraphProperty", - "keywords": "Interface IGraphProperty The graph property containing request or response data. Inherited Members IEquatable.Equals(IGraphProperty) Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphProperty : IEquatable Properties Key Gets the key. Declaration string Key { get; } Property Value Type Description String Type Gets the type of the property. Declaration string Type { get; } Property Value Type Description String Value Gets the value. Declaration object Value { get; } Property Value Type Description Object Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphProperty.ConvertProperty(IGraphProperty)" + "bot_media/Microsoft.Skype.Bots.Media.MediaPlatform.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatform.html", + "title": "Class MediaPlatform", + "keywords": "Class MediaPlatform This class represents the Skype Bots Media Platform. Inheritance Object MediaPlatform Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public static class MediaPlatform Fields DefaultMaxMediaPort The default maximum media port. Declaration public const uint DefaultMaxMediaPort = 65535U Field Value Type Description UInt32 DefaultMinMediaPort The default minimum media port. Declaration public const uint DefaultMinMediaPort = 49152U Field Value Type Description UInt32 MaxNumberOfConcurrentSendVideoSocketsPerPlatform The maximum number of send video/vbss sockets allowed by the media plaform. Declaration public const int MaxNumberOfConcurrentSendVideoSocketsPerPlatform = 1000 Field Value Type Description Int32 MaxNumberOfVideoSocketsPerCall The maximum number of video sockets that can be passed to the CreateMediaConfiguration API. Declaration public const int MaxNumberOfVideoSocketsPerCall = 10 Field Value Type Description Int32 MinNumberOfCoresRequired The minimum number of cores that the Media Platform requires. Declaration public const int MinNumberOfCoresRequired = 2 Field Value Type Description Int32 Name Name of the Bots Media Platform Declaration public const string Name = \"SkypeBotsMediaPlatform\" Field Value Type Description String Properties CurrentHealth The current health status of the media platform. Declaration public static MediaPlatformHealthStatus CurrentHealth { get; } Property Value Type Description MediaPlatformHealthStatus Methods CreateMediaConfiguration(IAudioSocket) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for the audio modality. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IDataSocket) Reserved for the internal use. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IDataSocket dataSocket) Parameters Type Name Description IAudioSocket audioSocket IDataSocket dataSocket Returns Type Description Newtonsoft.Json.Linq.JObject CreateMediaConfiguration(IAudioSocket, IVideoSocket) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for each modality. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IVideoSocket videoSocket) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IVideoSocket videoSocket Socket that handles video. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for each modality. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets) Parameters Type Name Description IAudioSocket audioSocket Socket that handles audio. IList < IVideoSocket > videoSockets Ordered list of video sockets. The order in which the sockets are provided maps to the order of the streams exposed by MediaPaaS (eg. the first video socket in the list will correspond to the first video stream exposed in the list of MediaStreams in MediaPaaS' MediaFlow resource). If multiview sockets are provided, only the first one can have a send direction (ie. send only or send receive) and all the sockets should have a receive direction. Returns Type Description Newtonsoft.Json.Linq.JObject Serialized MediaConfiguration object. Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList, IVideoSocket) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for each modality. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets, IVideoSocket vbssSocket) Parameters Type Name Description IAudioSocket audioSocket IList < IVideoSocket > videoSockets Ordered list of video sockets. The order in which the sockets are provided maps to the order of the streams exposed by MediaPaaS (eg. the first video socket in the list will correspond to the first video stream exposed in the list of MediaStreams in MediaPaaS' MediaFlow resource). If multiview sockets are provided, only the first one can have a send direction (ie. send only or send receive) and all the sockets should have a receive direction. IVideoSocket vbssSocket Video socket for the video-based screen sharing (VBSS) modality. Socket must be configured as RecvOnly. Returns Type Description Newtonsoft.Json.Linq.JObject Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized, or a vbssSocket is configured to be sendonly or sendrecv. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. CreateMediaConfiguration(IAudioSocket, IList, IVideoSocket, IDataSocket) Reserved for the internal use. Declaration public static JObject CreateMediaConfiguration(IAudioSocket audioSocket, IList videoSockets, IVideoSocket vbssSocket, IDataSocket dataSocket) Parameters Type Name Description IAudioSocket audioSocket IList < IVideoSocket > videoSockets IVideoSocket vbssSocket IDataSocket dataSocket Returns Type Description Newtonsoft.Json.Linq.JObject CreateMediaConfiguration(IVideoSocket) Returns a serialized mediaConfiguration object, containing MP URI and render/source contexts for each modality. Declaration public static JObject CreateMediaConfiguration(IVideoSocket vbssSocket) Parameters Type Name Description IVideoSocket vbssSocket Video socket for the video-based screen sharing (VBSS) modality. Socket must be configured as RecvOnly. Returns Type Description Newtonsoft.Json.Linq.JObject Exceptions Type Condition ArgumentException A VideoSocket is not configured correctly. InvalidOperationException MediaPlatform is not initialized, or a vbssSocket is configured to be sendonly or sendrecv. SkypeMediaException The media platform is currently overloaded and cannot handle new calls. GetCurrentTimestamp() Get a current timestamp, in 100-ns units. To be used when sourcing media buffers. Declaration public static long GetCurrentTimestamp() Returns Type Description Int64 Initialize(MediaPlatformSettings) Initializes the Media Platform for Bot. Declaration public static void Initialize(MediaPlatformSettings settings) Parameters Type Name Description MediaPlatformSettings settings Settings to initialize the Bot Media Platform. Shutdown() Shuts down the Bot Media Platform. Declaration public static void Shutdown() Events MediaPlatformHealthChanged Raised when there is a change in the media platform's health status. The event arguments report the current and previous platform health conditions. Declaration public static event EventHandler MediaPlatformHealthChanged Event Type Type Description EventHandler < MediaPlatformHealthChangedEventArgs > Remarks A bot application which may handle very high call volumes or perform complex real-time media processing should monitor this event for changes in the media platform health status. When the event reports the platform health status has become HeavilyLoaded, the application should avoid starting new bot calls on the machine instance until the health status returns back to Normal." }, - "common/Microsoft.Graph.Communications.Common.OData.ODataResolver.html": { - "href": "common/Microsoft.Graph.Communications.Common.OData.ODataResolver.html", - "title": "Class ODataResolver", - "keywords": "Class ODataResolver Contract resolver that allows us to create OData json payloads with type information. Inheritance Object ODataResolver GraphObfuscationContractResolver Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ODataResolver : CamelCasePropertyNamesContractResolver Constructors ODataResolver(Boolean, Assembly[]) Initializes a new instance of the ODataResolver class which can be used to serialize/deserialize classes present in typeAssemblies . Declaration public ODataResolver(bool addOdataType, params Assembly[] typeAssemblies) Parameters Type Name Description Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. Assembly [] typeAssemblies Assemblies in which the OData object exist. Methods CreateProperties(Type, MemberSerialization) Declaration protected override IList CreateProperties(Type type, MemberSerialization memberSerialization) Parameters Type Name Description Type type Newtonsoft.Json.MemberSerialization memberSerialization Returns Type Description IList < Newtonsoft.Json.Serialization.JsonProperty > ResolveContractConverter(Type) Declaration protected override JsonConverter ResolveContractConverter(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Newtonsoft.Json.JsonConverter Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.DataMediaReceivedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.DataMediaReceivedEventArgs.html", + "title": "Class DataMediaReceivedEventArgs", + "keywords": "Class DataMediaReceivedEventArgs Reserved for the internal use. Inheritance Object EventArgs DataMediaReceivedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class DataMediaReceivedEventArgs : EventArgs Constructors DataMediaReceivedEventArgs() Declaration public DataMediaReceivedEventArgs() Properties Buffer Reserved for the internal use. Declaration public DataMediaBuffer Buffer { get; } Property Value Type Description DataMediaBuffer" }, - "common/Microsoft.Graph.Communications.Common.AutoClean.html": { - "href": "common/Microsoft.Graph.Communications.Common.AutoClean.html", - "title": "Class AutoClean", - "keywords": "Class AutoClean Helper class to automatically cleanup. Inheritance Object Disposable AutoClean AutoClean Implements IDisposable Inherited Members Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class AutoClean : Disposable, IDisposable Constructors AutoClean(Action) Initializes a new instance of the AutoClean class. Declaration public AutoClean(Action action) Parameters Type Name Description Action action Cleanup action. Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.AudioLowOnFramesEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioLowOnFramesEventArgs.html", + "title": "Class AudioLowOnFramesEventArgs", + "keywords": "Class AudioLowOnFramesEventArgs Audio low on frame event args Inheritance Object EventArgs LowOnFramesEventArgs AudioLowOnFramesEventArgs Inherited Members LowOnFramesEventArgs.MediaType LowOnFramesEventArgs.RemainingMediaLengthInMS EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioLowOnFramesEventArgs : LowOnFramesEventArgs Constructors AudioLowOnFramesEventArgs() Declaration public AudioLowOnFramesEventArgs()" }, - "common/Microsoft.Graph.Communications.Common.AutoClean-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.AutoClean-1.html", - "title": "Class AutoClean", - "keywords": "Class AutoClean Helper class to automatically cleanup but with associated state. Inheritance Object Disposable AutoClean AutoClean Implements IDisposable Inherited Members AutoClean.Dispose(Boolean) Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class AutoClean : AutoClean, IDisposable Type Parameters Name Description T State type. Constructors AutoClean(T, Action) Initializes a new instance of the AutoClean class. Declaration public AutoClean(T t, Action action) Parameters Type Name Description T t Instance of the custom data. Action action Cleanup action. Properties Data Gets the custom data. Declaration public T Data { get; } Property Value Type Description T Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "core/Microsoft.Graph.Communications.Core.GraphModelExtensions.html": { + "href": "core/Microsoft.Graph.Communications.Core.GraphModelExtensions.html", + "title": "Class GraphModelExtensions", + "keywords": "Class GraphModelExtensions Generic graph model extensions. Inheritance Object GraphModelExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class GraphModelExtensions Methods FixModel(Object) Fixes the model to match latest protocol. Declaration public static void FixModel(object object) Parameters Type Name Description Object object The object." }, - "client/Microsoft.Graph.Communications.Resources.IResource-2.html": { - "href": "client/Microsoft.Graph.Communications.Resources.IResource-2.html", - "title": "Interface IResource", - "keywords": "Interface IResource The stateful resource interface. Inherited Members IResource.Id IResource.ModifiedDateTime IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResource : IResource, IResourceBase, IDisposable where TSelf : IResource where TEntity : Entity Type Parameters Name Description TSelf The self type of the resource. TEntity The containing Entity type. Properties Resource Gets the resource. Declaration TEntity Resource { get; } Property Value Type Description TEntity Events OnUpdated Event fired when this resource has been updated. Declaration event ResourceEventHandler OnUpdated Event Type Type Description ResourceEventHandler See Also IResource" + "common/Microsoft.Graph.Communications.Common.Telemetry.ClientLogEventId.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.ClientLogEventId.html", + "title": "Enum ClientLogEventId", + "keywords": "Enum ClientLogEventId Event ids for client logs Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum ClientLogEventId Fields Name Description ClientHttpTrace The event id for client HTTP trace. ClientTrace The event id for client trace Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(ClientLogEventId, String, String) Validator.Equals(ClientLogEventId, String) Validator.NotEquals(ClientLogEventId, String, String)" }, - "client/Microsoft.Graph.Communications.Client.StateManager-2.html": { - "href": "client/Microsoft.Graph.Communications.Client.StateManager-2.html", - "title": "Class StateManager", - "keywords": "Class StateManager The state manager implementation. Inheritance Object StateManager Implements IStateManager ICollection IEnumerable IEnumerable IDisposable Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class StateManager : Disposable, IStateManager, ICollection, IEnumerable, IEnumerable, IDisposable where TResource : IResource where TEntity : Entity Type Parameters Name Description TResource The type of the resource. TEntity The type of the entity. Constructors StateManager(ISerializer, ICache) Initializes a new instance of the StateManager class. Declaration public StateManager(ISerializer serializer, ICache cache) Parameters Type Name Description ISerializer serializer The serializer. ICache cache The cache. Properties Count Declaration public int Count { get; } Property Value Type Description Int32 IsReadOnly Declaration public bool IsReadOnly { get; } Property Value Type Description Boolean Item[String] Declaration public TResource this[string id] { get; } Parameters Type Name Description String id Property Value Type Description TResource Methods Add(TResource) Adds an item to the ICollection . Declaration public void Add(TResource item) Parameters Type Name Description TResource item The object to add to the ICollection . Exceptions Type Condition ServiceException If the resource already exists in the collection. Clear() Declaration public void Clear() Contains(TResource) Declaration public bool Contains(TResource item) Parameters Type Name Description TResource item Returns Type Description Boolean CopyContent() Declaration public ICollection CopyContent() Returns Type Description ICollection CopyTo(TResource[], Int32) Declaration public void CopyTo(TResource[] array, int arrayIndex) Parameters Type Name Description TResource[] array Int32 arrayIndex Dispose(Boolean) Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing GetEnumerator() Declaration public IEnumerator GetEnumerator() Returns Type Description IEnumerator GetOrAdd(String, Func) Declaration public TResource GetOrAdd(string id, Func resourceFactory) Parameters Type Name Description String id Func resourceFactory Returns Type Description TResource GetOrAddAsync(String, Func>) Declaration public Task GetOrAddAsync(string id, Func> resourceFactory) Parameters Type Name Description String id Func < Task > resourceFactory Returns Type Description Task Remove(TResource) Removes the occurrence of a specific object from the IStateManager . Declaration public bool Remove(TResource item) Parameters Type Name Description TResource item The object to remove from the IStateManager . Returns Type Description Boolean true if item was successfully removed from the IStateManager . Exceptions Type Condition ServiceException If the resource does not exist in the collection. Remove(String) Removes the occurrence of a specific object from the IStateManager . Declaration public TResource Remove(string id) Parameters Type Name Description String id The identifier of the object to remove from the IStateManager . Returns Type Description TResource The IResource that was removed. Exceptions Type Condition ServiceException If the resource does not exist in the collection. TryRemove(String, out TResource) Declaration public bool TryRemove(string id, out TResource resource) Parameters Type Name Description String id TResource resource Returns Type Description Boolean Explicit Interface Implementations IEnumerable.GetEnumerator() Declaration IEnumerator IEnumerable.GetEnumerator() Returns Type Description IEnumerator Implements IStateManager System.Collections.Generic.ICollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable System.IDisposable See Also IStateManager " + "client/Microsoft.Graph.Communications.Client.Authentication.RequestValidationResult.html": { + "href": "client/Microsoft.Graph.Communications.Client.Authentication.RequestValidationResult.html", + "title": "Struct RequestValidationResult", + "keywords": "Struct RequestValidationResult The result of the request validation. Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() ValueType.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Graph.Communications.Client.Authentication Assembly : Microsoft.Graph.Communications.Client.dll Syntax public struct RequestValidationResult Fields IsValid Indicates whether the request is valid. Declaration public bool IsValid Field Value Type Description Boolean TenantId The tenant id for the incoming request. Declaration public string TenantId Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.HashingObfuscationConfiguration.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.HashingObfuscationConfiguration.html", - "title": "Class HashingObfuscationConfiguration", - "keywords": "Class HashingObfuscationConfiguration The hashing obfuscation configuration. This configurations is preconfigured to use the HashingObfuscationEngine and provides logic to automatically generate a salt which resets daily. Inheritance Object ObfuscationConfiguration HashingObfuscationConfiguration Inherited Members ObfuscationConfiguration.DefaultUriFilters ObfuscationConfiguration.DefaultContentTypeFilters ObfuscationConfiguration.DefaultContentDispositionFilters ObfuscationConfiguration.DefaultHeaderFilters ObfuscationConfiguration.ObfuscationEngine ObfuscationConfiguration.ObfuscationMembers ObfuscationConfiguration.ObfuscationSerializerSettings ObfuscationConfiguration.ContentDispositionFilters ObfuscationConfiguration.ContentTypeFilters ObfuscationConfiguration.HeaderFilters ObfuscationConfiguration.UriFilters Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class HashingObfuscationConfiguration : ObfuscationConfiguration Constructors HashingObfuscationConfiguration(IEnumerable, Boolean, ObfuscationMember[]) Initializes a new instance of the HashingObfuscationConfiguration class. Declaration public HashingObfuscationConfiguration(IEnumerable filters = null, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IEnumerable < BaseFilter > filters The filters. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . HashingObfuscationConfiguration(IEnumerable, IEnumerable, IEnumerable, Boolean, ObfuscationMember[]) Initializes a new instance of the HashingObfuscationConfiguration class. Declaration public HashingObfuscationConfiguration(IEnumerable headerFilters, IEnumerable contentDispositionFilters, IEnumerable contentTypeFilters, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IEnumerable < HeaderFilter > headerFilters The header filters. IEnumerable < ContentDispositionFilter > contentDispositionFilters The content disposition filters. IEnumerable < ContentTypeFilter > contentTypeFilters The content type filters. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) HttpObfuscationHelpers.LogHeaderText(ObfuscationConfiguration, IEnumerable>>) HttpObfuscationHelpers.LogHeaderText(ObfuscationConfiguration, String, IEnumerable) See Also ObfuscationConfiguration" + "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformHealthStatus.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformHealthStatus.html", + "title": "Enum MediaPlatformHealthStatus", + "keywords": "Enum MediaPlatformHealthStatus Health status of the media platform Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaPlatformHealthStatus Fields Name Description HeavilyLoaded The media platform is under heavy load and the application should avoid allowing the current call volume to increase Normal The media platform is operating normally Overloaded The media platform is overloaded and new calls may be rejected" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.GraphObfuscationContractResolver.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.GraphObfuscationContractResolver.html", - "title": "Class GraphObfuscationContractResolver", - "keywords": "Class GraphObfuscationContractResolver Newtonsoft JSON resolver that uses Graph Obfuscation attribute to serialize data for logging purposes. Inheritance Object ODataResolver GraphObfuscationContractResolver Inherited Members ODataResolver.ResolveContractConverter(Type) ODataResolver.CreateProperties(Type, MemberSerialization) Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphObfuscationContractResolver : ODataResolver Constructors GraphObfuscationContractResolver(IObfuscationEngine, Boolean, ObfuscationMember[]) Initializes a new instance of the GraphObfuscationContractResolver class. Declaration public GraphObfuscationContractResolver(IObfuscationEngine engine, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IObfuscationEngine engine The obfuscation engine. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified this GraphObfuscationContractResolver will cache the members and check the cache for the ObfuscationTag . Methods CreateMemberValueProvider(MemberInfo) Declaration protected override IValueProvider CreateMemberValueProvider(MemberInfo member) Parameters Type Name Description MemberInfo member Returns Type Description Newtonsoft.Json.Serialization.IValueProvider ResolveContract(Type) Declaration public override JsonContract ResolveContract(Type type) Parameters Type Name Description Type type Returns Type Description Newtonsoft.Json.Serialization.JsonContract Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.IAudioSocket.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.IAudioSocket.html", + "title": "Interface IAudioSocket", + "keywords": "Interface IAudioSocket Interface to an AudioSocket. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IAudioSocket : IDisposable Methods GetQualityOfExperienceData() Get the Quality of Experience (QoE) data for the audio socket. Declaration AudioQualityOfExperienceData GetQualityOfExperienceData() Returns Type Description AudioQualityOfExperienceData Remarks The bot should fetch the QoE data no more than once every 30 seconds. To get accurate metrics, the bot should let media flow for at least 30 seconds before fetching the QoE data. Send(AudioMediaBuffer) Sends a frame of audio media, where a frame contains 20 milliseconds of audio content (PCM samples). Declaration void Send(AudioMediaBuffer buffer) Parameters Type Name Description AudioMediaBuffer buffer AudioMediaBuffer containing the frame of audio media to send. Remarks The application must create a concrete class which derives from the AudioMediaBuffer abstract class. The buffer object passed to the Send method is still potentially in-use after the method returns to the caller. The application must not free the buffer's frame data until the the buffer object's Dispose() method is invoked by the Media Platform. The application should be sending 50 frames of audio media per second with each frame containing 20 milliseconds of audio content. The AudioSocket must be enabled to send media via the AudioSocketSettings.StreamDirections property. SendDtmfTone(ToneId) Sends a DTMF tone. Declaration void SendDtmfTone(ToneId tone) Parameters Type Name Description ToneId tone The DTMF digit. Ranges from 0-16. Remarks Sending DTMF tone is only allowed if the AudioSocket is configured for sending media. SendDtmfTones(IEnumerable, Int32) Sends a sequence of DTMF tones with an optional delay between each tone. Declaration void SendDtmfTones(IEnumerable tones, int delayBetweenTonesInMilliseconds = -1) Parameters Type Name Description IEnumerable < ToneId > tones The list of DTMF digits to be sent. Ranges from 0-16. Int32 delayBetweenTonesInMilliseconds Delay (in milliseconds) between each DTMF tone sent. Remarks By default, the delay is set to -1 which picks a random time between 0 to 500 milliseconds. Events AudioMediaReceived If the application has configured the AudioSocket to receive media, this event is raised each time a frame of audio media is received, where a frame contains 20 milliseconds of audio content (PCM samples). Once the application has consumed the buffer, it must call the buffer's Dispose() method. Declaration event EventHandler AudioMediaReceived Event Type Type Description EventHandler < AudioMediaReceivedEventArgs > Remarks The application must be able to handle at least 50 incoming audio buffers per second. Events are serialized, so only one event at a time is raised to the app. The event handler should return as quickly as possible; any time-consuming per-frame processing should be performed asynchronously from the event handler. AudioSendStatusChanged If the application has configured the AudioSocket to send media, this event is raised to inform the application when it may begin sending media and when it should stop. The application cannot send media before receiving a MediaSendStatusChanged event indicating the SendStatus is Started. Declaration event EventHandler AudioSendStatusChanged Event Type Type Description EventHandler < AudioSendStatusChangedEventArgs > DominantSpeakerChanged This event is raised when there is a change in the dominant speaker in the conference. If there is no dominant speaker in the conference, the CurrentDominantSpeaker argument in the event will have the value None (0xFFFFFFFF). Declaration event EventHandler DominantSpeakerChanged Event Type Type Description EventHandler < DominantSpeakerChangedEventArgs > MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > ToneReceived This event is raised when the DTMF tone is received. ToneId enum in the event arguments indicates the tone value. Declaration event EventHandler ToneReceived Event Type Type Description EventHandler < ToneReceivedEventArgs >" }, - "common/Microsoft.Graph.Communications.Common.OData.ODataJsonConverter.html": { - "href": "common/Microsoft.Graph.Communications.Common.OData.ODataJsonConverter.html", - "title": "Class ODataJsonConverter", - "keywords": "Class ODataJsonConverter Handles resolving interfaces to the correct derived class during serialization/deserialization. Inheritance Object ODataJsonConverter Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class ODataJsonConverter : JsonConverter Constructors ODataJsonConverter(Assembly[]) Initializes a new instance of the ODataJsonConverter class. Declaration public ODataJsonConverter(params Assembly[] typeAssemblies) Parameters Type Name Description Assembly [] typeAssemblies The type assemblies. Properties CanWrite Declaration public override bool CanWrite { get; } Property Value Type Description Boolean Methods CanConvert(Type) Declaration public override bool CanConvert(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Boolean ReadJson(JsonReader, Type, Object, JsonSerializer) Deserializes the object to the correct type. Declaration public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonReader reader The Newtonsoft.Json.JsonReader to read from. Type objectType The interface type. Object existingValue The existing value of the object being read. Newtonsoft.Json.JsonSerializer serializer The Newtonsoft.Json.JsonSerializer for deserialization. Returns Type Description Object The deserialized object WriteJson(JsonWriter, Object, JsonSerializer) Declaration public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonWriter writer Object value Newtonsoft.Json.JsonSerializer serializer Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.DataMediaBuffer.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.DataMediaBuffer.html", + "title": "Class DataMediaBuffer", + "keywords": "Class DataMediaBuffer Reserved for the internal use. Inheritance Object DataMediaBuffer Implements IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public abstract class DataMediaBuffer : IDisposable Constructors DataMediaBuffer() Declaration protected DataMediaBuffer() Properties Data Reserved for the internal use. Declaration public byte[] Data { get; protected set; } Property Value Type Description Byte [] MediaSourceId Reserved for the internal use. Declaration public uint MediaSourceId { get; protected set; } Property Value Type Description UInt32 Methods Dispose() Reserved for the internal use. Declaration public void Dispose() Dispose(Boolean) Reserved for the internal use. Declaration protected abstract void Dispose(bool disposing) Parameters Type Name Description Boolean disposing Implements System.IDisposable" }, - "common/Microsoft.Graph.Communications.Common.Exceptions.RoutingException.html": { - "href": "common/Microsoft.Graph.Communications.Common.Exceptions.RoutingException.html", - "title": "Class RoutingException", - "keywords": "Class RoutingException Generic routing exception Inheritance Object Exception RoutingException RoutingBadRequestException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Exceptions Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class RoutingException : Exception, ISerializable, _Exception Constructors RoutingException(String) Initializes a new instance of the RoutingException class. Declaration public RoutingException(string message) Parameters Type Name Description String message message RoutingException(String, Exception) Initializes a new instance of the RoutingException class. Declaration public RoutingException(string message, Exception innerException) Parameters Type Name Description String message message Exception innerException inner exception Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.AudioSettings.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioSettings.html", + "title": "Class AudioSettings", + "keywords": "Class AudioSettings Audio frame player settings Inheritance Object AudioSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioSettings Constructors AudioSettings(UInt32) Default constructor Declaration public AudioSettings(uint buffersizeInMs) Parameters Type Name Description UInt32 buffersizeInMs Properties BufferSizeInMs Audio buffer length in ms Declaration public uint BufferSizeInMs { get; set; } Property Value Type Description UInt32" }, - "common/Microsoft.Graph.Communications.Common.Exceptions.RoutingBadRequestException.html": { - "href": "common/Microsoft.Graph.Communications.Common.Exceptions.RoutingBadRequestException.html", - "title": "Class RoutingBadRequestException", - "keywords": "Class RoutingBadRequestException Indicate there's a bad request Inheritance Object Exception RoutingException RoutingBadRequestException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Exceptions Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class RoutingBadRequestException : RoutingException, ISerializable, _Exception Constructors RoutingBadRequestException(String) Initializes a new instance of the RoutingBadRequestException class. Declaration public RoutingBadRequestException(string message) Parameters Type Name Description String message message RoutingBadRequestException(String, Exception) Initializes a new instance of the RoutingBadRequestException class. Declaration public RoutingBadRequestException(string message, Exception innerException) Parameters Type Name Description String message message Exception innerException inner exception Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.Telemetry.LogEvent.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LogEvent.html", + "title": "Class LogEvent", + "keywords": "Class LogEvent Log data Inheritance Object LogEvent Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class LogEvent Constructors LogEvent() Declaration public LogEvent() Properties CallerInfo Gets or sets the caller information Declaration public CallerInfo CallerInfo { get; set; } Property Value Type Description CallerInfo CallerInfoString Gets the caller information string. Declaration public string CallerInfoString { get; } Property Value Type Description String Component Gets or sets the component in which the log is created. Declaration public string Component { get; set; } Property Value Type Description String CorrelationId Gets or sets the correlation id Declaration public Guid CorrelationId { get; set; } Property Value Type Description Guid EventType Gets or sets the type of the event. Declaration public LogEventType EventType { get; set; } Property Value Type Description LogEventType Level Gets or sets the trace level of the event. Declaration public TraceLevel Level { get; set; } Property Value Type Description TraceLevel LogicalThreadId Gets or sets the logical thread identifier. Declaration public uint LogicalThreadId { get; set; } Property Value Type Description UInt32 ManagedThreadId Gets or sets the thread ID. Declaration public int ManagedThreadId { get; set; } Property Value Type Description Int32 Message Gets or sets the Description of the event. Declaration public string Message { get; set; } Property Value Type Description String ProcessId Gets or sets the process ID. Declaration public int ProcessId { get; set; } Property Value Type Description Int32 Properties Gets or sets the Custom properties for the event. Declaration public IReadOnlyDictionary Properties { get; set; } Property Value Type Description IReadOnlyDictionary < Type , Object > PropertiesString Gets the custom properties in string format. Declaration public string PropertiesString { get; } Property Value Type Description String RequestId Gets or sets the request identifier. Declaration public Guid RequestId { get; set; } Property Value Type Description Guid Timestamp Gets or sets the Timestamp of the event. Declaration public DateTime Timestamp { get; set; } Property Value Type Description DateTime Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) LoggingExtensions.GetTypedProperties(LogEvent, Type) LoggingExtensions.GetTypedProperty(LogEvent)" }, - "common/Microsoft.Graph.Communications.Common.SlimLock.html": { - "href": "common/Microsoft.Graph.Communications.Common.SlimLock.html", - "title": "Class SlimLock", - "keywords": "Class SlimLock A SemaphoreSlim based lock implementation Inheritance Object Disposable SlimLock Implements IDisposable Inherited Members Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class SlimLock : Disposable, IDisposable Constructors SlimLock() Declaration public SlimLock() Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) Lock() Acquire a disposable lock Declaration public IDisposable Lock() Returns Type Description IDisposable Disposable cleanup to release semaphore. LockAsync() Acquire a disposable lock Declaration public Task LockAsync() Returns Type Description Task < IDisposable > Disposable cleanup to release semaphore. Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.StateMachine-1.Transition.html": { + "href": "common/Microsoft.Graph.Communications.Common.StateMachine-1.Transition.html", + "title": "Class StateMachine.Transition", + "keywords": "Class StateMachine.Transition Single transition from Source to Targets Inheritance Object StateMachine.Transition Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class Transition Constructors Transition(TStateEnum, TStateEnum[]) Initializes a new instance of the StateMachine.Transition class. Declaration public Transition(TStateEnum source, params TStateEnum[] targets) Parameters Type Name Description TStateEnum source The source. TStateEnum[] targets The targets. Properties Source Gets the source state. Declaration public TStateEnum Source { get; } Property Value Type Description TStateEnum The source. Targets Gets the target states. Declaration public TStateEnum[] Targets { get; } Property Value Type Description TStateEnum[] The targets. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.CollectionUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.CollectionUtils.html", - "title": "Class CollectionUtils", - "keywords": "Class CollectionUtils Collection Utilities Inheritance Object CollectionUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class CollectionUtils Methods AddRange(ICollection, IEnumerable) Adds the range of source values into target. Declaration public static void AddRange(this ICollection target, IEnumerable source) Parameters Type Name Description ICollection target The target. IEnumerable source The source. Type Parameters Name Description T The type of Collection ForEach(IEnumerable, Action) Analogous to IList.ForEach but for IEnumerable Declaration public static void ForEach(this IEnumerable enumerable, Action action) Parameters Type Name Description IEnumerable enumerable Enumeration Action action Action to invoke on each element Type Parameters Name Description T Element type. ForEachParallel(IEnumerable, Action, IGraphLogger) Analogous to IList.ForEach but for IEnumerable Declaration public static Exception ForEachParallel(this IEnumerable enumerable, Action action, IGraphLogger logger) Parameters Type Name Description IEnumerable enumerable Enumeration Action action Action to invoke on each element IGraphLogger logger Instance of the Logger Returns Type Description Exception Exception if any. Type Parameters Name Description T Element type GetValueOrDefault(IDictionary, TKey) Get Value or default Declaration public static TValue GetValueOrDefault(this IDictionary dictionary, TKey key) Parameters Type Name Description IDictionary dictionary Dictionary instance TKey key Key to lookup Returns Type Description TValue Value from dictionary or default value. Type Parameters Name Description TKey Type of the key TValue Type of the value GetValueOrDefault(IDictionary, TKey, TValue) Get Value or default Declaration public static TValue GetValueOrDefault(this IDictionary dictionary, TKey key, TValue defaultValue) Parameters Type Name Description IDictionary dictionary Dictionary instance TKey key Key to lookup TValue defaultValue The default value to be returned if it doesn't exist. Returns Type Description TValue Value from dictionary or default value. Type Parameters Name Description TKey Type of the key TValue Type of the value ToSortedList(IEnumerable, Func) Converts sequence to a sorted list. Declaration public static SortedList ToSortedList(this IEnumerable sequence, Func keySelector) Parameters Type Name Description IEnumerable sequence The sequence. Func keySelector The function selector which provides a key given the value. Returns Type Description SortedList Sorted list. Type Parameters Name Description TKey The type of the key. TValue The type of the value. TryRemoveAndDispose(ConcurrentDictionary, TKey) Try to remove key from concurrent dictionary and dispose the value. Declaration public static void TryRemoveAndDispose(this ConcurrentDictionary dictionary, TKey key) where TValue : IDisposable Parameters Type Name Description ConcurrentDictionary dictionary Dictionary to clean up TKey key Key to lookup Type Parameters Name Description TKey Key type TValue Value type" + "common/Microsoft.Graph.Communications.Common.SecureStringUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.SecureStringUtils.html", + "title": "Class SecureStringUtils", + "keywords": "Class SecureStringUtils SecureString Utilities Inheritance Object SecureStringUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class SecureStringUtils Methods ConvertToUnsecureString(SecureString) Converts a SecureString into a managed string for consumption Declaration public static string ConvertToUnsecureString(this SecureString secureString) Parameters Type Name Description SecureString secureString The SecureString to convert into a managed string Returns Type Description String String representation of the SecureString" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClient.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClient.html", - "title": "Class GraphHttpClient", - "keywords": "Class GraphHttpClient Graph client that handles transport over http. Inheritance Object ObjectRoot GraphHttpClient Implements IGraphHttpClient IGraphClient Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphHttpClient : ObjectRoot, IGraphHttpClient, IGraphClient Constructors GraphHttpClient(IGraphLogger, JsonSerializerSettings, HttpClient, Int32, String, ProductInfoHeaderValue, IEnumerable, String) Initializes a new instance of the GraphHttpClient class. Declaration public GraphHttpClient(IGraphLogger logger, JsonSerializerSettings jsonSerializerSettings = null, HttpClient httpClient = null, int numberOfRetries = 3, string correlationIdHeader = null, ProductInfoHeaderValue userAgent = null, IEnumerable defaultProperties = null, string metricName = \"PartnerHttpRequests\") Parameters Type Name Description IGraphLogger logger The logger. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. HttpClient httpClient The HTTP client. Int32 numberOfRetries The number of retries. String correlationIdHeader The correlation identifier header. ProductInfoHeaderValue userAgent The user agent. IEnumerable < IGraphProperty > defaultProperties The default properties. String metricName The metric name. Properties CustomRedirectUriGenerator Gets or sets the custom redirect URI generator. This is called in case of a redirect (3XX) response from the request. Clients can use this to read the response and give the new redirect url to call in the next request. Declaration public Func CustomRedirectUriGenerator { get; set; } Property Value Type Description Func < HttpResponseMessage , Uri > The custom redirect URI generator. DefaultProperties Gets the default properties. Declaration public IEnumerable DefaultProperties { get; } Property Value Type Description IEnumerable < IGraphProperty > GraphLogger Gets the graph logger. Declaration public IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger SerializerSettings Gets the serializer settings. Declaration public JsonSerializerSettings SerializerSettings { get; } Property Value Type Description Newtonsoft.Json.JsonSerializerSettings Methods Clone(HttpClient) Clones this instance with optional overrides. Declaration public IGraphHttpClient Clone(HttpClient httpClient = null) Parameters Type Name Description HttpClient httpClient The HTTP client to replace the original. Returns Type Description IGraphHttpClient Cloned client with the updated properties. InitializeServicePointSettings() Initializes global service point settings. Declaration public static void InitializeServicePointSettings() LogRequest(TraceLevel, HttpRequestMessage, Object, String, String, Int32) Logs the request message. Declaration protected void LogRequest(TraceLevel level, HttpRequestMessage httpRequest, object content = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The level. HttpRequestMessage httpRequest The http request to log. Object content The response time. String memberName Name of the member. String filePath The file path. Int32 lineNumber The line number. LogResponse(TraceLevel, HttpRequestMessage, Int64, HttpResponseMessage, Object, Exception, String, String, Int32) Logs the response message. Declaration protected void LogResponse(TraceLevel level, HttpRequestMessage httpRequest, long responseTime, HttpResponseMessage httpResponse = null, object content = null, Exception exception = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description TraceLevel level The level. HttpRequestMessage httpRequest The http request to log. Int64 responseTime The response time. HttpResponseMessage httpResponse The http response to log. Object content The content to log. Exception exception The exception to log. String memberName Name of the member. String filePath The file path. Int32 lineNumber The line number. SendAsync(IGraphRequest, CancellationToken) Declaration public Task SendAsync(IGraphRequest graphRequest, CancellationToken cancellationToken = default(CancellationToken)) where T : class Parameters Type Name Description IGraphRequest graphRequest CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T SendAsync(IGraphRequest, CancellationToken) Declaration public Task> SendAsync(IGraphRequest graphRequest, CancellationToken cancellationToken = default(CancellationToken)) where T1 : class where T2 : class Parameters Type Name Description IGraphRequest graphRequest CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T1 T2 SendHttpRequestAsync(IGraphRequest, CancellationToken) Sends the request asynchronously. We only retry if the Http request fails with an exception. We do not retry in case of error response returned from the request. Declaration protected virtual Task> SendHttpRequestAsync(IGraphRequest graphRequest, CancellationToken cancellationToken) where T1 : class where T2 : class Parameters Type Name Description IGraphRequest graphRequest The request to be sent out. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IGraphResponse > HttpResponseMessage received for the graphRequest . Type Parameters Name Description T1 Type of the content present in the request. T2 Type of the expected content in response. SendRawHttpRequestAsync(HttpRequestMessage, CancellationToken) Send a Http request as an asynchronous operation. The content sent using this is not parsed or logged. Declaration public Task SendRawHttpRequestAsync(HttpRequestMessage httpRequest, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description HttpRequestMessage httpRequest The http request message to send. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < HttpResponseMessage > The task object representing the asynchronous operation. Implements IGraphHttpClient IGraphClient Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also IGraphHttpClient" + "common/Microsoft.Graph.Communications.Common.JsonUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.JsonUtils.html", + "title": "Class JsonUtils", + "keywords": "Class JsonUtils Json Utils Inheritance Object JsonUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class JsonUtils Fields JsonContentType Json content type Declaration public const string JsonContentType = \"application/json\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.GraphObfuscationAttribute.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.GraphObfuscationAttribute.html", - "title": "Class GraphObfuscationAttribute", - "keywords": "Class GraphObfuscationAttribute Attribute used for decoration of data objects. This is used for obfuscation for logging. Inheritance Object Attribute GraphObfuscationAttribute Implements _Attribute Inherited Members Attribute.GetCustomAttributes(MemberInfo, Type) Attribute.GetCustomAttributes(MemberInfo, Type, Boolean) Attribute.GetCustomAttributes(MemberInfo) Attribute.GetCustomAttributes(MemberInfo, Boolean) Attribute.IsDefined(MemberInfo, Type) Attribute.IsDefined(MemberInfo, Type, Boolean) Attribute.GetCustomAttribute(MemberInfo, Type) Attribute.GetCustomAttribute(MemberInfo, Type, Boolean) Attribute.GetCustomAttributes(ParameterInfo) Attribute.GetCustomAttributes(ParameterInfo, Type) Attribute.GetCustomAttributes(ParameterInfo, Type, Boolean) Attribute.GetCustomAttributes(ParameterInfo, Boolean) Attribute.IsDefined(ParameterInfo, Type) Attribute.IsDefined(ParameterInfo, Type, Boolean) Attribute.GetCustomAttribute(ParameterInfo, Type) Attribute.GetCustomAttribute(ParameterInfo, Type, Boolean) Attribute.GetCustomAttributes(Module, Type) Attribute.GetCustomAttributes(Module) Attribute.GetCustomAttributes(Module, Boolean) Attribute.GetCustomAttributes(Module, Type, Boolean) Attribute.IsDefined(Module, Type) Attribute.IsDefined(Module, Type, Boolean) Attribute.GetCustomAttribute(Module, Type) Attribute.GetCustomAttribute(Module, Type, Boolean) Attribute.GetCustomAttributes(Assembly, Type) Attribute.GetCustomAttributes(Assembly, Type, Boolean) Attribute.GetCustomAttributes(Assembly) Attribute.GetCustomAttributes(Assembly, Boolean) Attribute.IsDefined(Assembly, Type) Attribute.IsDefined(Assembly, Type, Boolean) Attribute.GetCustomAttribute(Assembly, Type) Attribute.GetCustomAttribute(Assembly, Type, Boolean) Attribute.Equals(Object) Attribute.GetHashCode() Attribute.Match(Object) Attribute.IsDefaultAttribute() Attribute._Attribute.GetTypeInfoCount(UInt32) Attribute._Attribute.GetTypeInfo(UInt32, UInt32, IntPtr) Attribute._Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr) Attribute._Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr) Attribute.TypeId Object.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax [AttributeUsage(AttributeTargets.Class | AttributeTargets.Enum | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)] public class GraphObfuscationAttribute : Attribute, _Attribute Constructors GraphObfuscationAttribute() Declaration public GraphObfuscationAttribute() Properties Tag Gets or sets the tag. Declaration public ObfuscationTag Tag { get; set; } Property Value Type Description ObfuscationTag Implements System.Runtime.InteropServices._Attribute Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also Attribute" + "common/Microsoft.Graph.Communications.Common.HttpConstants.html": { + "href": "common/Microsoft.Graph.Communications.Common.HttpConstants.html", + "title": "Class HttpConstants", + "keywords": "Class HttpConstants The constant values for http. Inheritance Object HttpConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpConstants Fields GraphV1Prefixes Expected values of x-ms-gateway-serviceRoot header in the requests coming in to PMA from GraphV1 endpoints Declaration public static readonly IEnumerable GraphV1Prefixes Field Value Type Description IEnumerable < String >" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.ClientEtwLogger.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.ClientEtwLogger.html", - "title": "Class ClientEtwLogger", - "keywords": "Class ClientEtwLogger Logger for client that publishes to ETW. Inheritance Object EventSource ClientEtwLogger Implements IDisposable Inherited Members EventSource.IsEnabled() EventSource.IsEnabled(EventLevel, EventKeywords) EventSource.IsEnabled(EventLevel, EventKeywords, EventChannel) EventSource.GetGuid(Type) EventSource.GetName(Type) EventSource.GenerateManifest(Type, String) EventSource.GenerateManifest(Type, String, EventManifestOptions) EventSource.GetSources() EventSource.SendCommand(EventSource, EventCommand, IDictionary) EventSource.SetCurrentThreadActivityId(Guid) EventSource.SetCurrentThreadActivityId(Guid, Guid) EventSource.GetTrait(String) EventSource.ToString() EventSource.OnEventCommand(EventCommandEventArgs) EventSource.WriteEvent(Int32) EventSource.WriteEvent(Int32, Int32) EventSource.WriteEvent(Int32, Int32, Int32) EventSource.WriteEvent(Int32, Int32, Int32, Int32) EventSource.WriteEvent(Int32, Int64) EventSource.WriteEvent(Int32, Int64, Int64) EventSource.WriteEvent(Int32, Int64, Int64, Int64) EventSource.WriteEvent(Int32, String) EventSource.WriteEvent(Int32, String, String) EventSource.WriteEvent(Int32, String, String, String) EventSource.WriteEvent(Int32, String, Int32) EventSource.WriteEvent(Int32, String, Int32, Int32) EventSource.WriteEvent(Int32, String, Int64) EventSource.WriteEvent(Int32, Int64, String) EventSource.WriteEvent(Int32, Int32, String) EventSource.WriteEvent(Int32, Byte[]) EventSource.WriteEvent(Int32, Int64, Byte[]) EventSource.WriteEventCore(Int32, Int32, EventSource.EventData*) EventSource.WriteEventWithRelatedActivityIdCore(Int32, Guid*, Int32, EventSource.EventData*) EventSource.WriteEvent(Int32, Object[]) EventSource.WriteEventWithRelatedActivityId(Int32, Guid, Object[]) EventSource.Dispose() EventSource.Dispose(Boolean) EventSource.Write(String) EventSource.Write(String, EventSourceOptions) EventSource.Write(String, T) EventSource.Write(String, EventSourceOptions, T) EventSource.Write(String, EventSourceOptions, T) EventSource.Write(String, EventSourceOptions, Guid, Guid, T) EventSource.Name EventSource.Guid EventSource.Settings EventSource.CurrentThreadActivityId EventSource.ConstructionException EventSource.EventCommandExecuted Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax [EventSource(Name = \"Microsoft-Graph-Telemetry-Client\")] public class ClientEtwLogger : EventSource, IDisposable Constructors ClientEtwLogger(IGraphLogger) Initializes a new instance of the ClientEtwLogger class. Declaration public ClientEtwLogger(IGraphLogger logger) Parameters Type Name Description IGraphLogger logger The logger. Methods HttpTrace(Guid, String, String, String, String, String, String, String, Int32, String, String, String, String, String, String) Trace for client's http calls. Declaration [Event(100, Level = EventLevel.Informational, Message = \"{5}\")] public void HttpTrace(Guid correlationId, string component, string traceLevel, string url, string transactionDirection, string message, string appName, string appId, int mtid, string callingLine, string traceType, string headers, string method, string responseCode, string responseTime) Parameters Type Name Description Guid correlationId The correlation identifier. String component The component. String traceLevel The trace level. String url The URL for the request. String transactionDirection The direction of the request this request/response corresponds to. String message The body for the request/response. String appName Name of the application. String appId The application identifier. Int32 mtid The managed tid. String callingLine The line in which log is produced. String traceType Denote whether this is request/response. String headers The headers. String method The method for the request. String responseCode The response code from response. String responseTime Time taken to process the request. Trace(Guid, String, String, String, String, String, Int32, String) Trace for client's normal trace calls. Declaration [Event(101, Level = EventLevel.Informational, Message = \"{3}\")] public void Trace(Guid correlationId, string component, string traceLevel, string message, string appName, string appId, int mtid, string callingLine) Parameters Type Name Description Guid correlationId The correlation identifier. String component The component. String traceLevel The trace level. String message The message. String appName Name of the application. String appId The application identifier. Int32 mtid The managed tid. String callingLine The line in which log is produced. Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "client/Microsoft.Graph.Communications.Client.Authentication.IRequestAuthenticationProvider.html": { + "href": "client/Microsoft.Graph.Communications.Client.Authentication.IRequestAuthenticationProvider.html", + "title": "Interface IRequestAuthenticationProvider", + "keywords": "Interface IRequestAuthenticationProvider The authentication provider interface. This is used to authenticate Inbound requests from Microsoft Graph. It validates the request was issued by Microsoft Graph. Outbound requests to Microsoft Graph. Tenant token is acquired to provide Microsoft Graph the permissions the bot has been consented by the tenant admin Namespace : Microsoft.Graph.Communications.Client.Authentication Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IRequestAuthenticationProvider Methods AuthenticateOutboundRequestAsync(HttpRequestMessage, String) Authenticates the specified request message. This method will be called any time there is an outbound request. This method should add any required headers for authentication (eg: Authorization). Declaration Task AuthenticateOutboundRequestAsync(HttpRequestMessage request, string tenant) Parameters Type Name Description HttpRequestMessage request The outbound http request object. String tenant The tenant for which this request belongs to. Returns Type Description Task The Task . SDK awaits on this task to make sure the bot has included the required headers. ValidateInboundRequestAsync(HttpRequestMessage) Validates the inbound request. This method will be called any time we have an incoming request. Returning IsValid false will result in a Forbidden response being created. SDK waits until a successful validation is returned along with tenant data in RequestValidationResult to fire any events. Declaration Task ValidateInboundRequestAsync(HttpRequestMessage request) Parameters Type Name Description HttpRequestMessage request The incoming request. Returns Type Description Task < RequestValidationResult > The RequestValidationResult structure." }, - "client/Microsoft.Graph.Communications.Client.IStateManager-1.html": { - "href": "client/Microsoft.Graph.Communications.Client.IStateManager-1.html", - "title": "Interface IStateManager", - "keywords": "Interface IStateManager The state manager interface. This object is responsible for storing the resources in memory. Inherited Members ICollection.Add(TResource) ICollection.Clear() ICollection.Contains(TResource) ICollection.CopyTo(TResource[], Int32) ICollection.Remove(TResource) ICollection.Count ICollection.IsReadOnly IEnumerable.GetEnumerator() IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IStateManager : ICollection, IEnumerable, IEnumerable, IDisposable where TResource : IResource Type Parameters Name Description TResource The type of the resource. Properties Item[String] Gets the IResource with the specified identifier. Declaration TResource this[string id] { get; } Parameters Type Name Description String id The identifier. Property Value Type Description TResource The IResource . Methods CopyContent() Copies the content contained by this instance. Declaration ICollection CopyContent() Returns Type Description ICollection The copied ICollection GetOrAdd(String, Func) Gets the resource with the specified id if it exists in the collection, otherwise executes the resource factory to create the resource. State manager does not guarantee that the resource factory is executed only once, so operations must be idempotent (I.E. GET, PUT, etc...). Declaration TResource GetOrAdd(string id, Func resourceFactory) Parameters Type Name Description String id The identifier. Func resourceFactory The resource factory. Returns Type Description TResource The IResource that was found or created. GetOrAddAsync(String, Func>) Gets the resource with the specified id if it exists in the collection, otherwise executes the resource factory to create the resource. State manager does not guarantee that the resource factory is executed only once, so operations must be idempotent (I.E. GET, PUT, etc...). This method supports asynchronously creating the resource. Declaration Task GetOrAddAsync(string id, Func> resourceFactory) Parameters Type Name Description String id The identifier. Func < Task > resourceFactory The resource factory. Returns Type Description Task The IResource that was found or created. Remove(String) Removes the resource with the specified id from the state manager. Declaration TResource Remove(string id) Parameters Type Name Description String id The identifier. Returns Type Description TResource The IResource that was removed. TryRemove(String, out TResource) Tries to remove the resource with the specified id. Declaration bool TryRemove(string id, out TResource resource) Parameters Type Name Description String id The identifier. TResource resource The resource. Returns Type Description Boolean true if the IResource was removed, false otherwise." + "bot_media/Microsoft.Skype.Bots.Media.VideoSocket.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSocket.html", + "title": "Class VideoSocket", + "keywords": "Class VideoSocket Provides Send and Receive I/O access to a video stream. Inheritance Object VideoSocket Implements IVideoSocket IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public sealed class VideoSocket : IVideoSocket, IDisposable, IInternalVideoSocket, IInternalSocket Constructors VideoSocket(VideoSocketSettings) Initializes a new VideoSocket object. Declaration public VideoSocket(VideoSocketSettings settings) Parameters Type Name Description VideoSocketSettings settings Configuration settings for the VideoSocket Properties MediaType MediaType of the video socket. This could be Video or Vbss. The MediaType is set after the socket is passed to the CreateMediaConfiguration API. It may also be set via the VideoSocketSettings during socket creation. Declaration public MediaType MediaType { get; } Property Value Type Description MediaType ReceiveColorFormat VideoColorFormat to receive Declaration public VideoColorFormat ReceiveColorFormat { get; } Property Value Type Description VideoColorFormat SocketId The 0-based ID of the socket. This socket ID is useful to identify a socket in a multiview (ie. more than 1 video socket) call. The same ID is used in the event args of the VideoMediaReceived and VideoSendStatusChanged events that this class may raise. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the CreateMediaConfiguration API. Eg., if the collection of IVideoSocket objects in the CreateMediaConfiguration API contains {socketA, socketB, socketC}, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Before the call to CreateMediaConfiguration, the SocketId has a value of -1. Declaration public int SocketId { get; } Property Value Type Description Int32 Methods Dispose() Disposes the object. Declaration public void Dispose() GetQualityOfExperienceData() Get the Quality of Experience (QoE) data for the audio socket. Declaration public VideoQualityOfExperienceData GetQualityOfExperienceData() Returns Type Description VideoQualityOfExperienceData Remarks The bot should fetch the QoE data no more than once every 30 seconds. To get accurate metrics, the bot should let media flow for at least 30 seconds before fetching the QoE data. RequestKeyFrame() Allows the application to request for key frame. Only valid for sockets with the ReceiveColorFormat as H264 Declaration public void RequestKeyFrame() Send(VideoMediaBuffer) Sends a frame of video media. Declaration public void Send(VideoMediaBuffer buffer) Parameters Type Name Description VideoMediaBuffer buffer VideoMediaBuffer containing the frame of video media to send. Remarks The application must create a concrete class which derives from the VideoMediaBuffer abstract class. The buffer object passed to the Send method is still potentially in-use after the method returns to the caller. The application must not free the buffer's data until the the buffer object's Dispose() method is invoked by the Media Platform. The application should be sending up to 30 video frames per second. The VideoSocket must be enabled to send media via the VideoSocketSettings.StreamDirections property. SetReceiveBandwidthLimit(UInt32) Sets the bandwidth limit on the receive stream of the VideoSocket. This is only supported if the socket supports receiving H264 video format. It is recommended to wait for the VideoReceiveStatusChanged event with MediaReceiveStatus Active state during the initial call setup before applying the receive bandwidth limit on the socket. Bandwidth range (in bits per second) for various resolutions and frame rates per media type: Media type: Video 1000000 - 4000000 1080p at 30 fps 550000 - 2500000 720p at 30 fps 375000 - 1500000 540p at 30 fps 200000 - 800000 360p at 30 fps 150000 - 250000 360p at 15 fps 120000 - 220000 240p at 15 fps 60000 - 200000 180p at 15 fps 20000 - 100000 180p at 7.5 fps 10000 - 25000 180p at 3.75 fps 1000 - 12500 180p at 1.875 fps Media type: Vbss Resolution: 1080p 2000000 - 4000000 at 30 fps 600000 - 3000000 at 15 fps 300000 - 700000 at 7.5 fps 150000 - 350000 at 3.75 fps 70000 - 200000 at 1.875 fps Declaration public void SetReceiveBandwidthLimit(uint bitsPerSecond) Parameters Type Name Description UInt32 bitsPerSecond The receive bitrate SetSendBandwidthLimit(UInt32) Sets the bandwidth limit on the send stream of the VideoSocket. This is only supported if the socket supports sending H264 video formats. It is recommended to wait for the VideoSendStatusChanged event with MediaSendStatus Active state during the initial call setup before applying the send bandwidth limit on the socket. Bandwidth range (in bits per second) for various resolutions and frame rates per media type: Media type: Video 1000000 - 4000000 1080p at 30 fps 550000 - 2500000 720p at 30 fps 375000 - 1500000 540p at 30 fps 200000 - 800000 360p at 30 fps 150000 - 250000 360p at 15 fps 120000 - 220000 240p at 15 fps 60000 - 200000 180p at 15 fps 20000 - 100000 180p at 7.5 fps 10000 - 25000 180p at 3.75 fps 1000 - 12500 180p at 1.875 fps Media type: Vbss Resolution: 1080p 2000000 - 4000000 at 30 fps 600000 - 3000000 at 15 fps 300000 - 700000 at 7.5 fps 150000 - 350000 at 3.75 fps 70000 - 200000 at 1.875 fps Declaration public void SetSendBandwidthLimit(uint bitsPerSecond) Parameters Type Name Description UInt32 bitsPerSecond The send bitrate Subscribe(VideoResolution) Request to receive the video of the peer in a 1:1 call. No need to specify a MediaSourceId. The bot cannot subscribe to a video source unless the VideoReceiveStatusChanged event is raised indicating the VideoSocket's MediaReceiveStatus is Active . Declaration public void Subscribe(VideoResolution preferredVideoResolution) Parameters Type Name Description VideoResolution preferredVideoResolution The requested video resolution. The received video frames should have this resolution if the bandwidth constraints and sender capabilities allow, however the bot may receive video frames at a resolution lower than requested. Subscribe(VideoResolution, UInt32) Request to receive the video source of a participant in a meeting or group call. The video source must be identified by its MediaSourceId available from the roster. The bot cannot subscribe to a video source unless the VideoReceiveStatusChanged event is raised indicating the VideoSocket's MediaReceiveStatus is Active . Declaration public void Subscribe(VideoResolution preferredVideoResolution, uint MediaSourceId) Parameters Type Name Description VideoResolution preferredVideoResolution The requested video resolution. The received video frames should have this resolution if the bandwidth constraints and sender capabilities allow, however the bot may receive video frames at a resolution lower than requested. UInt32 MediaSourceId Media source identifier of the video source to be received Exceptions Type Condition ObjectDisposedException Thrown if the VideoSocket is disposed. InvalidOperationException Thrown if the subscription is invalid. SkypeMediaException Thrown if an internal media failure occurs. Unsubscribe() Stops the current video subscription on the VideoSocket. The VideoMediaReceived events will stop raising video buffers. Declaration public void Unsubscribe() UpdateVideoSendCapability(VideoSendCapability) Allows the application to update dynamically the send capability (such as SupportedSendVideoFormats or MaxConcurrentSendStreams) of the video socket. The purpose of this API is to allow the application to communicate changes in VideoSocket's send capability to the platform during the call. Declaration public void UpdateVideoSendCapability(VideoSendCapability capability) Parameters Type Name Description VideoSendCapability capability Events MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration public event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > Remarks Note: this event can be raised even if there is no active video subscription; i.e., the VideoSocket is \"idle\" and not receiving media. MediaStreamQualityChanged The event is raised if a media stream quality change was detected Declaration public event EventHandler MediaStreamQualityChanged Event Type Type Description EventHandler < VideoMediaStreamQualityChangedEventArgs > VideoKeyFrameNeeded If the application has configured the VideoSocket to receive encoded media, this event is raised each time a key frame is needed. Events are serialized, so only one event at a time is raised to the app. Declaration public event EventHandler VideoKeyFrameNeeded Event Type Type Description EventHandler < VideoKeyFrameNeededEventArgs > VideoMediaReceived If the application has configured the VideoSocket to receive media, this event is raised each time a frame of video media is received. Once the application has consumed the buffer, it must call the buffer's Dispose() method. Declaration public event EventHandler VideoMediaReceived Event Type Type Description EventHandler < VideoMediaReceivedEventArgs > Remarks The incoming video frame rate is variable. The frame rate can vary between 1.875 frames per second (fps) up to 30 fps. The application must be able to receive up to 30 video buffers per second. Events are serialized, so only one event at a time is raised to the app. The event handler should return as quickly as possible; any time-consuming per-frame processing should be performed asynchronously from the event handler. VideoReceiveStatusChanged If the application has configured the VideoSocket to receive media, this event is raised to inform the application when it is ready to receive media. When the status is active the application can subscribe to a video source, when inactive video subscription won't be allowed Declaration public event EventHandler VideoReceiveStatusChanged Event Type Type Description EventHandler < VideoReceiveStatusChangedEventArgs > VideoSendStatusChanged If the application has configured the VideoSocket to send media, this event is raised to inform the application when it may begin sending media and when it should stop. The application cannot send media before receiving a VideoMediaSendStatusChanged event indicating the SendStatus is Active, such media will be discarded. Declaration public event EventHandler VideoSendStatusChanged Event Type Type Description EventHandler < VideoSendStatusChangedEventArgs > Implements IVideoSocket System.IDisposable" }, - "core/Microsoft.Graph.Communications.Core.Serialization.CommsSerializer.html": { - "href": "core/Microsoft.Graph.Communications.Core.Serialization.CommsSerializer.html", - "title": "Class CommsSerializer", - "keywords": "Class CommsSerializer An interface for serializing and deserializing JSON objects. This serializer is used throughout the Communications workload to provide extra functionality. Specifically it supports more robust serialization/deserialization of @odata.type property and deserialization of open type additional data. Inheritance Object CommsSerializer Implements ISerializer Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Serialization Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class CommsSerializer : ISerializer Constructors CommsSerializer(Boolean) Initializes a new instance of the CommsSerializer class. Declaration public CommsSerializer(bool pretty = false) Parameters Type Name Description Boolean pretty If set to true make the formatting pretty. CommsSerializer(Boolean, Assembly[]) Initializes a new instance of the CommsSerializer class. Declaration public CommsSerializer(bool pretty = false, params Assembly[] assemblies) Parameters Type Name Description Boolean pretty If set to true make the formatting pretty. Assembly [] assemblies The assemblies to use for deserialization. The CommsSerializer searches through the specified assemblies in order specified to find the @odata.type in the json payload. Properties CoreAssemblies Gets the list of core Assembly detected. Declaration public Assembly[] CoreAssemblies { get; } Property Value Type Description Assembly [] JsonSerializerSettings Gets the JSON serializer settings. Declaration public JsonSerializerSettings JsonSerializerSettings { get; } Property Value Type Description Newtonsoft.Json.JsonSerializerSettings Methods DeserializeObject(Stream) Declaration public T DeserializeObject(Stream stream) Parameters Type Name Description Stream stream Returns Type Description T Type Parameters Name Description T DeserializeObject(String) Declaration public T DeserializeObject(string inputString) Parameters Type Name Description String inputString Returns Type Description T Type Parameters Name Description T SerializeObject(Object) Declaration public string SerializeObject(object serializeableObject) Parameters Type Name Description Object serializeableObject Returns Type Description String Implements Microsoft.Graph.ISerializer See Also ISerializer" + "bot_media/Microsoft.Skype.Bots.Media.VideoSinkEncodingFormat.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSinkEncodingFormat.html", + "title": "Enum VideoSinkEncodingFormat", + "keywords": "Enum VideoSinkEncodingFormat VideoSinkEncodingFormats Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum VideoSinkEncodingFormat Fields Name Description H264 H264 Yuv Yuv" }, - "common/Microsoft.Graph.Communications.Common.Observer-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Observer-1.html", - "title": "Class Observer", - "keywords": "Class Observer Observer class. Inheritance Object Disposable Observer Implements IDisposable IObserver Inherited Members Disposable.Dispose() Disposable.IsDisposed Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class Observer : Disposable, IDisposable, IObserver Type Parameters Name Description T Type of the value the observer returns. Constructors Observer(IObservable, Action, Action, Action) Initializes a new instance of the Observer class. Declaration public Observer(IObservable observable, Action onNext, Action onError = null, Action onCompleted = null) Parameters Type Name Description IObservable observable Observable object. Action onNext Callback for next. Action < Exception > onError Callback for error. Action onCompleted Callback for completed. Methods Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Overrides Disposable.Dispose(Boolean) Explicit Interface Implementations IObserver.OnCompleted() Callback when observer has no more data. Declaration void IObserver.OnCompleted() IObserver.OnError(Exception) Callback when observer hits an error. Declaration void IObserver.OnError(Exception error) Parameters Type Name Description Exception error Exception info. IObserver.OnNext(T) Callback when data arrives. Declaration void IObserver.OnNext(T value) Parameters Type Name Description T value Observed value. Implements System.IDisposable System.IObserver Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.VideoSendStatusChangedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSendStatusChangedEventArgs.html", + "title": "Class VideoSendStatusChangedEventArgs", + "keywords": "Class VideoSendStatusChangedEventArgs Event arguments of a VideoSendStatusChanged event. Inheritance Object EventArgs VideoSendStatusChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoSendStatusChangedEventArgs : EventArgs Constructors VideoSendStatusChangedEventArgs() Declaration public VideoSendStatusChangedEventArgs() Properties MediaSendStatus The media send status. Declaration public MediaSendStatus MediaSendStatus { get; set; } Property Value Type Description MediaSendStatus MediaType MediaType of the video socket raising the event. This could be Video or Vbss. Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType PreferredEncodedVideoSourceFormats The preferred video source format if encoded video is sent. Declaration public VideoFormat[] PreferredEncodedVideoSourceFormats { get; set; } Property Value Type Description VideoFormat [] PreferredVideoSourceFormat The preferred video source format if raw video is sent. Declaration public VideoFormat PreferredVideoSourceFormat { get; set; } Property Value Type Description VideoFormat SocketId The 0-based ID of the socket that is raising this event. This socket ID can be used in multiview (ie. more than 1 video socket) to determine which video socket is raising this event. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the Microsoft.Skype.Bots.Media.MediaPlatform (or IMediaPlatform) API CreateMediaConfiguration. Eg. If the collection of IVideoSocket objects in the CreateMediaConfiguration API contains { socketA, socketB, socketC }, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Declaration public int SocketId { get; set; } Property Value Type Description Int32" }, - "calls/Microsoft.Graph.Communications.Calls.CommunicationsClientExtensions.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.CommunicationsClientExtensions.html", - "title": "Class CommunicationsClientExtensions", - "keywords": "Class CommunicationsClientExtensions Extensions for stateful client. Inheritance Object CommunicationsClientExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public static class CommunicationsClientExtensions Methods Calls(ICommunicationsClient, Boolean) Gets the call collection. This is the main entry point for the calling SDK. The return value of this function can be cached by the clients as required. Declaration public static ICallCollection Calls(this ICommunicationsClient client, bool maintainState = true) Parameters Type Name Description ICommunicationsClient client The stateful client. Boolean maintainState If set to true the resulting IResourceCollection will hold all IResource instances it creates unless explicitly deleted (either by the service or by the developer). If set to false no IResource generated by the IResourceCollection or its children will be stored by the ICommunicationsClient , instead it is the developers responsibility to control the lifetime of the generated instances. Returns Type Description ICallCollection The root singleton ICallCollection node. Multiple invocations of this method will return the same ICallCollection ." + "bot_media/Microsoft.Skype.Bots.Media.VideoMediaBuffer.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoMediaBuffer.html", + "title": "Class VideoMediaBuffer", + "keywords": "Class VideoMediaBuffer Represents an unmanaged buffer containing video media data. Inheritance Object VideoMediaBuffer Implements IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public abstract class VideoMediaBuffer : IDisposable Constructors VideoMediaBuffer() Declaration protected VideoMediaBuffer() Properties Data Pointer to the unmanaged media buffer. Declaration public IntPtr Data { get; protected set; } Property Value Type Description IntPtr Remarks For the H264 video format, Data points to the start code of the first NALU of the frame and the whole buffer contains all the NALUs of the frame in sequence separated by their start codes. The frame data is an unencrypted depacketized H.264 elementary stream. B frames and SEI messages are not supported. Supported NALU types are 7 (SPS), 8 (PPS), 5 (IDR), and 1 (non-IDR). NALU start code prefixes can be either 0x000001 (3 bytes) or 0x00000001 (4 bytes). Fragmentation and packetization of NALUs is automatically handled by the platform. When receiving video in the H264 format, the platform ensures the application always receives decodable, full frames. Length The length of data in the media buffer. Declaration public long Length { get; protected set; } Property Value Type Description Int64 MediaSourceId MediaSourceId (MSI) of the video buffer. Within group or conference video calls, the MSI value identifies the video media source. This property is populated by the Real-Time Media Platform for Bots on received video buffers. When sending buffers via the IVideoSocket.Send API, this property is unused. Declaration public uint MediaSourceId { get; protected set; } Property Value Type Description UInt32 OriginalVideoFormat Original VideoFormat of the buffer when it was sourced. It is only used when receiving video buffers via the IVideoSocket.VideoMediaReceived event handler, in which case the VideoMediaBuffer.VideoFormat property may have different Width and Height values than the OriginalVideoFormat property, which represents the original format of the buffer. The reason is that the buffer may have been resized before being transmitted, so the original Width and Height may have been resized. If the Width and Height properties of OriginalVideoFormat differ from the VideoFormat property, the consumer of the VideoMediaBuffer raised in the VideoMediaReceived event should resize the buffer to fit the OriginalVideoFormat size. When sending buffers via the IVideoSocket.Send API, this property should always be null. Declaration public VideoFormat OriginalVideoFormat { get; protected set; } Property Value Type Description VideoFormat Stride Stride of the video buffer. This property is optional when sourcing video buffers that are sent via the IVideoSocket.Send API. Stride (also called pitch) represents the number of bytes it takes to read one row of pixels in memory. It may differ from the width depending on the color format. Declaration public int Stride { get; protected set; } Property Value Type Description Int32 Timestamp Timestamp of when the media content was sourced, in 100-ns units. When sourcing media buffers, this property should be set using the value from the MediaPlatform.GetCurrentTimestamp() API. Declaration public long Timestamp { get; protected set; } Property Value Type Description Int64 VideoFormat VideoFormat of the video media buffer. Declaration public VideoFormat VideoFormat { get; protected set; } Property Value Type Description VideoFormat Methods Dispose() Disposes the object. Declaration public void Dispose() Dispose(Boolean) Releases unmanaged resources held by the buffer object. Must be implemented in the derived class. Declaration protected abstract void Dispose(bool disposing) Parameters Type Name Description Boolean disposing If true, both managed and unmanaged resources can be disposed. If false, only unmanaged resources can be disposed. Implements System.IDisposable" }, - "client/Microsoft.Graph.Communications.Client.Transport.html": { - "href": "client/Microsoft.Graph.Communications.Client.Transport.html", - "title": "Namespace Microsoft.Graph.Communications.Client.Transport", - "keywords": "Namespace Microsoft.Graph.Communications.Client.Transport Classes GraphAuthClient The graph auth client. GraphAuthClientFactory The HTTP graph client factory. GraphClientContext The context for the graph client wrapper. GraphClientWrapper The graph client wrapper." + "bot_media/Microsoft.Skype.Bots.Media.ToneId.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.ToneId.html", + "title": "Enum ToneId", + "keywords": "Enum ToneId DTMF Tone Id enum. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum ToneId Fields Name Description A Tone A B Tone B C Tone C D Tone D Flash Tone flash Pound Pound tone Star Star tone Tone0 Tone 0 Tone1 Tone 1 Tone2 Tone 2 Tone3 Tone 3 Tone4 Tone 4 Tone5 Tone 5 Tone6 Tone 6 Tone7 Tone 7 Tone8 Tone 8 Tone9 Tone 9" }, - "client/Microsoft.Graph.Communications.Client.html": { - "href": "client/Microsoft.Graph.Communications.Client.html", - "title": "Namespace Microsoft.Graph.Communications.Client", - "keywords": "Namespace Microsoft.Graph.Communications.Client Classes CommunicationsClientBuilder The class the provides the builder for stateful client. CommunicationsClientExtensions Extensions for Stateful Client. GraphLoggerExtensions The graph logger extensions for the communications client. PagedList An object that contains paginated list of the generic type T. StateManager The state manager implementation. Interfaces ICommunicationsClient The CommunicationsClient interface. This is the entry point of the SDK and a reference to this instance must be held for the duration of the session. ICommunicationsClientBuilder The builder object that builds the ICommunicationsClient . Use this class to setup the SDK's configuration. IPagedList The paged list interface. IStateManager The state manager interface. This object is responsible for storing the resources in memory." + "bot_media/Microsoft.Skype.Bots.Media.MediaSendStatus.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaSendStatus.html", + "title": "Enum MediaSendStatus", + "keywords": "Enum MediaSendStatus Indicates whether an AudioSocket or VideoSocket is capable of sending media. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaSendStatus Fields Name Description Active Media can be sent Inactive Media cannot be sent" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphProperty.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphProperty.html", - "title": "Class GraphProperty", - "keywords": "Class GraphProperty The IGraphProperty helpers and extensions. Inheritance Object GraphProperty Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class GraphProperty Fields ContentType The content type Declaration public const string ContentType = \"content\" Field Value Type Description String RequestType The request type Declaration public const string RequestType = \"request\" Field Value Type Description String Methods Add(ICollection, String, Object, String) Adds the property to the exchange. Declaration public static IGraphProperty Add(this ICollection properties, string key, object value, string type = null) Parameters Type Name Description ICollection < IGraphProperty > properties The properties. String key The key. Object value The value. String type The type. Returns Type Description IGraphProperty The added IGraphProperty . Add(ICollection, String, T, String) Adds the property to the exchange. Declaration public static IGraphProperty Add(this ICollection properties, string key, T value, string type = null) Parameters Type Name Description ICollection < IGraphProperty > properties The properties. String key The key. T value The value. String type The type. Returns Type Description IGraphProperty The added IGraphProperty . Type Parameters Name Description T The expected type of the property. Contains(IEnumerable, String) Finds the property in the given exchange. Declaration public static bool Contains(this IEnumerable properties, string key) Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String key The key. Returns Type Description Boolean The found IGraphProperty . ContentProperty(String, Object) Creates the property of content type. Declaration public static IGraphProperty ContentProperty(string key, object value) Parameters Type Name Description String key The key. Object value The values. Returns Type Description IGraphProperty The content IGraphProperty . ContentProperty(String, T) Creates the property of content type. Declaration public static IGraphProperty ContentProperty(string key, T value) Parameters Type Name Description String key The key. T value The values. Returns Type Description IGraphProperty The content IGraphProperty . Type Parameters Name Description T The type of the property to create. ConvertProperty(IGraphProperty) Converts the property. Declaration public static IGraphProperty ConvertProperty(this IGraphProperty property) Parameters Type Name Description IGraphProperty property The property. Returns Type Description IGraphProperty The IGraphProperty with the expected generic type if the types match, null otherwise. Type Parameters Name Description T The type of value expected. Find(IEnumerable, String) Finds the property in the given exchange. Declaration public static IGraphProperty Find(this IEnumerable properties, string key) Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String key The key. Returns Type Description IGraphProperty The found IGraphProperty . Find(IEnumerable, String) Finds the property in the given exchange. Declaration public static IGraphProperty Find(this IEnumerable properties, string key) Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String key The key. Returns Type Description IGraphProperty The found IGraphProperty . Type Parameters Name Description T The expected type of the property. Property(String, Object, String) Creates a property of the specified type. Declaration public static IGraphProperty Property(string key, object value, string type = null) Parameters Type Name Description String key The key. Object value The values. String type The type. Returns Type Description IGraphProperty The created IGraphProperty . Property(String, T, String) Creates a property of the specified type. Declaration public static IGraphProperty Property(string key, T value, string type = null) Parameters Type Name Description String key The key. T value The value. String type The type. Returns Type Description IGraphProperty The created IGraphProperty . Type Parameters Name Description T The type of the property to create. RequestProperty(String, Object) Creates the property of request type. Declaration public static IGraphProperty RequestProperty(string key, object value) Parameters Type Name Description String key The key. Object value The value. Returns Type Description IGraphProperty The request IGraphProperty . RequestProperty(String, T) Creates the property of request type. Declaration public static IGraphProperty RequestProperty(string key, T value) Parameters Type Name Description String key The key. T value The value. Returns Type Description IGraphProperty The request IGraphProperty . Type Parameters Name Description T The type of the property to create. See Also IGraphProperty IGraphProperty" + "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCallExtensions.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCallExtensions.html", + "title": "Class MediaCallExtensions", + "keywords": "Class MediaCallExtensions Stateful call media extensions Inheritance Object MediaCallExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public static class MediaCallExtensions Methods CreateMediaSession(ICall, AudioSocketSettings, VideoSocketSettings, VideoSocketSettings, DataSocketSettings, Guid) Creates a local media session for the provided call with a given socket configuration. Declaration public static ILocalMediaSession CreateMediaSession(this ICall call, AudioSocketSettings audioSocketSettings, VideoSocketSettings videoSocketSettings, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null, Guid mediaSessionId = default(Guid)) Parameters Type Name Description ICall call The call. AudioSocketSettings audioSocketSettings The audio socket settings. VideoSocketSettings videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Guid mediaSessionId The id for the media session. Returns Type Description ILocalMediaSession A ILocalMediaSession . Exceptions Type Condition ArgumentNullException If the call has not been specified. ArgumentException If the call does not have a valid identifier. CreateMediaSession(ICall, AudioSocketSettings, IEnumerable, VideoSocketSettings, DataSocketSettings, Guid) Creates a local media session for the provided call with a given socket configuration. Declaration public static ILocalMediaSession CreateMediaSession(this ICall call, AudioSocketSettings audioSocketSettings, IEnumerable videoSocketSettings = null, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null, Guid mediaSessionId = default(Guid)) Parameters Type Name Description ICall call The call. AudioSocketSettings audioSocketSettings The audio socket settings. IEnumerable < VideoSocketSettings > videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Guid mediaSessionId The id for the media session. Returns Type Description ILocalMediaSession A ILocalMediaSession . Exceptions Type Condition ArgumentNullException If the call has not been specified. ArgumentException If the call does not have a valid identifier. GetLocalMediaSession(ICall) Gets the local media session for this call object. Declaration public static ILocalMediaSession GetLocalMediaSession(this ICall call) Parameters Type Name Description ICall call The call. Returns Type Description ILocalMediaSession Local media session object Exceptions Type Condition InvalidCastException This call does not have a valid ILocalMediaSession object." }, - "calls/Microsoft.Graph.Communications.Calls.ICall.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.ICall.html", - "title": "Interface ICall", - "keywords": "Interface ICall The stateful call interface. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface ICall : IResource, IResource, IResourceBase, IDisposable Properties CorrelationId Gets the correlation identifier. Declaration [Obsolete(\"Please use ScenarioId instead.\")] Guid CorrelationId { get; } Property Value Type Description Guid MediaSession Gets the media session, if any. This is used only for Local Media Scenarios. Declaration IMediaSession MediaSession { get; } Property Value Type Description IMediaSession Participants Gets the Participants collection for this call. Declaration IParticipantCollection Participants { get; } Property Value Type Description IParticipantCollection Resource Gets the call resource. Declaration Call Resource { get; } Property Value Type Description Call ScenarioId Gets the scenario identifier. Declaration Guid ScenarioId { get; } Property Value Type Description Guid TenantId Gets the tenant identifier. Declaration string TenantId { get; } Property Value Type Description String Methods AnswerAsync(MediaConfig, IEnumerable, String, Guid, CancellationToken) Answer an incoming call asynchronously. Declaration Task AnswerAsync(MediaConfig mediaConfig, IEnumerable acceptedModalities = null, string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description MediaConfig mediaConfig The MediaConfig . IEnumerable < Modality > acceptedModalities The accepted list of Modality . String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated ChangeScreenSharingRoleAsync(ScreenSharingRole, CancellationToken) Changes own sharing role in a vbss session. Declaration Task ChangeScreenSharingRoleAsync(ScreenSharingRole role, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description ScreenSharingRole role The role to change to. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. DeleteAsync(Boolean, CancellationToken) Deletes this call asynchronously. Declaration Task DeleteAsync(bool handleHttpNotFoundInternally = false, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description Boolean handleHttpNotFoundInternally If the ICall is already gone, whether to handle the exception gracefully or not. CancellationToken cancellationToken The CancellationToken for the request. Returns Type Description Task The Task that completes after the request has been sent. The completion of this task does not guarantee deletion. Confirmation of deletion comes as a notification and can be subscribed by ICall.OnUpdated and ICallCollection.OnUpdated KeepAliveAsync(CancellationToken) Send heartbeat to keep call alive. Declaration Task KeepAliveAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. MuteAsync(CancellationToken) Mutes the self participant asynchronously. Declaration Task MuteAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The mute notification will come in on IParticipant.OnUpdated PlayPromptAsync(IEnumerable, Action, CancellationToken) Plays the specified media prompts. Declaration Task PlayPromptAsync(IEnumerable prompts, Action promptsQueued = null, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description IEnumerable < MediaPrompt > prompts The list of MediaPrompt to play Action promptsQueued A callback indicating when the prompts have been queued, but have not yet completed playing. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < PlayOperationResult > The PlayOperationResult with information on how the play operation completed. Exceptions Type Condition ServiceException An error has occurred when playing the prompt. RedirectAsync(IEnumerable, Nullable, String, Guid, CancellationToken) Redirects the incoming call asynchronously. Declaration Task RedirectAsync(IEnumerable targets, int? timeout = default(int? ), string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description IEnumerable < InvitationParticipantInfo > targets The targets to whom the call should be redirected to. Nullable < Int32 > timeout The timeout after which the redirect is canceled. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. RejectAsync(Nullable, String, Guid, CancellationToken) Rejects the incoming call asynchronously. Declaration Task RejectAsync(RejectReason? rejectReason = default(RejectReason? ), string callbackUri = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description Nullable < RejectReason > rejectReason The reason for call rejection. String callbackUri The optional callback uri. Specifying this will override the default callback uri set when creating the ICommunicationsClient Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. SubscribeToToneAsync(CancellationToken) Subscribe to DTMF (dual-tone multi-frequency signaling). This allows you to be notified when the user presses keys on a \"touchtone\" phone. Declaration Task SubscribeToToneAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The DTMF notifications will come on ICall.OnUpdated TransferAsync(InvitationParticipantInfo, CancellationToken) Transfer a call to a given target. Declaration Task TransferAsync(InvitationParticipantInfo target, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description InvitationParticipantInfo target The target to transfer the call to. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the call has been answered. Any updates on call will be delivered via notification and can be observed using ICall.OnUpdated UnmuteAsync(CancellationToken) Unmutes the self participant asynchronously. Declaration Task UnmuteAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The unmute notification will come in on IParticipant.OnUpdated Extension Methods CallExtensions.AnswerAsync(ICall, IMediaSession, String, Guid, CancellationToken) CallExtensions.AnswerAsync(ICall, IEnumerable, IEnumerable, String, Guid, CancellationToken) CallExtensions.AnswerAsync(ICall, IEnumerable, String, Guid, CancellationToken)" + "calls/Microsoft.Graph.Communications.Calls.ParticipantExtensions.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.ParticipantExtensions.html", + "title": "Class ParticipantExtensions", + "keywords": "Class ParticipantExtensions Extensions for the stateful participant resource. Inheritance Object ParticipantExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public static class ParticipantExtensions Methods InviteAsync(IParticipantCollection, IdentitySet, String, CancellationToken) Invite a participant into the existing call. Declaration public static Task InviteAsync(this IParticipantCollection participantCollection, IdentitySet identitySet, string replacesCallId = null, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description IParticipantCollection participantCollection The participant collection into which a new participant is being invited. IdentitySet identitySet The identity set of the invited participant. String replacesCallId The replaces call identifier. This is an optional field used for consultative transfer. This is used to bring a participant from an existing call. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. This does not guarantee that the participant has joined. Any updates on the participant collection will be delivered via notification and can be observed using IParticipantCollection.OnUpdated Exceptions Type Condition ArgumentNullException If IdentitySet is null." }, - "client/Microsoft.Graph.Communications.Resources.html": { - "href": "client/Microsoft.Graph.Communications.Resources.html", - "title": "Namespace Microsoft.Graph.Communications.Resources", - "keywords": "Namespace Microsoft.Graph.Communications.Resources Classes CollectionEventArgs The collection event arguments. ResourceEventArgs The resource event arguments. Interfaces IResource The stateful resource interface. IResource The stateful resource interface. IResourceBase The resource base interface. IResourceCollection The resource collection interface. IResourceCollection The resource collection interface. IResourceCollection The resource collection interface. Delegates CollectionEventHandler The call collection event handler delegate. ResourceEventHandler The resource event handler delegate." + "common/Microsoft.Graph.Communications.Common.TaskExtension.html": { + "href": "common/Microsoft.Graph.Communications.Common.TaskExtension.html", + "title": "Class TaskExtension", + "keywords": "Class TaskExtension Extensions for Task Inheritance Object TaskExtension Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class TaskExtension Methods ExpectExceptionAsync(Task, Type) Except an exception Declaration public static Task ExpectExceptionAsync(this Task task, Type expectedEx) Parameters Type Name Description Task task task Type expectedEx expected exception Returns Type Description Task Task representing completion ExpectExceptionAsync(Task, Type) Except an exception Declaration public static Task ExpectExceptionAsync(this Task task, Type expectedEx) Parameters Type Name Description Task task task Type expectedEx expected exception Returns Type Description Task Task representing completion Type Parameters Name Description T type IgnoreExceptionAsync(Task, Type) Ignore exception Declaration public static Task IgnoreExceptionAsync(this Task task, Type exceptionType) Parameters Type Name Description Task task task Type exceptionType exception type Returns Type Description Task Task representing completion IgnoreExceptionAsync(Task, Type) Ignore exception Declaration public static Task IgnoreExceptionAsync(this Task task, Type exceptionType) Parameters Type Name Description Task task task Type exceptionType exception type Returns Type Description Task Task representing completion Type Parameters Name Description T type" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.BaseFilter.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters.BaseFilter.html", - "title": "Class BaseFilter", - "keywords": "Class BaseFilter Non generic base filter. Inheritance Object BaseFilter BaseFilter Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.Filters Assembly : Microsoft.Graph.Communications.Common.dll Syntax public abstract class BaseFilter Constructors BaseFilter() Declaration protected BaseFilter() Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.StringUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.StringUtils.html", + "title": "Class StringUtils", + "keywords": "Class StringUtils String Utils Inheritance Object StringUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class StringUtils Methods ConvertOrDefault(String, T) Convert string to type or return default Declaration public static T ConvertOrDefault(string value, T defaultValue = null) Parameters Type Name Description String value input value T defaultValue default value Returns Type Description T result of the conversion Type Parameters Name Description T Type of return value EqualsIgnoreCase(String, String) Case insensitive string comparison Declaration public static bool EqualsIgnoreCase(this string valueA, string valueB) Parameters Type Name Description String valueA Input string A String valueB Input string B Returns Type Description Boolean Value indicating whether strings are equal in a case insensitive comparision FromBase64(String) Converts the specified string, which encodes binary data as base-64 digits, to an equivalent 8-bit unsigned integer array. Declaration public static byte[] FromBase64(this string data) Parameters Type Name Description String data The string to convert. Returns Type Description Byte [] An array of 8-bit unsigned integers. FromBase64Url(String) Converts the specified string, which encodes binary data as base-64 digits, to an equivalent 8-bit unsigned integer array. Declaration public static byte[] FromBase64Url(this string data) Parameters Type Name Description String data The string to convert. Returns Type Description Byte [] An array of 8-bit unsigned integers. GetSHA256Hash(String) Creates a SHA256 hash of the passed string. Declaration public static string GetSHA256Hash(this string input) Parameters Type Name Description String input The input string. Returns Type Description String The SHA256 hash. Join(IEnumerable, String) Concatenates the members of a constructed IEnumerable collection of type String , using the specified separator between each member. Declaration public static string Join(this IEnumerable values, string separator) Parameters Type Name Description IEnumerable < String > values A collection that contains the strings to concatenate. String separator The string to use as a separator. separator is included in the returned string only if values has more than one element. Returns Type Description String A string that consists of the members of values delimited by the separator string. If values has no members, the method returns Empty . NamespaceInCamelCase(String) Returns a namespace in camel case. Declaration public static string NamespaceInCamelCase(this string value) Parameters Type Name Description String value Value to convert. Returns Type Description String The namespace string in camel case. NamespaceInPascalCase(String) Returns a namespace in pascal case. Declaration public static string NamespaceInPascalCase(this string value) Parameters Type Name Description String value Value to convert. Returns Type Description String The namespace string in pascal case. SafeFormat(String, Object[]) Format a string with arguments. Declaration public static string SafeFormat(this string text, params object[] args) Parameters Type Name Description String text Format string. Object [] args Optional arguments. Returns Type Description String Formatted string. ToBase64(ArraySegment, Nullable, Nullable) Convert array segment to base 64 representation. Declaration public static string ToBase64(this ArraySegment data, int? offset = default(int? ), int? count = default(int? )) Parameters Type Name Description ArraySegment < Byte > data Data to convert. Nullable < Int32 > offset Optional override offset. Nullable < Int32 > count Optional override count. Returns Type Description String Base 64 encoded string. ToBase64(Byte[]) Convert byte array to base64. Declaration public static string ToBase64(this byte[] data) Parameters Type Name Description Byte [] data The data. Returns Type Description String Base64 representation. ToBase64Url(ArraySegment, Nullable, Nullable) Convert array segment to base 64 URL representation. Declaration public static string ToBase64Url(this ArraySegment data, int? offset = default(int? ), int? count = default(int? )) Parameters Type Name Description ArraySegment < Byte > data Data to convert. Nullable < Int32 > offset Optional override offset. Nullable < Int32 > count Optional override count. Returns Type Description String Base 64 encoded string. ToCamelCase(String) Converts value to camel casing. Declaration public static string ToCamelCase(this string value) Parameters Type Name Description String value Value to convert. Returns Type Description String Returns string in camel case. ToPascalCase(String) Converts value to pascal casing. Declaration public static string ToPascalCase(this string value) Parameters Type Name Description String value Value to convert. Returns Type Description String Returns string in pascal case. TrimEnd(String, String) Remove a substring from the end of a given string. This is called iteratively. Declaration public static string TrimEnd(this string target, string trimString) Parameters Type Name Description String target The target. String trimString The trim string. Returns Type Description String The string after being trimmed. TrimStart(String, String) Remove a substring from the beginning of a given string. This is called iteratively. Declaration public static string TrimStart(this string target, string trimString) Parameters Type Name Description String target The target. String trimString The trim string. Returns Type Description String The string after being trimmed." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.html", - "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry.Obfuscation", - "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Classes GraphObfuscationAttribute Attribute used for decoration of data objects. This is used for obfuscation for logging. GraphObfuscationContractResolver Newtonsoft JSON resolver that uses Graph Obfuscation attribute to serialize data for logging purposes. HashingObfuscationConfiguration The hashing obfuscation configuration. This configurations is preconfigured to use the HashingObfuscationEngine and provides logic to automatically generate a salt which resets daily. HashingObfuscationEngine Obfuscation engine that hashes PII using salt. ObfuscatedValueProvider Newtonsoft JSONs value provider for obfuscated data. ObfuscationConfiguration Configuration for obfuscation of different parts. ObfuscationSerializer The obfuscation serializer can be used to serialize and de-serialize an obfuscation schema, as well as generate a schema from specified assemblies. Structs ObfuscationMember The obfuscation member. This struct is used to generate an obfuscation schema for any class type or it's members. It can be passed into the GraphObfuscationContractResolver which will cache the schema when resolving object and member obfuscation. Interfaces IObfuscationEngine Obfuscation engine that can obfuscate data. Enums ObfuscationTag Tag used to provide a hint for the type of obfuscation to perform." + "calls/Microsoft.Graph.Communications.Calls.RecordOperationResult.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.RecordOperationResult.html", + "title": "Class RecordOperationResult", + "keywords": "Class RecordOperationResult Class to define parameters required for joining a meeting. Inheritance Object RecordOperationResult Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public class RecordOperationResult Constructors RecordOperationResult(String, String, ResultInfo) Initializes a new instance of the RecordOperationResult class. Declaration public RecordOperationResult(string recordingLocation, string recordingAccessToken, ResultInfo resultInfo) Parameters Type Name Description String recordingLocation The location of the recording. String recordingAccessToken Token to access the recording. ResultInfo resultInfo The result information. Properties RecordingAccessToken Gets the recording access token required to retrieve the recording. Declaration public string RecordingAccessToken { get; } Property Value Type Description String RecordingLocation Gets the recording location. Link to the \"live raw stream as it is being recorded\" or \"recorded stream after it’s recorded\". Client need to call GET request on this link passing RecordingAccessToken as bearer token in order to download the stream. Declaration public string RecordingLocation { get; } Property Value Type Description String ResultInfo Gets the result information. Declaration public ResultInfo ResultInfo { get; } Property Value Type Description ResultInfo The result information." }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphResponseExtensions.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphResponseExtensions.html", - "title": "Class GraphResponseExtensions", - "keywords": "Class GraphResponseExtensions Extensions for IGraphResponse class. Inheritance Object GraphResponseExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class GraphResponseExtensions Methods ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable) Converts IGraphResponse into a HttpResponseMessage . Declaration public static HttpResponseMessage ToHttpResponseMessage(this IGraphResponse graphResponse, JsonSerializerSettings jsonSerializerSettings = null, IEnumerable defaultProperties = null) Parameters Type Name Description IGraphResponse graphResponse The graph response to be converted. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. IEnumerable < IGraphProperty > defaultProperties The default properties. Returns Type Description HttpResponseMessage HttpResponseMessage corresponding to graphResponse . Type Parameters Name Description T Type of content available in the response. ToHttpStatus(ResponseStatus) Convert ResponseStatus to it's corresponding HttpStatusCode . Declaration public static HttpStatusCode ToHttpStatus(this ResponseStatus status) Parameters Type Name Description ResponseStatus status The status. Returns Type Description HttpStatusCode HttpStatusCode for the ResponseStatus" + "calls/Microsoft.Graph.Communications.Calls.PlayOperationResult.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.PlayOperationResult.html", + "title": "Class PlayOperationResult", + "keywords": "Class PlayOperationResult Class to define parameters required for joining a meeting. Inheritance Object PlayOperationResult Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public class PlayOperationResult Constructors PlayOperationResult(ResultInfo) Initializes a new instance of the PlayOperationResult class. Declaration public PlayOperationResult(ResultInfo resultInfo) Parameters Type Name Description ResultInfo resultInfo The result information. Properties ResultInfo Gets the result information. Declaration public ResultInfo ResultInfo { get; } Property Value Type Description ResultInfo The result information." }, - "common/Microsoft.Graph.Communications.Common.Transport.NoContentMessage.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.NoContentMessage.html", - "title": "Class NoContentMessage", - "keywords": "Class NoContentMessage IGraphClient requires type parameters for functionality. This is a marked Type/class to make function calls to IGraphClient indicating we have request/response with no body. The sole purpose of this class's existence is to reduce code duplicacy. Inheritance Object NoContentMessage Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class NoContentMessage Constructors NoContentMessage() Declaration public NoContentMessage() Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.VideoReceiveStatusChangedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoReceiveStatusChangedEventArgs.html", + "title": "Class VideoReceiveStatusChangedEventArgs", + "keywords": "Class VideoReceiveStatusChangedEventArgs Event arguments of a VideoReceiveStatusChanged event. Inheritance Object EventArgs VideoReceiveStatusChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoReceiveStatusChangedEventArgs : EventArgs Constructors VideoReceiveStatusChangedEventArgs() Declaration public VideoReceiveStatusChangedEventArgs() Properties MediaReceiveStatus The media receive status. Declaration public MediaReceiveStatus MediaReceiveStatus { get; set; } Property Value Type Description MediaReceiveStatus MediaType MediaType of the video socket raising the event. This could be Video or Vbss. Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType SocketId Socket Id associated with the video receive event Declaration public int SocketId { get; set; } Property Value Type Description Int32" }, - "common/Microsoft.Graph.Communications.Common.Transport.ResponseStatus.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.ResponseStatus.html", - "title": "Enum ResponseStatus", - "keywords": "Enum ResponseStatus Different status of IGraphResponse . Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public enum ResponseStatus Fields Name Description Accepted The request was successfully accepted. BadRequest The request was semantically/syntactically invalid. Conflict There was a conflict in processing the request. Created The request resource was successfully created. Forbidden The request was forbidden. InternalServerError The request resulted in an internal server error. MultiStatus The multi status response. NoContent There was no content in the response. NotFound The requested resource was not found. NotImplemented The not implemented Ok The request was successfully processed. RequestTimeout Client did not send a request within the time the server was expecting the request. ServiceUnavailable The server is temporarily unavailable. TooManyRequests Too many requests were tried. Unauthorized The request was not authorized by the callee. Extension Methods AdditionalDataExtensions.SetInAdditionalData(String, Object) Extensions.Pin() Extensions.ChangeType(Type) Extensions.ChangeType() Extensions.TryDispose(IGraphLogger) EnumUtils.GetDescription() ReflectionUtils.GetPropertyUsingReflection(String) ReflectionUtils.SetPropertyUsingReflection(String, Object) Validator.IsNull(String, String) Validator.NotNull(String, String) Validator.Equals(ResponseStatus, String, String) Validator.Equals(ResponseStatus, String) Validator.NotEquals(ResponseStatus, String, String) GraphResponseExtensions.ToHttpStatus()" + "core/Microsoft.Graph.ContractsConstants.Signature.html": { + "href": "core/Microsoft.Graph.ContractsConstants.Signature.html", + "title": "Class ContractsConstants.Signature", + "keywords": "Class ContractsConstants.Signature Signature for Assembly visibility. Inheritance Object ContractsConstants.Signature Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Signature Fields VisibleToCastle Visible to property added to InternalsVisibleTo Castle signed builds. Declaration public const string VisibleToCastle = \", PublicKey=0024000004800000940000000602000000240000525341310004000001000100c547cac37abd99c8db225ef2f6c8a3602f3b3606cc9891605d02baa56104f4cfc0734aa39b93bf7852f7d9266654753cc297e7d2edfe0bac1cdcf9f717241550e0a7b191195b7667bb4f64bcb8e2121380fd1d9d46ad2d92d2d15605093924cceaf74c4861eff62abf69b9291ed0a340e113be11e6a7d3113e92484cf7045cc7\" Field Value Type Description String VisibleToMicrosoft Visible to property added to InternalsVisibleTo Microsoft signed builds. Declaration public const string VisibleToMicrosoft = \", PublicKey=0024000004800000940000000602000000240000525341310004000001000100b5fc90e7027f67871e773a8fde8938c81dd402ba65b9201d60593e96c492651e889cc13f1415ebb53fac1131ae0bd333c5ee6021672d9718ea31a8aebd0da0072f25d87dba6fc90ffd598ed4da35e44c398c454307e8e33b8426143daec9f596836f97c8f74750e5975c64e2189f45def46b2a2b1247adc3652bf5c308055da9\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Exceptions.html": { - "href": "common/Microsoft.Graph.Communications.Common.Exceptions.html", - "title": "Namespace Microsoft.Graph.Communications.Common.Exceptions", - "keywords": "Namespace Microsoft.Graph.Communications.Common.Exceptions Classes ConfigurationException Configuration is bad. Mandatory configuration setting is missing. Or raw (string) setting value can not be converted to property type. InvalidStateTransitionException Exception to throw when a invalid transition is requested RoutingBadRequestException Indicate there's a bad request RoutingException Generic routing exception" + "core/Microsoft.Graph.ContractsConstants.NotificationProperties.html": { + "href": "core/Microsoft.Graph.ContractsConstants.NotificationProperties.html", + "title": "Class ContractsConstants.NotificationProperties", + "keywords": "Class ContractsConstants.NotificationProperties Notification properties constants Inheritance Object ContractsConstants.NotificationProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class NotificationProperties Fields ResourceData The resource data Declaration public const string ResourceData = \"resourceData\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.OData.html": { - "href": "common/Microsoft.Graph.Communications.Common.OData.html", - "title": "Namespace Microsoft.Graph.Communications.Common.OData", - "keywords": "Namespace Microsoft.Graph.Communications.Common.OData Classes CamelCaseStringEnumConverter Converts an System.Enum to and from its name string value. When converting to its string value it will use camelCase formatting. ODataConfiguration OData Configuration object to be used for different classes. ODataConstants The OData constants. ODataJsonConverter Handles resolving interfaces to the correct derived class during serialization/deserialization. ODataResolver Contract resolver that allows us to create OData json payloads with type information. ODataSerializeAsTypeAttribute Specify how a given object should be written/read on the wire. ODataTimeSpanConverter Custom json converter for TimeSpans." + "core/Microsoft.Graph.ContractsConstants.IdentityProperties.html": { + "href": "core/Microsoft.Graph.ContractsConstants.IdentityProperties.html", + "title": "Class ContractsConstants.IdentityProperties", + "keywords": "Class ContractsConstants.IdentityProperties Identity properties constants Inheritance Object ContractsConstants.IdentityProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class IdentityProperties Fields ApplicationInstance The application instance identity. Declaration public const string ApplicationInstance = \"applicationInstance\" Field Value Type Description String Encrypted The encrypted identity. Declaration public const string Encrypted = \"encrypted\" Field Value Type Description String Guest The guest identity. Declaration public const string Guest = \"guest\" Field Value Type Description String Hidden The hidden identity. Declaration public const string Hidden = \"hidden\" Field Value Type Description String IdentityProvider The identity provider TODO: Deprecated Declaration public const string IdentityProvider = \"identityProvider\" Field Value Type Description String IdentityProviderAAD The AAD identity provider TODO: Deprecated Declaration public const string IdentityProviderAAD = \"AAD\" Field Value Type Description String IdentityProviderMSA The MSA identity provider TODO: Deprecated Declaration public const string IdentityProviderMSA = \"MSA\" Field Value Type Description String IdentityProviderNone The None identity provider TODO: Deprecated Declaration public const string IdentityProviderNone = \"None\" Field Value Type Description String OnPremises The on-premises identity. Declaration public const string OnPremises = \"onPremises\" Field Value Type Description String Phone The phone identity. Declaration public const string Phone = \"phone\" Field Value Type Description String TenantId The tenant identity. Declaration public const string TenantId = \"tenantId\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Transport.HttpRequestMessageExtensions.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.HttpRequestMessageExtensions.html", - "title": "Class HttpRequestMessageExtensions", - "keywords": "Class HttpRequestMessageExtensions Extensions for HttpRequestMessage . Inheritance Object HttpRequestMessageExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpRequestMessageExtensions Methods Add(HttpHeaders, IGraphProperty) Adds the header. Declaration public static void Add(this HttpHeaders headers, IGraphProperty property) Parameters Type Name Description HttpHeaders headers The headers. IGraphProperty property The property. CloneHttpRequestMessageAsync(HttpRequestMessage) Clones the HTTP request message. Declaration public static Task CloneHttpRequestMessageAsync(this HttpRequestMessage req) Parameters Type Name Description HttpRequestMessage req The req. Returns Type Description Task < HttpRequestMessage > Cloned request message GetHttpAndContentHeaders(HttpRequestMessage) Gets headers from the http request and the content. Declaration public static IEnumerable>> GetHttpAndContentHeaders(this HttpRequestMessage message) Parameters Type Name Description HttpRequestMessage message The message. Returns Type Description IEnumerable < KeyValuePair < String , IEnumerable < String >>> The list of http and content headers. ToGraphRequestAsync(HttpRequestMessage) Converts a HttpRequestMessage into a IGraphRequest . Declaration public static Task ToGraphRequestAsync(this HttpRequestMessage httpRequest) Parameters Type Name Description HttpRequestMessage httpRequest HttpRequestMessage to be converted. Returns Type Description Task < IGraphRequest > IGraphRequest object corresponding to httpRequest ToGraphRequestAsync(HttpRequestMessage, JsonSerializerSettings) Converts a HttpRequestMessage into a IGraphRequest . Declaration public static Task> ToGraphRequestAsync(this HttpRequestMessage httpRequest, JsonSerializerSettings serializerSettings = null) Parameters Type Name Description HttpRequestMessage httpRequest HttpRequestMessage to be converted. Newtonsoft.Json.JsonSerializerSettings serializerSettings Json serializer settings. Returns Type Description Task < IGraphRequest > IGraphRequest object corresponding to httpRequest Type Parameters Name Description T Type of the content present in httpRequest ToRequestType(HttpMethod) Convert HttpMethod to the type of the request. Declaration public static RequestType ToRequestType(this HttpMethod httpMethod) Parameters Type Name Description HttpMethod httpMethod The HTTP method. Returns Type Description RequestType RequestType corresponding to the httpMethod Exceptions Type Condition InvalidOperationException Thrown if httpMethod has no corresponding RequestType" + "core/Microsoft.Graph.ContractsConstants.EntityContainerNames.html": { + "href": "core/Microsoft.Graph.ContractsConstants.EntityContainerNames.html", + "title": "Class ContractsConstants.EntityContainerNames", + "keywords": "Class ContractsConstants.EntityContainerNames Singleton/EntitySet constants Inheritance Object ContractsConstants.EntityContainerNames Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class EntityContainerNames Fields Application The application singleton root. Compatible for old path. Declaration public const string Application = \"app\" Field Value Type Description String CallRecords The \"callRecords\" Declaration public const string CallRecords = \"callRecords\" Field Value Type Description String Communications The communications singleton for v1. Declaration public const string Communications = \"communications\" Field Value Type Description String Me The \"me\" Declaration public const string Me = \"me\" Field Value Type Description String Presence The \"presence\" Declaration public const string Presence = \"presence\" Field Value Type Description String Users The users Declaration public const string Users = \"users\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphClientFactory.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphClientFactory.html", - "title": "Interface IGraphClientFactory", - "keywords": "Interface IGraphClientFactory Interface for factory of IGraphClient . Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphClientFactory Methods Create(IGraphLogger) Creates a new IGraphClient . Declaration IGraphClient Create(IGraphLogger logger = null) Parameters Type Name Description IGraphLogger logger An optional IGraphLogger logger to be used in the new IGraphClient . Returns Type Description IGraphClient The IGraphClient . Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "core/Microsoft.Graph.Communications.Core.CommsConstants.html": { + "href": "core/Microsoft.Graph.Communications.Core.CommsConstants.html", + "title": "Class CommsConstants", + "keywords": "Class CommsConstants The communications constants. Inheritance Object CommsConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class CommsConstants" }, - "core/Microsoft.Graph.Communications.Core.Serialization.html": { - "href": "core/Microsoft.Graph.Communications.Core.Serialization.html", - "title": "Namespace Microsoft.Graph.Communications.Core.Serialization", - "keywords": "Namespace Microsoft.Graph.Communications.Core.Serialization Classes CommsSerializer An interface for serializing and deserializing JSON objects. This serializer is used throughout the Communications workload to provide extra functionality. Specifically it supports more robust serialization/deserialization of @odata.type property and deserialization of open type additional data." + "core/Microsoft.Graph.Communications.Core.CommsConstants.HttpPropertyNames.html": { + "href": "core/Microsoft.Graph.Communications.Core.CommsConstants.HttpPropertyNames.html", + "title": "Class CommsConstants.HttpPropertyNames", + "keywords": "Class CommsConstants.HttpPropertyNames Constants used for HTTP property names Inheritance Object CommsConstants.HttpPropertyNames Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class HttpPropertyNames Fields ResponseHeaders The Response Headers string Declaration public const string ResponseHeaders = \"responseHeaders\" Field Value Type Description String StatusCode The Status Code string Declaration public const string StatusCode = \"statusCode\" Field Value Type Description String" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.html", - "title": "Namespace Microsoft.Graph.Communications.Calls.Media", - "keywords": "Namespace Microsoft.Graph.Communications.Calls.Media Classes AudioSendBuffer Creates an Audio Buffer for Send and also implements Dispose MediaCallExtensions Stateful call media extensions MediaCommunicationsClientBuilderExtensions The stateful client builder extension. MediaCommunicationsClientExtensions The stateful client extension. MediaSession MediaSession.MediaProperties Gets the media properties. VideoSendBuffer Creates a Video Buffer for Send and also implements Dispose Interfaces ILocalMediaSession" + "bot_media/Microsoft.Skype.Bots.Media.VideoFormat.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoFormat.html", + "title": "Class VideoFormat", + "keywords": "Class VideoFormat VideoFormat Inheritance Object VideoFormat Implements IEquatable < VideoFormat > Inherited Members Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoFormat : IEquatable Fields H264_1280x720_1_875Fps H264 1280x720 1.875fps video format Declaration public static readonly VideoFormat H264_1280x720_1_875Fps Field Value Type Description VideoFormat H264_1280x720_15Fps H264 1280x720 15fps video format Declaration public static readonly VideoFormat H264_1280x720_15Fps Field Value Type Description VideoFormat H264_1280x720_3_75Fps H264 1280x720 3.75fps video format Declaration public static readonly VideoFormat H264_1280x720_3_75Fps Field Value Type Description VideoFormat H264_1280x720_30Fps H264 1280x720 30fps video format Declaration public static readonly VideoFormat H264_1280x720_30Fps Field Value Type Description VideoFormat H264_1280x720_7_5Fps H264 1280x720 7.5fps video format Declaration public static readonly VideoFormat H264_1280x720_7_5Fps Field Value Type Description VideoFormat H264_1920x1080_1_875Fps H264 1920x1080 1.875fps video format Declaration public static readonly VideoFormat H264_1920x1080_1_875Fps Field Value Type Description VideoFormat H264_1920x1080_15Fps H264 1920x1080 15fps video format Declaration public static readonly VideoFormat H264_1920x1080_15Fps Field Value Type Description VideoFormat H264_1920x1080_3_75Fps H264 1920x1080 3.75fps video format Declaration public static readonly VideoFormat H264_1920x1080_3_75Fps Field Value Type Description VideoFormat H264_1920x1080_30Fps H264 1920x1080 30fps video format Declaration public static readonly VideoFormat H264_1920x1080_30Fps Field Value Type Description VideoFormat H264_1920x1080_7_5Fps H264 1920x1080 7.5fps video format Declaration public static readonly VideoFormat H264_1920x1080_7_5Fps Field Value Type Description VideoFormat H264_320x180_1_875Fps H264 320x180 1.875fps video format Declaration public static readonly VideoFormat H264_320x180_1_875Fps Field Value Type Description VideoFormat H264_320x180_15Fps H264 320x180 15fps video format Declaration public static readonly VideoFormat H264_320x180_15Fps Field Value Type Description VideoFormat H264_320x180_3_75Fps H264 320x180 3.75fps video format Declaration public static readonly VideoFormat H264_320x180_3_75Fps Field Value Type Description VideoFormat H264_320x180_7_5Fps H264 320x180 7.5fps video format Declaration public static readonly VideoFormat H264_320x180_7_5Fps Field Value Type Description VideoFormat H264_424x240_15Fps H264 424x240 15fps video format Declaration public static readonly VideoFormat H264_424x240_15Fps Field Value Type Description VideoFormat H264_640x360_15Fps H264 640x360 15fps video format Declaration public static readonly VideoFormat H264_640x360_15Fps Field Value Type Description VideoFormat H264_640x360_30Fps H264 640x360 30fps video format Declaration public static readonly VideoFormat H264_640x360_30Fps Field Value Type Description VideoFormat H264_960x540_30Fps H264 960x540 30fps video format Declaration public static readonly VideoFormat H264_960x540_30Fps Field Value Type Description VideoFormat NV12_1080x1920_30Fps NV12 1080x1920 30fps video format Declaration public static readonly VideoFormat NV12_1080x1920_30Fps Field Value Type Description VideoFormat NV12_1280x720_1_875Fps NV12 1280x720 1.875fps video format Declaration public static readonly VideoFormat NV12_1280x720_1_875Fps Field Value Type Description VideoFormat NV12_1280x720_15Fps NV12 1280x720 15fps video format Declaration public static readonly VideoFormat NV12_1280x720_15Fps Field Value Type Description VideoFormat NV12_1280x720_3_75Fps NV12 1280x720 3.75fps video format Declaration public static readonly VideoFormat NV12_1280x720_3_75Fps Field Value Type Description VideoFormat NV12_1280x720_30Fps NV12 1280x720 30fps video format Declaration public static readonly VideoFormat NV12_1280x720_30Fps Field Value Type Description VideoFormat NV12_1280x720_7_5Fps NV12 1280x720 7.5fps video format Declaration public static readonly VideoFormat NV12_1280x720_7_5Fps Field Value Type Description VideoFormat NV12_180x320_30Fps NV12 180x320 15fps video format Declaration public static readonly VideoFormat NV12_180x320_30Fps Field Value Type Description VideoFormat NV12_1920x1080_1_875Fps NV12 1920x1080 1.875fps video format Declaration public static readonly VideoFormat NV12_1920x1080_1_875Fps Field Value Type Description VideoFormat NV12_1920x1080_15Fps NV12 1920x1080 15fps video format Declaration public static readonly VideoFormat NV12_1920x1080_15Fps Field Value Type Description VideoFormat NV12_1920x1080_3_75Fps NV12 1920x1080 3.75fps video format Declaration public static readonly VideoFormat NV12_1920x1080_3_75Fps Field Value Type Description VideoFormat NV12_1920x1080_30Fps NV12 1920x1080 30fps video format Declaration public static readonly VideoFormat NV12_1920x1080_30Fps Field Value Type Description VideoFormat NV12_1920x1080_7_5Fps NV12 1920x1080 7.5fps video format Declaration public static readonly VideoFormat NV12_1920x1080_7_5Fps Field Value Type Description VideoFormat NV12_240x424_15Fps NV12 240x424 15fps video format Declaration public static readonly VideoFormat NV12_240x424_15Fps Field Value Type Description VideoFormat NV12_270x480_15Fps NV12 270x480 15fps video format Declaration public static readonly VideoFormat NV12_270x480_15Fps Field Value Type Description VideoFormat NV12_320x180_15Fps NV12 320x180 15fps video format Declaration public static readonly VideoFormat NV12_320x180_15Fps Field Value Type Description VideoFormat NV12_360x640_15Fps NV12 360x640 15fps video format Declaration public static readonly VideoFormat NV12_360x640_15Fps Field Value Type Description VideoFormat NV12_360x640_30Fps NV12 360x640 30fps video format Declaration public static readonly VideoFormat NV12_360x640_30Fps Field Value Type Description VideoFormat NV12_424x240_15Fps NV12 424x240 15fps video format Declaration public static readonly VideoFormat NV12_424x240_15Fps Field Value Type Description VideoFormat NV12_480x270_15Fps NV12 480x270 15fps video format Declaration public static readonly VideoFormat NV12_480x270_15Fps Field Value Type Description VideoFormat NV12_480x848_30Fps NV12 480x848 30fps video format Declaration public static readonly VideoFormat NV12_480x848_30Fps Field Value Type Description VideoFormat NV12_540x960_30Fps NV12 540x960 30fps video format Declaration public static readonly VideoFormat NV12_540x960_30Fps Field Value Type Description VideoFormat NV12_640x360_15Fps NV12 640x360 15fps video format Declaration public static readonly VideoFormat NV12_640x360_15Fps Field Value Type Description VideoFormat NV12_640x360_30Fps NV12 640x360 30fps video format Declaration public static readonly VideoFormat NV12_640x360_30Fps Field Value Type Description VideoFormat NV12_720x1280_30Fps NV12 720x1280 30fps video format Declaration public static readonly VideoFormat NV12_720x1280_30Fps Field Value Type Description VideoFormat NV12_848x480_30Fps NV12 848x480 30fps video format Declaration public static readonly VideoFormat NV12_848x480_30Fps Field Value Type Description VideoFormat NV12_960x540_30Fps NV12 960x540 30fps video format Declaration public static readonly VideoFormat NV12_960x540_30Fps Field Value Type Description VideoFormat Rgb24_1080x1920_30Fps Rgb24 1080x1920 30fps video format Declaration public static readonly VideoFormat Rgb24_1080x1920_30Fps Field Value Type Description VideoFormat Rgb24_1280x720_1_875Fps Rgb24 1280x720 1.875fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_1_875Fps Field Value Type Description VideoFormat Rgb24_1280x720_15Fps Rgb24 1280x720 15fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_15Fps Field Value Type Description VideoFormat Rgb24_1280x720_3_75Fps Rgb24 1280x720 3.75fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_3_75Fps Field Value Type Description VideoFormat Rgb24_1280x720_30Fps Rgb24 1280x720 30fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_30Fps Field Value Type Description VideoFormat Rgb24_1280x720_7_5Fps Rgb24 1280x720 7.5fps video format Declaration public static readonly VideoFormat Rgb24_1280x720_7_5Fps Field Value Type Description VideoFormat Rgb24_180x320_30Fps Rgb24 180x320 15fps video format Declaration public static readonly VideoFormat Rgb24_180x320_30Fps Field Value Type Description VideoFormat Rgb24_1920x1080_1_875Fps Rgb24 1920x1080 1.875fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_1_875Fps Field Value Type Description VideoFormat Rgb24_1920x1080_15Fps Rgb24 1920x1080 15fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_15Fps Field Value Type Description VideoFormat Rgb24_1920x1080_3_75Fps Rgb24 1920x1080 3.75fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_3_75Fps Field Value Type Description VideoFormat Rgb24_1920x1080_30Fps Rgb24 1920x1080 30fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_30Fps Field Value Type Description VideoFormat Rgb24_1920x1080_7_5Fps Rgb24 1920x1080 7.5fps video format Declaration public static readonly VideoFormat Rgb24_1920x1080_7_5Fps Field Value Type Description VideoFormat Rgb24_240x424_15Fps Rgb24 240x424 15fps video format Declaration public static readonly VideoFormat Rgb24_240x424_15Fps Field Value Type Description VideoFormat Rgb24_270x480_15Fps Rgb24 270x480 15fps video format Declaration public static readonly VideoFormat Rgb24_270x480_15Fps Field Value Type Description VideoFormat Rgb24_320x180_15Fps Rgb24 320x180 15fps video format Declaration public static readonly VideoFormat Rgb24_320x180_15Fps Field Value Type Description VideoFormat Rgb24_360x640_15Fps Rgb24 360x640 15fps video format Declaration public static readonly VideoFormat Rgb24_360x640_15Fps Field Value Type Description VideoFormat Rgb24_360x640_30Fps Rgb24 360x640 30fps video format Declaration public static readonly VideoFormat Rgb24_360x640_30Fps Field Value Type Description VideoFormat Rgb24_424x240_15Fps Rgb24 424x240 15fps video format Declaration public static readonly VideoFormat Rgb24_424x240_15Fps Field Value Type Description VideoFormat Rgb24_480x270_15Fps Rgb24 480x270 15fps video format Declaration public static readonly VideoFormat Rgb24_480x270_15Fps Field Value Type Description VideoFormat Rgb24_480x848_30Fps Rgb24 480x848 30fps video format Declaration public static readonly VideoFormat Rgb24_480x848_30Fps Field Value Type Description VideoFormat Rgb24_540x960_30Fps Rgb24 540x960 30fps video format Declaration public static readonly VideoFormat Rgb24_540x960_30Fps Field Value Type Description VideoFormat Rgb24_640x360_15Fps Rgb24 640x360 15fps video format Declaration public static readonly VideoFormat Rgb24_640x360_15Fps Field Value Type Description VideoFormat Rgb24_640x360_30Fps Rgb24 640x360 30fps video format Declaration public static readonly VideoFormat Rgb24_640x360_30Fps Field Value Type Description VideoFormat Rgb24_720x1280_30Fps Rgb24 720x1280 30fps video format Declaration public static readonly VideoFormat Rgb24_720x1280_30Fps Field Value Type Description VideoFormat Rgb24_848x480_30Fps Rgb24 848x480 30fps video format Declaration public static readonly VideoFormat Rgb24_848x480_30Fps Field Value Type Description VideoFormat Rgb24_960x540_30Fps Rgb24 960x540 30fps video format Declaration public static readonly VideoFormat Rgb24_960x540_30Fps Field Value Type Description VideoFormat Yuy2_1080x1920_30Fps YUY2 1080x1920 30fps video format Declaration public static readonly VideoFormat Yuy2_1080x1920_30Fps Field Value Type Description VideoFormat Yuy2_1280x720_1_875Fps YUY2 1280x720 1.875fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_1_875Fps Field Value Type Description VideoFormat Yuy2_1280x720_15Fps YUY2 1280x720 15fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_15Fps Field Value Type Description VideoFormat Yuy2_1280x720_3_75Fps YUY2 1280x720 3.75fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_3_75Fps Field Value Type Description VideoFormat Yuy2_1280x720_30Fps YUY2 1280x720 30fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_30Fps Field Value Type Description VideoFormat Yuy2_1280x720_7_5Fps YUY2 1280x720 7.5fps video format Declaration public static readonly VideoFormat Yuy2_1280x720_7_5Fps Field Value Type Description VideoFormat Yuy2_180x320_30Fps YUY2 180x320 15fps video format Declaration public static readonly VideoFormat Yuy2_180x320_30Fps Field Value Type Description VideoFormat Yuy2_1920x1080_1_875Fps YUY2 1920x1080 1.875fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_1_875Fps Field Value Type Description VideoFormat Yuy2_1920x1080_15Fps YUY2 1920x1080 15fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_15Fps Field Value Type Description VideoFormat Yuy2_1920x1080_3_75Fps YUY2 1920x1080 3.75fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_3_75Fps Field Value Type Description VideoFormat Yuy2_1920x1080_30Fps YUY2 1920x1080 30fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_30Fps Field Value Type Description VideoFormat Yuy2_1920x1080_7_5Fps YUY2 1920x1080 7.5fps video format Declaration public static readonly VideoFormat Yuy2_1920x1080_7_5Fps Field Value Type Description VideoFormat Yuy2_240x424_15Fps YUY2 240x424 15fps video format Declaration public static readonly VideoFormat Yuy2_240x424_15Fps Field Value Type Description VideoFormat Yuy2_270x480_15Fps YUY2 270x480 15fps video format Declaration public static readonly VideoFormat Yuy2_270x480_15Fps Field Value Type Description VideoFormat Yuy2_320x180_15Fps YUY2 320x180 15fps video format Declaration public static readonly VideoFormat Yuy2_320x180_15Fps Field Value Type Description VideoFormat Yuy2_360x640_15Fps YUY2 360x640 15fps video format Declaration public static readonly VideoFormat Yuy2_360x640_15Fps Field Value Type Description VideoFormat Yuy2_360x640_30Fps YUY2 360x640 30fps video format Declaration public static readonly VideoFormat Yuy2_360x640_30Fps Field Value Type Description VideoFormat Yuy2_424x240_15Fps YUY2 424x240 15fps video format Declaration public static readonly VideoFormat Yuy2_424x240_15Fps Field Value Type Description VideoFormat Yuy2_480x270_15Fps YUY2 480x270 15fps video format Declaration public static readonly VideoFormat Yuy2_480x270_15Fps Field Value Type Description VideoFormat Yuy2_480x848_30Fps YUY2 480x848 30fps video format Declaration public static readonly VideoFormat Yuy2_480x848_30Fps Field Value Type Description VideoFormat Yuy2_540x960_30Fps YUY2 540x960 30fps video format Declaration public static readonly VideoFormat Yuy2_540x960_30Fps Field Value Type Description VideoFormat Yuy2_640x360_15Fps YUY2 640x360 15fps video format Declaration public static readonly VideoFormat Yuy2_640x360_15Fps Field Value Type Description VideoFormat Yuy2_640x360_30Fps YUY2 640x360 30fps video format Declaration public static readonly VideoFormat Yuy2_640x360_30Fps Field Value Type Description VideoFormat Yuy2_720x1280_30Fps YUY2 720x1280 30fps video format Declaration public static readonly VideoFormat Yuy2_720x1280_30Fps Field Value Type Description VideoFormat Yuy2_848x480_30Fps YUY2 848x480 30fps video format Declaration public static readonly VideoFormat Yuy2_848x480_30Fps Field Value Type Description VideoFormat Yuy2_960x540_30Fps YUY2 960x540 30fps video format Declaration public static readonly VideoFormat Yuy2_960x540_30Fps Field Value Type Description VideoFormat Properties BitRate Bit rate Declaration public uint BitRate { get; } Property Value Type Description UInt32 FrameRate Frame rate Declaration public float FrameRate { get; } Property Value Type Description Single Height Height Declaration public int Height { get; } Property Value Type Description Int32 VideoColorFormat VideoColorFormat Declaration public VideoColorFormat VideoColorFormat { get; } Property Value Type Description VideoColorFormat Width Width Declaration public int Width { get; } Property Value Type Description Int32 Methods Equals(VideoFormat) Equals to compare videoformat objects Declaration public bool Equals(VideoFormat videoFormat) Parameters Type Name Description VideoFormat videoFormat Returns Type Description Boolean Equals(Object) Overrides base Equals to compare objects Declaration public override bool Equals(object obj) Parameters Type Name Description Object obj Returns Type Description Boolean Overrides Object.Equals(Object) GetHashCode() Custom GetHashCode implementation Declaration public override int GetHashCode() Returns Type Description Int32 Overrides Object.GetHashCode() ToString() Provides video format details by overriding the default ToString(). Declaration public override string ToString() Returns Type Description String Details of VideoFormat. Overrides Object.ToString() Operators Equality(VideoFormat, VideoFormat) Overload == operator to do VideoFormat comparison Declaration public static bool operator ==(VideoFormat a, VideoFormat b) Parameters Type Name Description VideoFormat a VideoFormat b Returns Type Description Boolean Inequality(VideoFormat, VideoFormat) Overload != operator to do VideoFormat comparison Declaration public static bool operator !=(VideoFormat a, VideoFormat b) Parameters Type Name Description VideoFormat a VideoFormat b Returns Type Description Boolean Implements System.IEquatable" }, - "client/Microsoft.Graph.Communications.Client.ICommunicationsClientBuilder.html": { - "href": "client/Microsoft.Graph.Communications.Client.ICommunicationsClientBuilder.html", - "title": "Interface ICommunicationsClientBuilder", - "keywords": "Interface ICommunicationsClientBuilder The builder object that builds the ICommunicationsClient . Use this class to setup the SDK's configuration. Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface ICommunicationsClientBuilder Properties Id Gets the client id. Declaration Guid Id { get; } Property Value Type Description Guid Methods Build() Build and return the stateful client object. Declaration ICommunicationsClient Build() Returns Type Description ICommunicationsClient The ICommunicationsClient . Exceptions Type Condition ArgumentException Cannot build the client without setting the required parameters. SetAuthenticationProvider(IRequestAuthenticationProvider) Sets the custom authentication provider. The authentication provider would add authentication to outbound requests and validates any inbound requests. See IRequestAuthenticationProvider Declaration ICommunicationsClientBuilder SetAuthenticationProvider(IRequestAuthenticationProvider provider) Parameters Type Name Description IRequestAuthenticationProvider provider The authentication provider. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the provider is null . SetCacheStrategy(ICache) Sets the cache strategy. Declaration ICommunicationsClientBuilder SetCacheStrategy(ICache cacheStrategy) Parameters Type Name Description ICache cacheStrategy The cache strategy. Returns Type Description ICommunicationsClientBuilder This ICommunicationsClientBuilder object. Exceptions Type Condition ArgumentNullException If the cacheStrategy strategy is null . SetHttpClient(HttpClient, IEnumerable>) Sets the http client. Use a custom HTTP Client instead of the one generated by the SDK. Declaration ICommunicationsClientBuilder SetHttpClient(HttpClient httpClient, IEnumerable> defaultHeaders = null) Parameters Type Name Description HttpClient httpClient The place call endpoint URL. IEnumerable < KeyValuePair < String , String >> defaultHeaders The default headers. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the httpClient is null . SetNotificationUrl(Uri) Set the notification uri for your bot. This is the default notification url for the bot. This can be overriden on a per-resource basis depending on the API support. Declaration ICommunicationsClientBuilder SetNotificationUrl(Uri notificationUrl) Parameters Type Name Description Uri notificationUrl The callback Url. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the notificationUrl is null . ArgumentException URI must be https. SetServiceBaseUrl(Uri) Sets the service base URL. This set's the Endpoint URL for the service. Declaration ICommunicationsClientBuilder SetServiceBaseUrl(Uri serviceBaseUrl) Parameters Type Name Description Uri serviceBaseUrl The place call endpoint URL. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the serviceBaseUrl is null . ArgumentException URI must be https." + "bot_media/Microsoft.Skype.Bots.Media.PerfCounterConfiguration.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.PerfCounterConfiguration.html", + "title": "Class PerfCounterConfiguration", + "keywords": "Class PerfCounterConfiguration Perf counter configuration Inheritance Object PerfCounterConfiguration Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class PerfCounterConfiguration Constructors PerfCounterConfiguration() Constructor Declaration public PerfCounterConfiguration() Properties UseMPAzureAppHostPerfCounterProvider If set to true, will use MPAzureAppHost's default perf counter provider which uses the registered win32 perf counters Otherwise, will use the in-memory MPPerfCounterProvider that doesn't load win32 perf counters Declaration public bool UseMPAzureAppHostPerfCounterProvider { get; set; } Property Value Type Description Boolean VerifyPerfCounterConfiguration Default is true If set to false, will not verify the perf counter configuration of the bot (MediaPerf.dll and/or MP perf counters) Declaration public bool VerifyPerfCounterConfiguration { get; set; } Property Value Type Description Boolean Methods IsValidConfiguration(PerfCounterConfiguration) Checks if the config is valid Declaration public static bool IsValidConfiguration(PerfCounterConfiguration perfConfig) Parameters Type Name Description PerfCounterConfiguration perfConfig Returns Type Description Boolean ToString() ToString override Declaration public override string ToString() Returns Type Description String Overrides Object.ToString()" }, - "common/Microsoft.Graph.Communications.Common.ObjectRoot.html": { - "href": "common/Microsoft.Graph.Communications.Common.ObjectRoot.html", - "title": "Class ObjectRoot", - "keywords": "Class ObjectRoot Base object. Inheritance Object ObjectRoot Observable GraphLoggerShim GraphHttpClient GraphHttpClientFactory Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public abstract class ObjectRoot Constructors ObjectRoot(IGraphLogger) Initializes a new instance of the ObjectRoot class. Declaration protected ObjectRoot(IGraphLogger logger) Parameters Type Name Description IGraphLogger logger Logger instance. Properties GraphLogger Gets the logger. Declaration protected IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "calls_media/Microsoft.Graph.Communications.Calls.Media.VideoSendBuffer.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.VideoSendBuffer.html", + "title": "Class VideoSendBuffer", + "keywords": "Class VideoSendBuffer Creates a Video Buffer for Send and also implements Dispose Inheritance Object VideoSendBuffer Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public class VideoSendBuffer : VideoMediaBuffer Constructors VideoSendBuffer(Byte[], UInt32, VideoFormat, Int64) Initializes a new instance of the VideoSendBuffer class. Declaration public VideoSendBuffer(byte[] buffer, uint length, VideoFormat format, long timeStamp = 0L) Parameters Type Name Description Byte [] buffer The buffer. UInt32 length The length. VideoFormat format The format. Int64 timeStamp The time stamp. VideoSendBuffer(IntPtr, Int64, VideoFormat, Int64) Initializes a new instance of the VideoSendBuffer class. Declaration public VideoSendBuffer(IntPtr data, long length, VideoFormat videoFormat, long timeStamp = 0L) Parameters Type Name Description IntPtr data The data. Int64 length The length. VideoFormat videoFormat The video format. Int64 timeStamp The time stamp. Methods Dispose(Boolean) Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing" }, - "client/Microsoft.Graph.Communications.Client.Notifications.FixedSizeQueue-1.html": { - "href": "client/Microsoft.Graph.Communications.Client.Notifications.FixedSizeQueue-1.html", - "title": "Class FixedSizeQueue", - "keywords": "Class FixedSizeQueue A class that implements a fixed size list. Inheritance Object FixedSizeQueue Implements IReadOnlyCollection IEnumerable IEnumerable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client.Notifications Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class FixedSizeQueue : IReadOnlyCollection, IEnumerable, IEnumerable Type Parameters Name Description T The generic type Constructors FixedSizeQueue(Int32) Initializes a new instance of the FixedSizeQueue class. Declaration public FixedSizeQueue(int maxSize) Parameters Type Name Description Int32 maxSize The maximum size. Properties Count Gets the number of elements in the collection. Declaration public int Count { get; } Property Value Type Description Int32 Methods Enqueue(T) Enqueues the item. Declaration public void Enqueue(T item) Parameters Type Name Description T item The object. GetEnumerator() Declaration public IEnumerator GetEnumerator() Returns Type Description IEnumerator Remove(T) Removes the specified item. Declaration public void Remove(T item) Parameters Type Name Description T item The item. Explicit Interface Implementations IEnumerable.GetEnumerator() Declaration IEnumerator IEnumerable.GetEnumerator() Returns Type Description IEnumerator Implements System.Collections.Generic.IReadOnlyCollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable See Also ICollection " + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.IObfuscationEngine.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.IObfuscationEngine.html", + "title": "Interface IObfuscationEngine", + "keywords": "Interface IObfuscationEngine Obfuscation engine that can obfuscate data. Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IObfuscationEngine Properties Enabled Gets a value indicating whether obfuscation is enabled. Declaration bool Enabled { get; } Property Value Type Description Boolean ObfuscationConfiguration Gets or sets the obfuscation configuration. This is also set when configuration is linked to an obfuscation engine. Declaration ObfuscationConfiguration ObfuscationConfiguration { get; set; } Property Value Type Description ObfuscationConfiguration Methods Obfuscate(Object, ObfuscationTag) Obfuscates the specified payload. Declaration string Obfuscate(object payload, ObfuscationTag obfuscationTag) Parameters Type Name Description Object payload The payload. ObfuscationTag obfuscationTag The obfuscation tag. Returns Type Description String Obfuscated data. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphClient.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphClient.html", - "title": "Interface IGraphClient", - "keywords": "Interface IGraphClient This class abstracts any communication with different services. This client acts at an object level rather than wire level and thus providing richer experience when working with complex objects. Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphClient Properties DefaultProperties Gets the default properties. Declaration IEnumerable DefaultProperties { get; } Property Value Type Description IEnumerable < IGraphProperty > GraphLogger Gets the graph logger. Declaration IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Methods SendAsync(IGraphRequest, CancellationToken) Send a request as an asynchronous operation. Declaration Task SendAsync(IGraphRequest request, CancellationToken cancellationToken = default(CancellationToken)) where TRequest : class Parameters Type Name Description IGraphRequest request The request message to send. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IGraphResponse > The task object representing the asynchronous operation. Type Parameters Name Description TRequest Type of the content present in the request. SendAsync(IGraphRequest, CancellationToken) Send a request as an asynchronous operation. Declaration Task> SendAsync(IGraphRequest request, CancellationToken cancellationToken = default(CancellationToken)) where TRequest : class where TResponse : class Parameters Type Name Description IGraphRequest request The request message to send. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IGraphResponse > The task object representing the asynchronous operation. Type Parameters Name Description TRequest Type of the content present in the request. TResponse Type of the expected content in response. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "client/Microsoft.Graph.Communications.Client.Transport.GraphClientContext.html": { + "href": "client/Microsoft.Graph.Communications.Client.Transport.GraphClientContext.html", + "title": "Class GraphClientContext", + "keywords": "Class GraphClientContext The context for the graph client wrapper. Inheritance Object GraphClientContext Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client.Transport Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class GraphClientContext Constructors GraphClientContext() Declaration public GraphClientContext() Properties ScenarioId Gets or sets the scenario identifier. Declaration public Guid ScenarioId { get; set; } Property Value Type Description Guid TenantId Gets or sets the tenant. Declaration public string TenantId { get; set; } Property Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Transport.HttpResponseMessageExtensions.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.HttpResponseMessageExtensions.html", - "title": "Class HttpResponseMessageExtensions", - "keywords": "Class HttpResponseMessageExtensions Extensions for HttpResponseMessage class. Inheritance Object HttpResponseMessageExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpResponseMessageExtensions Methods GetHttpAndContentHeaders(HttpResponseMessage) Gets headers from the http response and the content. Declaration public static IEnumerable>> GetHttpAndContentHeaders(this HttpResponseMessage message) Parameters Type Name Description HttpResponseMessage message The message. Returns Type Description IEnumerable < KeyValuePair < String , IEnumerable < String >>> The list of http and content headers. GetOutcomeFromResponseOrException(Nullable, Exception) Try extracting outcome outcome from HTTP response status code or exception Declaration public static string GetOutcomeFromResponseOrException(int? statusCode, Exception exception) Parameters Type Name Description Nullable < Int32 > statusCode HTTP response status code Exception exception The exception Returns Type Description String Outcome string ToGraphResponseAsync(HttpResponseMessage) Converts HttpResponseMessage to an instance of IGraphResponse . Declaration public static Task ToGraphResponseAsync(this HttpResponseMessage httpResponse) Parameters Type Name Description HttpResponseMessage httpResponse HTTP response to be converted. Returns Type Description Task < IGraphResponse > IGraphResponse corresponding to httpResponse . ToGraphResponseAsync(HttpResponseMessage, JsonSerializerSettings) Converts HttpResponseMessage to an instance of IGraphResponse . Declaration public static Task> ToGraphResponseAsync(this HttpResponseMessage httpResponse, JsonSerializerSettings serializerSettings = null) where T : class Parameters Type Name Description HttpResponseMessage httpResponse HTTP response to be converted. Newtonsoft.Json.JsonSerializerSettings serializerSettings Add serializer that can serialize the content. Returns Type Description Task < IGraphResponse > IGraphResponse corresponding to httpResponse . Type Parameters Name Description T Type of the expected response." + "common/Microsoft.Graph.Communications.Common.Transport.Http.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.Http.html", + "title": "Namespace Microsoft.Graph.Communications.Common.Transport.Http", + "keywords": "Namespace Microsoft.Graph.Communications.Common.Transport.Http Classes HttpUtils Utilities for Http transport" }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphResponse.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphResponse.html", - "title": "Interface IGraphResponse", - "keywords": "Interface IGraphResponse The response got in exchange of a IGraphRequest . Inherited Members IGraphResponse.Status IGraphResponse.ReasonPhrase IGraphResponse.ErrorContent IGraphExchange.Content IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphResponse : IGraphResponse, IGraphExchange, IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphResponseExtensions.ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable)" + "common/Microsoft.Graph.Communications.Common.Transport.Http.HttpUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.Transport.Http.HttpUtils.html", + "title": "Class HttpUtils", + "keywords": "Class HttpUtils Utilities for Http transport Inheritance Object HttpUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport.Http Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpUtils Methods GetRequestTypeForHttpMethod(String) Gets the type of the request for the given http method. Declaration public static RequestType GetRequestTypeForHttpMethod(string httpMethod) Parameters Type Name Description String httpMethod The HTTP method. Returns Type Description RequestType RequestType corresponding to the httpMethod Exceptions Type Condition InvalidOperationException Thrown if httpMethod has no corresponding RequestType" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphResponseException.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphResponseException.html", - "title": "Class GraphResponseException", - "keywords": "Class GraphResponseException Class representing GraphResponseException Inheritance Object Exception GraphResponseException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphResponseException : Exception, ISerializable, _Exception Constructors GraphResponseException(IGraphResponse) Initializes a new instance of the GraphResponseException class. Declaration public GraphResponseException(IGraphResponse errorResponse) Parameters Type Name Description IGraphResponse errorResponse The error response. Properties Response Gets the response. Declaration public IGraphResponse Response { get; } Property Value Type Description IGraphResponse The response. Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also Exception" + "calls/Microsoft.Graph.Communications.Calls.JoinMeetingParameters.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.JoinMeetingParameters.html", + "title": "Class JoinMeetingParameters", + "keywords": "Class JoinMeetingParameters Class to define parameters required for joining a meeting. Inheritance Object JoinMeetingParameters Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public class JoinMeetingParameters Constructors JoinMeetingParameters(ChatInfo, MeetingInfo, IMediaSession) Initializes a new instance of the JoinMeetingParameters class. Use this constructor for app hosted media. Declaration public JoinMeetingParameters(ChatInfo chatInfo, MeetingInfo meetingInfo, IMediaSession mediaSession) Parameters Type Name Description ChatInfo chatInfo The chat information. MeetingInfo meetingInfo The meeting information. IMediaSession mediaSession The media session. JoinMeetingParameters(ChatInfo, MeetingInfo, IEnumerable, IEnumerable) Initializes a new instance of the JoinMeetingParameters class. Use this constructor for service hosted media. Declaration public JoinMeetingParameters(ChatInfo chatInfo, MeetingInfo meetingInfo, IEnumerable requestedModalities, IEnumerable prefetchPrompts = null) Parameters Type Name Description ChatInfo chatInfo The chat information. MeetingInfo meetingInfo The meeting information. IEnumerable < Modality > requestedModalities The list of modalities for the call IEnumerable < MediaInfo > prefetchPrompts The list of media files to prefetch Properties AdditionalData Gets or sets the additional data. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > AllowGuestToBypassLobby Gets or sets a value indicating whether to bypass lobby when joining a group call as guest. Declaration public bool? AllowGuestToBypassLobby { get; set; } Property Value Type Description Nullable < Boolean > ChatInfo Gets the chat information. Declaration public ChatInfo ChatInfo { get; } Property Value Type Description ChatInfo CorrelationId Gets or sets the correlation identifier. Declaration [Obsolete(\"Please use AddAsync(JoinMeetingParameters parameters, Guid scenarioId).\")] public Guid CorrelationId { get; set; } Property Value Type Description Guid GuestIdentity Gets or sets the guest identity. Declaration public Identity GuestIdentity { get; set; } Property Value Type Description Identity MediaSession Gets the media session. Declaration public IMediaSession MediaSession { get; } Property Value Type Description IMediaSession MeetingInfo Gets the meeting information. Declaration public MeetingInfo MeetingInfo { get; } Property Value Type Description MeetingInfo PrefetchPrompts Gets the list of media files to prefetch. Declaration public IEnumerable PrefetchPrompts { get; } Property Value Type Description IEnumerable < MediaInfo > RequestedModalities Gets the list of modalities to join the call with. Declaration public IEnumerable RequestedModalities { get; } Property Value Type Description IEnumerable < Modality > Subject Gets or sets the subject. Declaration public string Subject { get; set; } Property Value Type Description String TenantId Gets or sets the tenant id Declaration public string TenantId { get; set; } Property Value Type Description String" }, - "client/Microsoft.Graph.Communications.Resources.ResourceEventArgs-1.html": { - "href": "client/Microsoft.Graph.Communications.Resources.ResourceEventArgs-1.html", - "title": "Class ResourceEventArgs", - "keywords": "Class ResourceEventArgs The resource event arguments. Inheritance Object ResourceEventArgs Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class ResourceEventArgs where TEntity : Entity Type Parameters Name Description TEntity The containing NewResource type. NewResource Constructors ResourceEventArgs(TEntity, TEntity, String) Initializes a new instance of the ResourceEventArgs class. Declaration public ResourceEventArgs(TEntity oldResource, TEntity newResource, string resourcePath) Parameters Type Name Description TEntity oldResource The old resource. TEntity newResource The new resource. String resourcePath The resource path. Properties AdditionalData Gets or sets the additional data for the event. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > NewResource Gets the new resource. Declaration public TEntity NewResource { get; } Property Value Type Description TEntity OldResource Gets the old resource. Declaration public TEntity OldResource { get; } Property Value Type Description TEntity ResourcePath Gets the resource path for this resource. Declaration public string ResourcePath { get; } Property Value Type Description String" + "calls/Microsoft.Graph.Communications.Calls.IParticipantCollection.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.IParticipantCollection.html", + "title": "Interface IParticipantCollection", + "keywords": "Interface IParticipantCollection The stateful participant collection interface. Inherited Members IDisposable.Dispose() IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface IParticipantCollection : IResourceCollection, IResourceCollection, IResourceCollection, IResourceBase, IDisposable, IReadOnlyCollection, IEnumerable, IEnumerable Methods GetAsync(String, CancellationToken) Gets the participant from the collection. Declaration Task GetAsync(string participantId, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description String participantId The participant identifier. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IParticipant > The found IParticipant . Exceptions Type Condition ServiceException If the specified participant was not found. InviteAsync(IEnumerable, CancellationToken) Invites a list of participants given their identities. Declaration Task InviteAsync(IEnumerable participants, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description IEnumerable < InvitationParticipantInfo > participants The list of InvitationParticipantInfo to invite. CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The invite updates will come in on IParticipantCollection.OnUpdated Extension Methods ParticipantExtensions.InviteAsync(IParticipantCollection, IdentitySet, String, CancellationToken)" }, - "client/Microsoft.Graph.Communications.Resources.IResourceCollection.html": { - "href": "client/Microsoft.Graph.Communications.Resources.IResourceCollection.html", - "title": "Interface IResourceCollection", - "keywords": "Interface IResourceCollection The resource collection interface. Inherited Members IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResourceCollection : IResourceBase, IDisposable Methods TerminateAsync(TimeSpan) Performs collection specific terminate tasks. Declaration Task TerminateAsync(TimeSpan timeout = default(TimeSpan)) Parameters Type Name Description TimeSpan timeout The timeout. Returns Type Description Task < Boolean > True if all instances terminated successfully, false otherwise. See Also IResourceBase" + "bot_media/Microsoft.Skype.Bots.Media.VideoSocketSettings.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSocketSettings.html", + "title": "Class VideoSocketSettings", + "keywords": "Class VideoSocketSettings The video socket settings. Inheritance Object VideoSocketSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoSocketSettings Constructors VideoSocketSettings() Initializes a VideoSocketSettings object. Declaration public VideoSocketSettings() Properties CallId An alphanumeric string that uniquely identifies a call. Declaration public string CallId { get; set; } Property Value Type Description String MaxConcurrentSendStreams The maximum number of concurrent (simulcast) streams that can be sent. Declaration public uint MaxConcurrentSendStreams { get; set; } Property Value Type Description UInt32 Remarks This setting applies only if the VideoSocket uses H264 encoded video formats. MediaType Specifies the media type of the VideoSocket. Valid types are: MediaType.Video and MediaType.Vbss Declaration public MediaType? MediaType { get; set; } Property Value Type Description Nullable < MediaType > ReceiveColorFormat What color format should received video be delivered in. Currently only NV12 and H264 are allowed. Declaration public VideoColorFormat ReceiveColorFormat { get; set; } Property Value Type Description VideoColorFormat StreamDirections The directionality of the media stream. This indicates whether it is enabled to both send and receive media, or only send or only receive media. Declaration public StreamDirection StreamDirections { get; set; } Property Value Type Description StreamDirection SupportedSendVideoFormats The list of video formats the VideoSocket supports sending. Declaration public IList SupportedSendVideoFormats { get; set; } Property Value Type Description IList < VideoFormat > Remarks For the main-video modality ( MediaType.Video ), the following ten H264 send video formats are supported: H264_1920x1080_30Fps H264_1280x720_30Fps H264_960x540_30Fps H264_640x360_30Fps H264_640x360_15Fps H264_424x240_15Fps H264_320x180_15Fps H264_320x180_7_5Fps H264_320x180_3_75Fps H264_320x180_1_875Fps (If the SupportedSendVideoFormats list contains other H264 video formats for main-video, they will be ignored and not used.) At least one of the H264_320x180 video formats must be supported. For best video interoperability, the bot should support all the H264_320x180 formats. For the Vbss modality, all of the send formats must be of the same resolution. The resolution should best match the native resolution of the content to be shared. Downscaling the Vbss content to a lower resolution should be avoided (but may be necessary if the native content resolution is larger than 1080p). The bot should support as many different frame rates as possible. The 1.875 fps frame rate must be supported." }, - "client/Microsoft.Graph.Communications.Client.Cache.ServiceCache.html": { - "href": "client/Microsoft.Graph.Communications.Client.Cache.ServiceCache.html", - "title": "Class ServiceCache", - "keywords": "Class ServiceCache The cache that restores the data directly from the service. In this case there is no storage of data, as the service acts as the master. Inheritance Object ServiceCache Implements ICache Namespace : Microsoft.Graph.Communications.Client.Cache Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class ServiceCache : ObjectRootDisposable, ICache Constructors ServiceCache(IGraphLogger, IGraphClient, ISerializer, String) Initializes a new instance of the ServiceCache class. Declaration public ServiceCache(IGraphLogger logger, IGraphClient client, ISerializer serializer, string baseUri) Parameters Type Name Description IGraphLogger logger Logger instance. IGraphClient client The client. ISerializer serializer The serializer. String baseUri The base URI. Methods GetDataAsync(IEnumerable, String, CancellationToken) Gets the serialized string of the data at the specified resource path asynchronously. Fetching data only happens in HA/DR scenarios, so could take longer. Declaration public Task GetDataAsync(IEnumerable properties, string resourcePath, CancellationToken cancellationToken = default(CancellationToken)) where T : Entity Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < String > The recovered serialized data at the specified resource path. Type Parameters Name Description T The type of Entity to fetch. GetDataCollectionAsync(IEnumerable, String, CancellationToken) Gets the resource paths for the children of the collection with the specified resource path asynchronously. Fetching data only happens in HA/DR scenarios, so could take longer. Declaration public Task> GetDataCollectionAsync(IEnumerable properties, string resourcePath, CancellationToken cancellationToken = default(CancellationToken)) where T : Entity Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IEnumerable < String >> The recovered collection or child resource paths. Type Parameters Name Description T The type of Entity contained in the collection. SetData(ChangeType, IResource, IEnumerable, String, Lazy) Sets the data under the specified resource path. These should be short running operations, as they block notification callbacks. Declaration public void SetData(ChangeType change, IResource resource, IEnumerable properties, string resourcePath, Lazy serializedData) Parameters Type Name Description ChangeType change The type of change occuring. IResource resource The resource being serialized. IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. Lazy < String > serializedData The serialized data lazy string. For performance reasons the string is only serialized when requested. Implements ICache See Also ObjectRootDisposable ICache" + "bot_media/Microsoft.Skype.Bots.Media.VideoResolution.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoResolution.html", + "title": "Enum VideoResolution", + "keywords": "Enum VideoResolution Video resolution for vbss and video Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum VideoResolution Fields Name Description HD1080p 1920 X 1080 HD720p 1280 X 720 SD180p 320 X 180 SD240p 424 X 240 SD360p 640 X 360 SD540p 960 X 540" }, - "client/Microsoft.Graph.Communications.Client.Cache.ICache.html": { - "href": "client/Microsoft.Graph.Communications.Client.Cache.ICache.html", - "title": "Interface ICache", - "keywords": "Interface ICache The cache interface used to store and recover the data used by the SDK. Namespace : Microsoft.Graph.Communications.Client.Cache Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface ICache Methods GetDataAsync(IEnumerable, String, CancellationToken) Gets the serialized string of the data at the specified resource path asynchronously. Fetching data only happens in HA/DR scenarios, so could take longer. Declaration Task GetDataAsync(IEnumerable properties, string resourcePath, CancellationToken cancellationToken = default(CancellationToken)) where T : Entity Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < String > The recovered serialized data at the specified resource path. Type Parameters Name Description T The type of Entity to fetch. GetDataCollectionAsync(IEnumerable, String, CancellationToken) Gets the resource paths for the children of the collection with the specified resource path asynchronously. Fetching data only happens in HA/DR scenarios, so could take longer. Declaration Task> GetDataCollectionAsync(IEnumerable properties, string resourcePath, CancellationToken cancellationToken = default(CancellationToken)) where T : Entity Parameters Type Name Description IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < IEnumerable < String >> The recovered collection or child resource paths. Type Parameters Name Description T The type of Entity contained in the collection. SetData(ChangeType, IResource, IEnumerable, String, Lazy) Sets the data under the specified resource path. These should be short running operations, as they block notification callbacks. Declaration void SetData(ChangeType change, IResource resource, IEnumerable properties, string resourcePath, Lazy serializedData) Parameters Type Name Description ChangeType change The type of change occuring. IResource resource The resource being serialized. IEnumerable < IGraphProperty > properties The properties. String resourcePath The resource path. Lazy < String > serializedData The serialized data lazy string. For performance reasons the string is only serialized when requested." + "bot_media/Microsoft.Skype.Bots.Media.AudioSocket.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioSocket.html", + "title": "Class AudioSocket", + "keywords": "Class AudioSocket Provides Send and Receive I/O access to an audio stream. Inheritance Object AudioSocket Implements IAudioSocket IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public sealed class AudioSocket : IAudioSocket, IDisposable, IInternalAudioSocket, IInternalSocket Constructors AudioSocket(AudioSocketSettings) Initializes a new AudioSocket object. Declaration public AudioSocket(AudioSocketSettings settings) Parameters Type Name Description AudioSocketSettings settings Configuration settings for the AudioSocket Methods Dispose() Disposes the object Declaration public void Dispose() GetQualityOfExperienceData() Get the Quality of Experience (QoE) data for the audio socket. Declaration public AudioQualityOfExperienceData GetQualityOfExperienceData() Returns Type Description AudioQualityOfExperienceData Remarks The bot should fetch the QoE data no more than once every 30 seconds. To get accurate metrics, the bot should let media flow for at least 30 seconds before fetching the QoE data. Send(AudioMediaBuffer) Sends a frame of audio media, where a frame contains 20 milliseconds of audio content (PCM samples). Declaration public void Send(AudioMediaBuffer buffer) Parameters Type Name Description AudioMediaBuffer buffer AudioMediaBuffer containing the frame of audio media to send. Remarks The application must create a concrete class which derives from the AudioMediaBuffer abstract class. The buffer object passed to the Send method is still potentially in-use after the method returns to the caller. The application must not free the buffer's frame data until the the buffer object's Dispose() method is invoked by the Media Platform. The application should be sending 50 frames of audio media per second with each frame containing 20 milliseconds of audio content. The AudioSocket must be enabled to send media via the AudioSocketSettings.StreamDirections property. SendDtmfTone(ToneId) Sends a DTMF tone. Declaration public void SendDtmfTone(ToneId tone) Parameters Type Name Description ToneId tone The DTMF digit. Ranges from 0-16. Remarks Sending DTMF tone is only allowed if the AudioSocket is configured for sending media. SendDtmfTones(IEnumerable, Int32) Sends a sequence of DTMF tones with an optional delay between each tone. Declaration public void SendDtmfTones(IEnumerable tones, int delayBetweenTonesInMilliseconds = -1) Parameters Type Name Description IEnumerable < ToneId > tones The list of DTMF digits to be sent. Ranges from 0-16. Int32 delayBetweenTonesInMilliseconds Delay (in milliseconds) between each DTMF digit sent. Remarks By default, the delay is set to -1 which picks a random time between 0 to 500 milliseconds. Events AudioMediaReceived If the application has configured the AudioSocket to receive media, this event is raised each time a frame of audio media is received, where a frame contains 20 milliseconds of audio content (PCM samples). Once the application has consumed the buffer, it must call the buffer's Dispose() method. Declaration public event EventHandler AudioMediaReceived Event Type Type Description EventHandler < AudioMediaReceivedEventArgs > Remarks The application must be able to handle at least 50 incoming audio buffers per second. Events are serialized, so only one event at a time is raised to the app. The event handler should return as quickly as possible; any time-consuming per-frame processing should be performed asynchronously from the event handler. AudioSendStatusChanged If the application has configured the AudioSocket to send media, this event is raised to inform the application when it may begin sending media and when it should stop. The application cannot send media before receiving a MediaSendStatusChanged event indicating the SendStatus is Active, such media will be discarded. Declaration public event EventHandler AudioSendStatusChanged Event Type Type Description EventHandler < AudioSendStatusChangedEventArgs > DominantSpeakerChanged This event is raised when there is a change in the dominant speaker in the conference. If there is no dominant speaker in the conference the CurrentDominantSpeaker argument in the event will have the value None (0xFFFFFFFF). Declaration public event EventHandler DominantSpeakerChanged Event Type Type Description EventHandler < DominantSpeakerChangedEventArgs > MediaStreamFailure This event is raised if there is a network connection failure with the peer. To recover, the bot will need to start a new call or rejoin the meeting. Declaration public event EventHandler MediaStreamFailure Event Type Type Description EventHandler < MediaStreamFailureEventArgs > ToneReceived This event is raised when the DTMF tone is received. ToneId enum indicates the tone value. Declaration public event EventHandler ToneReceived Event Type Type Description EventHandler < ToneReceivedEventArgs > Implements IAudioSocket System.IDisposable" }, - "core/Microsoft.Graph.Communications.Core.Notifications.NotificationProcessor.html": { - "href": "core/Microsoft.Graph.Communications.Core.Notifications.NotificationProcessor.html", - "title": "Class NotificationProcessor", - "keywords": "Class NotificationProcessor The notification processor class. Inheritance Object NotificationProcessor Implements INotificationProcessor IDisposable Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class NotificationProcessor : Disposable, INotificationProcessor, IDisposable Constructors NotificationProcessor(IAuthenticationProvider, ISerializer) Initializes a new instance of the NotificationProcessor class. Declaration public NotificationProcessor(IAuthenticationProvider authenticationProvider, ISerializer serializer) Parameters Type Name Description IAuthenticationProvider authenticationProvider The authentication provider. ISerializer serializer The serializer. Exceptions Type Condition ArgumentNullException If the authentication provider is null. Properties AuthenticationProvider Gets the authentication provider. TODO: This should probably not be a part of the INotificationProcessor . Ideally the request is already validated prior to making it in here. This means that 1) Already sanitized by authentication provider and 2) The tenant/scenario id parameters extracted into the IGraphRequest. Declaration public IAuthenticationProvider AuthenticationProvider { get; } Property Value Type Description IAuthenticationProvider The authentication provider. Methods ExtractNotifications(String, ISerializer) Extracts the notifications from the specified content string. Declaration public static CommsNotifications ExtractNotifications(string content, ISerializer serializer) Parameters Type Name Description String content The content. ISerializer serializer The serializer. Returns Type Description CommsNotifications The deserialized CommsNotifications . Exceptions Type Condition ServiceException If the specified content is invalid. ProcessNotifications(Uri, String, String, Guid, Guid, IEnumerable>) Processes the notifications and raise the required callbacks. This function should be called in order for the SDK to raise any required events and process state changes. Declaration public void ProcessNotifications(Uri callbackUri, string content, string tenantId, Guid requestId, Guid scenarioId, IEnumerable> additionalData = null) Parameters Type Name Description Uri callbackUri The callback URI. String content The notifications content. String tenantId The tenant identifier. Guid requestId The request identifier. Guid scenarioId The scenario identifier. IEnumerable < KeyValuePair < String , Object >> additionalData Additional data associated with the notification. Events OnCollectionNotificationReceived Occurs when a collection notification is received. Declaration public event Action OnCollectionNotificationReceived Event Type Type Description Action < CollectionNotificationEventArgs > OnNotificationReceived Occurs when a notification is received. This is a global hook for all notifications. Declaration public event Action OnNotificationReceived Event Type Type Description Action < NotificationEventArgs > OnResourceNotificationReceived Occurs when a single resource notification is received. Declaration public event Action OnResourceNotificationReceived Event Type Type Description Action < NotificationEventArgs > Implements INotificationProcessor System.IDisposable See Also INotificationProcessor" + "calls/Microsoft.Graph.Communications.Calls.IMediaSession.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.IMediaSession.html", + "title": "Interface IMediaSession", + "keywords": "Interface IMediaSession The IMediaSession interface. For local media scenarios, this session object represents the modalities and the media configuration. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface IMediaSession : IDisposable Properties MediaSessionId Gets the id of this media session. Declaration Guid MediaSessionId { get; } Property Value Type Description Guid Modalities Gets the supported modalities Declaration Modality[] Modalities { get; } Property Value Type Description Modality [] Methods GetMediaConfiguration() Get the media configuration Declaration JObject GetMediaConfiguration() Returns Type Description Newtonsoft.Json.Linq.JObject A Newtonsoft.Json.Linq.JObject produced by the Media library." }, - "common/Microsoft.Graph.Communications.Common.WeakKey-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.WeakKey-1.html", - "title": "Class WeakKey", - "keywords": "Class WeakKey Wrapping a weak reference and recording hash code. Note: It is the responsibility of the client to clean up the collection entry in the finalizer of the object. Otherwise the key will not match for subsequent lookups. Inheritance Object WeakKey Inherited Members Object.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class WeakKey where T : class Type Parameters Name Description T Type of the key to be used in a lookup. Constructors WeakKey(T) Initializes a new instance of the WeakKey class. Declaration public WeakKey(T t) Parameters Type Name Description T t Underlying object. WeakKey(WeakReference) Initializes a new instance of the WeakKey class. Declaration public WeakKey(WeakReference weak) Parameters Type Name Description WeakReference weak Underlying object wrapped in weak reference. Properties Unwrapped Gets the target. Declaration public T Unwrapped { get; } Property Value Type Description T Value Gets the weak reference to the underlying object. Declaration public WeakReference Value { get; } Property Value Type Description WeakReference Methods Equals(Object) Determines whether the specified object is equal to the current object. Declaration public override bool Equals(object obj) Parameters Type Name Description Object obj The object to compare with the current object. Returns Type Description Boolean true if the specified object is equal to the current object. Overrides Object.Equals(Object) GetHashCode() Overrides hash code to hand out the underlying object's hash code. Declaration public override int GetHashCode() Returns Type Description Int32 Hash code of underlying object. Overrides Object.GetHashCode() Operators Implicit(T to WeakKey) Implicit cast operator to weak key. Declaration public static implicit operator WeakKey(T t) Parameters Type Name Description T t Wrap with weak key. Returns Type Description WeakKey Implicit(WeakKey to T) Implicit type cast operator. Declaration public static implicit operator T(WeakKey key) Parameters Type Name Description WeakKey key Extract underlying object. Returns Type Description T Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "calls/Microsoft.Graph.Communications.Calls.ICallCollection.html": { + "href": "calls/Microsoft.Graph.Communications.Calls.ICallCollection.html", + "title": "Interface ICallCollection", + "keywords": "Interface ICallCollection The stateful call collection interface. Inherited Members IDisposable.Dispose() IReadOnlyCollection.Count IEnumerable.GetEnumerator() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface ICallCollection : IResourceCollection, IResourceCollection, IResourceCollection, IResourceBase, IDisposable, IReadOnlyCollection, IEnumerable, IEnumerable Methods AddAsync(Call, IMediaSession, Guid, CancellationToken) Create a new call and add to the collection. Declaration Task AddAsync(Call resource, IMediaSession mediaSession = null, Guid scenarioId = default(Guid), CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description Call resource The call resource to be added. IMediaSession mediaSession The media session object, if any. This is valid only for application hosted media scenarios. Guid scenarioId The scenario identitifer. This parameter should be used for tracking scenarios across multiple calls. Automatically generated by the SDK if not provided. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < ICall > The ICall that has been created. This call has not yet been established and those notifications will fire on ICall.OnUpdated Events OnIncoming The incoming call event. This event is triggered when a new call is being received by the bot. Declaration event CollectionEventHandler OnIncoming Event Type Type Description CollectionEventHandler < ICallCollection , ICall > Extension Methods CallCollectionExtensions.AddAsync(ICallCollection, JoinMeetingParameters, Guid, CancellationToken)" }, - "common/Microsoft.Graph.Communications.Common.Validator.html": { - "href": "common/Microsoft.Graph.Communications.Common.Validator.html", - "title": "Class Validator", - "keywords": "Class Validator Helper class with various condition validation utilities. Inheritance Object Validator Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class Validator Methods Any(IEnumerable) Determines whether a sequence contains any elements. Declaration public static bool Any(this IEnumerable source) Parameters Type Name Description IEnumerable source The IEnumerable to check for emptiness. Returns Type Description Boolean true if the source sequence contains any elements; otherwise, false . Equals(T, T, IComparer, String, String) Throw if value > is not equal to expected Declaration public static T Equals(T value, T expected, IComparer comparer, string paramName = null, string message = null) Parameters Type Name Description T value value T expected expected IComparer comparer comparer String paramName paramName String message Optional message. Returns Type Description T The input value if validation succeeded. Type Parameters Name Description T Type of the input value Exceptions Type Condition ArgumentException The argument value should match the expected value. Equals(T, T, String, String) Throw if value > is not equal to expected Declaration public static T Equals(this T value, T expected, string paramName = null, string message = null) Parameters Type Name Description T value value T expected expected String paramName paramName String message Optional message. Returns Type Description T The input value if validation succeeded. Type Parameters Name Description T Type of the input value Exceptions Type Condition ArgumentException The argument value should match the expected value. Equals(T, T, String) Throws the TE if value > is not equal to expected Declaration public static T Equals(this T value, T expected, string message = null) where TE : Exception Parameters Type Name Description T value value T expected expected String message Optional message. Returns Type Description T The input value if validation succeeded. Type Parameters Name Description T Type of the input value TE The type of Exception to throw FirstObject(IEnumerable) Gets the first object in the enumerable. Declaration public static object FirstObject(this IEnumerable source) Parameters Type Name Description IEnumerable source The IEnumerable to check for object. Returns Type Description Object langword_csharp_object if the source sequence contains an element; otherwise, null . FirstObject(IEnumerable, Func) Gets the first object in the enumerable that matches the specified predicate. Declaration public static object FirstObject(this IEnumerable source, Func predicate) Parameters Type Name Description IEnumerable source The IEnumerable to check for object. Func < Object , Boolean > predicate The Func used to match the object. Returns Type Description Object langword_csharp_object if the source sequence contains the matching element; otherwise, null . InRange(T, T, T, String) Throws ArgumentOutOfRangeException if value is not in the given range defined by minValue and maxValue Declaration public static void InRange(this T value, T minValue, T maxValue, string paramName = null) where T : IComparable Parameters Type Name Description T value value to verify T minValue Minimum range value T maxValue Maximum range value String paramName Variable name. Type Parameters Name Description T Comparable Exceptions Type Condition ArgumentOutOfRangeException If the value is out of range. IsEnum(Type) Throws the ArgumentException if given type is not Enum Declaration public static void IsEnum(this Type type) Parameters Type Name Description Type type The type IsFalse(Boolean, String, String) Throw ArgumentException condition is not false Declaration public static void IsFalse(this bool condition, string paramName = null, string message = null) Parameters Type Name Description Boolean condition Condition to check. String paramName Optional variable name. String message Optional message. IsFalse(Boolean, String) Throw T exception if condition is not false Declaration public static void IsFalse(this bool condition, string message = null) where T : Exception Parameters Type Name Description Boolean condition Condition to check. String message Optional message. Type Parameters Name Description T Exception type to raise IsNull(Object, String, String) Throw ArgumentException if obj is not null. Declaration public static void IsNull(this object obj, string paramName = null, string message = null) Parameters Type Name Description Object obj The object to check. String paramName Optional variable name. String message Optional message. IsTrue(Boolean, String, String) Throw ArgumentException condition is not true Declaration public static void IsTrue(this bool condition, string paramName = null, string message = null) Parameters Type Name Description Boolean condition Condition to check. String paramName Optional variable name. String message Optional message. IsTrue(Boolean, String) Throw T exception if condition is not true Declaration public static void IsTrue(this bool condition, string message = null) where T : Exception Parameters Type Name Description Boolean condition Condition to check. String message Optional message. Type Parameters Name Description T Exception type to raise NotEmpty(T, String, String) Throw ArgumentNullException if obj is null. Declaration public static T NotEmpty(this T obj, string paramName = null, string message = null) where T : IEnumerable Parameters Type Name Description T obj The object to check. String paramName Variable name. String message Optional message. Returns Type Description T The validated IEnumerable . Type Parameters Name Description T Enumerable type Exceptions Type Condition ArgumentNullException If the object is null. ArgumentException If the object is empty. NotEquals(T, T, String, String) Throw if value > is equal to unexpected Declaration public static T NotEquals(this T value, T unexpected, string paramName = null, string message = null) Parameters Type Name Description T value The value to compare. T unexpected The unexpected value. String paramName the parameter name. String message Optional message. Returns Type Description T The input value if validation succeeded. Type Parameters Name Description T Type of the input value Exceptions Type Condition ArgumentException The argument value should not match the expected value. NotNull(T, String, String) Throw ArgumentNullException if obj is null. Declaration public static T NotNull(this T obj, string paramName = null, string message = null) Parameters Type Name Description T obj The object. String paramName Name of the parameter. String message The message. Returns Type Description T The validated object. Type Parameters Name Description T The type of the object to validate. Exceptions Type Condition ArgumentException If the object is null. NotNullOrWhitespace(String, String, String) Throws the ArgumentException if string is null or whitespace. Declaration public static string NotNullOrWhitespace(this string value, string paramName = null, string message = null) Parameters Type Name Description String value value to check String paramName Variable name. String message Optional message. Returns Type Description String The validated String . Exceptions Type Condition ArgumentException If the string is null or whitespace. VerifyContains(IEnumerable, T) Throws the ArgumentException if collection does not contains the specified value Declaration public static void VerifyContains(this IEnumerable enumerable, T value) Parameters Type Name Description IEnumerable enumerable The enumerable. T value The value. Type Parameters Name Description T Type of value VerifyContainsKey(IDictionary, TK) Throws the ArgumentException if collection does not contain the specified key Declaration public static void VerifyContainsKey(this IDictionary dictionary, TK key) Parameters Type Name Description IDictionary dictionary The dictionary. TK key The key. Type Parameters Name Description TK Key type TV Value type VerifyContainsKey(IReadOnlyDictionary, TK) Throws the ArgumentException if collection does not contain the specified key Declaration public static void VerifyContainsKey(this IReadOnlyDictionary dictionary, TK key) Parameters Type Name Description IReadOnlyDictionary dictionary The dictionary. TK key The key. Type Parameters Name Description TK Key type TV Value type VerifyNotContainsKey(IDictionary, TK) Throws the ArgumentException if collection contains the specified key Declaration public static void VerifyNotContainsKey(this IDictionary dictionary, TK key) Parameters Type Name Description IDictionary dictionary The dictionary. TK key The key. Type Parameters Name Description TK Key type TV Value type" + "bot_media/Microsoft.Skype.Bots.Media.VideoQualityType.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoQualityType.html", + "title": "Enum VideoQualityType", + "keywords": "Enum VideoQualityType Type of the video media quality Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum VideoQualityType Fields Name Description ReceiveFreeze Video freeze for the received stream" }, - "common/Microsoft.Graph.Communications.Common.Utilities.html": { - "href": "common/Microsoft.Graph.Communications.Common.Utilities.html", - "title": "Class Utilities", - "keywords": "Class Utilities Utilities class. Inheritance Object Utilities Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class Utilities Methods CombineHashCodes(Object[]) Combine several hash codes into a single hash code Declaration public static int CombineHashCodes(params object[] args) Parameters Type Name Description Object [] args Objects to combine into a single hash. Returns Type Description Int32 Combined hash code. DecodeReplacesContextFromBase64(String) Decodes the replaces context for consultative call transfer scenario. Declaration public static Uri DecodeReplacesContextFromBase64(this string replacesContext) Parameters Type Name Description String replacesContext The replaces context. Returns Type Description Uri The decoded replaces URI. Exceptions Type Condition InvalidOperationException Replaces context provided for consultative transfer is invalid. EncodeReplacesUriToBase64(Uri) Base64 Encodes the replaces URI for consultative call transfer scenario. Declaration public static string EncodeReplacesUriToBase64(this Uri replacesUri) Parameters Type Name Description Uri replacesUri The replaces URI. Returns Type Description String The encoded replaces context. SafeDispose(ref T, IGraphLogger) Safely dispose members. Declaration public static void SafeDispose(ref T t, IGraphLogger logger = null) where T : class, IDisposable Parameters Type Name Description T t Reference to member. IGraphLogger logger Logger instance. Type Parameters Name Description T Type of the member." + "bot_media/Microsoft.Skype.Bots.Media.VideoQualityOfExperienceData.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoQualityOfExperienceData.html", + "title": "Class VideoQualityOfExperienceData", + "keywords": "Class VideoQualityOfExperienceData Video quality of experience data Inheritance Object MediaQualityOfExperienceData VideoQualityOfExperienceData Inherited Members MediaQualityOfExperienceData.NetworkMetrics MediaQualityOfExperienceData.TotalMediaDuration Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoQualityOfExperienceData : MediaQualityOfExperienceData Constructors VideoQualityOfExperienceData() VideoQualityOfExperienceData constructor Declaration public VideoQualityOfExperienceData() Properties VideoMetrics Video-specific quality of experience metrics Declaration public VideoMetrics VideoMetrics { get; set; } Property Value Type Description VideoMetrics" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClientContainer.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphHttpClientContainer.html", - "title": "Class GraphHttpClientContainer", - "keywords": "Class GraphHttpClientContainer This class is used to handle multiple http clients within one service. This class extends the concurrent dictionary and contains a mapping from a key for the client to the http client itself. Inheritance Object ConcurrentDictionary < String , IGraphHttpClient > GraphHttpClientContainer Implements IDictionary < String , IGraphHttpClient > ICollection < KeyValuePair < String , IGraphHttpClient >> IDictionary ICollection IReadOnlyDictionary < String , IGraphHttpClient > IReadOnlyCollection < KeyValuePair < String , IGraphHttpClient >> IEnumerable < KeyValuePair < String , IGraphHttpClient >> IEnumerable Inherited Members ConcurrentDictionary.TryAdd(String, IGraphHttpClient) ConcurrentDictionary.ContainsKey(String) ConcurrentDictionary.TryRemove(String, IGraphHttpClient) ConcurrentDictionary.TryGetValue(String, IGraphHttpClient) ConcurrentDictionary.TryUpdate(String, IGraphHttpClient, IGraphHttpClient) ConcurrentDictionary.Clear() System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.CopyTo(System.Collections.Generic.KeyValuePair[], System.Int32) ConcurrentDictionary.ToArray() ConcurrentDictionary.GetEnumerator() ConcurrentDictionary.GetOrAdd(String, Func) ConcurrentDictionary.GetOrAdd(String, IGraphHttpClient) ConcurrentDictionary.GetOrAdd(String, Func, TArg) ConcurrentDictionary.AddOrUpdate(String, Func, Func, TArg) ConcurrentDictionary.AddOrUpdate(String, Func, Func) ConcurrentDictionary.AddOrUpdate(String, IGraphHttpClient, Func) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.IDictionary.Add(System.String, Microsoft.Graph.Communications.Common.Transport.IGraphHttpClient) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.IDictionary.Remove(System.String) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.Add(System.Collections.Generic.KeyValuePair) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.Contains(System.Collections.Generic.KeyValuePair) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.Remove(System.Collections.Generic.KeyValuePair) ConcurrentDictionary.IEnumerable.GetEnumerator() ConcurrentDictionary.IDictionary.Add(Object, Object) ConcurrentDictionary.IDictionary.Contains(Object) ConcurrentDictionary.IDictionary.GetEnumerator() ConcurrentDictionary.IDictionary.Remove(Object) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.IDictionary.get_Item(System.Object) System.Collections.Concurrent.ConcurrentDictionary.System.Collections.IDictionary.set_Item(System.Object, System.Object) ConcurrentDictionary.ICollection.CopyTo(Array, Int32) ConcurrentDictionary.Item[String] ConcurrentDictionary.Count ConcurrentDictionary.IsEmpty ConcurrentDictionary.Keys System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.IReadOnlyDictionary.Keys ConcurrentDictionary.Values System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.IReadOnlyDictionary.Values System.Collections.Concurrent.ConcurrentDictionary.System.Collections.Generic.ICollection>.IsReadOnly ConcurrentDictionary.IDictionary.IsFixedSize ConcurrentDictionary.IDictionary.IsReadOnly ConcurrentDictionary.IDictionary.Keys ConcurrentDictionary.IDictionary.Values ConcurrentDictionary.IDictionary.Item[Object] ConcurrentDictionary.ICollection.IsSynchronized ConcurrentDictionary.ICollection.SyncRoot Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphHttpClientContainer : ConcurrentDictionary, IDictionary, ICollection>, IDictionary, ICollection, IReadOnlyDictionary, IReadOnlyCollection>, IEnumerable>, IEnumerable Constructors GraphHttpClientContainer(IGraphHttpClient) Initializes a new instance of the GraphHttpClientContainer class. Declaration public GraphHttpClientContainer(IGraphHttpClient defaultGraphHttpClient) Parameters Type Name Description IGraphHttpClient defaultGraphHttpClient The default graph HTTP client. Properties DefaultGraphHttpClient Gets the default graph HTTP client. Declaration public IGraphHttpClient DefaultGraphHttpClient { get; } Property Value Type Description IGraphHttpClient Implements System.Collections.Generic.IDictionary System.Collections.Generic.ICollection System.Collections.IDictionary System.Collections.ICollection System.Collections.Generic.IReadOnlyDictionary System.Collections.Generic.IReadOnlyCollection System.Collections.Generic.IEnumerable System.Collections.IEnumerable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) CollectionUtils.ForEach(IEnumerable, Action) CollectionUtils.ForEachParallel(IEnumerable, Action, IGraphLogger) CollectionUtils.GetValueOrDefault(IDictionary, TKey) CollectionUtils.GetValueOrDefault(IDictionary, TKey, TValue) CollectionUtils.AddRange(ICollection, IEnumerable) CollectionUtils.ToSortedList(IEnumerable, Func) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.Any(IEnumerable) Validator.FirstObject(IEnumerable, Func) Validator.FirstObject(IEnumerable) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.NotEmpty(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) Validator.VerifyNotContainsKey(IDictionary, TK) Validator.VerifyContainsKey(IDictionary, TK) Validator.VerifyContainsKey(IReadOnlyDictionary, TK) Validator.VerifyContains(IEnumerable, T)" + "bot_media/Microsoft.Skype.Bots.Media.VideoKeyFrameNeededEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoKeyFrameNeededEventArgs.html", + "title": "Class VideoKeyFrameNeededEventArgs", + "keywords": "Class VideoKeyFrameNeededEventArgs Event arguments of a VideoKeyFrameNeeded event. Inheritance Object EventArgs VideoKeyFrameNeededEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoKeyFrameNeededEventArgs : EventArgs Constructors VideoKeyFrameNeededEventArgs() Declaration public VideoKeyFrameNeededEventArgs() Properties MediaType MediaType of the video buffer. This could be Video or Vbss. Declaration public MediaType MediaType { get; set; } Property Value Type Description MediaType SocketId The 0-based ID of the socket that is raising this event. This socket ID can be used in multiview (ie. more than 1 video socket) to determine which video socket is raising this event. The socket ID property will be present in both single view and multiview cases. The ID maps to the order in which the video sockets are provided to the Microsoft.Skype.Bots.Media.MediaPlatform (or IMediaPlatform) API CreateMediaConfiguration. Eg. If the collection of IVideoSocket objects in the CreateMediaConfiguration API contains { socketA, socketB, socketC }, the sockets will have the ID mapping of: 0 for socketA, 1 for socketB and 2 for socketC. Declaration public int SocketId { get; set; } Property Value Type Description Int32 VideoFormats VideoFormats for which keyframe is needed Declaration public VideoFormat[] VideoFormats { get; set; } Property Value Type Description VideoFormat []" }, - "common/Microsoft.Graph.Communications.Common.Exceptions.ConfigurationException.html": { - "href": "common/Microsoft.Graph.Communications.Common.Exceptions.ConfigurationException.html", - "title": "Class ConfigurationException", - "keywords": "Class ConfigurationException Configuration is bad. Mandatory configuration setting is missing. Or raw (string) setting value can not be converted to property type. Inheritance Object Exception ConfigurationException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Exceptions Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ConfigurationException : Exception, ISerializable, _Exception Constructors ConfigurationException(String) Initializes a new instance of the ConfigurationException class. Declaration public ConfigurationException(string message) Parameters Type Name Description String message The message that describes the error. ConfigurationException(String, Exception) Initializes a new instance of the ConfigurationException class. Declaration public ConfigurationException(string message, Exception innerException) Parameters Type Name Description String message The error message that explains the reason for the exception. Exception innerException The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified. Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ExceptionUtils.FindInnerException(Exception) ExceptionUtils.FormatException(Exception, Int32) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.SkypeMediaException.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.SkypeMediaException.html", + "title": "Class SkypeMediaException", + "keywords": "Class SkypeMediaException Root class for the exceptions that are specific to the Skype Media Bots SDK, ie. exceptions other than the standard .NET Framework exceptions. Inheritance Object Exception SkypeMediaException Implements ISerializable _Exception Inherited Members Exception.GetBaseException() Exception.ToString() Exception.GetObjectData(SerializationInfo, StreamingContext) Exception.GetType() Exception.Message Exception.Data Exception.InnerException Exception.TargetSite Exception.StackTrace Exception.HelpLink Exception.Source Exception.HResult Exception.SerializeObjectState Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class SkypeMediaException : Exception, ISerializable, _Exception Implements System.Runtime.Serialization.ISerializable System.Runtime.InteropServices._Exception" }, - "common/Microsoft.Graph.Communications.Common.Disposable.html": { - "href": "common/Microsoft.Graph.Communications.Common.Disposable.html", - "title": "Class Disposable", - "keywords": "Class Disposable Common disposable pattern Inheritance Object Disposable AutoClean ObjectRootDisposable Observer SlimLock GraphLogger Implements IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class Disposable : IDisposable Constructors Disposable() Declaration public Disposable() Properties IsDisposed Gets a value indicating whether this instance is disposed. Declaration protected bool IsDisposed { get; } Property Value Type Description Boolean true if this instance is disposed; otherwise, false . Methods Dispose() Dispose resources. Declaration public void Dispose() Dispose(Boolean) Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected. Declaration protected virtual void Dispose(bool disposing) Parameters Type Name Description Boolean disposing true to release both managed and unmanaged resources; false to release only unmanaged resources. Finalize() Finalizes an instance of the Disposable class. Declaration protected void Finalize() Implements System.IDisposable Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.MediaQualityState.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaQualityState.html", + "title": "Enum MediaQualityState", + "keywords": "Enum MediaQualityState Indicates the media quality state Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum MediaQualityState Fields Name Description Detected Detected Recovered Recovered" }, - "core/Microsoft.Graph.Communications.Core.Exceptions.ClientException.html": { - "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ClientException.html", - "title": "Class ClientException", - "keywords": "Class ClientException Class for client error exception. Inheritance Object ClientException Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax [Obsolete(\"Deprecated, please use Microsoft.Graph.ClientException instead.\")] public class ClientException : ClientException Constructors ClientException(Error, Exception) Initializes a new instance of the ClientException class. Declaration [Obsolete(\"Deprecated, please use Microsoft.Graph.ClientException instead.\")] public ClientException(Error error, Exception innerException = null) Parameters Type Name Description Error error The Error to wrap. Exception innerException The Exception to wrap." + "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformFactory.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformFactory.html", + "title": "Class MediaPlatformFactory", + "keywords": "Class MediaPlatformFactory MediaPlatformFactory that is used to create IMediaPlatform. Inheritance Object MediaPlatformFactory Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public static class MediaPlatformFactory Methods CreateMediaPlatform() Creates the Media Platform for bots. The platform has to be initialized before it is used. Declaration public static IMediaPlatform CreateMediaPlatform() Returns Type Description IMediaPlatform The interface to the Media Platform." }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphResponse.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphResponse.html", - "title": "Class GraphResponse", - "keywords": "Class GraphResponse Inheritance Object GraphResponse < NoContentMessage > GraphResponse Implements IGraphResponse IGraphResponse < NoContentMessage > IGraphExchange < NoContentMessage > IGraphExchange Inherited Members GraphResponse.ToString() GraphResponse.Content GraphResponse.Properties GraphResponse.ReasonPhrase GraphResponse.ErrorContent GraphResponse.Status Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphResponse : GraphResponse, IGraphResponse, IGraphResponse, IGraphExchange, IGraphExchange Constructors GraphResponse(IGraphResponse) Initializes a new instance of the GraphResponse class. This is a copy constructor. Declaration public GraphResponse(IGraphResponse response) Parameters Type Name Description IGraphResponse < NoContentMessage > response The response to be used to create a new instance. GraphResponse(ResponseStatus) Initializes a new instance of the GraphResponse class. Create a new graph response Declaration public GraphResponse(ResponseStatus status) Parameters Type Name Description ResponseStatus status Status indicating success/failure/other for the response. GraphResponse(String, ResponseStatus, String) Initializes a new instance of the GraphResponse class. Declaration public GraphResponse(string errorContent, ResponseStatus status, string reasonPhrase) Parameters Type Name Description String errorContent Content of the error. ResponseStatus status The status. String reasonPhrase The reason phrase. Implements IGraphResponse IGraphResponse IGraphExchange IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphResponseExtensions.ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable)" + "bot_media/Microsoft.Skype.Bots.Media.IMediaPlatformLogger.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.IMediaPlatformLogger.html", + "title": "Interface IMediaPlatformLogger", + "keywords": "Interface IMediaPlatformLogger Interface for collecting MediaPlatform logs from the Bots.Media library. Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IMediaPlatformLogger Methods WriteLog(LogLevel, String) Log a trace statement Declaration void WriteLog(LogLevel level, string logStatement) Parameters Type Name Description LogLevel level Level of log String logStatement The log itself." }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphResponse-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphResponse-1.html", - "title": "Class GraphResponse", - "keywords": "Class GraphResponse The base of the exchange of a IGraphRequest or IGraphResponse . Inheritance Object GraphResponse GraphResponse Implements IGraphResponse IGraphExchange IGraphExchange Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphResponse : IGraphResponse, IGraphExchange, IGraphExchange Type Parameters Name Description T Constructors GraphResponse(T, ResponseStatus) Initializes a new instance of the GraphResponse class. Create a new graph response Declaration public GraphResponse(T content, ResponseStatus status) Parameters Type Name Description T content The serialized content of the response. ResponseStatus status Status indicating success/failure/other for the response. GraphResponse(String, ResponseStatus, String) Initializes a new instance of the GraphResponse class. Declaration public GraphResponse(string errorContent, ResponseStatus status, string reasonPhrase) Parameters Type Name Description String errorContent Content of the error. ResponseStatus status The status. String reasonPhrase The reason phrase. Properties Content Declaration public T Content { get; set; } Property Value Type Description T ErrorContent Declaration public string ErrorContent { get; set; } Property Value Type Description String Properties Gets the properties of the exchange. Declaration public ICollection Properties { get; } Property Value Type Description ICollection < IGraphProperty > ReasonPhrase Declaration public string ReasonPhrase { get; set; } Property Value Type Description String Status Declaration public ResponseStatus Status { get; } Property Value Type Description ResponseStatus Methods ToString() Declaration public override string ToString() Returns Type Description String Overrides Object.ToString() Implements IGraphResponse IGraphExchange IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphResponseExtensions.ToHttpResponseMessage(IGraphResponse, JsonSerializerSettings, IEnumerable)" + "bot_media/Microsoft.Skype.Bots.Media.DataSocketSettings.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.DataSocketSettings.html", + "title": "Class DataSocketSettings", + "keywords": "Class DataSocketSettings Reserved for the internal use. Inheritance Object DataSocketSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class DataSocketSettings Constructors DataSocketSettings() Reserved for the internal use. Declaration public DataSocketSettings() Properties CallId Reserved for the internal use. Declaration public string CallId { get; set; } Property Value Type Description String ReceiveDataType Reserved for the internal use. Declaration public DataType ReceiveDataType { get; set; } Property Value Type Description DataType SendDataType Reserved for the internal use. Declaration public DataType SendDataType { get; set; } Property Value Type Description DataType StreamDirections Reserved for the internal use. Declaration public StreamDirection StreamDirections { get; set; } Property Value Type Description StreamDirection" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphRequest.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphRequest.html", - "title": "Class GraphRequest", - "keywords": "Class GraphRequest Inheritance Object GraphRequest < NoContentMessage > GraphRequest Implements IGraphRequest IGraphRequest < NoContentMessage > IGraphExchange < NoContentMessage > IGraphExchange Inherited Members GraphRequest.ToString() GraphRequest.Content GraphRequest.Properties GraphRequest.Uri GraphRequest.RequestType Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class GraphRequest : GraphRequest, IGraphRequest, IGraphRequest, IGraphExchange, IGraphExchange Constructors GraphRequest(IGraphRequest) Initializes a new instance of the GraphRequest class. Declaration public GraphRequest(IGraphRequest graphRequest) Parameters Type Name Description IGraphRequest < NoContentMessage > graphRequest The graph request. GraphRequest(Uri, RequestType) Initializes a new instance of the GraphRequest class. Create the graph request object Declaration public GraphRequest(Uri location, RequestType requestType) Parameters Type Name Description Uri location The uri location for the request. RequestType requestType Type of the request. Implements IGraphRequest IGraphRequest IGraphExchange IGraphExchange Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphRequestExtensions.ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable)" + "bot_media/Microsoft.Skype.Bots.Media.DataSendStatusChangedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.DataSendStatusChangedEventArgs.html", + "title": "Class DataSendStatusChangedEventArgs", + "keywords": "Class DataSendStatusChangedEventArgs Reserved for the internal use. Inheritance Object EventArgs DataSendStatusChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class DataSendStatusChangedEventArgs : EventArgs Constructors DataSendStatusChangedEventArgs() Declaration public DataSendStatusChangedEventArgs() Properties MediaSendStatus Reserved for the internal use. Declaration public MediaSendStatus MediaSendStatus { get; set; } Property Value Type Description MediaSendStatus" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventFormatter.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.LogEventFormatter.html", - "title": "Class LogEventFormatter", - "keywords": "Class LogEventFormatter The log event formatter Inheritance Object LogEventFormatter Implements ILogEventFormatter Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class LogEventFormatter : ILogEventFormatter Constructors LogEventFormatter(LogEventFormatterFlags, String, String) Initializes a new instance of the LogEventFormatter class. Declaration public LogEventFormatter(LogEventFormatterFlags flags = LogEventFormatterFlags.ForDefault, string inlineSeparator = \" \", string timestampFormat = \"yyyy-MM-ddTHH:mm:ss.ffffZ\") Parameters Type Name Description LogEventFormatterFlags flags The formatter flags to control which will be shown in output message. String inlineSeparator The inline separator for logging fields String timestampFormat The default timestamp format Fields DefaultTimestampFormat The default timestamp format. Declaration public const string DefaultTimestampFormat = \"yyyy-MM-ddTHH:mm:ss.ffffZ\" Field Value Type Description String Methods Format(LogEvent) Format the log event. Declaration public string Format(LogEvent logEvent) Parameters Type Name Description LogEvent logEvent The log event Returns Type Description String The formatted text. Implements ILogEventFormatter Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.AudioMediaBuffer.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioMediaBuffer.html", + "title": "Class AudioMediaBuffer", + "keywords": "Class AudioMediaBuffer Represents an unmanaged buffer containing audio media data. Inheritance Object AudioMediaBuffer Implements IDisposable Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public abstract class AudioMediaBuffer : IDisposable Constructors AudioMediaBuffer() Declaration protected AudioMediaBuffer() Properties ActiveSpeakers Current active speakers in the conference. Declaration public uint[] ActiveSpeakers { get; protected set; } Property Value Type Description UInt32 [] Remarks The value is the IDs (MediaSourceIds) of the audio source of the active speakers in the conference and does not include bot's own MediaSourceId. If there is no active speaker, or there is just silence in the conference, the value is an empty array. AudioFormat The audio format. Declaration public AudioFormat AudioFormat { get; protected set; } Property Value Type Description AudioFormat Data Pointer to the unmanaged media buffer. Declaration public IntPtr Data { get; protected set; } Property Value Type Description IntPtr IsSilence Indicates if the received audio media buffer contains only silence. This property is set automatically for received audio buffers. When sending buffers via the Send method, this property is unused. Declaration public bool IsSilence { get; protected set; } Property Value Type Description Boolean Length The length in bytes of the data in the media buffer. Declaration public long Length { get; protected set; } Property Value Type Description Int64 Timestamp Timestamp of when the media content was received by the bot, or if the bot is sending media, the timestamp of when the media was sourced. It is in 100-ns units. When sourcing media buffers, this property should be set using the value from the MediaPlatform.GetCurrentTimestamp() API. Declaration public long Timestamp { get; protected set; } Property Value Type Description Int64 UnmixedAudioBuffers Contains the list of received unmixed audio buffers (up to four at a time). Declaration public UnmixedAudioBuffer[] UnmixedAudioBuffers { get; protected set; } Property Value Type Description UnmixedAudioBuffer [] Remarks This is useful for advanced meeting scenarios, such as being able to receive separate audio buffers for individual speakers. This value is set only on the receive side when the AudioSocketSetting.ReceiveUnmixedMeetingAudio property is set to true. Creating unmixed audio buffers and sending it on the AudioSocket is not supported. This property is null when unmixed buffers are not requested. Methods Dispose() Disposes the object. Declaration public void Dispose() Dispose(Boolean) Releases unmanaged resources held by the buffer object. Must be implemented in the derived class. Declaration protected abstract void Dispose(bool disposing) Parameters Type Name Description Boolean disposing If true, both managed and unmanaged resources can be disposed. If false, only unmanaged resources can be disposed. Implements System.IDisposable" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.JsonConverters.TypedPropertiesConverter.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.JsonConverters.TypedPropertiesConverter.html", - "title": "Class JsonConverters.TypedPropertiesConverter", - "keywords": "Class JsonConverters.TypedPropertiesConverter The json converter for Type. Inheritance Object JsonConverters.TypedPropertiesConverter Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class TypedPropertiesConverter : JsonConverter Constructors TypedPropertiesConverter() Declaration public TypedPropertiesConverter() Properties CanRead Declaration public override bool CanRead { get; } Property Value Type Description Boolean Methods CanConvert(Type) Declaration public override bool CanConvert(Type objectType) Parameters Type Name Description Type objectType Returns Type Description Boolean ReadJson(JsonReader, Type, Object, JsonSerializer) Declaration public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonReader reader Type objectType Object existingValue Newtonsoft.Json.JsonSerializer serializer Returns Type Description Object WriteJson(JsonWriter, Object, JsonSerializer) Declaration public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) Parameters Type Name Description Newtonsoft.Json.JsonWriter writer Object value Newtonsoft.Json.JsonSerializer serializer Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "core/Microsoft.Graph.html": { + "href": "core/Microsoft.Graph.html", + "title": "Namespace Microsoft.Graph", + "keywords": "Namespace Microsoft.Graph Classes ContractsConstants OData Model Constants ContractsConstants.AuthConstants Various constants used by the AuthZ layer ContractsConstants.CallProperties Call properties constants ContractsConstants.EntityContainerNames Singleton/EntitySet constants ContractsConstants.IdentityProperties Identity properties constants ContractsConstants.NotificationProperties Notification properties constants ContractsConstants.Signature Signature for Assembly visibility. IdentityExtensions Extensions for graph api contracts IdentitySetExtensions Extentions for graph api contracts NotificationsExtensions Communications notifications extensions." }, - "common/Microsoft.Graph.Communications.Common.StateMachine-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.StateMachine-1.html", - "title": "Class StateMachine", - "keywords": "Class StateMachine Lockfree enum-based state machine. Transitions are O(1). Inheritance Object StateMachine Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public sealed class StateMachine where TStateEnum : struct, IComparable, IFormattable, IConvertible Type Parameters Name Description TStateEnum The enum type which represents state. Constructors StateMachine(TStateEnum, StateMachine.Transition[]) Initializes a new instance of the StateMachine class. Declaration public StateMachine(TStateEnum initalState, StateMachine.Transition[] transitions) Parameters Type Name Description TStateEnum initalState State of the inital. StateMachine.Transition <>[] transitions The transitions. Properties State Gets the state. Declaration public TStateEnum State { get; } Property Value Type Description TStateEnum The state. Methods ToString() Returns a String that represents this instance. Declaration public override string ToString() Returns Type Description String A String that represents this instance. Overrides Object.ToString() TransitionState(TStateEnum) Transition to next state. Transition to same state is not allowed. Non valid transition throws exception. Declaration public TStateEnum TransitionState(TStateEnum newState) Parameters Type Name Description TStateEnum newState The new state. Returns Type Description TStateEnum Previous state Exceptions Type Condition Exception If transition is not allow, exception is thrown. TransitionStateSafe(TStateEnum) Transition to the next state. Transition to same state has to be allowed via transitions. Non valid transition returns null. Declaration public TStateEnum? TransitionStateSafe(TStateEnum newState) Parameters Type Name Description TStateEnum newState The new state. Returns Type Description Nullable Previous state or null; if transition is not valid. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaSession.MediaProperties.html": { + "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaSession.MediaProperties.html", + "title": "Class MediaSession.MediaProperties", + "keywords": "Class MediaSession.MediaProperties Gets the media properties. Inheritance Object MediaSession.MediaProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public class MediaProperties Constructors MediaProperties() Declaration public MediaProperties() Properties MediaSessionId Gets or sets the media session identifier. Declaration public Guid MediaSessionId { get; set; } Property Value Type Description Guid" }, - "client/Microsoft.Graph.Communications.Resources.IResourceBase.html": { - "href": "client/Microsoft.Graph.Communications.Resources.IResourceBase.html", - "title": "Interface IResourceBase", - "keywords": "Interface IResourceBase The resource base interface. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResourceBase : IDisposable Properties Client Gets the client. Declaration ICommunicationsClient Client { get; } Property Value Type Description ICommunicationsClient CreatedDateTime Gets the created date time of this resource. Declaration DateTimeOffset CreatedDateTime { get; } Property Value Type Description DateTimeOffset GraphClient Gets the graph client. Declaration IGraphClient GraphClient { get; } Property Value Type Description IGraphClient GraphLogger Gets the graph logger. Declaration IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger ResourcePath Gets the resource path for this collection. Declaration string ResourcePath { get; } Property Value Type Description String See Also IDisposable" + "bot_media/Microsoft.Skype.Bots.Media.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.html", + "title": "Namespace Microsoft.Skype.Bots.Media", + "keywords": "Namespace Microsoft.Skype.Bots.Media Classes AudioLowOnFramesEventArgs Audio low on frame event args AudioMediaBuffer Represents an unmanaged buffer containing audio media data. AudioMediaReceivedEventArgs Event arguments of an AudioMediaReceived event. AudioMetrics Audio-specific QoE metrics AudioQualityOfExperienceData Audio quality of experience data AudioSendStatusChangedEventArgs Event arguments of an AudioSendStatusChanged event. AudioSettings Audio frame player settings AudioSocket Provides Send and Receive I/O access to an audio stream. AudioSocketSettings The settings to initialize the AudioSocket. AudioVideoFramePlayer AudioVideoFramePlayer is responsible for streaming real time audio and video buffers. This frame player will handle audio and video sync from the audio and video buffer's timestamps AudioVideoFramePlayerSettings AudioVideoFramePlayer settings. This will help configure the player settings. DataMediaBuffer Reserved for the internal use. DataMediaReceivedEventArgs Reserved for the internal use. DataSendStatusChangedEventArgs Reserved for the internal use. DataSocket Reserved for the internal use. DataSocketSettings Reserved for the internal use. DominantSpeakerChangedEventArgs Event arguments of the DominantSpeakerChanged event. LowOnFramesEventArgs LowOnFrames event arguments MediaPlatform This class represents the Skype Bots Media Platform. MediaPlatformFactory MediaPlatformFactory that is used to create IMediaPlatform. MediaPlatformHealthChangedEventArgs Event arguments of the MediaPlatformHealthChangedEvent providing the current and previous health status of the media platform. MediaPlatformInstanceSettings Class that stores the settings of the Azure instance hosting the Bot Media Platform. MediaPlatformSettings Class that stores settings needed to initialize Bot Media Platform. MediaQualityOfExperienceData Media quality of experience (QoE) data MediaStreamFailureEventArgs Event arguments of the MediaStreamFailure event. NetworkMetrics QoE network level metrics PerfCounterConfiguration Perf counter configuration PortRange The Port range SkypeMediaException Root class for the exceptions that are specific to the Skype Media Bots SDK, ie. exceptions other than the standard .NET Framework exceptions. ToneReceivedEventArgs Event arguments of the ToneReceived event. VideoFormat VideoFormat VideoKeyFrameNeededEventArgs Event arguments of a VideoKeyFrameNeeded event. VideoLowOnFramesEventArgs Video low on frame event args VideoMediaBuffer Represents an unmanaged buffer containing video media data. VideoMediaReceivedEventArgs Event arguments of a VideoMediaReceived event. VideoMediaStreamQualityChangedEventArgs Event arguments of the video media stream quality event. VideoMetrics Video-specific quality of experience metrics VideoQualityOfExperienceData Video quality of experience data VideoReceiveStatusChangedEventArgs Event arguments of a VideoReceiveStatusChanged event. VideoSendCapability The Video Send Capability VideoSendStatusChangedEventArgs Event arguments of a VideoSendStatusChanged event. VideoSettings Video Frame player settings VideoSocket Provides Send and Receive I/O access to a video stream. VideoSocketSettings The video socket settings. Structs UnmixedAudioBuffer Represents an unmanaged audio buffer containing unmixed data corresponding to a specific speaker in a conference. This structure contains a pointer to the unmanaged audio buffer, the length of the buffer and the ID of the audio source of the active speaker. Interfaces IAudioSocket Interface to an AudioSocket. IAudioVideoFramePlayer Interface for the AudioVideoFramePlayer responsible for streaming real time audio video IDataSocket Reserved for the internal use. IMediaPlatform Interface to the MediaPlatform. IMediaPlatformLogger Interface for collecting MediaPlatform logs from the Bots.Media library. IVideoSocket Interface to a VideoSocket. Enums AudioFormat The audio format. DataType Reserved for internal use. HostingEnvironmentConfiguration HostingEnvironmentConfiguration to use for the MediaPlatform. In most cases, the default value is correct. Only in Azure Government clouds do different settings need to be applied. LogLevel Specifies a current logging level for a log line. MediaPlatformHealthStatus Health status of the media platform MediaQualityState Indicates the media quality state MediaReceiveStatus Indicates if the VideoSocket is capable of receiving media. MediaSendStatus Indicates whether an AudioSocket or VideoSocket is capable of sending media. MediaType Indicates the media type of the socket. StreamDirection Stream directionality, from the point-of-view of the local media endpoint. ToneId DTMF Tone Id enum. VideoColorFormat VideoColorFormat VideoQualityType Type of the video media quality VideoResolution Video resolution for vbss and video VideoSinkEncodingFormat VideoSinkEncodingFormats" }, - "client/Microsoft.Graph.Communications.Resources.IResource.html": { - "href": "client/Microsoft.Graph.Communications.Resources.IResource.html", - "title": "Interface IResource", - "keywords": "Interface IResource The stateful resource interface. Inherited Members IResourceBase.CreatedDateTime IResourceBase.Client IResourceBase.GraphClient IResourceBase.GraphLogger IResourceBase.ResourcePath IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public interface IResource : IResourceBase, IDisposable Properties Id Gets the identifier. Declaration string Id { get; } Property Value Type Description String ModifiedDateTime Gets the last modified date time of this resource. Declaration DateTimeOffset ModifiedDateTime { get; } Property Value Type Description DateTimeOffset Resource Gets the resource. Declaration object Resource { get; } Property Value Type Description Object See Also IResourceBase" + "bot_media/Microsoft.Skype.Bots.Media.VideoSendCapability.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoSendCapability.html", + "title": "Class VideoSendCapability", + "keywords": "Class VideoSendCapability The Video Send Capability Inheritance Object VideoSendCapability Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoSendCapability Constructors VideoSendCapability() Declaration public VideoSendCapability() Properties MaxConcurrentSendStreams Maximum number of concurrent streams that can be sent. Declaration public uint MaxConcurrentSendStreams { get; set; } Property Value Type Description UInt32 SupportedSendVideoFormats The list of video formats the VideoSocket supports sending. Declaration public IList SupportedSendVideoFormats { get; set; } Property Value Type Description IList < VideoFormat > Remarks For the main-video modality ( MediaType.Video ), the following ten H264 send video formats are supported: H264_1920x1080_30Fps H264_1280x720_30Fps H264_960x540_30Fps H264_640x360_30Fps H264_640x360_15Fps H264_424x240_15Fps H264_320x180_15Fps H264_320x180_7_5Fps H264_320x180_3_75Fps H264_320x180_1_875Fps (If the SupportedSendVideoFormats list contains other H264 video formats for main-video, they will be ignored and not used.) At least one of the H264_320x180 video formats must be supported. For best video interoperability, the bot should support all the H264_320x180 formats. For the Vbss modality, all of the send formats must be of the same resolution. The resolution should best match the native resolution of the content to be shared. Downscaling the Vbss content to a lower resolution should be avoided (but may be necessary if the native content resolution is larger than 1080p). The bot should support as many different frame rates as possible. The 1.875 fps frame rate must be supported. Methods ToString() String representation of VideoSendCapability Declaration public override string ToString() Returns Type Description String Overrides Object.ToString()" }, - "client/Microsoft.Graph.Communications.Client.Transport.GraphAuthClientFactory.html": { - "href": "client/Microsoft.Graph.Communications.Client.Transport.GraphAuthClientFactory.html", - "title": "Class GraphAuthClientFactory", - "keywords": "Class GraphAuthClientFactory The HTTP graph client factory. Inheritance Object GraphAuthClientFactory Implements IGraphClientFactory Namespace : Microsoft.Graph.Communications.Client.Transport Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class GraphAuthClientFactory : ObjectRoot, IGraphClientFactory Constructors GraphAuthClientFactory(IGraphLogger, JsonSerializerSettings, IRequestAuthenticationProvider, ProductInfoHeaderValue, IEnumerable, HttpClient) Initializes a new instance of the GraphAuthClientFactory class. Declaration public GraphAuthClientFactory(IGraphLogger logger, JsonSerializerSettings jsonSerializerSettings, IRequestAuthenticationProvider authenticationProvider, ProductInfoHeaderValue userAgent, IEnumerable defaultProperties, HttpClient httpClient = null) Parameters Type Name Description IGraphLogger logger Logger instance. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. IRequestAuthenticationProvider authenticationProvider The authentication provider. ProductInfoHeaderValue userAgent The user agent. IEnumerable < IGraphProperty > defaultProperties The default properties. HttpClient httpClient The HTTP client. Properties AuthenticationProvider Gets the authentication provider. Declaration public IRequestAuthenticationProvider AuthenticationProvider { get; } Property Value Type Description IRequestAuthenticationProvider The authentication provider. GraphLogger Gets the graph logger. Declaration public IGraphLogger GraphLogger { get; } Property Value Type Description IGraphLogger Methods Create(IGraphLogger) Creates a new IGraphClient . Declaration public IGraphClient Create(IGraphLogger logger = null) Parameters Type Name Description IGraphLogger logger An optional IGraphLogger logger to be used in the new IGraphClient . Returns Type Description IGraphClient The IGraphClient . Implements IGraphClientFactory See Also ObjectRoot IGraphClientFactory" + "bot_media/Microsoft.Skype.Bots.Media.VideoLowOnFramesEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoLowOnFramesEventArgs.html", + "title": "Class VideoLowOnFramesEventArgs", + "keywords": "Class VideoLowOnFramesEventArgs Video low on frame event args Inheritance Object EventArgs LowOnFramesEventArgs VideoLowOnFramesEventArgs Inherited Members LowOnFramesEventArgs.MediaType LowOnFramesEventArgs.RemainingMediaLengthInMS EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class VideoLowOnFramesEventArgs : LowOnFramesEventArgs Constructors VideoLowOnFramesEventArgs() Declaration public VideoLowOnFramesEventArgs() Properties VideoFormat The video format for the low on frame event Declaration public VideoFormat VideoFormat { get; set; } Property Value Type Description VideoFormat" }, - "client/Microsoft.Graph.Communications.Client.Transport.GraphAuthClient.html": { - "href": "client/Microsoft.Graph.Communications.Client.Transport.GraphAuthClient.html", - "title": "Class GraphAuthClient", - "keywords": "Class GraphAuthClient The graph auth client. Inheritance Object GraphAuthClient Namespace : Microsoft.Graph.Communications.Client.Transport Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class GraphAuthClient : GraphHttpClient Constructors GraphAuthClient(IGraphLogger, JsonSerializerSettings, HttpClient, IRequestAuthenticationProvider, ProductInfoHeaderValue, IEnumerable) Initializes a new instance of the GraphAuthClient class. Declaration public GraphAuthClient(IGraphLogger logger, JsonSerializerSettings jsonSerializerSettings, HttpClient httpClient, IRequestAuthenticationProvider authenticationProvider, ProductInfoHeaderValue userAgent, IEnumerable defaultProperties) Parameters Type Name Description IGraphLogger logger The logger. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. HttpClient httpClient The HTTP client. IRequestAuthenticationProvider authenticationProvider The authentication provider. ProductInfoHeaderValue userAgent The user agent. IEnumerable < IGraphProperty > defaultProperties The default properties. Exceptions Type Condition ArgumentNullException If the authentication provider is null. Methods SendHttpRequestAsync(IGraphRequest, CancellationToken) Declaration protected override Task> SendHttpRequestAsync(IGraphRequest graphRequest, CancellationToken cancellationToken) where T1 : class where T2 : class Parameters Type Name Description IGraphRequest graphRequest CancellationToken cancellationToken Returns Type Description Task < IGraphResponse > Type Parameters Name Description T1 T2 See Also GraphHttpClient" + "common/Microsoft.Graph.Communications.Common.OData.ODataConstants.html": { + "href": "common/Microsoft.Graph.Communications.Common.OData.ODataConstants.html", + "title": "Class ODataConstants", + "keywords": "Class ODataConstants The OData constants. Inheritance Object ODataConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class ODataConstants Fields ODataType The OData type. Declaration public const string ODataType = \"@odata.type\" Field Value Type Description String" }, - "client/Microsoft.Graph.Communications.Client.CommunicationsClientBuilder.html": { - "href": "client/Microsoft.Graph.Communications.Client.CommunicationsClientBuilder.html", - "title": "Class CommunicationsClientBuilder", - "keywords": "Class CommunicationsClientBuilder The class the provides the builder for stateful client. Inheritance Object CommunicationsClientBuilder Implements ICommunicationsClientBuilder Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class CommunicationsClientBuilder : ICommunicationsClientBuilder Constructors CommunicationsClientBuilder(String, String, IGraphLogger, ObfuscationMember[]) Initializes a new instance of the CommunicationsClientBuilder class. Declaration public CommunicationsClientBuilder(string appName, string appId, IGraphLogger logger = null, ObfuscationMember[] additionalObfuscationMembers = null) Parameters Type Name Description String appName Name of the application. String appId The application identifier. IGraphLogger logger The logger ObfuscationMember [] additionalObfuscationMembers Additional members to obfuscate. Properties Id Gets the client id. Declaration public Guid Id { get; } Property Value Type Description Guid Methods Build() Build and return the stateful client object. Declaration public ICommunicationsClient Build() Returns Type Description ICommunicationsClient The ICommunicationsClient . Exceptions Type Condition ArgumentException Cannot build the client without setting the required parameters. SetAuthenticationProvider(IRequestAuthenticationProvider) Sets the custom authentication provider. The authentication provider would add authentication to outbound requests and validates any inbound requests. See IRequestAuthenticationProvider Declaration public ICommunicationsClientBuilder SetAuthenticationProvider(IRequestAuthenticationProvider authenticationProvider) Parameters Type Name Description IRequestAuthenticationProvider authenticationProvider Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the provider is null . SetCacheStrategy(ICache) Sets the cache strategy. Declaration public ICommunicationsClientBuilder SetCacheStrategy(ICache cacheStrategy) Parameters Type Name Description ICache cacheStrategy The cache strategy. Returns Type Description ICommunicationsClientBuilder This ICommunicationsClientBuilder object. Exceptions Type Condition ArgumentNullException If the cacheStrategy strategy is null . SetHttpClient(HttpClient, IEnumerable>) Sets the http client. Use a custom HTTP Client instead of the one generated by the SDK. Declaration public ICommunicationsClientBuilder SetHttpClient(HttpClient httpClient, IEnumerable> defaultHeaders = null) Parameters Type Name Description HttpClient httpClient The place call endpoint URL. IEnumerable < KeyValuePair < String , String >> defaultHeaders The default headers. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the httpClient is null . SetNotificationUrl(Uri) Set the notification uri for your bot. This is the default notification url for the bot. This can be overriden on a per-resource basis depending on the API support. Declaration public ICommunicationsClientBuilder SetNotificationUrl(Uri notificationUrlInput) Parameters Type Name Description Uri notificationUrlInput Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the notificationUrl is null . ArgumentException URI must be https. SetServiceBaseUrl(Uri) Sets the service base URL. This set's the Endpoint URL for the service. Declaration public ICommunicationsClientBuilder SetServiceBaseUrl(Uri serviceBaseUrlInput) Parameters Type Name Description Uri serviceBaseUrlInput Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ArgumentNullException If the serviceBaseUrl is null . ArgumentException URI must be https. Implements ICommunicationsClientBuilder" + "common/Microsoft.Graph.Communications.Common.ExceptionUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.ExceptionUtils.html", + "title": "Class ExceptionUtils", + "keywords": "Class ExceptionUtils Exception utilities Inheritance Object ExceptionUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class ExceptionUtils Methods FindInnerException(Exception) Find the inner exception that caused the error. Declaration public static Exception FindInnerException(this Exception exception) Parameters Type Name Description Exception exception Top level exception. Returns Type Description Exception Inner exception causing the error. FormatException(Exception, Int32) Format the exception including up to depth inner exceptions. Includes stack trace of the last inner exception (up to depth ). Declaration public static string FormatException(this Exception exception, int depth = 4) Parameters Type Name Description Exception exception Top level exception. Int32 depth The depth of inner exceptions, valid range is [1..4]. 1 means that most top exception will be formatted. Returns Type Description String Formatted exception GetBaseException(Exception) Gets the base exception of an exception. If the exception is an AggregateException, then the inner exceptions are flattened before getting the base exception. Declaration public static Exception GetBaseException(Exception exception) Parameters Type Name Description Exception exception The exception Returns Type Description Exception Whether it's base exception" }, - "core/Microsoft.Graph.Communications.Core.Exceptions.ServiceException.html": { - "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ServiceException.html", - "title": "Class ServiceException", - "keywords": "Class ServiceException A Service Exception. Inheritance Object ServiceException Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax [Obsolete(\"Deprecated, please use Microsoft.Graph.ServiceException instead.\")] public class ServiceException : ServiceException Constructors ServiceException(Error, Exception) Initializes a new instance of the ServiceException class. Declaration [Obsolete(\"Deprecated, please use Microsoft.Graph.ServiceException instead.\")] public ServiceException(Error error = null, Exception innerException = null) Parameters Type Name Description Error error The error. Exception innerException The inner exception. ServiceException(Error, HttpResponseHeaders, HttpStatusCode, Exception) Initializes a new instance of the ServiceException class. Declaration [Obsolete(\"Deprecated, please use Microsoft.Graph.ServiceException instead.\")] public ServiceException(Error error, HttpResponseHeaders responseHeaders, HttpStatusCode statusCode, Exception innerException = null) Parameters Type Name Description Error error The error. HttpResponseHeaders responseHeaders The response headers. HttpStatusCode statusCode The status code. Exception innerException The inner exception. See Also ServiceException" + "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.html": { + "href": "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.html", + "title": "Class LogProperties", + "keywords": "Class LogProperties The log properties. Inheritance Object LogProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Client.dll Syntax public static class LogProperties Remarks For better logging experience, all property names should be specific enough. Avoid using generic name such as Id, Name, etc." }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphProperty-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphProperty-1.html", - "title": "Interface IGraphProperty", - "keywords": "Interface IGraphProperty Inherited Members IGraphProperty.Key IGraphProperty.Type IEquatable.Equals(IGraphProperty) Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphProperty : IGraphProperty, IEquatable Type Parameters Name Description T The type of content contained in this property. Properties Value Gets the value. Declaration T Value { get; } Property Value Type Description T Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) GraphProperty.ConvertProperty(IGraphProperty)" + "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.ChatData.html": { + "href": "client/Microsoft.Graph.Communications.Common.Telemetry.LogProperties.ChatData.html", + "title": "Class LogProperties.ChatData", + "keywords": "Class LogProperties.ChatData Chat data. Inheritance Object LogProperties.ChatData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class ChatData Constructors ChatData() Declaration public ChatData() Properties ChatId Gets or sets the chat identifier. Declaration public string ChatId { get; set; } Property Value Type Description String TenantId Gets or sets the tenant identifier. Declaration public string TenantId { get; set; } Property Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphHttpClient.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphHttpClient.html", - "title": "Interface IGraphHttpClient", - "keywords": "Interface IGraphHttpClient Interface for Http transport client. Gives us a way to work with different instances of GraphClient through Dependency Injection. Inherited Members IGraphClient.SendAsync(IGraphRequest, CancellationToken) IGraphClient.SendAsync(IGraphRequest, CancellationToken) IGraphClient.GraphLogger IGraphClient.DefaultProperties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphHttpClient : IGraphClient Properties CustomRedirectUriGenerator Gets or sets the custom redirect URI generator. This is called in case of a redirect (3XX) response from the request. Clients can use this to read the response and give the new redirect url to call in the next request. Declaration Func CustomRedirectUriGenerator { get; set; } Property Value Type Description Func < HttpResponseMessage , Uri > The custom redirect URI generator. Methods Clone(HttpClient) Clones this instance with optional overrides. Declaration IGraphHttpClient Clone(HttpClient httpClient = null) Parameters Type Name Description HttpClient httpClient The HTTP client to replace the original. Returns Type Description IGraphHttpClient Cloned client with the updated properties. SendRawHttpRequestAsync(HttpRequestMessage, CancellationToken) Send a Http request as an asynchronous operation. The content sent using this is not parsed or logged. Declaration Task SendRawHttpRequestAsync(HttpRequestMessage httpRequest, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description HttpRequestMessage httpRequest The http request message to send. CancellationToken cancellationToken The cancellation token. Returns Type Description Task < HttpResponseMessage > The task object representing the asynchronous operation. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) See Also IGraphClient" + "common/Microsoft.Graph.Communications.Common.MathUtils.html": { + "href": "common/Microsoft.Graph.Communications.Common.MathUtils.html", + "title": "Class MathUtils", + "keywords": "Class MathUtils Various math utilities Inheritance Object MathUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class MathUtils Methods CeilingRound(Int32, Int32) Gets the ceiling value after rounding. Declaration public static int CeilingRound(this int n, int round) Parameters Type Name Description Int32 n Value to round up. Int32 round Rounding increment. Returns Type Description Int32 Ceiling value." }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphExchange-1.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphExchange-1.html", - "title": "Interface IGraphExchange", - "keywords": "Interface IGraphExchange The base of the exchange of a IGraphRequest or IGraphResponse . Inherited Members IGraphExchange.Properties Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphExchange : IGraphExchange Type Parameters Name Description T Type of the body of exchange. Properties Content Gets or sets the content of the exchange. Declaration T Content { get; set; } Property Value Type Description T Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "core/Microsoft.Graph.ContractsConstants.CallProperties.html": { + "href": "core/Microsoft.Graph.ContractsConstants.CallProperties.html", + "title": "Class ContractsConstants.CallProperties", + "keywords": "Class ContractsConstants.CallProperties Call properties constants Inheritance Object ContractsConstants.CallProperties Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class CallProperties Fields AllowGuestToBypassLobby The lobbyBypass value for group call join. Declaration public const string AllowGuestToBypassLobby = \"allowGuestToBypassLobby\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.HashingObfuscationEngine.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.HashingObfuscationEngine.html", - "title": "Class HashingObfuscationEngine", - "keywords": "Class HashingObfuscationEngine Obfuscation engine that hashes PII using salt. Inheritance Object HashingObfuscationEngine Implements IObfuscationEngine Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class HashingObfuscationEngine : IObfuscationEngine Constructors HashingObfuscationEngine(Func) Initializes a new instance of the HashingObfuscationEngine class. Declaration public HashingObfuscationEngine(Func saltProvider) Parameters Type Name Description Func < Byte []> saltProvider The salt provider. Properties Enabled Gets a value indicating whether obfuscation is enabled. Declaration public bool Enabled { get; } Property Value Type Description Boolean HashAlgorithm Gets or sets the hash algorithm. Declaration public HashAlgorithm HashAlgorithm { get; set; } Property Value Type Description HashAlgorithm HashLength Gets or sets the length of the hashed payload. Set this to -1 for full salt. Declaration public int HashLength { get; set; } Property Value Type Description Int32 ObfuscationConfiguration Gets or sets the obfuscation configuration. This is also set when configuration is linked to an obfuscation engine. Declaration public ObfuscationConfiguration ObfuscationConfiguration { get; set; } Property Value Type Description ObfuscationConfiguration SaltProvider Gets or sets the salt provider. Declaration protected Func SaltProvider { get; set; } Property Value Type Description Func < Byte []> Methods Obfuscate(Object, ObfuscationTag) Obfuscates the specified payload. Declaration public string Obfuscate(object payload, ObfuscationTag obfuscationTag) Parameters Type Name Description Object payload The payload. ObfuscationTag obfuscationTag The obfuscation tag. Returns Type Description String Obfuscated data. Implements IObfuscationEngine Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "core/Microsoft.Graph.ContractsConstants.AuthConstants.html": { + "href": "core/Microsoft.Graph.ContractsConstants.AuthConstants.html", + "title": "Class ContractsConstants.AuthConstants", + "keywords": "Class ContractsConstants.AuthConstants Various constants used by the AuthZ layer Inheritance Object ContractsConstants.AuthConstants Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class AuthConstants Fields ConsumerTenantIds list of tenant ids that are considered as skype consumer tenants Declaration public static readonly ICollection ConsumerTenantIds Field Value Type Description ICollection < String >" }, - "client/Microsoft.Graph.Communications.Common.Telemetry.CommsLogEventFormatter.html": { - "href": "client/Microsoft.Graph.Communications.Common.Telemetry.CommsLogEventFormatter.html", - "title": "Class CommsLogEventFormatter", - "keywords": "Class CommsLogEventFormatter Test log formatter. Inheritance Object CommsLogEventFormatter Implements ILogEventFormatter Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Client.dll Syntax public class CommsLogEventFormatter : ILogEventFormatter Constructors CommsLogEventFormatter() Declaration public CommsLogEventFormatter() Methods Format(LogEvent) Declaration public string Format(LogEvent logEvent) Parameters Type Name Description LogEvent logEvent Returns Type Description String Implements ILogEventFormatter" + "core/Microsoft.Graph.Communications.Core.html": { + "href": "core/Microsoft.Graph.Communications.Core.html", + "title": "Namespace Microsoft.Graph.Communications.Core", + "keywords": "Namespace Microsoft.Graph.Communications.Core Classes CommsConstants The communications constants. CommsConstants.HttpPropertyNames Constants used for HTTP property names CommsGeneratedErrorConstants The generated error constants. CommsGeneratedErrorConstants.Codes The codes CommsGeneratedErrorConstants.Messages The messages. GraphModelExtensions Generic graph model extensions." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationConfiguration.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationConfiguration.html", - "title": "Class ObfuscationConfiguration", - "keywords": "Class ObfuscationConfiguration Configuration for obfuscation of different parts. Inheritance Object ObfuscationConfiguration HashingObfuscationConfiguration Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ObfuscationConfiguration Constructors ObfuscationConfiguration(IObfuscationEngine, IEnumerable, Boolean, ObfuscationMember[]) Initializes a new instance of the ObfuscationConfiguration class. Declaration public ObfuscationConfiguration(IObfuscationEngine engine, IEnumerable filters = null, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IObfuscationEngine engine The obfuscation engine. IEnumerable < BaseFilter > filters The filters. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . ObfuscationConfiguration(IObfuscationEngine, IEnumerable, IEnumerable, IEnumerable, Boolean, ObfuscationMember[]) Initializes a new instance of the ObfuscationConfiguration class. Declaration public ObfuscationConfiguration(IObfuscationEngine engine, IEnumerable headerFilters, IEnumerable contentDispositionFilters, IEnumerable contentTypeFilters, bool addOdataType = true, ObfuscationMember[] members = null) Parameters Type Name Description IObfuscationEngine engine The obfuscation engine. IEnumerable < HeaderFilter > headerFilters The header filters. IEnumerable < ContentDispositionFilter > contentDispositionFilters The content disposition filters. IEnumerable < ContentTypeFilter > contentTypeFilters The content type filters. Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. ObfuscationMember [] members The predefined set of obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . Properties ContentDispositionFilters Gets the content disposition filters. Declaration public IEnumerable ContentDispositionFilters { get; } Property Value Type Description IEnumerable < ContentDispositionFilter > ContentTypeFilters Gets the content type filters. Declaration public IEnumerable ContentTypeFilters { get; } Property Value Type Description IEnumerable < ContentTypeFilter > DefaultContentDispositionFilters Gets the default content disposition filters. Declaration public static IEnumerable DefaultContentDispositionFilters { get; } Property Value Type Description IEnumerable < ContentDispositionFilter > DefaultContentTypeFilters Gets the default content type filters. Declaration public static IEnumerable DefaultContentTypeFilters { get; } Property Value Type Description IEnumerable < ContentTypeFilter > DefaultHeaderFilters Gets the default header filters. Transfer-Encoding: (redacted) OData-Version: (redacted) Duration: (redacted) Strict-Transport-Security: (redacted) Cache-Control: (redacted) Date: (redacted) Location: (redacted) x-ms-ags-diagnostic: (redacted) scenario-id: (redacted) request-id: (redacted) client-request-id: (redacted) X-Microsoft-Skype-Chain-ID: (redacted) X-Microsoft-Skype-Caller-Region: (redacted) X-Microsoft-Skype-Callee-Region: (redacted) X-Microsoft-Skype-Message-ID: (redacted) X-Microsoft-Skype-Original-Message-ID: (redacted) Declaration public static IEnumerable DefaultHeaderFilters { get; } Property Value Type Description IEnumerable < HeaderFilter > DefaultUriFilters Gets the default header filters. Declaration public static IEnumerable DefaultUriFilters { get; } Property Value Type Description IEnumerable < UriFilter > HeaderFilters Gets the header filters. Declaration public IEnumerable HeaderFilters { get; } Property Value Type Description IEnumerable < HeaderFilter > ObfuscationEngine Gets the obfuscation engine. Declaration public IObfuscationEngine ObfuscationEngine { get; } Property Value Type Description IObfuscationEngine ObfuscationMembers Gets the obfuscation members. When specified the obfuscation serializer will cache the members and check the cache for the ObfuscationTag . This can be used to cache obfuscation attributes, but it can also be used in cases where original contracts are not redily available (such as in SDK). Declaration public ObfuscationMember[] ObfuscationMembers { get; } Property Value Type Description ObfuscationMember [] ObfuscationSerializerSettings Gets the obfuscation serializer settings. Declaration public JsonSerializerSettings ObfuscationSerializerSettings { get; } Property Value Type Description Newtonsoft.Json.JsonSerializerSettings UriFilters Gets the URI filters. Declaration public IEnumerable UriFilters { get; } Property Value Type Description IEnumerable < UriFilter > Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String) HttpObfuscationHelpers.LogHeaderText(ObfuscationConfiguration, IEnumerable>>) HttpObfuscationHelpers.LogHeaderText(ObfuscationConfiguration, String, IEnumerable)" + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.html", + "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry.HttpLogging", + "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry.HttpLogging Classes HttpLogData The log data for http trace. HttpObfuscationHelpers Static class that provides helper functions for HTTP Logging." }, - "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationMember.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationMember.html", - "title": "Struct ObfuscationMember", - "keywords": "Struct ObfuscationMember The obfuscation member. This struct is used to generate an obfuscation schema for any class type or it's members. It can be passed into the GraphObfuscationContractResolver which will cache the schema when resolving object and member obfuscation. Inherited Members ValueType.Equals(Object) ValueType.GetHashCode() ValueType.ToString() Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public struct ObfuscationMember Properties Members Gets or sets the members belonging to this member. Declaration public ObfuscationMember[] Members { get; set; } Property Value Type Description ObfuscationMember [] Name Gets or sets the name of the member. For classes this should be type full name, for members this should be the member name. Declaration public string Name { get; set; } Property Value Type Description String Tag Gets or sets the obfuscation tag. Specifies how this member should be obfuscated. Declaration public ObfuscationTag? Tag { get; set; } Property Value Type Description Nullable < ObfuscationTag > Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "common/Microsoft.Graph.Communications.Common.Telemetry.AadApplicationIdentity.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.AadApplicationIdentity.html", + "title": "Class AadApplicationIdentity", + "keywords": "Class AadApplicationIdentity The application identity in Azure AD. Inheritance Object AadApplicationIdentity Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class AadApplicationIdentity Remarks For better logging experience, all property names should be specific enough. Avoid using generic name such as Id, Name, etc. Constructors AadApplicationIdentity() Declaration public AadApplicationIdentity() Properties AppId Gets or sets the id of application. Declaration public string AppId { get; set; } Property Value Type Description String AppName Gets or sets the name of application. Declaration public string AppName { get; set; } Property Value Type Description String Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.Communications.Core.Notifications.NotificationEventArgs.html": { - "href": "core/Microsoft.Graph.Communications.Core.Notifications.NotificationEventArgs.html", - "title": "Class NotificationEventArgs", - "keywords": "Class NotificationEventArgs Notification event arguments class. Inheritance Object NotificationEventArgs CollectionNotificationEventArgs Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public class NotificationEventArgs Constructors NotificationEventArgs(Uri, CommsNotification, ChangeType, Object) Initializes a new instance of the NotificationEventArgs class. Declaration public NotificationEventArgs(Uri callbackUri, CommsNotification notification, ChangeType changeType, object resourceData) Parameters Type Name Description Uri callbackUri The callback URI. CommsNotification notification The notification. ChangeType changeType Type of the change. Object resourceData The resource data. Properties AdditionalData Gets or sets the additional data. Declaration public IDictionary AdditionalData { get; set; } Property Value Type Description IDictionary < String , Object > CallbackUri Gets the callback URI. Declaration public Uri CallbackUri { get; } Property Value Type Description Uri ChangeType Gets the type of the change. Declaration public ChangeType ChangeType { get; } Property Value Type Description ChangeType Notification Gets the notification. Declaration public CommsNotification Notification { get; } Property Value Type Description CommsNotification NotificationId Gets the notification identifier. Declaration public Guid NotificationId { get; } Property Value Type Description Guid RequestId Gets or sets the request identifier. Declaration public Guid RequestId { get; set; } Property Value Type Description Guid ResourceData Gets the resource data. Declaration public object ResourceData { get; } Property Value Type Description Object ScenarioId Gets or sets the scenario identifier. Declaration public Guid ScenarioId { get; set; } Property Value Type Description Guid TenantId Gets or sets the tenant. Declaration public string TenantId { get; set; } Property Value Type Description String" + "bot_media/Microsoft.Skype.Bots.Media.AudioVideoFramePlayerSettings.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioVideoFramePlayerSettings.html", + "title": "Class AudioVideoFramePlayerSettings", + "keywords": "Class AudioVideoFramePlayerSettings AudioVideoFramePlayer settings. This will help configure the player settings. Inheritance Object AudioVideoFramePlayerSettings Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioVideoFramePlayerSettings Constructors AudioVideoFramePlayerSettings(AudioSettings, VideoSettings, UInt32) Constructor Declaration public AudioVideoFramePlayerSettings(AudioSettings audioSettings, VideoSettings videoSettings, uint minEnqueuedMediaLengthInMs) Parameters Type Name Description AudioSettings audioSettings BufferSize needs to be set to the size of AudioMediaBuffer to be sent VideoSettings videoSettings UInt32 minEnqueuedMediaLengthInMs Properties AudioSettings Audio settings Declaration public AudioSettings AudioSettings { get; set; } Property Value Type Description AudioSettings MinEnqueuedMediaLengthInMs The minimum length after which the player will raise the LowOnFrames event Declaration public uint MinEnqueuedMediaLengthInMs { get; set; } Property Value Type Description UInt32 VideoSettings Video Settings Declaration public VideoSettings VideoSettings { get; set; } Property Value Type Description VideoSettings" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCommunicationsClientExtensions.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCommunicationsClientExtensions.html", - "title": "Class MediaCommunicationsClientExtensions", - "keywords": "Class MediaCommunicationsClientExtensions The stateful client extension. Inheritance Object MediaCommunicationsClientExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public static class MediaCommunicationsClientExtensions Methods CreateMediaSession(ICommunicationsClient, AudioSocketSettings, VideoSocketSettings, VideoSocketSettings, DataSocketSettings, Guid) Creates a local media session for the provided communications client with a given socket configuration. Declaration public static ILocalMediaSession CreateMediaSession(this ICommunicationsClient statefulClient, AudioSocketSettings audioSocketSettings, VideoSocketSettings videoSocketSettings, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null, Guid mediaSessionId = default(Guid)) Parameters Type Name Description ICommunicationsClient statefulClient The stateful client. AudioSocketSettings audioSocketSettings The audio socket settings. VideoSocketSettings videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Guid mediaSessionId The id for the media session. Returns Type Description ILocalMediaSession A ILocalMediaSession . Exceptions Type Condition ArgumentNullException If the communications client has not been specified. ArgumentException If the client does not have a valid identifier. CreateMediaSession(ICommunicationsClient, AudioSocketSettings, IEnumerable, VideoSocketSettings, DataSocketSettings, Guid) Creates a local media session for the provided communications client with a given socket configuration. Declaration public static ILocalMediaSession CreateMediaSession(this ICommunicationsClient client, AudioSocketSettings audioSocketSettings, IEnumerable videoSocketSettings = null, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null, Guid mediaSessionId = default(Guid)) Parameters Type Name Description ICommunicationsClient client The communications client. AudioSocketSettings audioSocketSettings The audio socket settings. IEnumerable < VideoSocketSettings > videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Guid mediaSessionId The id for the media session. Returns Type Description ILocalMediaSession A ILocalMediaSession . Exceptions Type Condition ArgumentNullException If the communications client has not been specified. ArgumentException If the client does not have a valid identifier." + "bot_media/Microsoft.Skype.Bots.Media.AudioSendStatusChangedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.AudioSendStatusChangedEventArgs.html", + "title": "Class AudioSendStatusChangedEventArgs", + "keywords": "Class AudioSendStatusChangedEventArgs Event arguments of an AudioSendStatusChanged event. Inheritance Object EventArgs AudioSendStatusChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class AudioSendStatusChangedEventArgs : EventArgs Constructors AudioSendStatusChangedEventArgs() Declaration public AudioSendStatusChangedEventArgs() Properties MediaSendStatus Status if socket is ready to send media. Declaration public MediaSendStatus MediaSendStatus { get; set; } Property Value Type Description MediaSendStatus" }, - "client/Microsoft.Graph.Communications.Client.CommunicationsClientExtensions.html": { - "href": "client/Microsoft.Graph.Communications.Client.CommunicationsClientExtensions.html", - "title": "Class CommunicationsClientExtensions", - "keywords": "Class CommunicationsClientExtensions Extensions for Stateful Client. Inheritance Object CommunicationsClientExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public static class CommunicationsClientExtensions Methods CreateResponse(ICommunicationsClient, HttpStatusCode, Guid, Guid, Object) Creates the response. Declaration public static HttpResponseMessage CreateResponse(this ICommunicationsClient client, HttpStatusCode statusCode, Guid requestId, Guid scenarioId, object responseContent = null) Parameters Type Name Description ICommunicationsClient client The client. HttpStatusCode statusCode The status code. Guid requestId The request identifier. Guid scenarioId The scenario identifier. Object responseContent The response content. Returns Type Description HttpResponseMessage The HTTP response. LogAndCreateResponse(ICommunicationsClient, HttpRequestMessage, Guid, Guid, CommsNotifications, HttpStatusCode, Stopwatch, Exception) Logs the request, creates the response, and logs the response. Declaration public static HttpResponseMessage LogAndCreateResponse(this ICommunicationsClient client, HttpRequestMessage request, Guid requestId, Guid scenarioId, CommsNotifications notifications, HttpStatusCode statusCode, Stopwatch stopwatch, Exception exception = null) Parameters Type Name Description ICommunicationsClient client The client. HttpRequestMessage request The request. Guid requestId The request identifier. Guid scenarioId The scenario identifier. CommsNotifications notifications The notifications that were extracted. HttpStatusCode statusCode The status code. Stopwatch stopwatch The stopwatch tracking how long the request is taking. Exception exception Any exceptions raised. Returns Type Description HttpResponseMessage The response for the associated request. ProcessNotificationAsync(ICommunicationsClient, HttpRequestMessage) Processes the notifications and raises the required callbacks. This function should be called in order for the SDK to raise any required events and process state changes. Declaration public static Task ProcessNotificationAsync(this ICommunicationsClient client, HttpRequestMessage request) Parameters Type Name Description ICommunicationsClient client The stateful client. HttpRequestMessage request The http request that is incoming from service. Returns Type Description Task < HttpResponseMessage > Http Response Message after processed by the SDK. This has to be returned to the server." + "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.Messages.html": { + "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.Messages.html", + "title": "Class ErrorConstants.Messages", + "keywords": "Class ErrorConstants.Messages Error Messages Inheritance Object ErrorConstants.Messages Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Messages Fields AuthenticationProviderMissing The authentication provider missing Declaration public const string AuthenticationProviderMissing = \"Authentication provider is required before sending a request.\" Field Value Type Description String BaseUrlMissing The base URL missing Declaration public const string BaseUrlMissing = \"Base URL cannot be null or empty.\" Field Value Type Description String ClientErrorAuthenticatingRequest The client error processing notifications Declaration public const string ClientErrorAuthenticatingRequest = \"Unexpected exception happened on client when authenticating request.\" Field Value Type Description String ClientErrorProcessingNotifications The client error processing notifications Declaration public const string ClientErrorProcessingNotifications = \"Unexpected exception happened on client when processing notification.\" Field Value Type Description String InvalidTypeForDateConverter The invalid type for date converter Declaration public const string InvalidTypeForDateConverter = \"DateConverter can only serialize objects of type Date.\" Field Value Type Description String LocationHeaderNotSetOnRedirect The location header not set on redirect Declaration public const string LocationHeaderNotSetOnRedirect = \"Location header not present in redirection response.\" Field Value Type Description String MessageContentIsEmpty The message content is empty Declaration public const string MessageContentIsEmpty = \"Unexpected empty message content.\" Field Value Type Description String NotificationChangeTypeIsEmpty The notification change type is empty Declaration public const string NotificationChangeTypeIsEmpty = \"No change type specified for the incoming notification.\" Field Value Type Description String NotificationResourceDataIsEmpty The notification resource data is empty Declaration public const string NotificationResourceDataIsEmpty = \"No resource data specified for the incoming notification.\" Field Value Type Description String NotificationResourceNotRecognized The notification resource is not recognized Declaration public const string NotificationResourceNotRecognized = \"Resource in notification is not recognized.\" Field Value Type Description String NotificationResourcePathIsEmpty The notification resource path is empty Declaration public const string NotificationResourcePathIsEmpty = \"No resource path specified for the incoming notification.\" Field Value Type Description String NotificationsAreEmpty The notifications are empty Declaration public const string NotificationsAreEmpty = \"Notifications received from server are empty.\" Field Value Type Description String NotificationUriNotSet The notification URI not set Declaration public const string NotificationUriNotSet = \"Notification URI is not set for the resource.\" Field Value Type Description String OverallTimeoutCannotBeSet The overall timeout cannot be set Declaration public const string OverallTimeoutCannotBeSet = \"Overall timeout cannot be set after the first request is sent.\" Field Value Type Description String RehydrationFailedNotFound The re-hydration failed not found Declaration public const string RehydrationFailedNotFound = \"Rehydration is performed on a resource that doesn't exist.\" Field Value Type Description String RehydrationFailedWithEmptyResource The re-hydration failed with empty resource Declaration public const string RehydrationFailedWithEmptyResource = \"Rehydration failed since service returned an empty resource.\" Field Value Type Description String RequestTimedOut The request timed out Declaration public const string RequestTimedOut = \"The request timed out.\" Field Value Type Description String RequestUrlMissing The request URL missing Declaration public const string RequestUrlMissing = \"Request URL is required to send a request.\" Field Value Type Description String TooManyRedirectsFormatString The too many redirects format string Declaration public const string TooManyRedirectsFormatString = \"More than {0} redirects encountered while sending the request.\" Field Value Type Description String UnableToCreateInstanceOfTypeFormatString The unable to create instance of type format string Declaration public const string UnableToCreateInstanceOfTypeFormatString = \"Unable to create an instance of type {0}.\" Field Value Type Description String UnableToDeserializeNotification The unable to deserialize notification Declaration public const string UnableToDeserializeNotification = \"Unable to deserialize the notification.\" Field Value Type Description String UnexpectedExceptionOnSend The unexpected exception on send Declaration public const string UnexpectedExceptionOnSend = \"An error occurred sending the request.\" Field Value Type Description String UnexpectedExceptionResponse The unexpected exception response Declaration public const string UnexpectedExceptionResponse = \"Unexpected exception returned from the service.\" Field Value Type Description String" }, - "client/Microsoft.Graph.Communications.Client.GraphLoggerExtensions.html": { - "href": "client/Microsoft.Graph.Communications.Client.GraphLoggerExtensions.html", - "title": "Class GraphLoggerExtensions", - "keywords": "Class GraphLoggerExtensions The graph logger extensions for the communications client. Inheritance Object GraphLoggerExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Client Assembly : Microsoft.Graph.Communications.Client.dll Syntax public static class GraphLoggerExtensions Methods LogHttpRequest(IGraphLogger, HttpRequestMessage, HttpStatusCode, Object, Exception, String, String, Int32) Logs the request message. Declaration public static TraceLevel LogHttpRequest(this IGraphLogger logger, HttpRequestMessage request, HttpStatusCode statusCode, object requestContent = null, Exception exception = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. HttpRequestMessage request The request. HttpStatusCode statusCode The status code. Object requestContent The request content. Exception exception The exception. String memberName The member name. String filePath The file path. Int32 lineNumber The line number. Returns Type Description TraceLevel The trace level of the logged request message. LogHttpResponse(IGraphLogger, TraceLevel, HttpRequestMessage, HttpResponseMessage, Int64, Object, String, String, Int32) Logs the http response message. Declaration public static void LogHttpResponse(this IGraphLogger logger, TraceLevel level, HttpRequestMessage request, HttpResponseMessage response, long responseTime, object responseContent = null, string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description IGraphLogger logger The logger. TraceLevel level The log level. HttpRequestMessage request The request. HttpResponseMessage response The response. Int64 responseTime The response time in milliseconds. Object responseContent The response content. String memberName The member name. String filePath The file path. Int32 lineNumber The line number. ParseRequestId(IGraphLogger, HttpRequestMessage) Parses the request identifier. Declaration public static Guid ParseRequestId(this IGraphLogger logger, HttpRequestMessage request) Parameters Type Name Description IGraphLogger logger The logger. HttpRequestMessage request The request. Returns Type Description Guid The message id. ParseScenarioId(IGraphLogger, HttpRequestMessage) Parses the scenario identifier. Declaration public static Guid ParseScenarioId(this IGraphLogger logger, HttpRequestMessage request) Parameters Type Name Description IGraphLogger logger The logger. HttpRequestMessage request The request. Returns Type Description Guid The scenario id." + "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.Codes.html": { + "href": "core/Microsoft.Graph.Communications.Core.Exceptions.ErrorConstants.Codes.html", + "title": "Class ErrorConstants.Codes", + "keywords": "Class ErrorConstants.Codes Error Codes Inheritance Object ErrorConstants.Codes Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Exceptions Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class Codes Fields BridgeGone Error code indicating the bridge is gone/deleted from the server. Declaration public const string BridgeGone = \"BridgeGone\" Field Value Type Description String ChatGone Error code indicating the chat is gone/deleted from the server. Declaration public const string ChatGone = \"ChatGone\" Field Value Type Description String ClientCallbackError The client callback error code. Declaration public const string ClientCallbackError = \"clientCallbackError\" Field Value Type Description String ClientContextMissing The client context missing error code. Declaration public const string ClientContextMissing = \"clientContextIsMissing\" Field Value Type Description String GeneralException The general exception error code. Declaration public const string GeneralException = \"generalException\" Field Value Type Description String InvalidRequest The invalid request error code. Declaration public const string InvalidRequest = \"invalidRequest\" Field Value Type Description String ItemNotFound The item not found error code. Declaration public const string ItemNotFound = \"itemNotFound\" Field Value Type Description String MismatchedCompletedOperation The mismatched completed operation error code. Declaration public const string MismatchedCompletedOperation = \"mismatchedCompletedOperation\" Field Value Type Description String NotAllowed The not allowed error code. Declaration public const string NotAllowed = \"notAllowed\" Field Value Type Description String OperationFailed The operation failed error code. Declaration public const string OperationFailed = \"operationFailed\" Field Value Type Description String RehydrationFailedWithEmptyResource The re-hydration failed with empty resource error code. Declaration public const string RehydrationFailedWithEmptyResource = \"rehydrationFailedWithEmptyResource\" Field Value Type Description String RehydrationFailedWithNotFound The re-hydration failed with not found error code. Declaration public const string RehydrationFailedWithNotFound = \"rehydrationFailedWithNotFound\" Field Value Type Description String Timeout The timeout error code. Declaration public const string Timeout = \"timeout\" Field Value Type Description String TooManyRedirects The too many redirects error code. Declaration public const string TooManyRedirects = \"tooManyRedirects\" Field Value Type Description String" }, - "common/Microsoft.Graph.Communications.Common.Telemetry.html": { - "href": "common/Microsoft.Graph.Communications.Common.Telemetry.html", - "title": "Namespace Microsoft.Graph.Communications.Common.Telemetry", - "keywords": "Namespace Microsoft.Graph.Communications.Common.Telemetry Classes AadApplicationIdentity The application identity in Azure AD. CallerInfo Class that encapsulates the caller's (creator's) information ClientEtwLogger Logger for client that publishes to ETW. GraphLogger Logging portion of graph. GraphLoggerShim The graph logger shim. This wrapper on the IGraphLogger attaches some extra data to each log request. GraphLoggerWrapper The ILogger wrapper for IGraphLogger. JsonConverters Json converters. JsonConverters.TypedPropertiesConverter The json converter for Type. LogEvent Log data LogEventFormatter The log event formatter LoggingConstants Constants used for logging that are common between server and client. LoggingExtensions Extensions class for logging. MetricLogData The metric of Geneva Instrumentation Framework (Ifx). Interfaces IGraphLogger The logger interface used by Graph Services. This logger emits logs that can be observed by different observers. ILogEventFormatter Interface to format log event. Enums ClientLogEventId Event ids for client logs HttpTraceType Trace used for HTTP traces. LogEventFormatterFlags The log event formatter enums LogEventType Log event type that describes what type of LogEvent this is. TransactionDirection Direction for request message." + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.HttpObfuscationHelpers.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.HttpObfuscationHelpers.html", + "title": "Class HttpObfuscationHelpers", + "keywords": "Class HttpObfuscationHelpers Static class that provides helper functions for HTTP Logging. Inheritance Object HttpObfuscationHelpers Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class HttpObfuscationHelpers Methods GetUrlText(Uri, Boolean, IEnumerable, IObfuscationEngine) Converts the URL to its representation depending on the filters. Declaration public static string GetUrlText(Uri url, bool obfuscationEnabled, IEnumerable uriFilters = null, IObfuscationEngine engine = null) Parameters Type Name Description Uri url The URL. Boolean obfuscationEnabled if set to true [filter pii]. IEnumerable < UriFilter > uriFilters The URI filters. IObfuscationEngine engine Custom obfuscation engine. If null, use (redacted) Returns Type Description String String representation LogHeaderText(ObfuscationConfiguration, IEnumerable>>) Logs the header text. Declaration public static IEnumerable LogHeaderText(this ObfuscationConfiguration configuration, IEnumerable>> headers) Parameters Type Name Description ObfuscationConfiguration configuration The configuration. IEnumerable < KeyValuePair < String , IEnumerable < String >>> headers The headers. Returns Type Description IEnumerable < String > The obfuscated header and value pairs. LogHeaderText(ObfuscationConfiguration, String, IEnumerable) Logs the header text. Declaration public static string LogHeaderText(this ObfuscationConfiguration configuration, string headerName, IEnumerable headerValues) Parameters Type Name Description ObfuscationConfiguration configuration The configuration. String headerName Name of the header. IEnumerable < String > headerValues The header values. Returns Type Description String The obfuscated header and value pair." }, - "common/Microsoft.Graph.Communications.Common.Transport.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.html", - "title": "Namespace Microsoft.Graph.Communications.Common.Transport", - "keywords": "Namespace Microsoft.Graph.Communications.Common.Transport Classes GraphHttpClient Graph client that handles transport over http. GraphHttpClientContainer This class is used to handle multiple http clients within one service. This class extends the concurrent dictionary and contains a mapping from a key for the client to the http client itself. GraphHttpClientFactory The HTTP graph client factory. GraphProperty The IGraphProperty helpers and extensions. GraphRequest GraphRequest The base of the exchange of a IGraphRequest or IGraphResponse . GraphRequestExtensions Extensions for IGraphRequest class. GraphResponse GraphResponse The base of the exchange of a IGraphRequest or IGraphResponse . GraphResponseException Class representing GraphResponseException GraphResponseExtensions Extensions for IGraphResponse class. HttpRequestMessageExtensions Extensions for HttpRequestMessage . HttpResponseMessageExtensions Extensions for HttpResponseMessage class. NoContentMessage IGraphClient requires type parameters for functionality. This is a marked Type/class to make function calls to IGraphClient indicating we have request/response with no body. The sole purpose of this class's existence is to reduce code duplicacy. Structs GraphProperty Interfaces IGraphClient This class abstracts any communication with different services. This client acts at an object level rather than wire level and thus providing richer experience when working with complex objects. IGraphClientFactory Interface for factory of IGraphClient . IGraphExchange The base of the exchange of a IGraphRequest or IGraphResponse . IGraphExchange The base of the exchange of a IGraphRequest or IGraphResponse . IGraphHttpClient Interface for Http transport client. Gives us a way to work with different instances of GraphClient through Dependency Injection. IGraphProperty The graph property containing request or response data. IGraphProperty IGraphRequest The request object used by the graph sdk. IGraphRequest The request object with content. IGraphResponse The response got in exchange of a IGraphRequest . IGraphResponse The response got in exchange of a IGraphRequest . Enums RequestType Type of request that we want to issue on the transport ResponseStatus Different status of IGraphResponse ." + "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.HttpLogData.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.HttpLogging.HttpLogData.html", + "title": "Class HttpLogData", + "keywords": "Class HttpLogData The log data for http trace. Inheritance Object HttpLogData Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.HttpLogging Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class HttpLogData Constructors HttpLogData() Declaration public HttpLogData() Properties Content Gets or sets the content. Declaration public string Content { get; set; } Property Value Type Description String Headers Gets or sets the headers. Declaration public IEnumerable Headers { get; set; } Property Value Type Description IEnumerable < String > HeadersString Gets the headers string. Declaration public string HeadersString { get; } Property Value Type Description String Method Gets or sets the method. Declaration public string Method { get; set; } Property Value Type Description String ResponseStatusCode Gets or sets the response status code. Declaration public int? ResponseStatusCode { get; set; } Property Value Type Description Nullable < Int32 > ResponseTime Gets or sets the response time in milliseconds. Declaration public long? ResponseTime { get; set; } Property Value Type Description Nullable < Int64 > TraceType Gets or sets the trace type. Declaration public HttpTraceType TraceType { get; set; } Property Value Type Description HttpTraceType TransactionDirection Gets or sets the transaction direction. Declaration public TransactionDirection TransactionDirection { get; set; } Property Value Type Description TransactionDirection Url Gets or sets the url. Declaration public string Url { get; set; } Property Value Type Description String Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.Communications.Core.Notifications.NotificationProcessorExtensions.html": { - "href": "core/Microsoft.Graph.Communications.Core.Notifications.NotificationProcessorExtensions.html", - "title": "Class NotificationProcessorExtensions", - "keywords": "Class NotificationProcessorExtensions Extensions for container client. Inheritance Object NotificationProcessorExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Core.Notifications Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class NotificationProcessorExtensions Methods ExtractResouceData(CommsNotification) Extracts the resource data from the specified notification. Declaration public static object ExtractResouceData(this CommsNotification notification) Parameters Type Name Description CommsNotification notification The notification. Returns Type Description Object The resource data notification content. Exceptions Type Condition ServiceException If the specified notification is invalid. ProcessNotificationAsync(INotificationProcessor, HttpRequestMessage) Processes the notification sent from the server to the client. This overload accepts the type of HttpRequest. Declaration public static Task ProcessNotificationAsync(this INotificationProcessor processor, HttpRequestMessage request) Parameters Type Name Description INotificationProcessor processor The processor. HttpRequestMessage request The request. Returns Type Description Task < HttpResponseMessage > Response to be sent back. SanitizeResource(String, String) Gets the model URI. Declaration public static string SanitizeResource(this string resource, string baseUrl = null) Parameters Type Name Description String resource The resource. String baseUrl The base URL. Returns Type Description String The model uri string. Exceptions Type Condition ArgumentNullException If the resource string is null or whitespace. TryGetGuid(HttpHeaders, String, out Guid) Tries to get the GUID value for the specifed header. Declaration public static bool TryGetGuid(this HttpHeaders headers, string header, out Guid guid) Parameters Type Name Description HttpHeaders headers The headers collection. String header The header to look at. Guid guid The found guid Returns Type Description Boolean True if the specified header is a valid guid, false otherwise." + "common/Microsoft.Graph.Communications.Common.Telemetry.CallerInfo.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.CallerInfo.html", + "title": "Class CallerInfo", + "keywords": "Class CallerInfo Class that encapsulates the caller's (creator's) information Inheritance Object CallerInfo Inherited Members Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class CallerInfo Constructors CallerInfo(String, String, Int32) Initializes a new instance of the CallerInfo class. Declaration public CallerInfo(string memberName = \"\", string filePath = \"\", int lineNumber = 0) Parameters Type Name Description String memberName Name of the member. String filePath The file path. Int32 lineNumber The line number. Methods GetHashCode() Returns a hash code for this instance. Declaration public override int GetHashCode() Returns Type Description Int32 A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. Overrides Object.GetHashCode() ToString() Returns a String that represents the caller info. Declaration public override string ToString() Returns Type Description String A String that represents the caller info. Overrides Object.ToString() Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "core/Microsoft.Graph.Communications.Core.Notifications.html": { - "href": "core/Microsoft.Graph.Communications.Core.Notifications.html", - "title": "Namespace Microsoft.Graph.Communications.Core.Notifications", - "keywords": "Namespace Microsoft.Graph.Communications.Core.Notifications Classes CollectionNotificationEventArgs The collection notification event args. FailedNotificationEventArgs Event arguments used when exceptions are raised in callbacks. NotificationEventArgs Notification event arguments class. NotificationProcessor The notification processor class. NotificationProcessorExtensions Extensions for container client. Interfaces INotificationProcessor The notification processor interface." + "common/Microsoft.Graph.Communications.Common.OData.ODataConfiguration.html": { + "href": "common/Microsoft.Graph.Communications.Common.OData.ODataConfiguration.html", + "title": "Class ODataConfiguration", + "keywords": "Class ODataConfiguration OData Configuration object to be used for different classes. Inheritance Object ODataConfiguration Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.OData Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ODataConfiguration Constructors ODataConfiguration(Boolean, Assembly[]) Initializes a new instance of the ODataConfiguration class. Declaration public ODataConfiguration(bool addOdataType, params Assembly[] odataAssemblies) Parameters Type Name Description Boolean addOdataType If true, attach the @odata.type property, otherwise only attach this property if it's already present as a first class property. Assembly [] odataAssemblies The OData assemblies. Properties JsonSerializerSettingsForOData Gets json serializer settings for OData. Declaration public JsonSerializerSettings JsonSerializerSettingsForOData { get; } Property Value Type Description Newtonsoft.Json.JsonSerializerSettings Newtonsoft.Json.JsonSerializerSettings for serializing/deserializing OData objects. Methods FillODataJsonSerializerSettings(Boolean, JsonSerializerSettings) Fills the json serializer settings. Declaration public JsonSerializerSettings FillODataJsonSerializerSettings(bool addOdataType, JsonSerializerSettings settings) Parameters Type Name Description Boolean addOdataType If true, attach the @odata.type property to each object, otherwise only attach this property if it's already present. Newtonsoft.Json.JsonSerializerSettings settings The settings. Returns Type Description Newtonsoft.Json.JsonSerializerSettings Serialization settings. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "calls/Microsoft.Graph.Communications.Calls.IParticipant.html": { - "href": "calls/Microsoft.Graph.Communications.Calls.IParticipant.html", - "title": "Interface IParticipant", - "keywords": "Interface IParticipant The stateful participant interface. This represents a single participant in a call. Inherited Members IDisposable.Dispose() Namespace : Microsoft.Graph.Communications.Calls Assembly : Microsoft.Graph.Communications.Calls.dll Syntax public interface IParticipant : IResource, IResource, IResourceBase, IDisposable Properties Resource Gets the stateful participant resource. Declaration Participant Resource { get; } Property Value Type Description Participant Methods DeleteAsync(Boolean, CancellationToken) Deletes this participant asynchronously. Declaration Task DeleteAsync(bool handleHttpNotFoundInternally = false, CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description Boolean handleHttpNotFoundInternally If the IParticipant is already gone, whether to handle the exception gracefully or not. CancellationToken cancellationToken The CancellationToken for the request. Returns Type Description Task The Task that completes after the request has been sent. The completion of this task does not guarantee deletion. Confirmation of deletion comes as a notification and can be subscribed by IParticipant.OnUpdated and IParticipantCollection.OnUpdated MuteAsync(CancellationToken) Performs the mute operation asynchronously. Declaration Task MuteAsync(CancellationToken cancellationToken = default(CancellationToken)) Parameters Type Name Description CancellationToken cancellationToken The cancellation token. Returns Type Description Task The Task that completes after the request has been sent. The mute notification will come in on IParticipant.OnUpdated See Also IResource" + "client/Microsoft.Graph.Communications.Resources.CollectionEventHandler-2.html": { + "href": "client/Microsoft.Graph.Communications.Resources.CollectionEventHandler-2.html", + "title": "Delegate CollectionEventHandler", + "keywords": "Delegate CollectionEventHandler The call collection event handler delegate. Namespace : Microsoft.Graph.Communications.Resources Assembly : Microsoft.Graph.Communications.Client.dll Syntax public delegate void CollectionEventHandler(TSender sender, CollectionEventArgs e); Parameters Type Name Description TSender sender The sender. CollectionEventArgs e The event arguments. Type Parameters Name Description TSender The type of the sender. TEntity The type of the arguments. Constructors CollectionEventHandler(Object, IntPtr) Declaration public CollectionEventHandler(object object, IntPtr method) Parameters Type Name Description Object object IntPtr method Methods BeginInvoke(TSender, CollectionEventArgs, AsyncCallback, Object) Declaration public virtual IAsyncResult BeginInvoke(TSender sender, CollectionEventArgs e, AsyncCallback callback, object object) Parameters Type Name Description TSender sender CollectionEventArgs e AsyncCallback callback Object object Returns Type Description IAsyncResult EndInvoke(IAsyncResult) Declaration public virtual void EndInvoke(IAsyncResult result) Parameters Type Name Description IAsyncResult result Invoke(TSender, CollectionEventArgs) Declaration public virtual void Invoke(TSender sender, CollectionEventArgs e) Parameters Type Name Description TSender sender CollectionEventArgs e" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaSession.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaSession.html", - "title": "Class MediaSession", - "keywords": "Class MediaSession Inheritance Object MediaSession Implements ILocalMediaSession IMediaSession IDisposable Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public class MediaSession : ObjectRootDisposable, ILocalMediaSession, IMediaSession, IDisposable Constructors MediaSession(IGraphLogger, Guid, AudioSocketSettings, VideoSocketSettings, VideoSocketSettings, DataSocketSettings) Initializes a new instance of the MediaSession class. Declaration public MediaSession(IGraphLogger logger, Guid mediaSessionId, AudioSocketSettings audioSocketSettings, VideoSocketSettings videoSocketSettings, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null) Parameters Type Name Description IGraphLogger logger The logger. Guid mediaSessionId The media session id. AudioSocketSettings audioSocketSettings The audio socket settings. VideoSocketSettings videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Exceptions Type Condition ArgumentException When no media session id or no valid socket settings have been specified. MediaSession(IGraphLogger, Guid, AudioSocketSettings, IEnumerable, VideoSocketSettings, DataSocketSettings) Initializes a new instance of the MediaSession class. Declaration public MediaSession(IGraphLogger logger, Guid mediaSessionId, AudioSocketSettings audioSocketSettings, IEnumerable videoSocketSettings = null, VideoSocketSettings vbssSocketSettings = null, DataSocketSettings dataSocketSettings = null) Parameters Type Name Description IGraphLogger logger The logger. Guid mediaSessionId The media session id. AudioSocketSettings audioSocketSettings The audio socket settings. IEnumerable < VideoSocketSettings > videoSocketSettings The video socket settings. VideoSocketSettings vbssSocketSettings The video based screen sharing socket settings. DataSocketSettings dataSocketSettings The data socket settings. Exceptions Type Condition ArgumentException When no media session id or no valid socket settings have been specified. Properties AudioSocket Gets the audio socket associated with this media session. Declaration public IAudioSocket AudioSocket { get; } Property Value Type Description IAudioSocket DataSocket Gets the data socket associated with this media session. Declaration public IDataSocket DataSocket { get; } Property Value Type Description IDataSocket MediaSessionId Declaration public Guid MediaSessionId { get; } Property Value Type Description Guid Modalities Declaration public Modality[] Modalities { get; } Property Value Type Description Modality [] VbssSocket Gets the VBSS socket associated with this media session. Declaration public IVideoSocket VbssSocket { get; } Property Value Type Description IVideoSocket VideoSocket Gets the video socket associated with this media session. If current media session contains multiple sockets, this will return the first one in the list. Declaration public IVideoSocket VideoSocket { get; } Property Value Type Description IVideoSocket VideoSockets Gets the list of video socket associated with this media session. Declaration public IReadOnlyList VideoSockets { get; } Property Value Type Description IReadOnlyList < IVideoSocket > Methods Dispose(Boolean) Declaration protected override void Dispose(bool disposing) Parameters Type Name Description Boolean disposing GetMediaConfiguration() Declaration public JObject GetMediaConfiguration() Returns Type Description Newtonsoft.Json.Linq.JObject Implements ILocalMediaSession IMediaSession System.IDisposable" + "client/Microsoft.Graph.Communications.Client.Authentication.html": { + "href": "client/Microsoft.Graph.Communications.Client.Authentication.html", + "title": "Namespace Microsoft.Graph.Communications.Client.Authentication", + "keywords": "Namespace Microsoft.Graph.Communications.Client.Authentication Structs RequestValidationResult The result of the request validation. Interfaces IRequestAuthenticationProvider The authentication provider interface. This is used to authenticate Inbound requests from Microsoft Graph. It validates the request was issued by Microsoft Graph. Outbound requests to Microsoft Graph. Tenant token is acquired to provide Microsoft Graph the permissions the bot has been consented by the tenant admin" }, - "common/Microsoft.Graph.Communications.Common.Transport.IGraphExchange.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.IGraphExchange.html", - "title": "Interface IGraphExchange", - "keywords": "Interface IGraphExchange The base of the exchange of a IGraphRequest or IGraphResponse . Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface IGraphExchange Properties Properties Gets the properties of the exchange. Declaration ICollection Properties { get; } Property Value Type Description ICollection < IGraphProperty > Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" + "bot_media/Microsoft.Skype.Bots.Media.VideoColorFormat.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.VideoColorFormat.html", + "title": "Enum VideoColorFormat", + "keywords": "Enum VideoColorFormat VideoColorFormat Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public enum VideoColorFormat Fields Name Description H264 H264 NV12 NV12 Rgb24 RGB24 Yuy2 YUY2" }, - "core/Microsoft.Graph.Communications.Core.Exceptions.html": { - "href": "core/Microsoft.Graph.Communications.Core.Exceptions.html", - "title": "Namespace Microsoft.Graph.Communications.Core.Exceptions", - "keywords": "Namespace Microsoft.Graph.Communications.Core.Exceptions Classes ClientException Class for client error exception. ErrorConstants Error Constants ErrorConstants.Codes Error Codes ErrorConstants.Messages Error Messages ServiceException A Service Exception." + "bot_media/Microsoft.Skype.Bots.Media.MediaStreamFailureEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaStreamFailureEventArgs.html", + "title": "Class MediaStreamFailureEventArgs", + "keywords": "Class MediaStreamFailureEventArgs Event arguments of the MediaStreamFailure event. Inheritance Object EventArgs MediaStreamFailureEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class MediaStreamFailureEventArgs : EventArgs Constructors MediaStreamFailureEventArgs() Declaration public MediaStreamFailureEventArgs()" }, - "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCommunicationsClientBuilderExtensions.html": { - "href": "calls_media/Microsoft.Graph.Communications.Calls.Media.MediaCommunicationsClientBuilderExtensions.html", - "title": "Class MediaCommunicationsClientBuilderExtensions", - "keywords": "Class MediaCommunicationsClientBuilderExtensions The stateful client builder extension. Inheritance Object MediaCommunicationsClientBuilderExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Calls.Media Assembly : Microsoft.Graph.Communications.Calls.Media.dll Syntax public static class MediaCommunicationsClientBuilderExtensions Methods SetMediaPlatformSettings(ICommunicationsClientBuilder, MediaPlatformSettings) Set the local media platform settings. This function also initializes the local media platform. Declaration public static ICommunicationsClientBuilder SetMediaPlatformSettings(this ICommunicationsClientBuilder statefulClientBuilder, MediaPlatformSettings mediaSettings) Parameters Type Name Description ICommunicationsClientBuilder statefulClientBuilder The stateful client builder. MediaPlatformSettings mediaSettings The media settings. Returns Type Description ICommunicationsClientBuilder The ICommunicationsClientBuilder . Exceptions Type Condition ClientException When something fails while initializing the media platform. TerminateAsync(ICommunicationsClient, Boolean, TimeSpan) Stops the specified stateful client. This would end all the calls and shuts down the media platform. This should only be used during shutdown. Declaration public static Task TerminateAsync(this ICommunicationsClient statefulClient, bool onlyMedia, TimeSpan timeout = default(TimeSpan)) Parameters Type Name Description ICommunicationsClient statefulClient The stateful client. Boolean onlyMedia if set to true terminate only the media platform. TimeSpan timeout The timeout. Returns Type Description Task < Boolean > True if all instances were terminated, false otherwise." + "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformHealthChangedEventArgs.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.MediaPlatformHealthChangedEventArgs.html", + "title": "Class MediaPlatformHealthChangedEventArgs", + "keywords": "Class MediaPlatformHealthChangedEventArgs Event arguments of the MediaPlatformHealthChangedEvent providing the current and previous health status of the media platform. Inheritance Object EventArgs MediaPlatformHealthChangedEventArgs Inherited Members EventArgs.Empty Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public class MediaPlatformHealthChangedEventArgs : EventArgs Constructors MediaPlatformHealthChangedEventArgs() Declaration public MediaPlatformHealthChangedEventArgs() Properties CurrentHealth The current health status. Declaration public MediaPlatformHealthStatus CurrentHealth { get; set; } Property Value Type Description MediaPlatformHealthStatus PreviousHealth The previous health status. Declaration public MediaPlatformHealthStatus PreviousHealth { get; set; } Property Value Type Description MediaPlatformHealthStatus" }, - "client/Microsoft.Graph.Communications.Client.Cache.html": { - "href": "client/Microsoft.Graph.Communications.Client.Cache.html", - "title": "Namespace Microsoft.Graph.Communications.Client.Cache", - "keywords": "Namespace Microsoft.Graph.Communications.Client.Cache Classes ServiceCache The cache that restores the data directly from the service. In this case there is no storage of data, as the service acts as the master. Structs CacheContext The stored cache context Interfaces ICache The cache interface used to store and recover the data used by the SDK." + "bot_media/Microsoft.Skype.Bots.Media.IAudioVideoFramePlayer.html": { + "href": "bot_media/Microsoft.Skype.Bots.Media.IAudioVideoFramePlayer.html", + "title": "Interface IAudioVideoFramePlayer", + "keywords": "Interface IAudioVideoFramePlayer Interface for the AudioVideoFramePlayer responsible for streaming real time audio video Namespace : Microsoft.Skype.Bots.Media Assembly : Microsoft.Skype.Bots.Media.dll Syntax public interface IAudioVideoFramePlayer Methods ClearAsync(Boolean, List) Clears media buffers from the param settings, if nothing is specified it will clear all the audio and video buffers that are in the queue Declaration Task ClearAsync(bool clearAudio = true, List videoFormats = null) Parameters Type Name Description Boolean clearAudio true will clear the audio buffers, default value is set to true List < VideoFormat > videoFormats list of video formats to clear, default value is null Returns Type Description Task EnqueueBuffersAsync(IList, IList) Enqueue the audio and video media buffers. Usage should be to enqueue the same audio and video length, if audio and video socket are active. Declaration Task EnqueueBuffersAsync(IList audioMediaBuffers, IList videoMediaBuffers) Parameters Type Name Description IList < AudioMediaBuffer > audioMediaBuffers IList < VideoMediaBuffer > videoMediaBuffers Returns Type Description Task ShutdownAsync() This will shutdown the player and clean the associated resources Declaration Task ShutdownAsync() Returns Type Description Task Events LowOnFrames This event will be raised if the player is low on frames Declaration event EventHandler LowOnFrames Event Type Type Description EventHandler < LowOnFramesEventArgs >" }, - "common/Microsoft.Graph.Communications.Common.CertUtils.html": { - "href": "common/Microsoft.Graph.Communications.Common.CertUtils.html", - "title": "Class CertUtils", - "keywords": "Class CertUtils Certificates utilities Inheritance Object CertUtils Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class CertUtils Methods GetCertificate(String, StoreLocation) Get certificate from the certificate store, throw exception if not found. Declaration public static X509Certificate2 GetCertificate(string thumbprint, StoreLocation location) Parameters Type Name Description String thumbprint The thumbprint. StoreLocation location The certificate store location. Returns Type Description X509Certificate2 True if the certificate is found. HasPrivateKeyAccess(X509Certificate2, IGraphLogger) Verifies the private key access on a given certificate. If a logger is provided, the cert Common name and any errors are printed out. Declaration public static bool HasPrivateKeyAccess(this X509Certificate2 certificate, IGraphLogger logger = null) Parameters Type Name Description X509Certificate2 certificate The certificate. IGraphLogger logger The logger. Returns Type Description Boolean True if private key can be accessed, false otherwise. TryGetCertificate(String, StoreLocation) Tries to the get certificate from the certificate store. Declaration public static X509Certificate2 TryGetCertificate(string thumbprint, StoreLocation location) Parameters Type Name Description String thumbprint The thumbprint. StoreLocation location The certificate store location. Returns Type Description X509Certificate2 True if the certificate is found. TryGetCertificate(String, String, StoreLocation) Tries to the get certificate from the certificate store. Declaration public static X509Certificate2 TryGetCertificate(string issuer, string enhancedKeyUsage, StoreLocation location) Parameters Type Name Description String issuer The issuer. String enhancedKeyUsage Enhanced key usage. StoreLocation location The certificate store location. Returns Type Description X509Certificate2 True if the certificate is found. TryGetCertificateWithCommonName(String, StoreLocation) Tries to get certificate with common name from the certificate store. Declaration public static X509Certificate2 TryGetCertificateWithCommonName(string commonName, StoreLocation location) Parameters Type Name Description String commonName Name of the common. StoreLocation location The location. Returns Type Description X509Certificate2 The certificate. null if not found." + "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationSerializer.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.Obfuscation.ObfuscationSerializer.html", + "title": "Class ObfuscationSerializer", + "keywords": "Class ObfuscationSerializer The obfuscation serializer can be used to serialize and de-serialize an obfuscation schema, as well as generate a schema from specified assemblies. Inheritance Object ObfuscationSerializer Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Telemetry.Obfuscation Assembly : Microsoft.Graph.Communications.Common.dll Syntax public class ObfuscationSerializer Constructors ObfuscationSerializer() Declaration public ObfuscationSerializer() Properties Members Gets or sets the members belonging to the class. Declaration public ObfuscationMember[] Members { get; set; } Property Value Type Description ObfuscationMember [] Methods ExtractFromAssemblies(Assembly[]) Extracts the obfuscation members from the specified assemblies. Declaration public ObfuscationMember[] ExtractFromAssemblies(params Assembly[] assemblies) Parameters Type Name Description Assembly [] assemblies The assemblies. Returns Type Description ObfuscationMember [] The list of ObfuscationMember stucts extracted from the specified assemblies. GenerateSchema(ObfuscationMember[]) Generates the schema from the specified obfuscation members. Declaration public string GenerateSchema(params ObfuscationMember[] members) Parameters Type Name Description ObfuscationMember [] members The obfuscation classes. Returns Type Description String The schema associated with the specified classes. LoadFromSchema(String) Loads the obfuscations classes from the specified schema. Declaration public ObfuscationMember[] LoadFromSchema(string schema) Parameters Type Name Description String schema The schema. Returns Type Description ObfuscationMember [] The loaded obfuscation classes. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.Extensions.html": { - "href": "common/Microsoft.Graph.Communications.Common.Extensions.html", - "title": "Class Extensions", - "keywords": "Class Extensions Defines Extensions. Inheritance Object Extensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class Extensions Methods ChangeType(Object, Type) Returns an object of the specified type and whose value is equivalent to the specified object. Declaration public static object ChangeType(this object value, Type conversionType) Parameters Type Name Description Object value An object that implements the IConvertible interface. Type conversionType The type of object to return. Returns Type Description Object Converted object Exceptions Type Condition InvalidCastException This conversion is not supported. -or- value is null and conversionType is a value conversionType.-or- value does not implement the IConvertible interface. FormatException value is not in a format recognized by conversionType . OverflowException value represents a number that is out of the range of conversionType . ArgumentNullException conversionType is null. ChangeType(Object) Convert conversionType of an object Declaration public static T ChangeType(this object value) Parameters Type Name Description Object value An object that implements the IConvertible interface. Returns Type Description T Converted object Type Parameters Name Description T Type requested Exceptions Type Condition InvalidCastException This conversion is not supported. -or- value is null and is a value conversionType.-or- value does not implement the IConvertible interface. FormatException value is not in a format recognized by . OverflowException value represents a number that is out of the range of . ArgumentNullException is null. CreateObserver(IObservable, Action, Action, Action) Create observer Declaration public static Observer CreateObserver(this IObservable observable, Action onNext, Action onError = null, Action onCompleted = null) Parameters Type Name Description IObservable observable Object providing the events. Action onNext Callback for data. Action < Exception > onError Callback for errors. Action onCompleted Callback for completion. Returns Type Description Observer New observer object Type Parameters Name Description T Type of the observer. GetDeterministicHashCode(String) Gets deterministic hash code of the given string. Using FNV-1a hash: https://en.wikipedia.org/wiki/Fowler%E2%80%93Noll%E2%80%93Vo_hash_function Declaration public static uint GetDeterministicHashCode(this string str) Parameters Type Name Description String str The string. Returns Type Description UInt32 The unsigned hash code. Lock(Mutex) Lock mutex Declaration public static IDisposable Lock(this Mutex mutex) Parameters Type Name Description Mutex mutex Mutex to enter. Returns Type Description IDisposable Disposable cleanup to release mutex. Pin(Object) Pin object memory. Declaration public static AutoClean Pin(this object obj) Parameters Type Name Description Object obj Object to pin. Returns Type Description AutoClean < IntPtr > Disposable cleanup to release pinned memory. PushDir(String) Push directory and restore when done. Declaration public static IDisposable PushDir(string directory) Parameters Type Name Description String directory New directory to change to. Returns Type Description IDisposable Disposable to restore to previous directory. Read(ReaderWriterLockSlim) Automatic cleanup of entering read lock. Declaration public static IDisposable Read(this ReaderWriterLockSlim lockSlim) Parameters Type Name Description ReaderWriterLockSlim lockSlim Lock instance. Returns Type Description IDisposable Disposable cleanup instance. ReplaceFirst(String, String, String) Replaces the first occurence of search string with replace string. Declaration public static string ReplaceFirst(this string text, string search, string replace) Parameters Type Name Description String text The source text. String search The search string. String replace String to be replaced. Returns Type Description String Updated soruce text. ReplaceScheme(Uri, String, String) Replace URI scheme. Declaration public static Uri ReplaceScheme(this Uri uri, string find, string replace) Parameters Type Name Description Uri uri Subject URI String find Find string. String replace Replace string. Returns Type Description Uri New URI. SafeWait(SemaphoreSlim) Safe wait on semaphore Declaration public static IDisposable SafeWait(this SemaphoreSlim semaphoreSlim) Parameters Type Name Description SemaphoreSlim semaphoreSlim The semaphore to wait on. Returns Type Description IDisposable Disposable cleanup to release semaphore. SafeWaitAsync(SemaphoreSlim) Safe wait on semaphore Declaration public static Task SafeWaitAsync(this SemaphoreSlim semaphoreSlim) Parameters Type Name Description SemaphoreSlim semaphoreSlim The semaphore to wait on. Returns Type Description Task < IDisposable > Disposable cleanup to release semaphore. TrapErrors(Action, IGraphLogger, TraceLevel, String, String, String, Int32) Trap exceptions from action. Declaration public static Exception TrapErrors(this Action action, IGraphLogger logger, TraceLevel level, string component = \"\", string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description Action action Action to run. IGraphLogger logger Logger to log exception data. TraceLevel level Trace level. String component The component in which this log is created. String memberName Calling function. String filePath Filename where code is located. Int32 lineNumber Line number where code is located. Returns Type Description Exception Task containing exception if any. TrapErrors(Action, TKey, IGraphLogger, TraceLevel, String, String, String, Int32) Trap exceptions from action. Declaration public static Exception TrapErrors(this Action action, TKey key, IGraphLogger logger, TraceLevel level, string component = \"\", string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description Action action Action to run. TKey key Key for the action. IGraphLogger logger Logger to log exception data. TraceLevel level Trace level. String component The component in which this log is created. String memberName Calling function. String filePath Filename where code is located. Int32 lineNumber Line number where code is located. Returns Type Description Exception Task containing exception if any. Type Parameters Name Description TKey Action key type. TrapErrorsAsync(Task, IGraphLogger, TraceLevel, String, String, String, Int32) Trap exceptions from antecedent task. Declaration public static Task TrapErrorsAsync(this Task task, IGraphLogger logger, TraceLevel level, string component = \"\", string memberName = null, string filePath = null, int lineNumber = 0) Parameters Type Name Description Task task Antecedent task. IGraphLogger logger Logger to log exception data. TraceLevel level Trace level. String component The component in which this log is created. String memberName Calling function. String filePath Filename where code is located. Int32 lineNumber Line number where code is located. Returns Type Description Task < Exception > Task containing exception if any. TryDispose(Object, IGraphLogger) Try and dispose the object if it supports the right interface. Declaration public static void TryDispose(this object obj, IGraphLogger logger = null) Parameters Type Name Description Object obj Object to dispose. IGraphLogger logger Logger instance. UpgradeableRead(ReaderWriterLockSlim) Automatic cleanup of entering read lock. Declaration public static IDisposable UpgradeableRead(this ReaderWriterLockSlim lockSlim) Parameters Type Name Description ReaderWriterLockSlim lockSlim Lock instance. Returns Type Description IDisposable Disposable cleanup instance. WaitAsync(Task, Int32) Waits for the Task to complete execution within a specified number of milliseconds. Traps errors on the task to avoid unobserved task exceptions. Declaration public static Task WaitAsync(this Task task, int millisecondsTimeout = -1) Parameters Type Name Description Task task Task to wait. Int32 millisecondsTimeout The number of milliseconds to wait, or Infinite (-1) to wait indefinitely. Returns Type Description Task < Boolean > true if the Task completed execution within the allotted time; otherwise, false. Write(ReaderWriterLockSlim) Automatic cleanup of entering write lock. Declaration public static IDisposable Write(this ReaderWriterLockSlim lockSlim) Parameters Type Name Description ReaderWriterLockSlim lockSlim Lock instance. Returns Type Description IDisposable Disposable cleanup instance." + "common/Microsoft.Graph.Communications.Common.Telemetry.ILogEventFormatter.html": { + "href": "common/Microsoft.Graph.Communications.Common.Telemetry.ILogEventFormatter.html", + "title": "Interface ILogEventFormatter", + "keywords": "Interface ILogEventFormatter Interface to format log event. Namespace : Microsoft.Graph.Communications.Common.Telemetry Assembly : Microsoft.Graph.Communications.Common.dll Syntax public interface ILogEventFormatter Methods Format(LogEvent) Format the log event. Declaration string Format(LogEvent logEvent) Parameters Type Name Description LogEvent logEvent The log event Returns Type Description String The formatted text. Extension Methods AdditionalDataExtensions.SetInAdditionalData(Object, String, Object) Extensions.Pin(Object) Extensions.ChangeType(Object, Type) Extensions.ChangeType(Object) Extensions.TryDispose(Object, IGraphLogger) ReflectionUtils.GetPropertyUsingReflection(Object, String) ReflectionUtils.SetPropertyUsingReflection(Object, String, Object) Validator.IsNull(Object, String, String) Validator.NotNull(T, String, String) Validator.Equals(T, T, String, String) Validator.Equals(T, T, String) Validator.NotEquals(T, T, String, String)" }, - "common/Microsoft.Graph.Communications.Common.Transport.GraphRequestExtensions.html": { - "href": "common/Microsoft.Graph.Communications.Common.Transport.GraphRequestExtensions.html", - "title": "Class GraphRequestExtensions", - "keywords": "Class GraphRequestExtensions Extensions for IGraphRequest class. Inheritance Object GraphRequestExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph.Communications.Common.Transport Assembly : Microsoft.Graph.Communications.Common.dll Syntax public static class GraphRequestExtensions Methods ToHttpMethod(RequestType) Convert RequestType to the corresponding HTTP method. Declaration public static HttpMethod ToHttpMethod(this RequestType requestType) Parameters Type Name Description RequestType requestType Type of the request. Returns Type Description HttpMethod HttpMethod for the RequestType ToHttpRequestMessage(IGraphRequest, JsonSerializerSettings, IEnumerable) Converts IGraphRequest into a HttpRequestMessage . Declaration public static HttpRequestMessage ToHttpRequestMessage(this IGraphRequest graphRequest, JsonSerializerSettings jsonSerializerSettings = null, IEnumerable defaultProperties = null) Parameters Type Name Description IGraphRequest graphRequest The graph request to be converted. Newtonsoft.Json.JsonSerializerSettings jsonSerializerSettings The json serializer settings. IEnumerable < IGraphProperty > defaultProperties The default properties. Returns Type Description HttpRequestMessage HttpRequestMessage corresponding to graphRequest . Type Parameters Name Description T Type of content available in the request." + "core/Microsoft.Graph.NotificationsExtensions.html": { + "href": "core/Microsoft.Graph.NotificationsExtensions.html", + "title": "Class NotificationsExtensions", + "keywords": "Class NotificationsExtensions Communications notifications extensions. Inheritance Object NotificationsExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class NotificationsExtensions Methods GetResourceData(CommsNotification) Gets the resource data. Declaration public static object GetResourceData(this CommsNotification notification) Parameters Type Name Description CommsNotification notification The notification. Returns Type Description Object The resource data object for the specified notification. GetResourceData(CommsNotification) Gets the resource data. Declaration public static T GetResourceData(this CommsNotification notification) Parameters Type Name Description CommsNotification notification The notification. Returns Type Description T The resource data T object for the specified notification. Type Parameters Name Description T The expected resource data type. SetResourceData(CommsNotification, Object) Sets the resource data. Declaration public static void SetResourceData(this CommsNotification notification, object data) Parameters Type Name Description CommsNotification notification The notification. Object data The data." }, - "common/Microsoft.Graph.Communications.Common.html": { - "href": "common/Microsoft.Graph.Communications.Common.html", - "title": "Namespace Microsoft.Graph.Communications.Common", - "keywords": "Namespace Microsoft.Graph.Communications.Common Classes AutoClean Helper class to automatically cleanup. AutoClean Helper class to automatically cleanup but with associated state. CertUtils Certificates utilities CollectionUtils Collection Utilities Disposable Common disposable pattern EnumUtils Enum Utilities ExceptionUtils Exception utilities Extensions Defines Extensions. GuidUtils Guid Utils HighResolutionDateTime High resolution datetime HttpConstants The constant values for http. HttpConstants.HeaderNames The header names. JsonUtils Json Utils MathUtils Various math utilities MetricUtils The metric utils class ObjectRoot Base object. ObjectRootDisposable Base object. Observable Observable Base class Observer Observer class. ReflectionUtils Reflection utilities SafeNativeMethods Contains p/invokes and associated wrappers for the Native methods SecureStringUtils SecureString Utilities SlimLock A SemaphoreSlim based lock implementation StateMachine Lockfree enum-based state machine. Transitions are O(1). StateMachine.Transition Single transition from Source to Targets StringUtils String Utils TaskExtension Extensions for Task TaskQueue Task queue to encapsulate chaining of tasks. Utilities Utilities class. Validator Helper class with various condition validation utilities. WeakKey Wrapping a weak reference and recording hash code. Note: It is the responsibility of the client to clean up the collection entry in the finalizer of the object. Otherwise the key will not match for subsequent lookups. WeakKeyDictionary Dictionary with weak reference for the key." + "core/Microsoft.Graph.IdentitySetExtensions.html": { + "href": "core/Microsoft.Graph.IdentitySetExtensions.html", + "title": "Class IdentitySetExtensions", + "keywords": "Class IdentitySetExtensions Extentions for graph api contracts Inheritance Object IdentitySetExtensions Inherited Members Object.ToString() Object.Equals(Object) Object.Equals(Object, Object) Object.ReferenceEquals(Object, Object) Object.GetHashCode() Object.GetType() Object.MemberwiseClone() Namespace : Microsoft.Graph Assembly : Microsoft.Graph.Communications.Core.dll Syntax public static class IdentitySetExtensions Fields DodAppParticipantPrefix The application participant prefix for dod cloud Declaration public const string DodAppParticipantPrefix = \"28:dod-global:\" Field Value Type Description String DodDirectoryAppParticipantPrefix The directory application participant prefix for dod cloud Declaration public const string DodDirectoryAppParticipantPrefix = \"28:dod:\" Field Value Type Description String DodDirectoryParticipantPrefix The directory participant prefix for DoD cloud Declaration public const string DodDirectoryParticipantPrefix = \"8:dod:\" Field Value Type Description String DodOnPremisesParticipantPrefix The external prefix for DoD cloud Declaration public const string DodOnPremisesParticipantPrefix = \"8:dod-sfb:\" Field Value Type Description String EncryptedParticipantPrefix The encrypted participant prefix Declaration public const string EncryptedParticipantPrefix = \"29:\" Field Value Type Description String GcchAppParticipantPrefix The application participant prefix for gcch cloud Declaration public const string GcchAppParticipantPrefix = \"28:gcch-global:\" Field Value Type Description String GcchDirectoryAppParticipantPrefix The directory application participant prefix for gcch cloud Declaration public const string GcchDirectoryAppParticipantPrefix = \"28:gcch:\" Field Value Type Description String GcchDirectoryParticipantPrefix The directory participant prefix for GCCH cloud Declaration public const string GcchDirectoryParticipantPrefix = \"8:gcch:\" Field Value Type Description String GcchOnPremisesParticipantPrefix The external prefix for GCCH cloud Declaration public const string GcchOnPremisesParticipantPrefix = \"8:gcch-sfb:\" Field Value Type Description String PhoneParticipantPrefix The phone participant prefix Declaration public const string PhoneParticipantPrefix = \"4:\" Field Value Type Description String PublicAppParticipantPrefix The application participant prefix Declaration public const string PublicAppParticipantPrefix = \"28:\" Field Value Type Description String PublicDirectoryAppParticipantPrefix The directory application participant prefix for public cloud Declaration public const string PublicDirectoryAppParticipantPrefix = \"28:orgid:\" Field Value Type Description String PublicDirectoryParticipantPrefix The directory participant prefix for public cloud Declaration public const string PublicDirectoryParticipantPrefix = \"8:orgid:\" Field Value Type Description String PublicOnPremisesParticipantPrefix The external prefix for public cloud Declaration public const string PublicOnPremisesParticipantPrefix = \"8:sfb:\" Field Value Type Description String SkypeParticipantPrefix The skype participant prefix Declaration public const string SkypeParticipantPrefix = \"8:\" Field Value Type Description String TeamsVisitorParticipantPrefix The teams visitor participant prefix For anonymous users we need to support 8:teamsvisitor:objectId Declaration public const string TeamsVisitorParticipantPrefix = \"8:teamsvisitor:\" Field Value Type Description String Methods CreateIdentitySetByMri(String, String, String) Creates participant from MRI if possible. For chat service thread mris we return null Declaration public static IdentitySet CreateIdentitySetByMri(string mri, string tenantId, string displayName) Parameters Type Name Description String mri Participant MRI String tenantId The tenant identifier. String displayName The display name. Returns Type Description IdentitySet Created identity set Exceptions Type Condition ArgumentOutOfRangeException mri GetAppParticipantPrefix(CloudNamespace) Gets app participant prefix for the provided CloudNamespace . Declaration public static string GetAppParticipantPrefix(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace The cloud where the app participant belongs Returns Type Description String Prefix to be used to construct the MRI GetDirectoryAppParticipantEnv(CloudNamespace) Returns the env differentiator part of the app participant prefix corresponding to cloudNamespace . This differentiator doesn't have participant prefix (8:, 4:, 28: or 29:) in it. Declaration public static string GetDirectoryAppParticipantEnv(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace Cloud environment where the identity set belongs Returns Type Description String Env differentiator part of the app participant prefix corresponding to cloudNamespace GetDirectoryAppParticipantPrefix(CloudNamespace) Gets directory app participant prefix for the provided CloudNamespace . Declaration public static string GetDirectoryAppParticipantPrefix(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace The cloud where the directory app participant belongs Returns Type Description String Prefix to be used to construct the MRI GetDirectoryParticipantPrefix(CloudNamespace) Gets a user prefix for the provided CloudNamespace . Declaration public static string GetDirectoryParticipantPrefix(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace The cloud where the user belongs Returns Type Description String Prefix to be used to construct the MRI GetEnumerator(IdentitySet) Enumerates through all the Identity objects found in this IdentitySet Declaration public static IEnumerable> GetEnumerator(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description IEnumerable < KeyValuePair < String , Identity >> The IEnumerable{KeyValuePair{string, Identity}} for the specified IdentitySet . GetMri(IdentitySet, CloudNamespace) Gets participant MRI The priority order is: User, Guest, Encrypted, Application Instance, Application, Phone Declaration public static string GetMri(this IdentitySet identitySet, CloudNamespace cloudNamespace) Parameters Type Name Description IdentitySet identitySet Participant identity set CloudNamespace cloudNamespace Cloud environment where the identity set belongs Returns Type Description String Participant MRI GetObjectIdForAppParticipant(String) Get the object id for an app Declaration public static string GetObjectIdForAppParticipant(string mri) Parameters Type Name Description String mri participant mri Returns Type Description String The object id of the participant> GetObjectIdForDirectoryAppParticipant(String) Get the object id for a directory app participant Declaration public static string GetObjectIdForDirectoryAppParticipant(string mri) Parameters Type Name Description String mri participant mri Returns Type Description String The object id of the participant> GetObjectIdForDirectoryParticipant(String) /Get the object id for a directory participant Declaration public static string GetObjectIdForDirectoryParticipant(string mri) Parameters Type Name Description String mri participant mri Returns Type Description String The object id of the participant> GetObjectIdForOnPremisesParticipant(String) /Get the object id for an external participant Declaration public static string GetObjectIdForOnPremisesParticipant(string mri) Parameters Type Name Description String mri participant mri Returns Type Description String The object id of the participant> GetOnPremisesParticipantPrefix(CloudNamespace) Gets an external prefix for the provided CloudNamespace . Declaration public static string GetOnPremisesParticipantPrefix(CloudNamespace cloudNamespace) Parameters Type Name Description CloudNamespace cloudNamespace The cloud where the user belongs Returns Type Description String Prefix to be used to construct the MRI GetPrimaryIdentity(IdentitySet) Gets the primary identity from the specified IdentitySet . The priority order is: User, Guest, Phone, Encrypted, OnPremises, Application Instance, Application Declaration public static Identity GetPrimaryIdentity(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Identity Primary Identity IsConsumer(IdentitySet) Indicates whether this identity set is a consumer identity. Declaration public static bool IsConsumer(this IdentitySet identitySet) Parameters Type Name Description IdentitySet identitySet The identity set. Returns Type Description Boolean true if the identity is a consumer identity, false otherwise. MriHasAppParticipantPrefix(String) Returns whether a MRI is a directory participant prefix or not. Declaration public static bool MriHasAppParticipantPrefix(string mri) Parameters Type Name Description String mri Participant MRI Returns Type Description Boolean true if mri is a valid directory participant prefix MriHasDirectoryAppParticipantPrefix(String) Returns whether a MRI is a directory participant prefix or not. Declaration public static bool MriHasDirectoryAppParticipantPrefix(string mri) Parameters Type Name Description String mri Participant MRI Returns Type Description Boolean true if mri is a valid directory participant prefix MriHasDirectoryParticipantPrefix(String) Returns whether a MRI is a directory participant prefix or not. Declaration public static bool MriHasDirectoryParticipantPrefix(string mri) Parameters Type Name Description String mri Participant MRI Returns Type Description Boolean true if mri is a valid directory participant prefix MriHasOnPremisesParticipantPrefix(String) Returns whether a MRI is an external participant prefix or not. Declaration public static bool MriHasOnPremisesParticipantPrefix(string mri) Parameters Type Name Description String mri Participant MRI Returns Type Description Boolean true if mri is a valid external participant prefix" } } \ No newline at end of file diff --git a/docs/manifest.json b/docs/manifest.json index 7df775fc..644b3603 100644 --- a/docs/manifest.json +++ b/docs/manifest.json @@ -42,7 +42,7 @@ "output": { ".html": { "relative_path": "articles/Logging.html", - "hash": "odfH40dACl3Fh8rR5Dt3+g==" + "hash": "cAZrNrk4ylqLQSMRllIJvw==" } }, "is_incremental": false, @@ -54,7 +54,7 @@ "output": { ".html": { "relative_path": "articles/Testing.html", - "hash": "VLBLQTFfvBB65DP0lFvMYA==" + "hash": "Dh1m0k4Tx1Sa6AZUWDJpUA==" } }, "is_incremental": false, @@ -97,12 +97,15 @@ "version": "" }, { + "log_codes": [ + "UidNotFound" + ], "type": "Conceptual", "source_relative_path": "articles/calls/appHostedMediaCalls.md", "output": { ".html": { "relative_path": "articles/calls/appHostedMediaCalls.html", - "hash": "UEYWigiODE5IF3a3LKqgag==" + "hash": "RT3NeUYo0xjnOu1U5ym0AQ==" } }, "is_incremental": false, @@ -126,7 +129,7 @@ "output": { ".html": { "relative_path": "articles/calls/register-calling-bot.html", - "hash": "6TJLi1E6wgvtxD7wqYPtNQ==" + "hash": "jhO8QHjC0P778ZDSz9QBsA==" } }, "is_incremental": false, @@ -145,12 +148,15 @@ "version": "" }, { + "log_codes": [ + "UidNotFound" + ], "type": "Conceptual", "source_relative_path": "articles/index.md", "output": { ".html": { "relative_path": "articles/index.html", - "hash": "skP+1IhOrAjthwxj+e/mRg==" + "hash": "Yz7PIwdBNpI6jpdhpFdMmA==" } }, "is_incremental": false, @@ -241,12 +247,15 @@ "version": "" }, { + "log_codes": [ + "UidNotFound" + ], "type": "Conceptual", "source_relative_path": "index.md", "output": { ".html": { "relative_path": "index.html", - "hash": "48hBHr0N/ymXkkZ8cGHBPQ==" + "hash": "+Wy+ceZgotx/d1DgrVZc8A==" } }, "is_incremental": false, @@ -3756,6 +3765,39 @@ "is_incremental": false, "version": "" }, + { + "type": "Resource", + "source_relative_path": "resources/app-studio-app-details-app-id.png", + "output": { + "resource": { + "relative_path": "resources/app-studio-app-details-app-id.png" + } + }, + "is_incremental": false, + "version": "" + }, + { + "type": "Resource", + "source_relative_path": "resources/app-studio-connect-to-a-bot-id.png", + "output": { + "resource": { + "relative_path": "resources/app-studio-connect-to-a-bot-id.png" + } + }, + "is_incremental": false, + "version": "" + }, + { + "type": "Resource", + "source_relative_path": "resources/app-studio-connect-to-bot-id.png", + "output": { + "resource": { + "relative_path": "resources/app-studio-connect-to-bot-id.png" + } + }, + "is_incremental": false, + "version": "" + }, { "type": "Resource", "source_relative_path": "resources/app-studio-create-new.png", @@ -3880,17 +3922,17 @@ "details": "Processor TocDocumentProcessor cannot support incremental build because the processor doesn't implement ISupportIncrementalDocumentProcessor interface.", "incrementalPhase": "build" }, - "ResourceDocumentProcessor": { - "can_incremental": false, - "details": "Processor ResourceDocumentProcessor cannot support incremental build because the processor doesn't implement ISupportIncrementalDocumentProcessor interface.", + "ConceptualDocumentProcessor": { + "can_incremental": true, "incrementalPhase": "build" }, "ManagedReferenceDocumentProcessor": { "can_incremental": true, "incrementalPhase": "build" }, - "ConceptualDocumentProcessor": { - "can_incremental": true, + "ResourceDocumentProcessor": { + "can_incremental": false, + "details": "Processor ResourceDocumentProcessor cannot support incremental build because the processor doesn't implement ISupportIncrementalDocumentProcessor interface.", "incrementalPhase": "build" } } diff --git a/docs/resources/app-studio-app-details-app-id.png b/docs/resources/app-studio-app-details-app-id.png new file mode 100644 index 0000000000000000000000000000000000000000..417d01e6e5843c24bd8bd578832b6b9a1b8e9754 GIT binary patch literal 81520 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

    v}X_b-x_aq7%8EP>8=cczuh^IT^w+)fyO zfZT1YE4>}GQx25=ih+D2do`wmi~7ZNw2#;1?zCS+*Q3Z7mOGDn_HlJg+<)jUmBqeX zXC5dKU*<;)Kknk4dP-m?YJnKzJ*#N5e)&>AzuklMwm9*i%FNyEeEqg3$mWvo@6Asj zi+tb4429a+AZ`usqyNC5RRDNqu-q!*pVtp!YIB;`2ZqcOZ1wYq07s1`1c$i|d7Hf$@UILAEM8%_{^C!*@V#gq5R2nDS@K_Encb6~Y(24)VK#;)zxS|R|E<5@71?A@A zZ8Q39UbJJ;M_1P=hfi6jA&N6%uE5zg75V}q1+wTlU7#n5^ac-Xm)p!&Tm80(qMPHT zpGC!3n^TF}R|jSo777V4Gv_}#u?KxJYYL)l0*(6)$XkKctXG0tg+vRioUh89if-R> zi^xJh5}!0WJ2V_HiE~#QUb3s9@&695z0U5NP2l{h^?63>1~FH&tsgyYRc+ga>b#VQkuN2TTTDe=!d+06Y6=Q&xp3PkrVD&!>XQp{`3 zVsYUAsGNdqV6j_*Z?`3~ZVU!7$r9wfUHE4jI2_L0{Iw7kIC<|~XGgw2-v=5n5S$4k z*(vN<(Q8S>7{cm~8+^xT196IKzIUIKfX#CpSAGnD4@hMMpl2=Hy)3AZn$|?He2X*F zZ3C(nRFsC>1TB%-5QH68o!SHR*4VJJUn6sfPjBewvh&wU_YYz$SM6mxIg+Bw0G4B8 zDqz=h^s(mU^rJaiUQ(Bm*AOtI)oT9nV*>F*5oO}1YW7d!r`(*y@^<+t+qf+^%ii$j zDDnxJzbX=mLOG_S{P1UMu`|0)GUoY|8$5eZcc*P2-(JD{BO@!_ddXx`G(G>RMu0MSJ0W6has>l7G5}zHe9a z?5lNvABX?TL&Bt|dVG5RXfI*ijU1*xp)3lh*7~4_7&n}+S2^O#Ajr`nt$FFI`QfNr zZI-D6)%cmcMPqE+6OKS*gd1Ryt=9xPZ=@^XxKUMkdB8=PU8zz~?LF^g&TN$3$)lTd z3wnYh!sgfr+c(W2AB|<_hSgnlqJpq!LnGdVXnr$akDjHX?Tmz?qM~+BCB7d$_qIzD z2gC?170bOyD@@d@!tIrKC`vYG8g@guANIMSvr=$sfvY$iORdJ48i916e9n*a`?cGs z>=HFsCi+QM5RO*Gl2@^`7|G1`M*yq)($Z9Yw!fd11k2&jE+yp2}f%7PWI(>ak+dQ#iId#U=e z`L5};@k_KR)p)7&@oo1$eBvz$-iaj8nCJO70On|BU+6xyY-D3!hKHgWp}cs_+YK*#1U5TluX|efGz{r1fy~c*Q&_5rjLf6^ow0?b$F|~BDqHvLd|8> z)gej%%J5Z|cqa1!-Qzy=c;GlPjFDM(D#6)1qhEl*9AYc5ucjP7H9c*e4d`NZtYmj2 z$H??4XSC-;2RL_EiX?S0ip>F`AbE#Ba9)sCe3Gdl5G#GP8%=XOW)O3bN9C{(iLdek zGXfvL&u%6u;w*3k;6RWnKF_v6ez_6>owZ+RUUBcoT(|;IKm7O~fFxk4Q*)^{Z^*%N*RTC#<vlGp1;nh_s))Ys$3)mo(s%gm8CK+UBCbT E0k~cfyZ`_I literal 0 HcmV?d00001 diff --git a/docs/resources/app-studio-connect-to-a-bot-id.png b/docs/resources/app-studio-connect-to-a-bot-id.png new file mode 100644 index 0000000000000000000000000000000000000000..4e7162bc22141265a9d7ca80a7086e54143e6e85 GIT binary patch literal 15660 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 W$C!GjSn!1NGjU;Qp&|io@Bao-KwGc? literal 0 HcmV?d00001 diff --git a/docs/resources/app-studio-connect-to-bot-id.png b/docs/resources/app-studio-connect-to-bot-id.png new file mode 100644 index 0000000000000000000000000000000000000000..4e7162bc22141265a9d7ca80a7086e54143e6e85 GIT binary patch literal 15660 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 W$C!GjSn!1NGjU;Qp&|io@Bao-KwGc? literal 0 HcmV?d00001