2016-04-04 12:36:30 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
let links = require('../lib/models/links');
|
2016-04-25 13:19:55 +00:00
|
|
|
let settings = require('../lib/models/settings');
|
|
|
|
let lists = require('../lib/models/lists');
|
|
|
|
let subscriptions = require('../lib/models/subscriptions');
|
|
|
|
let tools = require('../lib/tools');
|
2017-03-07 14:30:56 +00:00
|
|
|
let _ = require('../lib/translate')._;
|
2016-04-04 12:36:30 +00:00
|
|
|
|
|
|
|
let log = require('npmlog');
|
|
|
|
let express = require('express');
|
|
|
|
let router = new express.Router();
|
|
|
|
|
|
|
|
let trackImg = new Buffer('R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7', 'base64');
|
|
|
|
|
|
|
|
router.get('/:campaign/:list/:subscription', (req, res) => {
|
|
|
|
res.writeHead(200, {
|
|
|
|
'Content-Type': 'image/gif',
|
|
|
|
'Content-Length': trackImg.length
|
|
|
|
});
|
|
|
|
|
|
|
|
links.countOpen(req.ip, req.params.campaign, req.params.list, req.params.subscription, (err, opened) => {
|
|
|
|
if (err) {
|
|
|
|
log.error('Redirect', err.stack || err);
|
|
|
|
}
|
|
|
|
if (opened) {
|
|
|
|
log.verbose('Redirect', 'First open for %s:%s:%s', req.params.campaign, req.params.list, req.params.subscription);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
res.end(trackImg);
|
|
|
|
});
|
|
|
|
|
2016-06-09 06:53:38 +00:00
|
|
|
router.get('/:campaign/:list/:subscription/:link', (req, res) => {
|
|
|
|
|
|
|
|
let notFound = () => {
|
|
|
|
res.status(404);
|
|
|
|
return res.render('archive/view', {
|
|
|
|
layout: 'archive/layout',
|
2017-03-07 14:30:56 +00:00
|
|
|
message: _('Oops, we couldn\'t find a link for the URL you clicked'),
|
2016-06-09 06:53:38 +00:00
|
|
|
campaign: {
|
|
|
|
subject: 'Error 404'
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
links.resolve(req.params.link, (err, linkId, url) => {
|
2016-04-04 12:36:30 +00:00
|
|
|
if (err) {
|
|
|
|
req.flash('danger', err.message || err);
|
|
|
|
return res.redirect('/');
|
|
|
|
}
|
2016-06-08 08:16:32 +00:00
|
|
|
if (!linkId || !url) {
|
|
|
|
log.error('Redirect', 'Unresolved URL: <%s>', req.url);
|
2016-06-09 06:53:38 +00:00
|
|
|
return notFound();
|
2016-06-08 08:16:32 +00:00
|
|
|
}
|
2016-04-04 12:36:30 +00:00
|
|
|
links.countClick(req.ip, req.params.campaign, req.params.list, req.params.subscription, linkId, (err, status) => {
|
|
|
|
if (err) {
|
|
|
|
log.error('Redirect', err.stack || err);
|
|
|
|
}
|
|
|
|
if (status) {
|
|
|
|
log.verbose('Redirect', 'First click for %s:%s:%s (%s)', req.params.campaign, req.params.list, req.params.subscription, url);
|
|
|
|
}
|
|
|
|
});
|
2016-04-25 13:19:55 +00:00
|
|
|
|
|
|
|
if (!/\[[^\]]+\]/.test(url)) {
|
|
|
|
// no special tags, just pass on the link
|
|
|
|
return res.redirect(url);
|
|
|
|
}
|
|
|
|
|
|
|
|
// url might include variables, need to rewrite those just as we do with message content
|
|
|
|
lists.getByCid(req.params.list, (err, list) => {
|
|
|
|
if (err) {
|
|
|
|
req.flash('danger', err.message || err);
|
|
|
|
return res.redirect('/');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!list) {
|
2016-06-09 06:53:38 +00:00
|
|
|
log.error('Redirect', 'Could not resolve list for merge tags: <%s>', req.url);
|
|
|
|
return notFound();
|
2016-04-25 13:19:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
settings.get('serviceUrl', (err, serviceUrl) => {
|
|
|
|
if (err) {
|
|
|
|
// ignore
|
|
|
|
}
|
|
|
|
serviceUrl = (serviceUrl || '').toString().trim();
|
|
|
|
|
|
|
|
subscriptions.getWithMergeTags(list.id, req.params.subscription, (err, subscription) => {
|
|
|
|
if (err) {
|
|
|
|
req.flash('danger', err.message || err);
|
|
|
|
return res.redirect('/');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!subscription) {
|
2016-06-09 06:53:38 +00:00
|
|
|
log.error('Redirect', 'Could not resolve subscription for merge tags: <%s>', req.url);
|
|
|
|
return notFound();
|
2016-04-25 13:19:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
url = tools.formatMessage(serviceUrl, {
|
|
|
|
cid: req.params.campaign
|
|
|
|
}, list, subscription, url, str => encodeURIComponent(str));
|
|
|
|
|
|
|
|
res.redirect(url);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-04-04 12:36:30 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = router;
|