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.4.tar.gz (45.8 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.4-py3-none-any.whl (48.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for samsungtvws-3.0.4.tar.gz
Algorithm Hash digest
SHA256 f2f14f7beee118812d8440d1d21bf4dd143ca15f69dcea52f91a7a9d9a7d9c7e
MD5 9437bfc68caebd0f8c3071f4401c4928
BLAKE2b-256 ac651916c01ff163cbd0e3a5996dc2343f146d0754e06ba50c00cc4adda020f0

See more details on using hashes here.

Provenance

The following attestation bundles were made for samsungtvws-3.0.4.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.4-py3-none-any.whl.

File metadata

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

File hashes

Hashes for samsungtvws-3.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 3223388b7b789c5d44b0d6f68032755af7c4386009bbb91dc06ddfe026b3fc02
MD5 b176ac581143f43e3cdb0027c7049b55
BLAKE2b-256 0e952a5980848b92640501f19ad93791865a62799b76fae565e291c049de3a6c

See more details on using hashes here.

Provenance

The following attestation bundles were made for samsungtvws-3.0.4-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