Files
freeplanet_serverside/server/router/users_router.js

173 lines
4.9 KiB
JavaScript
Raw Normal View History

2019-02-05 03:40:22 +01:00
const express = require('express');
const router = express.Router();
var { User } = require('../models/user');
2019-02-06 18:48:32 +01:00
var sendemail = require('../sendemail');
const tools = require('../tools/general');
2019-02-06 18:48:32 +01:00
var server_constants = require('../tools/server_constants');
2019-02-05 03:40:22 +01:00
const _ = require('lodash');
2019-02-06 18:48:32 +01:00
var reg = require('../reg/registration');
2019-02-05 03:40:22 +01:00
var { authenticate } = require('../middleware/authenticate');
var mongoose = require('mongoose');
const Subscription = mongoose.model('subscribers');
function existSubScribe(userId, access, browser) {
return Subscription.findOne({ userId, access, browser })
.then(itemsub => {
return itemsub
})
.catch(err => {
return null
})
}
2019-02-05 03:40:22 +01:00
// POST /users
router.post('/', (req, res) => {
tools.mylog("POST /users");
2019-02-05 03:40:22 +01:00
var body = _.pick(req.body, ['email', 'password', 'username', 'idapp', 'keyappid', 'lang']);
var user = new User(body);
// tools.mylog("LANG PASSATO = " + user.lang, "IDAPP", user.idapp);
2019-02-05 03:40:22 +01:00
user.linkreg = reg.getlinkregByEmail(body.email, body.username);
user.verified_email = false;
if (tools.testing()) {
2019-02-06 18:48:32 +01:00
user.verified_email = true;
}
2019-02-05 03:40:22 +01:00
user.save().then(() => {
User.findByUsername(user.username)
.then((usertrovato) => {
2019-02-06 18:48:32 +01:00
tools.mylog("TROVATO USERNAME ? ", user.username, usertrovato);
2019-02-05 03:40:22 +01:00
if (usertrovato !== null) {
return user.generateAuthToken(req);
2019-02-05 03:40:22 +01:00
} else {
res.status(11100).send();
return 0;
}
}).then((token) => {
// tools.mylog("passo il TOKEN: ", token);
2019-02-05 03:40:22 +01:00
res.header('x-auth', token).send(user);
// tools.mylog("LINKREG = " + user.linkreg);
2019-02-05 03:40:22 +01:00
// Invia un'email all'utente
// tools.mylog('process.env.TESTING_ON', process.env.TESTING_ON);
console.log('res.locale', res.locale);
if (!tools.testing()) {
sendemail.sendEmail_Registration(user.lang, user.email, user.username, user.idapp, user.linkreg);
2019-02-06 18:48:32 +01:00
}
2019-02-05 03:40:22 +01:00
});
}).catch((e) => {
res.status(400).send(e);
})
});
router.get('/:username', (req, res) => {
var username = req.params.username;
User.findByUsername(username).then((user) => {
if (!user) {
return res.status(404).send();
}
res.status(200).send();
}).catch((e) => {
res.status(400).send();
});
});
router.post('/login', (req, res) => {
var body = _.pick(req.body, ['username', 'password', 'idapp', 'keyappid', 'lang']);
var user = new User(body);
2019-02-13 18:47:58 +01:00
// const subs = _.pick(req.body, ['subs']);
2019-02-05 03:40:22 +01:00
tools.mylog("LOGIN: username: " + user.username + " pwd = " + user.password);
2019-02-06 18:48:32 +01:00
tools.mylog("user REC:", user);
2019-02-05 03:40:22 +01:00
if (body.keyappid !== process.env.KEY_APP_ID)
return res.status(400).send();
2019-02-13 18:47:58 +01:00
let resalreadysent = false;
2019-02-05 03:40:22 +01:00
User.findByCredentials(user.username, user.password)
.then((user) => {
tools.mylog("CREDENZIALI ! ");
2019-02-05 03:40:22 +01:00
if (!user) {
tools.mylogshow("NOT FOUND !");
2019-02-05 03:40:22 +01:00
res.status(404).send({ code: server_constants.RIS_CODE_LOGIN_ERR });
}
return user
})
.then(user => {
2019-02-13 18:47:58 +01:00
if (user) {
return user.generateAuthToken(req).then((token) => {
var usertosend = User();
usertosend.username = user.username;
usertosend.email = user.email;
usertosend.userId = user._id.toHexString();
usertosend.verified_email = user.verified_email;
// tools.mylog("user.verified_email:" + user.verified_email);
tools.mylog("usertosend.userId", usertosend.userId);
// tools.mylog("usertosend:");
// tools.mylog(usertosend);
return { usertosend, token }
})
2019-02-13 18:47:58 +01:00
.then((myris) => {
const access = 'auth';
const browser = req.get('User-Agent');
2019-02-13 18:47:58 +01:00
// Check if already exist Subscribe
return existSubScribe(myris.usertosend.userId, access, browser).then(subscribe => {
2019-02-13 18:47:58 +01:00
return (subscribe !== null)
}).then(subsExistonDb => {
return { usertosend: myris.usertosend, token: myris.token, subsExistonDb }
}).catch(err => {
return { usertosend: myris.usertosend, token: myris.token, subsExistonDb:false }
})
}).then(myris => {
console.log('res', myris.token, myris.usertosend);
2019-02-13 18:47:58 +01:00
// SEND TOKEN AND CODE RESULT
res.header('x-auth', myris.token).send({
usertosend: myris.usertosend,
code: server_constants.RIS_CODE_OK,
subsExistonDb: myris.subsExistonDb
});
// tools.mylog("TROVATOOO!");
tools.mylog('FINE LOGIN')
2019-02-05 03:40:22 +01:00
});
2019-02-13 18:47:58 +01:00
}
})
.catch((e) => {
tools.mylog("ERRORE IN LOGIN: " + e);
2019-02-13 18:47:58 +01:00
if (!resalreadysent)
res.status(400).send({ code: server_constants.RIS_CODE_LOGIN_ERR_GENERIC });
});
2019-02-05 03:40:22 +01:00
});
router.delete('/me/token', authenticate, (req, res) => {
tools.mylog("TOKENREM = " + req.token);
2019-02-05 03:40:22 +01:00
req.user.removeToken(req.token).then(() => {
res.status(200).send();
}, () => {
res.status(400).send();
});
});
module.exports = router;