60 for (uint8_t i = 0; i < client_count; i++) {
61 uint16_t client = clients[i];
67 bool require_ack = entry->indicate;
70 ESP_LOGW(TAG,
"INDICATE acknowledgment is not yet supported (i.e. it works as a NOTIFY)");
74 length, this->value_.data(), require_ack);
76 ESP_LOGE(TAG,
"esp_ble_gatts_send_indicate failed %d", err);
179 esp_ble_gatts_cb_param_t *param) {
181 case ESP_GATTS_ADD_CHAR_EVT: {
183 this->
handle_ = param->add_char.attr_handle;
186 descriptor->do_create(
this);
193 case ESP_GATTS_READ_EVT: {
194 if (param->read.handle != this->handle_)
197 if (!param->read.need_rsp)
204 uint16_t max_offset = 22;
206 esp_gatt_rsp_t response;
207 if (param->read.is_long) {
208 if (this->
value_.size() - this->value_read_offset_ < max_offset) {
212 memcpy(response.attr_value.value, this->value_.data() + response.attr_value.offset, response.attr_value.len);
215 response.attr_value.len = max_offset;
217 memcpy(response.attr_value.value, this->value_.data() + response.attr_value.offset, response.attr_value.len);
221 response.attr_value.offset = 0;
222 if (this->
value_.size() + 1 > max_offset) {
223 response.attr_value.len = max_offset;
226 response.attr_value.len = this->
value_.size();
228 memcpy(response.attr_value.value, this->value_.data(), response.attr_value.len);
231 response.attr_value.handle = this->
handle_;
232 response.attr_value.auth_req = ESP_GATT_AUTH_REQ_NONE;
235 esp_ble_gatts_send_response(gatts_if, param->read.conn_id, param->read.trans_id, ESP_GATT_OK, &response);
237 ESP_LOGE(TAG,
"esp_ble_gatts_send_response failed: %d", err);
241 case ESP_GATTS_WRITE_EVT: {
242 if (this->
handle_ != param->write.handle)
245 if (param->write.is_prep) {
246 this->
value_.insert(this->
value_.end(), param->write.value, param->write.value + param->write.len);
252 if (param->write.need_rsp) {
253 esp_gatt_rsp_t response;
255 response.attr_value.len = param->write.len;
256 response.attr_value.handle = this->
handle_;
257 response.attr_value.offset = param->write.offset;
258 response.attr_value.auth_req = ESP_GATT_AUTH_REQ_NONE;
259 memcpy(response.attr_value.value, param->write.value, param->write.len);
262 esp_ble_gatts_send_response(gatts_if, param->write.conn_id, param->write.trans_id, ESP_GATT_OK, &response);
265 ESP_LOGE(TAG,
"esp_ble_gatts_send_response failed: %d", err);
269 if (!param->write.is_prep) {
278 case ESP_GATTS_EXEC_WRITE_EVT: {
282 if (param->exec_write.exec_write_flag == ESP_GATT_PREP_WRITE_EXEC) {
288 esp_ble_gatts_send_response(gatts_if, param->write.conn_id, param->write.trans_id, ESP_GATT_OK,
nullptr);
290 ESP_LOGE(TAG,
"esp_ble_gatts_send_response failed: %d", err);
299 descriptor->gatts_event_handler(event, gatts_if, param);