/srcds-tools

A set of tools for interacting with Source Dedicated Server in node.js (Not actively maintained)

Primary LanguageJavaScriptMIT LicenseMIT

srcds-tools

No Maintenance Intended

A set of tools for interacting with Source Dedicated Server in node.js.

Current version: v0.2.0

Documentation

RConClient

For issuing commands to SRCDS via the Source RCON Protocol, srcds-tools provides the RConClient type. Typical usage is as follows:

var RConClient = require("srcds-tools").RConClient;

var rcon = new RConClient();

rcon.connect("127.0.0.1", 27015);

rcon.sendPassword("password123");

rcon.sendCommand("sv_cheats 1", function (response) {

	// Code to be executed when the server responds

});

.verbose

A boolean which, if set to true, causes the RConClient to output debug information to console.log().

.connect(address, port)

Establishes a TCP connection to the game server. The port can be passed as a second parameter, or as part of the address string. Once connect() is called, it is safe to call sendPassword() immediately.

rcon.connect("127.0.0.1", 27015);

// or

rcon.connect("127.0.0.1:27015");

.sendPassword(password, [callback])

Sends an authentication request to the server using the given password. If RConClient is able to authenticate successfully, callback is invoked. If the server rejects the password, an RConBadPasswordError is passed to the callback as the first parameter. The callback is optional, but highly advised since sending commands after a failed auth attempt can result in an RCON ban from the server.

rcon.sendPassword("dingbats", function (error) {

	if (error) throw error;

	console.log("Authenticated successfully!");

});

.sendCommand(command, [callback])

Instructs the server to execute the specified command. The server's response will be passed to callback if it is specified. If the RCON password changes, sendPassword() will need to be called again or a RConBadPasswordError may be thrown.

rcon.sendCommand("_restart", function (response) {

	console.log("Server says: " + response);

});

.setTimeout(duration)

Changes the maximum duration (in milliseconds) that RConClient will wait for a response before throwing an RConTimeoutError. Default is 1000 (1 second). Calling this method is usually unneccessary unless you want quicker/slower timeouts.

// Future requests will time out in 1/2 second
rcon.setTimeout(500);

Utilities

The srcds-tools module also provides a few utilites that can be used for debugging or independently of the module itself. They are located in the util directory.

RConCLI

RConCLI.js is a simple command-line implementation of RConClient. To use it, simply run the file with node.

node ./util/RConCLI.js