This is part of the Bot Builder Community project which contains Bot Framework Components and other projects / packages for use with Bot Framework Composer and the Bot Builder .NET SDK v4.
The Actions SDK Adapter allows you to add an additional endpoint to your bot for conversational actions built with the latest Google Actions SDK. The Google endpoint can be used in conjunction with other channels meaning, for example, you can have a bot exposed on out of the box channels such as Facebook and Teams, but also via a Google Action (as well as side by side with other adapters (e.g. the Alexa adapter) also available from the Bot Builder Community Project).
Incoming requests from your Google action are transformed, by the adapter, into Bot Builder Activties and then when your bot responds, the adapter transforms the outgoing Activity into an appropriate Actions SDK response.
The adapter currently supports the following scenarios;
- Support for voice based Google actions
- Support for Actions SDK Card, Table Card, List and Collections
- Automatic conversion of Suggested Actions on outgoing activity into Google Suggestion Chips
- Account Linking - send a Bot Framework Signin Card to trigger the account linking flow
- Full incoming request from Google is added to the incoming activity as ChannelData
This readme focuses on consuming the Google Actions SDK component in Bot Framework Composer. For more information about the supported scenarios and how to consume the Google Actions SDK adapter in code-first scenarios, visit the Google Actions SDK adapter readme.
- Prerequisites
- Component Installation
- Create an Actions SDK action project
- Configure your Actions SDK project
- Configure Composer Actions SDK Connection
- Complete configuration for Actions on Google
- Testing your Action
-
Access to the Actions on Google developer console with sufficient permissions to login to create / manage projects at https://console.actions.google.com/. If you do not have this you can create an account for free.
-
The gactions command-line tool. Download this here
-
Go to Package Manager (in the left hand navigation within Composer).
-
Within in Package Manager, search for an install the latest version of Bot.Builder.Community.Components.Adapters.ActionsSDK.
-
Log into the Actions on Google console and then click the New project button. Specify a name for your new project, as well as the language / region. Finally click the Create project button.
-
On the next screen, select Custom for the type of your new action.
- On the next screen, select Blank project for the project template to use to build your action.
- Your action will now be created. Once the creation process has finished you will be presented with your project dashboard. Note: you do not need to set a Display name yet.
You now need to configure your new Actions SDK project, with appropriate settings, scenes, intents, types etc. You will do this using the gactions CLI tool and the provided action template files included in the 'action' folder in this repository.
-
If you haven't already, install the gactions CLI tool.
-
If you haven't already, Download a copy of this repository.
-
Navigate to botbuilder-community-dotnet/libraries/Bot.Builder.Community.Adapters.ActionsSDK/action/settings/settings.yaml, and replace with your project ID. You can find your project id by navigating to Project settings from the menu in the top right hand of the Google Actions Console.
-
Open a command prompt and change the directory to the botbuilder-community-dotnet/libraries/Bot.Builder.Community.Adapters.ActionsSDK/action/ directory.
-
Run 'gactions login' to login and follow the instructions to login to your account.
-
Run 'gactions push' to push local settings to your project.
-
Run 'gactions deploy preview' to deploy your project (including the locally defined scenes etc).
-
Finally, navigate back to your project within the Google Actions Console. You will see that the display name has been updated to 'Bot Framework Sample'. Change this to a display name of your choice. This will also be your invocation name, which is the name used by users when they invoke your action.
Before you can complete the configuration of your Actiosn SDK project, you need to configure the Actions SDK connection in Bot Framework Composer.
-
In Composer, go to your bot settings. Under the
adapters
section, there should be a new entry calledGoogle Actions SDK connection
. SelectConfigure
to wire up your project. -
A modal will pop up. Fill the
invocation name
andproject id
with the information from your Actions SDK project. -
Once you close the modal, your adapter should appear as configured in the bot settings with a green check mark.
- Deploy your bot to Azure and make a note of the URL to your deployed bot.
NOTE If you are not ready to deploy your bot to Azure, or wish to test / debug your bot locally, you can use a tool such as ngrok (which you will likely already have installed if you have used the Bot Framework emulator previously) to tunnel through to your bot running locally and provide you with a publicly accessible URL for this.
If you wish create an ngrok tunnel and obtain a URL to your bot, use the following command in a terminal window (this assumes your local bot is running on port 3980, alter the port numbers in the command if your bot is not).
ngrok.exe http 3980 -host-header="localhost:3980"
-
Navigate back to the Google Actions console and navigate to your action project.
-
Navigate to the Develop tab and then to the Webhook page on the left hand menu.
-
Enter your Actions SDK endpoint. This will be the URL of your deployed application (or ngrok endpoint - see below), plus '/api/actionssdk' (for example,
https://yourbotapp.azurewebsites.net/api/actionssdk
).
You can now test interacting with your action using the simulator (if using an ngrok endpoint, ensure both your bot and ngrok endpoint are running).
-
Navigate to https://console.actions.google.com/ and navigate to your action project.
-
In the action dashboard navigate to the Test tab at the top of the page.
-
To perform a basic test enter "ask hello world" into the simulator input box. For example, if your action display name was 'Bot Framework Sample', you would type 'Talk to Bot Framework Sample hello world'. This should return an echo of your message.
Now that you have enabled testing for your action, you can also test your action using a physical Google assistant device or using Google assistant on an Android device. Providing you are logged into the device with the same account used to login to the Actions on Google Console (or an account that you have added as a beta tester for your action within the console).