Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

update Readme and some more error handling #41

Merged
merged 1 commit into from
Mar 2, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 11 additions & 21 deletions README.MD
Original file line number Diff line number Diff line change
@@ -1,24 +1,19 @@
# CS2 Server Control with a Nodejs-powered web-API (LINUX only)
this API is used to start/stop/update a CS2 linux dedicated server and control it via rcon.
The backend accepts RESTful api calls authenticated either via steamID or a configurable user with hppt authentication for stateless API calls.
The backend accepts RESTful api calls authenticated either via steamID or a configurable user with http authentication for stateless API calls.
A full featured example webinterface is provided to get a quick start on the application.

## Disclaimer
The use of this software is at your own risk.
It exposes control of your server and shell functions to the internet. Although I did everything to secure the API, any bugs may lead to security breaches on your server.
I strongly adivise to use secure connections to prevent possible man-in-the-middle attacks.

## CS2 Beta Info
### New in Beta.3:
- Reworked the code, to make the initial configuration much easier.
- Example Webinterface is now served via the app, so you don't need to configure a seperate webserver.
- Made using websockets for data-transfer to Webinterface the standard.

### This is a beta release for CS2. It has the following changes to previous functionality
### This is the first release for CS2. It has the following changes to previous functionality
- The Steam-Api calls for the map details now need an API-Token. See configuration section below for details.
- Changed Log-reception to http logs, since UDP is not supported anymore in new server. Unnecessary library source-log-receiver removed.
- Maplist loading is still bugged in CS2 Server - therefore working with a static Maplist.
- Still working with the old CS_GO map-pictures, since the new ones are not yet available in the workshop
- API calls are unchanged.
- Maplist loading has changed to the worse, see [Maps TL;DR](https://github.com/Taraman17/nodejs-cs2-api/blob/master/MAPS.MD) for details how the API deals with it.
- Changed API calls (non braking).
- mapchange can now be done with map-filename (without extension), workshop-id or map-title as argument.
- added API endpoints for pausing and resuming the match (/control/pause & /control/unpause). Status is tracked in serverInfo.pause (false/true).

## Prerequisites
Expand Down Expand Up @@ -71,9 +66,9 @@ Start the script with
```console
node serverControl.js
```
In your brower open http://\<yourIP>:8090/gameserver.htm
In your browser open http://\<yourIP>:8090/gameserver.htm to see the example webinterface

The API will detect a running server and connect to it.
If the server is already running in a screen, the API will detect a running server and connect to it.

To start the API on boot and have it running in the background, I recommend [PM2](https://pm2.keymetrics.io/)

Expand Down Expand Up @@ -118,7 +113,7 @@ The /control message will return a JSON-String.
If run without startmap, server will be started with de_dust2.
- stop -> stop the server with RCON 'quit': { "success": true/false }
- kill -> use 'kill' command to shutdown the server, if RCON connection is not working: { "success": true/false }
- changemap -> additional argument "map" (action=changemap&map=mapname):
- changemap -> additional argument "map" (action=changemap&map=mapfilename/workshopid/title):
- reloadmaplist -> reload the available maps on the server (action=reloadmaplist): { "success": true/false }

If you do not use websockets, the answer will be sent after completion of the operation.
Expand Down Expand Up @@ -188,7 +183,7 @@ UpdateProgress looks as follows:
{ "type": "updateProgress", "payload": { "step": <string>, "progress": <int> } }
```
## Api calls with http authentication
For stateless API-Calls via command line or other automatic tools the http basic authentication can be activated in the config with
For stateless API-Calls via command line or other automatic tools the http basic authentication can be activated in the config with:
```
"httpAuth": true,
"httpUser": { "username": "", "password": "" },
Expand All @@ -202,12 +197,7 @@ The interface is:
http://<your-servers-address>:<your-port>/csgoapi/http/v1.0/...
```

## Example
An example of a webinterface is available in the folder "example"
It assumes, that you run it on the same domain as the API. If you want to change that, you can do so in js/gameserver.js (see comment in the file)
To correctly load the maplist for server start, edit the respective line at the beginning of gameserver.js.
The Webinterface works with and without websockets.

## Support
If you have any questions, contact me.

If you find any bugs or have feature requests, don't hesitate to open an issue.
2 changes: 2 additions & 0 deletions modules/apiV10.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
* @requires child_process
* @requires node-pty
* @requires express
* @requires express.Router
* @requires ./logger.js
* @requires ./config.js
* @requires ./serverInfo.js
* @requires ./controlEmitter.js
Expand Down
4 changes: 2 additions & 2 deletions modules/sharedFunctions.js
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ async function reloadMaplist() {
res.on('end', () => {
if (res.statusCode != 200) {
logger.warn(`getMapDetails api call failed. Status = ${res.statusCode}`);
reject([]);
reject('Api call was unsuccessful');
} else {
try {
let resJson = JSON.parse(resData);
Expand All @@ -140,7 +140,7 @@ async function reloadMaplist() {
resolve(returnDetails);
} catch (e) {
logger.warn(`Reading map details failed: ${e}`);
reject([]);
reject('Could not read map details from api response');
}
}
});
Expand Down
Loading