spee.ch/server/utils/awaitFileSize.js

31 lines
907 B
JavaScript
Raw Normal View History

2019-04-18 17:51:21 +02:00
const { getFileListFileByOutpoint } = require('server/lbrynet');
const logger = require('winston');
2019-02-26 07:56:44 +01:00
function delay(t) {
return new Promise(function(resolve) {
setTimeout(resolve, t);
2019-02-26 07:56:44 +01:00
});
}
const awaitFileSize = (outpoint, size, interval, timeout) => {
logger.debug('awaitFileSize');
let start = Date.now();
function checkFileList() {
logger.debug('checkFileList');
return getFileListFileByOutpoint(outpoint).then(result => {
logger.debug('File List Result', result);
if (result[0]['completed'] === true || result[0]['written_bytes'] > size) {
logger.debug('FILE READY');
return 'ready';
} else if (timeout !== 0 && Date.now() - start > timeout) {
throw new Error('Timeout on awaitFileSize');
} else {
return delay(interval).then(checkFileList);
}
});
}
return checkFileList();
2019-02-26 07:56:44 +01:00
};
2019-04-18 17:51:21 +02:00
module.exports = awaitFileSize;