Выход из разговора (Dialogflow)

Исследуйте в Dialogflow

Нажмите «Продолжить» , чтобы импортировать наш пример выхода из разговора в Dialogflow. Затем выполните следующие действия, чтобы развернуть и протестировать образец:

  1. Введите имя агента и создайте новый агент Dialogflow для примера.
  2. После завершения импорта агента нажмите Перейти к агенту .
  3. В главном навигационном меню перейдите в раздел «Выполнение» .
  4. Включите встроенный редактор и нажмите «Развернуть» . Редактор содержит пример кода.
  5. В главном меню навигации выберите «Интеграции» и нажмите «Google Ассистент» .
  6. В появившемся модальном окне включите автоматический просмотр изменений и нажмите «Тест» , чтобы открыть симулятор действий.
  7. В симуляторе введите Talk to my test app чтобы протестировать образец!
Продолжить

Всякий раз, когда пользователи хотят выйти из разговора, они могут сказать что-то вроде:

  • "Выход"
  • "отмена"
  • "останавливаться"
  • "неважно"
  • "до свидания"

По умолчанию Ассистент завершает разговор и воспроизводит звуковой сигнал. Чтобы переопределить это поведение, вы можете согласиться на получение последнего запроса, который вы сможете использовать для очистки логики выполнения и ответа пользователю в последний раз. Ваш окончательный ответ должен представлять собой один простой ответ с ограничением в 60 символов для значений textToSpeech и displayText .

Максимальное время выполнения запроса на выход из разговора составляет 2 секунды; если ответ не получен, разговор завершится звуковым сигналом выхода по умолчанию. Если ваш индивидуальный ответ на отмену не удался (из-за превышения лимита символов, неправильного типа ответа и т. д.), разговор также завершится звуковым сигналом выхода по умолчанию.

Диалоговый поток

Чтобы получать события выхода из разговора:

  1. В левой части навигации щелкните значок + рядом с пунктом меню «Намерения» .
  2. Дайте намерению имя (например, Exit Conversation ») и щелкните раздел «События» .
  3. Введите actions_intent_CANCEL в поле Добавить событие .
  4. Либо укажите ответ в разделе «Ответ» , либо настройте свой собственный ответ для этого намерения в коде веб-перехватчика.
  5. Включить Установить это намерение как завершение разговора .
  6. Нажмите Сохранить .
  7. На панели навигации слева нажмите «Интеграции» .
  8. Выберите Google Assistant и нажмите «Обновить черновик» , затем «Протестируйте» , чтобы убедиться, что изменения отражены в вашем проекте.

Когда пользователь запрашивает выход из разговора, срабатывает созданное вами намерение, и ваш ответ возвращается пользователю. Например, вот некоторый код выполнения, который использует клиентскую библиотеку для обработки намерения отмены и возврата ответа.

const {dialogflow} = require('actions-on-google');
const functions = require('firebase-functions');

const app = dialogflow({debug: true});

app
.intent('Exit Conversation', (conv) => {
  conv
.close(`Okay, talk to you next time!`);
});

exports
.dialogflowFirebaseFulfillment = functions.https.onRequest(app);
package com.example;

import com.google.actions.api.ActionRequest;
import com.google.actions.api.ActionResponse;
import com.google.actions.api.DialogflowApp;
import com.google.actions.api.ForIntent;
import com.google.actions.api.response.ResponseBuilder;

public class MyActionsApp extends DialogflowApp {

 
@ForIntent("Exit Conversation")
 
public ActionResponse exit(ActionRequest request) {
   
ResponseBuilder responseBuilder = getResponseBuilder(request);
    responseBuilder
.add("Okay, talk to you next time!");
    responseBuilder
.endConversation();
   
return responseBuilder.build();
 
}
}

Обратите внимание, что приведенный ниже JSON описывает запрос веб-перехватчика.

{
 
"responseId": "e0c9d47f-aa99-4d03-bd48-a64c79e9c2a2-712767ed",
 
"queryResult": {
   
"queryText": "actions_intent_CANCEL",
   
"parameters": {},
   
"allRequiredParamsPresent": true,
   
"fulfillmentText": "Webhook failed for intent: Exit Conversation",
   
"fulfillmentMessages": [
     
{
       
"text": {
         
"text": [
           
"Webhook failed for intent: Exit Conversation"
         
]
       
}
     
}
   
],
   
"outputContexts": [
     
{
       
"name": "projects/df-exits-kohler/agent/sessions/ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0/contexts/actions_capability_audio_output"
     
},
     
{
       
"name": "projects/df-exits-kohler/agent/sessions/ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0/contexts/actions_capability_media_response_audio"
     
},
     
{
       
"name": "projects/df-exits-kohler/agent/sessions/ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0/contexts/actions_capability_account_linking"
     
},
     
{
       
"name": "projects/df-exits-kohler/agent/sessions/ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0/contexts/actions_capability_screen_output"
     
},
     
{
       
"name": "projects/df-exits-kohler/agent/sessions/ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0/contexts/actions_capability_web_browser"
     
},
     
{
       
"name": "projects/df-exits-kohler/agent/sessions/ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0/contexts/google_assistant_input_type_keyboard"
     
},
     
{
       
"name": "projects/df-exits-kohler/agent/sessions/ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0/contexts/actions_intent_cancel"
     
}
   
],
   
"intent": {
     
"name": "projects/df-exits-kohler/agent/intents/b506991f-ad7a-4c4b-8adc-5e6c62727381",
     
"displayName": "Exit Conversation"
   
},
   
"intentDetectionConfidence": 1,
   
"languageCode": "en"
 
},
 
"originalDetectIntentRequest": {
   
"source": "google",
   
"version": "2",
   
"payload": {
     
"user": {
       
"locale": "en-US",
       
"userVerificationStatus": "VERIFIED"
     
},
     
"conversation": {
       
"conversationId": "ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0",
       
"type": "ACTIVE",
       
"conversationToken": "[]"
     
},
     
"inputs": [
       
{
         
"intent": "actions.intent.CANCEL",
         
"rawInputs": [
           
{
             
"inputType": "KEYBOARD",
             
"query": "cancel"
           
}
         
]
       
}
     
],
     
"surface": {
       
"capabilities": [
         
{
           
"name": "actions.capability.AUDIO_OUTPUT"
         
},
         
{
           
"name": "actions.capability.MEDIA_RESPONSE_AUDIO"
         
},
         
{
           
"name": "actions.capability.ACCOUNT_LINKING"
         
},
         
{
           
"name": "actions.capability.SCREEN_OUTPUT"
         
},
         
{
           
"name": "actions.capability.WEB_BROWSER"
         
}
       
]
     
},
     
"availableSurfaces": [
       
{
         
"capabilities": [
           
{
             
"name": "actions.capability.SCREEN_OUTPUT"
           
},
           
{
             
"name": "actions.capability.WEB_BROWSER"
           
},
           
{
             
"name": "actions.capability.AUDIO_OUTPUT"
           
}
         
]
       
}
     
]
   
}
 
},
 
"session": "projects/df-exits-kohler/agent/sessions/ABwppHGVnlRtMz1RhGGmDOSlCFAbc2QaM12xYtw0raWvv-R5GYM6tkqiVOpIOexm_LTBCvmARwpbZ_onRuX0"
}

Обратите внимание, что приведенный ниже JSON описывает ответ веб-перехватчика.

{
 
"payload": {
   
"google": {
     
"expectUserResponse": false,
     
"richResponse": {
       
"items": [
         
{
           
"simpleResponse": {
             
"textToSpeech": "Okay, talk to you next time!"
           
}
         
}
       
]
     
}
   
}
 
}
}

SDK действий

Чтобы получить намерения выхода из разговора:

  1. В объекте conversations внутри вашего пакета действий объявите, что вы хотите получать намерение actions.intent.CANCEL каждый раз, когда пользователь хочет выйти из разговора.


    {
     
    "actions": [
       
    {
         
    "description": "Default Welcome Intent",
         
    "name": "MAIN",
         
    "fulfillment": {
           
    "conversationName": "conversation_1"
         
    },
         
    "intent": {
           
    "name": "actions.intent.MAIN"
         
    }
       
    }
     
    ],
     
    "conversations": {
       
    "conversation_1": {
         
    "name": "conversation_1",
         
    "url": "YOUR_ENDPOINT_URL",
          "inDialogIntents": [
            {
              "name": "actions.intent.CANCEL"
            }
          ]
       
    }
     
    }
    }
  2. Когда вы получаете запрос с намерением actions.intent.CANCEL , очистите всю логику выполнения, которая вам нужна, и верните пользователю соответствующую фразу выхода. Например, вот код выполнения, который использует клиентскую библиотеку для обработки намерения отмены.

    const {actionssdk} = require('actions-on-google');
    const functions = require('firebase-functions');

    const app = actionssdk({debug: true});

    app
    .intent('actions.intent.MAIN', (conv) => {
      conv
    .ask(`Hi! Try saying 'exit' or 'cancel'`);
    });

    app
    .intent('actions.intent.TEXT', (conv, input) => {
      conv
    .ask(`You said ${input}`);
      conv
    .ask(`Try saying 'exit' or 'cancel'`);
    });

    app
    .intent('actions.intent.CANCEL', (conv) => {
      conv
    .close(`Okay, talk to you next time!`);
    });

    exports
    .dialogflowFirebaseFulfillment = functions.https.onRequest(app);
    package com.example;

    import com.google.actions.api.ActionRequest;
    import com.google.actions.api.ActionResponse;
    import com.google.actions.api.ActionsSdkApp;
    import com.google.actions.api.ConstantsKt;
    import com.google.actions.api.ForIntent;
    import com.google.actions.api.response.ResponseBuilder;
    import com.google.actions.api.response.helperintent.Confirmation;
    import com.google.actions.api.response.helperintent.DateTimePrompt;
    import com.google.actions.api.response.helperintent.Permission;
    import com.google.actions.api.response.helperintent.Place;
    import com.google.api.services.actions_fulfillment.v2.model.DateTime;
    import com.google.api.services.actions_fulfillment.v2.model.Location;

    public class MyActionsApp extends ActionsSdkApp {

     
    @ForIntent("actions.intent.MAIN")
     
    public ActionResponse welcome(ActionRequest request) {
       
    ResponseBuilder responseBuilder = getResponseBuilder(request);
        responseBuilder
    .add("Hi! Try saying 'exit' or 'cancel'");
       
    return responseBuilder.build();
     
    }

     
    @ForIntent("actions.intent.TEXT")
     
    public ActionResponse fallback(ActionRequest request) {
       
    ResponseBuilder responseBuilder = getResponseBuilder(request);
        responseBuilder
    .add("You said " + request.getRawInput().getQuery());
        responseBuilder
    .add("Try saying 'exit' or 'cancel'");
       
    return responseBuilder.build();
     
    }

     
    @ForIntent("actions.intent.CANCEL")
     
    public ActionResponse exit(ActionRequest request) {
       
    ResponseBuilder responseBuilder = getResponseBuilder(request);
        responseBuilder
    .add("Okay, talk to you next time!");
        responseBuilder
    .endConversation();
       
    return responseBuilder.build();
     
    }

    }

    Обратите внимание, что приведенный ниже JSON описывает запрос веб-перехватчика.

    {
     
    "user": {
       
    "locale": "en-US",
       
    "userVerificationStatus": "VERIFIED"
     
    },
     
    "conversation": {
       
    "conversationId": "ABwppHEtH6XptryyLGWDBOVnLgy8EkOclTPETd4lcLh_f6ghQAzzg0seUuq3YocyFT8B17N6AGD6YPPjQw5CXBM",
       
    "type": "NEW"
     
    },
     
    "inputs": [
       
    {
         
    "intent": "actions.intent.CANCEL",
         
    "rawInputs": [
           
    {
             
    "inputType": "KEYBOARD",
             
    "query": "exit"
           
    }
         
    ]
       
    }
     
    ],
     
    "surface": {
       
    "capabilities": [
         
    {
           
    "name": "actions.capability.SCREEN_OUTPUT"
         
    },
         
    {
           
    "name": "actions.capability.ACCOUNT_LINKING"
         
    },
         
    {
           
    "name": "actions.capability.MEDIA_RESPONSE_AUDIO"
         
    },
         
    {
           
    "name": "actions.capability.AUDIO_OUTPUT"
         
    },
         
    {
           
    "name": "actions.capability.WEB_BROWSER"
         
    }
       
    ]
     
    },
     
    "availableSurfaces": [
       
    {
         
    "capabilities": [
           
    {
             
    "name": "actions.capability.AUDIO_OUTPUT"
           
    },
           
    {
             
    "name": "actions.capability.SCREEN_OUTPUT"
           
    },
           
    {
             
    "name": "actions.capability.WEB_BROWSER"
           
    }
         
    ]
       
    }
     
    ]
    }

    Обратите внимание, что приведенный ниже JSON описывает ответ веб-перехватчика.

    {
     
    "expectUserResponse": false,
     
    "finalResponse": {
       
    "richResponse": {
         
    "items": [
           
    {
             
    "simpleResponse": {
               
    "textToSpeech": "Okay, talk to you next time!"
             
    }
           
    }
         
    ]
       
    }
     
    }
    }