В итоге мне пришлось делать все вручную:
- поиск сессий для одного с соответствующим идентификатором пользователя
- загрузить последнюю информацию о пользователе и заменить в сеансе
- сохранить новую информацию обратно в базу данных
var mongoose = require ('mongoose');
var Schema = mongoose.Schema;
const SessionSchema = new Schema({_id: String}, { strict: false });
const Session = mongoose.model('sessions', SessionSchema, 'sessions');
var User = require('../queries/single.js');
module.exports = function (userId, callback) {
console.log('finding session for',userId);
Session.findOne({session: {$regex: userId}},null,{lean: true},(err, session)=>{
if (err) return callback(err);
if (!session) return callback('user session not found');
//parse session
var sessionJson = JSON.parse(session.session);
//add reset flag
sessionJson.passport.user.resetSession = true;
//get updated user info
User({_id: sessionJson.passport.user._id}, (err, updatedUser)=>{
if (err) return callback(err);
//add new user info to session json
sessionJson.passport.user = updatedUser;
//save back to session
Session.findOneAndUpdate({_id: session._id},{$set: {session: JSON.stringify(sessionJson)}}, (err, savedSession) => {
if (err) return callback(err);
//success
return callback(null);
});
});
});
};