-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
109 lines (80 loc) · 3.19 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
98
99
100
101
102
103
104
105
106
107
108
109
require("dotenv").config()
const express = require("express")
const app = express()
const jwt = require("jsonwebtoken")
app.use(express.json())
let refreshTokens = []
app.post("/login", (req, res) => {
// Authentication
const username = req.body.username
const user = { name: username }
const accessToken = generateAccessToken(user)
const refreshToken = jwt.sign(user, process.env.REFRESH_TOKEN_SECRET)
// Check if username is truthy and if not, return a 401 status code.
// Ref: https://stackoverflow.com/a/5515349
if (!username) return res.status(401).send("Unauthorized")
refreshTokens.push(refreshToken)
res.json({
access_token: accessToken,
refresh_token: refreshToken,
})
})
app.post("/refreshToken", (req, res) => {
const refreshToken = req.body.refresh_token
if (refreshToken == null) return res.status(401).send("Unauthorized")
// Check to see if the Refresh Token we pass in the body of the request
// is in the refreshTokens list
if (!refreshTokens.includes(refreshToken))
return res.status(403).send({ message: "Forbidden" })
// Remove old refresh token from refreshTokens list using Refresh Token Rotation
// https://auth0.com/docs/secure/tokens/refresh-tokens/refresh-token-rotation
refreshTokens = refreshTokens.filter(c => c != refreshToken)
jwt.verify(refreshToken, process.env.REFRESH_TOKEN_SECRET, (err, user) => {
if (err) return res.status(403).send({ message: "Forbidden" })
const accessToken = generateAccessToken({ name: user.name })
const refreshToken = generateRefreshToken({ name: user.name })
res.json({ access_token: accessToken, refresh_token: refreshToken })
refreshTokens.push({ refresh_token: refreshToken })
})
})
app.delete("/logout", (req, res) => {
// Invalidate the Refresh Token we pass to the request body
refreshTokens = refreshTokens.filter(
access_token => access_token !== req.body.access_token
)
res.sendStatus(204)
})
const posts = []
app.post("/posts", authenticateToken, (req, res) => {
const username = req.body.username
const title = req.body.title
posts.push({ username: username, title: title })
res.json({ username: username, title: title })
})
app.get("/posts", authenticateToken, (req, res) => {
res.json(posts.filter(post => post.username === req.user.name))
})
app.get("/validateToken", authenticateToken, (req, res) => {
res.status(200).send({ message: "The Access Token you provided is valid!" })
})
function generateAccessToken(user) {
return jwt.sign(user, process.env.ACCESS_TOKEN_SECRET, {
expiresIn: process.env.ACCESS_TOKEN_EXPIRATION || "10m",
})
}
function generateRefreshToken(user) {
return jwt.sign(user, process.env.REFRESH_TOKEN_SECRET, {
expiresIn: process.env.REFRESH_TOKEN_EXPIRATION || "20m",
})
}
function authenticateToken(req, res, next) {
const authHeader = req.headers["authorization"]
const token = authHeader && authHeader.split(" ")[1]
if (token == null) return res.status(401).send({ message: "Unauthorized" })
jwt.verify(token, process.env.ACCESS_TOKEN_SECRET, (err, user) => {
if (err) return res.status(401).send({ message: "Unauthorized" })
req.user = user
next()
})
}
app.listen(process.env.APP_PORT || 3333)