raincatcher-mongoose-store
One stop shop for all Mongoose schemas
Run tests
Ensure Mongo is running on your machine, type the following command
npm test
Models
Mongoose models can be found in models
directory. To add a new model use the same naming convention for desired dataset. ie. workorders
model for workorders
dataset / collection. Then require the directory and access the model using the name applied.
Note: Each schema require autogenerated timestamp
that are used by other modules like raincatcher-sync to determine if object was changed. When creating new schema please make sure to add {timestamps: true}
as schema option.
API
connect
To connect to mongo
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var customSchemas = {
workorders: function(mongooseConnection) {
var customWorkorderSchema = new Schema({
...
name: {type: String}
...
}, {timestamps: true});
mongooseConnection.model('CustomWorkorderModel', customWorkorderSchema);
}
...
...
};
Connector.connect('mongodb://mongoUriGoseHere:27017/db', {}, customSchemas)
.then(function() {
}, function(error) {
});
getDAL
Get the Data access layer object for a collection/dataset.
var datasetId = "workorders";
Connector.getDAL(datasetId).
then(function(_dal) {
}, function(error) {
});
listen
The Data Access Layer object for a collection has a listen
function that ensures that the CRUDL topics for the data set are subscribed.
function customListFunction() {
return this.model.list();
}
var datasetId = "workorders";
Connector.getDAL(datasetId).
then(function(_dal) {
_dal.listen(":data", mediator, {
list: customListFunction
});
}, function(error) {
});
The following functions are overridable:
- create
- update
- list
- remove
- read
disconnect
Connector.disconnect()
.then(function() {
}, function(error) {
});