-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathapp.js
72 lines (59 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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
const express = require('express');
const session = require('express-session');
const passport = require('passport');
const WebAppStrategy = require('ibmcloud-appid').WebAppStrategy;
const app = express();
app.use(session({
secret: '123456',
resave: true,
saveUninitialized: true
}));
app.use(passport.initialize());
app.use(passport.session());
passport.serializeUser((user, cb) => cb(null, user));
passport.deserializeUser((user, cb) => cb(null, user));
passport.use(new WebAppStrategy({
tenantId: "0f6a1a8c-70e5-4c0c-aeb8-466c84a8ac96",
clientId: "c5993bce-3b7a-4d0a-95fe-59f993780628",
secret: "MjhiNDEwOTEtZTg1Ny00MDhhLThhMWItMDM4YjgxZTQ4NTAy",
oauthServerUrl: "https://eu-gb.appid.cloud.ibm.com/oauth/v4/0f6a1a8c-70e5-4c0c-aeb8-466c84a8ac96",
redirectUri: "http://localhost:3000/appid/callback"
}));
// Handle Login
app.get('/appid/login', passport.authenticate(WebAppStrategy.STRATEGY_NAME, {
successRedirect: '/dataentry.html',
forceLogin: true
}));
// Handle callback
app.get('/appid/callback', passport.authenticate(WebAppStrategy.STRATEGY_NAME));
// Handle logout
app.get('/appid/logout', function(req, res){
WebAppStrategy.logout(req);
res.redirect('/');
});
// Protect the whole app
// app.use(passport.authenticate(WebAppStrategy.STRATEGY_NAME));
// Make sure only requests from an authenticated browser session can reach /api
app.use('/api', (req, res, next) => {
if (req.user){
next();
} else {
res.status(401).send("Unauthorized");
}
});
// The /api/user API used to retrieve name of a currently logged in user
app.get('/api/user', (req, res) => {
// console.log(req.session[WebAppStrategy.AUTH_CONTEXT]);
res.json({
user: {
name: req.user.name,
email: req.user.email
}
});
});
// Serve static resources
app.use(express.static('./public'));
// Start server
app.listen(3000, () => {
console.log('Listening on http://localhost:3000');
});