Python SDK for the Open Voice Interaction Protocol (OpenVIP)
Project description
openvip
Open Voice Interaction Protocol (OpenVIP) HTTP API specification.
This API allows applications to send and receive voice interaction messages.
Quick Start
# Subscribe to messages (SSE) — this IS the registration
curl http://localhost:8770/agents/my-agent-id/messages
# Send a message to an agent
curl -X POST http://localhost:8770/agents/my-agent-id/messages \\
-H \"Content-Type: application/json\" \\
-d '{\"openvip\": \"1.0\", \"type\": \"transcription\", \"id\": \"uuid\", \"timestamp\": \"2026-02-06T10:30:00Z\", \"text\": \"hello\"}'
# Text-to-speech
curl -X POST http://localhost:8770/speech \\
-H \"Content-Type: application/json\" \\
-d '{\"openvip\": \"1.0\", \"type\": \"speech\", \"id\": \"uuid\", \"timestamp\": \"2026-02-06T10:30:05Z\", \"text\": \"hello world\", \"language\": \"en\"}'
Agent Lifecycle
Agents are ephemeral. An agent exists only while its SSE connection is open. No explicit registration is needed — connecting to the SSE endpoint registers the agent. Disconnecting automatically de-registers it.
This Python package is automatically generated by the OpenAPI Generator project:
- API version: 1.0
- Package version: 1.0.0
- Generator version: 7.21.0-SNAPSHOT
- Build package: org.openapitools.codegen.languages.PythonClientCodegen For more information, please visit https://openvip.org
Requirements.
Python 3.9+
Installation & Usage
pip install
If the python package is hosted on a repository, you can install directly using:
pip install git+https://github.com/GIT_USER_ID/GIT_REPO_ID.git
(you may need to run pip with root permission: sudo pip install git+https://github.com/GIT_USER_ID/GIT_REPO_ID.git)
Then import the package:
import openvip
Setuptools
Install via Setuptools.
python setup.py install --user
(or sudo python setup.py install to install the package for all users)
Then import the package:
import openvip
Tests
Execute pytest to run the tests.
Getting Started
Please follow the installation procedure and then run the following:
import openvip
from openvip.rest import ApiException
from pprint import pprint
# Defining the host is optional and defaults to http://localhost:8770
# See configuration.py for a list of all supported configuration parameters.
configuration = openvip.Configuration(
host = "http://localhost:8770"
)
# Enter a context with an instance of the API client
with openvip.ApiClient(configuration) as api_client:
# Create an instance of the API class
api_instance = openvip.ControlApi(api_client)
control_request = {"openvip":"1.0","id":"770e8400-e29b-41d4-a716-446655440000","command":"stt.stop"} # ControlRequest |
try:
# Send control command
api_response = api_instance.send_control(control_request)
print("The response of ControlApi->send_control:\n")
pprint(api_response)
except ApiException as e:
print("Exception when calling ControlApi->send_control: %s\n" % e)
Documentation for API Endpoints
All URIs are relative to http://localhost:8770
| Class | Method | HTTP request | Description |
|---|---|---|---|
| ControlApi | send_control | POST /control | Send control command |
| MessagesApi | send_message | POST /agents/{agent_id}/messages | Send message to agent |
| MessagesApi | subscribe_agent | GET /agents/{agent_id}/messages | Subscribe to agent messages (SSE) |
| SpeechApi | text_to_speech | POST /speech | Text-to-speech request |
| StatusApi | get_status | GET /status | Get engine status |
| StatusApi | subscribe_status | GET /status/stream | Subscribe to status changes (SSE) |
Documentation For Models
- ControlRequest
- Error
- Message
- Response
- SpeechRequest
- SpeechResponse
- Status
- StatusStt
- StatusTts
- Transcription
Documentation For Authorization
Endpoints do not require authorization.
Author
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 Distributions
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 openvip-1.0.0rc2-py3-none-any.whl.
File metadata
- Download URL: openvip-1.0.0rc2-py3-none-any.whl
- Upload date:
- Size: 59.3 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 |
175bad7eb860314cffc886ec8c8fc03b9c4dedddd143b887373de6dc72c47aef
|
|
| MD5 |
fb5ebc7ab1e950a1a7c58028f9ff97b4
|
|
| BLAKE2b-256 |
3dbe317eccbe209c6e741105242b1e41ec2b93bd49b66b40940c1394a2d8ff9f
|
Provenance
The following attestation bundles were made for openvip-1.0.0rc2-py3-none-any.whl:
Publisher:
publish-python.yml on openvip-dev/sdks
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
openvip-1.0.0rc2-py3-none-any.whl -
Subject digest:
175bad7eb860314cffc886ec8c8fc03b9c4dedddd143b887373de6dc72c47aef - Sigstore transparency entry: 999913090
- Sigstore integration time:
-
Permalink:
openvip-dev/sdks@e846cbd9ca3d23111f973f23478630308d59e832 -
Branch / Tag:
refs/tags/v1.0.0rc2 - Owner: https://github.com/openvip-dev
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-python.yml@e846cbd9ca3d23111f973f23478630308d59e832 -
Trigger Event:
push
-
Statement type: