Skip to content

Unreal Tournament stats tracking website for the utstats-lite mutator

Notifications You must be signed in to change notification settings

scottadkin/node-utstats-lite

Repository files navigation

Node UTStats Lite

Unreal Tournament stats website for the https://github.com/rxut/UTStatsLite

Requirements

  • MYSQL Server
  • Node.js 18.17 or later.

Installing

  • Extract the contents of the archive into a folder.
  • Open a terminal in the folder you extracted to.
  • Run the command npm install to install all dependencies.
  • Open config.mjs and change the settings to connect to your mysql server.
  • If you are using an ARM OS you will have to follow this(https://github.com/Automattic/node-canvas?tab=readme-ov-file#compiling) additional step to get the canvas package to install otherwise you will get an error message
  • Run the command node install.mjs to create the database and other settings.

How to change website port

  • Open package.json in the main directory.
  • Find the "scripts" block.
  • Find the line "start": "next start",.
  • To change the port simply add -p portnumber after next start, for example "start": "next start -p 8080", will run the website on port 8080.
  • You can also do the same with the dev mode "dev": "next dev", -> "dev": "next dev -p 8080",

Starting The Website

  • Open a terminal in the folder you installed to.
  • Run the command npm run build to build the website.
  • Once the website has been built, run the command npm run start
  • Open http://localhost:3000 with your browser to see the result.
  • To Create an admin account go to http://localhost:3000/register, the first account is auto activated, every following account needs to be activated.
  • To Login go to http://localhost:3000/login
  • To go to the admin area go to http://localhost:3000/admin
  • In the admin you can then add S/FTP servers to the importer list. ftp admin image
  • If you want to separate gametypes by team sizes, for example CTF 1v1, CTF 2v2 there is now a setting for each ftp server and logs folder called append team sizes, if the all teams have the same amount of players the importer will now append the team sizes to the end of the gametype to keep rankings/records separate.

Running The Log Importer

  • Open a terminal in the folder you installed to.
  • Run the command node importer.mjs.

Converting Node UTStats 2 FTP Settings To Lite

  • If you want to insert all your ftp settings from node utstats-2 you need to create a backup with the node utstats 2 admin tool.
  • Open the archive.
  • Place nstats_ftp.json in the main directory of your node utstats lite folder.
  • Run the command node nutsftptolite.mjs
  • You should now see the settings added in the admin area.

Match JSON API

You can fetch json data of matches via match ids or permahashes(recommended) by using the following path /api/json/match/?id=matchid. You have options to ignore certain data by appending a comma separated list &ignore=type1,type2 An example for ignoring player weapon stats and multikills,sprees would be https://example.com/api/json/match/?id=1337&ignore=weapons,special Valid Ignore types are:

Optional Damage Mutator

You can enable basic damage tracking for players by adding this mutator So far there is only match player data displayed for damage.

About

Unreal Tournament stats tracking website for the utstats-lite mutator

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published