2011-12-01 55 views
3

。所有版本都是最新的。我该如何拒绝用户使用mongoose-auth/everyauth登录使用node.js/expressjs/mongoose/mongoose-auth/everyauth

我想在开发过程中使用数据库表通过电子邮件地址将用户列入白名单,但我希望auth的主要方法是Facebook。我希望mongoose-auth只在Facebook电子邮件位于alpha_whitelist中时创建帐户。这将为表中的地址创建帐户,但如果用户不在白名单中,则超时并使服务器崩溃。

findOrCreateUser: function (sess, accessTok, accessTokExtra, fbUser) { 
    var promise = this.Promise(), 
     User = this.User()(); 
     // TODO Check user in session or request helper first 
     // e.g., req.user or sess.auth.userId 
     User.findOne({'fb.id': fbUser.id}, function (err, foundUser) { 
      if(foundUser) 
       return promise.fulfill(foundUser); 
      alpha_whitelist.findOne(
       {email: fbUser.email}, 
       function(err,doc) { 
        if(doc) { 
         console.log("CREATING"); 
         User.createWithFB(fbUser, accessTok, accessTokExtra.expires, function (err, createdUser) { 
          console.log(err,createdUser); 
          if (err) return promise.fail(err); 
          return promise.fulfill(createdUser); 
         }); 
        } else { 
         console.log('Denied'); 
         //not sure what to do here... i need to break the auth chain and redirect the user back to '/' 
        } 
       }); 
     }); 
     return promise; 
    } 

看来,无论我放在那里,它都会失败并使服务器崩溃。我显然缺少一些东西。任何帮助,将不胜感激。

回答

1

我没有测试过这一点,但我敢肯定,你只需要返回无极就像其它代码块都在做

else { 
    console.log('Denied'); 
    return promise.fail('Denied'); 
} 
+0

是的,你确实是对的。我曾尝试过,但没有意识到发生了什么事。看起来我必须用everyauth的'moduleErrorback'方法来捕捉错误。这里有一个链接帮助:https://github.com/bnoguchi/everyauth/issues/36感谢您的帮助。 – jhoff

0

我没有用过everyauth,但我猜你正在寻找validateRegistration功能,如果你把你的白名单中的代码存在,如:

.validateRegistration(function (newUser) { 
    db.checkWhiteList(function (success) { 
     return null; // everything OK 
    }, 
    function (err) { 
     return [ "Not on whitelist" ]; 
    } 
}); 

有一个在GitHub page在这个简短的说明。

+0

我认为'validateRegistration'功能仅适用于密码模块,而不是Facebook。它提供了一种我可以使用的备用方法,任何登录的用户都可以创建帐户,然后根据请求和路由检查白名单。 – jhoff

相关问题