mirror of
https://github.com/tornadocash/trusted-setup-server.git
synced 2025-01-08 04:44:20 +01:00
59 lines
1.5 KiB
JavaScript
59 lines
1.5 KiB
JavaScript
const path = require('path')
|
|
const { NODE_ENV } = process.env
|
|
require('dotenv').config({ path: path.join(__dirname, `../.env.${NODE_ENV}`) })
|
|
const express = require('express')
|
|
const bodyParser = require('body-parser')
|
|
const session = require('express-session')
|
|
const { Nuxt, Builder } = require('nuxt')
|
|
const config = require('../nuxt.config.js')
|
|
const sessionsController = require('./controllers/authorize')
|
|
const contributionController = require('./controllers/contribute')
|
|
const models = require('./models')
|
|
const attestationWatcher = require('./attestationWatcher')
|
|
|
|
const app = express()
|
|
|
|
async function start() {
|
|
config.dev = NODE_ENV !== 'production'
|
|
await models.sequelize.sync()
|
|
const nuxt = new Nuxt(config)
|
|
|
|
const { host, port } = nuxt.options.server
|
|
|
|
// Build only in dev mode
|
|
if (config.dev) {
|
|
const builder = new Builder(nuxt)
|
|
await builder.build()
|
|
} else {
|
|
await nuxt.ready()
|
|
}
|
|
app.use(
|
|
session({
|
|
secret: process.env.SESSION_SECRET,
|
|
resave: false,
|
|
saveUninitialized: true
|
|
})
|
|
)
|
|
app.use((req, res, next) => {
|
|
res.locals.session = req.session
|
|
next()
|
|
})
|
|
|
|
app.use(bodyParser.urlencoded({ extended: true }))
|
|
app.use(bodyParser.json())
|
|
|
|
app.use('/api', sessionsController)
|
|
app.use('/api', contributionController)
|
|
|
|
// Give nuxt middleware to express
|
|
app.use(nuxt.render)
|
|
|
|
app.listen(port, host, () => {
|
|
console.log(`Server is running on port ${port}.`)
|
|
})
|
|
|
|
attestationWatcher()
|
|
console.log('attestationWatcher started')
|
|
}
|
|
start()
|