forked from ALEXZZZ9/PS4-5.01-WebKit-Exploit-PoC
-
Notifications
You must be signed in to change notification settings - Fork 0
/
app.js
105 lines (82 loc) · 2.77 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
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
102
103
104
105
const fs = require('fs');
const mkdirp = require('mkdirp');
const express = require('express');
const logger = require('morgan');
const bodyParser = require('body-parser');
const serveIndex = require('serve-index');
const serveStatic = require('serve-static');
const contentDisposition = require('content-disposition');
const path = require('path');
const freshUp = require('fresh-up');
const app = express();
const port = 80;
const hourMs = 0; // 1000 * 60 * 60;
const ExcludeErrorsID = [404];
const root = path.join(__dirname/*process.cwd()*/, 'data');
const wwwRoot = root; // path.join(root, 'www');
const jssRoot = root; // path.join(root, 'www');
const jssExt = '.jss';
const sendJssErrors = true;
/** Middlewares */
//app.use(logger('dev'));
app.use(bodyParser.urlencoded({ extended: true }));
/** Query */
app.use((req, res, next) => {
req.q = (req.method === 'GET') ? req.query : req.body;
next();
});
/** JSS server */
app.use((req, res, next) => {
let filePath;
const potentialIndexFile = path.resolve(jssRoot, `.${req.path}`, `./index${jssExt}`);
if (req.path.endsWith(jssExt)) {
filePath = path.resolve(jssRoot, `.${req.path}`);
} else if (fs.existsSync(potentialIndexFile)) {
filePath = potentialIndexFile;
} else {
return next();
}
if (!fs.existsSync(filePath)) {
return next(NewError(`Not Found URL: ${req.url}`, 404));
}
try {
require(filePath)(req, res); // eslint-disable-line import/no-dynamic-require
} catch (e) {
freshUp(require.resolve(filePath));
if (sendJssErrors) {
return res.status(500).send(`<pre>${e.stack}</pre>`);
} else {
return next(NewError('Server error', 500));
}
}
freshUp(require.resolve(filePath));
return undefined;
});
/** Static server */
app.use(serveIndex(wwwRoot, {'icons': true}))
app.use(serveStatic(wwwRoot, { maxAge: hourMs, 'index': false }));
/** Errors */
app.use((req, res, next) => {
return ReturnFormatError(res, NewError(`Not Found URL: ${req.url}`, 404));
});
app.use((err, req, res, next) => {
return ReturnFormatError(res, err);
});
/** Listen */
app.listen(port, () => {
console.log('Server listening on port ' + port);
});
/** Helpers */
function NewError (message, code = 500, data = null) {
let err = new Error(message);
err.code = code;
if (data !== null) err.data = data;
return err;
};
function ReturnFormatError(res, error) {
if (!ExcludeErrorsID.includes(error.code)) console.error(error.message);
if (!error.code || error.code === 500) return res.status(500).json({status: 500, error: 'Server error'});
let jError = {status: error.code, error: error.message};
if (error.data) jError['data'] = error.data;
return res.status(error.code).json(jError);
};