2017-05-30 06:06:14 +00:00
|
|
|
var express = require('express');
|
|
|
|
var router = new express.Router();
|
2017-06-12 11:41:02 +00:00
|
|
|
var mail = require('../mail.js');
|
2017-08-31 14:11:37 +00:00
|
|
|
var database = require('../database.js');
|
2017-06-12 11:41:02 +00:00
|
|
|
|
2017-08-31 14:11:37 +00:00
|
|
|
// Single user notification
|
|
|
|
router.post('/:recipient/noticeUserSend', function(request, response) {
|
|
|
|
var params = {
|
|
|
|
recipient: request.params.recipient,
|
|
|
|
sender: request.body.sender,
|
|
|
|
category: request.body.category,
|
|
|
|
message: request.body.message
|
|
|
|
};
|
2017-06-12 11:41:02 +00:00
|
|
|
|
2017-08-31 14:11:37 +00:00
|
|
|
if (params.sender == params.recipient)
|
|
|
|
return;
|
|
|
|
|
|
|
|
let query = `SELECT COUNT(*) isEnabled
|
|
|
|
FROM noticeSubscription s
|
|
|
|
JOIN noticeCategory c ON c.id = s.noticeCategoryFk AND c.isEnabled
|
|
|
|
WHERE c.keyName = ? AND s.userFk = ?`;
|
|
|
|
|
|
|
|
database.pool.query(query, [params.category, params.recipient, params.sender], (error, result) => {
|
|
|
|
mail.sendWithTemplate('notice', params, result => {
|
|
|
|
return response.json(result);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// Send notification to all user subscribed to category
|
|
|
|
router.post('/:category/noticeCategorySend', function(request, response) {
|
|
|
|
var params = {
|
|
|
|
sender: request.body.sender,
|
|
|
|
category: request.params.category,
|
|
|
|
message: request.body.message
|
|
|
|
};
|
|
|
|
|
|
|
|
let query = `SELECT s.userFk id FROM noticeSubscription s JOIN noticeCategory
|
|
|
|
c ON c.id = s.noticeCategoryFk AND c.isEnabled WHERE c.keyName = ? AND s.userFk != ?`;
|
|
|
|
|
|
|
|
database.pool.query(query, [params.category, params.sender], (error, result) => {
|
|
|
|
result.forEach(function(user) {
|
|
|
|
params.recipient = user.id;
|
|
|
|
|
|
|
|
mail.sendWithTemplate('notice', params, result => {
|
|
|
|
return response.json(result);
|
|
|
|
});
|
|
|
|
}, this);
|
|
|
|
});
|
2017-08-30 12:50:46 +00:00
|
|
|
});
|
2017-06-12 11:41:02 +00:00
|
|
|
|
2017-08-31 14:11:37 +00:00
|
|
|
// Send system notification
|
|
|
|
router.post('/:recipient/noticeSystemSend', function(request, response) {
|
|
|
|
var params = {
|
|
|
|
recipient: request.params.recipient,
|
|
|
|
sender: 50069, // verdnatura
|
|
|
|
category: request.body.category,
|
|
|
|
message: request.body.message
|
|
|
|
};
|
|
|
|
|
|
|
|
mail.sendWithTemplate('notice', params, result => {
|
|
|
|
return response.json(result);
|
|
|
|
});
|
2017-05-30 06:06:14 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = router;
|