Skip to content

Commit

Permalink
Callautomation/release/beta2 features (#37485)
Browse files Browse the repository at this point in the history
Beta 2 features implementation of PMA BETA2_2023_06_15_preview contract:

SendDtmf
DtmfSubscription
PlayTTS
PlaySSML
Recognize Choices
Recognize Freeform
Mute
BYO Cogsvc changes for Answer/CreateCall
  • Loading branch information
abhishesingh-msft committed Sep 18, 2023
1 parent dbe1f9b commit 18060f2
Show file tree
Hide file tree
Showing 98 changed files with 2,948 additions and 611 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
# Release History

## 1.1.0-beta.1 (Unreleased)
- Play and recognize supports TTS and SSML source prompts.
- Recognize supports choices and freeform speech.
- Start/Stop continuous DTMF recognition by subscribing/unsubscribing to tones.
- Send DTMF tones to a participant in the call.
- Mute participants in the call.

### Features Added

Expand Down

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -208,11 +208,13 @@ public virtual Response<AnswerCallResult> AnswerCall(AnswerCallOptions options,
private AnswerCallRequestInternal CreateAnswerCallRequest(AnswerCallOptions options)
{
AnswerCallRequestInternal request = new AnswerCallRequestInternal(options.IncomingCallContext, options.CallbackUri.AbsoluteUri);

// Add custom cognitive service domain name
if (options.AzureCognitiveServicesEndpointUri != null)
{
request.AzureCognitiveServicesEndpointUrl = options.AzureCognitiveServicesEndpointUri.AbsoluteUri;
}

request.AnsweredBy = Source == null ? null : new CommunicationUserIdentifierModel(Source.Id);
request.OperationContext = options.OperationContext;

Expand Down Expand Up @@ -578,6 +580,7 @@ private CreateCallRequestInternal CreateCallRequest(CreateCallOptions options)
{
request.AzureCognitiveServicesEndpointUrl = options.AzureCognitiveServicesEndpointUri.AbsoluteUri;
}

request.OperationContext = options.OperationContext;

return request;
Expand All @@ -601,6 +604,7 @@ private CreateCallRequestInternal CreateCallRequest(CreateGroupCallOptions optio
{
request.AzureCognitiveServicesEndpointUrl = options.AzureCognitiveServicesEndpointUri.AbsoluteUri;
}

request.OperationContext = options.OperationContext;
return request;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ public class CallAutomationClientOptions : ClientOptions
/// <summary>
/// The latest version of the CallAutomation service.
/// </summary>
internal const ServiceVersion LatestVersion = ServiceVersion.V2023_03_06;
internal const ServiceVersion LatestVersion = ServiceVersion.V2023_06_15_Preview;

internal string ApiVersion { get; }

Expand All @@ -33,6 +33,7 @@ public CallAutomationClientOptions(ServiceVersion version = LatestVersion)
ApiVersion = version switch
{
ServiceVersion.V2023_03_06 => "2023-03-06",
ServiceVersion.V2023_06_15_Preview => "2023-06-15-preview",
_ => throw new ArgumentOutOfRangeException(nameof(version)),
};
}
Expand All @@ -46,7 +47,11 @@ public enum ServiceVersion
/// The GA1 of the CallAutomation service.
/// </summary>
#pragma warning disable CA1707 // Identifiers should not contain underscores
V2023_03_06 = 1
V2023_03_06 = 1,
/// <summary>
/// The beta2 of the CallAutomation service.
/// </summary>
V2023_06_15_Preview = 2
#pragma warning restore CA1707 // Identifiers should not contain underscores
}
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

namespace Azure.Communication.CallAutomation
{
/// <summary><see cref="SendDtmfEventResult"/> is returned from WaitForEvent of <see cref="SendDtmfResult"/>.</summary>
public class SendDtmfEventResult
{
/// <summary>
/// Indicates whether the returned event is considered successful or not.
/// </summary>
public bool IsSuccess { get; internal set; }

/// <summary>
/// <see cref="SendDtmfCompleted"/> event will be returned once the dtmf tones have been sent successfully.
/// </summary>
public SendDtmfCompleted SuccessResult { get; }

/// <summary>
/// <see cref="SendDtmfFailed"/> event will be returned if send dtmf tones completed unsuccessfully.
/// </summary>
public SendDtmfFailed FailureResult { get; }

internal SendDtmfEventResult(bool isSuccess, SendDtmfCompleted successResult, SendDtmfFailed failureResult)
{
IsSuccess = isSuccess;
SuccessResult = successResult;
FailureResult = failureResult;
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -613,17 +613,13 @@ public virtual CallMedia GetCallMedia()
/// Only Acs Users are currently supported.
/// </summary>
/// <param name="targetParticipant">Participant to mute.</param>
/// <param name="operationContext">The Operation Context.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <exception cref="RequestFailedException">The server returned an error. See <see cref="Exception.Message"/> for details returned from the server.</exception>
/// <exception cref="ArgumentNullException"> <paramref name="targetParticipant"/> is null. </exception>
/// <returns>A Response containing MuteParticipantsResult.</returns>
public virtual Response<MuteParticipantsResult> MuteParticipants(CommunicationIdentifier targetParticipant, string operationContext = default, CancellationToken cancellationToken = default)
/// <returns>A Response containing MuteParticipantsResponse.</returns>
public virtual Response<MuteParticipantsResult> MuteParticipants(CommunicationIdentifier targetParticipant, CancellationToken cancellationToken = default)
{
var options = new MuteParticipantsOptions(new List<CommunicationIdentifier> { targetParticipant })
{
OperationContext = operationContext
};
var options = new MuteParticipantsOptions(new List<CommunicationIdentifier> { targetParticipant });

return MuteParticipants(options, cancellationToken);
}
Expand All @@ -636,7 +632,7 @@ public virtual Response<MuteParticipantsResult> MuteParticipants(CommunicationId
/// <param name="cancellationToken">The cancellation token.</param>
/// <exception cref="RequestFailedException">The server returned an error. See <see cref="Exception.Message"/> for details returned from the server.</exception>
/// <exception cref="ArgumentNullException"> <paramref name="options"/> is null. </exception>
/// <returns>A Response containing MuteParticipantsResult. </returns>
/// <returns>A Response containing MuteParticipantsResponse. </returns>
public virtual Response<MuteParticipantsResult> MuteParticipants(MuteParticipantsOptions options, CancellationToken cancellationToken = default)
{
using DiagnosticScope scope = _clientDiagnostics.CreateScope($"{nameof(CallConnection)}.{nameof(MuteParticipants)}");
Expand All @@ -648,59 +644,16 @@ public virtual Response<MuteParticipantsResult> MuteParticipants(MuteParticipant

MuteParticipantsRequestInternal request = new MuteParticipantsRequestInternal(
options.TargetParticipants.Select(participant => CommunicationIdentifierSerializer.Serialize(participant)));
var repeatabilityHeaders = new RepeatabilityHeaders();

request.OperationContext = options.OperationContext;

return RestClient.Mute(CallConnectionId, request, cancellationToken);
}
catch (Exception ex)
{
scope.Failed(ex);
throw;
}
}

/// <summary>
/// Unmute participant from the call.
/// Only Acs Users are currently supported.
/// </summary>
/// <param name="targetParticipant">Participant to unmute.</param>
/// <param name="operationContext">The Operation Context.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <exception cref="ArgumentNullException"> <paramref name="targetParticipant"/> is null. </exception>
/// <exception cref="RequestFailedException">The server returned an error. See <see cref="Exception.Message"/> for details returned from the server.</exception>
/// <returns></returns>
public virtual Response<UnmuteParticipantsResult> UnmuteParticipants(CommunicationIdentifier targetParticipant, string operationContext = default, CancellationToken cancellationToken = default)
{
var options = new UnmuteParticipantsOptions(new List<CommunicationIdentifier> { targetParticipant })
{
OperationContext = operationContext,
};
return UnmuteParticipants(options, cancellationToken);
}

/// <summary>
/// Unmute participants from the call.
/// Only Acs Users are currently supported.
/// </summary>
/// <param name="options">Options for the UnmuteParticipant operation.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <exception cref="ArgumentNullException"> <paramref name="options"/> is null. </exception>
/// <exception cref="ArgumentException"> <paramref name="options"/> OperationContext is too long. </exception>
/// <exception cref="RequestFailedException">The server returned an error. See <see cref="Exception.Message"/> for details returned from the server.</exception>
/// <returns></returns>
public virtual Response<UnmuteParticipantsResult> UnmuteParticipants(UnmuteParticipantsOptions options, CancellationToken cancellationToken = default)
{
using DiagnosticScope scope = _clientDiagnostics.CreateScope($"{nameof(CallConnection)}.{nameof(UnmuteParticipants)}");
scope.Start();
try
{
UnmuteParticipantsRequestInternal request = new UnmuteParticipantsRequestInternal(
options.TargetParticipants.Select(participant => CommunicationIdentifierSerializer.Serialize(participant)).ToList());

request.OperationContext = options.OperationContext;

return RestClient.Unmute(CallConnectionId, request, cancellationToken);
return RestClient.Mute(
CallConnectionId,
request,
repeatabilityHeaders.RepeatabilityRequestId,
repeatabilityHeaders.RepeatabilityFirstSent,
cancellationToken);
}
catch (Exception ex)
{
Expand All @@ -714,17 +667,14 @@ public virtual Response<UnmuteParticipantsResult> UnmuteParticipants(UnmuteParti
/// Only Acs Users are currently supported.
/// </summary>
/// <param name="targetParticipant">Participants to mute.</param>
/// <param name="operationContext">The Operation Context.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <exception cref="ArgumentNullException"> <paramref name="targetParticipant"/> is null. </exception>
/// <exception cref="RequestFailedException">The server returned an error. See <see cref="Exception.Message"/> for details returned from the server.</exception>
/// <returns></returns>
public async virtual Task<Response<MuteParticipantsResult>> MuteParticipantsAsync(CommunicationIdentifier targetParticipant, string operationContext = default, CancellationToken cancellationToken = default)
public async virtual Task<Response<MuteParticipantsResult>> MuteParticipantsAsync(CommunicationIdentifier targetParticipant, CancellationToken cancellationToken = default)
{
var options = new MuteParticipantsOptions(new List<CommunicationIdentifier> { targetParticipant })
{
OperationContext = operationContext
};
var options = new MuteParticipantsOptions(new List<CommunicationIdentifier> { targetParticipant });

return await MuteParticipantsAsync(options, cancellationToken).ConfigureAwait(false);
}

Expand All @@ -748,10 +698,16 @@ public async virtual Task<Response<MuteParticipantsResult>> MuteParticipantsAsyn

MuteParticipantsRequestInternal request = new MuteParticipantsRequestInternal(
options.TargetParticipants.Select(participant => CommunicationIdentifierSerializer.Serialize(participant)));
var repeatabilityHeaders = new RepeatabilityHeaders();

request.OperationContext = options.OperationContext;

return await RestClient.MuteAsync(CallConnectionId, request, cancellationToken).ConfigureAwait(false);
return await RestClient.MuteAsync(
CallConnectionId,
request,
repeatabilityHeaders.RepeatabilityRequestId,
repeatabilityHeaders.RepeatabilityFirstSent,
cancellationToken).ConfigureAwait(false);
}
catch (Exception ex)
{
Expand Down
Loading

0 comments on commit 18060f2

Please sign in to comment.