| /* |
| * |
| * Copyright (c) 2022 Project CHIP Authors |
| * All rights reserved. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #include "TemperatureManager.h" |
| #include "AppConfig.h" |
| #include "AppTask.h" |
| #include <zephyr/logging/log.h> |
| |
| LOG_MODULE_DECLARE(app, CONFIG_CHIP_APP_LOG_LEVEL); |
| |
| using namespace chip; |
| using namespace ::chip::DeviceLayer; |
| |
| constexpr EndpointId kThermostatEndpoint = 1; |
| |
| namespace ThermAttr = chip::app::Clusters::Thermostat::Attributes; |
| |
| TemperatureManager TemperatureManager::sTempMgr; |
| |
| CHIP_ERROR TemperatureManager::Init() |
| { |
| app::DataModel::Nullable<int16_t> temp; |
| int16_t heatingSetpoint, coolingSetpoint; |
| uint8_t systemMode; |
| |
| PlatformMgr().LockChipStack(); |
| ThermAttr::LocalTemperature::Get(kThermostatEndpoint, temp); |
| ThermAttr::OccupiedCoolingSetpoint::Get(kThermostatEndpoint, &coolingSetpoint); |
| ThermAttr::OccupiedHeatingSetpoint::Get(kThermostatEndpoint, &heatingSetpoint); |
| ThermAttr::SystemMode::Get(kThermostatEndpoint, &systemMode); |
| PlatformMgr().UnlockChipStack(); |
| |
| mCurrentTempCelsius = ConvertToPrintableTemp(temp.Value()); |
| mHeatingCelsiusSetPoint = ConvertToPrintableTemp(coolingSetpoint); |
| mCoolingCelsiusSetPoint = ConvertToPrintableTemp(heatingSetpoint); |
| mThermMode = systemMode; |
| |
| GetAppTask().UpdateThermoStatUI(); |
| |
| return CHIP_NO_ERROR; |
| } |
| |
| int8_t TemperatureManager::ConvertToPrintableTemp(int16_t temperature) |
| { |
| constexpr uint8_t kRoundUpValue = 50; |
| |
| // Round up the temperature as we won't print decimals on LCD |
| // Is it a negative temperature |
| if (temperature < 0) |
| { |
| temperature -= kRoundUpValue; |
| } |
| else |
| { |
| temperature += kRoundUpValue; |
| } |
| |
| return static_cast<int8_t>(temperature / 100); |
| } |
| |
| void TemperatureManager::AttributeChangeHandler(EndpointId endpointId, AttributeId attributeId, uint8_t * value, uint16_t size) |
| { |
| switch (attributeId) |
| { |
| case ThermAttr::LocalTemperature::Id: { |
| int8_t Temp = ConvertToPrintableTemp(*((int16_t *) value)); |
| LOG_INF("Local temp %d", Temp); |
| mCurrentTempCelsius = Temp; |
| } |
| break; |
| |
| case ThermAttr::OccupiedCoolingSetpoint::Id: { |
| int8_t coolingTemp = ConvertToPrintableTemp(*((int16_t *) value)); |
| LOG_INF("CoolingSetpoint %d", coolingTemp); |
| mCoolingCelsiusSetPoint = coolingTemp; |
| } |
| break; |
| |
| case ThermAttr::OccupiedHeatingSetpoint::Id: { |
| int8_t heatingTemp = ConvertToPrintableTemp(*((int16_t *) value)); |
| LOG_INF("HeatingSetpoint %d", heatingTemp); |
| mHeatingCelsiusSetPoint = heatingTemp; |
| } |
| break; |
| |
| case ThermAttr::SystemMode::Id: { |
| LOG_INF("SystemMode %d", static_cast<uint8_t>(*value)); |
| uint8_t mode = static_cast<uint8_t>(*value); |
| if (mThermMode != mode) |
| { |
| mThermMode = mode; |
| } |
| } |
| break; |
| |
| default: { |
| LOG_INF("Unhandled thermostat attribute %x", attributeId); |
| return; |
| } |
| break; |
| } |
| |
| GetAppTask().UpdateThermoStatUI(); |
| } |
| |
| uint8_t TemperatureManager::GetMode() |
| { |
| return mThermMode; |
| } |
| |
| int8_t TemperatureManager::GetCurrentTemp() |
| { |
| return mCurrentTempCelsius; |
| } |
| int8_t TemperatureManager::GetHeatingSetPoint() |
| { |
| return mHeatingCelsiusSetPoint; |
| } |
| |
| int8_t TemperatureManager::GetCoolingSetPoint() |
| { |
| return mCoolingCelsiusSetPoint; |
| } |