/******************************************************************************
*
* Copyright 2018 The Android Open Source Project
*
* 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.
*
******************************************************************************/
#pragma once
#include "gatt/database.h"
#include <utility>
namespace gatt {
class DatabaseBuilder {
public:
constexpr static std::pair<uint16_t, uint16_t> EXPLORE_END =
std::make_pair(0xFFFF, 0xFFFF);
void AddService(uint16_t handle, uint16_t end_handle,
const bluetooth::Uuid& uuid, bool is_primary);
void AddIncludedService(uint16_t handle, const bluetooth::Uuid& uuid,
uint16_t start_handle, uint16_t end_handle);
void AddCharacteristic(uint16_t handle, uint16_t value_handle,
const bluetooth::Uuid& uuid, uint8_t properties);
void AddDescriptor(uint16_t handle, const bluetooth::Uuid& uuid);
/* Returns true if next service exploration started, false if there are no
* more services to explore. */
bool StartNextServiceExploration();
/* Return pair with start and end handle of the currently explored service.
*/
const std::pair<uint16_t, uint16_t>& CurrentlyExploredService();
/* Return pair with start and end handle of the descriptor range to discover,
* or DatabaseBuilder::EXPLORE_END if no more descriptors left.
*/
std::pair<uint16_t, uint16_t> NextDescriptorRangeToExplore();
/* Returns true, if GATT discovery is in progress, false if discovery was not
* started, or is already finished.
*/
// TODO(jpawlowski): in the future, we might create this object only for the
// time of discovery, in such case InProgress won't be needed, because object
// existence will mean discovery is pending
bool InProgress() const;
/* Call this method at end of GATT discovery, to obtain object representing
* the database of remote device */
Database Build();
void Clear();
/* Return text representation of internal state for debugging purposes */
std::string ToString() const;
private:
Database database;
/* Start and end handle of service that is currently being discovered on the
* remote device */
std::pair<uint16_t, uint16_t> pending_service;
/* Characteristic inside pending_service that is currently being explored */
uint16_t pending_characteristic;
/* sorted, unique set of start_handle, end_handle pair of all services that
* have not yet been discovered */
std::set<std::pair<uint16_t, uint16_t>> services_to_discover;
};
} // namespace gatt