Creating an FAQ Bot - Workplace and Make(formerly Integromat)
In this tutorial, we will show you how to create an FAQ bot that searches a Google sheet and returns the questions and answers.
In this tutorial, we will show you how to create an FAQ bot that takes the question from the user, looks that question up in a Google sheet and returns a carousel of up to 10 questions that could possibly answer the question the user has asked.
This tutorial uses The Bot Platform, Workplace, Make(formerly Integromat) and Google Sheets.
Step 1 - Creating our Bot
For this tutorial, we will create a simple bot that asks the user what they would like to know and stores their question in an attribute called question.
data:image/s3,"s3://crabby-images/b9f4d/b9f4d015eb7bce21cd87c2639a03119037dfc607" alt="Screenshot 2021-07-08 at 10.53.02.png 311"
data:image/s3,"s3://crabby-images/a7d87/a7d877f29b0f6fc6ee361397ece6137cf7306209" alt="Screenshot 2021-07-08 at 10.53.29.png 625"
Once they enter a question, they are then taken to a message called ‘Question look up’. Once you have created your basic bot, connect it up to Workplace.
Step 2 - Setting up Make(formerly Integromat)
Head over to make.com and create a new scenario.
For the first step in our scenario, we need to add a webhooks module and you want to make sure you add a custom webhook.
data:image/s3,"s3://crabby-images/f2663/f26632b81b3f2c49fad58703c8082fa6baaeb0a7" alt="Screenshot 2021-07-08 at 10.54.04.png 620"
Add a new webhook and give it a name you will recognise. Once you have added your new webhook, you want to copy the new URL address it generates.
data:image/s3,"s3://crabby-images/32d56/32d564de9e56f107ae30a4eb14bc606fc483b876" alt="webhook 5.gif 800"
Step 3 - Setting up our webhook
Now we want to head back to our bot. In the ‘Question look up’ message, we want to add a little holding message to explain the slight wait while our bot looks up the questions. Then we want to add a webhook message. Paste in the URL you just generated in Make(formerly Integromat).
data:image/s3,"s3://crabby-images/641fb/641fb315a224083e3eb2162640ebbe45e2104b20" alt="Screenshot 2021-07-08 at 10.55.24.png 301"
Save your bot and push the changes live.
Step 4 - Generate your spreadsheet of FAQs
The next step is to create your list of FAQs within a Google sheet. When creating your sheet, we suggest at the minimum you need three columns. Column one will contain your FAQ question in full. Column two will contain keywords that cover the main points of your question. Column three will contain the answer to your question. For example, please see our spreadsheet below.
data:image/s3,"s3://crabby-images/6cba0/6cba0cb5d4295f667a792f5cbdfab441e5ba8d2d" alt="Screenshot 2021-07-08 at 10.56.09.png 1087"
This helps you provide the best possible FAQ answer to any of your users’ questions.
Step 5 - Finishing our Make(formerly Integromat) scenario
Now we need to finish our Make(formerly Integromat) scenario to get it to look up the questions in our spreadsheet and return the best answers to the users.
Head back over to Make(formerly Integromat) and click the ‘Run Once’ button. Now go back to your bot and test the current journey. Once you have completed your test, you should have a small 1 appear in your scenario as shown below:
data:image/s3,"s3://crabby-images/d244e/d244ea924f218585e8511f412e818b58e9626d00" alt="Screenshot 2021-07-08 at 10.56.41.png 533"
This shows us that your bot has pushed out information to Make(formerly Integromat).
The next step is to split up the question typed in by the user to ensure we find all the relevant questions. So click the small semi circle next to the webhook module and we want to add a Text Parser module. This module uses regular expression to cut our user input up into separate words by looking for the spaces between words. In the pattern field, we want to add \s which checks for any spaces. In our new value, we want to add a comma ‘ , ‘. This will then turn all the words our user enters into a list as such.
Book leave becomes book,leave
Make sure you check the Global match box so it does it for our complete sentence. Then in our text field, you want to add the value entered by the user. You can find this under the information pulled through from our webhook, under state and then under vars. (See our Bootcamp section for help finding these variables).
data:image/s3,"s3://crabby-images/4bcfd/4bcfd1e4da3dcd4058518ae2232cb8851de2ed82" alt="Screenshot 2021-07-08 at 10.04.12.png 395"
data:image/s3,"s3://crabby-images/c2f53/c2f53391c6da9b4102f8d72cfbedca831bcff6b2" alt="Screenshot 2021-07-08 at 10.04.18.png 396"
Next we need to add another text parser which will remove any question marks added by the user.
Our pattern this time is ?
Our new value is a comma ,
But the text this time is the field created by our previous text parser.
data:image/s3,"s3://crabby-images/c0b9f/c0b9f1e77a8bf4bc34d4312e20aa3612cfe0ae97" alt="Screenshot 2021-07-08 at 10.06.44.png 398"
data:image/s3,"s3://crabby-images/6c3bb/6c3bbc5c60bb2c4a20b70203b60ba476fe0d3792" alt="Screenshot 2021-07-08 at 10.06.49.png 394"
Now we have created a string of words we are looking for. We need to split these up and put them into a form we can use.
The next module we need is a ‘Set multiple variables’.
Under variables, click add item. Give the variable a name of ‘Split string’. In our variable value field, we want to split our long list into separate variables, so we use the Split function. In this field you want to add the split function. Then you want to use the text from the last text parser and our separator is our comma ,
When finished it should look as follows:
data:image/s3,"s3://crabby-images/f673c/f673c3f5dcdaea0401c94f7902c4623b7c370318" alt="Screenshot 2021-07-08 at 10.13.29.png 396"
Click save and then click ok.
The final step in this text manipulation is to see how many words the user has entered as their question. So the next module we need to add is another ‘Set Variable’. We want to count how many words added to our array by the previous set multiple variables step. So we use the length function.
data:image/s3,"s3://crabby-images/b4eac/b4eac0a9fcd13838ebbe9859b88b66d5b7566767" alt="Screenshot 2021-07-08 at 10.18.42.png 400"
Our scenario now looks as below.
data:image/s3,"s3://crabby-images/faffc/faffc3e3f6bdab8dbfb89dad863f4814ee616506" alt="Screenshot 2021-07-08 at 10.19.24.png 657"
Step 6 - Setting up our search in Make(formerly Integromat)
The next stage of our scenario needs to search through all the FAQs within our spreadsheet for the words the user entered into our bot.
We need to add an ‘Iterator’ module to our scenario. This means our scenario will go through each word the user entered and search for possible FAQs. In the aggregator make sure the slider is set to map. Then you want to use the array of variables created in the set multiple variables step. This looks as follows:
data:image/s3,"s3://crabby-images/ff296/ff29614bf2206f7824762ee477ffa00f34c24419" alt="Screenshot 2021-07-08 at 10.27.14.png 398"
We now need to search our spreadsheet. Add a ‘Google Sheets search rows’ module. Click the add at the top and hook Make(formerly Integromat) up to your Google drive. Once you have done this, select your FAQs spreadsheet from the drop down menu under Spreadsheet. Select the sheet you have stored your data. Now scroll down to your filter.
You want to search your keywords column. Then you want to change the middle option to Contains (case insensitive) and in the next box, you want to use the value from your iterator step.
data:image/s3,"s3://crabby-images/c9c66/c9c6675e1f529e4df07a8b8134b784b1d246e114" alt="Screenshot 2021-07-08 at 10.33.50.png 399"
You also want to set the maximum number of returned rows to be 10.
Now we want to aggregate all the possible FAQs and answers into an array, so add an array aggregator module. For now, leave the set up of this module as it will require the next module to function correctly.
Add a Create JSON module to your scenario. Next to data structure, we want to click add and then give it a name to describe it. Then click on the Generator button and paste in the following code:
{
"recipient": {
"id": "USER_ID"
},
"message": {
"raw": {
"multipart": [{
"text": "one"
}, {
"text": "two"
}, {
"text": "three"
}]
}
}
}
When finished, click save and then additional fields should appear. In the FBID field, use the FBID pulled through from the webhook step. In the multipart step, make sure the map slider is active and in this field, use the data from the previous array aggregator step.
data:image/s3,"s3://crabby-images/77490/77490113cfc3710cdec94c07737c3f3a29a7302d" alt="Screenshot 2021-07-08 at 10.41.37.png 488"
Now we want to go back to our array aggregator step and finish setting this up. Change your Source Module to the Google sheets search rows module. In your target structure type field, change it to message: raw: multipart.
Then in your text field, you can structure your messages how you want. In our example, we have added the question and the answer pulled through from our Google Sheets module.
data:image/s3,"s3://crabby-images/49e67/49e673b9f81ea75a6c8d76070bc75e4f7badb1b9" alt="Screenshot 2021-07-08 at 10.44.14.png 399"
The final step in our scenario is a webhook response. Add the webhook response module and in the body, use the data from the Create JSON module.
data:image/s3,"s3://crabby-images/54af3/54af34c3dd1cc93ab29ec40d410e55b9d663a5a2" alt="Screenshot 2021-07-08 at 10.45.35.png 477"
When finished, your scenario should look as follows:
data:image/s3,"s3://crabby-images/1a043/1a043910ca9a8412a77348979e373d6901a877d6" alt="Screenshot 2021-07-08 at 10.46.19.png 1222"
You can extend this tutorial further by adding in a router with a filter to return a different message if no results are found. You can also add in an option to submit a question to a team member if no suitable FAQ is found.
Updated about 2 years ago