nodejs / mongoose更新"多级"文件中的值/无法设置属性

时间:2014-04-07 14:51:31

标签: javascript node.js mongodb mongoose

我有一个“用户”集合,包含一些字段(名称,名字,登录名,密码......)

我想存储用户&密码在一个名为“local”的“子文档”中(对于本地连接,将来我可以有一个名为“facebook”或“google”的子文档...)

所以,这是mongo中文档的结构:

db.User.find(){
    "__v": 0,
    "_id": ObjectId("5342b25940bcab2d1d71e04a"),
    "active": true,
    "address": "juddegaass, 2A",
    "api_key": "3cead67add74395ce4d1dfcdd3ea4979",
    "city": "Kehlen",
    "country": "LU",
    "create_date": ISODate("2014-04-07T14:12:41.104Z"),
    "credit": 0,
    "email": "admin@company.com",
    "firstname": "Admin",
    "lastname": "Istrator",
    "local": {
        "email": "admin@company.com",
        "password": "$2a$08$Y7GorE3UhceNhPzvAdv7X.wDNxp80snHdng0hq9r1AePqRW1iHU5i"
    },
    "role": "su",
    "uptade_date": ISODate("2014-04-07T14:12:41.104Z"),
    "zip": "8281"
}

我有一个表单来更新用户,我的问题是我提交此表单时。我收到了一个错误:

TypeError: Cannot set property 'email' of undefined

这是我的Node User Mapper中的更新功能:

var toUpdate = {};

if (data.firstname) toUpdate.firstname = data.firstname;
if (data.lastname) toUpdate.lastname = data.lastname;
if (data.email) {
    toUpdate.email = data.email; 
    toUpdate.local.email = data.email;
}
if (data.password !== '') toUpdate.local.password = user.generateHash(data.password);
if (data.role) toUpdate.role = data.role;
...
if (data.apiKey) toUpdate.api_key = data.apiKey;
if (data.active) toUpdate.active = data.active;

dbUser.update({'_id' : data.id}, toUpdate, {upsert : true}, function (err) { 
    if (err) return callback(new Error(err));
    callback(null, data.id);
});

当然,我可以声明“本地”子对象,但如果我声明它,密码值将被删除。

1 个答案:

答案 0 :(得分:1)

您的评论清楚地表明您可能已在数据库中为此项目添加了条目。当您使用mongoose时,更新的正确方法是先将其从数据库中取出,然后保存。

dbUser.findbyId(data.id, function(err, user){
  if(err){
    return callback(err);
  }
  if(!user){
    user = new dbUser();
  }
  if (data.firstname) user.firstname = data.firstname;
  //...//
  if(data.email){
     user.local = user.local || {}; 
     user.local.email = data.email;
  }
  if(data.password !== '') {
    user.local = user.local || {}; 
    user.local.password = dbUser.generateHash(data.password);
  }
  user.save(callback); 
});