Skip to main content

Python client library and CLI tool for Volumio

Project description

volumito

Python client library and CLI tool for Volumio.

Overview

volumito is a Python library and a command-line tool that allows you to interact with your Volumio player, programmatically or on a shell.

Features

  • Clean Python API to connect to and control a Volumio player
  • Built-in comprehensive command-line tool with a lot of options
  • Type-safe implementation with full type hints
  • Comprehensive test coverage (100%)

Requirements

  • Python 3.13 or later
  • A running Volumio player

Installation

From PyPI

Activate your virtual environment (volumito_env), and install:

(volumito_env) $ pip install volumito

From Source

Clone the repository and install from source in a virtual environment:

$ git clone https://github.com/pettarin/volumito
$ cd volumito

$ # here Micromamba is used, choose your favorite
$ # package/virtual environment manager
$ micromamba env create -f environment.yml
$ micromamba activate volumito_dev

(volumito_dev) $ pip install -e .
(volumito_dev) $ # or
(volumito_dev) $ make install-e-this

(volumito_dev) $ # for developing volumito, use the dev configuration:
(volumito_dev) $ pip install -e .[dev]
(volumito_dev) $ # or
(volumito_dev) $ make install-e-this-dev

Usage

Basic Command

Query a Volumio instance at the default location (volumio.local:3000):

volumito info

Connection Options

Specify custom connection parameters:

# Custom host
volumito info --host my-volumio.local
volumito info --host 192.168.1.100

# HTTPS connection
volumito info --scheme https

# Custom ports
volumito info --rest-api-port 8080 --mpd-port 7000

# Custom timeout (in seconds)
volumito info --timeout 10

Output Formats

Choose from multiple output formats:

# Pretty JSON with 4-space indentation (default)
volumito info --format pretty

# Compact JSON with 2-space indentation
volumito info --format json

# Human-readable table
volumito info --format table

# Raw unformatted JSON
volumito info --raw

Field Filtering

Control which fields are displayed:

# Show only key playback information (default)
volumito info --fields short

# Show all available fields
volumito info --fields all

Short fields include:

  • position
  • title
  • artist
  • album
  • samplerate
  • bitdepth
  • channels
  • service
  • duration

Verbosity Control

# Verbose mode - show connection details
volumito info --verbose

# Quiet mode - suppress error messages
volumito info --quiet

Examples

Combine options for specific use cases:

# Table format with all fields
volumito info --format table --fields all

# Pipe to jq for advanced JSON processing
volumito info --raw | jq '.title, .artist'

# Save state to file
volumito info --format json > volumio_state.json

# Monitor playback every 5 seconds
while true; do
    clear
    volumito info --format table
    sleep 5
done

Album Art

Get the current album art URL:

# Get URL only
volumito track albumart

# Download album art to file
volumito track albumart -o albumart.jpg

# With custom host and save path
volumito track albumart --host 192.168.1.100 -o /path/to/albumart.jpg

Development

Setup Development Environment

# Create micromamba environment
micromamba create -n volumito_dev python=3.13

# Activate environment
micromamba activate volumito_dev

# Install in development mode
pip install -e .

Running Tests

# Run all checks (tests, linter, and type checker)
make test
# OR equivalently
make test-all

# Run unit tests only
make test-unit

# Run tests with coverage
make coverage

# Run linter
make lint

# Run type checker
make check-type-hints

Project Structure

TODO

volumito/
├── src/
│   └── volumito/
│       ├── __init__.py
│       ├── api_client.py    # Volumio API client
│       └── cli.py           # Click-based CLI
├── tests/
│   ├── test_api_client.py
│   └── test_cli.py
├── examples/
│   └── README.md
├── pyproject.toml
├── Makefile
└── README.md

API Reference

TODO

License

This project is licensed under the GNU General Public License v3.0 or later (GPLv3+).

See the LICENSE file for details.

Authors

  • Alberto Pettarin (Web)

Contributing

Contributions are not currently being accepted, as the Python API is not stable yet.

Legal Disclaimers

Volumio and Volumio logo are a registered trademark of Volumio SRL, a company registered in Italy (VAT ID: IT07009020483).

Please refer to the Volumio Terms Of Service.

This project and its authors are not affiliated nor endorsed by Volumio SRL.

Project details


Download files

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

Source Distribution

volumito-0.0.1.tar.gz (36.8 kB view details)

Uploaded Source

Built Distribution

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

volumito-0.0.1-py3-none-any.whl (26.8 kB view details)

Uploaded Python 3

File details

Details for the file volumito-0.0.1.tar.gz.

File metadata

  • Download URL: volumito-0.0.1.tar.gz
  • Upload date:
  • Size: 36.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.0

File hashes

Hashes for volumito-0.0.1.tar.gz
Algorithm Hash digest
SHA256 e32f4b000966abdd30e035e0ab41cb9ff1c91a96ea532ca90f145f1ad0341221
MD5 85991f18dd23860a8fa0e91ead569d44
BLAKE2b-256 82528eca18abd58500ea55ad05f8b7ff3061afcd71aea8a37b6117d396b8065b

See more details on using hashes here.

File details

Details for the file volumito-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: volumito-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 26.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.0

File hashes

Hashes for volumito-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f57bd7e46302fb4ed9e7e0cc85835a7386d5c04dfa25937e8b625775fe781db3
MD5 ee420bd9c40bfed7b2d7ae5ff58d4ef0
BLAKE2b-256 1ace7769e3e71f04f2f5b5a94f0b66214eca0d88106948bba80ff5804e088bd8

See more details on using hashes here.

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