Lights¶
bridge.lights owns Light models for on/off, dimming, color, color temperature,
and effects. Split main/trim zones appear as separate Light resources; dual-channel
RGB+WW fixtures stay as one light (see Split devices).
Dual-channel fixtures¶
Fixtures with separate color and white brightness channels (RGBCW strips,
flushmounts, and similar) expose:
Light.is_dual_channel—Truewhen both channels are presentLight.color_brightness/Light.white_brightness— last known per-channel levelsLight.channel_brightness("color")/channel_brightness("white")— accessors for integrationsLight.dimming— overall brightness;dimming.func_instanceis usually"primary"and tracks which instance last updated the cached level
Reading: Subscribe to bridge.lights as usual. Use color_mode.mode together
with the per-channel brightness fields to reflect the active API mode (color,
white, mixed, etc.).
Writing: LightController.set_state and set_brightness route dimming PUTs by
command context:
RGB, effects, or
color_mode="color"/"sequence"→colorbrightnessCCT,
color_mode="white", or white-only zones →whitebrightnessBrightness-only updates follow the cached
color_modewhen no explicit mode is passed;mixedmode usesprimaryoverall brightness
The outbound DimmingFeature.func_instance on the PUT selects the API brightness row.
Controller¶
- class aioafero.v1.controllers.light.LightController(bridge: AferoBridgeV1)[source]
Bases:
BaseResourcesController[Light]Light devices on
bridge.lights(including split zones).- Parameters:
bridge (AferoBridgeV1)
- ITEM_CLS
alias of
Light
- async turn_on(device_id: str) None[source]
Turn on the light.
- Parameters:
device_id (str) – Device ID from this controller.
- Return type:
None
- async turn_off(device_id: str) None[source]
Turn off the light.
- Parameters:
device_id (str) – Device ID from this controller.
- Return type:
None
- async set_color_temperature(device_id: str, temperature: int) None[source]
Set color temperature or white mode when CCT is unavailable.
- async set_white(device_id: str, *, on: bool | None = True, brightness: int | None = None) None[source]
Set white mode without a color-temperature function.
- async set_brightness(device_id: str, brightness: int) None[source]
Set brightness, turning the light on if needed.
- async set_rgb(device_id: str, red: int, green: int, blue: int) None[source]
Set RGB color, turning the light on if needed.
- async set_effect(device_id: str, effect: str) None[source]
Set a color sequence effect, turning the light on if needed.
- async initialize_elem(afero_device: AferoDevice) Light[source]
Initialize the element.
- Parameters:
afero_device (AferoDevice) – Afero Device that contains the updated states
- Returns:
Newly initialized resource
- Return type:
- async update_elem(afero_device: AferoDevice) set[source]
Update the Light with the latest API data.
- Parameters:
afero_device (AferoDevice) – Afero Device that contains the updated states
- Returns:
States that have been modified
- Return type:
- async update_elem_color(cur_item: Light, color_seq_states: dict) set[source]
Perform the update for effects.
- async set_state(device_id: str, on: bool | None = None, temperature: int | None = None, brightness: int | None = None, color_mode: str | None = None, color: tuple[int, int, int] | None = None, effect: str | None = None, force_white_mode: int | None = None, numbers: dict[tuple[str, str], float] | None = None) None[source]
Update light state in the cloud.
- Parameters:
device_id (str) – Device ID from this controller.
on (bool | None) – Power state.
temperature (int | None) – Color temperature in kelvin.
brightness (int | None) – Brightness percentage.
color_mode (str | None) – API color mode (
white,color,sequence, etc.).color (tuple[int, int, int] | None) – RGB tuple
(red, green, blue).effect (str | None) – Named color sequence effect.
force_white_mode (int | None) – Brightness to apply after forcing white mode.
numbers (dict[tuple[str, str], float] | None) – Number features keyed by
(functionClass, functionInstance).
- Return type:
None
- __getitem__(device_id: str) AferoResource
Get item by device_id.
- Parameters:
device_id (str)
- Return type:
AferoResource
- __init__(bridge: AferoBridgeV1) None
Initialize instance.
- Parameters:
bridge (AferoBridgeV1)
- Return type:
None
- async emit_to_subscribers(evt_type: EventType, item_id: str, item: AferoResource)
Emit updates to subscribers.
- generate_update_dev(device_id: str, states: list[AferoState]) AferoDevice
Generate update data for the event controller.
- Parameters:
device_id (str)
states (list[AferoState])
- Return type:
- get_device(device_id: str) AferoResource
Return the current model for a tracked device.
- Parameters:
device_id (str) – Device ID on this controller (split or parent metadevice ID).
- Returns:
Resource model with parsed feature state.
- Raises:
DeviceNotFound – If
device_idis not tracked by this controller.- Return type:
AferoResource
- get_filtered_devices(initial_data: list[dict]) list[AferoDevice]
Determine devices that align to the controller.
- Parameters:
- Return type:
- async initialize() None
Initialize controller the controller.
Initialization process should only occur once. During this process, it will subscribe to all updates for the given resources and register any device split callbacks for the event controller.
- Return type:
None
- async initialize_number(func_def: dict, state: AferoState) tuple[tuple[str, str | None], NumbersFeature] | None
Initialize a number from the provided data.
- Parameters:
func_def (dict)
state (AferoState)
- Return type:
tuple[tuple[str, str | None], NumbersFeature] | None
- async initialize_select(functions: list[dict], state: AferoState) tuple[tuple[str, str | None], SelectFeature] | None
Initialize a select from the provided data.
- Parameters:
state (AferoState)
- Return type:
tuple[tuple[str, str | None], SelectFeature] | None
- async initialize_sensor(state: AferoState, child_id: str) AferoSensor | AferoBinarySensor | None
Initialize the sensor.
- Parameters:
state (AferoState) – State to update
child_id (str) – device_id of the parent device
- Return type:
AferoSensor | AferoBinarySensor | None
- property initialized: bool
Determine if the controller has been initialized.
- property items: list[AferoResource]
Return all items for this resource.
- async split_sensor_data(state: AferoState) tuple[Any, str | None]
Split the sensor value and return a tuple of the sensor value and key.
- Parameters:
state (AferoState)
- Return type:
- subscribe(callback: Callable[[EventType, dict | None], None], id_filter: str | tuple[str] | None = None, event_filter: EventType | tuple[EventType] | None = None) Callable
Subscribe to status changes for this resource type.
- Parameters:
- Returns:
function to unsubscribe.
- Return type:
- property subscribers: dict[str, list[tuple[Callable[[EventType, dict | None], None], tuple[EventType] | None]]]
Get all subscribers aligned to this controller.
- async update(device_id: str, obj_in: AferoResource | None = None, states: list[dict] | None = None, send_duplicate_states: bool = False) ClientResponse | None
Update Afero IoT with the new data.
- async update_afero_api(device_id: str, states: list[dict]) ClientResponse | bool
Update Afero IoT API with the new states.
- async update_number(state: AferoState, cur_item: AferoResource) str | None
Update the number if its tracked and a change has been detected.
- Parameters:
state (AferoState) – State to update
cur_item (AferoResource) – Current item to update
- Returns:
Identifier of the number that was updated or None
- Return type:
str | None
- async update_select(state: AferoState, cur_item: AferoResource) str | None
Update the select if its tracked and a change has been detected.
- Parameters:
state (AferoState) – State to update
cur_item (AferoResource) – Current item to update
- Returns:
Identifier of the select that was updated or None
- Return type:
str | None
- async update_sensor(state: AferoState, cur_item: AferoResource) str | None
Update the sensor if its tracked and a change has been detected.
- Parameters:
state (AferoState) – State to update
cur_item (AferoResource) – Current item to update
- Returns:
Identifier of the sensor that was updated or None
- Return type:
str | None
Model¶
- class aioafero.v1.models.light.Light(*, _id: str, available: bool, device_information: ~aioafero.v1.models.resource.DeviceInformation = <factory>, split_identifier: str | None = None, numbers: dict[tuple[str, str | None], ~aioafero.v1.models.features.NumbersFeature] | None = <factory>, selects: dict[tuple[str, str | None], ~aioafero.v1.models.features.SelectFeature] | None = <factory>, sensors: dict[str, ~aioafero.v1.models.sensor.AferoSensor] = <factory>, binary_sensors: dict[str, ~aioafero.v1.models.sensor.AferoBinarySensor] = <factory>, type: ~aioafero.v1.models.resource.ResourceTypes = ResourceTypes.LIGHT, on: ~aioafero.v1.models.features.OnFeature | None = None, color: ~aioafero.v1.models.features.ColorFeature | None = None, color_mode: ~aioafero.v1.models.features.ColorModeFeature | None = None, color_modes: list[str] | None = None, color_temperature: ~aioafero.v1.models.features.ColorTemperatureFeature | None = None, dimming: ~aioafero.v1.models.features.DimmingFeature | None = None, effect: ~aioafero.v1.models.features.EffectFeature | None = None, supports_white: bool = False, dual_channel: bool = False, color_brightness: int | None = None, white_brightness: int | None = None)[source]
Bases:
StandardMixinRepresentation of an Afero Light.
- Parameters:
_id (str)
available (bool)
device_information (DeviceInformation)
split_identifier (str | None)
numbers (dict[tuple[str, str | None], NumbersFeature] | None)
selects (dict[tuple[str, str | None], SelectFeature] | None)
sensors (dict[str, AferoSensor])
binary_sensors (dict[str, AferoBinarySensor])
type (ResourceTypes)
on (OnFeature | None)
color (ColorFeature | None)
color_mode (ColorModeFeature | None)
color_temperature (ColorTemperatureFeature | None)
dimming (DimmingFeature | None)
effect (EffectFeature | None)
supports_white (bool)
dual_channel (bool)
color_brightness (int | None)
white_brightness (int | None)
- __post_init__()[source]
Determine if white only is supported.
- property supports_color: bool
Return if this light supports color control.
- property supports_color_temperature: bool
Return if this light supports color_temperature control.
- property supports_color_white: bool
Return if this light supports setting white.
- property supports_dimming: bool
Return if this light supports brightness control.
- property supports_effects: bool
Return if this light supports brightness control.
- property supports_on
If the light can be toggled on or off.
- property is_on: bool
Return bool if light is currently powered on.
- property brightness: float
Return current brightness of light.
- property is_dual_channel: bool
Return True when color and white brightness are independently controllable.
- channel_brightness(channel: str) float | None[source]
Return cached brightness percentage for a dual-channel zone.
- __init__(*, _id: str, available: bool, device_information: ~aioafero.v1.models.resource.DeviceInformation = <factory>, split_identifier: str | None = None, numbers: dict[tuple[str, str | None], ~aioafero.v1.models.features.NumbersFeature] | None = <factory>, selects: dict[tuple[str, str | None], ~aioafero.v1.models.features.SelectFeature] | None = <factory>, sensors: dict[str, ~aioafero.v1.models.sensor.AferoSensor] = <factory>, binary_sensors: dict[str, ~aioafero.v1.models.sensor.AferoBinarySensor] = <factory>, type: ~aioafero.v1.models.resource.ResourceTypes = ResourceTypes.LIGHT, on: ~aioafero.v1.models.features.OnFeature | None = None, color: ~aioafero.v1.models.features.ColorFeature | None = None, color_mode: ~aioafero.v1.models.features.ColorModeFeature | None = None, color_modes: list[str] | None = None, color_temperature: ~aioafero.v1.models.features.ColorTemperatureFeature | None = None, dimming: ~aioafero.v1.models.features.DimmingFeature | None = None, effect: ~aioafero.v1.models.features.EffectFeature | None = None, supports_white: bool = False, dual_channel: bool = False, color_brightness: int | None = None, white_brightness: int | None = None) None
- Parameters:
_id (str)
available (bool)
device_information (DeviceInformation)
split_identifier (str | None)
numbers (dict[tuple[str, str | None], NumbersFeature] | None)
selects (dict[tuple[str, str | None], SelectFeature] | None)
sensors (dict[str, AferoSensor])
binary_sensors (dict[str, AferoBinarySensor])
type (ResourceTypes)
on (OnFeature | None)
color (ColorFeature | None)
color_mode (ColorModeFeature | None)
color_temperature (ColorTemperatureFeature | None)
dimming (DimmingFeature | None)
effect (EffectFeature | None)
supports_white (bool)
dual_channel (bool)
color_brightness (int | None)
white_brightness (int | None)
- Return type:
None