Skip to main content

Asynchronous Python TCP Client for FlicHub

Project description

Asynchronous Python TCP Client for FlicHub

Get events from the FlicHub when a Flic/Twist Button is clicked and send them to home-assistant-flichub.

To be able to use this client you need to enable the Flic Hub SDK described on this page.

Create a new module and name it pyflichub-tcpclient (or any name) and paste the code found in tcpserver.js in the editor and press play. Check the box "Restart after crash or reboot."

This will open a TCP Server on port 8124 (configurable by changing PORT)

Usage

import asyncio
from pyflichub.client import FlicHubTcpClient
from pyflichub.button import FlicButton
from pyflichub.event import Event

def event_callback(button: FlicButton, event: Event):
    print(f"Received event: {event.event}")
    if button:
        print(f"Button: {button.name} ({button.bdaddr})")

    if event.event == 'button':
        print(f"Action: {event.action}")

def command_callback(cmd):
    print(f"Received command: {cmd.command}")

async def main():
    loop = asyncio.get_event_loop()
    client = FlicHubTcpClient(
        ip='192.168.1.100',
        port=8124,
        loop=loop,
        event_callback=event_callback,
        command_callback=command_callback
    )

    await client.async_connect()

    # Retrieve all buttons
    buttons = await client.get_buttons()
    print(f"Found {len(buttons)} buttons.")

    # Keep the connection alive
    while True:
        await asyncio.sleep(1)

if __name__ == '__main__':
    asyncio.run(main())

Emitted Events

The following events are explicitly dispatched to the event_callback provided during initialization:

  • button: Fired when a button interaction occurs (e.g. click, double-click, hold). Provides the action type in event.action ('down', 'up', 'single', 'double', 'hold', 'idle').
  • buttonAdded: Fired when a new button is paired to the hub. The library will automatically try to fetch its details in the background. The button argument to the callback may be None initially.
  • buttonDeleted: Fired when a button is unpaired/deleted.
  • buttonConnected: Fired when a button makes a physical connection to the hub.
  • buttonDisconnected: Fired when the connection to the button drops.
  • buttonReady: Fired when the button connection has been fully verified and is ready for use.
  • actionMessage: Fired when a Flic Hub Studio message action is executed (configured as a trigger in the Flic app).
  • virtualDeviceUpdate: Fired when a Flic Twist rotates to control a virtual device. Contains values in event.values (like brightness, volume, etc.).

Handling Twist Jitter/Sensitivity

When working with virtual device outputs mapping to Flic Twist, you may find the outputs to be twitchy or experience jitter. To resolve this, you can utilize the provided RateDetentController utility. This allows variable-speed adjusters with features like sticky neutral and debounce to smooth out inputs.

from pyflichub.twist_controller import RateDetentController

# Inside your application...
def on_volume_change(new_volume_pct):
    print(f"Setting volume to: {new_volume_pct}%")

# Create a controller once for the button
volume_controller = RateDetentController(
    cfg={"minOutPct": 0, "maxOutPct": 100},
    on_change_callback=on_volume_change
)

def event_callback(button: FlicButton, event: Event):
    if event.event == 'virtualDeviceUpdate':
        # Push raw values through the controller
        # Make sure you only pass value updates matching the button and device
        volume_controller.update_raw(event.values['volume'] * 100)

Disclaimer

This python library was not made by Flic. It is not official, not developed, and not supported by Flic.

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

pyflichub_tcpclient-0.1.18.tar.gz (23.1 kB view details)

Uploaded Source

Built Distribution

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

pyflichub_tcpclient-0.1.18-py3-none-any.whl (13.0 kB view details)

Uploaded Python 3

File details

Details for the file pyflichub_tcpclient-0.1.18.tar.gz.

File metadata

  • Download URL: pyflichub_tcpclient-0.1.18.tar.gz
  • Upload date:
  • Size: 23.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for pyflichub_tcpclient-0.1.18.tar.gz
Algorithm Hash digest
SHA256 d148490d5db799d1883cf8f5a29830d5d9f4ffcefcc5853aeac56e27a80f2c5d
MD5 c04f7f63355ae436f8a0c148c6744f55
BLAKE2b-256 c14f6541f4d868447323b8a03147b679097d3ddf2aec2f3ac6b1164f738e9ffc

See more details on using hashes here.

File details

Details for the file pyflichub_tcpclient-0.1.18-py3-none-any.whl.

File metadata

File hashes

Hashes for pyflichub_tcpclient-0.1.18-py3-none-any.whl
Algorithm Hash digest
SHA256 2a6f4dc50cccb6e6fe69e0706023086a6843df849ceb0ec9a700006eea0250a2
MD5 e6c53371e6e4d89ab7d03bbb9b62c577
BLAKE2b-256 66296b254b3dc96b09e99036948547e3d7a569ea3da2e3f02698f391c2b61191

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