Samsung Smart TV WS API wrapper
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.
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.
- 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)
Requires Python >= 3.9.
Core library:
pip install samsungtvwsCommon install (async + encrypted + CLI):
pip install "samsungtvws[async,encrypted,cli]"async: async I/O support (aiohttp,websockets)encrypted: v1 encrypted API support for older Orsay TVs (cryptography,py3rijndael)cli: installs thesamsungtvcommand (typer,wakeonlan)
Examples:
pip install "samsungtvws[cli]"
pip install "samsungtvws[async]"
pip install "samsungtvws[encrypted]"pip install "git+https://github.com/xchwarze/samsung-tv-ws-api.git#egg=samsungtvws[async,encrypted,cli]"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.
If installed with the cli extra:
samsungtv --helpThis library can be used either programmatically or via the CLI, depending on the integration needs.
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.
For quick testing, automation, or scripting, the library provides a fully featured command-line interface.
Requires installation with the cli extra.
Once installed:
samsungtv --helpPower on TV using Wake-on-LAN:
samsungtv --host 192.168.1.50 wolToggle power:
samsungtv --host 192.168.1.50 powerList installed applications:
samsungtv --host 192.168.1.50 appsRun an application by ID:
samsungtv --host 192.168.1.50 app-run 3201606009684Open a URL in the TV browser:
samsungtv --host 192.168.1.50 open-browser https://duckduckgo.comGet device information:
samsungtv --host 192.168.1.50 device-infoEnable Art Mode:
samsungtv --host 192.168.1.50 art-mode onUpload an image to Art Mode:
samsungtv --host 192.168.1.50 art-upload image.jpgThe CLI exposes most of the library functionality, including:
- App management
- Remote control keys
- Device information
- Wake-on-LAN
- Full Art Mode management
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:
- https://developer.samsung.com/smarttv/develop/extension-libraries/smart-view-sdk/supported-device/supported-tvs.html
- https://developer.samsung.com/smarttv/develop/specifications/tv-model-groups.html
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
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
(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
LGPL-3.0

