我有一个用户模型和一个小部件模型。我在用户和小部件之间建立了关系。我还有一个为身份验证定义的策略,如果用户已通过身份验证,那么我将在req.session中保存用户ID。
小部件上需要用户:
attributes: {
user: {model: 'user', required: true}
}
有什么方法可以告诉WidgetController使用auth策略中的用户并仍然使用blueprint提供的所有默认操作?
答案 0 :(得分:3)
正如@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
。
答案 1 :(得分:1)
是的,有:)您可以使用策略来实现此目的:)
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
中存储“用户”完整对象,请调整代码并使用req.session.user.id
编辑
我道歉我使用自定义蓝图和查询,因为我使用sails ember blueprints :)但是如果我的内存正确,只需检查req.params["user"]
或req.query["user"]
即可让事情变得更加容易:)