mirror of
https://github.com/python-kasa/python-kasa.git
synced 2025-01-22 20:57:07 +00:00
9473d97ad2
Introduce common module interfaces across smart and iot devices and provide better typing implementation for getting modules to support this.
81 lines
2.1 KiB
Python
81 lines
2.1 KiB
Python
"""Module for base light effect module."""
|
|
|
|
from __future__ import annotations
|
|
|
|
from abc import ABC, abstractmethod
|
|
|
|
from ..feature import Feature
|
|
from ..module import Module
|
|
|
|
|
|
class LightEffect(Module, ABC):
|
|
"""Interface to represent a light effect module."""
|
|
|
|
LIGHT_EFFECTS_OFF = "Off"
|
|
|
|
def _initialize_features(self):
|
|
"""Initialize features."""
|
|
device = self._device
|
|
self._add_feature(
|
|
Feature(
|
|
device,
|
|
id="light_effect",
|
|
name="Light effect",
|
|
container=self,
|
|
attribute_getter="effect",
|
|
attribute_setter="set_effect",
|
|
category=Feature.Category.Primary,
|
|
type=Feature.Type.Choice,
|
|
choices_getter="effect_list",
|
|
)
|
|
)
|
|
|
|
@property
|
|
@abstractmethod
|
|
def has_custom_effects(self) -> bool:
|
|
"""Return True if the device supports setting custom effects."""
|
|
|
|
@property
|
|
@abstractmethod
|
|
def effect(self) -> str:
|
|
"""Return effect state or name."""
|
|
|
|
@property
|
|
@abstractmethod
|
|
def effect_list(self) -> list[str]:
|
|
"""Return built-in effects list.
|
|
|
|
Example:
|
|
['Aurora', 'Bubbling Cauldron', ...]
|
|
"""
|
|
|
|
@abstractmethod
|
|
async def set_effect(
|
|
self,
|
|
effect: str,
|
|
*,
|
|
brightness: int | None = None,
|
|
transition: int | None = None,
|
|
) -> None:
|
|
"""Set an effect on the device.
|
|
|
|
If brightness or transition is defined,
|
|
its value will be used instead of the effect-specific default.
|
|
|
|
See :meth:`effect_list` for available effects,
|
|
or use :meth:`set_custom_effect` for custom effects.
|
|
|
|
:param str effect: The effect to set
|
|
:param int brightness: The wanted brightness
|
|
:param int transition: The wanted transition time
|
|
"""
|
|
|
|
async def set_custom_effect(
|
|
self,
|
|
effect_dict: dict,
|
|
) -> None:
|
|
"""Set a custom effect on the device.
|
|
|
|
:param str effect_dict: The custom effect dict to set
|
|
"""
|