Функция jwt.verify ничего не возвращает и API не может получить ответ - PullRequest
0 голосов
/ 18 февраля 2019

Файл App.js

const express = require('express');
const bodyParser = require('body-parser');
const graphqlHttp = require('express-graphql');
const { buildSchema } = require('graphql');
const isAuth =  require('./middleware/is-auth');
var mysql      = require('mysql');

const app = express();
const jwt = require('jsonwebtoken'); 

var connection = mysql.createConnection({
host     : 'localhost', //mysql database host name
user     : 'root', //mysql database user name
password : '', //mysql database password
database : 'test' //mysql database name
});

connection.connect(function(err) {
if (err) throw err
console.log('You are now connected with mysql database...')
})


app.use(bodyParser.json());

app.use(isAuth);

app.use(
 '/graphql',
   graphqlHttp({
    schema: buildSchema(`
       type users {
         id: String!
         username: String!
         password: String!
         role: String!
         name: String!
         photo: String!
        }
       type AuthData
       {
      userID: String!
      token: String!
      tokenExpiration: Int!
    }
    type RootQuery {
        getUsers: [users!]!
        login(username: String!, password:  String!): AuthData! 
    }
    type RootMutation {
      createUsers(name: String): String
    }
    schema {
        query: RootQuery
        mutation: RootMutation
    }
`),
rootValue: {
  login: async ({username,password}) =>  {




    return new Promise((resolve, reject) => {
      connection.query('select * from users where username = "'+username+'"', (error, results, fields) => {
        if (error) {
          reject(error)
        } else {
          resolve(results);
        }
      })
    }).then(function(result) {
      const users =  result;

    if(!users || users[0] == null)
    {
      throw new Error('User does not exist')
    }
    const token = jwt.sign({userID: users[0]['id'], username: users[0]['username']}, 'SomeSuperSecretKey', {
       expiresIn: '1h'
    });
    return { userID: users[0]['id'], token, token,tokenExpiration: 1}
  })
  },
  getUsers: async (req) => {

    if(!req.isAuth)
    {
      throw new Error('Unauthenticated');
    }
    // Note, we have to return the Promise here
    return new Promise((resolve, reject) => {
      connection.query('select * from users', (error, results, fields) => {
        if (error) {
          reject(error)
        } else {
          // Don't stringify
          resolve(results)
        }
      })
    })
  },

},
graphiql: true
})
);

app.listen(3000);

is-auth.js Файл

const jwt  = require ('jsonwebtoken');

module.exports = (req, res, next) => {
   const authHeader = req.get('Authorization');
   if(!authHeader){
      console.log("Here");
      req.isAuth = false;
      return next();
    }
   const token = authHeader.split(' ')[1]; // bearer tokenValue 

   if(!token || token === ''){
      console.log("Here1");
      req.authHeader = false;
      return next();
   }

   let decodedToken;
   try
   {
      console.log(token);
      decodedToken = jwt.verify(token, 'SomeSuperSecretKey'); //same key used in app.js

   }catch(err){
      console.log(err);
      req.isAuth = false;
      return next(); 
   }

  if(!decodedToken){
      req.isAuth = true;
      req.userID = decodedToken.userID;
      return next(); 
  }

}

Post man Api

The jwt.verifyфункция не возвращает ничего, что застряло, и API не дает ответа.Так что проблема в функции проверки, которая застряла в нем.И если я ввожу свой собственный токен, он выдаст еще одну ошибку, которая говорит о том, что вам не разрешено вводить свой собственный токен, так как можно использовать сгенерированные токены jwt.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...