-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathsecure-link.js
62 lines (58 loc) · 1.88 KB
/
secure-link.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
const {InvalidSignatureError, LinkHasExpiredError, SecureLink} = require("@mingalevme/secure-link");
class SecureLinkMiddleware {
/**
* @param {SecureLink} secureLinkService
* @param logger
*/
constructor(secureLinkService, logger) {
this.secureLinkService = secureLinkService;
this.logger = logger;
}
/**
* @param {IncomingMessage} req
* @param {ServerResponse} res
* @param {function()} next
* @return void
*/
handle(req, res, next) {
const url = new URL(req.url, `${req.protocol}://${req.hostname}`)
this.#log(`${this.constructor.name}: handling request`, {"url": url.toString()});
try {
this.secureLinkService.validate(url)
} catch (e) {
if (e instanceof InvalidSignatureError) {
this.#log(`Invalid link signature`, {"url": url.toString()});
res.status(403)
.set('Content-Type', 'text/plain')
.send('Invalid signature')
} else if (e instanceof LinkHasExpiredError) {
this.#log(`Invalid is expired`, {"url": url.toString()});
res.status(410)
.set('Content-Type', 'text/plain')
.send('Link has expired')
} else {
this.#log(`Unknown error while validating link`, {
'link': url.toString(),
'err': e,
});
throw e
}
return
}
this.#log(`${this.constructor.name}: link is valid`, {"url": url.toString()});
next();
}
/**
*
* @param {string} message
* @param {any} meta
* @return void
*/
#log(message, meta) {
if (!this.logger) {
return
}
this.logger.debug(message, meta)
}
}
module.exports = SecureLinkMiddleware;