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);
183 esp_ble_gatts_cb_param_t *param) {
185 case ESP_GATTS_ADD_CHAR_EVT: {
187 this->
handle_ = param->add_char.attr_handle;
190 descriptor->do_create(
this);
197 case ESP_GATTS_READ_EVT: {
198 if (param->read.handle != this->handle_)
201 if (!param->read.need_rsp)
208 uint16_t max_offset = 22;
210 esp_gatt_rsp_t response;
211 if (param->read.is_long) {
212 if (this->
value_.size() - this->value_read_offset_ < max_offset) {
216 memcpy(response.attr_value.value, this->value_.data() + response.attr_value.offset, response.attr_value.len);
219 response.attr_value.len = max_offset;
221 memcpy(response.attr_value.value, this->value_.data() + response.attr_value.offset, response.attr_value.len);
225 response.attr_value.offset = 0;
226 if (this->
value_.size() + 1 > max_offset) {
227 response.attr_value.len = max_offset;
230 response.attr_value.len = this->
value_.size();
232 memcpy(response.attr_value.value, this->value_.data(), response.attr_value.len);
235 response.attr_value.handle = this->
handle_;
236 response.attr_value.auth_req = ESP_GATT_AUTH_REQ_NONE;
239 esp_ble_gatts_send_response(gatts_if, param->read.conn_id, param->read.trans_id, ESP_GATT_OK, &response);
241 ESP_LOGE(TAG,
"esp_ble_gatts_send_response failed: %d", err);
245 case ESP_GATTS_WRITE_EVT: {
246 if (this->
handle_ != param->write.handle)
249 esp_gatt_status_t
status = ESP_GATT_OK;
251 if (param->write.is_prep) {
252 const size_t offset = param->write.offset;
253 const size_t write_len = param->write.len;
254 const size_t new_size = offset + write_len;
260 if (offset != this->
value_.size()) {
261 status = ESP_GATT_INVALID_OFFSET;
262 }
else if (new_size > ESP_GATT_MAX_ATTR_LEN) {
263 status = ESP_GATT_INVALID_ATTR_LEN;
265 if (this->
value_.size() < new_size) {
266 this->
value_.resize(new_size);
268 memcpy(this->
value_.data() + offset, param->write.value, write_len);
274 if (param->write.need_rsp) {
275 esp_gatt_rsp_t response;
277 response.attr_value.len = param->write.len;
278 response.attr_value.handle = this->
handle_;
279 response.attr_value.offset = param->write.offset;
280 response.attr_value.auth_req = ESP_GATT_AUTH_REQ_NONE;
281 memcpy(response.attr_value.value, param->write.value, param->write.len);
284 esp_ble_gatts_send_response(gatts_if, param->write.conn_id, param->write.trans_id,
status, &response);
287 ESP_LOGE(TAG,
"esp_ble_gatts_send_response failed: %d", err);
291 if (!param->write.is_prep) {
300 case ESP_GATTS_EXEC_WRITE_EVT: {
304 if (param->exec_write.exec_write_flag == ESP_GATT_PREP_WRITE_EXEC) {
310 esp_ble_gatts_send_response(gatts_if, param->write.conn_id, param->write.trans_id, ESP_GATT_OK,
nullptr);
312 ESP_LOGE(TAG,
"esp_ble_gatts_send_response failed: %d", err);
321 descriptor->gatts_event_handler(event, gatts_if, param);