def _async_control_heating(self):
        """Check if we need to turn heating on or off."""
        if not self._active and None not in (self._cur_temp,
                                             self._target_temp):
            self._active = True
            _LOGGER.info('Obtained current and target temperature. '
                         'Generic thermostat active.')

        if not self._active:
            return

        if not self._enabled:
            return

        if self.min_cycle_duration:
            if self._is_device_active:
                current_state = STATE_ON
            else:
                current_state = STATE_OFF
            long_enough = condition.state(
                self.hass, self.heater_entity_id, current_state,
                self.min_cycle_duration)
            if not long_enough:
                return

        if self.ac_mode:
            is_cooling = self._is_device_active
            if is_cooling:
                too_cold = self._target_temp - self._cur_temp >= \
                    self._cold_tolerance
                if too_cold:
                    _LOGGER.info('Turning off AC %s', self.heater_entity_id)
                    switch.async_turn_off(self.hass, self.heater_entity_id)
            else:
                too_hot = self._cur_temp - self._target_temp >= \
                    self._hot_tolerance
                if too_hot:
                    _LOGGER.info('Turning on AC %s', self.heater_entity_id)
                    switch.async_turn_on(self.hass, self.heater_entity_id)
        else:
            is_heating = self._is_device_active
            if is_heating:
                too_hot = self._cur_temp - self._target_temp >= \
                    self._hot_tolerance
                if too_hot:
                    _LOGGER.info('Turning off heater %s',
                                 self.heater_entity_id)
                    switch.async_turn_off(self.hass, self.heater_entity_id)
            else:
                too_cold = self._target_temp - self._cur_temp >= \
                    self._cold_tolerance
                if too_cold:
                    _LOGGER.info('Turning on heater %s', self.heater_entity_id)
                    switch.async_turn_on(self.hass, self.heater_entity_id)
 def set_operation_mode(self, operation_mode):
     """Set operation mode."""
     if operation_mode == STATE_AUTO:
         self._enabled = True
     elif operation_mode == STATE_OFF:
         self._enabled = False
         if self._is_device_active:
             switch.async_turn_off(self.hass, self.heater_entity_id)
     else:
         _LOGGER.error('Unrecognized operation mode: %s', operation_mode)
         return
     # Ensure we updae the current operation after changing the mode
     self.schedule_update_ha_state()
Exemplo n.º 3
0
    def _async_control_heating(self):
        """Check if we need to turn heating on or off."""
        if not self._active and None not in (self._cur_temp,
                                             self._target_temp):
            self._active = True
            _LOGGER.info('Obtained current and target temperature. '
                         'Generic thermostat active.')

        if not self._active:
            return

        if self.min_cycle_duration:
            if self._is_device_active:
                current_state = STATE_ON
            else:
                current_state = STATE_OFF
            long_enough = condition.state(self.hass, self.heater_entity_id,
                                          current_state,
                                          self.min_cycle_duration)
            if not long_enough:
                return

        if self.ac_mode:
            is_cooling = self._is_device_active
            if is_cooling:
                too_cold = self._target_temp - self._cur_temp > self._tolerance
                if too_cold:
                    _LOGGER.info('Turning off AC %s', self.heater_entity_id)
                    switch.async_turn_off(self.hass, self.heater_entity_id)
            else:
                too_hot = self._cur_temp - self._target_temp > self._tolerance
                if too_hot:
                    _LOGGER.info('Turning on AC %s', self.heater_entity_id)
                    switch.async_turn_on(self.hass, self.heater_entity_id)
        else:
            is_heating = self._is_device_active
            if is_heating:
                too_hot = self._cur_temp - self._target_temp > self._tolerance
                if too_hot:
                    _LOGGER.info('Turning off heater %s',
                                 self.heater_entity_id)
                    switch.async_turn_off(self.hass, self.heater_entity_id)
            else:
                too_cold = self._target_temp - self._cur_temp > self._tolerance
                if too_cold:
                    _LOGGER.info('Turning on heater %s', self.heater_entity_id)
                    switch.async_turn_on(self.hass, self.heater_entity_id)
Exemplo n.º 4
0
 def _async_keep_alive(self, time):
     """Called at constant intervals for keep-alive purposes."""
     if self.current_operation in [STATE_COOL, STATE_HEAT]:
         switch.async_turn_on(self.hass, self.heater_entity_id)
     else:
         switch.async_turn_off(self.hass, self.heater_entity_id)
Exemplo n.º 5
0
 def _async_keep_alive(self, time):
     """Call at constant intervals for keep-alive purposes."""
     if self.current_operation in [STATE_COOL, STATE_HEAT]:
         switch.async_turn_on(self.hass, self.heater_entity_id)
     else:
         switch.async_turn_off(self.hass, self.heater_entity_id)
Exemplo n.º 6
0
 def _async_keep_alive(self, time):
     """Call at constant intervals for keep-alive purposes."""
     if self._active and self._is_device_active:
         switch.async_turn_on(self.hass, self.heater_entity_id)
     else:
         switch.async_turn_off(self.hass, self.heater_entity_id)