2020-08-16 16:40:05 +02:00
|
|
|
// Copyright 2020 Lukas Haubaum
|
|
|
|
//
|
|
|
|
// Licensed under the GNU Affero General Public License, Version 3;
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
|
|
|
|
// https://www.gnu.org/licenses/agpl-3.0.html
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
#ifndef _wifi_CONTROLLER_H_
|
|
|
|
#define _wifi_CONTROLLER_H_
|
|
|
|
|
|
|
|
#include "esp_err.h"
|
|
|
|
#include "esp_wifi_types.h"
|
|
|
|
|
|
|
|
#define WIFI_LOG "wifi-controller" // TAG for Logging
|
|
|
|
|
2020-12-06 12:48:12 +01:00
|
|
|
/**
|
|
|
|
* @brief callback function after successfull wifi connect
|
|
|
|
*/
|
2020-12-12 22:26:37 +01:00
|
|
|
typedef void (*wifi_callback)(void);
|
2020-12-06 12:48:12 +01:00
|
|
|
|
2020-08-16 16:40:05 +02:00
|
|
|
/**
|
|
|
|
* @brief scan for WiFis
|
|
|
|
*
|
|
|
|
* @param[out] ap_info scanned APs
|
|
|
|
* @param[out] ap_count number of scanned APs
|
|
|
|
*/
|
2020-12-12 22:26:37 +01:00
|
|
|
void wifi_controller_scan(wifi_ap_record_t ap_info[], uint16_t *ap_count, wifi_callback callback);
|
2020-08-16 16:40:05 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief connect to wifi ap
|
|
|
|
*
|
|
|
|
* @param[in] wifi_config config of wifi to connect
|
2020-12-06 12:48:12 +01:00
|
|
|
* @param[in] callback callback function after connection
|
2020-08-16 16:40:05 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* esp_err_t connection status
|
|
|
|
*/
|
2020-12-12 22:26:37 +01:00
|
|
|
esp_err_t wifi_controller_connect(wifi_config_t wifi_config, wifi_callback callback);
|
2020-08-16 16:40:05 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief reconnect to previous wifi
|
2020-12-06 12:48:12 +01:00
|
|
|
*
|
|
|
|
* @param[in] callback callback function after connection
|
2020-08-16 16:40:05 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* esp_err_t connection status
|
|
|
|
*/
|
2020-12-12 22:26:37 +01:00
|
|
|
esp_err_t wifi_controller_reconnect(wifi_callback callback);
|
2020-08-16 16:40:05 +02:00
|
|
|
|
|
|
|
/**
|
2020-12-06 12:48:12 +01:00
|
|
|
* @brief disconnect wifi
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
esp_err_t wifi_controller_disconnect(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief get current wifi connection
|
2020-08-16 16:40:05 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* wifi_ap_record_t pointer to current wifi connection, NULL if not connected
|
|
|
|
*/
|
|
|
|
wifi_ap_record_t *wifi_controller_connection(void);
|
|
|
|
|
|
|
|
#endif
|