-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
97 lines (86 loc) · 3 KB
/
server.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
const express = require('express');
const queryString = require('query-string');
const app = express();
const USERS = [
{id: 1,
firstName: 'Joe',
lastName: 'Schmoe',
userName: '[email protected]',
position: 'Sr. Engineer',
isAdmin: true,
// NEVER EVER EVER store passwords in plain text in real life. NEVER!!!!!!!!!!!
password: 'password'
},
{id: 2,
firstName: 'Sally',
lastName: 'Student',
userName: '[email protected]',
position: 'Jr. Engineer',
isAdmin: true,
// NEVER EVER EVER store passwords in plain text in real life. NEVER!!!!!!!!!!!
password: 'password'
},
{id: 3,
firstName: 'Lila',
lastName: 'LeMonde',
userName: '[email protected]',
position: 'Growth Hacker',
isAdmin: false,
// NEVER EVER EVER store passwords in plain text in real life. NEVER!!!!!!!!!!!
password: 'password'
},
{id: 4,
firstName: 'Freddy',
lastName: 'Fun',
userName: '[email protected]',
position: 'Community Manager',
isAdmin: false,
// NEVER EVER EVER store passwords in plain text in real life. NEVER!!!!!!!!!!!
password: 'password'
}
];
function gateKeeper(req, res, next) {
// `Object.assign` here gives us a neat, clean way to express the following idea:
// We want to create an object with default
// values of `null` for `user` and `pass`,
// and *then*, if after parsing the request header
// we find values for `user` and `pass` set
// there, we'll use those over the default.
// Either way, we're guaranteed to end up
// with an object that has `user` and `pass`
// keys.
const {user, pass} = Object.assign(
{user: null, pass: null}, queryString.parse(req.get('x-username-and-password')));
// ^^ the more verbose way to express this is:
//
// const parsedHeader = queryString.parse(req.get('x-username-and-password'));
// const user = parsedHeader.user || null;
// const pass = parsedHeader.pass || null;
// if there's a user in `USERS` with the username
// and password from the request headers,
// we set `req.user` equal to that object.
// Otherwise, `req.user` will be undefined.
req.user = USERS.find(
(usr, index) => usr.userName === user && usr.password === pass);
// gotta call `next()`!!! otherwise this middleware
// will hang.
next();
}
// use `gateKeeper` for all routes in our app.
// this means `req.user` will always be added
// to the request object.
app.use(gateKeeper);
app.get("/api/users/me", (req, res) => {
// send an error message if no or wrong credentials sent
if (req.user === undefined) {
return res.status(403).json({message: 'Must supply valid user credentials'});
}
// we're only returning a subset of the properties
// from the user object. Notably, we're *not*
// sending `password` or `isAdmin`.
const {firstName, lastName, id, userName, position} = req.user;
return res.json({firstName, lastName, id, userName, position});
});
app.listen(process.env.PORT, () => {
console.log(`Your app is listening on port ${process.env.PORT}`);
});