-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.js
81 lines (72 loc) · 2.22 KB
/
index.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
const cookieSession = require('cookie-session');
const querystring = require('querystring');
const express = require('express');
const convert = require('xml-js');
var jwt = require('jsonwebtoken');
const axios = require('axios');
const https = require('https');
const fs = require('fs');
const app = express();
var casLogin = '/cas/login?';
var casVerify = '/cas/serviceValidate?';
var casServer = 'https://cas.nss.udel.edu';
var serviceURL = 'https://planner.cis.udel.edu:3100';
const PORT = 3100;
app.use(cookieSession({
name: 'cas-session',
keys: ['key1', 'key2']
}))
var serviceURLQueryString = querystring.stringify({
service: serviceURL
});
function isEmpty(obj) {
for (var key in obj) {
if (obj.hasOwnProperty(key))
return false;
}
return true;
}
async function verifyTicket(ticket) {
try {
const response = await axios.get(casServer + casVerify + serviceURLQueryString + '&ticket=' + ticket);
return response.data;
} catch (error) {
console.error(error);
}
}
app.get('/', async (req, res) => {
if (isEmpty(req.query)) {
res.redirect(302, '/login');
} else {
try {
var data = await verifyTicket(req.query.ticket);
var jsonData = convert.xml2json(data, {
ignoreAttributes: true,
compact: true,
trim: true
});
var casCookie = jwt.sign(jsonData, 'universityofdelaware**1776**cisc');
res
.cookie(
'cas_user',
casCookie, {
expires: new Date(Date.now() + 259200000),
path: '/'
}
)
.redirect(302, 'https://planner.cis.udel.edu');
} catch (error) {
console.error(error);
}
}
})
app.get('/login', function (req, res) {
res.redirect(302, casServer + casLogin + serviceURLQueryString);
});
https.createServer({
key: fs.readFileSync('/var/secret/etc/ssl/forms-combined.cis.udel.edu.key'),
cert: fs.readFileSync('/var/secret/etc/ssl/forms-combined.cis.udel.edu.pem')
}, app)
.listen(PORT, function () {
console.log('API listening at: ' + serviceURL);
});