Python API for Culligan products
Project description
Culligan
A discovery for Culligan smart water products
Water Softener
The Excel sheet contains a listing of endpoints and what is needed for interaction with the Aylanetworks API. This data was gathered from proxy traffic.
The powershell module is a way to interact with the endpoints via Powershell.
The python code is for packageability and publishing to PyPi as a module.
The softener does have an http webpage for wifi status and connect/disconnect. Local control of the device does not seem possible without understanding how Ayla sends commands to the device.
Ayla References
This device is integrated by/with Ayla Networks and (generally) uses their documentation.
Local Wifi Module Doc
Direct doc linked from the reference above: salesforce doc
Installation
From PyPi
pip install culligan
Build from source
pip install build
pip build
pip install culligan
Library Requirements
Requires typical http interaction and datatype packages like requests, aiohttp, ujson, and the ayla-iot-unofficial module to handle devices and communication.
User Requirements
Reqiures a username and password (typically a smart device's app login credentials). The Culligan specific app_id is included in the package (obtained from the Culligan app).
Usage
Class Object
Instantiate a new class object through new_culligan_api() or Culligan() directly.
Access Tokens
The Culligan() object will call sign_in() automatically to obtain Culligan IoT and Ayla access_tokens. Then, it will instantiate an AylaApi() object with the Ayla access_token (no sign_in() required).
Use Culligan for communication with the Culligan IoT domain. Use the Ayla property of the Culligan object for direct communication with Ayla Networks.
Devices
Gather devices by calling the Ayla.get_devices().
By default, calling get_devices() will return a list of class specific device objects with updated properties for use.
See ayla-iot-unofficial/device.py for implemented device classes.
Typical Operation
python3 -m pip install Culligan
import Culligan
USERNAME = 'me@email.com'
PASSWORD = '$7r0nkP@s$w0rD'
CulliganApi = new_culligan_api(username, password)
CulliganApi.sign_in()
CulliganApi.Ayla = CulliganApi.get_ayla_api()
device_list = CulliganApi.Ayla.list_devices()
devices = CulliganApi.Ayla.get_devices()
# Example Water Softener Devices
softener = devices[0]
softener.capacity_remaining_gallons
softener.set_vacation_mode()
License
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 culligan-1.1.2.tar.gz
.
File metadata
- Download URL: culligan-1.1.2.tar.gz
- Upload date:
- Size: 11.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b061572072f1ec2be1d8387d241e656b8a496b4ea8748c879ddc4d8ea3f5f317 |
|
MD5 | bcda384ad2d714ffd881040547f868d2 |
|
BLAKE2b-256 | dfa68d7c02d267ace49184fe7456a827fcdd1f3b522fe4331e755482090cb479 |
File details
Details for the file culligan-1.1.2-py3-none-any.whl
.
File metadata
- Download URL: culligan-1.1.2-py3-none-any.whl
- Upload date:
- Size: 10.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 88cf1951a486c7246135d15aebef45952b5d43467409bc00e1c682a7a4d36cc6 |
|
MD5 | 6b0dca7dd316caa8d5c1c0655db68bdc |
|
BLAKE2b-256 | 18089b8370cf90c54d07af2fd6279f2f4f3d1c0b3919379250ea218090a5167e |