Skip to main content

Football bet rest server

Project description

Yak-toto

PyPI Docker Image Python Versions codecov 🔐 CodeQL Testing

Requisites

  • Ubuntu 22.04
  • Postgres 17.2

How to build the project

Database

To setup a database, run yak env init. This will ask you to fill different configuration in order build env file. Once done, you can run a docker script to start postgres database (at scripts/postgresrun.sh)

Backend

Run your project in a Python env is highly recommend. You can use venv python module using the following command:

uv venv
. .venv/bin/activate

Fetch all packages using uv with the following command:

uv pip install -e .

Before starting the backend, add JWT_SECRET_KEY and JWT_EXPIRATION_TIME in .env same as the Postgres user name and password. As login system is using JSON Web Token, a secret key is required and an expiration time (in seconds). To generate one, you can use the python built-in secrets module.

>>> import secrets
>>> secrets.token_hex(16)
'9292f79e10ed7ed03ffad66d196217c4'
JWT_SECRET_KEY=9292f79e10ed7ed03ffad66d196217c4
JWT_EXPIRATION_TIME=1800

Also, automatic backup can be done through yak_server/cli/backup_database script. It can be run using yak db backup.

Finally, fastapi needs some configuration to start. Last thing, for development environment, debug needs to be activated with a additional environment variable:

DEBUG=1

And then start backend with:

uvicorn --reload yak_server:create_app --factory

Data initialization

To run local testing, you can use the script create_database.py, initialize_database.py and create_admin.py located in yak_server/cli folder. To select, set COMPETITION environment variable in .env. It will read data from yak_server/data/{COMPETITION}/.

Testing

Yak-server is using pytest to run tests.

Profiling

You can run the application with profiler attached. To do so, please run the following command

uvicorn --reload scripts.profiling:create_app --factory

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

yak_server-0.81.0.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

yak_server-0.81.0-py3-none-any.whl (1.3 MB view details)

Uploaded Python 3

File details

Details for the file yak_server-0.81.0.tar.gz.

File metadata

  • Download URL: yak_server-0.81.0.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for yak_server-0.81.0.tar.gz
Algorithm Hash digest
SHA256 2eb6b3682aef2b2d0752545692fef805dd9b6c8eb77473d71175f3106a1f1026
MD5 1936c36917ff81883409831dd287ede8
BLAKE2b-256 e0e34ceff4d8878af4f8a4dcf6f6b87a7c48888f195cf3276b4b62bf9c5f74df

See more details on using hashes here.

Provenance

The following attestation bundles were made for yak_server-0.81.0.tar.gz:

Publisher: release.yml on yak-toto/yak-server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file yak_server-0.81.0-py3-none-any.whl.

File metadata

  • Download URL: yak_server-0.81.0-py3-none-any.whl
  • Upload date:
  • Size: 1.3 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for yak_server-0.81.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d394982cbdea6a97cdb7505f5528f3fc912eb7ad68c746f5a639f10a9241906d
MD5 ac19925d93e4d1eb3e59b156d17d844d
BLAKE2b-256 d4b00d5d0f746672ed96b429438c0149c24ae23b76c83e6d50765dc16d408b5e

See more details on using hashes here.

Provenance

The following attestation bundles were made for yak_server-0.81.0-py3-none-any.whl:

Publisher: release.yml on yak-toto/yak-server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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