- Booking Event (with email to user and admin)

- Cancel Event (with email to user and admin)
- Store into mongodb
This commit is contained in:
Paolo Arena
2019-10-05 20:01:56 +02:00
parent 507f465313
commit 8f69856c57
37 changed files with 758 additions and 46 deletions

View File

@@ -0,0 +1,101 @@
const express = require('express');
const router = express.Router();
const tools = require('../tools/general');
const server_constants = require('../tools/server_constants');
const { authenticate } = require('../middleware/authenticate');
const { Booking } = require('../models/booking');
const { ObjectID } = require('mongodb');
const sendemail = require('../sendemail');
const _ = require('lodash');
function sendNotif(res, idapp, user, recbooking) {
//++Todo: tools.sendNotificationToUser
// Send Email
if (recbooking.booked)
sendemail.sendEmail_Booking(res, user.lang, user.email, user, idapp, recbooking);
else
sendemail.sendEmail_CancelBooking(res, user.lang, user.email, user, idapp, recbooking);
}
router.post('/', authenticate, (req, res) => {
tools.mylog('INIZIO - booking');
// tools.mylog('req.body', req.body);
const body = _.pick(req.body, tools.allfieldBooking());
const id = body.id_bookedevent;
const fieldtochange = _.pick(req.body, tools.allfieldBookingChange());
tools.mylog('crea Booking');
const booking = new Booking(body);
const check = tools.checkUserOk(booking.userId, req.user._id);
if (check.exit) return check.ret;
// console.log('fieldtochange', fieldtochange);
return Booking.findOne({ id_bookedevent: id })
.then(trovato => {
// console.log('trovato', trovato);
if (trovato) {
return Booking.findOneAndUpdate({ id_bookedevent: id }, { $set: fieldtochange }, {
new: true,
upsert: true
}).then((recbooking) => {
// tools.mylog('booking:', booking);
// tools.mylog('already exist');
sendNotif(res, body.idapp, req.user, recbooking);
res.send({ code: server_constants.RIS_CODE_OK, msg: '', id: recbooking._id });
});
} else {
// save to database a new record
tools.mylog('save to database a new record');
booking._id = new ObjectID();
return booking.save().then((writeresult) => {
let idobj = writeresult._id;
Booking.findById(idobj)
.then((recbooking) => {
sendNotif(res, body.idapp, req.user, recbooking);
res.send({ code: server_constants.RIS_CODE_OK, msg: '', id: recbooking._id });
});
});
}
})
});
router.get('/:userId/:idapp', authenticate, (req, res) => {
const userId = req.params.userId;
const idapp = req.params.idapp;
// var category = req.params.category;
tools.mylog('GET BOOKINGS : ', req.params);
if (!ObjectID.isValid(userId)) {
return res.status(404).send();
}
if (userId !== String(req.user._id)) {
// I'm trying to write something not mine!
return res.status(404).send({ code: server_constants.RIS_CODE_TODO_CREATING_NOTMYUSER });
}
// Extract all the todos of the userId only
Booking.findAllByUserIdAndIdApp(userId, idapp).then((bookedevent) => {
res.send({ bookedevent });
}).catch((e) => {
console.log(e);
res.status(400).send(e);
});
});
module.exports = router;

View File

@@ -0,0 +1,73 @@
const server_constants = require('../tools/server_constants');
const express = require('express');
const router = express.Router();
const request = require('superagent');
const newsletter = [
{
name: 'Paolo',
mailchimpInstance: 'us16',
listUniqueId: 'e70fd8ba4c',
mailchimpApiKey: '24d1eb0e4f21dd7c52d47214b0d62cfd-us16'
// CLIENT ID 682712991042
// Client Secret 69c627f5dad15f6072ac4f86f5312a6078c94f72a0902d2f4c
},
{
name: 'Paolo',
mailchimpInstance: 'us16',
listUniqueId: 'e70fd8ba4c',
mailchimpApiKey: '24d1eb0e4f21dd7c52d47214b0d62cfd-us16'
// CLIENT ID 682712991042
// Client Secret 69c627f5dad15f6072ac4f86f5312a6078c94f72a0902d2f4c
},
{
name: 'AssShen',
mailchimpInstance: 'us4',
listUniqueId: '991c0b8321',
mailchimpApiKey: '07dd8b0bd078ae3a79e398656c276bbd-us4'
// CLIENT ID 682712991042
// Client Secret 69c627f5dad15f6072ac4f86f5312a6078c94f72a0902d2f4c
},
{
name: 'AssociazioneShen',
mailchimpInstance: '',
listUniqueId: '',
mailchimpApiKey: ''
}
];
router.post('/', (req, res) => {
idwebsite = req.body.idwebsite;
locale = req.body.locale;
request
.post('https://' + newsletter[idwebsite].mailchimpInstance + '.api.mailchimp.com/3.0/lists/' + newsletter[idwebsite].listUniqueId + '/members/')
.set('Content-Type', 'application/json;charset=utf-8')
.set('Authorization', 'Basic ' + new Buffer('any:' + newsletter[idwebsite].mailchimpApiKey).toString('base64'))
.send({
'email_address': req.body.email,
'status': server_constants.RIS_SUBSCRIBED_STR,
'merge_fields': {
'FNAME': req.body.firstName,
'LNAME': req.body.lastName
}
})
.end(function (err, response) {
console.log("STAT", response.status);
if (response.status < 300 || (response.status === 400 && response.body.title === "Member Exists")) {
if (response.status === 400 && response.body.title === "Member Exists")
res.send({result: server_constants.RIS_SUBSCRIBED_ALREADYEXIST, msg: server_constants.RIS_SUBSCRIBED_MSG_ALREADYEXIST[locale]});
else
res.send({result: server_constants.RIS_SUBSCRIBED_OK, msg: server_constants.RIS_SUBSCRIBED_MSG[locale]});
} else {
res.send({result: server_constants.RIS_SUBSCRIBED_ERR, msg: server_constants.RIS_SUBSCRIBED_MSG_FAILED[locale]});
}
});
});
module.exports = router;

View File

@@ -3,13 +3,13 @@ const router = express.Router();
const tools = require('../tools/general');
var server_constants = require('../tools/server_constants');
const server_constants = require('../tools/server_constants');
var { authenticate } = require('../middleware/authenticate');
const { authenticate } = require('../middleware/authenticate');
// var mongoose = require('mongoose');
var { Project } = require('../models/project');
const { Project } = require('../models/project');
const { Todo } = require('./../models/todo');
const _ = require('lodash');
@@ -31,11 +31,8 @@ router.post('/', authenticate, (req, res) => {
return res.status(400).send({ code: server_constants.RIS_CODE_LOGIN_ERR_GENERIC });
}
if (String(project.userId) !== String(req.user._id)) {
// I'm trying to write something not mine!
tools.mylog('project.userId = ', project.userId, 'req.user._id', req.user._id);
return res.status(404).send({ code: server_constants.RIS_CODE_TODO_CREATING_NOTMYUSER });
}
const check = tools.checkUserOk(project.userId, req.user._id);
if (check.exit) return check.ret;
tools.mylog('PROJECT POST :', project.descr, project._id);

View File

@@ -32,7 +32,7 @@ function existSubScribe(userId, access, browser) {
// POST /users
router.post('/', (req, res) => {
tools.mylog("POST /users");
var body = _.pick(req.body, ['email', 'password', 'username', 'idapp', 'keyappid', 'lang']);
var body = _.pick(req.body, ['email', 'password', 'username', 'name', 'surname', 'idapp', 'keyappid', 'lang']);
var user = new User(body);
// tools.mylog("LANG PASSATO = " + user.lang, "IDAPP", user.idapp);
@@ -63,7 +63,7 @@ router.post('/', (req, res) => {
// 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);
sendemail.sendEmail_Registration(user.lang, user.email, user, user.idapp, user.linkreg);
}
});
@@ -114,6 +114,8 @@ router.post('/login', (req, res) => {
return user.generateAuthToken(req).then((token) => {
var usertosend = User();
usertosend.username = user.username;
usertosend.name = user.name;
usertosend.surname = user.surname;
usertosend.email = user.email;
usertosend.userId = user._id.toHexString();
usertosend.verified_email = user.verified_email;