blob: 81565d532e4e7eadc2eb42c96b7bf20b8b124baa [file] [log] [blame]
/*
*
* Copyright (c) 2023 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 <DeviceManager.h>
#include <air-quality-sensor-manager.h>
#include <app/clusters/fan-control-server/fan-control-server.h>
#include <filter-delegates.h>
#include <relative-humidity-sensor-manager.h>
#include <temperature-sensor-manager.h>
#pragma once
namespace chip {
namespace app {
namespace Clusters {
constexpr std::bitset<4> gHepaFilterFeatureMap{ static_cast<uint32_t>(ResourceMonitoring::Feature::kCondition) |
static_cast<uint32_t>(ResourceMonitoring::Feature::kWarning) |
static_cast<uint32_t>(ResourceMonitoring::Feature::kReplacementProductList) };
constexpr std::bitset<4> gActivatedCarbonFeatureMap{ static_cast<uint32_t>(ResourceMonitoring::Feature::kCondition) |
static_cast<uint32_t>(ResourceMonitoring::Feature::kWarning) |
static_cast<uint32_t>(ResourceMonitoring::Feature::kReplacementProductList) };
/**
* @brief
* This class provides a singleton AIr Purifier Manager which also implements the FanControl::Delegate and the Device Callbacks.
* The class is responsible for all Air Purifier Elements on the Air Purifier Endpoint and it has members that are other Managers
* for the devices in its composition tree.
*/
class AirPurifierManager : public FanControl::Delegate, public DeviceManager::DeviceManagerCallbacks
{
public:
// Delete copy constructor and assignment operator.
AirPurifierManager(const AirPurifierManager &) = delete;
AirPurifierManager(const AirPurifierManager &&) = delete;
AirPurifierManager & operator=(const AirPurifierManager &) = delete;
static void InitInstance(EndpointId aEndpointId = 1, EndpointId aAirQualitySensorEndpointId = 2,
EndpointId aTemperatureSensorEndpointId = 3, EndpointId aHumiditySensorEndpointId = 4)
{
if (mInstance == nullptr)
{
mInstance = new AirPurifierManager(aEndpointId, aAirQualitySensorEndpointId, aTemperatureSensorEndpointId,
aHumiditySensorEndpointId);
mInstance->Init();
}
};
/**
* @brief Get an Air Purifier Manager object - this class acts as a singleton device manager for the air purifier
* @param[in] aEndpointId Endpoint that the air purifier is on
* @param[in] aAirQualitySensorEndpointId Endpoint that the air quality sensor is on
* @param[in] aTemperatureSensorEndpointId Endpoint that the temperature sensor is on
* @param[in] aHumiditySensorEndpointId Endpoint that the humidity sensor is on
* @return mInstance The AirPurifierManager instance, note this this could be nullptr if InitInstance has not been called
*/
static AirPurifierManager * GetInstance() { return mInstance; };
/**
* @brief Initialize the Air Purifier Manager and call init on underlying composed members.
*/
void Init();
/**
* @brief Top level handler for all attribute changes in the device. This function will call the appropriate attribute change
* handler based on the cluster id.
*/
void PostAttributeChangeCallback(EndpointId endpoint, ClusterId clusterId, AttributeId attributeId, uint8_t type, uint16_t size,
uint8_t * value) override;
/**
* @brief Handle the step command from the Fan Control Cluster
*/
Protocols::InteractionModel::Status HandleStep(FanControl::StepDirectionEnum aDirection, bool aWrap, bool aLowestOff) override;
private:
inline static AirPurifierManager * mInstance;
EndpointId mEndpointId;
EndpointId mAirQualitySensorEndpointId;
EndpointId mTemperatureSensorEndpointId;
EndpointId mHumiditySensorEndpointId;
uint8_t percentCurrent;
uint8_t speedCurrent;
// Set up for Activated Carbon Filter Monitoring
ActivatedCarbonFilterMonitoringDelegate activatedCarbonFilterDelegate;
ResourceMonitoring::Instance activatedCarbonFilterInstance;
// Set up for Hepa Filter Monitoring
HepaFilterMonitoringDelegate hepaFilterDelegate;
ResourceMonitoring::Instance hepaFilterInstance;
// Set up other members of composed device
AirQualitySensorManager mAirQualitySensorManager;
TemperatureSensorManager mTemperatureSensorManager;
RelativeHumiditySensorManager mHumiditySensorManager;
// Fan Mode Limits
static constexpr int FAN_MODE_LOW_LOWER_BOUND = 1;
static constexpr int FAN_MODE_LOW_UPPER_BOUND = 3;
static constexpr int FAN_MODE_MEDIUM_LOWER_BOUND = 4;
static constexpr int FAN_MODE_MEDIUM_UPPER_BOUND = 7;
static constexpr int FAN_MODE_HIGH_LOWER_BOUND = 8;
static constexpr int FAN_MODE_HIGH_UPPER_BOUND = 10;
/**
* @brief Construct a new Air Purifier Manager object - this class acts as a singleton device manager for the air purifier
* @param[in] aEndpointId Endpoint that the air purifier is on
* @param[in] aAirQualitySensorEndpointId Endpoint that the air quality sensor is on
* @param[in] aTemperatureSensorEndpointId Endpoint that the temperature sensor is on
* @param[in] aHumiditySensorEndpointId Endpoint that the humidity sensor is on
*/
AirPurifierManager(EndpointId aEndpointId, EndpointId aAirQualitySensorEndpointId, EndpointId aTemperatureSensorEndpointId,
EndpointId aHumiditySensorEndpointId) :
FanControl::Delegate(aEndpointId),
mEndpointId(aEndpointId),
activatedCarbonFilterInstance(&activatedCarbonFilterDelegate, mEndpointId, ActivatedCarbonFilterMonitoring::Id,
static_cast<uint32_t>(gActivatedCarbonFeatureMap.to_ulong()),
ResourceMonitoring::DegradationDirectionEnum::kDown, true),
hepaFilterInstance(&hepaFilterDelegate, mEndpointId, HepaFilterMonitoring::Id,
static_cast<uint32_t>(gHepaFilterFeatureMap.to_ulong()),
ResourceMonitoring::DegradationDirectionEnum::kDown, true),
mAirQualitySensorManager(aAirQualitySensorEndpointId), mTemperatureSensorManager(aTemperatureSensorEndpointId),
mHumiditySensorManager(aHumiditySensorEndpointId){};
/**
* @brief Handle attribute changes for the Fan Control Cluster
* @param[in] attributeId Cluster attribute id that changed
* @param[in] type Cluster attribute type
* @param[in] size Size of the attribute
* @param[in] value Pointer to the new value
*/
void HandleFanControlAttributeChange(AttributeId attributeId, uint8_t type, uint16_t size, uint8_t * value);
void PercentSettingWriteCallback(uint8_t aNewPercentSetting);
void SpeedSettingWriteCallback(uint8_t aNewSpeedSetting);
void FanModeWriteCallback(FanControl::FanModeEnum aNewFanMode);
void SetSpeedSetting(DataModel::Nullable<uint8_t> aNewSpeedSetting);
};
} // namespace Clusters
} // namespace app
} // namespace chip