| 12345678910111213141516171819202122232425262728293031323334353637 |
- const express = require('express')
- const path = require('path')
- const cookieParser = require('cookie-parser')
- const logger = require('morgan')
- const cors = require('cors')
- const csrf = require('./middleware/csrf')
- const response = require('./utils/responseHandler')
- const app = express()
- require('./config/db')()
- app.use(logger('dev'))
- app.use(express.json())
- app.use(cors({ origin: true, credentials: true }))
- app.use(express.urlencoded({ extended: false }))
- app.use(cookieParser(process.env.SRU51))
- // app.use(csrf( ['GET', 'HEAD', 'OPTIONS'], ['/v1/auth/login', /\/v1\/auto\//i, /v2/i]))
- app.use(express.static(path.join(__dirname, 'public')))
- app.use((req, res, next) => {req.data = {}; return next()})
- // routes
- app.use('/', require('./routes'))
- app.use((req, res) =>
- response.error(res, { code: 404, message: 'request not found' })
- )
- app.use((err, req, res, next) => {
- if (err.code === 'EBADCSRFTOKEN') {
- response.error(res, { code: 403, message: 'invalid csrf token' })
- } else {
- response.error(res, { code: err.code || 500, message: err.message })
- }
- })
- module.exports = app
|