Website CGI (or page generator) to display Race CTS leaderboards of a Xonotic server.

scuti c7753f4203 merged branch 'templates' (squash) hace 1 mes
doc 0a8611065b Limited line width to 80 characters hace 7 años
include f18aec4ff5 Revised repository organization hace 7 años
output c7753f4203 merged branch 'templates' (squash) hace 1 mes
queries 7b2120d122 main rankings query now places maps with the most records at the top hace 2 años
scripts c7753f4203 merged branch 'templates' (squash) hace 1 mes
src 336352a335 Added compilation flag for static generation (default: cgi) hace 2 años
templates c7753f4203 merged branch 'templates' (squash) hace 1 mes
.gitignore 511d47e4a2 Added ignore file. hace 7 años
LICENSE dad86bc0f2 Added license file hace 7 años
Makefile 336352a335 Added compilation flag for static generation (default: cgi) hace 2 años
README.md c7753f4203 merged branch 'templates' (squash) hace 1 mes

README.md

xdfcgi

A common gateway inferface (CGI) program written in C to display Race CTS leaderboards of Xonotic servers. It can also be a static page generator.

Requirements

sqlite-devel python3 python-sqlite

The first is only needed for compilation of the C program. The latter two are only for the auxiliary script allmaps.py.

Compiling

make makes a CGI program.

make staticgen makes a static page generator.

Usage: CGI Query Strings

The program queries the database db/cts.db (./src/dbquery.c, function static bool executequery)

  • (none)

    • Query file: queries/mranks.sql
    • Requests the map list of the server and related data.
  • ?map=[map name]

    • Query file: queries/mleaderboard-ojoin.sql
    • Requests the leaderboard of the map.
  • ?player=[clientid]

    • Query file: queries/rplayers.sql
    • Requests a player's ranks for all maps leaderboards s/he is present on.

Usage: Static Page Generation

python scripts/allmaps.py

The CGI program is still invoked in static generation. The files allmaps.py, output/leaderboard.css, overview.html, map.html produce the output.

Before executing allmaps.py, copy and modify the templates.

cp templates/overview.html .
cp templates/map.html .

allmaps.py outputs an html file for all distinct maps in the database. The leaderboards for each map (equivalent to ?map=[map name]) are in output/maps/.

Game Versions Used Under:

  • Xonotic 0.8.1
  • Xonotic 0.8.2

Compilers

  • gcc (GCC) 10.2.1
  • MinGW, GCC 4.7.1

This program uses an sqlite3 database file created from ~/.xonotic/data/data/server.db.

The database may be built using xonotic-py-sqlite3-defrag2db.