/SquireCore

The backend library used by Squire Tournament Services

Primary LanguageRustGNU Affero General Public License v3.0AGPL-3.0

Crates.io Documentation GitHub Workflows Coverage Status Maintenance

Overview

This repo contains the core functionalities of Squire Tournament Services. STS aims to provide highly flexible tools for organizing and running Magic: the Gathering tournaments. This includes pairing algorithms that can handle an arbitrary number of players, highly customizable scoring systems and scoring methods, and allowing for on-the-fly adjustments of all settings.

Here you will find three primary subdirectories that all Squire services utilize.

Starting off, the tournament model is defined in squire_lib. This is the very core of STS. Our tournament model is where we implement all of the aforementioned features. Every Squire client uses this library to ensure a uniform tournament experience everywhere.

Next, the backend server can be found in squire_core. This connects most clients together and helps them manage and synchronize their tournament data.

Lastly, there is the squire_sdk. The SDK is a general toolkit used by both the backends (namely squire_core) and all clients. It contains a model for synchronizing tournaments between clients and a backend, a generic client for communicating with a backend and that can be customized to fit the client's needs, as well as API data models used for sending and receiving requests from a backend.

How It Works

All Squire services work under a local-first model. This means that the status of the SquireCore backend will have limited effect on a client's ability to run and manage a tournament.

To do this, every service (client or backend) needs to share the same implementation of the tournament model and tournament sync procedure. This is the job of squire_lib and squire_sdk, respectively.

This is why everything in this repo is written in Rust. It is a language that can be distributed very easily across most platforms, can be run in the browser via WebAssembly (WASM), and is light-weight and reliable.

Clients and Services

Currently, there are two ready Squire services outside of this repo:

SquireDesktop is a native desktop application that lets you create and manage tournaments from your desktop. Like any Squire client, it can back up all tournament data to SquireCore in order to make it publicly accessible.

SquireBot is a Discord bot that can be used as a full Squire client, like the desktop. However, its primary use case is to notify players about the status of the tournament, such as being paired for a new match, the time left in the round, and the current standings.

There are plans for many more services in the future. To learn more, see our future plans.

Contributing

To contribute to the project, create branches off the repository itself (don't fork into your own namespace) and open PR's against the main branch. All PR's are subject to review.

Basic Setup

To construct the environment and run the project in development, you'll need to install a few things:

  • Rust
  • Docker (installed and running)
  • Possibly MongoDB

Debian Bullseye Specific Setup

A couple steps that are specific to Debian Bullseye, but which may or may not be relevant to other systems.

First install a couple requirements:

sudo apt install -y gcc libssl-dev pkg-config

Secondly, we need to be able to run Docker without root:

sudo usermod -a -G docker <your username>

Finally

cargo install cargo-shuttle
cargo install trunk // make sure to run these to installs separately
rustup target add wasm32-unknown-unknown
cargo shuttle run

For development, you will need to run the backend via Shuttle and the frontend via trunk. The trunk process will need to be configured to proxy calls to the backend. To run the backend, run the follow command while your working directory is SquireCore/squire_core:

cargo shuttle run

To run the frontend, run the following command while your working directory is SquireCore/squire_web:

trunk serve --proxy-backend http://localhost:8000/api --proxy-rewrite /api/

Trunk will attempt to recompile and serve the frontend when you save your changes. If successful, the frontend will reload with the new frontend.

Current and Future State

This repo (and STS as a whole) are still growing rapidly. Currently, everything in this repo is focused around proving the functionality of the tournament model; however, SquireCore (and therefore SquireSDK) will soon support many more things:

  • Searchable and queryable APIs for finding tournaments
  • Users, so players can track their involvement across tournaments
  • Organizations, to make finding tournaments easier for players and creating/managing tournament easier for organizers

We also have plans for the following services, all of which will be integrated together:

  • SquireWeb, our web frontend for all-things Squire
  • SquireMobile, Android and Apple mobile apps for players to manage participation in tournaments
  • SquireJudge, mobile apps designed for judges and TOs to track and manage parts of a tournament
  • SquireFall, a public database for searching and querying past tournament data (akin a tournament version of Scryfall)