Pigweed
 
Loading...
Searching...
No Matches
client2.h
1// Copyright 2024 The Pigweed Authors
2//
3// Licensed under the Apache License, Version 2.0 (the "License"); you may not
4// use this file except in compliance with the License. You may obtain a copy of
5// the License at
6//
7// https://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12// License for the specific language governing permissions and limitations under
13// the License.
14#pragma once
15
16#include "pw_async2/dispatcher.h"
17#include "pw_async2/once_sender.h"
18#include "pw_bluetooth/gatt/constants.h"
19#include "pw_bluetooth/gatt/error.h"
20#include "pw_bluetooth/gatt/types.h"
21#include "pw_bluetooth/internal/raii_ptr.h"
22#include "pw_containers/vector.h"
23#include "pw_function/function.h"
24#include "pw_multibuf/multibuf.h"
25#include "pw_result/expected.h"
26
27namespace pw::bluetooth::gatt {
28
31 public:
32 enum class RemoteServiceError {
35
38 };
39
41 struct ReadValue {
43 Handle handle;
44
47
52 };
53
57 Handle handle;
58
61 pw::expected<ReadValue, Error> result;
62 };
63
70 uint16_t offset = 0;
71
73 uint16_t max_bytes = kMaxValueLength;
74 };
75
78 enum class WriteMode : uint8_t {
82
87
96 };
97
104
107 uint16_t offset = 0;
108 };
109
110 virtual ~RemoteService2() = default;
111
119
125 characteristics_sender) = 0;
126
144 ReadByType(Uuid uuid) = 0;
145
162 ReadCharacteristic(Handle handle, std::optional<LongReadOptions> options) = 0;
163
183 Handle handle, pw::multibuf::MultiBuf&& value, WriteOptions options) = 0;
184
200 Handle handle, std::optional<LongReadOptions> options) = 0;
201
219 Handle handle, pw::multibuf::MultiBuf&& value) = 0;
220
248 Handle handle) = 0;
249
258 async2::Context& cx) = 0;
259
269 Handle handle) = 0;
270
271 private:
275 virtual void Disconnect() = 0;
276
277 public:
280 using Ptr = internal::RaiiPtr<RemoteService2, &RemoteService2::Disconnect>;
281};
282
284class Client2 {
285 public:
289 ServiceHandle handle;
290
293
296 Uuid type;
297 };
298
299 virtual ~Client2() = default;
300
310 async2::Context& cx);
311
319
326 virtual pw::expected<RemoteService2::Ptr, Error> ConnectToService(
327 ServiceHandle handle) = 0;
328};
329
330} // namespace pw::bluetooth::gatt
Definition: vector.h:65
Definition: dispatcher_base.h:52
Definition: once_sender.h:41
Definition: once_sender.h:268
Definition: poll.h:54
Represents a GATT client that interacts with services on a GATT server.
Definition: client2.h:284
virtual async2::Poll< ServiceHandle > PendServiceRemoved(async2::Context &cx)
virtual async2::Poll< RemoteServiceInfo > PendServiceUpdate(async2::Context &cx)
virtual pw::expected< RemoteService2::Ptr, Error > ConnectToService(ServiceHandle handle)=0
An interface for interacting with a GATT service on a peer device.
Definition: client2.h:30
RemoteServiceError
Definition: client2.h:32
@ kPeerDisconnected
The peer serving this service has disconnected.
@ kServiceRemoved
The service has been modified or removed.
virtual async2::OnceReceiver< pw::expected< ReadValue, Error > > ReadCharacteristic(Handle handle, std::optional< LongReadOptions > options)=0
virtual void DiscoverCharacteristics(async2::OnceRefSender< Vector< Characteristic2 > > characteristics_sender)=0
virtual async2::OnceReceiver< pw::expected< void, Error > > WriteDescriptor(Handle handle, pw::multibuf::MultiBuf &&value)=0
WriteMode
Definition: client2.h:78
internal::RaiiPtr< RemoteService2, &RemoteService2::Disconnect > Ptr
Definition: client2.h:280
virtual async2::OnceReceiver< pw::expected< Vector< ReadByTypeResult, 5 >, Error > > ReadByType(Uuid uuid)=0
virtual async2::OnceReceiver< pw::expected< ReadValue, Error > > ReadDescriptor(Handle handle, std::optional< LongReadOptions > options)=0
virtual async2::Poll< RemoteServiceError > PendError(async2::Context &cx)=0
virtual async2::Poll< ReadValue > PendNotification(Handle handle, async2::Context &cx)=0
virtual async2::OnceReceiver< pw::expected< void, Error > > StopNotifications(Handle handle)=0
virtual async2::OnceReceiver< pw::expected< void, Error > > WriteCharacteristic(Handle handle, pw::multibuf::MultiBuf &&value, WriteOptions options)=0
virtual async2::OnceReceiver< pw::expected< void, Error > > EnableNotifications(Handle handle)=0
Definition: multibuf.h:245
Represents a remote GATT service.
Definition: client2.h:287
ServiceHandle handle
Uniquely identifies this GATT service.
Definition: client2.h:289
bool primary
Indicates whether this is a primary or secondary service.
Definition: client2.h:292
uint16_t max_bytes
The maximum number of bytes to read.
Definition: client2.h:73
A result returned by ReadByType.
Definition: client2.h:55
pw::expected< ReadValue, Error > result
Definition: client2.h:61
Handle handle
Characteristic or descriptor handle.
Definition: client2.h:57
Wrapper around a possible truncated value received from the server.
Definition: client2.h:41
multibuf::MultiBuf value
The value of the characteristic or descriptor.
Definition: client2.h:46
bool maybe_truncated
Definition: client2.h:51
Handle handle
Characteristic or descriptor handle.
Definition: client2.h:43
uint16_t offset
Definition: client2.h:107
WriteMode mode
Definition: client2.h:103