# BigAssFan Binding The [BigAssFan](https://www.bigassfans.com/) binding is used to enable communication between openHAB and Big Ass Fans' Haiku family of residential fans and lights that implement the SenseME technology. ## Overview Fans, lights and controllers are discovered dynamically. There is a single thing created for each fan, light, or controller that's connected to the local WiFi network. Each thing has channels that allow control of the fan and light, as well as to monitor the status. When a fan or light is controlled from the remote control, Wall Controller, or smartphone app, the openHAB items linked to the device's channels will be updated to reflect the status. ### Important Notice The latest firmware for Haiku devices no longer uses the SenseMe protocol. As a result, this binding will not work with fans running firmware version 3.0.0 or later. ## Supported Things The binding currently supports the following devices. | Thing | ID | | |-------------|-------------|--------------------| | Fan | fan | BigAssFan consisting of fan and integrated LED light | | Light | light | Standalone LED light | | Controller | controller | Fan wall controller | ## Thing Configuration | Parameter | Parameter ID | Required/Optional | Description | |--------------|---------------|-------------------|-------------| | Label | label | Required | Label given to device in the Haiku Smartphone app. | | IP Address | ipAddress | Required | IP address of the device. | | MAC Address | macAddress | Required | MAC address of the device. | In the event that any of this information is changed on the device, the thing configuration must be updated manually, as it cannot be determined automatically by the binding. ### Manual Thing Creation Fan and light things can be manually created using the *UI*, or by placing a *.things* file in the *conf/things* directory. See example below. ## Device Discovery The BigAssFan binding discovers Haiku fans and lights on the network, and creates an inbox entry for each discovered device. Once added as a thing, the user can control the fan and light, similarly to how the device is controlled using the remote, Wall Controller, or smartphone app. Background discovery polls the network every few minutes for devices. Background discovery is **enabled** by default. To **disable** background discovery, add the following line to the *conf/services/runtime.cfg* file: ```text discovery.bigassfan:background=false ``` ## Channels The following channels are supported for fans: | Channel Name | Item Type | Description | |-------------------------|--------------|-------------------------------------------------------| | fan-power | Switch | Power on/off the fan | | fan-speed | Dimmer | Adjust the speed of the fan | | fan-direction | String | Indicates the direction in which the fan is turning | | fan-auto | Switch | Enable/disable fan auto mode | | fan-whoosh | Switch | Enable/disable fan "whoosh" mode | | fan-sleep | Switch | Enable/disable fan sleep mode | | fan-smartmode | String | Set Smartmode to HEATING, COOLING, or OFF | | fan-learn-minspeed | Dimmer | Set minimum fan speed for Smartmode COOLING | | fan-learn-maxspeed | Dimmer | Set maximum fan speed for Smartmode COOLING | | fan-wintermode | Switch | Enable/disable fan winter mode | | fan-speed-min | Dimmer | Set minimum fan speed | | fan-speed-max | Dimmer | Set maximum fan speed | | light-power | Switch | Power on/off the light | | light-level | Dimmer | Adjust the brightness of the light | | light-auto | Switch | Enable/disable light auto mode | | light-smarter | String | Enable/disable Smarter Lighting | | light-level-min | Dimmer | Set minimum light level for Smarter Lighting | | light-level-max | Dimmer | Set maximum light level for Smarter Lighting | | light-present | String | Indicates is a light is installed in the fan | | motion | Switch | Motion was detected | | time | DateTime | Fan's date and time | The following channels are supported for lights: | Channel Name | Item Type | Description | |-------------------------|--------------|-------------------------------------------------------| | light-power | Switch | Power on/off the light | | light-level | Dimmer | Adjust the brightness of the light | | light-hue | Dimmer | Adjust the color temperature of the light | | light-present | String | Indicates if a light is installed | | light-color | String | Indicates if the light supports hue adjustment | | motion | Switch | Motion was detected | | time | DateTime | Light's date and time | The following channels are supported for wall controllers: | Channel Name | Item Type | Description | |-------------------------|--------------|-------------------------------------------------------| | motion | Switch | Motion was detected | | time | DateTime | Wall controllers date and time | ## Fan Items The following item definitions would be used to control the fan. ```java Switch PorchFanPower { channel="bigassfan:fan:20F85EDAA56A:fan-power" } Dimmer PorchFanSpeed { channel="bigassfan:fan:20F85EDAA56A:fan-speed" } Switch PorchFanAuto { channel="bigassfan:fan:20F85EDAA56A:fan-auto" } Switch PorchFanWhoosh { channel="bigassfan:fan:20F85EDAA56A:fan-whoosh" } Switch PorchFanSleep { channel="bigassfan:fan:20F85EDAA56A:fan-sleep" } String PorchFanSmartmode { channel="bigassfan:fan:20F85EDAA56A:fan-smartmode" } Dimmer PorchFanSpeedMin { channel="bigassfan:fan:20F85EDAA56A:fan-learn-minspeed" } Dimmer PorchFanSpeedMax { channel="bigassfan:fan:20F85EDAA56A:fan-learn-maxspeed" } ``` The following item definitions would be used to control the light. ```java Switch PorchFanLightPower { channel="bigassfan:fan:20F85EDAA56A:light-power" } Dimmer PorchFanLightLevel { channel="bigassfan:fan:20F85EDAA56A:light-level" } Switch PorchFanLightAuto { channel="bigassfan:fan:20F85EDAA56A:light-auto" } Switch PorchFanLightSmarter { channel="bigassfan:fan:20F85EDAA56A:light-smarter" } Dimmer PorchFanLightLevelMin { channel="bigassfan:fan:20F85EDAA56A:light-level-min" } Dimmer PorchFanLightLevelMax { channel="bigassfan:fan:20F85EDAA56A:light-level-max" } ``` The following read-only items are provided by the fan. ```java String PorchFanLightPresent { channel="bigassfan:fan:20F85EDAA56A:light-present" } Switch PorchFanMotionSensor { channel="bigassfan:fan:20F85EDAA56A:motion" } DateTime PorchFanTime { channel="bigassfan:fan:20F85EDAA56A:time" } ``` ## Light Items ```java Switch KitchenLightPower { channel="bigassfan:light:20F85EDA87A0:light-power" } Dimmer KitchenLightLevel { channel="bigassfan:light:20F85EDA87A0:light-level" } Switch KitchenLightHue { channel="bigassfan:light:20F85EDA87A0:light-hue" } ``` The following read-only items are provided by the light. ```java String KitchenLightPresent { channel="bigassfan:light:20F85EDA87A0:light-present" } String KitchenLightColor { channel="bigassfan:light:20F85EDA87A0:light-color" } Switch KitchenLightMotionSensor { channel="bigassfan:light:20F85EDA87A0:motion" } DateTime KitchenLightTime { channel="bigassfan:light:20F85EDA87A0:time" } ``` ## Wall Controller Items The following read-only items are provided by the wall controller. ```java Switch PorchControllerMotionSensor { channel="bigassfan:controller:20F85ED87F01:motion" } DateTime PorchControllerTime { channel="bigassfan:controller:20F85ED87F01:time" } ``` ### Sitemap This is an example of how to set up your sitemap. ```perl Frame label="Control My BigAssFan" { Switch item=PorchFanPower label="Fan Power [%s]" Slider item=PorchFanSpeed label="Fan Speed [%s %%]" Switch item=PorchFanLightPower label="Light Power [%s]" Slider item=PorchFanLightLevel label="Light Brightness [%s %%]" } Frame label="Control My Light" { Switch item=KitchenLightPower label="Light Power [%s]" Slider item=KitchenLightLevel label="Light Level [%s %%]" Slider item=KitchenLightHue label="Light Hue [%s]" } ``` ### Manual Thing Creation Place a file named *bigassfan.things* in the *conf/things* directory. The file should contain lines formatted like this. ```java bigassfan:fan:20F85EDAA56A [ label="Porch Fan", ipAddress="192.168.12.62", macAddress="20:F8:5E:DA:A5:6A" ] ```