This repository contains the Dialogflow client, which is one of three parts of the LISA Voice Assistant Project among the frontend client and backend server repositories. Dialogflow is meant to be used by Vitalis elderlies to ask for the menu of the nearby kitchen(s). User voice input sends requests to and fetches data from the backend server.
This readme file will introduce the fundamental concepts of DialogFlow and walk you through the installation process. If still in doubt, visit the Dialogflow docs.
NOTE: Read the Docs for set-up and the latest status of the code - make sure to use the correct branch (development or any open branches that hasn’t been merged into development yet). Only merge into the master branch if all the codes in development are working AND you have already checked with Rein.
- LISA-server
- LISA-client
- LISA Dialogflow - you are here!
Dialogflow (formerly Api.ai) is a Google-owned developer of human–computer interaction technologies based on natural language conversations. You can develop a virtual buddy for Android, iOS, and Windows Phone smartphones that performs tasks and answers users’ questions in a natural language. It also created a natural language processing engine that incorporates conversation context like dialogue history, location and user preferences.
If you intent to understand and improve on the Dialogflow features of Project Lisa, I recommend a short and sweet YouTube series to get you started:
Alternatively, the following sections will give you an overview of Dialogflow.
An Agent is a specific virtual buddy, chatbot or skill. In this case, LISA. There is an invocation to start it: “Hey Google, praat met de keuken” or “Hey Google, talk to the kitchen” will trigger “Hallo, ik ben Lisa. Wat is uw vraag?”.
Edit invocation here if need be
An intent maps what a user says with what your agent does. To fetch the menu, LISA has the intent ‘fetch_menu’.
Example questions:
- “Wat eten we vanavond?”
- “Wat staat er morgen op het menu?”
- “Wat is het toetje vandaag?”
- “Wat is dinsdag het hoofdgerecht?”
Date and course information are sent along with the request to the server. If none are specified (“Wat eten we?”), the backend route will assume full meal for today.
An Entity is a property which can be used by Dialogflow to extract values from the user request. It filters information from natural speech, and transforms it to a standardized format. LISA uses two entities:
- @sys.date-time, date, a standard Dialogflow entity
- @gerecht, type, a custom entity
Dialogflow receives a request from the user (along with the entity values to be sent with the request) and now needs to request the information from the database to fulfill the user request. Now this data will be sent to our webhook so that the required information can be fetched (this will be dependent on your implementation). Once the webhook has fetched our required information it will send it back to Dialogflow so that it can be presented to the user in the desired manner.
When you are working with custom backend like Node.js with Express, you need to:
- turn on the option Enable webhook, and
- call for slot filling in the Fulfillment section of the intent.
-
First, make sure to set up the backend server if you didn't already
-
Download Zip File
There is no need to install anything. Simply download the zip so that it will be used to quickly set up Dialogflow for you.
For development purpose: Download the Dialogflow client developer as zip.
For production purpose: Download the Dialogflow client master as zip.
-
Dialogflow needs to connect to your backend server through a public URL, meaning that e.g. localhost:5000 simply won't work. We need to turn the local server url into a public url for testing. There are three ways to make your local server public, using either Localtunnel, Serveo, or a Heroku link.
-
To use LocalTunnel:
Install Localtunnel globally (requires NodeJS) to make it accessible anywhere:
npm install -g localtunnel
Possible error: Denied access?
sudo chown -R \$USER /usr/local/lib/node_modules sudo npm install -g locatunnel
Start a webserver on some local port (eg. http://localhost:5000) and use the command line interface to request a tunnel to your local server:
lt --port 5000
You will receive a url, for example https://gqgh.localtunnel.me, that you can share with anyone for as long as your local instance of lt remains active.
-
To use Serveo, run this in your terminal window (it should give you an url):
$ ssh -R 80:localhost:5000 serveo.net
You might need to type
yes
if a warning is thrown. The https link in green is your server URL.Serveo is a nice tool to use while developing: https://serveo.net/ It streams your server to the adress Serveo sets up for you. You can use this adress in Dialogflow -> fulfillment. The link look likes this:(this one does not work) https://dialogflow.cloud.google.com/#/agent/``/fulfillment
-
Hold onto the url you receive. We will use it in the next step.
-
-
Connect LISA to your local database:
For privacy reasons, it's best to use your personal Google account and create a new agent for development purpose:
- Log out of all your Google Accounts and delete the information in your local storage before only logging in with your personal Google account to make sure you continue the next steps with the right account.
- Go to Dialogflow and log in.
- Create a new agent (top left of the page). Besides adding a name (whatever name you like), you should see the option to set the default language. Make sure the default language is Dutch. If you don't see this option. Refresh page and try again.
- Once a new agent is created, go to the settings of the agent (the wheel next to your agent's name)
- Click on Export and Import and import the zip file from step 2. Don't forget to type IMPORT in the input form beneath it.
- Enable Webhook in the fulfullment tab and fill in
<local server URL you received from localtunnel, serveo, or heroku>/google-menus
as URL. - To integrate the agent with the Google Assistant, click on the integrations tab on the left of the page, and go to Google Assistant.
- Add the intents by clicking on the form add intent. The intents that come with the zip file should show up as a drop down menu. Select all of them.
- When you are finished, click on Test. If everything is set up correctly, you will be directed to your Google Actions test environment.
- The agent you created is a new project in your Google Actions. Go to Google Actions and click on the name of the agent you created.
- Go to Decide how your action is invoked.
- Set up an invocation, preferrably 'de Kok' and save it. NOTE: if your language setting in your Google account isn't Dutch by default (or if you get an error), switch off the box Match user's language setting. In the Google Assistant Voice part, you should see (NL-NL) in the voice form. In addition, after you hit "save" the form may throw an error saying the name is invalid. This may be a bug. As long as you see the pop-up 'Invocation details saved successfully', move on.
- Make sure to set the language to Dutch (NL).
- In your MyAccount page, navigate to privacy & personalization, Web/App activity and history must be turned on in order to have the location feature working.
- Testing: In the Google Actions test environment, first input 'Praat met de Kok' in the chat bar. Google assistant might ask you for the location, input 'Ja'. Try 'Wat eten we vanavond', if you get a response 'try another day', that means the menu for that day is empty and it works! If you get an error "MalformedResponse", refresh your webhook url.
Possible Errors:
MalformedResponse: When you test Dialogflow in the test environment, you may receive this error. When you do, you need to run localtunnel or serveo again to get a new url and update the webhook url before you test again.
The testing envrionment will not load: Does the testing not work, and you receive a Permisson access denied error? Most likely the accounts on Dialogflow and your Google Actions are not the same. You can check this by going to the settings of your agent in Dialogflow. Click on the Share tab, and you see the Google Account of the person who has access to the agent. If this is not your personal account remove the agent, and start again and make sure to be logged out and clean your local storage first before trying again.
Test envrionment works, but the menu isn't fetched? If you are in your testing environment, but the fetch-menu intent doesn't work, fetch a new Serveo or Localtunnel link and connect that as your webhook.
-
You can test the app with Google Assistant on your device as long as you're logged in with your personal Google account. Type or ask 'Hey Google, praat met de kok' (which means 'Hey Google, talk to the chef').
-
Ask what the menu is for the day you made some items for (e.g. 'Wat eten we vanavond?'). You can also ask for just the starter, main-course, or dessert for a specific day.
WARNING: this is the account used in production. Only make changes if a new backend version is deployed, otherwise you will break it.
Production Account
Google ID: lisa.vitalis.assistant@gmail.com
For the password, please contact Rein.
If you made changes to the lisa dialogflow client and are satisfied with the outcome, make sure to:
- restore the fulfillment url to
https://immense-fjord-88389.herokuapp.com
(this is the back-end that's in development. It may be outdated, so check to make sure) - export the settings as zip here
- unpack the zip in the root directory you cloned this repository in
-
$ git commit $ git push
If you messed something up, you can just clone this repository as zip from github and upload it to the dialogflow client.