我有一些Meteor 方法,我想保护它们,以便只有某些用户可以从客户端调用它们。但是,服务器也使用这些方法。我在 this.userid 中传递了用户 ID,因此我可以检查用户是否已登录以及是否允许他们拨打电话,没问题。但是当我还需要从服务器端调用该方法时,我如何确定它是一个服务器调用,以便我可以允许该方法执行。检查是否存在 this.userid 以确定其服务器调用是否也允许未经身份验证的用户调用该方法。我正在寻找一种方法来确定服务器是否调用了该方法,以便我可以允许它并仍然防止未经身份验证的用户调用该方法。
Meteor.methods({
makeCoffee: function (time) {
check(time, Number);
if(calledByServer || (Meteor.user() && Meteor.user().profile.usertype === 'coffee dude')){
//Makin' Coffee
}
else
throw new Meteor.Error(404, "Can't find my pants");
return "Coffee will be made at " + time;
}