48 lines
1.3 KiB
JavaScript
48 lines
1.3 KiB
JavaScript
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,
|
|
}
|