-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
executable file
·33 lines (26 loc) · 1.09 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
var express = require('express');
var path = require('path');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var favicon = require('serve-favicon');
var rfs = require('rotating-file-stream');
var app = express();
var critterHandler = require('./critters');
// view engine setup
// app.set('views', path.join(__dirname, 'views'));
// app.set('view engine', 'pug');
// Create Rotating Log
var appLogStream = rfs.createStream('critterforecast.log',{
interval: '1d',
path: "/data/log"
});
logger.token('remote-addr', function (req, res) { return req.headers['x-real-ip']; });
app.use(logger(':remote-addr [:date[iso]] :status :res[content-length] ":method :url HTTP/:http-version" ":referrer" ":user-agent"', { stream: appLogStream }));
app.use(cookieParser());
app.use(express.json());
app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(express.urlencoded({ extended: false }));
app.use(express.static(path.join(__dirname, 'public'), {maxAge: '4h'}));
app.use('/fish', critterHandler('fish'));
app.use('/insect', critterHandler('insect'));
module.exports = app;