Skip to main content

An OpenContest server written in Python

Project description

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/contests is where the contests folder in the container is mapped to on the host and by default creates a new folder called contests in 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.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

opencontest-server-2.8.0.tar.gz (20.9 kB view hashes)

Uploaded Source

Built Distribution

opencontest_server-2.8.0-py3-none-any.whl (22.5 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page