Реализация токена passport-http-bearer с помощью sails.js

Я пытаюсь реализовать паспорт passport-http-bearer стратегия, но он не нашел пользователя с информацией Bearer realm="Users",

мой request это почтовый запрос:

{'token':'simple_access_token',} 

У кого-нибудь есть идеи, почему возникает эта ошибка? Также я знаю здесь req должно быть https или же ssl вместо http, Как я могу это сделать?

Код, который я использую:

bearerPassportToken: function(req,res){
        passport.authenticate('bearer', function(err, user, info){
          if ((err) || (!user)) {
            if (err) return;
            if (!user)  
                console.log("info);//Info: Bearer realm="Users"
            res.redirect('/login');
            return;
          }
          req.logIn(user, function(err){
            if (err){
                res.redirect('/login');
            }
            //Need to write code for redirection
            ;
          });
        })(req, res);
    },

1 ответ

Решение

Недавно нам пришлось реализовать защиту API на основе Sails с токенами на предъявителя, и вот что мы сделали (протестировано с 0.9.x):

1) Подключите паспорт как пользовательское промежуточное ПО в config/passport.js (или это может быть config/express.jsв зависимости от вашего вкуса):

/**
 * Passport configuration
 */
var passport = require('passport');

module.exports.express = {
  customMiddleware: function(app)
  {
    app.use(passport.initialize());
    app.use(passport.session());
  }
};

2) Защитите необходимые контроллеры / действия с политикой в config/policies.js:

module.exports.policies = {
  // Default policy for all controllers and actions
  '*': 'authenticated'
};

3) Создайте политику, которая проверяет канал в api/policies/authenticated.js:

/**
 * Allow any authenticated user.
 */
var passport = require('passport');

module.exports = function (req, res, done) {
  passport.authenticate('bearer', {session: false}, function(err, user, info) {
    if (err) return done(err);
    if (user) return done();

    return res.send(403, {message: "You are not permitted to perform this action."});
  })(req, res);
};

4) Определите стратегию предъявителя для паспорта в services/passport.js (или где бы вы ни находили это более подходящим для вашего конкретного применения):

var passport = require('passport'),
  BearerStrategy = require('passport-http-bearer').Strategy;

/**
 * BearerStrategy
 *
 * This strategy is used to authenticate either users or clients based on an access token
 * (aka a bearer token).  If a user, they must have previously authorized a client
 * application, which is issued an access token to make requests on behalf of
 * the authorizing user.
 */
passport.use('bearer', new BearerStrategy(
  function(accessToken, done) {
    Tokens.findOne({token: accessToken}, function(err, token) {
      if (err) return done(err);
      if (!token) return done(null, false);
      if (token.userId != null) {
        Users.find(token.userId, function(err, user) {
          if (err) return done(err);
          if (!user) return done(null, false);
          // to keep this example simple, restricted scopes are not implemented,
          // and this is just for illustrative purposes
          var info = { scope: '*' }
          done(null, user, info);
        });
      }
      else {
        //The request came from a client only since userId is null
        //therefore the client is passed back instead of a user
        Clients.find({clientId: token.clientId}, function(err, client) {
          if (err) return done(err);
          if (!client) return done(null, false);
          // to keep this example simple, restricted scopes are not implemented,
          // and this is just for illustrative purposes
          var info = { scope: '*' }
          done(null, client, info);
        });
      }
    });
  }
));

Таким образом, вы сможете получить доступ к API, имея своего носителя в Authorization заголовок: Bearer 8j4s36...,

В этом примере отдельный сервер использовался для запроса / выдачи токенов, но вы могли бы также сделать это в том же приложении (тогда вам придется применять политику только к выбранным контроллерам).

Другие вопросы по тегам