Samsung Smart TV WS API wrapper
Project description
Samsung Smart TV WS API wrapper
This project is a library for remote controlling Samsung televisions via a TCP/IP connection.
It currently supports modern (post-2016) TVs with Ethernet or Wi-Fi connectivity. They should be all models with TizenOs.
Based on https://github.com/marysieek/samsung-tv-api work
Install
$ pip3 install samsungtvws[async,encrypted]
or
$ pip3 install "git+https://github.com/xchwarze/samsung-tv-ws-api.git#egg=samsungtvws[async,encrypted]"
or...!
$ git clone https://github.com/xchwarze/samsung-tv-ws-api
$ pip3 install "./samsung-tv-ws-api[async,encrypted]"
Extras
async
is required if you wish to use asynchronous I/O for all communications with the TV (SamsungTVAsyncRest
and SamsungTVWSAsyncRemote
)
encrypted
is required if you wish to communicate with a TV which only support the v1 API (some J and K models) for sending commands (SamsungTVEncryptedWSAsyncRemote
and SamsungTVEncryptedWSAsyncAuthenticator
).
Usage
Basic
import sys
import os
import logging
import wakeonlan
sys.path.append('../')
from samsungtvws import SamsungTVWS
# Increase debug level
logging.basicConfig(level=logging.INFO)
# Normal constructor
tv = SamsungTVWS('192.168.xxx.xxx')
# Autosave token to file
token_file = os.path.dirname(os.path.realpath(__file__)) + '/tv-token.txt'
tv = SamsungTVWS(host='192.168.xxx.xxx', port=8002, token_file=token_file)
# Toggle power
tv.shortcuts().power()
# Power On
wakeonlan.send_magic_packet('CC:6E:A4:xx:xx:xx')
# Open web in browser
tv.open_browser('https://duckduckgo.com/')
# View installed apps
apps = tv.app_list()
logging.info(apps)
# Open app (Spotify)
tv.run_app('3201606009684')
# Get app status (Spotify)
app = tv.rest_app_status('3201606009684')
logging.info(app)
# Open app (Spotify)
app = tv.rest_app_run('3201606009684')
logging.info(app)
# Close app (Spotify)
app = tv.rest_app_close('3201606009684')
logging.info(app)
# Install from official store (Spotify)
app = tv.rest_app_install('3201606009684')
logging.info(app)
# Get device info (device name, model, supported features..)
info = tv.rest_device_info()
logging.info(info)
Art Mode
TVs that support art mode (such as The Frame) can be controlled as follows:
import sys
import logging
sys.path.append('../')
from samsungtvws import SamsungTVWS
# Increase debug level
logging.basicConfig(level=logging.INFO)
# Normal constructor
tv = SamsungTVWS('192.168.xxx.xxx')
# Is art mode supported?
info = tv.art().supported()
logging.info(info)
# List the art available on the device
info = tv.art().available()
logging.info(info)
# Retrieve information about the currently selected art
info = tv.art().get_current()
logging.info(info)
# Retrieve a thumbnail for a specific piece of art. Returns a JPEG.
thumbnail = tv.art().get_thumbnail('SAM-F0206')
# Set a piece of art
tv.art().select_image('SAM-F0206')
# Set a piece of art, but don't immediately show it if not in art mode
tv.art().select_image('SAM-F0201', show=False)
# Determine whether the TV is currently in art mode
info = tv.art().get_artmode()
logging.info(info)
# Switch art mode on or off
tv.art().set_artmode(True)
tv.art().set_artmode(False)
# Upload a picture
file = open('test.png', 'rb')
data = file.read()
tv.art().upload(data)
# If uploading a JPEG
tv.art().upload(data, file_type='JPEG')
# To set the matte to modern and apricot color
tv.art().upload(data, matte='modern_apricot')
# Delete an uploaded item
tv.art().delete('MY-F0020')
# Delete multiple uploaded items
tv.art().delete_list(['MY-F0020', 'MY-F0021'])
# List available photo filters
info = tv.art().get_photo_filter_list()
logging.info(info)
# Apply a filter to a specific piece of art
tv.art().set_photo_filter('SAM-F0206', 'ink')
Async
Examples are available in the examples folder: async_remote.py
, async_rest.py
Encrypted API
Examples are available in the examples folder: encrypted_authenticator.py
, encrypted_remote.py
Supported TVs
List of support TV models. https://developer.samsung.com/smarttv/develop/extension-libraries/smart-view-sdk/supported-device/supported-tvs.html
2017 : M5500 and above
2016 : K4300, K5300 and above
2015 : J5500 and above (except J6203)
2014 : H4500, H5500 and above (except H6003/H6103/H6153/H6201/H6203)
Supported TV models may vary by region.
For complete list https://developer.samsung.com/smarttv/develop/specifications/tv-model-groups.html
License
LGPL-3.0
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 Distribution
Built Distribution
File details
Details for the file samsungtvws-2.7.2.tar.gz
.
File metadata
- Download URL: samsungtvws-2.7.2.tar.gz
- Upload date:
- Size: 28.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 106d89df70c9fff8a23089af223244c077260e83326ef8b2e5c9fa8d2706f25f |
|
MD5 | 27ae4ebf44495789768170d07184cf52 |
|
BLAKE2b-256 | e4c7aa95581ad09e0ec2628f9fc5f80fbf6556b2a96af40937479bb252ed890b |
Provenance
The following attestation bundles were made for samsungtvws-2.7.2.tar.gz
:
Publisher:
release.yml
on xchwarze/samsung-tv-ws-api
-
Statement:
- Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
samsungtvws-2.7.2.tar.gz
- Subject digest:
106d89df70c9fff8a23089af223244c077260e83326ef8b2e5c9fa8d2706f25f
- Sigstore transparency entry: 153784569
- Sigstore integration time:
- Permalink:
xchwarze/samsung-tv-ws-api@243b69526434b9cce5343425a08a8d1c2f002a5f
- Branch / Tag:
refs/tags/v2.7.2
- Owner: https://github.com/xchwarze
- Access:
public
- Token Issuer:
https://token.actions.githubusercontent.com
- Runner Environment:
github-hosted
- Publication workflow:
release.yml@243b69526434b9cce5343425a08a8d1c2f002a5f
- Trigger Event:
push
- Statement type:
File details
Details for the file samsungtvws-2.7.2-py3-none-any.whl
.
File metadata
- Download URL: samsungtvws-2.7.2-py3-none-any.whl
- Upload date:
- Size: 30.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3c903eeffc6239e32adba55b7f01ff061458f12b6b3c86bac91e9f25f511c994 |
|
MD5 | 66e85797bb518401598f50d76e1a3bc3 |
|
BLAKE2b-256 | f62e80f1fce8cc05b8a05f9fbbbbab104edc13eb4ab9a1fb850966831717637d |
Provenance
The following attestation bundles were made for samsungtvws-2.7.2-py3-none-any.whl
:
Publisher:
release.yml
on xchwarze/samsung-tv-ws-api
-
Statement:
- Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
samsungtvws-2.7.2-py3-none-any.whl
- Subject digest:
3c903eeffc6239e32adba55b7f01ff061458f12b6b3c86bac91e9f25f511c994
- Sigstore transparency entry: 153784572
- Sigstore integration time:
- Permalink:
xchwarze/samsung-tv-ws-api@243b69526434b9cce5343425a08a8d1c2f002a5f
- Branch / Tag:
refs/tags/v2.7.2
- Owner: https://github.com/xchwarze
- Access:
public
- Token Issuer:
https://token.actions.githubusercontent.com
- Runner Environment:
github-hosted
- Publication workflow:
release.yml@243b69526434b9cce5343425a08a8d1c2f002a5f
- Trigger Event:
push
- Statement type: