Skip to main content

Samsung Smart TV WS API wrapper

Project description


Samsung Smart TV WS API wrapper Version Lint & Tests

This project is a Python library for remotely controlling Samsung televisions via a TCP/IP connection.

It supports modern (post-2016) Samsung Smart TVs running Tizen OS, connected via Ethernet or Wi-Fi.


Documentation

Most of the general usage and features are documented in this README. Some advanced topics are covered in dedicated documents:

  • Commands
    Detailed remote key reference, including the full key list and all supported ways to send keys via the CLI.

  • Applications (App IDs)
    Extended documentation about application IDs, how to find them, and how to install or launch applications from the TV.

Features

  • WebSocket and REST APIs
  • Sync and async support
  • Encrypted v1 API support for older TVs
  • Full Art Mode support (Frame TVs)
  • Command-line interface (CLI)

Installation

Requires Python >= 3.9.

Install from PyPI (recommended)

Core library:

pip install samsungtvws

Common install (async + encrypted + CLI):

pip install "samsungtvws[async,encrypted,cli]"

Optional extras

  • async: async I/O support (aiohttp, websockets)
  • encrypted: v1 encrypted API support for older Orsay TVs (cryptography, py3rijndael)
  • cli: installs the samsungtv command (typer, wakeonlan)

Examples:

pip install "samsungtvws[cli]"
pip install "samsungtvws[async]"
pip install "samsungtvws[encrypted]"

Install from GitHub (latest main branch)

pip install "git+https://github.com/xchwarze/samsung-tv-ws-api.git#egg=samsungtvws[async,encrypted,cli]"

Local development install

git clone https://github.com/xchwarze/samsung-tv-ws-api.git
cd samsung-tv-ws-api
pip install --editable ".[async,encrypted,cli]"

--editable installs the package in development mode and can be omitted for a regular local install.


CLI check

If installed with the cli extra:

samsungtv --help

Usage

This library can be used either programmatically or via the CLI, depending on the integration needs.

Programmatic usage

For custom integrations or advanced control flows, the library can be consumed directly from Python code.

The examples/ directory contains ready-to-run programmatic examples, including:

  • WebSocket and REST usage
  • Async integrations
  • Encrypted API usage
  • Art Mode control

Reviewing these examples is the recommended starting point for manual integrations.


CLI usage

For quick testing, automation, or scripting, the library provides a fully featured command-line interface. Requires installation with the cli extra.

Once installed:

samsungtv --help

CLI examples

Power on TV using Wake-on-LAN:

samsungtv --host 192.168.1.50 wol

Toggle power:

samsungtv --host 192.168.1.50 power

List installed applications:

samsungtv --host 192.168.1.50 apps

Run an application by ID:

samsungtv --host 192.168.1.50 app-run 3201606009684

Open a URL in the TV browser:

samsungtv --host 192.168.1.50 open-browser https://duckduckgo.com

Get device information:

samsungtv --host 192.168.1.50 device-info

Enable Art Mode:

samsungtv --host 192.168.1.50 art-mode on

Upload an image to Art Mode:

samsungtv --host 192.168.1.50 art-upload image.jpg

The CLI exposes most of the library functionality, including:

  • App management
  • Remote control keys
  • Device information
  • Wake-on-LAN
  • Full Art Mode management

Supported TVs

This library is designed to support all Samsung Smart TVs running Tizen OS (2016+).

It also provides support for older Orsay-based TVs, specifically:

  • H series (2014)
  • Part of J series (2015)

Support for Orsay devices is mainly provided through the encrypted v1 API.

Official Samsung compatibility references:

Known issues and restrictions

Subnet / VLAN

Samsung Smart TVs do not allow WebSocket connections across different subnets or VLANs. If your TV is not on the same subnet as Home Assistant, the connection may fail.

Depending on the network setup, this limitation might be mitigated using:

  • IP masquerading (NAT)
  • A proxy

Samsung TV keeps asking for permission

The default setting on newer televisions is to ask for permission on every connection attempt.

To avoid this behavior, adjust:

Device Connection Manager → Access Notification Settings → First Time Only

It is also recommended to clean up previous attempts in:

Device Connection Manager → Device List

Patreon and Tips!

(I have this block in all my GPL projects) Those who want to help buy testing hardware or just give me a tip, you can do it by sending donations to my Binance account. I also made a Patreon

patreon binance-qr

License

LGPL-3.0

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

samsungtvws-3.0.5.tar.gz (46.5 kB view details)

Uploaded Source

Built Distribution

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

samsungtvws-3.0.5-py3-none-any.whl (48.0 kB view details)

Uploaded Python 3

File details

Details for the file samsungtvws-3.0.5.tar.gz.

File metadata

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

File hashes

Hashes for samsungtvws-3.0.5.tar.gz
Algorithm Hash digest
SHA256 c6f2e1c65736f41e46c24fb95c206b8ac619f6a2bdf1d26186e0f4c4e955105e
MD5 b684d4e72f5d4d3a662f2fbda1acae37
BLAKE2b-256 35765fe4d57979617208ea50628e395e641e3e2aa3183944047a461ebb96275a

See more details on using hashes here.

Provenance

The following attestation bundles were made for samsungtvws-3.0.5.tar.gz:

Publisher: release.yml on xchwarze/samsung-tv-ws-api

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

File details

Details for the file samsungtvws-3.0.5-py3-none-any.whl.

File metadata

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

File hashes

Hashes for samsungtvws-3.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 ede66a79011a1fa062a89afc57e2a12d1c475f7b0fd7d5fef4fe4ab8d0ee9fe1
MD5 a592c45a52ab76e56c48c298742c2b38
BLAKE2b-256 b7b02dd487ad3ef55059cd82ec557edbfa200b93347bfdebdfc8242d2f1e37e2

See more details on using hashes here.

Provenance

The following attestation bundles were made for samsungtvws-3.0.5-py3-none-any.whl:

Publisher: release.yml on xchwarze/samsung-tv-ws-api

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