/warhammer

Warhammer: Age of Sigmar REST API (Unofficial) built with Go and Sqlite. Including OpenTelemetry, Grafana, and Jaeger for logs, metrics, and traces.

Primary LanguageGoMIT LicenseMIT

Warhammer 🔥

A gRPC API for Warhammer Age of Sigmar

Intro ℹ️

Skip to Quick Start

What is this?

  • An API for creating, reading, deleting, and updating a database of Warhammer Age of Sigmar entities.
  • A set of Protobuf schemas to generate your own gRPC client or server
  • A set of OpenAPI specifications to generate your own http client or server

Why?

Most of the knowledge base for Warhammer Age of Sigmar relies on users digging through official PDF manuals. This makes it hard to efficiently find knowledge about the Warhammer universe for creators and players.

The goal of this repository is to empower the Warhammer community to make their own game companion tools in whatever language they please.

Quick Start

# Start the service with Railway
railway run

# OR start the service + database with docker-compose
docker-compose up

# OR deploy the gRPC service + HTTP REST API + PostgreSQL DB with kubernetes
kubectl apply -f deploy/warhammer.yaml

Documentation 📚

The Warhammer Age of Sigmar API provides support for protocol buffers via gRPC and http via REST. View the specifications below and generate your own server or client in any language.

↔️ Protobuf - View or download on buf.build

🌐 Open API - View Open API 3 Specification

Deploy 🚀

Warhammer is deployed with railway.app automatically when a change is merged into the main branch.

# Manual Deploy
railway up

Development ⚙️

# Generate kubernetes manifest
# Generate go code
make build