Dela via


Så här skickar du kontextuella data mellan anrop

Med Samtalsautomatisering kan utvecklare skicka anpassad kontextbaserad information vid routning av anrop. Utvecklare kan skicka metadata om anropet, anroparen eller annan information som är relevant för deras program eller affärslogik. På så sätt kan företag hantera och dirigera samtal mellan nätverk utan att behöva oroa sig för att förlora kontexten.

Det går att skicka kontexten genom att ange anpassade rubriker. Det här är en valfri lista över nyckel/värde-par som kan ingå som en del av AddParticipant eller Transfer åtgärder. Kontexten kan senare hämtas som en del av IncomingCall händelsenyttolasten.

Den anpassade samtalskontexten vidarebefordras också till SIP-protokollet, vilket omfattar både de anpassade sidhuvudena för frihandsformuläret och UUI-sip-huvud (Standard User-to-User Information). När du dirigerar ett inkommande samtal från telefoninätverket inkluderas datauppsättningen från din SBC i de anpassade rubrikerna och UUI på samma sätt i IncomingCall händelsenyttolasten.

Alla anpassade kontextdata är ogenomskinliga för Call Automation- eller SIP-protokoll och dess innehåll är inte relaterat till några grundläggande funktioner.

Nedan visas exempel på hur du kommer igång med anpassade kontextrubriker i Samtalsautomation.

Som en förutsättning rekommenderar vi att du läser dessa artiklar för att få ut det mesta av den här guiden:

  • Guide för att anropa Automation-begrepp som beskriver programmeringsmodellen för åtgärdshändelser och återanrop till händelser.
  • Lär dig mer om användaridentifierare som CommunicationUserIdentifier och Telefon NumberIdentifier som används i den här guiden.

För alla kodexempel client är det CallAutomationClient-objekt som kan skapas som det visas och callConnection är objektet Call Anslut ion som hämtats från Svar eller CreateCall-svar. Du kan också hämta den från motringningshändelser som tas emot av ditt program.

Tekniska parametrar

Call Automation stöder upp till 5 anpassade SIP-huvuden och 1 000 anpassade VOIP-huvuden. Dessutom kan utvecklare inkludera en dedikerad användar-till-användare-rubrik som en del av SIP-rubriklistan.

Den anpassade SIP-huvudnyckeln måste börja med ett obligatoriskt prefix "X-MS-Custom-". Den maximala längden på en SIP-huvudnyckel är 64 tecken, inklusive prefixet X-MS-Custom. SIP-huvudnyckeln kan bestå av alfanumeriska tecken och några markerade symboler som innehåller ., !, %, *, _, +, , ~. - Den maximala längden på SIP-huvudvärdet är 256 tecken. Samma begränsningar gäller när du konfigurerar SIP-huvudena på din SBC. SIP-huvudvärdet kan bestå av alfanumeriska tecken och några markerade symboler som innehåller =, ;, ., !, %, *, _, +, , ~. -

Den maximala längden på en VOIP-huvudnyckel är 64 tecken. Dessa rubriker kan skickas utan prefixet x-MS-Custom. Den maximala längden på VOIP-rubrikvärdet är 1 024 tecken.

Lägga till anpassad kontext när du bjuder in en deltagare

// Invite a communication services user and include one VOIP header
var addThisPerson = new CallInvite(new CommunicationUserIdentifier("<user_id>"));
addThisPerson.CustomCallingContext.AddVoip("myHeader", "myValue");
AddParticipantsResult result = await callConnection.AddParticipantAsync(addThisPerson);
// Invite a PSTN user and set UUI and custom SIP headers
var callerIdNumber = new PhoneNumberIdentifier("+16044561234"); 
var addThisPerson = new CallInvite(new PhoneNumberIdentifier("+16041234567"), callerIdNumber);

// Set custom UUI header. This key is sent on SIP protocol as User-to-User
addThisPerson.CustomCallingContext.AddSipUui("value");

// This provided key will be automatically prefixed with X-MS-Custom on SIP protocol, such as 'X-MS-Custom-{key}'
addThisPerson.CustomCallingContext.AddSipX("header1", "customSipHeaderValue1");
AddParticipantsResult result = await callConnection.AddParticipantAsync(addThisPerson);

Lägga till anpassad kontext under anropsöverföring

//Transfer to communication services user and include one VOIP header
var transferDestination = new CommunicationUserIdentifier("<user_id>"); 
var transferOption = new TransferToParticipantOptions(transferDestination);   
var transferOption = new TransferToParticipantOptions(transferDestination) {
    OperationContext = "<Your_context>",
    OperationCallbackUri = new Uri("<uri_endpoint>") // Sending event to a non-default endpoint.
};
transferOption.CustomCallingContext.AddVoip("customVoipHeader1", "customVoipHeaderValue1");
TransferCallToParticipantResult result = await callConnection.TransferCallToParticipantAsync(transferOption);

//Transfer a PSTN call to phone number and set UUI and custom SIP headers
var transferDestination = new PhoneNumberIdentifier("<target_phoneNumber>");
var transferOption = new TransferToParticipantOptions(transferDestination);
transferOption.CustomCallingContext.AddSipUui("uuivalue");
transferOption.CustomCallingContext.AddSipX("header1", "headerValue");
TransferCallToParticipantResult result = await callConnection.TransferCallToParticipantAsync(transferOption)

Läsa anpassad kontext från en inkommande samtalshändelse

AcsIncomingCallEventData incomingEvent = <incoming call event from Event Grid>;
// Retrieve incoming call custom context
AcsIncomingCallCustomContext callCustomContext = incomingEvent.CustomContext;

// Inspect dictionary with key/value pairs
var voipHeaders = callCustomContext.VoipHeaders;
var sipHeaders = callCustomContext.SipHeaders;

// Get SIP UUI header value
var userToUser = sipHeaders["user-To-User"]

// Proceed to answer or reject call as usual

Ytterligare resurser