-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
49 lines (42 loc) · 1.53 KB
/
app.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
var express = require("express");
var bodyParser = require('body-parser');
var logger = require('winston');
var puresecMicroservice = require("puresec-microservice-js");
var urlMaster = process.env.MASTER_URL || process.argv[2] || "http://localhost:3000";
var registrationInterval = process.env.MASTER_REGISTRATION_INTERVAL || process.argv[3] || 5;
var port = process.env.PORT || process.argv[4] || 3002;
var app = express();
var master = puresecMicroservice.master(urlMaster);
var utils = puresecMicroservice.utils();
var webApp = puresecMicroservice.webApp();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
extended: true
}));
webApp.registerHealthCheckEndpoint(app, function() {
logger.debug("health: UP");
});
webApp.registerNotificationEndpoint(app, function(req, res) {
logger.info("\nnotification received ..");
logger.info(req.body);
});
app.listen(port, function() {
var registerOptions = {
name: "Mock Handler 1",
description: "Mock implementation of handler",
type: "handler",
address: utils.currentAddress(port),
onSuccess: function(jsonBody) {
logger.info("registration result: ", jsonBody);
},
onError: function(error) {
logger.error("error during registration", error, "\nretry ..");
setTimeout(function() {
master.register(registerOptions);
}, registrationInterval * 1000);
}
};
// register
logger.info("try to register ..");
master.register(registerOptions);
});