我有一个用户模型和一个小部件模型。 我在用户和小部件之间建立了关系。 我还为身份验证定义了策略,如果用户经过身份验证,那么我将用户 ID 保存在 req.session 中。
小部件上需要用户:
attributes: {
user: {model: 'user', required: true}
}
有没有办法告诉 WidgetController 使用身份验证策略中的用户,并且仍然使用蓝图提供的所有默认操作?
@MrVinz在他的回答中所写的那样,政策是实现这一目标的好方法。 但是,不建议更改req.body
或req.query
,因为您可能希望访问其原始值。 相反,您可以使用req.options.values
为蓝图值提供默认值。 例如,要将name
值默认为登录用户的名称,您可以创建类似于以下内容的策略:
module.exports = function defaultNamePolicy (req, res, next) {
// Make sure req.options.values is an object, and don't overwrite
// values from prior policies
req.options.values = req.options.values || {};
// If there's a logged in user, default to using their name.
// Otherwise this will be undefined and will have no effect
req.options.values.name = req.session.user && req.session.user.name
return next();
}
req.options.values
中的值用作请求的默认值,因此如果存在req.param('name')
,则将使用它而不是 req.options.values.name
。
是的,有:)您可以使用策略来实现此:)
module.exports = function(req, res, next) {
if(req.session.user){
//then it depends on your implementation but
req.params["widget"].user=req.session.user
//cab be req.query["widget"] or req.body["widget"]
/*
if(req.params["widget"]){
req.params["widget"].user=req.session.user
}
if(req.query["widget"]){
req.query ["widget].user=req.session.user
}
if(req.body["widget"]){
req.body ["widget].user=req.session.user
}
*/
}
//other stuff
next();
}
你也可以通过做这样的事情来使它更通用
var model = req.options.model || req.options.controller;
if(model && sails.models[model].attributes['user']){
//do the same trick
}
如果在session
中存储"user"完整对象,请调整代码并使用req.session.user.id
编辑
很抱歉,我使用自定义蓝图和查询,因为我正在使用帆余烬蓝图:)但是,它使事情变得更加容易,您只需检查req.params["user"]
或req.query["user"]
我的记忆是否正确:)