Configurar a entrega a hubs de interação genéricos
O Copilot Studio permite entregar conversas do copiloto sem interrupções e com contexto a um agente humano por meio de um hub de interação.
Com algum desenvolvimento personalizado, você pode configurar seu copiloto para entregar conversas para qualquer hub de interação. Este guia descreve como fazer isso.
Pré-requisitos
- Você precisa criar um copiloto usando o Copilot Studio.
- Você precisa de um hub de participação que possa interagir programaticamente usando APIs ou SDK.
Importante
Algumas instruções nesta seção exigem desenvolvimento de software por você ou seus desenvolvedores. Ele se destina a profissionais de TI experientes, como administradores ou desenvolvedores de TI, que possuem um sólido conhecimento de utilitários, IDEs e ferramentas para desenvolvedores, e que desejam integrar hubs de interação de terceiros ao Copilot Studio.
Visão Geral
Uma entrega completa para um hub de interação segue este padrão:
Um usuário final interage com a tela de conversa do hub de interação.
O hub de interação direciona a conversa recebida para um copiloto, por meio dos recursos internos de roteamento de conversas.
Um adaptador personalizado retransmite as mensagens de conversa recebidas do hub de interação para um copiloto do Copilot Studio.
Quando o usuário final dispara a entrega, o Copilot Studio inicia a entrega com o contexto conversacional completo.
O adaptador personalizado intercepta a mensagem de entrega, analisa o contexto completo da conversa e roteia diretamente a conversa escalada para um agente humano qualificado, com base na disponibilidade.
A conversa do usuário final é transmitida sem interrupções e com contexto a um agente humano, que pode retomar a conversa.
Para entregar a conversa a um agente humano, você precisa criar um adaptador de transferência personalizado.
Criar um adaptador de entrega personalizado
Um adaptador une as conversas do hub de interação do agente e para ele, retransmitindo e transformando mensagens entre usuários finais, copilotos e agentes humanos.
Os hubs de engajamento de agentes mais populares fornecem kits de desenvolvimento de software (SDKs) ou documentam suas APIs publicamente, permitindo que você crie esses adaptadores.
Está fora do escopo deste documento abordar o que um adaptador personalizado pode conter. No entanto, a seguinte mensagem de exemplo entrega, com base no que Copilot Studio é gerado como parte da nossa experiência padrão de entrega para agente humano, pode ajudar você a começar.
Esses exemplos e trechos de código permitem que você extraia o contexto da conversa para transferir, de maneira contínua e contextualizada, as conversas do copiloto para qualquer hub de interação genérico.
Conteúdo de mensagem de exemplo de entrega
A entrega tem suporte atualmente somente pelo Direct Line. Saiba mais sobre como interagir com um copiloto pelo Direct Line. Na entrega, uma atividade de evento chamada handoff.initiate
é gerada e enviada ao adaptador.
Você pode ver um exemplo completo da atividade de entrega de mensagens em nosso site do GitHub.
Extrair contexto da mensagem de entrega
Para usar o contexto conversacional, você deve analisar a atividade do evento handoff.initiate
.
O trecho de código a seguir analisa a atividade do evento handoff.initiate
e extrai o contexto conversacional. Consulte o exemplo de código completo no GitHub.
public void InitiateHandoff(string botresponseJson)
{
BotResponse response = JsonConvert.DeserializeObject<BotResponse>(botresponseJson);
// Look for Handoff Initiate Activity. This indicates that conversation needs to be handed off to agent
Activity handoffInitiateActivity = response.Activities.ToList().FirstOrDefault(
item => string.Equals(item.Type, ActivityTypes.Event, System.StringComparison.Ordinal)
&& string.Equals(item.Name, HandoffInitiateActivityName, System.StringComparison.Ordinal));
if (handoffInitiateActivity != null)
{
// Read transcript from attachment
if (handoffInitiateActivity.Attachments?.Any() == true)
{
Attachment transcriptAttachment = handoffInitiateActivity.Attachments.FirstOrDefault(a => string.Equals(a.Name.ToLowerInvariant(), TranscriptAttachmentName, System.StringComparison.Ordinal));
if (transcriptAttachment != null)
{
Transcript transcript = JsonConvert.DeserializeObject<Transcript>(transcriptAttachment.Content.ToString());
}
}
// Read handoff context
HandoffContext context = JsonConvert.DeserializeObject<HandoffContext>(handoffInitiateActivity.Value.ToString());
// Connect to Agent Hub
// <YOUR CUSTOM ADAPTER CODE GOES HERE>
}
}