| 12345678910111213141516171819202122232425262728293031323334353637383940414243 | 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 dokumenController = require('./controller/dokumen.controller')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]))app.use(express.static(path.join(__dirname, 'public')))app.get('/', (req, res) => {  return res.json({    message: 'API SIDALI'  })})// route versionapp.use('/v1', require('./routes/v1'))app.get('/dokumen/:id/:nama_file', dokumenController.getDokumen)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
 |