import express from 'express'; import authenticate from '../src/authenticate'; import dbConnection from './db'; import session from 'express-session'; import cookieParser from 'cookie-parser'; import grant from "grant"; import router from "./routes/user"; import { loadSuml } from './loader'; const app = express() app.use(express.json()); app.use(express.urlencoded({ extended: true })); app.use(cookieParser()); app.use(session({ secret: process.env.SECRET, cookie: {}, resave: false, saveUninitialized: false, })); app.use(async function (req, res, next) { req.config = loadSuml('config'); req.rawUser = authenticate(req); req.user = req.rawUser && req.rawUser.authenticated ? req.rawUser : null; req.admin = req.user && req.user.roles === 'admin'; req.db = await dbConnection(); next(); }); router.use(grant.express()(require('./social').config)); app.use(require('./routes/banner').default); app.use(require('./routes/user').default); app.use(require('./routes/profile').default); app.use(require('./routes/admin').default); app.use(require('./routes/pronouns').default); app.use(require('./routes/sources').default); app.use(require('./routes/nouns').default); app.use(require('./routes/inclusive').default); export default { path: '/api', handler: app, }