simple FastAPI server to host TTS plugins as a service
Project description
OpenVoiceOS TTS Server
Turn any OVOS TTS plugin into a microservice — a small, stateless FastAPI app that exposes a TTS plugin over HTTP.
Install
pip install ovos-tts-server
# Optional: enable non-WAV output (mp3, ogg, flac, ...) via pydub
pip install "ovos-tts-server[audio]"
Companion plugin
Use in your voice assistant via the companion TTS plugin.
Configuration
The plugin is configured the same way as if it were running inside the assistant — through mycroft.conf:
{
"tts": {
"module": "ovos-tts-plugin-piper",
"ovos-tts-plugin-piper": {
"model": "alan-low"
}
}
}
Usage
ovos-tts-server --help
usage: ovos-tts-server [-h] [--engine ENGINE] [--port PORT] [--host HOST] [--cache]
options:
-h, --help show this help message and exit
--engine ENGINE tts plugin to be used
--port PORT port number (default: 9666)
--host HOST host (default: 0.0.0.0)
--cache save every synth to disk
Example — serve the Piper plugin:
ovos-tts-server --engine ovos-tts-plugin-piper --cache
Then GET http://localhost:9666/synthesize/hello.
Endpoints
| Method | Path | Description |
|---|---|---|
| GET | /status |
Plugin name, supported languages, default voice/model |
| GET | /v2/synthesize?utterance=<text>[&lang=...][&voice=...] |
Primary synthesis endpoint — returns WAV audio |
| GET | /synthesize/<utterance> |
Legacy path-based synthesis endpoint |
CORS is enabled for all origins.
Third-party API compatibility
The server can additionally expose its underlying TTS plugin behind drop-in compatibility endpoints for popular cloud TTS APIs — MaryTTS, ElevenLabs, OpenAI, Coqui, Google Cloud TTS, Amazon Polly, Azure, and Piper. Each vendor lives under its own URL prefix so multiple compat layers coexist with no path collisions. Auth tokens are accepted and silently ignored — wrap behind a reverse proxy if you need real auth.
See docs/api-compatibility.md for the full reference.
Documentation
Docker
Build a small image that serves any plugin:
FROM python:3.11-slim
RUN pip install --no-cache-dir "ovos-tts-server[audio]" {PLUGIN_HERE}
ENTRYPOINT ["ovos-tts-server", "--engine", "{PLUGIN_HERE}", "--cache"]
docker build . -t my_ovos_tts_plugin
docker run -p 8080:9666 my_ovos_tts_plugin
Then GET http://localhost:8080/synthesize/hello.
Each plugin can ship its own Dockerfile in its repository using ovos-tts-server.
Development
pip install -e ".[audio,test]"
pytest test/ -v
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 ovos_tts_server-1.4.0a1.tar.gz.
File metadata
- Download URL: ovos_tts_server-1.4.0a1.tar.gz
- Upload date:
- Size: 13.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
705c92c80d01859ebc99ffce163d9228f5de8ea31eed334a56dcab2c9711ffef
|
|
| MD5 |
72b99050bd05ea777310e13461783a15
|
|
| BLAKE2b-256 |
bc54e11df317734a8de992e12d9f5346fc40b139515b922632271e1a635208c2
|
File details
Details for the file ovos_tts_server-1.4.0a1-py3-none-any.whl.
File metadata
- Download URL: ovos_tts_server-1.4.0a1-py3-none-any.whl
- Upload date:
- Size: 15.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
757534af2473b1c6a9bceb53f41119c59a6a1fe9f9f89443510b08f163ed319d
|
|
| MD5 |
818138bedf945c201523ff0893f83c84
|
|
| BLAKE2b-256 |
18cc1b09bc4f9f5787ec7efc15d2ac75adcc2ea2536653d5a9e5a09369840397
|