forked from project-chip/connectedhomeip
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathConnectivityManagerImpl.h
361 lines (314 loc) · 13.1 KB
/
ConnectivityManagerImpl.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
/*
*
* Copyright (c) 2020-2021 Project CHIP Authors
* Copyright (c) 2018 Nest Labs, Inc.
*
* 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 <platform/ConnectivityManager.h>
#include <platform/internal/GenericConnectivityManagerImpl.h>
#include <platform/internal/GenericConnectivityManagerImpl_UDP.h>
#if INET_CONFIG_ENABLE_TCP_ENDPOINT
#include <platform/internal/GenericConnectivityManagerImpl_TCP.h>
#endif
#if CHIP_DEVICE_CONFIG_ENABLE_CHIPOBLE
#include <platform/internal/GenericConnectivityManagerImpl_BLE.h>
#else
#include <platform/internal/GenericConnectivityManagerImpl_NoBLE.h>
#endif
#if CHIP_DEVICE_CONFIG_ENABLE_THREAD
#include <platform/internal/GenericConnectivityManagerImpl_Thread.h>
#else
#include <platform/internal/GenericConnectivityManagerImpl_NoThread.h>
#endif
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
#include <platform/internal/GenericConnectivityManagerImpl_WiFi.h>
#else
#include <platform/internal/GenericConnectivityManagerImpl_NoWiFi.h>
#endif
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
#include <platform/Linux/dbus/wpa/DBusWpa.h>
#include <platform/Linux/dbus/wpa/DBusWpaBss.h>
#include <platform/Linux/dbus/wpa/DBusWpaInterface.h>
#include <platform/Linux/dbus/wpa/DBusWpaNetwork.h>
#include <system/SystemMutex.h>
#include <mutex>
#if CHIP_DEVICE_CONFIG_ENABLE_WIFIPAF
#include <transport/raw/WiFiPAF.h>
#endif
#endif
#include <platform/Linux/NetworkCommissioningDriver.h>
#include <platform/NetworkCommissioning.h>
#include <vector>
namespace chip {
namespace Inet {
class IPAddress;
} // namespace Inet
} // namespace chip
namespace chip {
namespace DeviceLayer {
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
struct GDBusWpaSupplicant
{
enum class WpaState
{
INIT,
CONNECTING,
CONNECTED,
NOT_CONNECTED,
NO_INTERFACE_PATH,
GOT_INTERFACE_PATH,
INTERFACE_CONNECTED,
};
enum class WpaScanningState
{
IDLE,
SCANNING,
};
WpaState state = WpaState::INIT;
WpaScanningState scanState = WpaScanningState::IDLE;
WpaSupplicant1 * proxy = nullptr;
WpaSupplicant1Interface * iface = nullptr;
WpaSupplicant1BSS * bss = nullptr;
gchar * interfacePath = nullptr;
gchar * networkPath = nullptr;
};
#endif
/**
* Concrete implementation of the ConnectivityManager singleton object for Linux platforms.
*/
class ConnectivityManagerImpl final : public ConnectivityManager,
#if CHIP_DEVICE_CONFIG_ENABLE_CHIPOBLE
public Internal::GenericConnectivityManagerImpl_BLE<ConnectivityManagerImpl>,
#else
public Internal::GenericConnectivityManagerImpl_NoBLE<ConnectivityManagerImpl>,
#endif
#if CHIP_DEVICE_CONFIG_ENABLE_THREAD
public Internal::GenericConnectivityManagerImpl_Thread<ConnectivityManagerImpl>,
#else
public Internal::GenericConnectivityManagerImpl_NoThread<ConnectivityManagerImpl>,
#endif
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
public Internal::GenericConnectivityManagerImpl_WiFi<ConnectivityManagerImpl>,
#else
public Internal::GenericConnectivityManagerImpl_NoWiFi<ConnectivityManagerImpl>,
#endif
public Internal::GenericConnectivityManagerImpl_UDP<ConnectivityManagerImpl>,
#if INET_CONFIG_ENABLE_TCP_ENDPOINT
public Internal::GenericConnectivityManagerImpl_TCP<ConnectivityManagerImpl>,
#endif
public Internal::GenericConnectivityManagerImpl<ConnectivityManagerImpl>
{
// Allow the ConnectivityManager interface class to delegate method calls to
// the implementation methods provided by this class.
friend class ConnectivityManager;
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
public:
void
SetNetworkStatusChangeCallback(NetworkCommissioning::Internal::BaseDriver::NetworkStatusChangeCallback * statusChangeCallback)
{
mpStatusChangeCallback = statusChangeCallback;
}
CHIP_ERROR ConnectWiFiNetworkAsync(ByteSpan ssid, ByteSpan credentials,
NetworkCommissioning::Internal::WirelessDriver::ConnectCallback * connectCallback);
#if CHIP_DEVICE_CONFIG_ENABLE_WIFI_PDC
CHIP_ERROR ConnectWiFiNetworkWithPDCAsync(ByteSpan ssid, ByteSpan networkIdentity, ByteSpan clientIdentity,
const Crypto::P256Keypair & clientIdentityKeypair,
NetworkCommissioning::Internal::WirelessDriver::ConnectCallback * connectCallback);
#endif // CHIP_DEVICE_CONFIG_ENABLE_WIFI_PDC
#if CHIP_DEVICE_CONFIG_ENABLE_WIFIPAF
CHIP_ERROR _WiFiPAFConnect(const SetupDiscriminator & connDiscriminator, void * appState, OnConnectionCompleteFunct onSuccess,
OnConnectionErrorFunct onError);
CHIP_ERROR _WiFiPAFCancelConnect();
void OnDiscoveryResult(gboolean success, GVariant * obj);
void OnNanReceive(GVariant * obj);
void OnNanSubscribeTerminated(gint term_subscribe_id, gint reason);
CHIP_ERROR _WiFiPAFSend(chip::System::PacketBufferHandle && msgBuf);
Transport::WiFiPAFBase * _GetWiFiPAF();
void _SetWiFiPAF(Transport::WiFiPAFBase * pWiFiPAF);
#endif
void PostNetworkConnect();
CHIP_ERROR CommitConfig();
void StartWiFiManagement();
bool IsWiFiManagementStarted();
void StartNonConcurrentWiFiManagement();
int32_t GetDisconnectReason();
CHIP_ERROR GetWiFiBssId(MutableByteSpan & value);
CHIP_ERROR GetWiFiSecurityType(app::Clusters::WiFiNetworkDiagnostics::SecurityTypeEnum & securityType);
CHIP_ERROR GetWiFiVersion(app::Clusters::WiFiNetworkDiagnostics::WiFiVersionEnum & wiFiVersion);
CHIP_ERROR GetConfiguredNetwork(NetworkCommissioning::Network & network);
CHIP_ERROR StartWiFiScan(ByteSpan ssid, NetworkCommissioning::WiFiDriver::ScanCallback * callback);
private:
CHIP_ERROR _ConnectWiFiNetworkAsync(GVariant * networkArgs,
NetworkCommissioning::Internal::WirelessDriver::ConnectCallback * connectCallback)
CHIP_REQUIRES(mWpaSupplicantMutex);
void _ConnectWiFiNetworkAsyncCallback(GObject * sourceObject, GAsyncResult * res);
#endif
public:
const char * GetEthernetIfName() { return (mEthIfName[0] == '\0') ? nullptr : mEthIfName; }
#if CHIP_DEVICE_CONFIG_ENABLE_WIFI
const char * GetWiFiIfName() { return (sWiFiIfName[0] == '\0') ? nullptr : sWiFiIfName; }
#endif
private:
// ===== Members that implement the ConnectivityManager abstract interface.
struct WiFiNetworkScanned
{
// The fields matches WiFiInterfaceScanResult::Type.
uint8_t ssid[Internal::kMaxWiFiSSIDLength];
uint8_t ssidLen;
uint8_t bssid[6];
int8_t rssi;
uint16_t frequencyBand;
uint8_t channel;
uint8_t security;
};
CHIP_ERROR _Init();
void _OnPlatformEvent(const ChipDeviceEvent * event);
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
WiFiStationMode _GetWiFiStationMode();
CHIP_ERROR _SetWiFiStationMode(ConnectivityManager::WiFiStationMode val);
System::Clock::Timeout _GetWiFiStationReconnectInterval();
CHIP_ERROR _SetWiFiStationReconnectInterval(System::Clock::Timeout val);
bool _IsWiFiStationEnabled();
bool _IsWiFiStationConnected();
bool _IsWiFiStationApplicationControlled();
bool _IsWiFiStationProvisioned();
void _ClearWiFiStationProvision();
bool _CanStartWiFiScan();
WiFiAPMode _GetWiFiAPMode();
CHIP_ERROR _SetWiFiAPMode(WiFiAPMode val);
bool _IsWiFiAPActive();
bool _IsWiFiAPApplicationControlled();
void _DemandStartWiFiAP();
void _StopOnDemandWiFiAP();
void _MaintainOnDemandWiFiAP();
System::Clock::Timeout _GetWiFiAPIdleTimeout();
void _SetWiFiAPIdleTimeout(System::Clock::Timeout val);
void UpdateNetworkStatus();
CHIP_ERROR StopAutoScan();
void _OnWpaProxyReady(GObject * sourceObject, GAsyncResult * res);
void _OnWpaInterfaceRemoved(WpaSupplicant1 * proxy, const char * path, GVariant * properties);
void _OnWpaInterfaceAdded(WpaSupplicant1 * proxy, const char * path, GVariant * properties);
void _OnWpaPropertiesChanged(WpaSupplicant1Interface * proxy, GVariant * properties);
void _OnWpaInterfaceScanDone(WpaSupplicant1Interface * proxy, gboolean success);
void _OnWpaInterfaceReady(GObject * sourceObject, GAsyncResult * res);
void _OnWpaInterfaceProxyReady(GObject * sourceObject, GAsyncResult * res);
void _OnWpaBssProxyReady(GObject * sourceObject, GAsyncResult * res);
#if CHIP_DEVICE_CONFIG_ENABLE_WIFIPAF
struct wpa_dbus_discov_info
{
uint32_t subscribe_id;
uint32_t peer_publish_id;
uint8_t peer_addr[6];
uint32_t ssi_len;
};
uint32_t mpresubscribe_id;
struct wpa_dbus_discov_info mpaf_info;
struct wpa_dbus_nanrx_info
{
uint32_t id;
uint32_t peer_id;
uint8_t peer_addr[6];
uint32_t ssi_len;
};
struct wpa_dbus_nanrx_info mpaf_nanrx_info;
OnConnectionCompleteFunct mOnPafSubscribeComplete;
OnConnectionErrorFunct mOnPafSubscribeError;
Transport::WiFiPAFBase * pmWiFiPAF;
void * mAppState;
CHIP_ERROR _SetWiFiPAFAdvertisingEnabled(WiFiPAFAdvertiseParam & args);
CHIP_ERROR _WiFiPAFPublish(WiFiPAFAdvertiseParam & args);
CHIP_ERROR _WiFiPAFCancelPublish();
#endif
bool _GetBssInfo(const gchar * bssPath, NetworkCommissioning::WiFiScanResponse & result);
CHIP_ERROR _StartWiFiManagement();
bool mAssociationStarted = false;
BitFlags<ConnectivityFlags> mConnectivityFlag;
GDBusWpaSupplicant mWpaSupplicant CHIP_GUARDED_BY(mWpaSupplicantMutex);
// Access to mWpaSupplicant has to be protected by a mutex because it is accessed from
// the CHIP event loop thread and dedicated D-Bus thread started by platform manager.
std::mutex mWpaSupplicantMutex;
NetworkCommissioning::Internal::BaseDriver::NetworkStatusChangeCallback * mpStatusChangeCallback = nullptr;
#endif
// ==================== ConnectivityManager Private Methods ====================
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
void DriveAPState();
CHIP_ERROR ConfigureWiFiAP();
void ChangeWiFiAPState(WiFiAPState newState);
static void DriveAPState(::chip::System::Layer * aLayer, void * aAppState);
#endif
// ===== Members for internal use by the following friends.
friend ConnectivityManager & ConnectivityMgr();
friend ConnectivityManagerImpl & ConnectivityMgrImpl();
static ConnectivityManagerImpl sInstance;
// ===== Private members reserved for use by this class only.
char mEthIfName[Inet::InterfaceId::kMaxIfNameLength];
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
ConnectivityManager::WiFiStationMode mWiFiStationMode;
ConnectivityManager::WiFiAPMode mWiFiAPMode;
WiFiAPState mWiFiAPState;
System::Clock::Timestamp mLastAPDemandTime;
System::Clock::Timeout mWiFiStationReconnectInterval;
System::Clock::Timeout mWiFiAPIdleTimeout;
#endif
#if CHIP_DEVICE_CONFIG_ENABLE_WIFI
char sWiFiIfName[Inet::InterfaceId::kMaxIfNameLength];
#endif
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
uint8_t sInterestedSSID[Internal::kMaxWiFiSSIDLength];
uint8_t sInterestedSSIDLen;
#endif
NetworkCommissioning::WiFiDriver::ScanCallback * mpScanCallback;
NetworkCommissioning::Internal::WirelessDriver::ConnectCallback * mpConnectCallback;
};
#if CHIP_DEVICE_CONFIG_ENABLE_WPA
inline ConnectivityManager::WiFiAPMode ConnectivityManagerImpl::_GetWiFiAPMode()
{
return mWiFiAPMode;
}
inline bool ConnectivityManagerImpl::_IsWiFiAPActive()
{
return mWiFiAPState == kWiFiAPState_Active;
}
inline bool ConnectivityManagerImpl::_IsWiFiAPApplicationControlled()
{
return mWiFiAPMode == kWiFiAPMode_ApplicationControlled;
}
inline System::Clock::Timeout ConnectivityManagerImpl::_GetWiFiAPIdleTimeout()
{
return mWiFiAPIdleTimeout;
}
#endif
/**
* Returns the public interface of the ConnectivityManager singleton object.
*
* chip applications should use this to access features of the ConnectivityManager object
* that are common to all platforms.
*/
inline ConnectivityManager & ConnectivityMgr()
{
return ConnectivityManagerImpl::sInstance;
}
/**
* Returns the platform-specific implementation of the ConnectivityManager singleton object.
*
* chip applications can use this to gain access to features of the ConnectivityManager
* that are specific to the ESP32 platform.
*/
inline ConnectivityManagerImpl & ConnectivityMgrImpl()
{
return ConnectivityManagerImpl::sInstance;
}
} // namespace DeviceLayer
} // namespace chip