traintimesPWA/server.js
2018-01-14 18:57:22 +00:00

34 lines
978 B
JavaScript

const express = require('express');
const cors = require('cors')
const path = require('path');
const apicache = require('apicache');
const logger = require('log4js').getLogger('Server');
const train = require('./server/lib/train');
logger.level = 'debug';
const app = express();
const port = process.env.PORT || 8100;
const sitePath = 'live';
apicache.options({ 'debug': true });
const cache = apicache.middleware;
app.use(express.static(path.join(__dirname, sitePath)));
app.options('*', cors()); // include before other routes
app.use('/gettrains', cors(), cache('60 seconds'), train.getTrainTimes);
app.use('/getnexttraintimes', cors(), cache('60 seconds'), train.getNextTrainTimes);
app.use('/getroute', cors(), cache('60 seconds'), train.getRoute);
app.use('/getnews', cors(), cache('30 minutes'), train.getNews);
app.listen(port, (err) => {
if (err)
return logger.error('Server error:', err);
logger.info(`TrainTime Server is listening on ${port}`);
});