Actions on Google Client Library
This client library makes it easy to create Actions for the Google Assistant and
supports Dialogflow, Actions SDK (v2), and Smart Home fulfillment.
:warning: We now recommend using Actions Builder or the Actions SDK to develop, test, and deploy Conversational Actions. For Conversational Actions built using Actions Builder see the @assistant/conversation library.
Setup Instructions
Install the library with either npm install actions-on-google
or yarn add actions-on-google
if you use yarn.
Developer Preview
To support features under Developer Preview, the library has a special preview
branch which can be installed using the @preview
tag.
This is installed with either npm install actions-on-google@preview
or yarn add actions-on-google@preview
.
The preview
tag will be kept up to date with every new version of the library.
You can use the Developer Preview version to experience exciting new features that we’re still testing to make sure we have the best developer experience, and help us providing feedback on the API design and feature set.
The APIs offered in Developer Preview have not matured to General Availability yet, which means:
- You can’t publish Actions that use features in Developer Preview.
- The APIs are potentially subject to backwards incompatible changes.
Conversational Services
Dialogflow
const {
dialogflow,
Image,
} = require('actions-on-google')
const app = dialogflow()
app.intent('Default Welcome Intent', conv => {
conv.ask('Hi, how is it going?')
conv.ask(`Here's a picture of a cat`)
conv.ask(new Image({
url: 'https://developers.google.com/web/fundamentals/accessibility/semantics-builtin/imgs/160204193356-01-cat-500.jpg',
alt: 'A cat',
}))
})
app.intent('Goodbye', conv => {
conv.close('See you later!')
})
app.intent('Default Fallback Intent', conv => {
conv.ask(`I didn't understand. Can you tell me something else?`)
})
Actions SDK
const {
actionssdk,
Image,
} = require('actions-on-google')
const app = actionssdk()
app.intent('actions.intent.MAIN', conv => {
conv.ask('Hi, how is it going?')
conv.ask(`Here's a picture of a cat`)
conv.ask(new Image({
url: 'https://developers.google.com/web/fundamentals/accessibility/semantics-builtin/imgs/160204193356-01-cat-500.jpg',
alt: 'A cat',
}))
})
app.intent('actions.intent.TEXT', (conv, input) => {
if (input === 'bye' || input === 'goodbye') {
return conv.close('See you later!')
}
conv.ask(`I didn't understand. Can you tell me something else?`)
})
Notes about the code snippet
Dialogflow
Actions SDK
Smart Home
const { smarthome } = require('actions-on-google')
const app = smarthome()
app.onExecute((body, headers) => {
return {
requestId: 'ff36...',
payload: {
},
}
})
app.onQuery((body, headers) => {
return {
requestId: 'ff36...',
payload: {
},
}
})
app.onSync((body, headers) => {
return {
requestId: 'ff36...',
payload: {
},
}
})
Notes about the code snippet
Frameworks
Export or run for your appropriate framework:
Firebase Functions
const functions = require('firebase-functions')
exports.fulfillment = functions.https.onRequest(app)
Dialogflow Inline Editor
const functions = require('firebase-functions')
exports.dialogflowFirebaseFulfillment = functions.https.onRequest(app)
Self Hosted Express Server
const express = require('express')
const bodyParser = require('body-parser')
const expressApp = express().use(bodyParser.json())
expressApp.post('/fulfillment', app)
expressApp.listen(3000)
AWS Lambda API Gateway
exports.fulfillment = app
Next Steps
Take a look at the docs and samples linked at the top to get to know the platform and supported functionalities.
Library Development Instructions
This library uses yarn
to run commands. Install yarn using instructions from https://yarnpkg.com/en/docs/install or with npm: npm i -g yarn
.
Install the library dependencies with yarn
. If you want to run any of the sample apps, follow the instructions in the sample README.
Functionality
Public interfaces, classes, functions, objects, and properties are labeled with the JSDoc @public
tag and exported at the top level. Everything else that is not labeled @public
and exported at the top level is considered internal and may be changed.
This library supports the following Services:
Actions SDK
This library supports only Actions SDK fulfillment version 2.
To ensure that your fulfillment uses version 2, set the "fulfillmentApiVersion": 2
property in your action package.
References & Issues
Make Contributions
Please read and follow the steps in the CONTRIBUTING.md.
License
See LICENSE.
Terms
Your use of this sample is subject to, and by using or downloading the sample files you agree to comply with, the Google APIs Terms of Service.