gancio/server/routes.js
2021-07-27 17:22:56 +02:00

83 lines
2.6 KiB
JavaScript

const config = require('config')
const express = require('express')
const cors = require('cors')
const api = require('./api')
const oauth = require('./api/oauth')
const auth = require('./api/auth')
const cookieParser = require('cookie-parser')
const federation = require('./federation')
const webfinger = require('./federation/webfinger')
const { spamFilter } = require('./federation/helpers')
const log = require('./log')
const exportController = require('./api/controller/export')
const eventController = require('./api/controller/event')
const announceController = require('./api/controller/announce')
// const metricsController = require('./metrics')
// const promBundle = require('express-prom-bundle')
// const metricsMiddleware = promBundle({ includeMethod: true })
const helpers = require('./helpers')
const app = express()
// ignore unimplemented ping url from fediverse
app.use(spamFilter)
// app.use(metricsMiddleware)
app.use((req, res, next) => {
log.debug(`${req.method} ${req.path}`)
next()
})
app.use('/media/', express.static(config.upload_path))
// initialize instance settings / authentication / locale
app.use(helpers.initSettings)
app.use('/noimg.svg', (req, res, next) => {
return express.static('./static/noimg.svg')
})
// serve favicon and static content
app.use('/logo.png', (req, res, next) => {
const logoPath = req.settings.logo || './static/gancio'
return express.static(logoPath + '.png')(req, res, next)
})
app.use('/favicon.ico', (req, res, next) => {
const faviconPath = req.settings.logo || './assets/favicon'
return express.static(faviconPath + '.ico')(req, res, next)
})
// rss/ics/atom feed
app.get('/feed/:type', cors(), exportController.export)
// federation api / activitypub / webfinger / nodeinfo
app.use('/.well-known', webfinger)
app.use('/federation', federation)
app.use(cookieParser())
// fill req.user if request is authenticated
app.use(auth.fillUser)
// api!
app.use('/api', api)
app.use('/oauth', oauth)
// // Handle 500
app.use((error, req, res, next) => {
log.error('[ERROR]', error)
res.status(500).send('500: Internal Server Error')
})
// remaining request goes to nuxt
// first nuxt component is ./pages/index.vue (with ./layouts/default.vue)
// prefill current events, tags, places and announcements (used in every path)
app.use(async (req, res, next) => {
// const start_datetime = getUnixTime(startOfWeek(startOfMonth(new Date())))
// req.events = await eventController._select(start_datetime, 100)
req.meta = await eventController._getMeta()
req.announcements = await announceController._getVisible()
next()
})
module.exports = app