You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
1.4 KiB
JavaScript
63 lines
1.4 KiB
JavaScript
const Koa = require('koa')
|
|
const app = new Koa()
|
|
const views = require('koa-views')
|
|
const cors = require('koa2-cors')
|
|
const json = require('koa-json')
|
|
const onerror = require('koa-onerror')
|
|
const bodyparser = require('koa-bodyparser')
|
|
const logger = require('koa-logger')
|
|
|
|
const log4js = require('./config/log4');
|
|
|
|
const index = require('./routes/index')
|
|
|
|
const { Aids: syncAids, AidsState: syncAidsState, newHotelDetails: syncNewHotels, hotelLgcDetails: syncHotelDetails, chinaHotelDetails: syncChinas } = require('./jobs/syncHeytripJobs');
|
|
const rlog = require('./middleware/request_log');
|
|
|
|
// error handler
|
|
onerror(app)
|
|
// app.proxy = true;
|
|
app.use(log4js);
|
|
// middlewares
|
|
app.use(bodyparser({
|
|
enableTypes:['json', 'form', 'text']
|
|
}))
|
|
app.use(cors({
|
|
origin: function(ctx){ return '*' }
|
|
}))
|
|
app.use(json())
|
|
app.use(logger())
|
|
app.use(require('koa-static')(__dirname + '/public'))
|
|
|
|
app.use(views(__dirname + '/views', {
|
|
extension: 'ejs'
|
|
}))
|
|
|
|
app.use(rlog);
|
|
|
|
// logger debug:
|
|
// app.use(async (ctx, next) => {
|
|
// const start = new Date()
|
|
// await next()
|
|
// const ms = new Date() - start
|
|
// console.log(`${ctx.method} ${ctx.url} - ${ms}ms`)
|
|
// })
|
|
|
|
// schedule jobs
|
|
// syncAids();
|
|
syncAidsState();
|
|
syncNewHotels();
|
|
syncHotelDetails();
|
|
syncChinas();
|
|
|
|
// routes
|
|
app.use(index.routes(), index.allowedMethods())
|
|
// app.use(routes(), allowedMethods())
|
|
|
|
// error-handling
|
|
app.on('error', (err, ctx) => {
|
|
console.error('server error', err, ctx)
|
|
});
|
|
|
|
module.exports = app
|