Control USB connected LED lights, like a human.
Project description
BusyLight for Humans controls USB LED lights from multiple vendors. Use the command-line interface or HTTP API to turn lights on/off, change colors, and apply effects.
What is BusyLight?
BusyLight provides simple control over USB LED status lights to show your availability, build status, system health, or any other visual indicator. Perfect for home offices, development workflows, and team collaboration.
Key Features:
- 23 supported devices from 9 vendors (Blink1, BlinkStick, Luxafor, etc.)
- Command-line interface with intuitive color and effect controls
- HTTP API with full documentation for automation and integration
- Multi-LED targeting for devices with multiple independent LEDs
- Cross-platform support for macOS and Linux (and maybe Windows, it's spotty).
Supported Hardware
| Vendor | Models | LED Support |
|---|---|---|
| Agile Innovative | BlinkStick, BlinkStick Pro, BlinkStick Square, BlinkStick Strip, BlinkStick Nano, BlinkStick Flex | Multi-LED targeting |
| Compulab | fit-statUSB | Single LED |
| EPOS | Busylight | Single LED |
| Embrava | Blynclight, Blynclight Mini, Blynclight Plus | Single LED |
| Kuando | Busylight Alpha, Busylight Omega | Single LED |
| Luxafor | Flag, Orb, Mute, Busy Tag, Bluetooth variants | Flag: Multi-LED, Others: Single LED |
| MuteMe | MuteMe Original, Mute Mini, MuteSync | Single LED |
| Plantronics | Status Indicator | Single LED |
| ThingM | Blink(1), Blink(1) mk2 | mk2: Multi-LED |
Installation
Basic Install (CLI only)
# Using uvx (recommended)
uvx --from busylight-for-humans busylight list
# Using pip
pip install busylight-for-humans
Web API Install
# Using uvx
uvx --from "busylight-for-humans[webapi]" busyserve
# Using pip
pip install busylight-for-humans[webapi]
Linux Setup
Linux requires udev rules for USB device access:
busylight udev-rules -o 99-busylights.rules
sudo cp 99-busylights.rules /etc/udev/rules.d/
sudo udevadm control -R
# Unplug and reconnect your device
Quick Start
Command Line
# Basic usage
busylight on # Green light
busylight on red # Red light
busylight blink blue # Blinking blue
busylight off # Turn off
# Multi-LED devices (Blink1 mk2, BlinkStick, etc.)
busylight on red --led 1 # First LED only
busylight on blue --led 2 # Second LED only
busylight rainbow --led 1 # Rainbow on first LED
busylight pulse green --led 2 # Pulse on second LED
Web API
# Start the server
busyserve
# Control via HTTP
curl "http://localhost:8000/light/0/on?color=red"
curl "http://localhost:8000/light/0/blink?color=blue&count=5"
curl "http://localhost:8000/lights/off"
# Multi-LED targeting
curl "http://localhost:8000/lights/on?color=red&led=1"
curl "http://localhost:8000/lights/rainbow?led=2"
Documentation
- Installation Guide - Detailed setup for all platforms
- CLI Reference - All commands, options, and examples
- Web API Guide - REST endpoints and integration examples
- Device Support - Full compatibility matrix and LED targeting
- Integration Examples - CI/CD, monitoring, and automation
Contributing
- Development environment setup
- Testing and code quality guidelines
- Architecture overview and design patterns
- Pull request process and coding standards
Support
- Report Issues - Bug reports and feature requests
- Request Device Support - New hardware support
- Discussions - Community help and questions
Gratitude
Thank you to @todbot and ThingM for graciously gifting
blink(1) mk3 lights to support this project!
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file busylight_for_humans-0.45.3.tar.gz.
File metadata
- Download URL: busylight_for_humans-0.45.3.tar.gz
- Upload date:
- Size: 1.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
71811ca3f4d33373a58b508680caadf1b3966acbbad9ad9e00694683597a907d
|
|
| MD5 |
6e9773c80f973521d55375c6a8ad7c27
|
|
| BLAKE2b-256 |
4df133394267db0dc3fb2bda0977dc3fafc0691fd6d71254e2de8cbde51fae6c
|
Provenance
The following attestation bundles were made for busylight_for_humans-0.45.3.tar.gz:
Publisher:
release.yaml on JnyJny/busylight
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
busylight_for_humans-0.45.3.tar.gz -
Subject digest:
71811ca3f4d33373a58b508680caadf1b3966acbbad9ad9e00694683597a907d - Sigstore transparency entry: 768713777
- Sigstore integration time:
-
Permalink:
JnyJny/busylight@a24e3d4141cb669d5d6c422259cef3e2c5505e67 -
Branch / Tag:
refs/tags/v0.45.3 - Owner: https://github.com/JnyJny
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@a24e3d4141cb669d5d6c422259cef3e2c5505e67 -
Trigger Event:
push
-
Statement type:
File details
Details for the file busylight_for_humans-0.45.3-py3-none-any.whl.
File metadata
- Download URL: busylight_for_humans-0.45.3-py3-none-any.whl
- Upload date:
- Size: 57.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
edcec3725935037bc1046b5aa2704d6cf3490be6e2a203f300205cd1add85b8f
|
|
| MD5 |
ce36304e277f43513c641310a41f37f1
|
|
| BLAKE2b-256 |
2b582899778cb582d2e9f55a95e9e546d8525182e4c90d8515206c7a8bd77471
|
Provenance
The following attestation bundles were made for busylight_for_humans-0.45.3-py3-none-any.whl:
Publisher:
release.yaml on JnyJny/busylight
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
busylight_for_humans-0.45.3-py3-none-any.whl -
Subject digest:
edcec3725935037bc1046b5aa2704d6cf3490be6e2a203f300205cd1add85b8f - Sigstore transparency entry: 768713782
- Sigstore integration time:
-
Permalink:
JnyJny/busylight@a24e3d4141cb669d5d6c422259cef3e2c5505e67 -
Branch / Tag:
refs/tags/v0.45.3 - Owner: https://github.com/JnyJny
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yaml@a24e3d4141cb669d5d6c422259cef3e2c5505e67 -
Trigger Event:
push
-
Statement type: