/feathers-camo

Easily create a Camo Service for Feathersjs.

Primary LanguageJavaScriptMIT LicenseMIT

feathers-mongoose

NPM

Build Status Code Climate

Create a Mongoose ORM wrapped service for FeathersJS.

Installation

npm install feathers-mongoose --save

Documentation

Please refer to the Feathers database adapter documentation for more details or directly at:

Getting Started

Creating an Mongoose service is this simple:

var mongoose = require('mongoose');
var MongooseModel = require('./models/mymodel')
var mongooseService = require('feathers-mongoose');

mongoose.Promise = global.Promise;
mongoose.connect('mongodb://localhost:27017/feathers');

app.use('/todos', mongooseService({
  Model: MongooseModel
}));

See the Mongoose Guide for more information on defining your model.

Complete Example

Here's a complete example of a Feathers server with a message mongoose-service.

const feathers = require('feathers');
const rest = require('feathers-rest');
const socketio = require('feathers-socketio');
const errors = require('feathers-errors');
const bodyParser = require('body-parser');
const mongoose = require('mongoose');
const service = require('feathers-mongoose');

// Require your models
const Message = require('./models/message');

// Tell mongoose to use native promises
// See http://mongoosejs.com/docs/promises.html
mongoose.Promise = global.Promise;

// Connect to your MongoDB instance(s)
mongoose.connect('mongodb://localhost:27017/feathers');


// Create a feathers instance.
const app = feathers()
  // Enable Socket.io
  .configure(socketio())
  // Enable REST services
  .configure(rest())
  // Turn on JSON parser for REST services
  .use(bodyParser.json())
  // Turn on URL-encoded parser for REST services
  .use(bodyParser.urlencoded({extended: true}));

// Connect to the db, create and register a Feathers service.
app.use('messages', service({
  name: 'message',
  Model: Message,
  paginate: {
    default: 2,
    max: 4
  }
}));

// A basic error handler, just like Express
app.use(errors.handler());

app.listen(3030);
console.log('Feathers Message mongoose service running on 127.0.0.1:3030');

You can run this example by using npm start and going to localhost:3030/messages. You should see an empty array. That's because you don't have any messages yet but you now have full CRUD for your new message service, including mongoose validations!

Changelog

3.3.0

  • Gets now support $populate. (#53)

3.2.0

  • Fixes toObject hook so it doesn't call toObject if it's not a mongoose model. (#44)
  • Ensures that new fields get added when doing an update (#48)
  • Adds 2 config params:
    • overwrite (default: true) - updates overwrite existing data
    • lean (default: false) - makes it so that queries call .lean() so that they run faster and return plain objects. (#51)

3.1.0

  • Use internal methods instead of service methods directly

3.0.0

  • Compatibility with Feathers 2.x
  • Changing how a service is initialized
  • Removing mongoose as a bundled dependency
  • Converting over to ES6
  • Converting to use the new service test harness
  • Moving over to Promises.
  • Updating documentation and example.

2.0.0

  • Consistency with other service adapters
  • Compatibility with Feathers 1.0+
  • Adequate tests
  • Autoreconnect by default when not passing a connection string
  • Add special query params:
    • $sort
    • $skip
    • $limit
    • $select
    • $populate

0.1.1

  • First working release

0.1.0

  • Initial release.

License

MIT

Authors