stagedings

June 13, 2026 ยท View on GitHub

An API to navigate scenes and subscenes that has been configured in a mididings script

PyPI Python OpenAPI Spec Discourse


What does stagedings allow?

  • A web-based interface
    • Alternative of the legacy livedings UI, which was based on Tkinter ๐Ÿช“
  • A HTTP layer that facilitates control and navigation allowing the abstraction of OSC subcalls
  • An OpenAPI specification making possible to generate a client SDK in multiple language with a code generator like Kiota making possible to use the API in .NET, Go, Java, PHP, Python, Ruby and TypeScript.

โš ๏ธ A scene patch dictionary defined in the run section of your mididings script is required to work correctly, check the run function documentation for more information on how to structure your patch.

๐Ÿ“˜ API documentation

Frontend

A responsive multiclient, real-time interface for scene/subscene navigation

stagedings UI screenshot

Features

  • Web UI with real-time scene/subscene updates
  • FastAPI backend with full REST and WebSocket support
  • Multiple clients supported
  • Use the mididings OSC interface
  • It exposes a fully compliant OpenAPI spec for easy generation of SDK clients in any language, enabling flexible remote control of mididings

The frontend allow

  • Direct navigation through scenes and subscenes
  • Exposes the Restart, Panic, Query and Quit commands

The backend allow

  • Endpoints for direct navigation through scenes and subscenes
  • Endpoints to the Restart, Panic, Query and Quit commands

โ„น๏ธ About commands

  • Restart will restart mididings process
  • Panic send not off to all ports and all channels
  • Quit stop mididings, be carefull
  • Query is a work in progress

โš’๏ธ Installation from PyPI

NOTE: This will also install mididings with OSC and AutoRestart support allowing a full working stack.

# Create a Python virtual environment
$ python3 -m venv .venv
$ source .venv/bin/activate

# Install stagedings including mididings as a dependency
$ pip install stagedings

โ–ถ๏ธ Running the application

$ stagedings [--host HOST] [--port PORT]

Options

  • --host
    • FastAPI server bind address
      • Default: localhost
      • Use 0.0.0.0 to allow network access or the server IP address
  • --port
    • FastAPI + WebSocket server port
      • Default: 5000

Use cases

Local development (single machine)

$ stagedings

This runs everything locally on:

http://localhost:5000

Network / multi-client setup

When clients access the server from other machines, you must expose the backend:

$ stagedings --host 0.0.0.0

or:

$ stagedings --host 192.168.1.100

Accessing the UI

Once running, open in a browser:

http://dings.local.com:5000

or:

http://192.168.1.100:5000

High Level Overview

stagedings UI screenshot

๐Ÿ”— Communication Workflow

stagedings UI screenshot

๐Ÿ’ฌ Feedback & Contributions

We welcome bug reports, feature ideas, and contributions! Please open an issue or discussion

๐Ÿ“œ License

All files in this repository are released under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 or later of the License.

Made in Quรฉbec ๐Ÿ‡จ๐Ÿ‡ฆ