整合passport.js和Meteor

Jun*_*hao 6 meteor meteorite passport.js

我试图在我的Meteor项目中实施passport.js,我很难通过护照发送用户信息.

首先,我正在构建一个在组织一侧使用LDAP的身份验证系统.你已经购买了Shibboleth的身份提供商,http: //shibboleth.net/products/identity-provider.html,并希望使用passport-saml作为驻留在web应用程序中的身份验证框架.我已经关注了这个git教程,https://github.com/bergie/passport-saml,以及官方的passport.js教程,我已经在Meteor服务器端的passport.js中实现了这些方法.

Meteor.startup(function () {
var require = Npm.require;
  passport = require('passport');
  var SamlStrategy = require('passport-saml').Strategy;

  passport.use(new SamlStrategy(
    {
      path: '/login/callback',
      entryPoint: 'https://openidp.feide.no/simplesaml/saml2/idp/SSOService.php',
      issuer: 'passport-saml'
    },
    function(profile, done) {
      findByEmail(profile.email, function(err, user) {
        if (err) {
          return done(err);
        }
        return done(null, user);
      });
    }
  ));

  Meteor.Router.add('/login/callback', 'POST', function(req, res){
    passport.authenticate('saml', { failureRedirect: '/', failureFlash: true });
    res.redirect('/');
  });

  Meteor.Router.add('/login', 'POST', function(req, res){
    passport.authenticate('saml', { failureRedirect: '/', failureFlash: true });
    res.redirect('/');
  });

  var app = __meteor_bootstrap__.app;
  app.use(passport.initialize());
  app.use(passport.session());

  passport.serializeUser(function(user, done) {
    done(null, user.id);
  });

  passport.deserializeUser(function(id, done) {
    User.findById(id, function(err, user) {
      done(err, user);
    });
  });

});
Run Code Online (Sandbox Code Playgroud)

我现在的问题是如何获得护照以发送用户信息.是通过passport.use中的函数传递一个配置文件对象来完成的吗?

非常感谢,我不确定我应该显示多少代码,请给我发表评论,我会改进这篇文章!

Spe*_*cer 1

这是在 Meteor 在 6.4 中更新对 oAuth 的支持之前被问到的,我假设用户已经解决了这个问题。对于我们这些正在寻找 oAuth + Meteor 的人来说,现在它集成得更好了。

无需搞乱 Passport.js

请参阅此处的博客文章:https://www.meteor.com/blog/2013/06/10/meteor-064-new-oauth-packages-and-recommended-updates

本质上你现在可以这样做:

$ meteor add accounts-twitter
$ meteor add accounts-facebook
Run Code Online (Sandbox Code Playgroud)

ETC。