Skip to content

jovo-community/jovo-community-mongodb

Repository files navigation

MongoDB Database Integration

Learn how to store user specific data of your Alexa Skills and Google Actions to a MongoDb database.

Introduction

The MongoDb database integration allows you to store user specific data into the widely supported documented-oriented NoSQL-database.

Configuration

Download the package like this:

$ npm install --save jovo-community-mongodb

MongoDb can be enabled in the src/app.js file like this:

// @language=javascript

// src/app.js

const { MongoDb } = require('jovo-community-mongodb');

// Enable DB after app initialization
app.use(new MongoDb());

// @language=typescript

// src/app.ts

import { MongoDb } from 'jovo-community-mongodb';

// Enable DB after app initialization
app.use(new MongoDb());

In your config.js file, you can set the db configuration like this:

// @language=javascript

// src/config.js

module.exports = {
    
    db: {
        MongoDb: {
            databaseName: 'yourDatabaseName',
        collectionName: 'yourCollectionName',
        uri: 'yourMongoDbURI',
        libraryConfig: { /* MongoClientOptions */ },
        },
    },

    // ...

};

// @language=typescript

// src/config.ts

const config = {
    
    db: {
        MongoDb: {
            databaseName: 'yourDatabaseName',
        collectionName: 'yourCollectionName',
        uri: 'yourMongoDbURI',
        },
    },

    // ...

};

If you don't specify a collection name, a default collection UserData will be created in your specified database.

libraryConfig: Additional options that can be passed to the MongoDB client. You can find all options in the official MongoClientOptions reference.

Troubleshooting

Usually, the MongoDb integration should work as intended. However, we came across some edge cases that can cause the integration to misbehave by not connecting properly to the database.

Timeout on AWS Lambda

If you want to deploy your skill to AWS Lambda, chances are, your skill will time out trying to connect to your MongoDb database. This is because by default, Lambda waits for all events in the event loop to be finished before returning a response, which means that it waits for the open MongoDb connection to close. To counteract this issue, you can set callbackWaitsForEmptyEventLoop to false in your index.js like so:

// @language=javascript
exports.handler = async (event, context, callback) => {
    context.callbackWaitsForEmptyEventLoop = false;
    await app.handle(new Lambda(event, context, callback));
};

// @language=typescript
export const handler = async (event: any, context: any, callback: Function) => { 
    context.callbackWaitsForEmptyEventLoop = false;
    await app.handle(new Lambda(event, context, callback));
};

This tells Lambda to return a response as soon as possible, without waiting for the event loop to be finished.

Read more about best practices here.

Connection Refused on MongoDb Atlas

When you're just getting started with the MongoDb integration and are using the MongoDb Atlas service, a common problem is that your MongoClient will refuse the connection and keep you from accessing your database. This is because on Atlas, you have to whitelist your ip address to keep your database safe from unauthorized access. For that, go to the dashboard of your project on Atlas, select "Network Access" on the right panel and select "ADD IP ADDRESS". Usually, that should be sufficient, but sometimes, your ip address can change, leading to the same problem again. If you don't want to change your address over and over again, you have the option to whitelist every ip address (including your own) by adding 0.0.0.0/0 to the list.

Read more about whitelisting here.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published