#pragma once #include namespace esphome { namespace haier { namespace hon_protocol { enum class VerticalSwingMode : uint8_t { HEALTH_UP = 0x01, MAX_UP = 0x02, HEALTH_DOWN = 0x03, UP = 0x04, CENTER = 0x06, DOWN = 0x08, AUTO = 0x0C }; enum class HorizontalSwingMode : uint8_t { CENTER = 0x00, MAX_LEFT = 0x03, LEFT = 0x04, RIGHT = 0x05, MAX_RIGHT = 0x06, AUTO = 0x07 }; enum class ConditioningMode : uint8_t { AUTO = 0x00, COOL = 0x01, DRY = 0x02, HEALTHY_DRY = 0x03, HEAT = 0x04, ENERGY_SAVING = 0x05, FAN = 0x06 }; enum class DataParameters : uint8_t { AC_POWER = 0x01, SET_POINT = 0x02, AC_MODE = 0x04, FAN_MODE = 0x05, USE_FAHRENHEIT = 0x07, TEN_DEGREE = 0x0A, HEALTH_MODE = 0x0B, BEEPER_STATUS = 0x16, LOCK_REMOTE = 0x17, QUIET_MODE = 0x19, FAST_MODE = 0x1A, }; enum class SpecialMode : uint8_t { NONE = 0x00, ELDERLY = 0x01, CHILDREN = 0x02, PREGNANT = 0x03 }; enum class FanMode : uint8_t { FAN_HIGH = 0x01, FAN_MID = 0x02, FAN_LOW = 0x03, FAN_AUTO = 0x05 }; struct HaierPacketControl { // Control bytes starts here // 10 uint8_t set_point; // Target temperature with 16°C offset (0x00 = 16°C) // 11 uint8_t vertical_swing_mode : 4; // See enum VerticalSwingMode uint8_t : 0; // 12 uint8_t fan_mode : 3; // See enum FanMode uint8_t special_mode : 2; // See enum SpecialMode uint8_t ac_mode : 3; // See enum ConditioningMode // 13 uint8_t : 8; // 14 uint8_t ten_degree : 1; // 10 degree status uint8_t display_status : 1; // If 0 disables AC's display uint8_t half_degree : 1; // Use half degree uint8_t intelligence_status : 1; // Intelligence status uint8_t pmv_status : 1; // Comfort/PMV status uint8_t use_fahrenheit : 1; // Use Fahrenheit instead of Celsius uint8_t : 1; uint8_t steri_clean : 1; // 15 uint8_t ac_power : 1; // Is ac on or off uint8_t health_mode : 1; // Health mode (negative ions) on or off uint8_t electric_heating_status : 1; // Electric heating status uint8_t fast_mode : 1; // Fast mode uint8_t quiet_mode : 1; // Quiet mode uint8_t sleep_mode : 1; // Sleep mode uint8_t lock_remote : 1; // Disable remote uint8_t beeper_status : 1; // If 1 disables AC's command feedback beeper (need to be set on every control command) // 16 uint8_t target_humidity; // Target humidity (0=30% .. 3C=90%, step = 1%) // 17 uint8_t horizontal_swing_mode : 3; // See enum HorizontalSwingMode uint8_t : 3; uint8_t human_sensing_status : 2; // Human sensing status // 18 uint8_t change_filter : 1; // Filter need replacement uint8_t : 0; // 19 uint8_t fresh_air_status : 1; // Fresh air status uint8_t humidification_status : 1; // Humidification status uint8_t pm2p5_cleaning_status : 1; // PM2.5 cleaning status uint8_t ch2o_cleaning_status : 1; // CH2O cleaning status uint8_t self_cleaning_status : 1; // Self cleaning status uint8_t light_status : 1; // Light status uint8_t energy_saving_status : 1; // Energy saving status uint8_t cleaning_time_status : 1; // Cleaning time (0 - accumulation, 1 - clear) }; struct HaierPacketSensors { // 20 uint8_t room_temperature; // 0.5°C step // 21 uint8_t room_humidity; // 0%-100% with 1% step // 22 uint8_t outdoor_temperature; // 1°C step, -64°C offset (0=-64°C) // 23 uint8_t pm2p5_level : 2; // Indoor PM2.5 grade (00: Excellent, 01: good, 02: Medium, 03: Bad) uint8_t air_quality : 2; // Air quality grade (00: Excellent, 01: good, 02: Medium, 03: Bad) uint8_t human_sensing : 2; // Human presence result (00: N/A, 01: not detected, 02: One, 03: Multiple) uint8_t : 1; uint8_t ac_type : 1; // 00 - Heat and cool, 01 - Cool only) // 24 uint8_t error_status; // See enum ErrorStatus // 25 uint8_t operation_source : 2; // who is controlling AC (00: Other, 01: Remote control, 02: Button, 03: ESP) uint8_t operation_mode_hk : 2; // Homekit only, operation mode (00: Cool, 01: Dry, 02: Heat, 03: Fan) uint8_t : 3; uint8_t err_confirmation : 1; // If 1 clear error status // 26 uint16_t total_cleaning_time; // Cleaning cumulative time (1h step) // 28 uint16_t indoor_pm2p5_value; // Indoor PM2.5 value (0 ug/m3 - 4095 ug/m3, 1 ug/m3 step) // 30 uint16_t outdoor_pm2p5_value; // Outdoor PM2.5 value (0 ug/m3 - 4095 ug/m3, 1 ug/m3 step) // 32 uint16_t ch2o_value; // Formaldehyde value (0 ug/m3 - 10000 ug/m3, 1 ug/m3 step) // 34 uint16_t voc_value; // VOC value (Volatile Organic Compounds) (0 ug/m3 - 1023 ug/m3, 1 ug/m3 step) // 36 uint16_t co2_value; // CO2 value (0 PPM - 10000 PPM, 1 PPM step) }; constexpr size_t HAIER_STATUS_FRAME_SIZE = 2 + sizeof(HaierPacketControl) + sizeof(HaierPacketSensors); struct DeviceVersionAnswer { char protocol_version[8]; char software_version[8]; uint8_t encryption[3]; char hardware_version[8]; uint8_t : 8; char device_name[8]; uint8_t functions[2]; }; enum class SubcommandsControl : uint16_t { GET_PARAMETERS = 0x4C01, // Request specific parameters (packet content: parameter ID1 + parameter ID2 + ...) GET_USER_DATA = 0x4D01, // Request all user data from device (packet content: None) GET_BIG_DATA = 0x4DFE, // Request big data information from device (packet content: None) SET_PARAMETERS = 0x5C01, // Set parameters of the device and device return parameters (packet content: parameter ID1 // + parameter data1 + parameter ID2 + parameter data 2 + ...) SET_SINGLE_PARAMETER = 0x5D00, // Set single parameter (0x5DXX second byte define parameter ID) and return all user // data (packet content: ???) SET_GROUP_PARAMETERS = 0x6001, // Set group parameters to device (0x60XX second byte define parameter is group ID, // the only group mentioned in document is 1) and return all user data (packet // content: all values like in status packet) }; } // namespace hon_protocol } // namespace haier } // namespace esphome