copyright | lastupdated | ||
---|---|---|---|
|
2019-08-06 |
{:shortdesc: .shortdesc} {:new_window: target="_blank"} {:deprecated: .deprecated} {:important: .important} {:note: .note} {:tip: .tip} {:pre: .pre} {:codeblock: .codeblock} {:screen: .screen} {:javascript: .ph data-hd-programlang='javascript'} {:java: .ph data-hd-programlang='java'} {:python: .ph data-hd-programlang='python'} {:swift: .ph data-hd-programlang='swift'}
{: #dialog-webhooks}
To make a programmatic call, define a webhook that sends a POST request callout to an external application that performs a programmatic function. You can then invoke the webhook from one or more dialog nodes.
A webhook is a mechanism that allows you to call out to an external program based on something happening in your program. When used in a dialog skill, a webhook is triggered when the assistant processes a node that has a webhook enabled. The webhook collects data that you specify or that you collect from the user during the conversation and save in context variables. It sends the data as part of a HTTP POST request to the URL that you specify as part of your webhook definition. The URL that receives the webhook is the listener. It performs a predefined action using the information that you pass to it as specified in the webhook definition, and can optionally return a response.
You can use a webhook to do the following types of things:
- Validate information that you collected from the user.
- Interact with an external web service to get information. For example, you might check on the expected arrival time for a flight from an air traffic service or get a forecast from a weather service.
- Send requests to an external application, such as a restaurant reservation site, to complete a simple transaction on the user's behalf.
- Trigger a SMS notification.
- Trigger a {{site.data.keyword.openwhisk}} web action.
You cannot use a webhook to call a {{site.data.keyword.openwhisk_short}} action that uses token-based Identity and Access Management (IAM) authentication. {: note}
For information about how to call a client application, see Calling a client application from a dialog node.
{: #dialog-webhooks-create}
You can define one webhook URL for a dialog skill, and then call the webhook from one or more dialog nodes.
The programmatic call to the external service must meet these requirements:
-
The call must be a POST HTTP request.
-
The format of the request and response must be in JSON. For example:
Content-Type: application/json
. -
The call must return in 5 seconds or less.
For less efficient services that you need to call, you can manage the call through a client application and pass the information to the dialog as a separate step. For more information, see Calling a client application from a dialog node. {: tip}
To add the webhook details, complete the following steps:
-
From the skill where you want to add the webhook, click the Options tab.
-
Click Webhooks.
-
In the URL field, add the URL for the external application to which you want to send HTTP POST request callouts.
For example, to call the Language Translator service, specify the URL for your service instance.
https://gateway.watsonplatform.net/language-translator/api/v3/translate?version=2018-05-01
{: codeblock}
If the external application that you call returns a response, it must be able to send back a response in JSON format. For the Language Translator service, for example, you must specify the format in which you want the result to be returned. You can do so by passing a header to the service.
-
In the Headers section, add any headers that you want to pass to the service one at a time by clicking Add header.
For example, add a header that indicates that you want the resulting value to be returned in JSON format.
Header example Header name Header value Content-Type application/json -
If the external service requires that you pass basic authentication credentials with the request, then provide them. Click Add authorization, add your credentials to the User name and Password fields, and then click Save.
The product creates a base-64 encoded ASCII string from the credentials and generates a header that it adds to the page for you.
Header example Header name Header value Authorization Basic `` For testing purposes, you can submit an API key over basic authentication. Click Add authorization, and then add
apikey
to the User name field, and paste the API key value into the Password field. Click Save. {: tip}
Your webhook details are saved automatically.
{: #dialog-webhooks-dialog-node-callout}
To use a webhook from a dialog node, you must enable webhooks on the node, and then add details for the callout.
-
Click the Dialog tab.
-
Find the dialog node where you want to add a callout. The callout to the webhook will occur whenever this node is triggered during a conversation with a user.
For example, you might want to send a callout to the webhook from the
#General_Greetings
node. -
Click to open the dialog node, and then click Customize.
-
Scroll down to the Webhooks section, and switch the toggle to On, and then click Apply.
If you did not have it enabled already, the Multiple conditional responses setting is switched on automatically and you cannot disable it. This setting is enabled to support adding different responses depending on the success or failure of the Webhook call. If you had a response specified for the node already, it becomes the first conditional response. {: note}
-
Add any data that you want to pass to the external application as key and value pairs in the Parameters section.
For example, if you call the Language Translator service, you must provide values for the following parameters:
Parameter example Key Value Description model_id "en_es" Identifies the input and output languages. In this example, the request is for text in English (en) to be translated into Spanish (es). text "How are you?" This parameter contains the text string that you want the service to translate. You can hard code this value, pass a context variable, such as $saved_text, or pass the user input to the service directly, by specifying `` as this value. In more complex use cases, you might collect information during a conversation with a user about their travel plans, for example. You can collect dates and destination information and save it in context variables that you can pass to an external application as parameters.
Travel parameters example Key Value depart_date $departure arrive_date $arrival origin $origin destination $destination -
Any response made by the callout is saved to the return variable. You can rename the variable that is automatically added to the Return variable field for you.
The generated variable name has the syntax
webhook_result_n
, where the appended_n
is incremented each time you add a webhook callout to a dialog node. This naming convention ensures that context variable names are unique across the dialog skill. If you change the name, be sure to use a unique name. -
In the conditional responses section, two response conditions are added automatically, one response to show when the webhook callout is successful and a return variable is sent back. And one response to show when the callout fails. You can edit these responses, and add more conditional responses to the node.
If the callout returns a response, and you know the format of the JSON response, then you can edit the dialog node response to include only the section of the response that you want to share with users.
For example, the Language Translator service returns an object like this:
{ "translations":[ {"translation":"¿Cómo estás?"} ], "word_count":3, "character_count":12 }
{: codeblock}
Use a SpEL expression that extracts only the translated text value.
Conditional responses example Condition Response $webhook_result_1 Your words in Spanish: . anything_else The call to the external application failed. Please try again later. If you use the recommended format for the response and the translation response shown earlier is returned, the assistant's response to the user would be:
Your words in Spanish: ¿Cómo estás?
-
When you are done, click the X to close the node. Your changes are automatically saved.
{: #dialog-webhooks-test}
When you first add a webhook callout, it can be useful to see exactly what is returned in the response from the external application, the data and its format. To do this, add this expression as the text response for the successful callout conditional response: $webhook_result_n
where n
is the appropriate number for the webhook you are testing.
This response returns the full body of the return variable, so you can see what the callout is sending back and decide what to share with the user. You can then use the methods documented in Expression language methods to extract only the information you care about from the response.
Test whether certain user inputs can generate errors in the callout, and build in ways to handle those situations. Errors generated by the external application are stored in output.webhook_error.<result_variable>
. You can use a conditional response like this while you are testing to capture such errors:
Condition | Response |
---|---|
output.webhook_error | The callout generated this error: . |
For example, you might not be authenticating the request properly (401), or you might be trying to pass a parameter with a name that is already in use by the external application. Test the webhook to discover and fix these types of errors before you deploy the webhook.
{: #dialog-webhooks-delete}
If you decide you do not want to make a webhook call from a dialog node, open the node's Customize page, and then switch Webhooks Off.
The Parameters section and the Return variable field are removed from the dialog node editor. However, any conditional responses that were added for you or that you added yourself remain.
The Multiple conditioned responses section is editable again. You can choose to switch the feature off. If you do so, then only the first conditional response is saved as the node's only text response.
To change the external service that you call from dialog nodes, edit the webhook details defined on the Webhooks page of the Options tab. If the new service expects different parameters to be passed to it, be sure to update any dialog nodes that call it.
{: #dialog-webhooks-cf}
You write the webhook URL and provide headers differently based on whether you are calling a standard action or a web action.
{: #dialog-webhooks-cf-web-action}
The following tips will help you call a {{site.data.keyword.openwhisk_short}} web action from your dialog.
-
Open the Options page for the skill, and then click Webhooks.
-
In the URL field, add the URL for the external application to which you want to send HTTP POST request callouts.
For example, to call a {{site.data.keyword.openwhisk_short}} web action, specify the URL for the public web action. For example:
https://us-south.functions.cloud.ibm.com/api/v1/web/my_org_dev/default/Hello%20World.json
{: codeblock}
If the external application that you call returns a response, it must be able to send back a response in JSON format.
Notice the request URL in this example ends in
.json
. By specifying this extension, you take advantage of a feature of web actions that lets you specify the desired content type of the response. Specifying this extension type ensures that, if the web actions can return responses in more than one format, a JSON response will be returned. See Extra features{: new_window} for more details. {: tip} -
You do not need to add any headers.
{{site.data.keyword.openwhisk_short}} web actions do not need to be authenticated, so you do not need to define an Authorization header.
Your webhook details are saved automatically.
-
Click the Dialog tab.
-
Click to open the dialog node from which you want to call the web action, and then click Customize.
-
Scroll down to the Webhooks section, and switch the toggle to On, and then click Apply.
-
Add any data that you want to pass to the external application as key and value pairs in the Parameters section.
For example, if you call the Hello World {{site.data.keyword.openwhisk_short}} web action, you might want to add the following information to pass in the message parameter that is accepted by that application:
Parameter example Key Value message "hello" When calling a {{site.data.keyword.openwhisk_short}} web action, you cannot pass parameters with the same key as parameters that are defined as part of the web action. See Protected parameters{: new_window} for more details. {: note}
-
You can edit the dialog node response to include only the section of the response that you want to display to users.
The Hello World {{site.data.keyword.openwhisk_short}} web action includes a message name and value pair in its response, along with other information. To show only the content of the message, you can use
<return-variable>.message
syntax to extract the message section only from the response object.Conditional responses example Condition Response $webhook_result_1 The application returned "$webhook_result_1.message". anything_else The call to the external application failed. Please try again later. -
When you are done, click the X to close the node. Your changes are automatically saved.
{: #dialog-webhooks-cf-action}
You can make a call to an action that is managed by Cloud Foundry, but not to an action that uses token-based Identity and Access Management (IAM) authentication.
The {{site.data.keyword.openwhisk_short}} actions support both synchronous or asynchronous calls. However, you cannot make an asynchronous call to a {{site.data.keyword.openwhisk_short}} action with a webhook. When you send an asynchronous request, only an activation ID is returned.
To make a synchronous call to a {{site.data.keyword.openwhisk_short}} action that is managed by Cloud Foundry, complete the following steps:
-
From the skill where you want to add the webhook, click the Options tab.
-
Click Webhooks.
-
In the URL field, specify the URL for the action.
Append a
?blocking=true
parameter to the action URL to force a synchronous call to be made.This syntax sends a synchronous request:
https://us-south.functions.cloud.ibm.com/api/v1/namespaces/my_org_dev/actions/Hello%20World?blocking=true
{: codeblock}
When you call an action, you must provide the API Key that is associated with the action as a header, which is described in the next step.
-
Provide authorization details with the request.
To call a {{site.data.keyword.openwhisk_short}} action that is managed by Cloud Foundry, complete the following steps:
-
Get the API Key. From the {{site.data.keyword.openwhisk_short}} Endpoint page, find the CURL section and click the eye icon to show the key details. Copy the
user ID:password
key that is listed after the-u
parameter in the curl command. -
Click Add authorization, add your credentials to the User name and Password fields, and then click Save.
The credentials are encoded and a header is generated and added to the page for you.
Your webhook details are saved automatically.
-
-
Click the Dialog tab.
-
Click to open the dialog node from which you want to call the web action, and then click Customize.
-
Scroll down to the Webhooks section, and switch the toggle to On, and then click Apply.
-
Add any data that you want to pass to the external application as key and value pairs in the Parameters section.
When you call a {{site.data.keyword.openwhisk_short}} action, you can pass parameters with the same key as parameters that are defined as part of the action. The parameters are not reserved like they are for web actions.
-
You can edit the dialog node response to include only the section of the response that you want to display to users.
For example, in the conditional responses section, you can use an expression with the syntax
$webhook_result.response.result.message
to extract the returned message only.Conditional responses example Condition Response $webhook_result_1 The application returned "$webhook_result.response.result.message". anything_else The call to the external application failed. Please try again later. -
When you are done, click the X to close the node. Your changes are automatically saved.