ctx.passport undefined при попытке создать jsonwebtoken при использовании паспорта с koa?

70
7

Я пытаюсь создать простой пользовательский регистр /login api, используя Koa 2 и паспорт.

Проблема при попытке входа в систему.

Вот код для маршрута;

import {
authEmail,
generateToken
} from '../../auth';

import User from '../../models/user';

export default (router) => {
router.post('/auth/email', authEmail(), generateToken());
router.post('/auth/register', register, generateToken());
};

async function register(ctx, next) {
const { name, email, password } = ctx.request.body;

// TODO - improve validation
if (name && email && password) {
let user = await User.findOne({ email });

if (!user) {
user = new User({
name,
email
});
user.password = user.generateHash(password);
await user.save();

ctx.passport = {
user: user._id,
};

console.log(ctx.passport)

await next();

} else {
ctx.status = 400;
ctx.body = { status: 'error', message: 'E-mail already registered' };
}
} else {
ctx.status = 400;
ctx.body = { status: 'error', message: 'Invalid email or password' };
}
}

Вот функции authEmail() + GenerateToken;

export function authEmail() {
return passport.authenticate('email');
}

/** After autentication using one of the strategies, generate a JWT token */
export function generateToken() {
return async ctx => {
console.log('generating token....')
console.log(ctx.passport)
const { user } = ctx.passport;
if (user === false) {
ctx.status = 401;
} else {
const _token = jwt.sign({id: user}, config.secret);
const token = 'JWT ${_token}';

const currentUser = await User.findOne({_id: user});

ctx.status = 200;
ctx.body = {
token,
user: currentUser,
};
}
};
}

и, наконец, стратегия отправки паспорта:

import User from '../../models/user';
import { Strategy as CustomStrategy } from 'passport-custom';

export default new CustomStrategy(async(ctx, done) => {
console.log('Email Strategy: ', ctx.body);
try {
/** Test whether is a login using email and password */
if (ctx.body.email && ctx.body.password) {
const user = await User.findOne({ email: ctx.body.email.toLowerCase() });

if (!user) { done(null, false, {'message': 'User not found.'}); }
const password = ctx.body.password;
if (!user.validPassword(password))
return done(null, false, {'message': 'Password not correct.'});

done(null, user);

} else {
done(null, false, {'message': 'Email and Password are required.'});
}
} catch (error) {
done(error);
}
});

При попытке запустить пост-запрос /auth/email я получаю следующую ошибку;

генерирующий токен....
не определено
xxx POST/api/auth/email 500 124ms
TypeError: Невозможно прочитать свойство 'user' undefined...

Это первый раз, когда я использую koa и паспорт, поэтому я пытался очистить репозиторий github, который я нашел. (https://github.com/zombiQWERTY/koa2-starter-kit), и код в основном адаптирован здесь.

Любые советы о том, что может быть проблемой, очень ценятся, и если вам нужна дополнительная информация/хотите, чтобы я делил другие части кода сервера, пожалуйста, дайте мне знать.

РЕДАКТИРОВАТЬ:

Вот трассировка стека:

   TypeError: Cannot read property 'user' of undefined
at _callee2$ (C:\api/app/auth/index.js:45:12)
at tryCatch (C:\api\node_modules\regenerator-runtime\runtime.js:65:40)
at Generator.invoke [as _invoke] (C:\api\node_modules\regenerator-runtime\runtime.js:303:22)
at Generator.prototype.(anonymous function) [as next] (C:\api\node_modules\regenerator-runtime\runtime.js:117:21)
at step (C:\api\app\auth\index.js:39:191)
at C:\api\app\auth\index.js:39:437
at Promise (<anonymous>)
at C:\api\app\auth\index.js:39:99
at C:\api/app/auth/index.js:45:5
at dispatch (C:\api\node_modules\koa-router\node_modules\koa-compose\index.js:44:32)
at next (C:\api\node_modules\koa-router\node_modules\koa-compose\index.js:45:18)
at p.then.cont (C:\api\node_modules\koa-passport\lib\framework\koa.js:144:16)
at <anonymous>
at process._tickDomainCallback (internal/process/next_tick.js:208:7)

Загрузил текущий код в репо: https://github.com/alexc101/koa-api

спросил(а) 2017-07-04T13:28:00+03:00 3 года, 3 месяца назад
1
Решение
81

Согласно документам koa-passport pass, с v3, вы должны сохранить своего пользователя в ctx.state.user вместо ctx.passport.user.

https://github.com/rkusa/koa-passport

Я снял ваше репо и изменил все ссылки ctx.passport на ctx.state а маршрут /email дал 200 сейчас.

ответил(а) 2017-07-04T23:54:00+03:00 3 года, 3 месяца назад
Ваш ответ
Введите минимум 50 символов
Чтобы , пожалуйста,
Выберите тему жалобы:

Другая проблема