1 /*
2  * Copyright 2020-2023 NXP
3  * All rights reserved.
4  *
5  * SPDX-License-Identifier: BSD-3-Clause
6  */
7 
8 #ifndef _WPL_H_
9 #define _WPL_H_
10 
11 #include "stdbool.h"
12 
13 #define WPL_WIFI_SSID_LENGTH      32U
14 #define WPL_WIFI_PASSWORD_MIN_LEN 8U
15 #define WPL_WIFI_PASSWORD_LENGTH  63U
16 
17 /* IP Address of Wi-Fi interface in AP (Access Point) mode */
18 #ifndef WPL_WIFI_AP_IP_ADDR
19 #define WPL_WIFI_AP_IP_ADDR "192.168.1.1"
20 #endif /* WPL_WIFI_AP_IP_ADDR */
21 
22 typedef void (*linkLostCb_t)(bool linkState);
23 
24 typedef enum _wpl_ret
25 {
26     WPLRET_SUCCESS,
27     WPLRET_FAIL,
28     WPLRET_NOT_FOUND,
29     WPLRET_AUTH_FAILED,
30     WPLRET_ADDR_FAILED,
31     WPLRET_NOT_CONNECTED,
32     WPLRET_NOT_READY,
33     WPLRET_TIMEOUT,
34     WPLRET_BAD_PARAM,
35 } wpl_ret_t;
36 
37 typedef enum _wpl_security
38 {
39     /* Used when the user only knows SSID and password. This option should be used
40      * for WPA2 security and lower. */
41     WPL_SECURITY_WILDCARD,
42     /* Use WPA3 SAE security */
43     WPL_SECURITY_WPA3_SAE,
44 } wpl_security_t;
45 
46 /**
47  * @brief  Initialize Wi-Fi driver and WPL layer.
48  *         Create an internal Event structure used for WPL layer (blocking API).
49  *         Set WPL layer state to WPL_INITIALIZED.
50  *         Should be the first function called from the WPL layer API.
51  *
52  * @return WPLRET_SUCCESS Wi-Fi driver and WPL layer initialized successfully.
53  */
54 wpl_ret_t WPL_Init(void);
55 
56 /**
57  * @brief  Start Wi-Fi driver and register an application link state callback.
58  *         Set WPL layer state to WPL_STARTED.
59  *         WPL_Start should be called only after WPL_Init was successfully performed.
60  *
61  * @param  callbackFunction Function which will be called from WPL layer in order to
62  *                          notify upper application that Wi-Fi link is lost or re/established.
63  *
64  * @return WPLRET_SUCCESS Wi-Fi driver started successfully.
65  */
66 wpl_ret_t WPL_Start(linkLostCb_t callbackFunction);
67 
68 /**
69  * @brief  Stop Wi-Fi driver.
70  *         Set WPL layer state to WPL_NOT_INITIALIZED.
71  *         WPL_Stop should be called only after WPL_Start was successfully performed.
72  *
73  * @return WPLRET_SUCCESS Wi-Fi driver is stopped.
74  */
75 wpl_ret_t WPL_Stop(void);
76 
77 /**
78  * @brief  Create an AP (Access Point) network profile and start Wi-Fi AP interface based on this profile.
79  *         If AP mode is started successfully, start a DHCP server.
80  *         If everything goes well, other devices can connect to this network.
81  *         If anything goes wrong, provided network profile is deleted, AP and DHCP are stopped.
82  *         WPL_Start_AP fails if AP interface is already up.
83  *         WPL_Start_AP should be called only after WPL_Start was successfully performed.
84  *
85  * @param  ssid Name of the AP network to be created.
86  * @param  password Password of the AP network to be created.
87  * @param  chan Channel of the AP network to be created.
88  *
89  * @return WPLRET_SUCCESS Network profile created, Wi-Fi AP interface up, DHCP server running.
90  */
91 wpl_ret_t WPL_Start_AP(const char *ssid, const char *password, int chan);
92 
93 /**
94  * @brief  Stop DHCP server, stop Wi-Fi AP (Access Point) interface and delete AP network profile.
95  *         WPL_Stop_AP should be called only after WPL_Start_AP was successfully performed.
96  *
97  * @return WPLRET_SUCCESS DHCP server stopped, AP interface down, AP network profile deleted.
98  */
99 wpl_ret_t WPL_Stop_AP(void);
100 
101 /**
102  * @brief  Scan for nearby Wi-Fi networks.
103            Print available networks information and store them in an internal buffer in JSON fomrat.
104            The returned buffer is dynamically allocated, caller is responsible for deallocation.
105  *         WPL_Scan should be called only after WPL_Start was successfully performed.
106  *
107  * @return Pointer to buffer with scan results.
108  */
109 char *WPL_Scan(void);
110 
111 /**
112  * @brief  Create and save a new STA (Station) network profile.
113  *         This STA network profile can be used in future (WPL_RemoveNetwork / WPL_Join) calls based on its label.
114  *         WPL_AddNetwork should be called only after WPL_Start was successfully performed.
115  *
116  * @param  ssid Name of the STA network to be created.
117  * @param  password Password of the STA network to be created.
118  * @param  label Alias for the network to be added. A network may be referred by its label.
119  * @param  security Prefered security type. Refer to wpl_security_t for list of options.
120  *
121  * @return WPLRET_SUCCESS New STA network profile was successfully saved.
122  */
123 wpl_ret_t WPL_AddNetworkWithSecurity(const char *ssid, const char *password, const char *label, wpl_security_t security);
124 
125 /**
126  * @brief  Create and save a new STA (Station) network profile.
127  *         This STA network profile can be used in future (WPL_RemoveNetwork / WPL_Join) calls based on its label.
128  *         WPL_AddNetwork should be called only after WPL_Start was successfully performed.
129  *
130  * @param  ssid Name of the STA network to be created.
131  * @param  password Password of the STA network to be created.
132  * @param  label Alias for the network to be added. A network may be referred by its label.
133  *
134  * @return WPLRET_SUCCESS New STA network profile was successfully saved.
135  */
136 wpl_ret_t WPL_AddNetwork(const char *ssid, const char *password, const char *label);
137 
138 /**
139  * @brief  Delete a previously added STA (Station) network profile.
140  *         The profile to be deleted is referred by its label and should have been previously added using
141  * WPL_AddNetwork. WPL_RemoveNetwork should be called only after WPL_AddNetwork was successfully performed (for this
142  * network).
143  *
144  * @param  label Alias for the network to be deleted. Label was set by WPL_AddNetwork.
145  *
146  * @return WPLRET_SUCCESS The profile network is deleted.
147  */
148 wpl_ret_t WPL_RemoveNetwork(const char *label);
149 
150 /**
151  * @brief  Connect to a Wi-Fi network.
152  *         Wi-Fi network is chosen by a STA network label.
153  *         The Wi-Fi network to connect to is referred by its label and should have been previously added using
154  * WPL_AddNetwork. WPL_Join should be called only after WPL_AddNetwork was successfully performed (for this network).
155  *
156  * @param  label Alias for the network to connect to. Label was set by WPL_AddNetwork.
157  *
158  * @return WPLRET_SUCCESS Device joined the Wi-Fi network using its STA interface.
159  */
160 wpl_ret_t WPL_Join(char *label);
161 
162 /**
163  * @brief  Disconnect from currently connected Wi-Fi network.
164  *         WPL_Leave should be called only after WPL_Join was successfully performed.
165  *
166  * @return WPLRET_SUCCESS Device left the Wi-Fi network it was connected to.
167  */
168 wpl_ret_t WPL_Leave(void);
169 
170 /**
171  * @brief  Get IP for AP interface or STA interface.
172  *
173  * @param  ip Pointer where IP should be stored.
174  * @param  client 0 for AP, 1 for STA.
175  *
176  * @return WPLRET_SUCCESS if the IP was successfully retrieved.
177  */
178 wpl_ret_t WPL_GetIP(char *ip, int client);
179 
180 #endif /* _WPL_H_ */
181