move app routes to separate directory for better composition in

preparation of firebase integration
This commit is contained in:
Ondřej Synáček 2020-11-01 13:08:48 +01:00
parent c7175382b6
commit 0ad6bba142
4 changed files with 78 additions and 45 deletions

View File

@ -4,8 +4,13 @@ const path = require('path')
const favicon = require('serve-favicon') const favicon = require('serve-favicon')
const rateLimit = require('express-rate-limit') const rateLimit = require('express-rate-limit')
const { retrieveICS } = require('./services/ics-retriever') const {
const crawl = require('./services/crawler') error,
notFound,
download,
downloadHTML,
} = require('./routes')
const { const {
genericErrorHandler, genericErrorHandler,
checkURLParameter, checkURLParameter,
@ -14,7 +19,6 @@ const {
createErrorLogger, createErrorLogger,
} = require('./middlewares') } = require('./middlewares')
const { createAppLogger } = require('./log-utils') const { createAppLogger } = require('./log-utils')
const { getNormalizedUrl } = require('./utils')
const port = process.env.PORT const port = process.env.PORT
const certEndpoint = process.env.CERT_ENDPOINT || '' const certEndpoint = process.env.CERT_ENDPOINT || ''
@ -60,60 +64,22 @@ if (certEndpoint) {
}) })
} }
app.get('/error', (req, res) => { app.get('/error', error)
const error = req.error || req.query.error || ''
res
.status(500)
.render('error', { error })
})
app.get('/about', (req, res) => { app.get('/about', (req, res) => {
res.render('about', { version }) res.render('about', { version })
}) })
// NOTE: Capture all unkown URLs // NOTE: Capture all unkown URLs
app.get('*', (req, res) => { app.get('*', notFound)
res.status(400).render('404')
})
app.use('/download/html', limiter) app.use('/download/html', limiter)
app.use('/download/html', checkURLParameter) app.use('/download/html', checkURLParameter)
app.post('/download/html', async (req, res, next) => { app.post('/download/html', downloadHTML(appLogger))
try {
const { url } = req.body
const facebookURL = getNormalizedUrl(url)
const html = await crawl(facebookURL, { logger: appLogger })
res
.contentType('text/html')
.status(200)
.send(Buffer.from(html, 'utf8'))
} catch (err) {
next(err)
}
})
app.use('/download', limiter) app.use('/download', limiter)
app.use('/download', checkURLParameter) app.use('/download', checkURLParameter)
app.post('/download', async (req, res, next) => { app.post('/download', download)
try {
const { url } = req.body
const ics = await retrieveICS(url, {
logger: appLogger,
crawl,
})
res
.contentType('text/calendar')
.status(200)
.send(Buffer.from(ics, 'utf8'))
} catch (err) {
next(err)
}
})
app.use(createErrorLogger({ dev: isDevelopment })) app.use(createErrorLogger({ dev: isDevelopment }))
app.use(genericErrorHandler) app.use(genericErrorHandler)

42
lib/routes/download.js Normal file
View File

@ -0,0 +1,42 @@
const { getNormalizedUrl } = require('../utils')
const crawl = require('../services/crawler')
const { retrieveICS } = require('../services/ics-retriever')
const downloadHTML = (logger) => (async (req, res, next) => {
try {
const { url } = req.body
const facebookURL = getNormalizedUrl(url)
const html = await crawl(facebookURL, { logger })
res
.contentType('text/html')
.status(200)
.send(Buffer.from(html, 'utf8'))
} catch (err) {
next(err)
}
})
const download = async (req, res, next) => {
try {
const { url } = req.body
const ics = await retrieveICS(url, {
logger: appLogger,
crawl,
})
res
.contentType('text/calendar')
.status(200)
.send(Buffer.from(ics, 'utf8'))
} catch (err) {
next(err)
}
}
module.exports = {
downloadHTML,
download,
}

16
lib/routes/error.js Normal file
View File

@ -0,0 +1,16 @@
const error = (req, res) => {
const error = req.error || req.query.error || ''
res
.status(500)
.render('error', { error })
}
const notFound = (req, res) => {
res.status(400).render('404')
}
module.exports = {
error,
notFound,
}

9
lib/routes/index.js Normal file
View File

@ -0,0 +1,9 @@
const { error, notFound } = require('./error')
const { download, downloadHTML } = require('./download')
module.exports = {
error,
notFound,
download,
downloadHTML,
}