2022-02-19 21:00:58 -08:00
2017-09-14 13:43:40 -07:00
2017-09-12 02:48:29 -07:00
2022-02-16 17:41:34 -08:00
2017-03-13 22:37:08 -07:00
2022-02-16 17:41:34 -08:00
2017-09-14 13:27:29 -07:00
2022-02-19 21:00:58 -08:00
2022-02-19 21:00:58 -08:00
2022-02-19 21:00:58 -08:00

xdfcgi

A common gateway inferface (CGI) program written in C to display data related to Race CTS leaderboards of Xonotic servers. It may also serve as 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.

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.

Static Page Generation

The files allmaps.py, output/leaderboard.css, template-generic.html, template_map-generic.html are for static page generation. Before executing allmaps.py, copy and modify the templates.

cp ./template-generic.html ./template.html
cp ./template_map-generic.html ./template_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/.

python allmaps.py

Game Versions Used Under:

  • Xonotic 0.8.1
  • Xonotic 0.8.2

Compilers

  • 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.

Description
Website CGI (or page generator) to display Race CTS leaderboards of a Xonotic server.
Readme 149 KiB
Languages
C 57.7%
Python 35.9%
HTML 3.4%
Makefile 2.3%
CSS 0.7%