From 7d77d478c1fbf232cd346064406055dd755e48fb Mon Sep 17 00:00:00 2001 From: Book Pauk Date: Wed, 27 Feb 2019 21:59:45 +0700 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=B8=D0=BB=20?= =?UTF-8?q?=D0=BA=D0=BE=D0=BD=D0=B2=D0=B5=D1=80=D1=82=D0=B5=D1=80=20=D1=84?= =?UTF-8?q?=D0=B0=D0=B9=D0=BB=D0=BE=D0=B2=20rtf?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/core/BookConverter/ConvertDoc.js | 4 +-- server/core/BookConverter/ConvertRtf.js | 33 +++++++++++++++++++++++++ server/core/BookConverter/index.js | 1 + 3 files changed, 35 insertions(+), 3 deletions(-) create mode 100644 server/core/BookConverter/ConvertRtf.js diff --git a/server/core/BookConverter/ConvertDoc.js b/server/core/BookConverter/ConvertDoc.js index 97a2dad6..d3571b0f 100644 --- a/server/core/BookConverter/ConvertDoc.js +++ b/server/core/BookConverter/ConvertDoc.js @@ -24,9 +24,7 @@ class ConvertDoc extends ConvertDocX { const fb2File = `${outFile}.fb2`; await fs.copy(inputFiles.sourceFile, docFile); - await this.execConverter(this.sofficePath, ['--headless', '--convert-to', 'docx', '--outdir', inputFiles.fileListDir, docFile], (data) => { - console.log(data.toString()); - }); + await this.execConverter(this.sofficePath, ['--headless', '--convert-to', 'docx', '--outdir', inputFiles.fileListDir, docFile]); return await super.convert(docxFile, fb2File, callback); } diff --git a/server/core/BookConverter/ConvertRtf.js b/server/core/BookConverter/ConvertRtf.js new file mode 100644 index 00000000..6e6eda31 --- /dev/null +++ b/server/core/BookConverter/ConvertRtf.js @@ -0,0 +1,33 @@ +const fs = require('fs-extra'); +const path = require('path'); + +const ConvertDocX = require('./ConvertDocX'); + +class ConvertRtf extends ConvertDocX { + check(data, opts) { + const {inputFiles} = opts; + + return this.config.useExternalBookConverter && + inputFiles.sourceFileType && inputFiles.sourceFileType.ext == 'rtf'; + } + + async run(data, opts) { + if (!this.check(data, opts)) + return false; + await this.checkExternalConverterPresent(); + + const {inputFiles, callback} = opts; + + const outFile = `${inputFiles.fileListDir}/${path.basename(inputFiles.sourceFile)}`; + const rtfFile = `${outFile}.rtf`; + const docxFile = `${outFile}.docx`; + const fb2File = `${outFile}.fb2`; + + await fs.copy(inputFiles.sourceFile, rtfFile); + await this.execConverter(this.sofficePath, ['--headless', '--convert-to', 'docx', '--outdir', inputFiles.fileListDir, rtfFile]); + + return await super.convert(docxFile, fb2File, callback); + } +} + +module.exports = ConvertRtf; diff --git a/server/core/BookConverter/index.js b/server/core/BookConverter/index.js index 40013536..ec3515be 100644 --- a/server/core/BookConverter/index.js +++ b/server/core/BookConverter/index.js @@ -3,6 +3,7 @@ const FileDetector = require('../FileDetector'); //порядок важен const convertClassFactory = [ + require('./ConvertRtf'), require('./ConvertDocX'), require('./ConvertDoc'), require('./ConvertFb2'),