Рефакторинг

This commit is contained in:
Book Pauk
2019-01-13 15:20:03 +07:00
parent 47b4bd9838
commit d040dd0718
2 changed files with 42 additions and 15 deletions

View File

@@ -0,0 +1,34 @@
const got = require('got');
class FileDownloader {
constructor() {
}
async load(url, callback) {
const maxDownloadSize = 10*1024*1024;
let estSize = 100000;
const request = got(url).on('downloadProgress', progress => {
if (progress.transferred > maxDownloadSize) {
request.cancel();
}
const prog = Math.round(progress.transferred/estSize*100);
if (callback)
callback(prog);
if (prog > 100)
estSize *= 1.5;
});
try {
return (await request).body;
} catch (error) {
if (request.isCanceled) {
throw new Error('file too big')
}
throw error;
}
}
}
module.exports = FileDownloader;

View File

@@ -1,11 +1,11 @@
const fs = require('fs-extra');
const workerState = require('./workerState');
const FileDownloader = require('./FileDownloader');
const FileDecompressor = require('./FileDecompressor');
const BookConverter = require('./BookConverter');
const utils = require('./utils');
const fs = require('fs-extra');
const got = require('got');
class ReaderWorker {
constructor(config) {
this.config = Object.assign({}, config);
@@ -16,12 +16,12 @@ class ReaderWorker {
this.config.tempPublicDir = `${config.publicDir}/tmp`;
fs.ensureDirSync(this.config.tempPublicDir);
this.down = new FileDownloader();
this.decomp = new FileDecompressor();
this.bookConverter = new BookConverter();
}
async loadBook(url, wState) {
const maxDownloadSize = 10*1024*1024;
let errMes = '';
let decompDir = '';
let downloadedFilename = '';
@@ -33,19 +33,12 @@ class ReaderWorker {
const decompDirname = utils.randomHexString(30);
//download
let estSize = 100000;//
const downdata = await got(url).on('downloadProgress', progress => {
if (progress.transferred > maxDownloadSize) {
errMes = 'file too big';
d.destroy();
}
const prog = Math.round(progress.transferred/estSize*100);
if (prog > 100)
estSize *= 1.5;
wState.set({progress: (prog > 100 ? 100 : prog) });
const downdata = await this.down.load(url, (progress) => {
wState.set({progress});
});
downloadedFilename = `${this.config.tempDownloadDir}/${tempFilename}`;
await fs.writeFile(downloadedFilename, downdata.body);
await fs.writeFile(downloadedFilename, downdata);
wState.set({progress: 100});
//decompress