Skip to main content

Async Python client to interact with internal OverKiz API (e.g. used by Somfy TaHoma).

Project description

Python client for OverKiz API

A fully async and easy to use API client for the (internal) OverKiz API. You can use this client to interact with smart devices connected to the OverKiz platform, used by various vendors like Somfy TaHoma and Atlantic Cozytouch.

This package is written for the Home Assistant ha-tahoma integration, but could be used by any Python project interacting with OverKiz hubs.

Somfy TaHoma has an official API, which can be consumed via the somfy-open-api. Unfortunately only a few device classes are supported via the official API, thus the need for this API client.

Supported hubs

  • Atlantic Cozytouch
  • Bouygues Flexom
  • Hitachi Hi Kumo
  • Nexity Eugénie
  • Rexel Energeasy Connect
  • Simu (LiveIn2)
  • Somfy Connexoon IO
  • Somfy Connexoon RTS
  • Somfy TaHoma
  • Somfy TaHoma Switch
  • Thermor Cozytouch

Installation

pip install pyoverkiz

Getting started

import asyncio
import time

from pyoverkiz.const import SUPPORTED_SERVERS
from pyoverkiz.client import OverkizClient

USERNAME = ""
PASSWORD = ""

async def main() -> None:
    async with OverkizClient(USERNAME, PASSWORD, server=SUPPORTED_SERVERS["somfy_europe"]) as client:
        try:
            await client.login()
        except Exception as exception:  # pylint: disable=broad-except
            print(exception)
            return

        devices = await client.get_devices()

        for device in devices:
            print(f"{device.label} ({device.id}) - {device.controllable_name}")
            print(f"{device.widget} - {device.ui_class}")

        while True:
            events = await client.fetch_events()
            print(events)

            time.sleep(2)

asyncio.run(main())

Development

Installation

  • For Linux, install pyenv using pyenv-installer

  • For MacOS, run brew install pyenv

  • Don't forget to update your .bashrc file (or similar):

    export PATH="~/.pyenv/bin:$PATH"
    eval "$(pyenv init -)"
    
  • Install the required dependencies

  • Install poetry: curl -sSL https://raw.githubusercontent.com/python-poetry/poetry/master/get-poetry.py | python

  • Clone this repository

  • cd python-overkiz-api

  • Install the required Python version: pyenv install

  • Init the project: poetry install

  • Run poetry run pre-commit install

PyCharm

As IDE you can use PyCharm.

Using snap, run snap install pycharm --classic to install it.

For MacOS, run brew cask install pycharm-ce

Once launched, don't create a new project, but open an existing one and select the python-overkiz-api folder.

Go to File | Settings | Project: nre-tag | Project Interpreter. Your interpreter must look like <whatever>/python-overkiz-api/.venv/bin/python

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

pyoverkiz-1.7.6.tar.gz (35.4 kB view details)

Uploaded Source

Built Distribution

pyoverkiz-1.7.6-py3-none-any.whl (38.2 kB view details)

Uploaded Python 3

File details

Details for the file pyoverkiz-1.7.6.tar.gz.

File metadata

  • Download URL: pyoverkiz-1.7.6.tar.gz
  • Upload date:
  • Size: 35.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.11.2 Linux/5.15.0-1033-azure

File hashes

Hashes for pyoverkiz-1.7.6.tar.gz
Algorithm Hash digest
SHA256 f55e34e051eb1558f414dd09a2837e72cd2cd74204161aa33c83bac79d4c5844
MD5 35397eb09dc47e8c8d708acef0b8933d
BLAKE2b-256 ce7e6c71fb520a4c3e067494aad20ed25558a6c807221ed6ab3cca3bca2cec88

See more details on using hashes here.

File details

Details for the file pyoverkiz-1.7.6-py3-none-any.whl.

File metadata

  • Download URL: pyoverkiz-1.7.6-py3-none-any.whl
  • Upload date:
  • Size: 38.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.11.2 Linux/5.15.0-1033-azure

File hashes

Hashes for pyoverkiz-1.7.6-py3-none-any.whl
Algorithm Hash digest
SHA256 653d8c00411fcfb55a59944b902ad0ed8bd0dbcf82167cf7844308e3c2ab0eba
MD5 aaa882a2430df7d102fd4aba0a2d01f0
BLAKE2b-256 4ee45f3ec4ed67f88164a1c1f38f680b1195d617c270f4dda5cc37151e0eb5f3

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