Работа над BookUpdateChecker
This commit is contained in:
@@ -35,7 +35,13 @@ module.exports = {
|
|||||||
dbName: 'reader-storage',
|
dbName: 'reader-storage',
|
||||||
thread: true,
|
thread: true,
|
||||||
openAll: true,
|
openAll: true,
|
||||||
}
|
},
|
||||||
|
{
|
||||||
|
serverName: 'buc',
|
||||||
|
dbName: 'book-update-server',
|
||||||
|
thread: true,
|
||||||
|
openAll: true,
|
||||||
|
},
|
||||||
],
|
],
|
||||||
|
|
||||||
servers: [
|
servers: [
|
||||||
@@ -45,6 +51,14 @@ module.exports = {
|
|||||||
ip: '0.0.0.0',
|
ip: '0.0.0.0',
|
||||||
port: '33080',
|
port: '33080',
|
||||||
},
|
},
|
||||||
|
/*{
|
||||||
|
serverName: 'buc',
|
||||||
|
mode: 'book_update_checker', //'none', 'normal', 'site', 'reader', 'omnireader', 'liberama.top', 'book_update_checker'
|
||||||
|
isHttps: true,
|
||||||
|
keysFile: 'server',
|
||||||
|
ip: '0.0.0.0',
|
||||||
|
port: '33443',
|
||||||
|
}*/
|
||||||
],
|
],
|
||||||
|
|
||||||
remoteStorage: false,
|
remoteStorage: false,
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
const WebSocket = require ('ws');
|
const WebSocket = require('ws');
|
||||||
//const _ = require('lodash');
|
//const _ = require('lodash');
|
||||||
|
|
||||||
|
const BUCServer = require('../core/BookUpdateChecker/BUCServer');
|
||||||
const log = new (require('../core/AppLogger'))().log;//singleton
|
const log = new (require('../core/AppLogger'))().log;//singleton
|
||||||
//const utils = require('../core/utils');
|
//const utils = require('../core/utils');
|
||||||
|
|
||||||
@@ -13,6 +14,8 @@ class BookUpdateCheckerController {
|
|||||||
this.isDevelopment = (config.branch == 'development');
|
this.isDevelopment = (config.branch == 'development');
|
||||||
|
|
||||||
//this.readerStorage = new JembaReaderStorage();
|
//this.readerStorage = new JembaReaderStorage();
|
||||||
|
this.bucServer = new BUCServer(config);
|
||||||
|
this.bucServer.main(); //no await
|
||||||
|
|
||||||
this.wss = wss;
|
this.wss = wss;
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,9 @@
|
|||||||
|
const fs = require('fs-extra');
|
||||||
|
|
||||||
|
const FileDownloader = require('../FileDownloader');
|
||||||
|
|
||||||
|
const log = new (require('../AppLogger'))().log;//singleton
|
||||||
|
|
||||||
let instance = null;
|
let instance = null;
|
||||||
|
|
||||||
//singleton
|
//singleton
|
||||||
@@ -18,6 +24,15 @@ class BUCServer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async main() {
|
async main() {
|
||||||
|
try {
|
||||||
|
//
|
||||||
|
|
||||||
|
log(`---------------------------`);
|
||||||
|
log(`Book Update checker started`);
|
||||||
|
log(`---------------------------`);
|
||||||
|
} catch (e) {
|
||||||
|
log(LM_FATAL, e.stack);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -31,7 +31,15 @@ class JembaConnManager {
|
|||||||
|
|
||||||
ayncExit.add(this.close.bind(this));
|
ayncExit.add(this.close.bind(this));
|
||||||
|
|
||||||
|
const serverNames = new Set();
|
||||||
|
for (const serverCfg of this.config.servers) {
|
||||||
|
serverNames.add(serverCfg.serverName);
|
||||||
|
}
|
||||||
|
|
||||||
for (const dbConfig of this.config.jembaDb) {
|
for (const dbConfig of this.config.jembaDb) {
|
||||||
|
if (dbConfig.serverName && !serverNames.has(dbConfig.serverName))
|
||||||
|
continue;
|
||||||
|
|
||||||
const dbPath = `${this.config.dataDir}/db/${dbConfig.dbName}`;
|
const dbPath = `${this.config.dataDir}/db/${dbConfig.dbName}`;
|
||||||
|
|
||||||
//бэкап
|
//бэкап
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
up: [
|
up: [
|
||||||
['create', {
|
['create', {
|
||||||
table: 'checked',
|
table: 'buc',
|
||||||
index: [
|
index: [
|
||||||
{field: 'queryTime', type: 'number'},
|
{field: 'queryTime', type: 'number'},
|
||||||
{field: 'checkTime', type: 'number'},
|
{field: 'checkTime', type: 'number'},
|
||||||
@@ -10,7 +10,7 @@ module.exports = {
|
|||||||
],
|
],
|
||||||
down: [
|
down: [
|
||||||
['drop', {
|
['drop', {
|
||||||
table: 'checked'
|
table: 'buc'
|
||||||
}],
|
}],
|
||||||
]
|
]
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ const argv = require('minimist')(process.argv.slice(2));
|
|||||||
const express = require('express');
|
const express = require('express');
|
||||||
const compression = require('compression');
|
const compression = require('compression');
|
||||||
const http = require('http');
|
const http = require('http');
|
||||||
|
const https = require('https');
|
||||||
const WebSocket = require ('ws');
|
const WebSocket = require ('ws');
|
||||||
|
|
||||||
const ayncExit = new (require('./core/AsyncExit'))();
|
const ayncExit = new (require('./core/AsyncExit'))();
|
||||||
@@ -57,7 +58,15 @@ async function main() {
|
|||||||
for (let serverCfg of config.servers) {
|
for (let serverCfg of config.servers) {
|
||||||
if (serverCfg.mode !== 'none') {
|
if (serverCfg.mode !== 'none') {
|
||||||
const app = express();
|
const app = express();
|
||||||
const server = http.createServer(app);
|
let server;
|
||||||
|
if (serverCfg.isHttps) {
|
||||||
|
const key = fs.readFileSync(`${config.dataDir}/${serverCfg.keysFile}.key`);
|
||||||
|
const cert = fs.readFileSync(`${config.dataDir}/${serverCfg.keysFile}.crt`);
|
||||||
|
|
||||||
|
server = https.createServer({key, cert}, app);
|
||||||
|
} else {
|
||||||
|
server = http.createServer(app);
|
||||||
|
}
|
||||||
const wss = new WebSocket.Server({ server, maxPayload: maxPayloadSize*1024*1024 });
|
const wss = new WebSocket.Server({ server, maxPayload: maxPayloadSize*1024*1024 });
|
||||||
|
|
||||||
const serverConfig = Object.assign({}, config, serverCfg);
|
const serverConfig = Object.assign({}, config, serverCfg);
|
||||||
@@ -86,7 +95,7 @@ async function main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
server.listen(serverConfig.port, serverConfig.ip, function() {
|
server.listen(serverConfig.port, serverConfig.ip, function() {
|
||||||
log(`Server-${serverConfig.serverName} is ready on ${serverConfig.ip}:${serverConfig.port}, mode: ${serverConfig.mode}`);
|
log(`Server "${serverConfig.serverName}" is ready on ${(serverConfig.isHttps ? 'https://' : 'http://')}${serverConfig.ip}:${serverConfig.port}, mode: ${serverConfig.mode}`);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user