Add blacklist function
This commit is contained in:
parent
100fd41713
commit
c9136f8abd
14 changed files with 486 additions and 48 deletions
|
@ -3,6 +3,7 @@
|
|||
let users = require('../lib/models/users');
|
||||
let lists = require('../lib/models/lists');
|
||||
let fields = require('../lib/models/fields');
|
||||
let blacklist = require('../lib/models/blacklist');
|
||||
let subscriptions = require('../lib/models/subscriptions');
|
||||
let tools = require('../lib/tools');
|
||||
let express = require('express');
|
||||
|
@ -326,4 +327,83 @@ router.post('/field/:listId', (req, res) => {
|
|||
});
|
||||
});
|
||||
|
||||
router.post('/blacklist/add', (req, res) => {
|
||||
let input = {};
|
||||
Object.keys(req.body).forEach(key => {
|
||||
input[(key || '').toString().trim().toUpperCase()] = (req.body[key] || '').toString().trim();
|
||||
});
|
||||
if (!(input.EMAIL) || (input.EMAIL === '')) {
|
||||
res.status(500);
|
||||
return res.json({
|
||||
error: 'EMAIL argument are required',
|
||||
data: []
|
||||
});
|
||||
}
|
||||
blacklist.add(input.EMAIL, (err) =>{
|
||||
if (err) {
|
||||
res.status(500);
|
||||
return res.json({
|
||||
error: err.message || err,
|
||||
data: []
|
||||
});
|
||||
}
|
||||
res.status(200);
|
||||
res.json({
|
||||
data: []
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
router.post('/blacklist/delete', (req, res) => {
|
||||
let input = {};
|
||||
Object.keys(req.body).forEach(key => {
|
||||
input[(key || '').toString().trim().toUpperCase()] = (req.body[key] || '').toString().trim();
|
||||
});
|
||||
if (!(input.EMAIL) || (input.EMAIL === '')) {
|
||||
res.status(500);
|
||||
return res.json({
|
||||
error: 'EMAIL argument are required',
|
||||
data: []
|
||||
});
|
||||
}
|
||||
blacklist.delete(input.EMAIL, (err) =>{
|
||||
if (err) {
|
||||
res.status(500);
|
||||
return res.json({
|
||||
error: err.message || err,
|
||||
data: []
|
||||
});
|
||||
}
|
||||
res.status(200);
|
||||
res.json({
|
||||
data: []
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
router.get('/blacklist/get', (req, res) => {
|
||||
let start = parseInt(req.query.start || 0, 10);
|
||||
let limit = parseInt(req.query.limit || 10000, 10);
|
||||
let search = req.query.search || '';
|
||||
|
||||
blacklist.get(start, limit, search, (err, data, total) => {
|
||||
if (err) {
|
||||
res.status(500);
|
||||
return res.json({
|
||||
error: err.message || err,
|
||||
data: []
|
||||
});
|
||||
}
|
||||
res.status(200);
|
||||
res.json({
|
||||
data: {
|
||||
total: total,
|
||||
start: start,
|
||||
limit: limit,
|
||||
emails: data
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
module.exports = router;
|
||||
|
|
68
routes/blacklist.js
Normal file
68
routes/blacklist.js
Normal file
|
@ -0,0 +1,68 @@
|
|||
'use strict';
|
||||
let express = require('express');
|
||||
let router = new express.Router();
|
||||
let passport = require('../lib/passport');
|
||||
let htmlescape = require('escape-html');
|
||||
let blacklist = require('../lib/models/blacklist');
|
||||
let tools = require('../lib/tools');
|
||||
let helpers = require('../lib/helpers');
|
||||
let _ = require('../lib/translate')._;
|
||||
|
||||
router.all('/*', (req, res, next) => {
|
||||
if (!req.user) {
|
||||
req.flash('danger', _('Need to be logged in to access restricted content'));
|
||||
return res.redirect('/users/login?next=' + encodeURIComponent(req.originalUrl));
|
||||
}
|
||||
res.setSelectedMenu('blacklist');
|
||||
next();
|
||||
});
|
||||
|
||||
router.get('/', passport.csrfProtection, (req, res) => {
|
||||
res.render('blacklist', {csrfToken: req.csrfToken()});
|
||||
});
|
||||
|
||||
router.post('/ajax/', (req, res) => {
|
||||
let start = parseInt(req.body.start || 0, 10);
|
||||
let limit = parseInt(req.body.length || 50, 10);
|
||||
let search = req.body.search.value || '';
|
||||
blacklist.get(start, limit, search, (err, data, total) => {
|
||||
if (err) {
|
||||
req.flash('danger', err.message || err);
|
||||
return res.redirect('/');
|
||||
}
|
||||
res.json({
|
||||
draw: req.body.draw,
|
||||
recordsTotal: total,
|
||||
recordsFiltered: total,
|
||||
data: data.map((row, i) => [
|
||||
(Number(req.body.start) || 0) + 1 + i,
|
||||
htmlescape(row),
|
||||
'<button class="btn btn-danger btn-sm" onclick="document.getElementById(\'delete-email-input\').value = \'' + row + '\'; document.getElementById(\'delete-email-form\').submit();">Delete</button>'
|
||||
])
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
router.post('/ajax/add', passport.csrfProtection, (req, res) => {
|
||||
let email = req.body.email;
|
||||
blacklist.add(email, (err) => {
|
||||
if (err) {
|
||||
req.flash('danger', err.message || err);
|
||||
return res.redirect(req.body.next);
|
||||
}
|
||||
return res.redirect(req.body.next)
|
||||
});
|
||||
});
|
||||
|
||||
router.post('/ajax/delete', passport.csrfProtection, (req, res) => {
|
||||
let email = req.body.email;
|
||||
blacklist.delete(email, (err) => {
|
||||
if (err) {
|
||||
req.flash('danger', err.message || err);
|
||||
return res.redirect(req.body.next);
|
||||
}
|
||||
return res.redirect(req.body.next);
|
||||
});
|
||||
});
|
||||
|
||||
module.exports = router;
|
|
@ -425,6 +425,9 @@ router.get('/status/:id/:status', passport.csrfProtection, (req, res) => {
|
|||
case 'complained':
|
||||
status = 4;
|
||||
break;
|
||||
case 'blacklisted':
|
||||
status = 5;
|
||||
break;
|
||||
default:
|
||||
req.flash('danger', _('Unknown status selector'));
|
||||
return res.redirect('/campaigns');
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue