Skip to main content

Asynchronous client library for LG WebOS TVs

Project description

AsyncWebOSTV

An asynchronous Python library for controlling LG WebOS TVs. This is an async port of the popular pywebostv library.

Features

  • Asynchronous API for controlling LG WebOS TVs
  • WebSocket-based communication
  • Support for all major TV controls (media, system, input, applications, TV channels, sources, etc.)
  • Real-time event subscriptions (volume, channel, foreground app, power state, audio output)
  • SSDP-based network device discovery
  • Secure SSL/TLS connections with certificate handling
  • Modern Python async/await syntax
  • Type hints for better IDE support
  • Comprehensive test coverage

Requirements

  • Python 3.11+
  • aiohttp>=3.8.0
  • websockets>=15.0.1

Installation

pip install asyncwebostv

Quick Start

import asyncio
from asyncwebostv.connection import WebOSClient
from asyncwebostv.controls import (
    MediaControl, SystemControl, ApplicationControl, TvControl, InputControl, SourceControl
)

async def main():
    # Create a WebOS client
    client = WebOSClient("192.168.1.100")  # Replace with your TV's IP

    # Connect to TV
    await client.connect()

    # Register with the TV (if needed)
    store = {}  # Dictionary to receive the client key
    async for status in client.register(store):
        if status == WebOSClient.PROMPTED:
            print("Please accept the connection on your TV")
        elif status == WebOSClient.REGISTERED:
            print(f"Registration successful, client key: {store.get('client_key')}")

    # Use the client key for future sessions to avoid re-pairing
    # client_key = store.get("client_key")

    # Create control interfaces
    media = MediaControl(client)
    system = SystemControl(client)

    # Control TV
    await media.volume_up()
    await system.notify("Hello from AsyncWebOSTV!")

    # Close connection
    await client.close()

asyncio.run(main())

Subscriptions

AsyncWebOSTV supports real-time event subscriptions so you don't have to poll the TV. Six subscriptions are available: get_volume, get_audio_output, get_sound_output, get_current_channel, get_current (foreground app), and power_state.

import asyncio
from asyncwebostv.connection import WebOSClient
from asyncwebostv.controls import MediaControl, SystemControl

async def main():
    client = WebOSClient("192.168.1.100", client_key="your-client-key")
    await client.connect()

    media = MediaControl(client)
    system = SystemControl(client)

    async def on_volume(success, payload):
        if success:
            print(f"Volume: {payload.get('volume')} muted={payload.get('muted')}")

    async def on_power(success, payload):
        if success:
            print(f"Power state: {payload.get('state')}")

    await media.subscribe_get_volume(on_volume)
    await system.subscribe_power_state(on_power)

    try:
        await asyncio.sleep(60)  # receive events for a minute
    finally:
        await media.unsubscribe_get_volume()
        await system.unsubscribe_power_state()
        await client.close()

asyncio.run(main())

Reconnect note: after await client.close(), discard your control objects (MediaControl, SystemControl, etc.) and create fresh ones against the new client before resubscribing. See the subscription spec for the full reconnect contract and the complete list of event payloads.

Secure Connections

AsyncWebOSTV supports secure SSL/TLS connections to WebOS TVs. The library provides two classes for secure connections:

SecureWebOSClient

Low-level secure client with enhanced SSL certificate handling:

import asyncio
from asyncwebostv import SecureWebOSClient, extract_certificate

async def main():
    # Extract and save certificate from TV
    cert_file = "tv_cert.pem"
    await extract_certificate("192.168.1.100", 3001, cert_file)

    # Create secure client with certificate verification
    client = SecureWebOSClient(
        host="192.168.1.100",
        port=3001,
        secure=True,
        cert_file=cert_file,
        verify_ssl=True,
        client_key="your-client-key"  # Optional
    )

    # Connect and use as normal
    await client.connect()

    # Close connection
    await client.close()

asyncio.run(main())

SecureWebOSTV

High-level secure client with SSL certificate handling:

import asyncio
from asyncwebostv import SecureWebOSTV

async def main():
    # Create secure TV client
    tv = SecureWebOSTV(
        host="192.168.1.100",
        port=3001,
        cert_file="tv_cert.pem",  # Optional
        verify_ssl=True           # Set to False to skip verification
    )

    # Extract and save certificate
    # await tv.get_certificate("tv_cert.pem")

    # Connect and register if needed
    await tv.connect()
    if not tv.client_key:
        client_key = await tv.register()

    # Now use the client property to access lower-level API
    client = tv.client

    # Close connection
    await tv.close()

asyncio.run(main())

Certificate Utilities

The library includes utility functions for working with TV certificates:

from asyncwebostv import extract_certificate, verify_certificate

# Extract certificate from TV
cert_pem = await extract_certificate("192.168.1.100", 3001, "tv_cert.pem")

# Verify if a saved certificate matches the current one on the TV
matches = await verify_certificate("tv_cert.pem", "192.168.1.100", 3001)

Client Key Management

Unlike some other libraries, AsyncWebOSTV does not save client keys to disk by default. Instead, it returns the client key to the caller through a provided dictionary.

# During registration
store = {}
async for status in client.register(store):
    pass

# After registration, the client key is in the store dictionary
client_key = store.get("client_key")
print(f"Your client key: {client_key}")

# Save it however you want (database, config file, etc.)

For subsequent connections, you can provide the client key directly:

client = WebOSClient("192.168.1.100", client_key="your-client-key")

This approach gives you more control over how client keys are stored and managed in your application.

Documentation

Detailed documentation lives in the docs/ directory:

Development

  1. Clone the repository:
git clone https://github.com/droman42/asyncwebostv.git
cd asyncwebostv
  1. Install development dependencies:
pip install -e ".[dev]"
  1. Run tests:
pytest
  1. Format code:
black .
isort .

Contributing

We welcome contributions! Please see our Contributing Guidelines for details.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

  • Original pywebostv library for inspiration
  • LG for their WebOS platform

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

asyncwebostv-0.3.2.tar.gz (26.9 kB view details)

Uploaded Source

Built Distribution

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

asyncwebostv-0.3.2-py3-none-any.whl (29.8 kB view details)

Uploaded Python 3

File details

Details for the file asyncwebostv-0.3.2.tar.gz.

File metadata

  • Download URL: asyncwebostv-0.3.2.tar.gz
  • Upload date:
  • Size: 26.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for asyncwebostv-0.3.2.tar.gz
Algorithm Hash digest
SHA256 62f296834b2c2ea615365781d2af9a0f9a355a50926d8de083a1d331e6111d19
MD5 154070b181f041ec8a5a229d4ad89c81
BLAKE2b-256 339234f09028bb421b1ec99e83d3439ecd5a559d4956cae8d26a5f1de5b3807a

See more details on using hashes here.

Provenance

The following attestation bundles were made for asyncwebostv-0.3.2.tar.gz:

Publisher: release.yml on droman42/asyncwebostv

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file asyncwebostv-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: asyncwebostv-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 29.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for asyncwebostv-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1cb5634acc7d0f52d1b457ff0bfa3d325c4b29898072208f64655c32520ec478
MD5 8975e8d2537e5e0174b03aa299402162
BLAKE2b-256 42f2f03b25e9ad65b88a4eb0256b734ea518eb6167474ec2ffb8392933981103

See more details on using hashes here.

Provenance

The following attestation bundles were made for asyncwebostv-0.3.2-py3-none-any.whl:

Publisher: release.yml on droman42/asyncwebostv

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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