Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stefanwalther/mongoose-connection-config
Helper library to set mongoose configurations.
https://github.com/stefanwalther/mongoose-connection-config
library mongodb mongoose
Last synced: 2 months ago
JSON representation
Helper library to set mongoose configurations.
- Host: GitHub
- URL: https://github.com/stefanwalther/mongoose-connection-config
- Owner: stefanwalther
- Created: 2018-02-22T13:44:00.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-10-29T20:44:52.000Z (2 months ago)
- Last Synced: 2024-10-29T22:51:28.741Z (2 months ago)
- Topics: library, mongodb, mongoose
- Language: JavaScript
- Size: 96.7 KB
- Stars: 1
- Watchers: 2
- Forks: 1
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Contributing: docs/contributing.md
Awesome Lists containing this project
README
# mongoose-connection-config
[![npm](https://img.shields.io/npm/v/mongoose-connection-config.svg)]()
[![CircleCI](https://img.shields.io/circleci/project/github/stefanwalther/mongoose-connection-config.svg)](https://circleci.com/projects/gh/stefanwalther/mongoose-connection-config)
[![Codecov](https://img.shields.io/codecov/c/github/stefanwalther/mongoose-connection-config.svg)](https://codecov.io/gh/stefanwalther/mongoose-connection-config)> Helper library to set mongoose connection configuration.
---
## Installation
```
$ npm install mongoose-connection-config --save
```## Usage
### Build the connection string
```js
const MongooseConnectionConfig = require('mongoose-connection-config');const opts = {
host: process.env.MONGO_HOST || 'localhost',
port: process.env.MONGO_PORT || 27017,
database: 'my-db'
};
const mcc = new MongooseConnectionConfig(opts);console.log(mcc.getMongoUri()); // => mongodb://localhost:27017/my-db
```### Override the connection string
If you want to ignore all options being passed in, then set the option `connection_string`, this value will then be returned, building the connection string will be skipped.
```js
const MongooseConnectionConfig = require('mongoose-connection-config');
const opts = {
connection_string: 'mongodb+srv://dbUser:[email protected]/test?retryWrites=true&w=majority',
host: process.env.MONGO_HOST || 'localhost',
port: process.env.MONGO_PORT || 27017,
database: 'my-db'
};
const mcc = new MongooseConnectionConfig(opts);console.log(mcc.getMongoUri()); // => mongodb+srv://dbUser:[email protected]/test?retryWrites=true&w=majority
```
## API
### [MongooseConnectionConfig](src/index.js#L10)
### [Configuration](src/index.js#L53)
Define a configuration object to pass to the constructor.If no options are defined, the default options will be used:
See [index.js => DEFAULT_CONFIGURATION](index.js) for more information about the current default options.**Params**
* `opts` **{Object}**: Options to pass in.
* **{String}**: `opts.connection_string - Full connection string which will then be returned, ignoring all other options.
* `opts.debug` **{Boolean}**: Whether MongoDB runs in debug mode or not.
* `opts.host` **{String}**: The MongoDBhost, defaults to `localhost`. See the mongodb [connection string spec](https://docs.mongodb.com/manual/reference/connection-string/) for more details.
* `opts.port` **{Number}**: The MongoDB port, defaults to `27017`. See the mongodb [connection string spec](https://docs.mongodb.com/manual/reference/connection-string/) for more details.
* `opts.database` **{String}**: The MongoDB database, defaults to `admin`. See the mongodb [connection string spec](https://docs.mongodb.com/manual/reference/connection-string/) for more details.
* `opts.connectOptions` **{Object}**: The MongoDB connection properties, being passed through to the native MongoDB driver. See [mongoose' documentation](http://mongoosejs.com/docs/connections.html), resp. [MongoDB's native driver for node.js' documentation](https://github.com/mongodb/node-mongodb-native) for more details.**Example**
```js
// Default Options:
const defaultOpts = {
debug: false,
host: 'localhost',
port: 27017,
database: '',
connectOptions: {
db: {},
server: {
auto_reconnect: true
},
replset: {},
user: {},
pass: {},
auth: {},
mongos: {}
}
};
```### [.constructor()](src/index.js#L77)
Initialize a new MongooseConnectionConfig.Basic Example:
**Params**
* **{Configuration}**: config - Configuration options overriding the default ones.
**Example**
```js
const MongooseConnectionConfig = require('./src');const opts = {
host: process.env.MONGO_HOST || 'localhost',
port: process.env.MONGO_PORT || 27017,
database: 'my-db'
};
const mcc = new MongooseConnectionConfig(opts);console.log(mcc.getMongoUri()); // => mongodb://localhost:27017/my-db *
```Example:
* `returns` **{Object}**
**Example**
```js
const MongooseConnectionConfig = require('./../src');let mongooseConnectionConfig = new MongooseConnectionConfig();
console.log(mongooseConnectionConfig.DEFAULT_CONFIG);
```Get the connection string.
* `returns` **{string}**
## Author
**Stefan Walther*** [github.com/stefanwalther](http://github.com/stefanwalther)
* [twitter](http://twitter.com/waltherstefan)## License
MIT***
_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.6.0, on June 01, 2019._