1
0
Fork 0
mirror of https://github.com/openstf/stf synced 2025-10-04 10:19:30 +02:00
OpenSTF/lib/db/index.js

62 lines
1.6 KiB
JavaScript

var r = require('rethinkdb')
var setup = require('./setup')
var logger = require('../util/logger')
var lifecycle = require('../util/lifecycle')
var db = module.exports = Object.create(null)
var log = logger.createLogger('db')
function connect() {
return r.connect({
// These environment variables are exposed when we --link to a
// RethinkDB container.
host: process.env.RETHINKDB_PORT_28015_TCP_ADDR || '127.0.0.1'
, port: process.env.RETHINKDB_PORT_28015_TCP_PORT || 28015
, db: process.env.RETHINKDB_ENV_DATABASE || 'stf'
, authKey: process.env.RETHINKDB_ENV_AUTHKEY
})
.then(function(conn) {
lifecycle.observe(function() {
return db.close()
})
return conn.on('error', function(err) {
log.fatal('Connection error', err.stack)
lifecycle.fatal()
})
})
.catch(function(err) {
log.fatal('Unable to connect to the database: "%s"', err.message)
lifecycle.fatal()
})
}
// Export memoized connection as a Promise
db.connect = (function() {
var connection = connect()
return function() {
return connection
}
})()
// Close connection, we don't really care if it hasn't been created yet or not
db.close = function() {
return db.connect().then(function(conn) {
return conn.close()
})
}
// Small utility for running queries without having to acquire a connection
db.run = function(q, options) {
return db.connect().then(function(conn) {
return q.run(conn, options)
})
}
// Sets up the database
db.setup = function() {
return db.connect().then(function(conn) {
return setup(conn)
})
}