C/C++ API Reference
Loading...
Searching...
No Matches
connection2.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/value_future.h"
18#include "pw_bluetooth/gatt/client2.h"
19#include "pw_bluetooth/internal/raii_ptr.h"
20#include "pw_bluetooth/low_energy/channel.h"
21#include "pw_bluetooth/types.h"
22
23namespace pw::bluetooth::low_energy {
24
26
33 public:
35 enum class ConnectionParameterUpdateError : uint8_t {
36 kFailure,
37 kInvalidParameters,
38 kRejected,
39 };
40
42 enum class DisconnectReason : uint8_t {
43 kFailure,
44 kRemoteUserTerminatedConnection,
47 };
48
58 uint16_t interval;
59
63 uint16_t latency;
64
72 };
73
85 uint16_t min_interval;
86
95 uint16_t max_interval;
96
100 uint16_t max_latency;
101
109 };
110
118 bool bondable_mode = true;
119
123 std::optional<Uuid> service_filter;
124
127 std::optional<RequestedConnectionParameters> parameters;
128
136 std::optional<uint16_t> att_mtu;
137 };
138
148 };
149
152 virtual ~Connection2() = default;
153
157 async2::Context& cx) = 0;
158
162 virtual gatt::Client2* GattClient() = 0;
163
167 virtual uint16_t AttMtu() = 0;
168
173
176
179 virtual async2::ValueFuture<
180 std::optional<pw::expected<void, ConnectionParameterUpdateError>>>
182
188 ConnectL2capParameters parameters) = 0;
189
190 private:
194 virtual void Release() = 0;
195
196 public:
199 using Ptr = internal::RaiiPtr<Connection2, &Connection2::Release>;
200};
201
202} // namespace pw::bluetooth::low_energy
Definition: context.h:46
Definition: poll.h:138
Definition: value_future.h:47
Represents a GATT client that interacts with services on a GATT server.
Definition: client2.h:288
Definition: connection2.h:32
virtual gatt::Client2 * GattClient()=0
std::optional< Uuid > service_filter
Definition: connection2.h:123
virtual ConnectionParameters Parameters()=0
Returns the current connection parameters.
uint16_t supervision_timeout
Definition: connection2.h:71
SecurityRequirements security_requirements
Definition: connection2.h:147
uint16_t max_receive_packet_size
Maximum supported packet size for receiving.
Definition: connection2.h:143
virtual async2::Poll< DisconnectReason > PendDisconnect(async2::Context &cx)=0
Psm psm
The identifier of the service to connect to.
Definition: connection2.h:141
internal::RaiiPtr< Connection2, &Connection2::Release > Ptr
Definition: connection2.h:199
virtual async2::Poll< uint16_t > PendAttMtuChange(async2::Context &cx)=0
virtual async2::ValueFuture< std::optional< pw::expected< void, ConnectionParameterUpdateError > > > RequestParameterUpdate(RequestedConnectionParameters parameters)=0
std::optional< RequestedConnectionParameters > parameters
Definition: connection2.h:127
Psm
Definition: channel.h:29
virtual async2::OptionalValueFuture< pw::Result< Channel::Ptr > > ConnectL2cap(ConnectL2capParameters parameters)=0
DisconnectReason
Possible reasons a connection was disconnected.
Definition: connection2.h:42
ConnectionParameterUpdateError
Possible errors when updating the connection parameters.
Definition: connection2.h:35
std::optional< uint16_t > att_mtu
Definition: connection2.h:136
@ kConnectionTimeout
This usually indicates that the link supervision timeout expired.
Represents parameters that are set on a per-connection basis.
Definition: connection2.h:112
Actual connection parameters returned by the controller.
Definition: connection2.h:50
The authentication an encryption requirements for a channel.
Definition: channel.h:32