Skip to content

teambition/limbo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

90 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

limbo

NPM version Build Status Talk topic

Factory/Loader of mongoose

Deal with what

  • A rpc server for querying mongodb.
  • Exchange data/message cross applications.
  • Listen for the data's change and emit events.

Providers

  • mongo query via mongoose api
  • rpc query via rpc methods

Overwrite the mongoose model methods

AFAIK, we can use hooks or so called middlewares to modify the mongoose model object before save and remove functions, but it does not works on update function. There was even leaded to an argument on github, but the maintainers still don't pay their attension on this issue. So I decide to use some tricks to overwrite the mongoose model methods, and make the hooks work. For example, we have an update function in model, we need update the updatedAt key when we save data by update function, we can overwrite this function.

_update = UserModel.update
UserModel.update = (conditions, update) ->
  update.updatedAt or= new Date
  _update.apply this, arguments

In limbo, we supply an overwrite function to help you overwrite the same name function of each model.

limbo = require 'limbo'
db = limbo.use 'test',
  conn: mongoose.createConnection 'mongodb://localhost/test'
# Overwrite the update function
db.loadOverwrite 'update', (_update) ->
  (conditions, update) ->
    update or= new Date
    _update.apply this, arguments
# Load schemas
db.loadSchema 'User', UserSchema
# Then each update function will auto update the updateAt key when executed
db.user.update()

We use a currying way to ensure your function recieve the exactly arguments by the user given. So the origin function of model will give you in the wrapper function (in this example, it is _update).

As the same as loadStatics and loadMethods in limbo, the loadOverwrite function also have a plural version: loadOverwrites, you can pass a group of overwrite function to it.

Dependencies

  • axon/axon-rpc limbo use axon as message-oriented middleware, and use axon as rpc middleware.

Example

Attention!

Some methods in rpc provider is not enabled, here is some examples:

  1. method chain cross functions is not allowed:

db.user.find({}).limit(1).exec(callback) => db.user.find({}, {limit: 1}, callback)

  1. RegExp in conditions is not allowed:

db.user.find({email: /gmail.com/}, {limit: 1}, callback) => db.user.aggregate([{$match: {'email': {$regex: 'gmail.com'}}}, {$limit: 1}])

  1. aggregate function in mongoose do not auto cast variables to ObjectId or anything else, so you should take case of these variables and do not use them in the rpc provider. (for the reason JSON only accept data)

Changelog

0.3.1

  • emit bind event when methods are loaded from rpc server

0.3.0

  • remove mongoose dependency and change the initial function

0.2.3

  • get rid of mongoose 3.8.17 (bugness) and use a lenient dependence

0.2.1

  • fix the confliction of _fn in coffeescript

0.2.0

  • forget manager, use model now
  • merge bind and enableRpc to one method: enableRpc
  • loadStatics, loadMethods and loadOverwrites in mongo provider
  • use the load prefix on all loading methods

0.1.8

  • auto detective provider

0.1.7

  • auto convert bind port to number

0.1.6

  • the rpc provider now support method chain (only use it after the connect callback)

0.1.5

  • move bind method to mongo provider
  • support connect to different ports in different rpc instance
  • remove _methods in exposed methods

0.1.4

  • the managers extends limbo.Manager will bind all methods to the manager itself.

0.0.3

  • event support for rpc call

0.0.2

  • support query by mongo/rpc provider
  • auto provide a rpc server so you can query via tcp connect

0.0.1

  • only readme

Licence

MIT