Bookshelf.js - 如何仅为一个查询获取“隐藏”字段?

时间:2017-07-11 15:24:16

标签: javascript arrays node.js knex.js bookshelf.js

我有以下Bookshelf模型:

Bookshelf.model.extend({
  tableName: 'users',
  hidden: ['password']
}, { 
  async getBy(filter) {
    return await this.query({where: filter}).fetch();
  }
})

如您所见,字段password被隐藏(因为我通常不希望它显示)。
但是,我需要它来连接我的用户(在进行哈希比较时):

const user = await userModel.getBy({email: req.body.email});
if (await bcrypt.compare(req.body.password, user.password)) { 
  // here user.password is undefined because it is hidden
}

有没有办法快捷查看可见性插件并获取密码而无需直接使用knexBookshelf.knex.raw())这样做?

致以最诚挚的问候,

1 个答案:

答案 0 :(得分:5)

好的,既然我找到了解决方案,我会回答我自己的问题,希望能帮助一些人:

14天前(2017年6月30日),问题#1379已合并。

它提供以下功能:

  

添加了使用直接指定给toJSON的选项覆盖锻造期间指定的选项的功能。

Here是提交,测试显示它是如何工作的。

就我而言,我会做以下事情:

const user = (await userModel.getBy({email: req.body.email})).toJSON({hidden: []});

hidden是一个空数组,因此它会覆盖先前的隐藏属性(hidden: ['password'])并获取要显示的密码。