forked from MichaelStephan/uptime
-
Notifications
You must be signed in to change notification settings - Fork 0
/
bootstrap.js
42 lines (40 loc) · 1.7 KB
/
bootstrap.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
var mongoose = require('mongoose');
var config = require('config');
var semver = require('semver');
// configure mongodb
var connectWithRetry = function() {
mongoose.connect(config.mongodb.connectionString || 'mongodb://' + config.mongodb.user + ':' + config.mongodb.password + '@' + config.mongodb.server +'/' + config.mongodb.database, { server: { auto_reconnect : true } }, function(err) {
if (err) {
console.error('Failed to connect to mongo on startup - retrying in 5 sec', err);
setTimeout(connectWithRetry, 5000);
} else {
mongoose.connection.on('open', function (err) {
mongoose.connection.on('error', function(err) {
console.log("Mongo collection failed, trying to reconnect");
});
mongoose.connection.db.admin().serverStatus(function(err, data) {
if (err) {
if (err.name === "MongoError" && (err.errmsg === 'need to login' || err.errmsg === 'unauthorized') && !config.mongodb.connectionString) {
console.log('Forcing MongoDB authentication');
mongoose.connection.db.authenticate(config.mongodb.user, config.mongodb.password, function(err) {
if (!err) return;
console.error(err);
process.exit(1);
});
return;
} else {
console.error(err);
process.exit(1);
}
}
if (!semver.satisfies(data.version, '>=2.1.0')) {
console.error('Error: Uptime requires MongoDB v2.1 minimum. The current MongoDB server uses only '+ data.version);
process.exit(1);
}
});
});
}
});
};
connectWithRetry();
module.exports = mongoose;