-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSignatureRequestValidator.js
41 lines (34 loc) · 1.08 KB
/
SignatureRequestValidator.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
const fs = require('fs')
const md5 = require('js-md5')
const ALLOWS_LAG_SECONDS = 30
const moment = require('moment')
const httpSignature = require('http-signature')
const RequestValidator = require('./RequestValidator')
const ENV = process.env.NODE_ENV || 'dev'
class SignatureRequestValidator extends RequestValidator {
constructor(opt) {
super(opt)
}
validate(request) {
this.req = request
return super.validate(request)
}
checkSignature() {
try {
let _parsed = httpSignature.parseRequest(this.req)
let pub = fs.readFileSync(`./phoenix-conf-store/certificates/${ENV}/${_parsed.keyId}/public`, 'ascii')
return httpSignature.verifySignature(_parsed, pub)
} catch (e) {
console.log(e)
return false
}
}
/**
* check header date
* @returns {boolean}
*/
checkHeaderDate() {
return moment(Date.parse(this.req.headers.date)).add(ALLOWS_LAG_SECONDS, 'seconds').isAfter(moment(new Date()))
}
}
module.exports = SignatureRequestValidator