Python client for interacting with Honeywell Total Connect Comfort (TCC) API
Project description
SomeComfort API Client
This module provides a Python client for interacting with Honeywell's Total Connect Comfort (TCC) API. It allows you to log in to the Honeywell TCC portal, retrieve and update thermostat data, and manage thermostat settings.
Based on the work kk7ds: https://github.com/kk7ds/somecomfort
Table of Contents
Features
- Log in to the Honeywell TCC portal and manage session cookies
- Retrieve thermostat data and associated devices
- Update thermostat settings (system mode, temperature setpoints, etc.)
- Handle session timeouts and automatic re-login
- Handle API rate limits
Installation
You can install the module by cloning the repository and installing the necessary dependencies.
git clone https://github.com/your-repo/somecomfort-client
cd somecomfort-client
pip install -r requirements.txt
Usage
Session Management
The Session class manages login, cookies, and communication with the Honeywell TCC API. You can use it as a context manager to ensure that resources are properly managed.
python
from somecomfort import Session
async with Session('your_username', 'your_password') as session:
# Now you are logged in, and can make API requests
locations = await session.get_locations()
print(locations)
Fetching Locations
You can fetch the list of locations (and associated thermostats) for the current account using the get_locations() method.
python
locations = await session.get_locations()
print(f"Fetched {len(locations)} locations.")
Fetching Thermostat Data
To retrieve data for a specific thermostat, use the get_thermostat_data() method by passing the thermostat ID.
python
thermostat_id = '123456'
thermostat_data = await session.get_thermostat_data(thermostat_id)
print(thermostat_data)
Setting Thermostat Settings
You can update the thermostat's settings (such as system mode, heat or cool setpoints) using the set_thermostat_settings() method.
python
settings = {
'SystemSwitch': 1, # 1 = Heat, 2 = Cool, 3 = Off, etc.
'HeatSetpoint': 70,
'CoolSetpoint': 75
}
await session.set_thermostat_settings('123456', settings)
Exception Handling
This module defines several custom exceptions to handle specific error conditions:
• AuthError: Raised for authentication failures.
• APIError: Raised when there are issues communicating with the API.
• SessionTimedOut: Raised when the session has expired and needs to be refreshed.
• APIRateLimited: Raised when the API rate limit is exceeded.
Example:
python
try:
locations = await session.get_locations()
except AuthError:
print("Login failed! Check your credentials.")
except APIError as e:
print(f"API error: {str(e)}")
Contributing
Contributions are welcome! If you'd like to contribute, please fork the repository, create a feature branch, and submit a pull request.
1. Fork the repo
2. Create a feature branch (git checkout -b feature/your-feature)
3. Commit your changes (git commit -am 'Add new feature')
4. Push to the branch (git push origin feature/your-feature)
5. Create a pull request
Please ensure that your code passes all linting and tests before submitting a PR.
License
This project is licensed under the MIT License. See the LICENSE file for more details.
API Documentation
This section provides an overview of the key classes and methods in this module. Detailed docstrings are available within the code for each class and method.
Session Class
The Session class is responsible for managing the connection to the Honeywell TCC API, logging in, handling cookies, and fetching/updating thermostat data.
Methods
• __aenter__() and __aexit__(): These asynchronous methods enable context management, ensuring the session is properly opened and closed.
• login(): Logs in to the Honeywell TCC portal.
• keepalive(): Ensures the session remains active by refreshing it.
• get_locations(): Fetches a list of locations associated with the user account.
• get_thermostat_data(thermostat_id): Fetches data for a specific thermostat.
• set_thermostat_settings(thermostat_id, settings): Updates the settings of a thermostat.
• close(): Closes the session and releases resources.
Example Usage:
python
async with Session('username', 'password') as session:
locations = await session.get_locations()
print(locations)
Device Class
The Device class represents individual thermostat devices within a location. It allows you to retrieve device status and update configurations.
Methods
• refresh(): Refreshes the device data.
• set_fan_mode(): Sets the fan mode (auto, on, circulate).
• set_system_mode(): Sets the system mode (heat, cool, off).
• set_setpoint_cool(temp): Sets the cool setpoint temperature.
• set_setpoint_heat(temp): Sets the heat setpoint temperature.
Example:
python
device = await session.get_device('123456')
await device.set_setpoint_cool(75)
await device.set_system_mode('cool')
Exception Handling in Detail
This module contains custom exceptions that are used throughout the codebase. Each of these exceptions inherits from SomeComfortError, the base exception class.
Exceptions
• SomeComfortError: The base exception class for all exceptions in this module.
• AuthError: Raised when authentication fails (e.g., incorrect username/password).
• APIError: Raised when the API returns an unexpected response or an error status.
• SessionTimedOut: Raised when the session has timed out and must be renewed.
• APIRateLimited: Raised when the API rate limit has been exceeded.
License
MIT License. See LICENSE for more information.
### How to Use:
- **README.md**: This entire file content can be saved as `README.md` and placed in the root directory of your project repository.
- **Additional Files**:
- **LICENSE**: Ensure you have a `LICENSE` file that corresponds to the MIT License if you're using that.
- **Detailed Documentation**: You can further elaborate on each class and method in a separate API documentation if needed (e.g., using Sphinx for Python docs).
Let me know if you need further adjustments or more sections added!
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
async_somecomfort-1.0.0.tar.gz
(28.8 kB
view details)
Built Distribution
File details
Details for the file async_somecomfort-1.0.0.tar.gz
.
File metadata
- Download URL: async_somecomfort-1.0.0.tar.gz
- Upload date:
- Size: 28.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0825880921fa857f29d7606c52d3f055440db16d40232995c72b5ec71c475a3c |
|
MD5 | 7eda80d0a9faf3e13d24dffd0df0590d |
|
BLAKE2b-256 | 08085e2dccc5af525d373c18297f8001db8760335e634ce8b5bb142b88b6d433 |
File details
Details for the file async_somecomfort-1.0.0-py2.py3-none-any.whl
.
File metadata
- Download URL: async_somecomfort-1.0.0-py2.py3-none-any.whl
- Upload date:
- Size: 30.6 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a19146b9064b093fb518aaaa254cb82868bfd00235a5d22b49bfd83426bba011 |
|
MD5 | ed05ed85402ec997db4f264585b5a27d |
|
BLAKE2b-256 | 2ccfcbf4e917240598705b059f25ea8216bd3ec73d881ab7da4d23ea032b837f |