|
|
@ -6,6 +6,7 @@ const cors = require('cors') |
|
|
|
const express = require('express') |
|
|
|
const favicon = require('serve-favicon') |
|
|
|
const http = require('http') |
|
|
|
const https = require('https') |
|
|
|
const path = require('path') |
|
|
|
const { ApolloServer } = require('apollo-server-express') |
|
|
|
// const oauth2orize = require('oauth2orize')
|
|
|
@ -166,10 +167,33 @@ module.exports = async () => { |
|
|
|
|
|
|
|
let srvConnections = {} |
|
|
|
|
|
|
|
WIKI.logger.info(`HTTP Server on port: [ ${WIKI.config.port} ]`) |
|
|
|
|
|
|
|
app.set('port', WIKI.config.port) |
|
|
|
WIKI.server = http.createServer(app) |
|
|
|
if (WIKI.config.ssl.enabled) { |
|
|
|
WIKI.logger.info(`HTTPS Server on port: [ ${WIKI.config.port} ]`) |
|
|
|
const tlsOpts = {} |
|
|
|
try { |
|
|
|
if (WIKI.config.ssl.format === 'pem') { |
|
|
|
tlsOpts.key = fs.readFileSync(WIKI.config.ssl.key) |
|
|
|
tlsOpts.cert = fs.readFileSync(WIKI.config.ssl.cert) |
|
|
|
} else { |
|
|
|
tlsOpts.pfx = fs.readFileSync(WIKI.config.ssl.pfx) |
|
|
|
} |
|
|
|
if (!_.isEmpty(WIKI.config.ssl.passphrase)) { |
|
|
|
tlsOpts.passphrase = WIKI.config.ssl.passphrase |
|
|
|
} |
|
|
|
if (!_.isEmpty(WIKI.config.ssl.dhparam)) { |
|
|
|
tlsOpts.dhparam = WIKI.config.ssl.dhparam |
|
|
|
} |
|
|
|
} catch (err) { |
|
|
|
WIKI.logger.error('Failed to setup HTTPS server parameters:') |
|
|
|
WIKI.logger.error(err) |
|
|
|
return process.exit(1) |
|
|
|
} |
|
|
|
WIKI.server = https.createServer(tlsOpts, app) |
|
|
|
} else { |
|
|
|
WIKI.logger.info(`HTTP Server on port: [ ${WIKI.config.port} ]`) |
|
|
|
WIKI.server = http.createServer(app) |
|
|
|
} |
|
|
|
apolloServer.installSubscriptionHandlers(WIKI.server) |
|
|
|
|
|
|
|
WIKI.server.listen(WIKI.config.port, WIKI.config.bindIP) |
|
|
@ -200,7 +224,11 @@ module.exports = async () => { |
|
|
|
}) |
|
|
|
|
|
|
|
WIKI.server.on('listening', () => { |
|
|
|
WIKI.logger.info('HTTP Server: [ RUNNING ]') |
|
|
|
if (WIKI.config.ssl.enabled) { |
|
|
|
WIKI.logger.info('HTTPS Server: [ RUNNING ]') |
|
|
|
} else { |
|
|
|
WIKI.logger.info('HTTP Server: [ RUNNING ]') |
|
|
|
} |
|
|
|
}) |
|
|
|
|
|
|
|
WIKI.server.destroy = (cb) => { |
|
|
|