Notifiche - Tutti - non letti
This commit is contained in:
@@ -14,7 +14,7 @@ const sendemail = require('../sendemail');
|
||||
|
||||
const _ = require('lodash');
|
||||
|
||||
const sendNotif = async (res, idapp, user, recbooking) => {
|
||||
const sendNotifBooking = async (res, idapp, user, recbooking) => {
|
||||
//++Todo: tools.sendNotificationToUser
|
||||
|
||||
// Send Email
|
||||
@@ -50,7 +50,7 @@ router.post('/', authenticate, (req, res) => {
|
||||
}).then((recbooking) => {
|
||||
// tools.mylog('booking:', booking);
|
||||
// tools.mylog('already exist');
|
||||
sendNotif(res, myrec.idapp, req.user, myrec);
|
||||
sendNotifBooking(res, myrec.idapp, req.user, myrec);
|
||||
return res.send({ code: server_constants.RIS_CODE_OK, msg: '', id });
|
||||
});
|
||||
} else {
|
||||
@@ -62,7 +62,7 @@ router.post('/', authenticate, (req, res) => {
|
||||
|
||||
Booking.findById(idobj)
|
||||
.then((recbooking) => {
|
||||
sendNotif(res, myrec.idapp, req.user, writeresult);
|
||||
sendNotifBooking(res, myrec.idapp, req.user, writeresult);
|
||||
return res.send({ code: server_constants.RIS_CODE_OK, msg: '', id: writeresult._id });
|
||||
});
|
||||
});
|
||||
@@ -86,7 +86,7 @@ router.delete('/:id/:notify/:idapp', authenticate, (req, res) => {
|
||||
|
||||
if (notify === '1') {
|
||||
recbooking.booked = false;
|
||||
sendNotif(res, idapp, req.user, recbooking);
|
||||
sendNotifBooking(res, idapp, req.user, recbooking);
|
||||
}
|
||||
|
||||
tools.mylog('DELETED ', recbooking._id);
|
||||
|
||||
@@ -4,14 +4,16 @@ const router = express.Router();
|
||||
const tools = require('../tools/general');
|
||||
const server_constants = require('../tools/server_constants');
|
||||
|
||||
const { authenticate } = require('../middleware/authenticate');
|
||||
const {authenticate} = require('../middleware/authenticate');
|
||||
|
||||
const { MyEvent } = require('../models/myevent');
|
||||
const {MyEvent} = require('../models/myevent');
|
||||
|
||||
const { ObjectID } = require('mongodb');
|
||||
const {ObjectID} = require('mongodb');
|
||||
|
||||
const sendemail = require('../sendemail');
|
||||
|
||||
const globalTables = require('../tools/globalTables');
|
||||
|
||||
const _ = require('lodash');
|
||||
|
||||
router.post('/', authenticate, (req, res) => {
|
||||
@@ -29,36 +31,34 @@ router.post('/', authenticate, (req, res) => {
|
||||
if (check.exit) return check.ret;
|
||||
|
||||
// Modify:
|
||||
return MyEvent.findOne({ id })
|
||||
.then((trovato) => {
|
||||
// console.log('trovato', trovato);
|
||||
if (trovato) {
|
||||
return myevent.findOneAndUpdate({ id }, { $set: fieldtochange }, {
|
||||
new: false,
|
||||
upsert: true
|
||||
}).then((recmyevent) => {
|
||||
// tools.mylog('myevent:', myevent);
|
||||
// tools.mylog('already exist');
|
||||
sendNotif(res, myrec.idapp, req.user, recmyevent);
|
||||
return res
|
||||
}).then((res) => {
|
||||
res.send({ code: server_constants.RIS_CODE_OK, msg: '', id: recmyevent._id });
|
||||
});
|
||||
} else {
|
||||
// save to database a new record
|
||||
tools.mylog('save to database a new record');
|
||||
myevent._id = new ObjectID();
|
||||
return myevent.save().then((writeresult) => {
|
||||
let idobj = writeresult._id;
|
||||
return MyEvent.findOne({id}).then((trovato) => {
|
||||
// console.log('trovato', trovato);
|
||||
if (trovato) {
|
||||
return myevent.findOneAndUpdate({id}, {$set: fieldtochange}, {
|
||||
new: false,
|
||||
upsert: true,
|
||||
}).then((recmyevent) => {
|
||||
// tools.mylog('myevent:', myevent);
|
||||
// tools.mylog('already exist');
|
||||
globalTables.sendNotif(res, myrec.idapp, req.user, recmyevent);
|
||||
return res;
|
||||
}).then((res) => {
|
||||
res.send({code: server_constants.RIS_CODE_OK, msg: '', id: recmyevent._id});
|
||||
});
|
||||
} else {
|
||||
// save to database a new record
|
||||
tools.mylog('save to database a new record');
|
||||
myevent._id = new ObjectID();
|
||||
return myevent.save().then((writeresult) => {
|
||||
let idobj = writeresult._id;
|
||||
|
||||
myevent.findById(idobj)
|
||||
.then((recmyevent) => {
|
||||
sendNotif(res, myrec.idapp, req.user, recmyevent);
|
||||
res.send({ code: server_constants.RIS_CODE_OK, msg: '', id: recmyevent._id });
|
||||
});
|
||||
myevent.findById(idobj).then((recmyevent) => {
|
||||
globalTables.sendNotif(res, myrec.idapp, req.user, recmyevent);
|
||||
res.send({code: server_constants.RIS_CODE_OK, msg: '', id: recmyevent._id});
|
||||
});
|
||||
}
|
||||
})
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
router.delete('/:id/:notify/:idapp', authenticate, (req, res) => {
|
||||
@@ -73,18 +73,17 @@ router.delete('/:id/:notify/:idapp', authenticate, (req, res) => {
|
||||
}
|
||||
|
||||
if (notify === '1')
|
||||
sendNotif(res, idapp, req.user, recmyevent);
|
||||
globalTables.sendNotif(res, idapp, req.user, recmyevent);
|
||||
|
||||
tools.mylog('DELETED ', recmyevent.descr, recmyevent._id);
|
||||
|
||||
res.send({ code: server_constants.RIS_CODE_OK, msg: '', id: recmyevent._id });
|
||||
res.send({code: server_constants.RIS_CODE_OK, msg: '', id: recmyevent._id});
|
||||
|
||||
}).catch((e) => {
|
||||
res.status(400).send();
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
router.get('/:userId/:idapp/:sall', authenticate, (req, res) => {
|
||||
const userId = req.params.userId;
|
||||
const idapp = req.params.idapp;
|
||||
@@ -99,12 +98,12 @@ router.get('/:userId/:idapp/:sall', authenticate, (req, res) => {
|
||||
|
||||
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 });
|
||||
return res.status(404).send({code: server_constants.RIS_CODE_TODO_CREATING_NOTMYUSER});
|
||||
}
|
||||
|
||||
// Extract all the todos of the userId only
|
||||
return MyEvent.findAllByUserIdAndIdApp(userId, idapp, sall).then((recevent) => {
|
||||
res.send({ recevent });
|
||||
res.send({recevent});
|
||||
}).catch((e) => {
|
||||
console.log(e.message);
|
||||
res.status(400).send(e);
|
||||
@@ -112,5 +111,4 @@ router.get('/:userId/:idapp/:sall', authenticate, (req, res) => {
|
||||
|
||||
});
|
||||
|
||||
|
||||
module.exports = router;
|
||||
|
||||
@@ -131,16 +131,12 @@ router.post('/send', authenticate, async (req, res) => {
|
||||
}
|
||||
|
||||
try {
|
||||
if (params.typesend === 0)
|
||||
params.typesend = shared_consts.TypeSend.PUSH_NOTIFICATION;
|
||||
|
||||
if (params.typemsg === shared_consts.TypeMsg.SEND_TO_MYSELF) {
|
||||
params.usernameDest = req.user.username;
|
||||
}
|
||||
|
||||
const ris = await globalTables.SendMsgToParam(idapp, params);
|
||||
|
||||
|
||||
return res.send({
|
||||
code: server_constants.RIS_CODE_OK,
|
||||
msg: ris.nummsgsent + ` Msg ${msgcosa} su ` + ris.numrec + ' !',
|
||||
|
||||
@@ -16,36 +16,10 @@ const sendemail = require('../sendemail');
|
||||
|
||||
const shared_consts = require('../tools/shared_nodejs');
|
||||
|
||||
const globalTables = require('../tools/globalTables');
|
||||
|
||||
const _ = require('lodash');
|
||||
|
||||
function checkifSendPushNotification() {
|
||||
return process.env.ENABLE_PUSHNOTIFICATION === "1";
|
||||
//return false;
|
||||
}
|
||||
|
||||
|
||||
async function sendNotif(res, idapp, user, recmsg) {
|
||||
if (tools.isBitActive(recmsg.options, shared_consts.MessageOptions.Notify_ByPushNotification)) {
|
||||
if (this.checkifSendPushNotification) {
|
||||
console.log('SEND PUSH NOTIFICATION ')
|
||||
//++Todo: tools.sendNotificationToUser
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
// Read from the operator table first
|
||||
let emaildest = await Operator.getEmailByUsername(recmsg.dest.idapp, recmsg.dest.username);
|
||||
if (!emaildest)
|
||||
emaildest = await User.getEmailByUsername(recmsg.dest.idapp, recmsg.dest.username);
|
||||
|
||||
console.log('emaildest', emaildest);
|
||||
|
||||
// Send Msg by EMAIL
|
||||
if (emaildest && tools.isBitActive(recmsg.options, shared_consts.MessageOptions.Notify_ByEmail))
|
||||
await sendemail.sendEmail_Msg(res, user.lang, emaildest, user, idapp, recmsg);
|
||||
|
||||
return true
|
||||
}
|
||||
|
||||
router.post('/', authenticate, (req, res) => {
|
||||
tools.mylog('INIZIO - SendMsg');
|
||||
@@ -72,7 +46,7 @@ router.post('/', authenticate, (req, res) => {
|
||||
// Add this field because I don't want to add into the database
|
||||
recmsg.source.infoevent = body.source.infoevent;
|
||||
|
||||
return await sendNotif(res, body.idapp, req.user, recmsg).then((ris) => {
|
||||
return await globalTables.sendNotif(res, body.idapp, req.user, recmsg).then((ris) => {
|
||||
return res.send({ code: server_constants.RIS_CODE_OK, msg: '', id: recmsg._id });
|
||||
})
|
||||
});
|
||||
|
||||
@@ -4,13 +4,13 @@ const router = express.Router();
|
||||
const tools = require('../tools/general');
|
||||
const server_constants = require('../tools/server_constants');
|
||||
|
||||
const { authenticate } = require('../middleware/authenticate');
|
||||
const {authenticate} = require('../middleware/authenticate');
|
||||
|
||||
const { User } = require('../models/user');
|
||||
const { Operator } = require('../models/operator');
|
||||
const { SendNotif } = require('../models/sendnotif');
|
||||
const {User} = require('../models/user');
|
||||
const {Operator} = require('../models/operator');
|
||||
const {SendNotif} = require('../models/sendnotif');
|
||||
|
||||
const { ObjectID } = require('mongodb');
|
||||
const {ObjectID} = require('mongodb');
|
||||
|
||||
const sendemail = require('../sendemail');
|
||||
|
||||
@@ -18,33 +18,6 @@ const shared_consts = require('../tools/shared_nodejs');
|
||||
|
||||
const _ = require('lodash');
|
||||
|
||||
|
||||
async function sendNotif(res, idapp, user, recnotif) {
|
||||
// Controlla nelle impostazioni che tipo di Notifica visualizzare
|
||||
|
||||
|
||||
if (tools.isBitActive(recnotif.options, shared_consts.MessageOptions.Notify_ByPushNotification)) {
|
||||
if (this.checkifSendPushNotification) {
|
||||
console.log('SEND PUSH NOTIFICATION ')
|
||||
//++Todo: tools.sendNotificationToUser
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
// Read from the operator table first
|
||||
let emaildest = await Operator.getEmailByUsername(recnotif.dest.idapp, recnotif.dest.username);
|
||||
if (!emaildest)
|
||||
emaildest = await User.getEmailByUsername(recnotif.dest.idapp, recnotif.dest.username);
|
||||
|
||||
console.log('emaildest', emaildest);
|
||||
|
||||
// Send Msg by EMAIL
|
||||
if (emaildest && tools.isBitActive(recnotif.options, shared_consts.MessageOptions.Notify_ByEmail))
|
||||
await sendemail.sendEmail_Msg(res, user.lang, emaildest, user, idapp, recnotif);
|
||||
|
||||
return true
|
||||
}
|
||||
|
||||
router.post('/', authenticate, (req, res) => {
|
||||
tools.mylog('INIZIO - SendNotif');
|
||||
// tools.mylog('req.body', req.body);
|
||||
@@ -59,25 +32,45 @@ router.post('/', authenticate, (req, res) => {
|
||||
// console.log('fieldtochange', fieldtochange);
|
||||
|
||||
myrecnotif._id = new ObjectID();
|
||||
return myrecnotif.save()
|
||||
.then((writeresult) => {
|
||||
let idobj = writeresult._id;
|
||||
return myrecnotif.save().then((writeresult) => {
|
||||
let idobj = writeresult._id;
|
||||
|
||||
myrecnotif._id = idobj;
|
||||
myrecnotif._id = idobj;
|
||||
|
||||
return SendNotif.findById(idobj)
|
||||
.then(async (recnotif) => {
|
||||
// Add this field because I don't want to add into the database
|
||||
return SendNotif.findById(idobj).then(async (recnotif) => {
|
||||
// Add this field because I don't want to add into the database
|
||||
|
||||
return await sendNotif(res, body.idapp, req.user, recnotif).then((ris) => {
|
||||
return res.send({ code: server_constants.RIS_CODE_OK, notif: '', id: recnotif._id });
|
||||
})
|
||||
});
|
||||
}).catch((e) => {
|
||||
console.log(e.message);
|
||||
// res.status(400).send(e);
|
||||
return res.send({ code: server_constants.RIS_CODE_ERR, notif: '' });
|
||||
})
|
||||
return await globalTables.sendNotif(res, body.idapp, req.user, recnotif).then((ris) => {
|
||||
return res.send({code: server_constants.RIS_CODE_OK, notif: '', id: recnotif._id});
|
||||
});
|
||||
});
|
||||
}).catch((e) => {
|
||||
console.log(e.message);
|
||||
// res.status(400).send(e);
|
||||
return res.send({code: server_constants.RIS_CODE_ERR, notif: ''});
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
router.get('/setall/:username/:idapp', authenticate, async (req, res) => {
|
||||
|
||||
const idapp = req.params.idapp;
|
||||
const username = req.params.username;
|
||||
const username_call = req.user.username;
|
||||
|
||||
try {
|
||||
if (username === username_call) {
|
||||
const arrNotifs = await SendNotif.find({idapp, dest: username, read: false}).lean();
|
||||
if (arrNotifs) {
|
||||
for (const rec of arrNotifs) {
|
||||
await SendNotif.setNotifAsRead(idapp, username_call, rec._id);
|
||||
}
|
||||
}
|
||||
res.send(true);
|
||||
}
|
||||
} catch (e) {
|
||||
res.status(400).send(e);
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
@@ -90,15 +83,14 @@ router.get('/:username/:lastdataread/:idapp', authenticate, (req, res) => {
|
||||
|
||||
if (req.user.idapp !== idapp) {
|
||||
// I'm trying to get something not mine!
|
||||
return res.status(404).send({ code: server_constants.RIS_CODE_NOT_MY_USERNAME });
|
||||
return res.status(404).send({code: server_constants.RIS_CODE_NOT_MY_USERNAME});
|
||||
}
|
||||
|
||||
|
||||
// Extract all the todos of the userId only
|
||||
return SendNotif.findAllNotifByUsernameIdAndIdApp(username, lastdataread, idapp).then((arrnotif) => {
|
||||
// const wait = new Promise((resolve, reject) => {
|
||||
// setTimeout(() => {
|
||||
res.send({ arrnotif });
|
||||
res.send({arrnotif});
|
||||
// }, 2000);
|
||||
// });
|
||||
|
||||
@@ -109,5 +101,4 @@ router.get('/:username/:lastdataread/:idapp', authenticate, (req, res) => {
|
||||
|
||||
});
|
||||
|
||||
|
||||
module.exports = router;
|
||||
|
||||
@@ -15,6 +15,8 @@ const sendemail = require('../sendemail');
|
||||
|
||||
const {Settings} = require('../models/settings');
|
||||
|
||||
const {SendNotif} = require('../models/sendnotif');
|
||||
|
||||
const tools = require('../tools/general');
|
||||
const shared_consts = require('../tools/shared_nodejs');
|
||||
|
||||
@@ -377,11 +379,15 @@ router.patch('/:id', authenticate, (req, res) => {
|
||||
|
||||
router.post('/profile', authenticate, (req, res) => {
|
||||
const username = req.body['username'];
|
||||
idapp = req.body.idapp;
|
||||
locale = req.body.locale;
|
||||
const idapp = req.body.idapp;
|
||||
const locale = req.body.locale;
|
||||
const idnotif = req.body['idnotif'] ? req.body['idnotif'] : '';
|
||||
|
||||
//++Todo: controlla che tipo di dati ha il permesso di leggere
|
||||
|
||||
// Check if ìs a Notif to read
|
||||
SendNotif.setNotifAsRead(idapp, username, idnotif);
|
||||
|
||||
try {
|
||||
return User.getUserProfileByUsername(idapp, username, req.user.username,
|
||||
false, req.user.perm).
|
||||
@@ -447,7 +453,7 @@ router.post('/notifs', authenticate, async (req, res) => {
|
||||
|
||||
try {
|
||||
if (!!myuser) {
|
||||
if (notifs) {
|
||||
if (tools.isArray(notifs) && notifs.length >= 0) {
|
||||
myuser.profile.notifs = notifs;
|
||||
myuser.save();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user