init-vulnogram.js (57 lines of code) (raw):
const pbkdf2 = require('./lib/pbkdf2.js');
const User = require('./models/user.js');
const mongoose = require('mongoose');
const config = require('./config/conf');
mongoose.Promise = global.Promise;
mongoose.set('strictQuery', false);
mongoose.connect(config.database, {
keepAlive: false,
});
User.findOne({username: process.env.VULNOGRAM_ADMIN_USERNAME}, function(err, adminUser) {
if (err) {
console.log("MongoDB Error: " + err);
return false; // or callback
}
if (adminUser) {
console.log(`Admin user, ${process.env.VULNOGRAM_ADMIN_USERNAME}, already exists. Skipping initialization.`);
mongoose.connection.close();
process.exit(0);
}
pbkdf2.hash(process.env.VULNOGRAM_ADMIN_PASSWORD, function (err, hash) {
if (err) {
console.error(err);
}
let newUser = new User({
name: process.env.VULNOGRAM_ADMIN_NAME,
email: process.env.VULNOGRAM_ADMIN_EMAIL,
username: process.env.VULNOGRAM_ADMIN_USERNAME,
priv: 0,
group: process.env.VULNOGRAM_ADMIN_CNA_EMAIL,
password: hash
}, { _id: false });
if(error = newUser.validateSync()) {
console.log("Error: " + error);
process.exit(1);
}
User.findOneAndUpdate({
username: newUser.username
},
newUser,
{
upsert: true,
setDefaultsOnInsert: true
},
function (err, doc) {
if (err) {
console.error(err);
} else {
if (doc) {
console.log('Success', 'User ' + doc.username + ' is now updated.\n');
} else {
console.log('Success', 'New user is now registered and can log in: ' + newUser.username);
}
}
mongoose.connection.close();
});
});
});