'use strict'; exports = module.exports = { login: login }; var developer = require('../developer.js'), passport = require('passport'), HttpError = require('connect-lastmile').HttpError, HttpSuccess = require('connect-lastmile').HttpSuccess; function auditSource(req) { var ip = req.headers['x-forwarded-for'] || req.connection.remoteAddress || null; return { ip: ip, username: req.user ? req.user.username : null, userId: req.user ? req.user.id : null }; } function login(req, res, next) { passport.authenticate('local', function (error, user) { if (error) return next(new HttpError(500, error)); if (!user) return next(new HttpError(401, 'Invalid credentials')); developer.issueDeveloperToken(user, auditSource(req), function (error, result) { if (error) return next(new HttpError(500, error)); next(new HttpSuccess(200, { token: result.token, expiresAt: result.expiresAt })); }); })(req, res, next); }