/** * * Copyright (c) 2016, Intel Corporation. * * This program is licensed under the terms and conditions of the * Apache License, version 2.0. The full text of the Apache License is at * http://www.apache.org/licenses/LICENSE-2.0 */ "use strict"; /** * This class will instantiate the ORM, load in the models, call the method * to create db connections, test the connection, then create the tables and * relationships if not present */ const fs = require('fs'), path = require('path'), Sequelize = require('sequelize'), config = require('config'); function init() { const db = { sequelize: new Sequelize(config.get("db.users.host"), config.get("db.users.options")), Sequelize: Sequelize }; return db.sequelize.authenticate().then(function () { const User = db.sequelize.define('users', { id: { type: Sequelize.INTEGER, primaryKey: true, autoIncrement: true }, displayName: Sequelize.STRING, uid: Sequelize.STRING, isLDAP: Sequelize.BOOLEAN, authToken: Sequelize.STRING, authDate: Sequelize.DATE, authenticated: Sequelize.BOOLEAN, mail: Sequelize.STRING, memberSince: Sequelize.DATE, password: Sequelize.STRING, /* SHA hash of user supplied password for !isLDAP users */ passwordExpires: Sequelize.DATE }, { timestamps: false }); return db.sequelize.sync({ force: false }).then(function () { return db; }); }).catch(function (error) { console.log("ERROR: Failed to authenticate with USER DB"); console.log("ERROR: " + JSON.stringify(config.get("db"), null, 2)); console.log(error); throw error; }); } module.exports = init();