|
@@ -1,7 +1,9 @@
|
|
const fs = require('fs-extra');
|
|
const fs = require('fs-extra');
|
|
const iconv = require('iconv-lite');
|
|
const iconv = require('iconv-lite');
|
|
const chardet = require('chardet');
|
|
const chardet = require('chardet');
|
|
|
|
+
|
|
const textUtils = require('./textUtils');
|
|
const textUtils = require('./textUtils');
|
|
|
|
+const utils = require('../utils');
|
|
|
|
|
|
class ConvertBase {
|
|
class ConvertBase {
|
|
constructor(config) {
|
|
constructor(config) {
|
|
@@ -27,6 +29,19 @@ class ConvertBase {
|
|
throw new Error('Внешний конвертер pdftohtml не найден');
|
|
throw new Error('Внешний конвертер pdftohtml не найден');
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ async execConverter(path, args, onData) {
|
|
|
|
+ try {
|
|
|
|
+ const result = await utils.spawnProcess(path, {args, onData});
|
|
|
|
+ if (result.code != 0)
|
|
|
|
+ throw new Error(`Внешний конвертер завершился с ошибкой: ${result.code}`);
|
|
|
|
+ } catch(e) {
|
|
|
|
+ if (e.status == 'killed')
|
|
|
|
+ throw new Error('Слишком долгое ожидание конвертера');
|
|
|
|
+ else
|
|
|
|
+ throw new Error(e.error);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
decode(data) {
|
|
decode(data) {
|
|
let selected = textUtils.getEncoding(data);
|
|
let selected = textUtils.getEncoding(data);
|
|
|
|
|