refactoring routes
This commit is contained in:
parent
15cdba96eb
commit
b8931ee8bf
5 changed files with 72 additions and 52 deletions
|
@ -32,6 +32,9 @@ export default {
|
||||||
components: { DbStep, Settings, Completed },
|
components: { DbStep, Settings, Completed },
|
||||||
middleware: 'setup',
|
middleware: 'setup',
|
||||||
layout: 'iframe',
|
layout: 'iframe',
|
||||||
|
head: {
|
||||||
|
title: 'Setup',
|
||||||
|
},
|
||||||
auth: false,
|
auth: false,
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
|
|
|
@ -4,7 +4,7 @@ const config = require('../../config')
|
||||||
const fs = require('fs')
|
const fs = require('fs')
|
||||||
const { Op } = require('sequelize')
|
const { Op } = require('sequelize')
|
||||||
const intersection = require('lodash/intersection')
|
const intersection = require('lodash/intersection')
|
||||||
const linkifyHtml = require('linkifyjs/html')
|
const linkifyHtml = require('linkify-html')
|
||||||
const Sequelize = require('sequelize')
|
const Sequelize = require('sequelize')
|
||||||
const dayjs = require('dayjs')
|
const dayjs = require('dayjs')
|
||||||
const helpers = require('../../helpers')
|
const helpers = require('../../helpers')
|
||||||
|
|
|
@ -4,7 +4,7 @@ const APUser = require('../api/models/ap_user')
|
||||||
|
|
||||||
const log = require('../log')
|
const log = require('../log')
|
||||||
const helpers = require('../helpers')
|
const helpers = require('../helpers')
|
||||||
const linkifyHtml = require('linkifyjs/html')
|
const linkifyHtml = require('linkify-html')
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
const ical = require('ical.js')
|
const ical = require('ical.js')
|
||||||
const settingsController = require('./api/controller/settings')
|
const settingsController = require('./api/controller/settings')
|
||||||
const acceptLanguage = require('accept-language')
|
const acceptLanguage = require('accept-language')
|
||||||
|
const express = require('express')
|
||||||
const dayjs = require('dayjs')
|
const dayjs = require('dayjs')
|
||||||
const timezone = require('dayjs/plugin/timezone')
|
const timezone = require('dayjs/plugin/timezone')
|
||||||
dayjs.extend(timezone)
|
dayjs.extend(timezone)
|
||||||
|
@ -78,6 +78,30 @@ module.exports = {
|
||||||
next()
|
next()
|
||||||
},
|
},
|
||||||
|
|
||||||
|
serveStatic () {
|
||||||
|
const router = express.Router()
|
||||||
|
// serve logo, favicon, event's images/thumb
|
||||||
|
router.use('/media/', express.static(config.upload_path))
|
||||||
|
router.use('/noimg.svg', express.static('./static/noimg.svg'))
|
||||||
|
|
||||||
|
router.use('/logo.png', (req, res, next) => {
|
||||||
|
const logoPath = req.settings.logo || './static/gancio'
|
||||||
|
return express.static(logoPath + '.png')(req, res, next)
|
||||||
|
})
|
||||||
|
|
||||||
|
router.use('/favicon.ico', (req, res, next) => {
|
||||||
|
const faviconPath = req.settings.logo || './assets/favicon'
|
||||||
|
return express.static(faviconPath + '.ico')(req, res, next)
|
||||||
|
})
|
||||||
|
|
||||||
|
return router
|
||||||
|
},
|
||||||
|
|
||||||
|
logRequest (req, res, next) {
|
||||||
|
log.debug(`${req.method} ${req.path}`)
|
||||||
|
next()
|
||||||
|
},
|
||||||
|
|
||||||
async getImageFromURL (url) {
|
async getImageFromURL (url) {
|
||||||
log.debug(`getImageFromURL ${url}`)
|
log.debug(`getImageFromURL ${url}`)
|
||||||
const filename = crypto.randomBytes(16).toString('hex') + '.jpg'
|
const filename = crypto.randomBytes(16).toString('hex') + '.jpg'
|
||||||
|
|
|
@ -1,52 +1,37 @@
|
||||||
const config = require('config')
|
|
||||||
const express = require('express')
|
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 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 metricsController = require('./metrics')
|
||||||
// const promBundle = require('express-prom-bundle')
|
// const promBundle = require('express-prom-bundle')
|
||||||
// const metricsMiddleware = promBundle({ includeMethod: true })
|
// const metricsMiddleware = promBundle({ includeMethod: true })
|
||||||
|
|
||||||
|
const config = require('./config')
|
||||||
const helpers = require('./helpers')
|
const helpers = require('./helpers')
|
||||||
|
const log = require('./log')
|
||||||
|
const api = require('./api')
|
||||||
|
|
||||||
|
|
||||||
const app = express()
|
const app = express()
|
||||||
|
|
||||||
// ignore unimplemented ping url from fediverse
|
app.use(helpers.logRequest)
|
||||||
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
|
// initialize instance settings / authentication / locale
|
||||||
app.use(helpers.initSettings)
|
app.use(helpers.initSettings)
|
||||||
|
app.use(helpers.serveStatic())
|
||||||
|
|
||||||
app.use('/noimg.svg', (req, res, next) => {
|
// ignore unimplemented ping url from fediverse
|
||||||
return express.static('./static/noimg.svg')
|
app.use(cookieParser())
|
||||||
})
|
|
||||||
|
|
||||||
// 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) => {
|
// do not handle all routes on setup
|
||||||
const faviconPath = req.settings.logo || './assets/favicon'
|
if (!config.firstrun) {
|
||||||
return express.static(faviconPath + '.ico')(req, res, next)
|
const cors = require('cors')
|
||||||
})
|
const { spamFilter } = require('./federation/helpers')
|
||||||
|
const oauth = require('./api/oauth')
|
||||||
|
const auth = require('./api/auth')
|
||||||
|
const federation = require('./federation')
|
||||||
|
const webfinger = require('./federation/webfinger')
|
||||||
|
const exportController = require('./api/controller/export')
|
||||||
|
|
||||||
// rss/ics/atom feed
|
// rss/ics/atom feed
|
||||||
app.get('/feed/:type', cors(), exportController.export)
|
app.get('/feed/:type', cors(), exportController.export)
|
||||||
|
@ -54,14 +39,17 @@ app.get('/feed/:type', cors(), exportController.export)
|
||||||
// federation api / activitypub / webfinger / nodeinfo
|
// federation api / activitypub / webfinger / nodeinfo
|
||||||
app.use('/.well-known', webfinger)
|
app.use('/.well-known', webfinger)
|
||||||
app.use('/federation', federation)
|
app.use('/federation', federation)
|
||||||
|
app.use(spamFilter)
|
||||||
app.use(cookieParser())
|
|
||||||
|
|
||||||
// fill req.user if request is authenticated
|
// fill req.user if request is authenticated
|
||||||
app.use(auth.fillUser)
|
app.use(auth.fillUser)
|
||||||
|
|
||||||
|
app.use('/oauth', oauth)
|
||||||
|
// app.use(metricsMiddleware)
|
||||||
|
}
|
||||||
|
|
||||||
// api!
|
// api!
|
||||||
app.use('/api', api)
|
app.use('/api', api)
|
||||||
app.use('/oauth', oauth)
|
|
||||||
|
|
||||||
// // Handle 500
|
// // Handle 500
|
||||||
app.use((error, req, res, next) => {
|
app.use((error, req, res, next) => {
|
||||||
|
@ -75,8 +63,13 @@ app.use((error, req, res, next) => {
|
||||||
app.use(async (req, res, next) => {
|
app.use(async (req, res, next) => {
|
||||||
// const start_datetime = getUnixTime(startOfWeek(startOfMonth(new Date())))
|
// const start_datetime = getUnixTime(startOfWeek(startOfMonth(new Date())))
|
||||||
// req.events = await eventController._select(start_datetime, 100)
|
// req.events = await eventController._select(start_datetime, 100)
|
||||||
|
if (!config.firstrun) {
|
||||||
|
const eventController = require('./api/controller/event')
|
||||||
|
const announceController = require('./api/controller/announce')
|
||||||
req.meta = await eventController._getMeta()
|
req.meta = await eventController._getMeta()
|
||||||
req.announcements = await announceController._getVisible()
|
req.announcements = await announceController._getVisible()
|
||||||
|
}
|
||||||
|
req.firstrun = config.firstrun
|
||||||
next()
|
next()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue