forked from espressif/arduino-esp32
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMatterHumiditySensor.cpp
111 lines (92 loc) · 3.64 KB
/
MatterHumiditySensor.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// Copyright 2024 Espressif Systems (Shanghai) PTE LTD
//
// 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 <sdkconfig.h>
#ifdef CONFIG_ESP_MATTER_ENABLE_DATA_MODEL
#include <Matter.h>
#include <app/server/Server.h>
#include <MatterEndpoints/MatterHumiditySensor.h>
using namespace esp_matter;
using namespace esp_matter::endpoint;
using namespace chip::app::Clusters;
bool MatterHumiditySensor::attributeChangeCB(uint16_t endpoint_id, uint32_t cluster_id, uint32_t attribute_id, esp_matter_attr_val_t *val) {
bool ret = true;
if (!started) {
log_e("Matter Humidity Sensor device has not begun.");
return false;
}
log_d("Humidity Sensor Attr update callback: endpoint: %u, cluster: %u, attribute: %u, val: %u", endpoint_id, cluster_id, attribute_id, val->val.u32);
return ret;
}
MatterHumiditySensor::MatterHumiditySensor() {}
MatterHumiditySensor::~MatterHumiditySensor() {
end();
}
bool MatterHumiditySensor::begin(uint16_t _rawHumidity) {
ArduinoMatter::_init();
// is it a valid percentage value?
if (_rawHumidity > 10000) {
log_e("Humidity Sensor Percentage value out of range [0..100].");
return false;
}
humidity_sensor::config_t humidity_sensor_config;
humidity_sensor_config.relative_humidity_measurement.measured_value = _rawHumidity;
humidity_sensor_config.relative_humidity_measurement.min_measured_value = nullptr;
humidity_sensor_config.relative_humidity_measurement.max_measured_value = nullptr;
// endpoint handles can be used to add/modify clusters.
endpoint_t *endpoint = humidity_sensor::create(node::get(), &humidity_sensor_config, ENDPOINT_FLAG_NONE, (void *)this);
if (endpoint == nullptr) {
log_e("Failed to create Humidity Sensor endpoint");
return false;
}
rawHumidity = _rawHumidity;
setEndPointId(endpoint::get_id(endpoint));
log_i("Humidity Sensor created with endpoint_id %d", getEndPointId());
started = true;
return true;
}
void MatterHumiditySensor::end() {
started = false;
}
bool MatterHumiditySensor::setRawHumidity(uint16_t _rawHumidity) {
if (!started) {
log_e("Matter Humidity Sensor device has not begun.");
return false;
}
// is it a valid percentage value?
if (_rawHumidity > 10000) {
log_e("Humidity Sensor Percentage value out of range [0..100].");
return false;
}
// avoid processing the a "no-change"
if (rawHumidity == _rawHumidity) {
return true;
}
esp_matter_attr_val_t humidityVal = esp_matter_invalid(NULL);
if (!getAttributeVal(RelativeHumidityMeasurement::Id, RelativeHumidityMeasurement::Attributes::MeasuredValue::Id, &humidityVal)) {
log_e("Failed to get Humidity Sensor Attribute.");
return false;
}
if (humidityVal.val.u16 != _rawHumidity) {
humidityVal.val.u16 = _rawHumidity;
bool ret;
ret = updateAttributeVal(RelativeHumidityMeasurement::Id, RelativeHumidityMeasurement::Attributes::MeasuredValue::Id, &humidityVal);
if (!ret) {
log_e("Failed to update Fan Speed Percent Attribute.");
return false;
}
rawHumidity = _rawHumidity;
}
log_v("Humidity Sensor set to %.02f Percent", (float)_rawHumidity / 100.00);
return true;
}
#endif /* CONFIG_ESP_MATTER_ENABLE_DATA_MODEL */