Skip to main content

ConnectLife Cloud API client library for Home Assistant integrations

Project description

ConnectLife Cloud API Client

A Python client library for the ConnectLife Cloud API, designed for Home Assistant integrations.

Features

  • Async/await support
  • Full type hints
  • Comprehensive error handling
  • Device management
  • Real-time status updates
  • Power consumption tracking
  • Self-check diagnostics

Installation

pip install connectlife-cloud

Usage

import asyncio
from connectlife_cloud import ConnectLifeCloudClient

async def main():
    client = ConnectLifeCloudClient(
        client_id="your_client_id",
        client_secret="your_client_secret"
    )
    
    try:
        # Get devices
        devices = await client.get_devices(access_token="your_token")
        print(f"Found {len(devices)} devices")
        
        # Control a device
        result = await client.control_device(
            puid="device_puid",
            properties={"power": True, "mode": "cool"},
            access_token="your_token"
        )
        print(f"Control result: {result}")
        
    finally:
        await client.close()

asyncio.run(main())

API Reference

ConnectLifeCloudClient

The main client class for interacting with the ConnectLife Cloud API.

Methods

  • get_devices(access_token): Get list of devices
  • control_device(puid, properties, access_token): Control a device
  • get_property_list(device_type_code, device_feature_code, access_token): Get device properties
  • query_static_data(puid, access_token): Query static device data
  • get_hour_power(date, puid, access_token): Get hourly power consumption
  • get_self_check(no_record, puid, access_token): Get device self-check info
  • get_devices_with_parsers(access_token): Get devices with their parsers
  • parse_device_status(device_id, status): Parse device status using appropriate parser

Mode Converter

Utilities for converting device mode descriptions (Chinese or English) to standard Home Assistant strings.

HVAC Mode Functions:

  • convert_mode_to_ha_string(mode_description): Convert HVAC mode description to HA standard string
  • get_ha_mode_string(value_map, device_value): Get HA HVAC mode string from device value map
  • find_device_value_for_ha_mode(value_map, ha_mode_string): Find device value for given HA mode (reverse lookup)

Fan Mode Functions:

  • convert_fan_mode_to_ha_string(fan_description): Convert fan mode description to HA standard string
  • get_ha_fan_mode_string(value_map, device_value): Get HA fan mode string from device value map
  • find_device_value_for_ha_fan_mode(value_map, ha_fan_mode_string): Find device value for given HA fan mode (reverse lookup)

The library handles bilingual support internally, converting Chinese descriptions (自动, 制冷, 制热, etc.) to standard English strings that can be directly used with Home Assistant enums like HVACMode("auto").

License

MIT License

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

connectlife_cloud-0.3.6.tar.gz (25.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

connectlife_cloud-0.3.6-py3-none-any.whl (30.5 kB view details)

Uploaded Python 3

File details

Details for the file connectlife_cloud-0.3.6.tar.gz.

File metadata

  • Download URL: connectlife_cloud-0.3.6.tar.gz
  • Upload date:
  • Size: 25.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for connectlife_cloud-0.3.6.tar.gz
Algorithm Hash digest
SHA256 7a6e74882aa4b1a84984bc96843bbb2cb06a1b29e58ac0f4130070cb7d9550e6
MD5 068849bf584da08824c3bab57cf10619
BLAKE2b-256 e43ac01c4b6ce2f91d2037593f3c9ef8300b41be09ee270ddfa2ce30f3125d71

See more details on using hashes here.

File details

Details for the file connectlife_cloud-0.3.6-py3-none-any.whl.

File metadata

File hashes

Hashes for connectlife_cloud-0.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 97f42d8eaa0eb6ef55752b1ed36129d990ae33c482142763e248ad9f4f03bd79
MD5 4e194f1553cb1c60d3f97f304165d5d5
BLAKE2b-256 b66b4a35ddcf225f8f0ce58c6430fce44ef461e3c164a6d26074d06fb4243d8a

See more details on using hashes here.

Supported by

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