ssl.mjs 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. import express from 'express'
  2. import { get } from 'lodash-es'
  3. import qs from 'querystring'
  4. export default function () {
  5. const router = express.Router()
  6. /**
  7. * Let's Encrypt Challenge
  8. */
  9. router.get('/.well-known/acme-challenge/:token', (req, res, next) => {
  10. res.type('text/plain')
  11. if (get(WIKI.config, 'letsencrypt.challenge', false)) {
  12. if (WIKI.config.letsencrypt.challenge.token === req.params.token) {
  13. res.send(WIKI.config.letsencrypt.challenge.keyAuthorization)
  14. WIKI.logger.info(`(LETSENCRYPT) Received valid challenge request. [ ACCEPTED ]`)
  15. } else {
  16. res.status(406).send('Invalid Challenge Token!')
  17. WIKI.logger.warn(`(LETSENCRYPT) Received invalid challenge request. [ REJECTED ]`)
  18. }
  19. } else {
  20. res.status(418).end()
  21. }
  22. })
  23. /**
  24. * Redirect to HTTPS if HTTP Redirection is enabled
  25. */
  26. // router.all('/*', (req, res, next) => {
  27. // if (WIKI.config.server.sslRedir && !req.secure && WIKI.servers.servers.https) {
  28. // let query = (!_.isEmpty(req.query)) ? `?${qs.stringify(req.query)}` : ``
  29. // return res.redirect(`https://${req.hostname}${req.originalUrl}${query}`)
  30. // } else {
  31. // next()
  32. // }
  33. // })
  34. return router
  35. }