Skip to main content

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.

See Ayla-iot-unofficial

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

MIT

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

culligan-1.1.1.tar.gz (11.6 kB view details)

Uploaded Source

Built Distribution

culligan-1.1.1-py3-none-any.whl (10.9 kB view details)

Uploaded Python 3

File details

Details for the file culligan-1.1.1.tar.gz.

File metadata

  • Download URL: culligan-1.1.1.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

Hashes for culligan-1.1.1.tar.gz
Algorithm Hash digest
SHA256 7fddb67f18337da6a20b6a67cd82b06ea161e49c2dbd8b5f2afda3d1335f43bc
MD5 f864ffa36e69b1b1dc48e75dc8f14e88
BLAKE2b-256 d5fc459d31f5a4cc58bb69ca9e89d8d24f925b1438ee288b9fab60aec3db8a80

See more details on using hashes here.

File details

Details for the file culligan-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: culligan-1.1.1-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

Hashes for culligan-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7243be09d74a176a9e8a13f79ebf50fa27b280b6f6f16eb9df4251d04b1c4faa
MD5 eb8343e6b060931e0e0c9d86077fc6f9
BLAKE2b-256 65362b513995c6e669067d37a71b07d73b7d7d820c5f829dd828bf783e630add

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page