Compare commits
No commits in common. "dev" and "main" have entirely different histories.
3 changed files with 12 additions and 202 deletions
|
@ -1,65 +1,7 @@
|
||||||
menu "Project Configuration"
|
menu "Example Configuration"
|
||||||
|
|
||||||
orsource "$IDF_PATH/examples/common_components/env_caps/$IDF_TARGET/Kconfig.env_caps"
|
orsource "$IDF_PATH/examples/common_components/env_caps/$IDF_TARGET/Kconfig.env_caps"
|
||||||
|
|
||||||
config ESP_WIFI_SSID
|
|
||||||
string "WiFi SSID"
|
|
||||||
default "myssid"
|
|
||||||
help
|
|
||||||
SSID (network name) for the example to connect to.
|
|
||||||
|
|
||||||
config ESP_WIFI_PASSWORD
|
|
||||||
string "WiFi Password"
|
|
||||||
default "mypassword"
|
|
||||||
help
|
|
||||||
WiFi password (WPA or WPA2) for the example to use.
|
|
||||||
|
|
||||||
choice ESP_WIFI_SAE_MODE
|
|
||||||
prompt "WPA3 SAE mode selection"
|
|
||||||
default ESP_WPA3_SAE_PWE_BOTH
|
|
||||||
help
|
|
||||||
Select mode for SAE as Hunt and Peck, H2E or both.
|
|
||||||
config ESP_WPA3_SAE_PWE_HUNT_AND_PECK
|
|
||||||
bool "HUNT AND PECK"
|
|
||||||
config ESP_WPA3_SAE_PWE_HASH_TO_ELEMENT
|
|
||||||
bool "H2E"
|
|
||||||
config ESP_WPA3_SAE_PWE_BOTH
|
|
||||||
bool "BOTH"
|
|
||||||
endchoice
|
|
||||||
|
|
||||||
config ESP_WIFI_PW_ID
|
|
||||||
string "PASSWORD IDENTIFIER"
|
|
||||||
depends on ESP_WPA3_SAE_PWE_HASH_TO_ELEMENT|| ESP_WPA3_SAE_PWE_BOTH
|
|
||||||
default ""
|
|
||||||
help
|
|
||||||
password identifier for SAE H2E
|
|
||||||
|
|
||||||
choice ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD
|
|
||||||
prompt "WiFi Scan auth mode threshold"
|
|
||||||
default ESP_WIFI_AUTH_WPA2_PSK
|
|
||||||
help
|
|
||||||
The weakest authmode to accept in the scan mode.
|
|
||||||
This value defaults to ESP_WIFI_AUTH_WPA2_PSK incase password is present and ESP_WIFI_AUTH_OPEN is used.
|
|
||||||
Please select ESP_WIFI_AUTH_WEP/ESP_WIFI_AUTH_WPA_PSK incase AP is operating in WEP/WPA mode.
|
|
||||||
|
|
||||||
config ESP_WIFI_AUTH_OPEN
|
|
||||||
bool "OPEN"
|
|
||||||
config ESP_WIFI_AUTH_WEP
|
|
||||||
bool "WEP"
|
|
||||||
config ESP_WIFI_AUTH_WPA_PSK
|
|
||||||
bool "WPA PSK"
|
|
||||||
config ESP_WIFI_AUTH_WPA2_PSK
|
|
||||||
bool "WPA2 PSK"
|
|
||||||
config ESP_WIFI_AUTH_WPA_WPA2_PSK
|
|
||||||
bool "WPA/WPA2 PSK"
|
|
||||||
config ESP_WIFI_AUTH_WPA3_PSK
|
|
||||||
bool "WPA3 PSK"
|
|
||||||
config ESP_WIFI_AUTH_WPA2_WPA3_PSK
|
|
||||||
bool "WPA2/WPA3 PSK"
|
|
||||||
config ESP_WIFI_AUTH_WAPI_PSK
|
|
||||||
bool "WAPI PSK"
|
|
||||||
endchoice
|
|
||||||
|
|
||||||
config GPIO_OUTPUT_0
|
config GPIO_OUTPUT_0
|
||||||
int "GPIO output pin 0"
|
int "GPIO output pin 0"
|
||||||
range ENV_GPIO_RANGE_MIN ENV_GPIO_OUT_RANGE_MAX
|
range ENV_GPIO_RANGE_MIN ENV_GPIO_OUT_RANGE_MAX
|
||||||
|
|
152
main/main.c
152
main/main.c
|
@ -14,16 +14,6 @@
|
||||||
#include <stdatomic.h>
|
#include <stdatomic.h>
|
||||||
#include <nvs_flash.h>
|
#include <nvs_flash.h>
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#include "freertos/FreeRTOS.h"
|
|
||||||
#include "freertos/task.h"
|
|
||||||
#include "freertos/event_groups.h"
|
|
||||||
#include "esp_system.h"
|
|
||||||
#include "esp_wifi.h"
|
|
||||||
#include "esp_event.h"
|
|
||||||
#include "esp_log.h"
|
|
||||||
|
|
||||||
#include "lwip/err.h"
|
|
||||||
#include "lwip/sys.h"
|
|
||||||
#include "esp_netif.h"
|
#include "esp_netif.h"
|
||||||
#include "protocol_examples_common.h"
|
#include "protocol_examples_common.h"
|
||||||
#include "protocol_examples_utils.h"
|
#include "protocol_examples_utils.h"
|
||||||
|
@ -35,10 +25,12 @@
|
||||||
#include "esp_check.h"
|
#include "esp_check.h"
|
||||||
#include "driver/gpio.h"
|
#include "driver/gpio.h"
|
||||||
|
|
||||||
|
#if !CONFIG_IDF_TARGET_LINUX
|
||||||
#include <esp_wifi.h>
|
#include <esp_wifi.h>
|
||||||
#include <esp_system.h>
|
#include <esp_system.h>
|
||||||
#include "nvs_flash.h"
|
#include "nvs_flash.h"
|
||||||
#include "esp_eth.h"
|
#include "esp_eth.h"
|
||||||
|
#endif // !CONFIG_IDF_TARGET_LINUX
|
||||||
|
|
||||||
#define EXAMPLE_HTTP_QUERY_KEY_MAX_LEN (64)
|
#define EXAMPLE_HTTP_QUERY_KEY_MAX_LEN (64)
|
||||||
|
|
||||||
|
@ -51,129 +43,8 @@
|
||||||
* handlers for the web server.
|
* handlers for the web server.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define EXAMPLE_ESP_WIFI_SSID CONFIG_ESP_WIFI_SSID
|
|
||||||
#define EXAMPLE_ESP_WIFI_PASS CONFIG_ESP_WIFI_PASSWORD
|
|
||||||
|
|
||||||
#if CONFIG_ESP_WPA3_SAE_PWE_HUNT_AND_PECK
|
|
||||||
#define ESP_WIFI_SAE_MODE WPA3_SAE_PWE_HUNT_AND_PECK
|
|
||||||
#define EXAMPLE_H2E_IDENTIFIER ""
|
|
||||||
#elif CONFIG_ESP_WPA3_SAE_PWE_HASH_TO_ELEMENT
|
|
||||||
#define ESP_WIFI_SAE_MODE WPA3_SAE_PWE_HASH_TO_ELEMENT
|
|
||||||
#define EXAMPLE_H2E_IDENTIFIER CONFIG_ESP_WIFI_PW_ID
|
|
||||||
#elif CONFIG_ESP_WPA3_SAE_PWE_BOTH
|
|
||||||
#define ESP_WIFI_SAE_MODE WPA3_SAE_PWE_BOTH
|
|
||||||
#define EXAMPLE_H2E_IDENTIFIER CONFIG_ESP_WIFI_PW_ID
|
|
||||||
#endif
|
|
||||||
#if CONFIG_ESP_WIFI_AUTH_OPEN
|
|
||||||
#define ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD WIFI_AUTH_OPEN
|
|
||||||
#elif CONFIG_ESP_WIFI_AUTH_WEP
|
|
||||||
#define ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD WIFI_AUTH_WEP
|
|
||||||
#elif CONFIG_ESP_WIFI_AUTH_WPA_PSK
|
|
||||||
#define ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD WIFI_AUTH_WPA_PSK
|
|
||||||
#elif CONFIG_ESP_WIFI_AUTH_WPA2_PSK
|
|
||||||
#define ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD WIFI_AUTH_WPA2_PSK
|
|
||||||
#elif CONFIG_ESP_WIFI_AUTH_WPA_WPA2_PSK
|
|
||||||
#define ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD WIFI_AUTH_WPA_WPA2_PSK
|
|
||||||
#elif CONFIG_ESP_WIFI_AUTH_WPA3_PSK
|
|
||||||
#define ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD WIFI_AUTH_WPA3_PSK
|
|
||||||
#elif CONFIG_ESP_WIFI_AUTH_WPA2_WPA3_PSK
|
|
||||||
#define ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD WIFI_AUTH_WPA2_WPA3_PSK
|
|
||||||
#elif CONFIG_ESP_WIFI_AUTH_WAPI_PSK
|
|
||||||
#define ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD WIFI_AUTH_WAPI_PSK
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* FreeRTOS event group to signal when we are connected*/
|
|
||||||
static EventGroupHandle_t s_wifi_event_group;
|
|
||||||
|
|
||||||
/* The event group allows multiple bits for each event, but we only care about two events:
|
|
||||||
* - we are connected to the AP with an IP
|
|
||||||
* - we failed to connect after the maximum amount of retries */
|
|
||||||
#define WIFI_CONNECTED_BIT BIT0
|
|
||||||
#define WIFI_FAIL_BIT BIT1
|
|
||||||
|
|
||||||
static const char *TAG = "devant";
|
static const char *TAG = "devant";
|
||||||
|
|
||||||
static void event_handler(void* arg, esp_event_base_t event_base,
|
|
||||||
int32_t event_id, void* event_data)
|
|
||||||
{
|
|
||||||
if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_START) {
|
|
||||||
esp_wifi_connect();
|
|
||||||
} else if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_DISCONNECTED) {
|
|
||||||
esp_wifi_connect();
|
|
||||||
ESP_LOGI(TAG,"Retry connect to the AP");
|
|
||||||
} else if (event_base == IP_EVENT && event_id == IP_EVENT_STA_GOT_IP) {
|
|
||||||
ip_event_got_ip_t* event = (ip_event_got_ip_t*) event_data;
|
|
||||||
ESP_LOGI(TAG, "got ip:" IPSTR, IP2STR(&event->ip_info.ip));
|
|
||||||
xEventGroupSetBits(s_wifi_event_group, WIFI_CONNECTED_BIT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void wifi_init_sta(void)
|
|
||||||
{
|
|
||||||
s_wifi_event_group = xEventGroupCreate();
|
|
||||||
|
|
||||||
ESP_ERROR_CHECK(esp_netif_init());
|
|
||||||
|
|
||||||
ESP_ERROR_CHECK(esp_event_loop_create_default());
|
|
||||||
esp_netif_create_default_wifi_sta();
|
|
||||||
|
|
||||||
wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT();
|
|
||||||
ESP_ERROR_CHECK(esp_wifi_init(&cfg));
|
|
||||||
|
|
||||||
esp_event_handler_instance_t instance_any_id;
|
|
||||||
esp_event_handler_instance_t instance_got_ip;
|
|
||||||
ESP_ERROR_CHECK(esp_event_handler_instance_register(WIFI_EVENT,
|
|
||||||
ESP_EVENT_ANY_ID,
|
|
||||||
&event_handler,
|
|
||||||
NULL,
|
|
||||||
&instance_any_id));
|
|
||||||
ESP_ERROR_CHECK(esp_event_handler_instance_register(IP_EVENT,
|
|
||||||
IP_EVENT_STA_GOT_IP,
|
|
||||||
&event_handler,
|
|
||||||
NULL,
|
|
||||||
&instance_got_ip));
|
|
||||||
|
|
||||||
wifi_config_t wifi_config = {
|
|
||||||
.sta = {
|
|
||||||
.ssid = EXAMPLE_ESP_WIFI_SSID,
|
|
||||||
.password = EXAMPLE_ESP_WIFI_PASS,
|
|
||||||
/* Authmode threshold resets to WPA2 as default if password matches WPA2 standards (password len => 8).
|
|
||||||
* If you want to connect the device to deprecated WEP/WPA networks, Please set the threshold value
|
|
||||||
* to WIFI_AUTH_WEP/WIFI_AUTH_WPA_PSK and set the password with length and format matching to
|
|
||||||
* WIFI_AUTH_WEP/WIFI_AUTH_WPA_PSK standards.
|
|
||||||
*/
|
|
||||||
.threshold.authmode = ESP_WIFI_SCAN_AUTH_MODE_THRESHOLD,
|
|
||||||
.sae_pwe_h2e = ESP_WIFI_SAE_MODE,
|
|
||||||
.sae_h2e_identifier = EXAMPLE_H2E_IDENTIFIER,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
ESP_ERROR_CHECK(esp_wifi_set_mode(WIFI_MODE_STA) );
|
|
||||||
ESP_ERROR_CHECK(esp_wifi_set_config(WIFI_IF_STA, &wifi_config) );
|
|
||||||
ESP_ERROR_CHECK(esp_wifi_start() );
|
|
||||||
|
|
||||||
ESP_LOGI(TAG, "wifi_init_sta finished.");
|
|
||||||
|
|
||||||
/* Waiting until either the connection is established (WIFI_CONNECTED_BIT) or connection failed for the maximum
|
|
||||||
* number of re-tries (WIFI_FAIL_BIT). The bits are set by event_handler() (see above) */
|
|
||||||
EventBits_t bits = xEventGroupWaitBits(s_wifi_event_group,
|
|
||||||
WIFI_CONNECTED_BIT | WIFI_FAIL_BIT,
|
|
||||||
pdFALSE,
|
|
||||||
pdFALSE,
|
|
||||||
portMAX_DELAY);
|
|
||||||
|
|
||||||
/* xEventGroupWaitBits() returns the bits before the call returned, hence we can test which event actually
|
|
||||||
* happened. */
|
|
||||||
if (bits & WIFI_CONNECTED_BIT) {
|
|
||||||
ESP_LOGI(TAG, "connected to ap SSID:%s password:%s",
|
|
||||||
EXAMPLE_ESP_WIFI_SSID, EXAMPLE_ESP_WIFI_PASS);
|
|
||||||
} else if (bits & WIFI_FAIL_BIT) {
|
|
||||||
ESP_LOGI(TAG, "Failed to connect to SSID:%s, password:%s",
|
|
||||||
EXAMPLE_ESP_WIFI_SSID, EXAMPLE_ESP_WIFI_PASS);
|
|
||||||
} else {
|
|
||||||
ESP_LOGE(TAG, "UNEXPECTED EVENT");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static atomic_bool status_one = false;
|
static atomic_bool status_one = false;
|
||||||
static atomic_bool status_two = false;
|
static atomic_bool status_two = false;
|
||||||
|
|
||||||
|
@ -347,13 +218,7 @@ void app_main(void)
|
||||||
{
|
{
|
||||||
static httpd_handle_t server = NULL;
|
static httpd_handle_t server = NULL;
|
||||||
|
|
||||||
//Initialize NVS
|
ESP_ERROR_CHECK(nvs_flash_init());
|
||||||
esp_err_t ret = nvs_flash_init();
|
|
||||||
if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND) {
|
|
||||||
ESP_ERROR_CHECK(nvs_flash_erase());
|
|
||||||
ret = nvs_flash_init();
|
|
||||||
}
|
|
||||||
ESP_ERROR_CHECK(ret);
|
|
||||||
ESP_ERROR_CHECK(esp_netif_init());
|
ESP_ERROR_CHECK(esp_netif_init());
|
||||||
ESP_ERROR_CHECK(esp_event_loop_create_default());
|
ESP_ERROR_CHECK(esp_event_loop_create_default());
|
||||||
|
|
||||||
|
@ -375,8 +240,13 @@ void app_main(void)
|
||||||
gpio_set_level(GPIO_OUTPUT_IO_0, 0);
|
gpio_set_level(GPIO_OUTPUT_IO_0, 0);
|
||||||
gpio_set_level(GPIO_OUTPUT_IO_1, 0);
|
gpio_set_level(GPIO_OUTPUT_IO_1, 0);
|
||||||
|
|
||||||
ESP_LOGI(TAG, "ESP_WIFI_MODE_STA");
|
printf("Minimum free heap size: %"PRIu32" bytes\n", esp_get_minimum_free_heap_size());
|
||||||
wifi_init_sta();
|
|
||||||
|
/* This helper function configures Wi-Fi or Ethernet, as selected in menuconfig.
|
||||||
|
* Read "Establishing Wi-Fi or Ethernet Connection" section in
|
||||||
|
* examples/protocols/README.md for more information about this function.
|
||||||
|
*/
|
||||||
|
ESP_ERROR_CHECK(example_connect());
|
||||||
|
|
||||||
/* Register event handlers to stop the server when Wi-Fi or Ethernet is disconnected,
|
/* Register event handlers to stop the server when Wi-Fi or Ethernet is disconnected,
|
||||||
* and re-start it upon connection.
|
* and re-start it upon connection.
|
||||||
|
@ -384,8 +254,6 @@ void app_main(void)
|
||||||
ESP_ERROR_CHECK(esp_event_handler_register(IP_EVENT, IP_EVENT_STA_GOT_IP, &connect_handler, &server));
|
ESP_ERROR_CHECK(esp_event_handler_register(IP_EVENT, IP_EVENT_STA_GOT_IP, &connect_handler, &server));
|
||||||
ESP_ERROR_CHECK(esp_event_handler_register(WIFI_EVENT, WIFI_EVENT_STA_DISCONNECTED, &disconnect_handler, &server));
|
ESP_ERROR_CHECK(esp_event_handler_register(WIFI_EVENT, WIFI_EVENT_STA_DISCONNECTED, &disconnect_handler, &server));
|
||||||
|
|
||||||
printf("Minimum free heap size: %"PRIu32" bytes\n", esp_get_minimum_free_heap_size());
|
|
||||||
|
|
||||||
/* Start the server for the first time */
|
/* Start the server for the first time */
|
||||||
server = start_webserver();
|
server = start_webserver();
|
||||||
while (server) {
|
while (server) {
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
pkgs ? import sources.nixpkgs { overlays = [ overlay ]; },
|
pkgs ? import sources.nixpkgs { overlays = [ overlay ]; },
|
||||||
}:
|
}:
|
||||||
pkgs.mkShell {
|
pkgs.mkShell {
|
||||||
name = "hackens-devant";
|
name = "hackes-devant";
|
||||||
|
|
||||||
buildInputs = with pkgs; [
|
buildInputs = with pkgs; [
|
||||||
esp-idf-esp32c3
|
esp-idf-esp32c3
|
||||||
|
|
Loading…
Reference in a new issue