-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapp.js
55 lines (45 loc) · 1.88 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
const U2F = require("u2f");
const Express = require("express");
const BodyParser = require("body-parser");
const Cors = require("cors");
const HTTPS = require("https");
const FS = require("fs");
const session = require("express-session");
const APP_ID = "https://trends247.live";
var app = Express();
app.use(session({ secret: "thepolyglotdeveloper", cookie: { secure: true, maxAge: 60000 }, saveUninitialized: true, resave: true }));
app.use(BodyParser.json());
app.use(BodyParser.urlencoded({ extended: true }));
app.use(Cors({ origin: [APP_ID], credentials: true }));
var user;
app.get("/register", (request, response, next) => {
request.session.u2f = U2F.request(APP_ID);
console.log(request.session.u2f);
response.send(request.session.u2f);
});
app.post("/register", (request, response, next) => {
console.log("request.session.u2f", request.session.u2f);
console.log("request.body.registerResponse", request.body.registerResponse);
var registration = U2F.checkRegistration(request.session.u2f, request.body.registerResponse);
console.log("registration", registration);
if (!registration.successful) {
return response.status(500).send({ message: "error" });
}
user = registration;
response.send({ message: "The hardware key has been registered" });
});
app.get("/login", (request, response, next) => {
request.session.u2f = U2F.request(APP_ID, user.keyHandle);
response.send(request.session.u2f);
});
app.post("/login", (request, response, next) => {
var success = U2F.checkSignature(request.session.u2f, request.body.loginResponse, user.publicKey);
response.send(success);
});
app.use(Express.static(__dirname + '/dist')); //Serves resources from public folder
HTTPS.createServer({
key: FS.readFileSync("./private.key"),
cert: FS.readFileSync("./certificate.crt"),
}, app).listen(443, () => {
console.log("Listening at :443...");
});