2015-04-18 14:14:36 +00:00
|
|
|
var cl = global.botanLoader;
|
2014-10-10 08:38:06 +00:00
|
|
|
var Dragonfly = global.Dragonfly;
|
|
|
|
|
|
|
|
var domain = require('domain');
|
2015-04-18 14:14:36 +00:00
|
|
|
|
|
|
|
var FatalError = cl.load( "botanss.errors.FatalError" );
|
2014-10-10 08:38:06 +00:00
|
|
|
|
|
|
|
// Message is hardcoded to prevent further exceptions occured
|
|
|
|
// This function must be bug-free
|
|
|
|
function server500( response, e )
|
|
|
|
{
|
|
|
|
response.statusCode = 500;
|
|
|
|
response.setHeader( 'Content-Type', 'text/plain' );
|
2015-07-29 04:03:47 +00:00
|
|
|
response.end( e.message || e );
|
2014-10-10 08:38:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function serverHandle( server, request, response, rHandle )
|
|
|
|
{
|
|
|
|
var d = domain.create();
|
|
|
|
|
|
|
|
d.addListener( 'error', function( e ) {
|
|
|
|
Dragonfly.Error( e.stack );
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
var killtimer = setTimeout( function()
|
|
|
|
{
|
|
|
|
process.exit(1);
|
|
|
|
}, 3000);
|
|
|
|
killtimer.unref();
|
|
|
|
|
|
|
|
server.close();
|
|
|
|
|
2016-04-28 07:58:00 +00:00
|
|
|
global.X_SERVER_CLUSTER.worker.destroy();
|
2014-10-10 08:38:06 +00:00
|
|
|
|
|
|
|
server500( response, e );
|
|
|
|
}
|
|
|
|
catch( ex )
|
|
|
|
{
|
|
|
|
Dragonfly.Error( ex.stack );
|
|
|
|
process.exit();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
d.add( request );
|
|
|
|
d.add( response );
|
|
|
|
|
|
|
|
d.run( function() {
|
|
|
|
rHandle( request, response );
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Construncor
|
|
|
|
function AppDomain( handler, port, cluster )
|
|
|
|
{
|
2015-04-18 14:14:36 +00:00
|
|
|
var http = require( "http" );
|
2014-10-10 08:38:06 +00:00
|
|
|
var server = http.createServer(
|
|
|
|
function(req, res) {
|
2022-04-03 12:52:44 +00:00
|
|
|
res._hrtime = process.hrtime.bigint();
|
2014-10-10 08:38:06 +00:00
|
|
|
serverHandle( server, req, res, handler );
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
server.listen( port );
|
|
|
|
Dragonfly.Info( "Listening on: " + port, Dragonfly.Visibility.VISIBLE );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
module.exports = AppDomain;
|