Catch parse exception
This commit is contained in:
@@ -183,38 +183,42 @@ module.exports.downloadFile = (url, destination, progressCallback, completeCallb
|
|||||||
responseType: 'stream',
|
responseType: 'stream',
|
||||||
})
|
})
|
||||||
.then(response => {
|
.then(response => {
|
||||||
const total = parseInt(response.headers['content-length'], 10);
|
try {
|
||||||
if (total === 0) {
|
const total = parseInt(response.headers['content-length'], 10);
|
||||||
completeCallback(Error('No data available for download'));
|
if (total === 0) {
|
||||||
} else {
|
completeCallback(Error('No data available for download'));
|
||||||
const stream = fs.createWriteStream(destination);
|
} else {
|
||||||
|
const stream = fs.createWriteStream(destination);
|
||||||
|
|
||||||
let downloaded = 0;
|
let downloaded = 0;
|
||||||
response.data.on('data', (chunk) => {
|
response.data.on('data', (chunk) => {
|
||||||
stream.write(Buffer.from(chunk));
|
stream.write(Buffer.from(chunk));
|
||||||
downloaded += chunk.length;
|
downloaded += chunk.length;
|
||||||
if (progressCallback) {
|
if (progressCallback) {
|
||||||
progressCallback((downloaded / total * 100.0).toFixed(2));
|
progressCallback((downloaded / total * 100.0).toFixed(2));
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
response.data.on('end', () => {
|
|
||||||
stream.end(() => {
|
|
||||||
if (downloaded === 0) {
|
|
||||||
completeCallback(Error('Received 0 bytes'));
|
|
||||||
} else if (downloaded !== total) {
|
|
||||||
completeCallback(Error('Received incorrect number of bytes'));
|
|
||||||
} else {
|
|
||||||
completeCallback();
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
|
||||||
|
|
||||||
response.data.on('error', error => {
|
response.data.on('end', () => {
|
||||||
stream.end(() => {
|
stream.end(() => {
|
||||||
completeCallback(error);
|
if (downloaded === 0) {
|
||||||
|
completeCallback(Error('Received 0 bytes'));
|
||||||
|
} else if (downloaded !== total) {
|
||||||
|
completeCallback(Error('Received incorrect number of bytes'));
|
||||||
|
} else {
|
||||||
|
completeCallback();
|
||||||
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
|
||||||
|
response.data.on('error', error => {
|
||||||
|
stream.end(() => {
|
||||||
|
completeCallback(error);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
completeCallback(error);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch(error => {
|
.catch(error => {
|
||||||
|
|||||||
Reference in New Issue
Block a user