-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathserver.js
38 lines (32 loc) · 1.05 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
// REQUIRES
var express = require('express');
var bodyParser = require('body-parser');
var sign = require('./signature');
var Dimelo = require('./dimelo');
var app = express();
app.use(bodyParser.json());
app.get('/', function(req, res) {
res.setHeader('Content-Type', 'text/html');
res.end('');
});
// handle post request
app.post('/', function(req, res) {
// set content-type
res.setHeader('Content-Type', 'application/json');
if (!Dimelo.Request.validation.isValid(req.body)) {
res.status(422).send({ error: 'Invalid action' });
return;
}
// check if signature is present AND valid
if ('x-smccsdk-signature' in req.headers && sign.isSigned(JSON.stringify(req.body), req.headers['x-smccsdk-signature'])) {
// process request
let response = JSON.stringify(Dimelo.Request.process(req.body));
res.setHeader('X-SMCCSDK-SIGNATURE', sign.signString(response));
res.end(response);
}
// bad signature
else
res.status(422).send({ error: 'Invalid signature' });
});
var port = Number(process.env.PORT || 3000);
app.listen(port);