data:image/s3,"s3://crabby-images/4dfc6/4dfc6d334a8603a937a74d0776160641f275465f" alt=""
If you can Dream It,
you can Do It
with the
Google Assistant
DevFest Florida
19 Jan 2019
data:image/s3,"s3://crabby-images/99e66/99e66554e17a977ade15b688c0598311d6554190" alt=""
(mostly)
Allen Firstenberg
Software developer / Consultant
Google Developer Expert for Assistant, IoT, Wearables, Identity
http://spiders.com/
http://prisoner.com/
http://prisoner.com/ubi/
Tell me about you
- Mobile or web?
- Alexa or Assistant?
- Mac vs Windows?
- JavaScript?
Java?
Something else?
data:image/s3,"s3://crabby-images/43947/43947a328d5873bee626ad4dca0af018c523a252" alt=""
- Magic Kingdom? Epcot? Hollywood Studios? Animal Kingdom?
What are we talking about?
data:image/s3,"s3://crabby-images/f07c0/f07c0ced9d0b9dff96e978097173e67a42de71f4" alt=""
What is the Google Assistant?
data:image/s3,"s3://crabby-images/c1ab1/c1ab186864a3836d3145334df2ffc30a64dc4f5a" alt=""
A conversation
between you and Google that helps you get things done
in your world.
data:image/s3,"s3://crabby-images/4e50f/4e50f3607332c03e38adb808032bdac446338573" alt=""
What are Actions on Google?
data:image/s3,"s3://crabby-images/f1fe0/f1fe01ea192d11b634b3dbab5f3f3c332a20bf75" alt=""
Actions on Google is the API
that lets you engage in conversations
with other services
through the Google Assistant.
data:image/s3,"s3://crabby-images/cb27e/cb27e6841c8f494a4cddb7d44e96956bdd14999e" alt=""
How do we build an Action?
- Design
- Develop
- Deploy
data:image/s3,"s3://crabby-images/d110c/d110c3a764a86051782e50a1247a42d03269c4e6" alt=""
What can Actions do?
data:image/s3,"s3://crabby-images/08e00/08e002aa74c8d6b8979b0c011feff5d58c7d8fb1" alt=""
- Query databases based on what the user is asking.
- Collect responses from the user (such as a form) and save them.
- Get some information about the user, with their permission.
- Fun things: Quizzes, personality tests, RPGs, quotes.
Can you express it as a conversation?
Conversation Design
You're doing it wrong
- Figure out what you want your code to do.
- Decide how you're going to present those results.
- "Build a screen" to get inputs.
data:image/s3,"s3://crabby-images/7b737/7b73781255a3b3bf2e225282bdae153cc40b8854" alt=""
data:image/s3,"s3://crabby-images/b2624/b26240b0d3ec91893c1742f134b522202cec55b2" alt=""
Personality?
Beware of picking up hitchhiking personalities.
Building Intents
data:image/s3,"s3://crabby-images/5d613/5d6139399d310c2af24a7406ad167a6266d67860" alt=""
Finally, the code
// Import the Dialogflow service function
const {dialogflow} = require('actions-on-google');
const action = dialogflow();
const functions = require('firebase-functions');
exports.webhook = functions.https.onRequest(action);
action.intent('favorite color', conv => {
let color = conv.parameters.color;
conv.ask( `My favorite color is ${color}, too. What would you like to do now?` );
});
Adding an API
const {dialogflow} = require('actions-on-google');
// Add a request-promise module
const rp = require('request-promise-native');
const action = dialogflow();
const functions = require('firebase-functions');
exports.webhook = functions.https.onRequest(action);
action.intent('favorite color', conv => {
let color = conv.parameters.color;
// Options to make the request
let options = {
uri: 'http://www.colourlovers.com/api/colors',
qs: {
keywords: color,
format: "json"
},
json: true
};
// Make the request
return rp(options)
.then( data => {
// Handle the result
conv.ask( `<speak>Did you know that ${data[0].title} has a hex value of`+
` <say-as interpret-as="characters">${data[0].hex}</say-as>.`+
` What would you like to do now?</speak>` );
});
});
Authenticating APIs
Google Sign In for Assistant
data:image/s3,"s3://crabby-images/eb149/eb149287274088e4eac4ce43f119339acb8c28ef" alt=""
const {dialogflow} = require('actions-on-google');
const action = dialogflow();
const functions = require('firebase-functions');
exports.webhook = functions.https.onRequest(action);
function getCredentials( id ){
// Get the user's OAuth credentials from firebase
// Return a Promise
}
function saveUserColor( credentials, name ){
// Use the Google Drive API to create a file using the user's credentials
// Return a Promise
}
action.intent('favorite color', conv => {
let color = conv.parameters.color;
const payload = conv.user.profile.payload;
const id = payload.sub; // OAuth Connect "sub" claim
return getCredentials( id )
.then( credentials => saveUserColor( credentials, color ) )
.then( () => {
conv.ask( `Ok, I've created a file named ${color}. What now?` );
});
});
Authenticating APIs
Credentials with Google Sign In for Assistant
Keep in mind...
- Remember the user's context
- Vary your responses
- Intents are what the user says,
not how you respond. - Internationalization has new twists
data:image/s3,"s3://crabby-images/1f77c/1f77ccab6de7b418fcc886e76d6e3be90faf5506" alt=""
Multivocal makes it easier
- Reduce boilerplate.
- Use sane defaults
- Session storage
- Suffixes and prompting
- Make it easy to override those defaults.
- Code generates results/values.
- Responses through configuration
- Templates
- Internationalization
data:image/s3,"s3://crabby-images/4e6f6/4e6f660c84bfc316453fb78adbfec99659c3d13f" alt=""
https://multivocal.info/
Using Multivocal
const Multivocal = require('multivocal');
exports.webhook = Multivocal.processFirebaseWebhook;
const config = {
Local: {
"en": {
Response: {
"Intent.favorite color": [
"My favorite colour is {{Parameter/color}}, too.",
"I agree, {{Parameter/color}} is rather nice."
]
},
Suffix: {
"Default": [
"What would you like to do now?"
]
}
},
"en-US": {
Response: {
"Intent.favorite color": [
"My favorite color is {{Parameter/color}}, too.",
"I agree, {{Parameter/color}} is very nice."
]
}
}
}
};
new Multivocal.Config.Simple(config);
Summary
- Most of what you need to do - you already know how to do.
- Create a personality first and write scripts for that personality.
- Remember to write your scripts how people actually talk. Test this.
- Intents are what the user says and does, not how you respond.
- In JavaScript, use Promises correctly.
- Don't mix your logic and your response.
data:image/s3,"s3://crabby-images/04b91/04b9128a050dd6c462f1f083a737371a3424f712" alt=""
data:image/s3,"s3://crabby-images/ed4e7/ed4e7dc9c14498525261880b0b9106e5db8c4a3c" alt=""
https://spiders.com/
https://prisoner.com/ubi/
https://actions.google.com/design
https://developers.google.com/actions
Stack Overflow: actions-on-google
https://multivocal.info/
If you can Dream It, you can Do It with the Google Assistant
By Allen “Prisoner” Firstenberg
If you can Dream It, you can Do It with the Google Assistant
- 1,057