In my dialogflow fulfillment, I want to query a mongodb database and based on the result return an answer. Since I use the actions-on-google database, I must use promises for async calls. How can I do that for a mongodb query?
const express = require("express");
const bodyParser = require("body-parser");
const {dialogflow} = require('actions-on-google');
const app = dialogflow()
var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/"
app.intent('Mongodb', (conv) =>{
MongoClient.connect(url, function(err, db) {
if (err) throw err;
var dbo = db.db("mydb");
var query = { address: /^S/ };
var path;
db.collection('paths', function(err, collection) {
collection.find({}).toArray(function(err, results) {
path = results;
console.log(results);
});
});
});
conv.ask(path)
});