Как я могу начать другой диалог, основанный на каждом другом намерении Луиса? - PullRequest
0 голосов
/ 18 января 2020

Я пытаюсь настроить простого чат-бота, в котором пользователь может сказать другое намерение и на основании этого у него будет другое диалоговое окно. В настоящее время у меня есть 2 возможных намерения и соответствующие им диалоги: «listBots» и «runBot».

Я настраиваю своего бота, чтобы получить намерение от Луиса, затем использую переключатель намерения, чтобы определить, какой диалог он должен запустить, здесь мой код, который пытается сделать это:

public class MainChatbot : ActivityHandler
{
    private readonly IOptions<Models.Configurations> _mySettings;
    protected readonly IRecognizer _recognizer;
    protected readonly BotState _conversationState;

    public MainChatbot(ConversationState conversationState, IOptions<Models.Configurations> mySettings, ChatbotRecognizer recognizer)
    {
        _mySettings = mySettings ?? throw new ArgumentNullException(nameof(mySettings));
        _recognizer = recognizer;
        _conversationState = conversationState;
    }

    protected override async Task OnMessageActivityAsync(ITurnContext<IMessageActivity> turnContext, CancellationToken cancellationToken)
    {
        var luisResult = await _recognizer.RecognizeAsync<Models.ChatbotIntent>(turnContext, cancellationToken);
        Models.ChatbotIntent.Intent TopIntent = luisResult.TopIntent().intent;
        await turnContext.SendActivityAsync(MessageFactory.Text($"Your Intention Is: {TopIntent.ToString()}"), cancellationToken);

        switch (TopIntent)
        {
            case Models.ChatbotIntent.Intent.RunBot:
                var RunBotOptions = new Models.RunBotOptions();
                Dialog RunBotDialog = new RunBotDialog();
                await RunBotDialog.RunAsync(turnContext, _conversationState.CreateProperty<DialogState>(nameof(DialogState)), cancellationToken);
                break;
            case Models.ChatbotIntent.Intent.ListBots:
                Dialog ListBotDialog = new ListBotDialog();
                await ListBotDialog.RunAsync(turnContext, _conversationState.CreateProperty<DialogState>(nameof(DialogState)), cancellationToken);
                break;
            default:
                break;
        }
        return;
    }

В основном в моем OnMessageActivityAsyn c, он просто вызывает Луис, чтобы получить намерение из пользовательского ввода, а затем включает намерение, в зависимости от случая, это создает другой диалог и запускает его. По крайней мере, в теории.

Здесь, в моем файле startup.cs, в зависимости я внедряю все классы бота и диалогов.

    // This method gets called by the runtime. Use this method to add services to the container.
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

        // Add functionality to inject IOptions<T>
        services.AddOptions();

        // Add our Config object so it can be injected
        services.Configure<Models.Configurations>(Configuration);

        // Create the Bot Framework Adapter with error handling enabled.
        services.AddSingleton<IBotFrameworkHttpAdapter, AdapterWithErrorHandler>();

        // Create the bot as a transient. In this case the ASP Controller is expecting an IBot.
        services.AddTransient<IBot, Dialogs.MainChatbot>();

        // Create the Conversation state. (Used by the Dialog system itself.)
        var storage = new MemoryStorage();
        var conversationState = new ConversationState(storage);
        services.AddSingleton(conversationState);


        // Register LUIS recognizer
        services.AddSingleton<ChatbotRecognizer>();

        // Dialogs
        services.AddSingleton<Dialogs.RunBotDialog>();
        services.AddSingleton<Dialogs.ListBotsDialog>();
    }

Это дает мне ошибку 500, поэтому я не не знаю, что не так. Я использую Bot-Framework v4.

1 Ответ

1 голос
/ 18 января 2020

Кажется, этот код работает как есть! Не уверен, почему это не сработало вчера. Я оставлю это для любого, кто мог бы искать ответ в будущем.

...