-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathnode_server.js
More file actions
80 lines (66 loc) · 2.3 KB
/
node_server.js
File metadata and controls
80 lines (66 loc) · 2.3 KB
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
/**
* Created by web on 5/24/17.
**/
var Hapi = require('hapi');
var corsHeaders = require('hapi-cors-headers');
var config = require('config');
var Inert = require('inert');
const Vision = require('vision');
const HapiSwagger = require('hapi-swagger');
var pack = require('./package');
var cluster = require('cluster');
//var models = require('./src/models/mysql');
var log = require('./logger/logger');
var numberOfCPUs = require('os').cpus().length;
const options = {
info: {
'title': 'Backend Demo API Documentation',
'version': pack.version
}
};
var server = new Hapi.Server();
try {
if (cluster.isMaster) {
for (var i = 0; i < numberOfCPUs; i++) {
var worker = cluster.fork();
log.info('worker %s started.', worker.id);
}
}
else {
// create the server
server.connection({
port: config.server.port
});
server.register([
Inert,
Vision,
{
'register': HapiSwagger,
'options': options
}
], function (err) {
server.route(require('./src/routes/routes'));
server.start(function (err) {
if (err) {
log.error(err);
} else {
log.info('Backend demo server is Running on : ' + server.info.uri);
}
});
server.on('response', function (request) {
if (request.response)
log.info(request.info.remoteAddress + ': ' + request.method.toUpperCase() + ' ' + request.url.path + ' --> ' + request.response.statusCode);
else
log.info("No statusCode : ", request.info.remoteAddress + ': ' + request.method.toUpperCase() + ' ' + request.url.path + ' --> ');
});
server.ext('onPreResponse', corsHeaders);
});
}
}
catch (er) {
log.error("ERROR : ", er);
}
var validate = function (decoded, request, callback) {
return callback(null, true);
};
module.exports = server;