2017-02-09 23:36:47 -05:00
|
|
|
const Eris = require('eris');
|
2017-02-09 21:56:36 -05:00
|
|
|
const fs = require('fs');
|
|
|
|
const https = require('https');
|
2017-12-24 15:04:08 -05:00
|
|
|
const config = require('../config');
|
2017-09-19 13:23:55 -04:00
|
|
|
|
2017-12-24 15:04:08 -05:00
|
|
|
const getUtils = () => require('../utils');
|
2017-02-09 21:56:36 -05:00
|
|
|
|
2018-02-11 14:54:30 -05:00
|
|
|
const attachmentDir = config.attachmentDir || `${__dirname}/../../attachments`;
|
2017-02-09 21:56:36 -05:00
|
|
|
|
2017-02-09 23:36:47 -05:00
|
|
|
/**
|
|
|
|
* Returns the filesystem path for the given attachment id
|
|
|
|
* @param {String} attachmentId
|
|
|
|
* @returns {String}
|
|
|
|
*/
|
|
|
|
function getPath(attachmentId) {
|
|
|
|
return `${attachmentDir}/${attachmentId}`;
|
2017-02-09 21:56:36 -05:00
|
|
|
}
|
|
|
|
|
2017-02-09 23:36:47 -05:00
|
|
|
/**
|
|
|
|
* Attempts to download and save the given attachement
|
|
|
|
* @param {Object} attachment
|
|
|
|
* @param {Number=0} tries
|
|
|
|
* @returns {Promise}
|
|
|
|
*/
|
2017-02-09 21:56:36 -05:00
|
|
|
function saveAttachment(attachment, tries = 0) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
if (tries > 3) {
|
|
|
|
console.error('Attachment download failed after 3 tries:', attachment);
|
|
|
|
reject('Attachment download failed after 3 tries');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-02-09 23:36:47 -05:00
|
|
|
const filepath = getPath(attachment.id);
|
2017-02-09 21:56:36 -05:00
|
|
|
const writeStream = fs.createWriteStream(filepath);
|
|
|
|
|
|
|
|
https.get(attachment.url, (res) => {
|
|
|
|
res.pipe(writeStream);
|
|
|
|
writeStream.on('finish', () => {
|
2018-02-11 14:54:30 -05:00
|
|
|
writeStream.end();
|
2017-02-09 21:56:36 -05:00
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
}).on('error', (err) => {
|
|
|
|
fs.unlink(filepath);
|
|
|
|
console.error('Error downloading attachment, retrying');
|
|
|
|
resolve(saveAttachment(attachment));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-02-09 23:36:47 -05:00
|
|
|
/**
|
|
|
|
* Attempts to download and save all attachments in the given message
|
|
|
|
* @param {Eris.Message} msg
|
|
|
|
* @returns {Promise}
|
|
|
|
*/
|
|
|
|
function saveAttachmentsInMessage(msg) {
|
2017-02-09 21:56:36 -05:00
|
|
|
if (! msg.attachments || msg.attachments.length === 0) return Promise.resolve();
|
|
|
|
return Promise.all(msg.attachments.map(saveAttachment));
|
|
|
|
}
|
|
|
|
|
2017-02-09 23:36:47 -05:00
|
|
|
/**
|
|
|
|
* Returns the self-hosted URL to the given attachment ID
|
|
|
|
* @param {String} attachmentId
|
|
|
|
* @param {String=null} desiredName Custom name for the attachment as a hint for the browser
|
|
|
|
* @returns {String}
|
|
|
|
*/
|
|
|
|
function getUrl(attachmentId, desiredName = null) {
|
2017-02-09 21:56:36 -05:00
|
|
|
if (desiredName == null) desiredName = 'file.bin';
|
2017-09-19 13:23:55 -04:00
|
|
|
return getUtils().getSelfUrl(`attachments/${attachmentId}/${desiredName}`);
|
2017-02-09 21:56:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
2017-02-09 23:36:47 -05:00
|
|
|
getPath,
|
2017-02-09 21:56:36 -05:00
|
|
|
saveAttachment,
|
2017-02-09 23:36:47 -05:00
|
|
|
saveAttachmentsInMessage,
|
|
|
|
getUrl,
|
2017-02-09 21:56:36 -05:00
|
|
|
};
|