Wie richte ich mit MongoLab eine MongoDB-Datenbank auf Heroku ein?

Ich benutze Express.js und MongoLab und bin dem gefolgtHeroku-Setup, um MongoDB zum Laufen zu bringen in der Produktion diesen Code in meinem werfenapp.js.

//Mongo on Heroku Setup
var mongo = require('mongodb');

var mongoUri = process.env.MONGOLAB_URI || 
  process.env.MONGOHQ_URL || 
  'mongodb://localhost/mydb'; 

mongo.Db.connect(mongoUri, function (err, db) {
  db.collection('mydocs', function(er, collection) {
    collection.insert({'mykey': 'myvalue'}, {safe: true}, function(er,rs) {
    });
  });
});

und ich habe die folgenden Routen und Felder für mein E-Mail-Formular (auch in app.js):

//Routes

app.get('/', function(req, res) {
    res.render('index', {
        title: 'DumbyApp'
    });
});

//save new email
app.post('/', function(req, res){
    emailProvider.save({
        address: req.param('address')
    }, function( error, docs) {
        res.redirect('/')
    });
});

Dadurch wird das neue Formular auf der Indexseite gerendert, und ich kann es lokal speichern, aber nicht in der Produktion, da ich nicht weiß, wie ich meine E-Mail-Sammlung einrichten soll. Kann mich jemand durch das führen? Neu in der Verwendung von MongoDB und Node.js, könnte also Hilfe gebrauchen.

BEARBEITEN:

In der MongoLab-Datenbankschnittstelle habe ich einencollection namensemails. Ist das die richtige Vorgehensweise?

EDIT 2:

Hier wird EmailProvider in app.js zusammen mit der Datei selbst definiert.

app.js

 var express = require('express')
  , routes = require('./routes')
  , user = require('./routes/user')
  , http = require('http')
  , path = require('path')
  , EmailProvider = require('./emailprovider').EmailProvider;

var emailProvider= new EmailProvider('localhost', 27017);

emailprovider.js

var Db = require('mongodb').Db;
var Connection = require('mongodb').Connection;
var Server = require('mongodb').Server;
var BSON = require('mongodb').BSON;
var ObjectID = require('mongodb').ObjectID;

EmailProvider = function(host, port) {
  this.db= new Db('localdb', new Server(host, port, {safe: false}, {auto_reconnect: true}, {}));
  this.db.open(function(){});
};


EmailProvider.prototype.getCollection= function(callback) {
  this.db.collection('emails', function(error, email_collection) {
    if( error ) callback(error);
    else callback(null, email_collection);
  });
};

//save new email
EmailProvider.prototype.save = function(emails, callback) {
    this.getCollection(function(error, email_collection) {
      if( error ) callback(error)
      else {
        if( typeof(emails.address)=="undefined")
          emails = [emails];

        for( var i =0;i< emails.address;i++ ) {
          email = emails[i];
          email.created_at = new Date();
        }

        email_collection.insert(emails, function() {
          callback(null, emails);
        });
      }
    });
};

exports.EmailProvider = EmailProvider;

Antworten auf die Frage(1)

Ihre Antwort auf die Frage