Sebastien 5a7a7c9e60 remove unnecessary http_server.c file 5 gadi atpakaļ
..
.gitignore d7dc25f5b6 Merge remote-tracking branch 'origin/Over_The_Air_Update' into 5 gadi atpakaļ
CMakeLists.txt b680999e62 Merge branch 'master' into httpd 5 gadi atpakaļ
Kconfig.projbuild ee1d54a1ba add a GPIO to drive external amplifier 5 gadi atpakaļ
LICENSE.md 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
README.md 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
ap.json 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
bootstrap.min.css.gz 7e4ed77af0 move to bootstrap 5 gadi atpakaļ
bootstrap.min.js.gz 7e4ed77af0 move to bootstrap 5 gadi atpakaļ
code.js 168c15ce02 httpd alpha version - release 5 gadi atpakaļ
component.mk e19c9e12dc memory leak fixed 5 gadi atpakaļ
compress.bat 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
connect 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
dns_server.c 4b3fab563a wip httpd implementation 5 gadi atpakaļ
dns_server.h 0ab1cd438b Full OTA refactor and other stability improvement 5 gadi atpakaļ
http_server_handlers.c e19c9e12dc memory leak fixed 5 gadi atpakaļ
http_server_handlers.h 4de4e07d99 messaging subsystem wip 5 gadi atpakaļ
index.html 168c15ce02 httpd alpha version - release 5 gadi atpakaļ
jquery.min.js.gz 7e4ed77af0 move to bootstrap 5 gadi atpakaļ
lock.png 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
main.c.txt 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
popper.min.js.gz 7e4ed77af0 move to bootstrap 5 gadi atpakaļ
settings.png 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
status 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
style.css 6b52cf5c15 fully hide dummy iframe 5 gadi atpakaļ
wifi0.png 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
wifi1.png 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
wifi2.png 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
wifi24.png 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
wifi3.png 6e7793a756 initial work on a wifi/http configuration module 5 gadi atpakaļ
wifi_manager.c e19c9e12dc memory leak fixed 5 gadi atpakaļ
wifi_manager.h d4576bbdd4 httpd implementation - wip 5 gadi atpakaļ
wifi_manager_http_server.c e19c9e12dc memory leak fixed 5 gadi atpakaļ

README.md

What is esp32-wifi-manager?

esp32-wifi-manager is an esp32 program that enables easy management of wifi networks through a web application.

esp32-wifi-manager is lightweight (8KB of task stack in total) and barely uses any CPU power through a completely event driven architecture. It's an all in one wifi scanner, http server & dns daemon living in the least amount of RAM possible.

For real time constrained applications, esp32-wifi-manager can live entirely on PRO CPU, leaving the entire APP CPU untouched for your own needs.

esp32-wifi-manager will automatically attempt to re-connect to a previously saved network on boot, and it will start its own wifi access point through which you can manage wifi networks if a saved network cannot be found and/or if the connection is lost.

esp32-wifi-manager is an esp-idf project that compiles successfully with the esp-idf 3.2 release. You can simply copy the project and start adding your own code to it.

Demo

esp32-wifi-manager demo

Look and Feel

esp32-wifi-manager on an mobile device esp32-wifi-manager on an mobile device

Adding esp32-wifi-manager to your code

Ther are effectively three different ways you can embed esp32-wifi-manager with your code:

  • Just forget about it and poll in your code for wifi connectivity status
  • Use event callbacks
  • Modify esp32-wifi-manager code directly to fit your needs

Event callbacks are the cleanest way to use the wifi manager and that's the recommended way to do it. A typical use-case would be to get notified when wifi manager finally gets a connection an access point. In order to do this you can simply define a callback function:

void cb_connection_ok(void *pvParameter){
	ESP_LOGI(TAG, "I have a connection!");
}

Then just register it by calling:

wifi_manager_set_callback(EVENT_STA_GOT_IP, &cb_connection_ok);

That's it! Now everytime the event is triggered it will call this function.

License

esp32-wifi-manager is MIT licensed. As such, it can be included in any project, commercial or not, as long as you retain original copyright. Please make sure to read the license file.