я пытаюсь выполнить вход в систему с помощью graphql, я хочу сначала проверить, существует ли электронная почта в базе данных, затем, если электронная почта существует, тогда я сравню пароль с хэшем bcrypt в пароле, если он вернет trueЗатем я обновлю токен в таблице пользователей в базе данных, но когда я проверил его с этим
mutation {
loginUser(user: {email: "kmd@vh.id", password: "1345968"}) {
password
}
}
, он вернул его вместо токена в базе данных
mutation {
loginUser(user: {email: "kmd@vh.id", password: "1345968"}) {
token
}
}
вот мой код
import models from '../../../models/index.js';
import User from '../../types/user.js';
import UserInput from '../../inputs/user.js';
const jwt = require('jsonwebtoken')
const bcrypt = require('bcryptjs')
require('dotenv').config()
const fs = require('fs');
const path = require('path');
var privateKey = fs.readFileSync(path.join(__dirname, '../../key/private.key'), 'utf8');
export default {
type: User,
args: {
user: {
type: UserInput
}
},
resolve (_,args) {
return models.user.findOne({
where: {email: args.user.email}
}).then((fUser)=> {
bcrypt.compare(args.user.password, fUser.password, function (err, res) {
if (res) {
return models.user.findById(fUser.id).then((user) => {
return user.update({ token: jwt.sign({id:fUser.id, role:fUser.role, email:fUser.email}, privateKey, { expiresIn: '1h' }) });
});
} else {
console.log(err+" error")
}
})
});
}
};
пожалуйста, я могу заставить его вернуть токен