I am new to Node and im facing an error : [RangeError: Maximum call stack size exceeded]
  im not able able to solve the problem because most of the stack problems in others stackoverflow questions about node deals with hundreds of callback but i have only 3 here,
  first a fetch (findbyid) then an update an later a save operation !
  my code is :
  app.post('/poker/tables/:id/join', function(req,res){
 var id = req.params.id;
 
 models.Table.findById(id, function (err, table) {
     if(err) { console.log(err); res.send( { message: 'error' }); return; }
 
     if(table.players.length >= table.maxPlayers ) {
         res.send( { message: "error: Can't join ! the Table is full" });
         return; 
     }
     console.log('Table isnt Full');
 
     var BuyIn = table.minBuyIn;
     if(req.user.money < table.maxPlayers ) {
         res.send( { message: "error: Can't join ! Tou have not enough money" });
         return; 
     }
     console.log('User has enought money');
 
     models.User.update({_id:req.user._id},{ $inc:{ money : -BuyIn }}, function(err, numAffected) {
         if(err) { console.log(err); res.send( { message: 'error: Cant update your account' }); return; }
         console.log('User money updated');
 
 
         table.players.push( {userId: req.user._id, username: req.user.username, chips:BuyIn, cards:{}} );
 
 
         table.save(function (err) {
             if(err) { console.log(err); res.send( { message: 'error' });return; }           
 
             console.log('Table Successfully saved with new player!');
             res.send( { message: 'success', table: table});
 
         });
     });
 
 })});
 
  The error occurs during the save operation at the end !
  I use MongoDb with mongoose so 'Table' and 'User' are my database collections.
  This is from my first project with nodejs,expressjs and mongodb so i probably have made huge mistakes in the async code :(
  thx for your help !
  
  EDIT: i tried to replace the save with an update : 
  models.Table.update({_id: table._id}, { '$push': { players : {userId: req.user._id, username: req.user.username, chips:BuyIn, cards:{}} } }, function(err,numAffected) {
 
                 if(err) { console.log(err); res.send( { message: 'error' });return; }           
 
                 console.log('Table Successfully saved with new player!');
                 res.send( { message: 'success', table: table});
 
 
             });
 
  But it doesnt help the error is still coming and i dont know how to debug it :/
  
  Last edit: i post the answer here because iam new to this site and it doesnt want me to answer due to the spam protection probably ( or i would have to wait 4 hours and i prefer not !)
  I finally got it !
  In fact i created another mongoose schema and model for the player witch is an embedded document in the table document but trying to save it directly as an object didnt worked i had to create a specific model instance for the player first and then add it to the table doc so my code is now 
  ... update user money ... then 
 
 var player = new models.Player({userId: req.user._id, username: req.user.username, chips:BuyIn, cards:{}});
 
     models.Table.update({_id: this._id}, { '$push': { 'players' : player } }, function(err,numAffected) {
         if(err) { console.log(err); res.send( { message: 'error during update', error: err });return; }         
 
         this.players.push( {userId: req.user._id, username: req.user.username, chips:BuyIn, cards:{}} );
         res.send( { message: 'success', table: this});
 
         }.bind(this));
 
  I dont really know why mongoose send me a stack size error due to this but it solved the problem !!!