| .github/workflows | ||
| conf | ||
| ocs | ||
| .gitignore | ||
| Dockerfile | ||
| LICENSE | ||
| pyproject.toml | ||
| README.md | ||
| setup.cfg | ||
OpenContest Server
An OpenContest server written using Python's HTTPServer and SQLite, with no external dependencies other than the Python standard library, requests, and Firejail.
Installation
Docker
Run the Docker Hub image:
docker run -d -p 9534:9534 --name opencontest-server -v $PWD/contests:/usr/src/app/contests laduecs/opencontest-server:latest
Note:
$PWD/contestsis where the contests folder in the container is mapped to on the host and by default creates a new folder calledcontestsin the current directory. It can be replaced with the full path to a different if desired.
AUR
Install the opencontest-server-git from the AUR:
paru -S opencontest-server-git
Start the server with systemctl start opencontest-server.
Pip
Install opencontest-server with pip:
pip install opencontest-server
Run the server with ocs.
Usage
You can place contests like the sample contest in a contests directory.
For debugging, you can run the server with the --verbose flag.
For production usage, you should put this server behind a reverse proxy like NGINX or Caddy because Python's HTTPServer does not implement any security features. You will also need to a domain name and a TLS certificate which you can easily obtain using Let's Encrypt.