-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdebug.js
109 lines (107 loc) · 2.58 KB
/
debug.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
106
107
108
109
const http = require('http');
const fs = require('fs');
const ejs = require('ejs');
const url = require('url');
ejs.rmWhitespace=true;
const server = http.createServer(async (req, resp) => {
const path = url.parse(req.url).pathname;
if(path == "/") {
resp.writeHead(200,{"Content-Type":"text/html; charset=utf8"});
resp.end(fs.readFileSync("source/index.html"));
return;
}
if(path == "/login"){
resp.writeHead(302,{"Location":"/home"});
resp.end();
return;
}
if(path == "/logout"){
resp.writeHead(302,{"Location":"/"});
resp.end();
return;
}
if(path == "/img/github.svg") {
resp.writeHead(200,{"Content-Type":"image/svg+xml"});
resp.end(fs.readFileSync("source/img/github.svg"));
return;
}
if(path == "/styles.css") {
resp.writeHead(200,{"Content-Type":"text/css"});
resp.end(fs.readFileSync("source/styles.css"));
return;
}
let html;
const isOfficer = url.parse(req.url, true).query.isOfficer!==undefined;
try{
html = await ejs.renderFile("source"+path+".ejs",{
user:{
role:isOfficer?"officer":"association",
name:"KEEER",
score:512,
reports:[
{
title:"活动1",
id:"report"
}
],
applications:[
{
title:"申请1",
id:"application"
}
],
messages:[
{
title:"消息1",
id:"message"
}
]
},
report:{
title:"活动1",
name:"客页KEEER",
begin:"2018年",
time:"1秒",
place:"空中花园",
size:"xlarge",
content:"你\n好\n<script>alert(/xss/);</script>\n",
checkedsize:"large",
score:200
},
application:{
title:"申请1",
name:"客页KEEER",
begin:"2018年",
time:"1秒",
place:"空中花园",
type:"room",
content:"你\n好\n<script>alert(/xss/);</script>\n",
reply:"回复\n已通过\n未通过\n原因:无"
},
message:{
title:"消息1",
from:"客页KEEER",
to:"???",
content:"你\n好\n<script>alert(/xss/);</script>\n",
score:-20
},
associations:[
"客页KEEER",
"物理社",
"化学社"
]
},
{
root:__dirname+"/source/"
}
);
} catch(e) {
html = "<textarea>Error: "+e.stack+"</textarea>";
} finally {
resp.writeHead(200,{"Content-Type":"text/html; charset=utf8"});
resp.end(html);
return;
}
});
server.listen(50082);
console.log("[INFO] OK.");