app.js 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. const express = require('express')
  2. const path = require('path')
  3. const cookieParser = require('cookie-parser')
  4. const logger = require('morgan')
  5. const cors = require('cors')
  6. const csrf = require('./middleware/csrf')
  7. const response = require('./utils/responseHandler')
  8. const app = express()
  9. require('./config/db')()
  10. app.use(logger('dev'))
  11. app.use(express.json())
  12. app.use(
  13. cors({
  14. origin: 'https://sidali.kemdiktisaintek.go.id',
  15. credentials: true,
  16. })
  17. )
  18. app.use(express.urlencoded({ extended: false }))
  19. app.use(cookieParser(process.env.SRU51))
  20. // app.use(csrf( ['GET', 'HEAD', 'OPTIONS'], ['/v1/auth/login', /\/v1\/auto\//i, /v2/i]))
  21. app.use(express.static(path.join(__dirname, 'public')))
  22. app.use((req, res, next) => {req.data = {}; return next()})
  23. // routes
  24. app.use('/', require('./routes'))
  25. app.use((req, res) =>
  26. response.error(res, { code: 404, message: 'request not found' })
  27. )
  28. app.use((err, req, res, next) => {
  29. if (err.code === 'EBADCSRFTOKEN') {
  30. response.error(res, { code: 403, message: 'invalid csrf token' })
  31. } else {
  32. response.error(res, { code: err.code || 500, message: err.message })
  33. }
  34. })
  35. module.exports = app