-
Notifications
You must be signed in to change notification settings - Fork 1
/
server.js
101 lines (83 loc) · 2.63 KB
/
server.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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
// Import express
"use strict";
const updateNotifier = require('update-notifier');
const pkg = require('./package.json');
const helmet = require('helmet');
const rout = require("./src/routes");
const express = require('express');
const bodyParser = require('body-parser');
const mongoose = require('mongoose');
mongoose.set('useCreateIndex', true);
const session = require('express-session');
const config = require('./src/config/config');
const swStats = require('swagger-stats');
const swaggerUi = require('swagger-ui-express');
const cors = require('cors');
const swaggeroptions = require('./apidoc');
const databaseconnection = require('./src/plugins/mongo.connections');
const notifier = updateNotifier({ pkg, updateCheckInterval: 1000 * 60 * 60 * 24 * 7 });
if (notifier.update) { console.log(`Update available: ${notifier.update.latest}`); }
const fn = '/api/v1';
const app = express();
app.use('/api/docs', swaggerUi.serve, swaggerUi.setup(null, swaggeroptions));
var sess = {
secret: config.TOKEN_SECRET,
cookie: {
path: '/',
httpOnly: false ,
maxAge: 24 * 60 * 60 * 1000,
secure: true,
expires: 0
},
resave: false,
saveUninitialized: false,
};
if (app.get('env') === 'production') {
app.use(function (req, res, next) {
var protocol = req.get('x-forwarded-proto');
protocol === 'https' ? next() : res.redirect('https://' + req.hostname + req.url );
});
app.set('trust proxy', 1);// trust first proxy
sess.cookie.secure = true; // serve secure cookies
}
app.use(swStats.getMiddleware());
app.use(helmet());
app.use(session(sess));
app.use(cors());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
for (let [key, value] of Object.entries(rout)) {
app.use(fn, value);
}
app.use('/api/doc', express.static('docs'));
app.use(function logErrors(err, req, res, next) {
console.error(err.stack);
next(err);
});
app.use(function clientErrorHandler(err, req, res, next) {
if (req.xhr) {
res.status(500).send({ error: 'Something failed!' });
} else {
next(err);
}
});
app.use(function errorHandler(err, req, res, next) {
res.status(500);
res.render('error', { error: err });
});
app.get('/', function (req, res) {
res.send('RestHub api started...');
let sess = req.session;
console.log(sess);
if (sess.username && sess.id) {
return res.redirect('/');
}
});
app.get('/favicon.ico', (req, res) => {
res.sendFile("./assets/favicon.ico",{ root: __dirname });
});
databaseconnection.connectMongoDatabase();
const server = app.listen(config.HOSTING_PORT, function () {
console.log("Running RestHub on port " + config.HOSTING_PORT);
});
module.exports = server;