2020-07-27 20:18:52 +02:00
|
|
|
const storage = require('../storage');
|
|
|
|
const { statDownloadEvent } = require('../amplitude');
|
|
|
|
|
|
|
|
module.exports = async function(req, res) {
|
|
|
|
try {
|
|
|
|
const id = req.params.id;
|
|
|
|
const meta = req.meta;
|
|
|
|
const ttl = await storage.ttl(id);
|
|
|
|
statDownloadEvent({
|
|
|
|
id,
|
|
|
|
ip: req.ip,
|
|
|
|
owner: meta.owner,
|
|
|
|
download_count: meta.dl,
|
|
|
|
ttl,
|
|
|
|
agent: req.ua.browser.name || req.ua.ua.substring(0, 6)
|
|
|
|
});
|
|
|
|
await storage.incrementField(id, 'dl');
|
2020-07-29 21:35:47 +02:00
|
|
|
if (meta.dl + 1 >= meta.dlimit) {
|
|
|
|
// Only dlimit number of tokens will be issued
|
|
|
|
// after which /download/token will return 403
|
|
|
|
// however the protocol doesn't prevent one token
|
|
|
|
// from making all the downloads and assumes
|
|
|
|
// clients are well behaved. If this becomes
|
|
|
|
// a problem we can keep track of used tokens.
|
2020-07-27 20:18:52 +02:00
|
|
|
await storage.kill(id);
|
|
|
|
}
|
|
|
|
res.sendStatus(200);
|
|
|
|
} catch (e) {
|
|
|
|
res.sendStatus(404);
|
|
|
|
}
|
|
|
|
};
|