const mongoose = require('mongoose') const Settings = require('settings-sharelatex') const logger = require('logger-sharelatex') const POOL_SIZE = Settings.mongo.poolSize if ( typeof global.beforeEach === 'function' && process.argv.join(' ').match(/unit/) ) { throw new Error( 'It looks like unit tests are running, but you are connecting to Mongo. Missing a stub?' ) } mongoose.connect( Settings.mongo.url, { poolSize: POOL_SIZE, config: { autoIndex: false }, useMongoClient: true, appname: 'web' } ) mongoose.connection.on('connected', () => logger.log( { url: Settings.mongo.url, poolSize: POOL_SIZE }, 'mongoose default connection open' ) ) mongoose.connection.on('error', err => logger.err({ err }, 'mongoose error on default connection') ) mongoose.connection.on('disconnected', () => logger.log('mongoose default connection disconnected') ) if (process.env.MONGOOSE_DEBUG) { mongoose.set('debug', (collectionName, method, query, doc) => logger.debug('mongoose debug', { collectionName, method, query, doc }) ) } mongoose.plugin(schema => { schema.options.usePushEach = true }) mongoose.Promise = global.Promise; module.exports = mongoose