Provides an API to the Lutron Smartbridge
Project description
pylutron-caseta
A Python API to control Lutron Caséta devices.
Getting started
If you don't know the IP address of the bridge, the leap-scan
tool (requires the cli extra, pip install pylutron_caseta[cli]
) will search for LEAP devices on the local network and display their address and LEAP port number.
Authentication
In order to communicate with the bridge device, you must complete the pairing process. This generates certificate files for authentication. pylutron_caseta can do this two ways.
lap-pair
If pylutron_caseta is installed with the cli extra (pip install pylutron_caseta[cli]
), the lap-pair
tool can be used to generate the certificate files. Simply running lap-pair <BRIDGE HOST>
(note the LEAP port number should not be included) will begin the pairing process. The certificate files will be saved in $XDG_CONFIG_HOME/pylutron_caseta
(normally ~/.config/pylutron_caseta
) in the files [BRIDGE HOST]-bridge.crt
, [BRIDGE HOST].crt
, [BRIDGE HOST].key
. Check lap-pair --help
if you want to use different files.
The pairing module
If pylutron_caseta is being integrated into a larger application, the pairing functionality can be reused to allow pairing from within that application.
async def pair(host: str):
def _ready():
print("Press the small black button on the back of the bridge.")
data = await async_pair(host, _ready)
with open("caseta-bridge.crt", "w") as cacert:
cacert.write(data["ca"])
with open("caseta.crt", "w") as cert:
cert.write(data["cert"])
with open("caseta.key", "w") as key:
key.write(data["key"])
print(f"Successfully paired with {data['version']}")
Connecting to the bridge
Once you have the certificate files, you can connect to the bridge and start controlling devices.
import asyncio
from pylutron_caseta.smartbridge import Smartbridge
async def example():
# `Smartbridge` provides an API for interacting with the Caséta bridge.
bridge = Smartbridge.create_tls(
"YOUR_BRIDGE_IP", "caseta.key", "caseta.crt", "caseta-bridge.crt"
)
await bridge.connect()
# Get the first light.
# The device is represented by a dict.
device = bridge.get_devices_by_domain("light")[0]
# Turn on the light.
# Methods that act on devices expect to be given the device id.
await bridge.turn_on(device["device_id"])
await bridge.close()
# Because pylutron_caseta uses asyncio,
# it must be run within the context of an asyncio event loop.
loop = asyncio.get_event_loop()
loop.run_until_complete(example())
The leap tool
For development and testing of new features, there is a leap
command in the cli extras (pip install pylutron_caseta[cli]
) which can be used for communicating directly with the bridge, similar to using curl
.
Getting information about the bridge:
$ leap 192.168.86.49/server | jq
{
"Servers": [
{
"href": "/server/1",
"Type": "LEAP",
"NetworkInterfaces": [
{
"href": "/networkinterface/1"
}
],
"EnableState": "Enabled",
"LEAPProperties": {
"PairingList": {
"href": "/server/leap/pairinglist"
}
},
"Endpoints": [
{
"Protocol": "TCP",
"Port": 8081,
"AssociatedNetworkInterfaces": null
}
]
}
]
}
Turning on the first dimmer:
$ ip=192.168.86.49
$ device=$(leap "${ip}/zone/status/expanded?where=Zone.ControlType:\"Dimmed\"" | jq -r '.ZoneExpandedStatuses[0].Zone.href')
$ leap -X CreateRequest "${ip}${device}/commandprocessor" -d '{"Command":{"CommandType":"GoToLevel","Parameter":[{"Type":"Level","Value":100}]}}'
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 pylutron_caseta-0.22.0.tar.gz
.
File metadata
- Download URL: pylutron_caseta-0.22.0.tar.gz
- Upload date:
- Size: 55.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.26.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c39c8ad013790565762728da61d831833350fd5dda797b3c8f8e5395b3739120 |
|
MD5 | ed0ccffa3bd111096dc6e9164ca9c551 |
|
BLAKE2b-256 | 9487bcb31a9ed117ca462934a9b4c9f2677ff63299e7e2d3aaa96ad7f9aa1fbf |
File details
Details for the file pylutron_caseta-0.22.0-py3-none-any.whl
.
File metadata
- Download URL: pylutron_caseta-0.22.0-py3-none-any.whl
- Upload date:
- Size: 35.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.26.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 14abb0598f798ac0cd7e77681f892c6b5c89d85061a4ad7e67922a8cd7570c0a |
|
MD5 | 5b74e53b1067b4619590d100b4701ccf |
|
BLAKE2b-256 | 8dc5061ae833cd0ce68f38e158ad3a1b3d7a2717229161e3912c44af8da5e85f |