fixed problem with then catch chain (Promise)...
This commit is contained in:
@@ -88,6 +88,7 @@ router.get('/:username', (req, res) => {
|
||||
router.post('/login', (req, res) => {
|
||||
var body = _.pick(req.body, ['username', 'password', 'idapp', 'keyappid', 'lang']);
|
||||
var user = new User(body);
|
||||
const subs = _.pick(req.body, ['subs']);
|
||||
|
||||
tools.mylog("LOGIN: username: " + user.username + " pwd = " + user.password);
|
||||
|
||||
@@ -104,9 +105,9 @@ router.post('/login', (req, res) => {
|
||||
tools.mylogshow("NOT FOUND !");
|
||||
res.status(404).send({ code: server_constants.RIS_CODE_LOGIN_ERR });
|
||||
}
|
||||
return user
|
||||
})
|
||||
.then(user => {
|
||||
let mytoken = '';
|
||||
return user.generateAuthToken(req).then((token) => {
|
||||
var usertosend = User();
|
||||
usertosend.username = user.username;
|
||||
@@ -119,47 +120,50 @@ router.post('/login', (req, res) => {
|
||||
|
||||
// tools.mylog("usertosend:");
|
||||
// tools.mylog(usertosend);
|
||||
return usertosend
|
||||
return { usertosend, token }
|
||||
})
|
||||
.then((usertosend) => {
|
||||
.then((myris) => {
|
||||
const useragent = req.get('User-Agent');
|
||||
const access = 'auth ' + useragent;
|
||||
// if (usertosend.tokens.length > 0)
|
||||
// access = usertosend.tokens[usertosend.tokens.length - 1].access;
|
||||
return existSubScribe(myris.usertosend.userId, access).then(subscribe => {
|
||||
let subscriptionModel = null;
|
||||
if (subscribe === null) {
|
||||
// Doesn't exist, so save sub passed in INPUT
|
||||
subscriptionModel = new Subscription(subs);
|
||||
subscriptionModel.userId = myris.usertosend.userId;
|
||||
subscriptionModel.access = access;
|
||||
|
||||
return existSubScribe(usertosend.userId, access)
|
||||
.then(subscribe => {
|
||||
if (subscribe === null) {
|
||||
// Doesn't exist, so save sub passed in INPUT
|
||||
let subscriptionModel = new Subscription(req.body.subs);
|
||||
subscriptionModel.userId = usertosend._id;
|
||||
subscriptionModel.access = access;
|
||||
}
|
||||
return {usertosend: myris.usertosend, token: myris.token, subscriptionModel }
|
||||
}).then(myris => {
|
||||
if (myris.subscriptionModel !== null) {
|
||||
return myris.subscriptionModel.save().then((err, subscription) => {
|
||||
if (err) {
|
||||
console.error(`Error occurred while saving subscription. Err: ${err}`);
|
||||
res.status(500).json({
|
||||
error: 'Technical error occurred'
|
||||
});
|
||||
} else {
|
||||
// Send 201 - resource created
|
||||
// res.status(201).json({ data: 'Subscription saved.' });
|
||||
// res.send({ data: 'Subscription saved.' });
|
||||
|
||||
return subscriptionModel.save((err, subscription) => {
|
||||
if (err) {
|
||||
console.error(`Error occurred while saving subscription. Err: ${err}`);
|
||||
res.status(500).json({
|
||||
error: 'Technical error occurred'
|
||||
});
|
||||
} else {
|
||||
// Send 201 - resource created
|
||||
// res.status(201).json({ data: 'Subscription saved.' });
|
||||
// res.send({ data: 'Subscription saved.' });
|
||||
tools.sendBackNotif(subscription, req.body.options)
|
||||
}
|
||||
return { usertosend: myris.usertosend, token: myris.token }
|
||||
});
|
||||
} else {
|
||||
return { usertosend: myris.usertosend, token: myris.token }
|
||||
}
|
||||
}).catch(e => {
|
||||
console.log('Err subscribing:', e);
|
||||
})
|
||||
}).then(myris => {
|
||||
console.log('res', myris.token, myris.usertosend);
|
||||
|
||||
tools.sendBackNotif(subscription, req.body.options)
|
||||
}
|
||||
|
||||
return { usertosend }
|
||||
});
|
||||
} else {
|
||||
return { usertosend }
|
||||
}
|
||||
});
|
||||
})
|
||||
.then((usertosend) => {
|
||||
console.log('res', mytoken, usertosend);
|
||||
|
||||
res.header('x-auth', mytoken).send({ usertosend, code: server_constants.RIS_CODE_OK });
|
||||
res.header('x-auth', myris.token).send({ usertosend: myris.usertosend, code: server_constants.RIS_CODE_OK });
|
||||
// tools.mylog("TROVATOOO!");
|
||||
|
||||
tools.mylog('FINE LOGIN')
|
||||
|
||||
Reference in New Issue
Block a user