The development framework for cross-platform voice apps
Documentation - CLI - Sample App - Contributing - Twitter
app.setHandler({
'LAUNCH': function() {
this.toIntent('HelloWorldIntent');
},
'HelloWorldIntent': function() {
this.ask('Hello World! What\'s your name?', 'Please tell me your name.');
},
'MyNameIsIntent': function(name) {
this.tell('Hey ' + name.value + ', nice to meet you!');
},
});
Jovo is the first open source framework that lets you build voice apps for both Amazon Alexa and Google Assistant with only one code base. Besides cross-platform development, Jovo also offers a variety of integrations and easy prototyping capabilities.
The main features of the Jovo ecosystem are:
- Jovo Framework: Build voice apps for both Amazon Alexa and Google Assistant
- Jovo CLI: Create, build, and deploy Jovo projects (including staging)
- Jovo Webhook: Develop and debug voice apps on your local computer
- Jovo Debugger: Test and debug voice apps in your browser
- Jovo Language Model: A consolidated language model that can be converted into Alexa Interaction Models and Dialogflow Agents
🚀 Join our newsletter for free courses on voice app development: www.jovo.tech/newsletter
Read more in our Getting Started Guide.
Install the Jovo CLI:
$ npm install -g jovo-cli
Create a new Jovo project:
$ jovo new <directory>
Name | Description | Docs |
---|---|---|
Command Line Tools | Create and run Jovo projects from your command line | 📝 |
Routing | Easy routing capabilities for intents and states | 📝 |
Data input | Deal with user specific data and request parameters (slots and entities) easily | 📝 |
Speech and visual output | Craft your responses, including speech an visual elements | 📝 |
Name | Description | Docs |
---|---|---|
User object | Create contextual experiences with user specific data and services | 📝 |
Speech Builder | Helpful class to create speech output and add variety to your responses | 📝 |
i18n | Create multilingual voice apps | 📝 |
Jovo Persistence Layer | Persist user specific data | 📝 |
Jovo Analytics Layer | Get usage statistics and logging with analytics integrations | 📝 |
Staging | Create and maintain different environments | 📝 |
Plugins | Extend the Jovo Framework without having to mess with its core code and architecture | 📝 |
Testing | Use the Jovo TestSuite to integrate unit tests into your voice app project | 📝 |
Jovo is not a common denominator solution. You can access platform specific features for Amazon Alexa and Google Assistant. See a list of supported features below.
Name | Description | Docs |
---|---|---|
Multi-platform handler | Add or overwrite specific intents and states for platform specific app logic | 📝 |
Name | Description | Docs |
---|---|---|
Audioplayer | Build Alexa Audioplayer Skills | 📝 |
VideoApp | Build Alexa VideoApp Skills | 📝 |
Alexa Cards | Create visual output with home cards for Alexa Skills | 📝 |
Alexa Device Address | Access users' device location | 📝 |
Alexa Lists | Access users' To Do and Shopping Lists | 📝 |
Alexa Verifier | Makes it possible to host your Alexa skill on your own server instead of AWS Lambda | 📝 |
Alexa Dialog Interface | Use Alexa's Dialog Directives for multi-turn conversations | 📝 |
Echo Show Render Templates | Display visual elements on Echo Show | 📝 |
Progressive Responses | Keep your users engaged while processing a longer request | 📝 |
Skill Events | Get notified when an event (e.g. Skill enabled/disabled) occurs | 📝 |
CanFulfillIntentRequest | Add name-free interaction to your skill and increase your skill's discoverability | 📝 |
Game Engine | Provides the toolset to receive Echo Button events | 📝 |
Gadget Controller | Allows you to control the user's Echo Buttons | 📝 |
Name | Description | Docs |
---|---|---|
Google Assistant Cards | Create visual Output for the Google Assistant mobile app | 📝 |
Suggestion Chips | Display buttons to allow your users to quickly reply on mobile phones | 📝 |
Location | Access your user's location data | 📝 |
Media Response | Play longform audio | 📝 |
The following features are not implemented yet. We appreciate any kind of help and are also happy to assist you, if you have any questions about the core code. You can reach us on Slack.
Platform | Feature | Docs |
---|---|---|
Amazon Alexa | PlaybackController Interface | 📝 |
Notifications | 📝 | |
Google Action | Table Card | 📝 |
Transactions | 📝 | |
Push Notifications | 📝 | |
Android Link | 📝 |
See the Jovo Persistence Layer for more information on storing user specific data.
Name | Description | Docs |
---|---|---|
File Persistence | Saves user specific data in JSON file for fast prototyping and development (default) | 📝 |
Dynamo DB | Saves user specific data in AWS DynamoDB table | 📝 |
See the Jovo Analytics Layer for more information on analytics features.
Name | Description | Docs |
---|---|---|
Dashbot | Chatbot and Voice App Analytics including Usage Metrics, Behavior Flows, and Live Interaction Transcripts | 📝 |
Bespoken Analytics | Voice App Analytics including Usage Metrics, Logging, and Monitoring | 📝 |
Chatbase | Voice App Analytics including Usage Metrics, Session Flows and Link Tracking | 📝 |
Botanalytics | AI powered Chatbot Analytics and Voice Analytics | 📝 |
See the Jovo CLI Docs for more information on CLI features.
Name | Description | Docs |
---|---|---|
bst proxy | Proxy service that creates a webhook link for local prototyping, with additional logging and analytics features | 📝 |
nodemon | Monitor changes and automatically restart the server | 📝 |
Find a quickstart guide and comprehensive tutorials here:
- General:
- Account Linking:
- Amazon Alexa:
- Google Action:
We strongly encourage everyone who wants to help the Jovo development take a look at the following resources:
- CONTRIBUTING.md
- Take a look at our issues
- Add your project to jovotech/builtwithjovo
Jovo is a free, open source framework for voice developers. We're improving it every day and appreciate any feedback. How to support us? Just go ahead and build something cool with the framework and let us know at feedback@jovo.tech. Thanks!