mobu
v1.0.0
Published
MOngoDb Uri builder and parser
Downloads
76
Maintainers
Readme
mobu - (mo)ngoD(b) (u)RI builder
mobu is a simple dependency free connection URI builder for MongoDB.
Install
$ npm install mobu
Usage
const mobu = require('mobu');
const mongoDbConnectionUri = mobu.build({
username: 'username', // optional
password: 'password', // optional but only if username is included
hosts: [
{ host: 'localhost', port: 27017 }
],
database: 'mydatabase',
options: [
{ replicaSet: 'myreplicaset' }
]
});
// mongoDbConnectionUri = 'mongodb://username:password@localhost:27017/mydatabase?replicaSet=myreplicaset'
API
mobu.build(options)
- Builds the connections string from the provided options. All options are optional. If no options are provided, the default connection string returned is:'mongodb://localhost:27017'
.username
- String The MongoDB username to use for the connectionpassword
- String The password for the MongoDB user. Only considered ifusername
is also provided.hosts
- Array The MongoDB hosts. Multiple can be provided. Each entry must be of the following form:host
- String The network hostname of a MongoDB instance. Default:'localhost'
port
- number or String The port number MongoDB is lisenting on for this instance. Default:27017
- database - String The name of the primary database to use for this connection.
options
- Array Any querystring parameters to include. mobu will accept any options so please check the MongoDB connection string documentation for the correct options. Each option is of the form:optionName: optionValue
optionValue
- String Any value for the provided option (optionName
)
Development
mobu will always as simple as possible dealing only with MongoDB connection strings. However in the future it will include additional validation checks and parsing abilities.
If you find any bugs or want to contribute, great! Please know that we strive for 100% code coverage in our tests so be sure to run the tests, add additional if neccessary, and check the coverage before submitting.
$ npm test
$ npm run cover