arma-server-web-admin/lib/server.js

232 lines
4.9 KiB
JavaScript
Raw Normal View History

var events = require('events');
var fs = require('fs');
var gamedig = require('gamedig');
var slug = require('slug');
var spawn = require('child_process').spawn;
2014-02-13 22:47:51 +00:00
var ArmaServer = require('arma-server');
2015-04-03 10:23:17 +00:00
var config = require('../config.js');
2015-01-03 02:51:21 +00:00
var queryInterval = 5000;
var queryTypes = {
arma1: 'arma',
arma2: 'arma2',
arma2oa: 'arma2',
arma3: 'arma3',
cwa: 'operationflashpoint',
ofp: 'operationflashpoint',
ofpresistance: 'operationflashpoint',
};
2014-02-13 22:47:51 +00:00
var createServerTitle = function(title) {
if (config.prefix) {
title = config.prefix + title;
}
if (config.suffix) {
title = title + config.suffix;
}
return title;
};
var Server = function (config, logs, options) {
this.config = config;
this.logs = logs;
this.update(options);
};
Server.prototype = new events.EventEmitter();
2014-02-13 22:47:51 +00:00
Server.prototype.update = function (options) {
this.admin_password = options.admin_password;
this.battle_eye = options.battle_eye;
2015-02-13 16:13:55 +00:00
this.headless = options.headless;
this.max_players = options.max_players;
2015-08-23 22:16:16 +00:00
this.missions = options.missions;
this.mods = options.mods || [];
this.password = options.password;
this.persistent = options.persistent;
this.port = options.port || 2302;
this.title = options.title;
this.von = options.von;
this.id = slug(this.title).replace('.', '-');
2015-01-17 02:40:22 +00:00
this.port = parseInt(this.port, 10); // If port is a string then gamedig fails
};
2014-02-13 22:47:51 +00:00
Server.prototype.queryStatus = function() {
if (!this.instance) {
return;
}
var self = this;
Gamedig.query(
{
type: queryTypes[config.game],
host: '127.0.0.1',
port: self.port,
},
function(state) {
if (!self.instance) {
return;
}
if(state.error) {
self.state = null;
} else {
self.state = state;
}
self.emit('state');
}
);
};
2014-02-13 22:47:51 +00:00
Server.prototype.start = function() {
2015-02-13 16:13:55 +00:00
var server = new ArmaServer.Server({
battleEye: this.battle_eye ? 1 : 0,
config: this.id,
disableVoN: this.von ? 0 : 1,
2015-04-03 10:23:17 +00:00
game: config.game,
2015-02-13 16:13:55 +00:00
headlessClients: this.headless ? ["127.0.0.1"] : null,
hostname: createServerTitle(this.title),
2015-02-13 16:13:55 +00:00
localClient: this.headless ? ["127.0.0.1"] : null,
2015-08-23 22:16:16 +00:00
missions: this.missions,
mods: this.mods,
password: this.password,
passwordAdmin: this.admin_password,
path: this.config.path,
persistent: this.persistent ? 1 : 0,
platform: this.config.type,
players: this.max_players,
port: this.port,
2016-04-24 17:07:43 +00:00
serverMods: config.serverMods,
});
server.writeServerConfig();
var instance = server.start();
2014-04-06 22:58:17 +00:00
var self = this;
2014-02-13 22:47:51 +00:00
var logStream = null;
if (this.config.type === 'linux') {
logStream = fs.createWriteStream(this.logs.generateLogFilePath(), {
'flags': 'a'
});
}
2014-11-24 00:56:54 +00:00
instance.stdout.on('data', function (data) {
if (logStream) {
logStream.write(data);
}
2014-02-13 22:47:51 +00:00
});
2014-11-24 00:56:54 +00:00
instance.stderr.on('data', function (data) {
if (logStream) {
logStream.write(data);
}
2014-02-13 22:47:51 +00:00
});
2014-11-24 00:56:54 +00:00
instance.on('close', function (code) {
logStream.end();
clearInterval(self.queryStatusInterval);
self.state = null;
2014-04-06 22:58:17 +00:00
self.pid = null;
2014-11-24 00:56:54 +00:00
self.instance = null;
self.emit('state');
2014-04-06 22:58:17 +00:00
});
2014-11-24 00:56:54 +00:00
this.pid = instance.pid;
this.instance = instance;
this.queryStatusInterval = setInterval(function () {
self.queryStatus();
}, queryInterval);
2014-04-06 22:58:17 +00:00
2015-02-13 16:13:55 +00:00
if (this.headless) {
var headless = new ArmaServer.Headless({
2015-04-03 10:23:17 +00:00
game: config.game,
2015-02-13 16:13:55 +00:00
host: "127.0.0.1",
mods: this.mods,
password: this.password,
path: this.config.path,
platform: this.config.type,
2015-02-13 16:13:55 +00:00
port: this.port,
});
var headlessInstance = headless.start();
headlessInstance.stdout.on('data', function (data) {
console.log(self.id + ' HC: ' + data);
});
headlessInstance.stderr.on('data', function (data) {
console.log(self.id + ' HC err: ' + data);
});
headlessInstance.on('close', function (code) {
console.log(self.id + ' HC exited with code ' + code);
self.headlessInstance = null;
});
self.headlessInstance = headlessInstance;
}
this.emit('state');
2014-04-06 22:58:17 +00:00
return this;
};
2014-04-06 22:58:17 +00:00
Server.prototype.stop = function(cb) {
var handled = false;
var self = this;
2014-04-06 22:58:17 +00:00
2014-11-24 00:56:54 +00:00
this.instance.on('close', function (code) {
2014-04-06 22:58:17 +00:00
if (!handled) {
handled = true;
if (cb) {
cb();
}
2014-04-06 22:58:17 +00:00
}
2014-02-13 22:47:51 +00:00
});
2014-04-06 22:58:17 +00:00
2014-11-24 00:56:54 +00:00
this.instance.kill();
2015-02-13 16:13:55 +00:00
if (this.headlessInstance) {
this.headlessInstance.kill();
}
2014-04-06 22:58:17 +00:00
setTimeout(function() {
if (!handled) {
handled = true;
if (cb) {
cb();
}
2014-04-06 22:58:17 +00:00
}
}, 5000);
return this;
2014-06-04 22:17:18 +00:00
};
Server.prototype.toJSON = function () {
return {
admin_password: this.admin_password,
battle_eye: this.battle_eye,
2015-02-13 16:13:55 +00:00
headless: this.headless,
2014-06-04 22:17:18 +00:00
id: this.id,
max_players: this.max_players,
2015-08-23 22:16:16 +00:00
missions: this.missions,
2014-06-04 22:17:18 +00:00
mods: this.mods,
password: this.password,
persistent: this.persistent,
2014-06-04 22:17:18 +00:00
pid: this.pid,
port: this.port,
state: this.state,
title: this.title,
von: this.von,
2014-06-04 22:17:18 +00:00
};
};
2014-02-13 22:47:51 +00:00
module.exports = Server;