From 86a124df886237ee0d9f7b9f59eacfc952058a51 Mon Sep 17 00:00:00 2001
From: Khoi Hoang <57012152+khoih-prog@users.noreply.github.com>
Date: Wed, 24 Feb 2021 02:37:51 -0500
Subject: [PATCH] ### Major Releases v1.2.0
### Major Releases v1.2.0
1. Configurable **Customs HTML Headers**, including Customs Style, Customs Head Elements, CORS Header.
2. Add support to **ESP32-S2 (ESP32-S2 Saola and AI-Thinker ESP-12K)**. Currently using EEPROM only. To add support to LittleFS and SPIFFS in future releases.
3. Fix Config Portal Bug.
4. Tested with [**Latest ESP32 Core 1.0.5**](https://github.com/espressif/arduino-esp32) for ESP32-based boards.
5. Update examples
---
CONTRIBUTING.md | 4 +-
README.md | 321 +++++++++++++--
.../AM2315_ESP32_SSL/AM2315_ESP32_SSL.ino | 52 ++-
examples/AM2315_ESP32_SSL/defines.h | 46 ++-
examples/AM2315_ESP8266/AM2315_ESP8266.ino | 52 ++-
examples/AM2315_ESP8266/defines.h | 108 +++--
.../Blynk_WM_Template/Blynk_WM_Template.ino | 14 +-
examples/DHT11ESP32/DHT11ESP32.ino | 54 ++-
examples/DHT11ESP32/defines.h | 45 +-
examples/DHT11ESP32_SSL/DHT11ESP32_SSL.ino | 56 ++-
examples/DHT11ESP32_SSL/defines.h | 45 +-
examples/DHT11ESP8266/DHT11ESP8266.ino | 58 ++-
examples/DHT11ESP8266/defines.h | 118 +++---
.../DHT11ESP8266_Debug/DHT11ESP8266_Debug.ino | 60 ++-
examples/DHT11ESP8266_Debug/defines.h | 118 +++---
.../DHT11ESP8266_SSL/DHT11ESP8266_SSL.ino | 56 ++-
examples/DHT11ESP8266_SSL/defines.h | 116 +++---
examples/ESP32WM_Config/ESP32WM_Config.ino | 52 ++-
examples/ESP32WM_Config/defines.h | 29 +-
.../ESP32WM_ForcedConfig.ino | 52 ++-
examples/ESP32WM_ForcedConfig/defines.h | 28 +-
.../ESP32WM_MRD_Config/ESP32WM_MRD_Config.ino | 24 +-
examples/ESP32WM_MRD_Config/defines.h | 34 +-
.../ESP32WM_MRD_ForcedConfig.ino | 52 ++-
examples/ESP32WM_MRD_ForcedConfig/defines.h | 30 +-
.../ESP8266WM_Config/ESP8266WM_Config.ino | 54 ++-
examples/ESP8266WM_Config/defines.h | 19 +-
.../ESP8266WM_ForcedConfig.ino | 54 ++-
examples/ESP8266WM_ForcedConfig/defines.h | 48 ++-
.../ESP8266WM_MRD_Config.ino | 52 ++-
examples/ESP8266WM_MRD_Config/defines.h | 44 +-
.../ESP8266WM_MRD_ForcedConfig.ino | 21 +
examples/ESP8266WM_MRD_ForcedConfig/defines.h | 48 ++-
keywords.txt | 27 +-
library.json | 6 +-
library.properties | 6 +-
pics/esp32_s2_Core_Unzipped.png | Bin 0 -> 45169 bytes
pics/esp32_s2_Toolchain.png | Bin 0 -> 22374 bytes
pics/esp32_s2_esptool.png | Bin 0 -> 46738 bytes
pics/esp32_s2_tools.png | Bin 0 -> 41911 bytes
src/BlynkSimpleEsp32_SSL_WM.h | 360 +++++++++++++---
src/BlynkSimpleEsp32_WM.h | 389 +++++++++++++++---
src/BlynkSimpleEsp8266_SSL_WM.h | 328 ++++++++++++---
src/BlynkSimpleEsp8266_WM.h | 358 +++++++++++++---
44 files changed, 2645 insertions(+), 793 deletions(-)
create mode 100644 pics/esp32_s2_Core_Unzipped.png
create mode 100644 pics/esp32_s2_Toolchain.png
create mode 100644 pics/esp32_s2_esptool.png
create mode 100644 pics/esp32_s2_tools.png
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index cf7300c..de46c6a 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -15,7 +15,7 @@ If you don't find anything, please [open a new issue](https://github.com/khoih-p
Please ensure to specify the following:
* Arduino IDE version (e.g. 1.8.13) or Platform.io version
-* `ESP8266` or `ESP32` Core Version (e.g. ESP8266 core v2.7.4 or ESP32 v1.0.4)
+* `ESP8266` or `ESP32` Core Version (e.g. ESP8266 core v2.7.4 or ESP32 v1.0.5)
* Contextual information (e.g. what you were trying to achieve)
* Simplest possible steps to reproduce
* Anything that might be relevant in your opinion, such as:
@@ -29,7 +29,7 @@ Please ensure to specify the following:
Arduino IDE version: 1.8.13
ESP8266 Core Version 2.7.4
OS: Ubuntu 20.04 LTS
-Linux Inspiron 5.4.0-60-generic #67-Ubuntu SMP Tue Jan 5 18:31:36 UTC 2021 x86_64 x86_64 x86_64 GNU/Linux
+Linux Inspiron 5.4.0-65-generic #73-Ubuntu SMP Mon Jan 18 17:25:17 UTC 2021 x86_64 x86_64 x86_64 GNU/Linux
Context:
The board couldn't autoreconnect to Local Blynk Server after router power recycling.
diff --git a/README.md b/README.md
index 6e9206d..f9f28dc 100644
--- a/README.md
+++ b/README.md
@@ -18,6 +18,7 @@
* [Features](#features)
* [Currently supported Boards](#currently-supported-boards)
* [Changelog](#changelog)
+ * [Major Releases v1.2.0](#major-releases-v120)
* [Releases v1.1.3](#releases-v113)
* [Releases v1.1.2](#releases-v112)
* [Releases v1.1.1](#releases-v111)
@@ -33,6 +34,21 @@
* [Installation](#installation)
* [I) For Arduino IDE](#i-for-arduino-ide)
* [II) For VS Code & PlatformIO:](#ii-for-vs-code--platformio)
+* [HOWTO Install esp32-s2 core for ESP32-S2 (Saola, AI-Thinker ESP-12K) boards into Arduino IDE)](#howto-install-esp32-s2-core-for-esp32-s2-saola-ai-thinker-esp-12k-boards-into-arduino-ide)
+ * [1. Save the original esp32 core](#1-save-the-original-esp32-core)
+ * [2. Download esp32-s2 core](#2-download-esp32-s2-core)
+ * [2.1 Download zip](#21-download-zip)
+ * [2.2 Unzip](#22-unzip)
+ * [2.3 Update esp32-s2 core directories](#23-update-esp32-s2-core-directories)
+ * [3. Download tools](#3-download-tools)
+ * [3.1 Download Toolchain for Xtensa (ESP32-S2) based on GCC](#31-download-toolchain-for-xtensa-esp32-s2-based-on-gcc)
+ * [3.2 Download esptool](#32-download-esptool)
+ * [3.3 Unzip](#33-unzip)
+ * [4. Update tools](#4-update-tools)
+ * [4.1 Update Toolchain](#41-update-toolchain)
+ * [4.2 Update esptool](#42-update-esptool)
+ * [5. esp32-s2 WebServer Library Patch](#5-esp32-s2-webserver-library-patch)
+* [Note for Platform IO using ESP32 LittleFS](#note-for-platform-io-using-esp32-littlefs)
* [HOWTO Use analogRead() with ESP32 running WiFi and/or BlueTooth (BT/BLE)](#howto-use-analogread-with-esp32-running-wifi-andor-bluetooth-btble)
* [1. ESP32 has 2 ADCs, named ADC1 and ADC2](#1--esp32-has-2-adcs-named-adc1-and-adc2)
* [2. ESP32 ADCs functions](#2-esp32-adcs-functions)
@@ -44,6 +60,9 @@
* [ 3. Example of Default Credentials](#3-example-of-default-credentials)
* [ 4. How to add dynamic parameters from sketch](#4-how-to-add-dynamic-parameters-from-sketch)
* [ 5. If you don't need to add dynamic parameters](#5-if-you-dont-need-to-add-dynamic-parameters)
+ * [ 6. To use custom HTML Style](#6-to-use-custom-html-style)
+ * [ 7. To use custom Head Elements](#7-to-use-custom-head-elements)
+ * [ 8. To use CORS Header](#8-to-use-cors-header)
* [Important Notes for using Dynamic Parameters' ids](#important-notes-for-using-dynamic-parameters-ids)
* [Important Notes](#important-notes)
* [Why using this Blynk_WiFiManager with MultiWiFi-MultiBlynk features](#why-using-this-blynk_wifimanager-with-multiwifi-multiblynk-features)
@@ -154,7 +173,9 @@ With version `v1.0.5` or later, you can configure:
This [**BlynkESP32_BT_WF** library](https://github.com/khoih-prog/BlynkESP32_BT_WF) currently supports these following boards:
- 1. **ESP8266 and ESP32-based boards using EEPROM, SPIFFS or LittleFS**.
+ 1. **ESP32 using EEPROM, SPIFFS or LittleFS**.
+ 2. **ESP32-S2 (ESP32-S2 Saola, AI-Thinker ESP-12K, etc.) using EEPROM**
+ 3. **ESP8266 using EEPROM, SPIFFS or LittleFS**.
---
@@ -162,6 +183,14 @@ This [**BlynkESP32_BT_WF** library](https://github.com/khoih-prog/BlynkESP32_BT_
## Changelog
+### Major Releases v1.2.0
+
+1. Configurable **Customs HTML Headers**, including Customs Style, Customs Head Elements, CORS Header.
+2. Add support to **ESP32-S2 (ESP32-S2 Saola and AI-Thinker ESP-12K)**. Currently using EEPROM only. To add support to LittleFS and SPIFFS in future releases.
+3. Fix Config Portal Bug.
+4. Tested with [**Latest ESP32 Core 1.0.5**](https://github.com/espressif/arduino-esp32) for ESP32-based boards.
+5. Update examples
+
### Releases v1.1.3
1. To permit autoreset after configurable timeout if DRD/MRD or non-persistent forced-CP. Check [**Good new feature: Blynk.resetAndEnterConfigPortal() Thanks & question #27**](https://github.com/khoih-prog/Blynk_WM/issues/27)
@@ -234,12 +263,13 @@ Thanks to [Thor Johnson](https://github.com/thorathome) to test, suggest and enc
## Prerequisites
1. [`Arduino IDE 1.8.13+`](https://www.arduino.cc/en/Main/Software)
-2. [`Blynk library 0.6.1+`](https://github.com/blynkkk/blynk-library/releases)
-3. [`ESP32 core 1.0.4+`](https://github.com/espressif/arduino-esp32/releases) for ESP32 boards
-4. [`ESP8266 core 2.7.4+`](https://github.com/esp8266/Arduino#installing-with-boards-manager) for ESP8266 boards. To use ESP8266 core 2.7.1+ for LittleFS.
-5. [`ESP_DoubleResetDetector library 1.1.1+`](https://github.com/khoih-prog/ESP_DoubleResetDetector) to use DRD feature. To install, check [data:image/s3,"s3://crabby-images/eee9d/eee9dece6825e49b95b818087744f734328db1fd" alt="arduino-library-badge"](https://www.ardu-badge.com/ESP_DoubleResetDetector).
-6. [`ESP_MultiResetDetector library 1.1.1+`](https://github.com/khoih-prog/ESP_MultiResetDetector) to use MRD feature. To install, check [data:image/s3,"s3://crabby-images/ecf51/ecf51db5f0c0a697c55fc568d4abf25fd4332016" alt="arduino-library-badge"](https://www.ardu-badge.com/ESP_MultiResetDetector).
-7. [`LittleFS_esp32 v1.0.5+`](https://github.com/lorol/LITTLEFS) to use ESP32 LittleFS.
+2. [`Blynk library 0.6.1+`](https://github.com/blynkkk/blynk-library/releases). [data:image/s3,"s3://crabby-images/fe4e1/fe4e1bd87517adbccf304ac6939b632b817db532" alt="Latest release"](https://github.com/blynkkk/blynk-library/releases/latest/)
+3. [`ESP32 Core 1.0.5+`](https://github.com/espressif/arduino-esp32) for ESP32-based boards. [data:image/s3,"s3://crabby-images/22864/22864fb64423b2782cf344eabf47f8245110c840" alt="Latest release"](https://github.com/espressif/arduino-esp32/releases/latest/)
+4. [`ESP32S2 Core 1.0.5+`](https://github.com/espressif/arduino-esp32/tree/esp32s2) for ESP32S2-based boards.
+5. [`ESP8266 Core 2.7.4+`](https://github.com/esp8266/Arduino) for ESP8266-based boards. [data:image/s3,"s3://crabby-images/f0afa/f0afa37a80f1d99ae7908502656c64969d7de30f" alt="Latest release"](https://github.com/esp8266/Arduino/releases/latest/). To use ESP8266 core 2.7.1+ for LittleFS.
+6. [`ESP_DoubleResetDetector library 1.1.1+`](https://github.com/khoih-prog/ESP_DoubleResetDetector) to use DRD feature. To install, check [data:image/s3,"s3://crabby-images/eee9d/eee9dece6825e49b95b818087744f734328db1fd" alt="arduino-library-badge"](https://www.ardu-badge.com/ESP_DoubleResetDetector).
+7. [`ESP_MultiResetDetector library 1.1.1+`](https://github.com/khoih-prog/ESP_MultiResetDetector) to use MRD feature. To install, check [data:image/s3,"s3://crabby-images/ecf51/ecf51db5f0c0a697c55fc568d4abf25fd4332016" alt="arduino-library-badge"](https://www.ardu-badge.com/ESP_MultiResetDetector).
+8. [`LittleFS_esp32 v1.0.5+`](https://github.com/lorol/LITTLEFS) for ESP32-based boards using LittleFS. To install, check [data:image/s3,"s3://crabby-images/843a7/843a76fc3e8f20fc4ecdda858e2bc479c12564cc" alt="arduino-library-badge"](https://www.ardu-badge.com/LittleFS_esp32).
---
@@ -288,6 +318,136 @@ Thanks to [Thor Johnson](https://github.com/thorathome) to test, suggest and enc
---
---
+## HOWTO Install esp32-s2 core for ESP32-S2 (Saola, AI-Thinker ESP-12K) boards into Arduino IDE
+
+
+These are instructions demonstrating the steps to install esp32-s2 core on Ubuntu machines. For Windows or other OS'es, just follow the the similar principles and steps.
+
+Assuming you already installed Arduino IDE ESP32 core and the installed directory is
+
+`/home/your_account/.arduino15/packages/esp32`
+
+
+### 1. Save the original esp32 core
+
+First, copy the whole original esp32 core to another safe place. Then delete all the sub-directories of
+
+`/home/your_account/.arduino15/packages/esp32/hardware/esp32/1.0.4`
+
+---
+
+### 2. Download esp32-s2 core
+
+#### 2.1 Download zip
+
+Download [**esp32-s2 core**](https://github.com/espressif/arduino-esp32/tree/esp32s2) in the `zip` format:
+
+`arduino-esp32-esp32s2.zip`
+
+#### 2.2 Unzip
+
+
+
+
+
+#### 2.3 Update esp32-s2 core directories
+
+Copy all subdirectories of esp32-s2 core into `/home/your_account/.arduino15/packages/esp32/hardware/esp32/1.0.4`
+
+---
+
+### 3 Download tools
+
+
+#### 3.1 Download Toolchain for Xtensa (ESP32-S2) based on GCC
+
+Download [**esp32-s2 Toolchain**](https://docs.espressif.com/projects/esp-idf/en/latest/esp32s2/api-guides/tools/idf-tools.html#xtensa-esp32s2-elf) corresponding to your environment (linux-amd64, win64, etc.).
+
+For example `xtensa-esp32s2-elf-gcc8_4_0-esp-2020r3-linux-amd64.tar.gz`, then un-archive.
+
+
+
+
+
+
+#### 3.2 Download esptool
+
+
+Download [esptool](https://github.com/espressif/esptool/releases) int the `zip` format:
+
+`esptool-3.0.zip`
+
+#### 3.3 Unzip
+
+
+
+
+
+---
+
+### 4. Update tools
+
+#### 4.1 Update Toolchain
+
+Copy whole `xtensa-esp32s2-elf` directory into `/home/your_account/.arduino15/packages/esp32/hardware/esp32/1.0.4/tools`
+
+
+#### 4.2 Update esptool
+
+Rename `esptool-3.0` directory to `esptool`
+
+
+Copy whole `esptool` directory into `/home/your_account/.arduino15/packages/esp32/hardware/esp32/1.0.4/tools`
+
+
+
+
+
+
+
+### 5. esp32-s2 WebServer Library Patch
+
+If you haven't installed a new version with [WebServer.handleClient delay PR #4350](https://github.com/espressif/arduino-esp32/pull/4350) or haven't applied the above mentioned PR, you have to use the following patch.
+
+
+**To be able to run Config Portal on ESP32-S2 boards**, you have to copy the files in [esp32-s2 WebServer Patch](esp32s2_WebServer_Patch/) directory into esp32-s2 WebServer library directory (~/.arduino15/packages/esp32/hardware/esp32/1.0.4/libraries/WebServer).
+
+Supposing the esp32-s2 version is 1.0.4, these files `WebServer.h/cpp` must be copied into the directory to replace:
+
+- `~/.arduino15/packages/esp32/hardware/esp32/1.0.4/libraries/WebServer/src/WebServer.h`
+- `~/.arduino15/packages/esp32/hardware/esp32/1.0.4/libraries/WebServer/src/WebServer.cpp`
+
+
+---
+
+That's it. You're now ready to compile and test for ESP32-S2 now
+
+---
+---
+
+### Note for Platform IO using ESP32 LittleFS
+
+In Platform IO, to fix the error when using [`LittleFS_esp32 v1.0`](https://github.com/lorol/LITTLEFS) for ESP32-based boards with ESP32 core v1.0.4- (ESP-IDF v3.2-), uncomment the following line
+
+from
+
+```
+//#define CONFIG_LITTLEFS_FOR_IDF_3_2 /* For old IDF - like in release 1.0.4 */
+```
+
+to
+
+```
+#define CONFIG_LITTLEFS_FOR_IDF_3_2 /* For old IDF - like in release 1.0.4 */
+```
+
+It's advisable to use the latest [`LittleFS_esp32 v1.0.5+`](https://github.com/lorol/LITTLEFS) to avoid the issue.
+
+Thanks to [Roshan](https://github.com/solroshan) to report the issue in [Error esp_littlefs.c 'utime_p'](https://github.com/khoih-prog/ESPAsync_WiFiManager/issues/28)
+
+---
+---
+
### HOWTO Use analogRead() with ESP32 running WiFi and/or BlueTooth (BT/BLE)
Please have a look at [**ESP_WiFiManager Issue 39: Not able to read analog port when using the autoconnect example**](https://github.com/khoih-prog/ESP_WiFiManager/issues/39) to have more detailed description and solution of the issue.
@@ -607,6 +767,31 @@ uint16_t NUM_MENU_ITEMS = 0;
```
+#### 6. To use custom HTML Style
+
+```
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+
+...
+
+Blynk.setCustomsStyle(NewCustomsStyle);
+```
+
+#### 7. To use custom Head Elements
+
+
+```
+Blynk.setCustomsHeadElement("");
+```
+
+#### 8. To use CORS Header
+
+```
+Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+```
+
+
---
---
@@ -761,7 +946,7 @@ BLYNK_WRITE(BLYNK_PIN_FORCED_CONFIG)
{
if (param.asInt())
{
- Serial.println( F("CP Button Hit. Rebooting") );
+ Serial.println( F("\nCP Button Hit. Rebooting") );
// This will keep CP once, clear after reset, even you didn't enter CP at all.
Blynk.resetAndEnterConfigPortal();
@@ -776,7 +961,7 @@ BLYNK_WRITE(BLYNK_PIN_FORCED_PERS_CONFIG)
{
if (param.asInt())
{
- Serial.println( F("Persistent CP Button Hit. Rebooting") );
+ Serial.println( F("\nPersistent CP Button Hit. Rebooting") );
// This will keep CP forever, until you successfully enter CP, and Save data to clear the flag.
Blynk.resetAndEnterConfigPortalPersistent();
@@ -853,6 +1038,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(LED_BUILTIN, OUTPUT);
@@ -902,6 +1092,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -931,25 +1137,21 @@ void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if USE_DYNAMIC_PARAMETERS
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -963,6 +1165,18 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if USE_DYNAMIC_PARAMETERS
+ displayCredentialsInLoop();
#endif
}
```
@@ -1021,8 +1235,15 @@ void loop()
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
-#define USE_LITTLEFS true
-#define USE_SPIFFS false
+#if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+#else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+#endif
#if !( USE_SPIFFS || USE_LITTLEFS)
// EEPROM_SIZE must be <= 2048 and >= CONFIG_DATA_SIZE (currently 172 bytes)
@@ -1031,22 +1252,35 @@ void loop()
#define EEPROM_START 0
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
-//#define USE_SSL true
-#define USE_SSL false
+#define USE_SSL true
+//#define USE_SSL false
#if USE_SSL
-#include
+ #include
#else
-#include
+ #include
#endif
#define PIN_D22 22 // Pin D22 mapped to pin GPIO22/SCL of ESP32
@@ -1150,7 +1384,7 @@ Blynk_WM_Configuration defaultConfig =
#ifndef dynamicParams_h
#define dynamicParams_h
-// USE_DYNAMIC_PARAMETERS defined in defines.h
+// USE_DYNAMIC_PARAMETERS defined in defined.h
/////////////// Start dynamic Credentials ///////////////
@@ -1228,7 +1462,7 @@ The following is the sample terminal output when running example [ESP8266WM_MRD_
```
Starting ESP8266WM_MRD_Config using LittleFS with SSL on ESP8266_NODEMCU
-Blynk_WM SSL for ESP8266 v1.1.3
+Blynk_WM SSL for ESP8266 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFD0002
multiResetDetectorFlag = 0xFFFD0002
@@ -1308,7 +1542,7 @@ BBBBBB
```
Starting ESP8266WM_MRD_Config using LittleFS with SSL on ESP8266_NODEMCU
-Blynk_WM SSL for ESP8266 v1.1.3
+Blynk_WM SSL for ESP8266 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFC0003
multiResetDetectorFlag = 0xFFFC0003
@@ -1370,7 +1604,7 @@ The following is the sample terminal output when running example [DHT11ESP8266_S
```
Starting DHT11ESP8266_SSL using LittleFS with SSL on ESP8266_NODEMCU
-Blynk_WM SSL for ESP8266 v1.1.3
+Blynk_WM SSL for ESP8266 v1.2.0
ESP_DoubleResetDetector v1.1.1
[293] Hostname=ESP8266-DHT11-SSL
[316] LoadCfgFile
@@ -1428,7 +1662,7 @@ The following is the sample terminal output when running example [ESP32WM_MRD_Co
```
Starting ESP32WM_MRD_Config using LITTLEFS without SSL on ESP32_DEV
-Blynk_WM for ESP32 v1.1.3
+Blynk_WM for ESP32 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFE0001
multiResetDetectorFlag = 0xFFFE0001
@@ -1505,7 +1739,7 @@ BBBBBB
```
Starting ESP32WM_MRD_Config using LITTLEFS without SSL on ESP32_DEV
-Blynk_WM for ESP32 v1.1.3
+Blynk_WM for ESP32 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFC0003
multiResetDetectorFlag = 0xFFFC0003
@@ -1563,7 +1797,7 @@ ets Jun 8 2016 00:22:57
```
Starting ESP32WM_MRD_Config using LITTLEFS without SSL on ESP32_DEV
-Blynk_WM for ESP32 v1.1.3
+Blynk_WM for ESP32 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFE0001
multiResetDetectorFlag = 0xFFFE0001
@@ -1687,7 +1921,7 @@ The following is the sample terminal output when running example [DHT11ESP8266_S
```
Starting DHT11ESP32_SSL using LITTLEFS with SSL on ESP32_DEV
-Blynk_WM SSL for ESP32 v1.1.3
+Blynk_WM SSL for ESP32 v1.2.0
ESP_DoubleResetDetector v1.1.1
[346] Hostname=ESP32-DHT11-SSL
[385] LoadCfgFile
@@ -1751,7 +1985,7 @@ Blynk.resetAndEnterConfigPortal();
```
Starting ESP8266WM_MRD_ForcedConfig using LittleFS without SSL on ESP8266_NODEMCU
-Blynk_WM for ESP8266 v1.1.3
+Blynk_WM for ESP8266 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFE0001
multiResetDetectorFlag = 0xFFFE0001
@@ -1837,7 +2071,7 @@ Non-Persistent CP will be removed after first reset, even you didn't enter the C
```
Starting ESP8266WM_MRD_ForcedConfig using LittleFS without SSL on ESP8266_NODEMCU
-Blynk_WM for ESP8266 v1.1.3
+Blynk_WM for ESP8266 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFE0001
multiResetDetectorFlag = 0xFFFE0001
@@ -1919,7 +2153,7 @@ Blynk.resetAndEnterConfigPortalPersistent();
```
Starting ESP8266WM_MRD_ForcedConfig using LittleFS without SSL on ESP8266_NODEMCU
-Blynk_WM for ESP8266 v1.1.3
+Blynk_WM for ESP8266 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFE0001
multiResetDetectorFlag = 0xFFFE0001
@@ -2006,7 +2240,7 @@ Persistent CP will remain after resets. The only way to get rid of Config Portal
```
Starting ESP8266WM_MRD_ForcedConfig using LittleFS without SSL on ESP8266_NODEMCU
-Blynk_WM for ESP8266 v1.1.3
+Blynk_WM for ESP8266 v1.2.0
ESP_MultiResetDetector v1.1.1
LittleFS Flag read = 0xFFFE0001
multiResetDetectorFlag = 0xFFFE0001
@@ -2104,6 +2338,14 @@ Sometimes, the library will only work if you update the board core to the latest
## Releases
+### Major Releases v1.2.0
+
+1. Configurable **Customs HTML Headers**, including Customs Style, Customs Head Elements, CORS Header.
+2. Add support to **ESP32-S2 (ESP32-S2 Saola and AI-Thinker ESP-12K)**. Currently using EEPROM only. To add support to LittleFS and SPIFFS in future releases.
+3. Fix Config Portal Bug.
+4. Tested with [**Latest ESP32 Core 1.0.5**](https://github.com/espressif/arduino-esp32) for ESP32-based boards.
+5. Update examples
+
### Releases v1.1.3
1. To permit autoreset after configurable timeout if DRD/MRD or non-persistent forced-CP. Check [**Good new feature: Blynk.resetAndEnterConfigPortal() Thanks & question #27**](https://github.com/khoih-prog/Blynk_WM/issues/27)
@@ -2251,6 +2493,7 @@ Submit issues to: [Blynk_WM issues](https://github.com/khoih-prog/Blynk_WM/issue
## TO DO
1. Fix bug. Add enhancement
+2. Add support to **ESP32-S2 (ESP32-S2 Saola, AI-Thinker ESP-12K, etc.) using LittleFS and SPIFFS**
## DONE
@@ -2281,6 +2524,8 @@ Submit issues to: [Blynk_WM issues](https://github.com/khoih-prog/Blynk_WM/issue
24. Add Table of Contents
25. Add Version String
26. Add functions to control Config Portal from software or Virtual Switches.
+27. Add support to **ESP32-S2 (ESP32-S2 Saola, AI-Thinker ESP-12K, etc.) using EEPROM**
+28. Configurable **Customs HTML Headers**, including Customs Style, Customs Head Elements, CORS Header
---
---
diff --git a/examples/AM2315_ESP32_SSL/AM2315_ESP32_SSL.ino b/examples/AM2315_ESP32_SSL/AM2315_ESP32_SSL.ino
index a990225..6da6c12 100644
--- a/examples/AM2315_ESP32_SSL/AM2315_ESP32_SSL.ino
+++ b/examples/AM2315_ESP32_SSL/AM2315_ESP32_SSL.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -126,6 +127,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
Serial.begin(115200);
@@ -178,6 +184,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -220,25 +242,21 @@ void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -252,5 +270,17 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
+ displayCredentialsInLoop();
#endif
}
diff --git a/examples/AM2315_ESP32_SSL/defines.h b/examples/AM2315_ESP32_SSL/defines.h
index 727ac92..3587522 100644
--- a/examples/AM2315_ESP32_SSL/defines.h
+++ b/examples/AM2315_ESP32_SSL/defines.h
@@ -28,8 +28,15 @@
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
-#define USE_LITTLEFS true
-#define USE_SPIFFS false
+#if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+#else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+#endif
#if !( USE_SPIFFS || USE_LITTLEFS)
@@ -39,24 +46,36 @@
#define EEPROM_START 0
#endif
-// Force some params in Blynk, only valid for library version 1.0.1 and later
-#define TIMEOUT_RECONNECT_WIFI 10000L
-#define RESET_IF_CONFIG_TIMEOUT true
-#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
-
-#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
-
//You have to download Blynk WiFiManager Blynk_WM library at //https://github.com/khoih-prog/Blynk_WM
// In order to enable (USE_BLYNK_WM = true). Otherwise, use (USE_BLYNK_WM = false)
#define USE_BLYNK_WM true
-//#define USE_BLYNK_WM false
-
-//#define USE_SSL true
#define USE_SSL false
#if USE_BLYNK_WM
+
+ /////////////////////////////////////////////
+
+ // Add customs headers from v1.2.0
+ #define USING_CUSTOMS_STYLE true
+ #define USING_CUSTOMS_HEAD_ELEMENT true
+ #define USING_CORS_FEATURE true
+
+ /////////////////////////////////////////////
+
+ // Force some params in Blynk, only valid for library version 1.0.1 and later
+ #define TIMEOUT_RECONNECT_WIFI 10000L
+ #define RESET_IF_CONFIG_TIMEOUT true
+
+ #define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+
+ // Config Timeout 120s (default 60s)
+ #define CONFIG_TIMEOUT 120000L
+
+ #define USE_DYNAMIC_PARAMETERS true
+ // Those above #define's must be placed before #include and
+ //////////////////////////////////////////
+
#if USE_SSL
#include //https://github.com/khoih-prog/Blynk_WM
#else
@@ -83,7 +102,6 @@
#endif
#define USE_LOCAL_SERVER true
- //#define USE_LOCAL_SERVER false
// If local server
#if USE_LOCAL_SERVER
diff --git a/examples/AM2315_ESP8266/AM2315_ESP8266.ino b/examples/AM2315_ESP8266/AM2315_ESP8266.ino
index f18f303..a6d6dcf 100644
--- a/examples/AM2315_ESP8266/AM2315_ESP8266.ino
+++ b/examples/AM2315_ESP8266/AM2315_ESP8266.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -124,6 +125,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
Serial.begin(115200);
@@ -170,6 +176,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -214,25 +236,21 @@ void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -246,5 +264,17 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
+ displayCredentialsInLoop();
#endif
}
diff --git a/examples/AM2315_ESP8266/defines.h b/examples/AM2315_ESP8266/defines.h
index d43171e..f48dd60 100644
--- a/examples/AM2315_ESP8266/defines.h
+++ b/examples/AM2315_ESP8266/defines.h
@@ -13,7 +13,7 @@
#define defines_h
#ifndef ESP8266
-#error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
+ #error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
#endif
#define BLYNK_PRINT Serial
@@ -34,72 +34,90 @@
//#define USE_SPIFFS true
#if USE_LITTLEFS
-//LittleFS has higher priority
-#define CurrentFileFS "LittleFS"
-#ifdef USE_SPIFFS
-#undef USE_SPIFFS
-#endif
-#define USE_SPIFFS false
+ //LittleFS has higher priority
+ #define CurrentFileFS "LittleFS"
+ #ifdef USE_SPIFFS
+ #undef USE_SPIFFS
+ #endif
+ #define USE_SPIFFS false
#elif USE_SPIFFS
-#define CurrentFileFS "SPIFFS"
+ #define CurrentFileFS "SPIFFS"
#endif
#if !( USE_LITTLEFS || USE_SPIFFS)
-// EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
-#define EEPROM_SIZE (4 * 1024)
-// EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
-#define EEPROM_START 768
+ // EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
+ #define EEPROM_SIZE (4 * 1024)
+ // EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
+ #define EEPROM_START 768
#endif
//You have to download Blynk WiFiManager Blynk_WM library at //https://github.com/khoih-prog/Blynk_WM
// In order to enable (USE_BLYNK_WM = true). Otherwise, use (USE_BLYNK_WM = false)
#define USE_BLYNK_WM true
-//#define USE_BLYNK_WM false
#define USE_SSL false
#if USE_BLYNK_WM
-#define USE_DYNAMIC_PARAMETERS true
+ /////////////////////////////////////////////
+
+ // Add customs headers from v1.2.0
+ #define USING_CUSTOMS_STYLE true
+ #define USING_CUSTOMS_HEAD_ELEMENT true
+ #define USING_CORS_FEATURE true
+
+ /////////////////////////////////////////////
+
+ // Force some params in Blynk, only valid for library version 1.0.1 and later
+ #define TIMEOUT_RECONNECT_WIFI 10000L
+ #define RESET_IF_CONFIG_TIMEOUT true
+
+ #define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+
+ // Config Timeout 120s (default 60s)
+ #define CONFIG_TIMEOUT 120000L
+
+ #define USE_DYNAMIC_PARAMETERS true
+ // Those above #define's must be placed before #include and
+ //////////////////////////////////////////
+
+ #if USE_SSL
+ #include //https://github.com/khoih-prog/Blynk_WM
+ #else
+ #include //https://github.com/khoih-prog/Blynk_WM
+ #endif
+
+ #include "Credentials.h"
+ #include "dynamicParams.h"
-#if USE_SSL
-#include //https://github.com/khoih-prog/Blynk_WM
#else
-#include //https://github.com/khoih-prog/Blynk_WM
-#endif
-
-#include "Credentials.h"
-#include "dynamicParams.h"
-#else
-
-#if USE_SSL
-#include
-#define BLYNK_HARDWARE_PORT 9443
-#else
-#include
-#define BLYNK_HARDWARE_PORT 8080
-#endif
+ #if USE_SSL
+ #include
+ #define BLYNK_HARDWARE_PORT 9443
+ #else
+ #include
+ #define BLYNK_HARDWARE_PORT 8080
+ #endif
#endif
#if !USE_BLYNK_WM
-#ifndef LED_BUILTIN
-#define LED_BUILTIN 2 // Pin D2 mapped to pin GPIO2/ADC12 of ESP32, control on-board LED
-#endif
-
-#define USE_LOCAL_SERVER true
-//#define USE_LOCAL_SERVER false
-
-// If local server
-#if USE_LOCAL_SERVER
-char blynk_server[] = "yourname.duckdns.org";
-#endif
-
-char auth[] = "***";
-char ssid[] = "***";
-char pass[] = "***";
+ #ifndef LED_BUILTIN
+ #define LED_BUILTIN 2 // Pin D2 mapped to pin GPIO2/ADC12 of ESP32, control on-board LED
+ #endif
+
+ #define USE_LOCAL_SERVER true
+
+ // If local server
+ #if USE_LOCAL_SERVER
+ char blynk_server[] = "yourname.duckdns.org";
+ #endif
+
+ char auth[] = "***";
+ char ssid[] = "***";
+ char pass[] = "***";
#endif
diff --git a/examples/Blynk_WM_Template/Blynk_WM_Template.ino b/examples/Blynk_WM_Template/Blynk_WM_Template.ino
index 0ca7071..aa72cd8 100644
--- a/examples/Blynk_WM_Template/Blynk_WM_Template.ino
+++ b/examples/Blynk_WM_Template/Blynk_WM_Template.ino
@@ -8,7 +8,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -33,6 +33,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
// Sketch uses Arduino IDE-selected ESP32 and ESP8266 to select compile choices
@@ -175,8 +176,15 @@
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
- #define USE_LITTLEFS true
- #define USE_SPIFFS false
+ #if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+ #else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+ #endif
#if USE_LITTLEFS
#warning Using LittleFS for ESP32
diff --git a/examples/DHT11ESP32/DHT11ESP32.ino b/examples/DHT11ESP32/DHT11ESP32.ino
index 1f7f598..2482aeb 100644
--- a/examples/DHT11ESP32/DHT11ESP32.ino
+++ b/examples/DHT11ESP32/DHT11ESP32.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -107,6 +108,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(LED_BUILTIN, OUTPUT);
@@ -155,6 +161,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -197,25 +219,21 @@ void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -229,5 +247,17 @@ void loop()
}
}
}
-#endif
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
+ displayCredentialsInLoop();
+#endif
}
diff --git a/examples/DHT11ESP32/defines.h b/examples/DHT11ESP32/defines.h
index 1dc467f..f8d0759 100644
--- a/examples/DHT11ESP32/defines.h
+++ b/examples/DHT11ESP32/defines.h
@@ -28,9 +28,15 @@
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
-#define USE_LITTLEFS true
-#define USE_SPIFFS false
-
+#if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+#else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+#endif
#if !( USE_SPIFFS || USE_LITTLEFS)
// EEPROM_SIZE must be <= 2048 and >= CONFIG_DATA_SIZE (currently 172 bytes)
@@ -39,24 +45,35 @@
#define EEPROM_START 0
#endif
-// Force some params in Blynk, only valid for library version 1.0.1 and later
-#define TIMEOUT_RECONNECT_WIFI 10000L
-#define RESET_IF_CONFIG_TIMEOUT true
-#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
-
-#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
-
//You have to download Blynk WiFiManager Blynk_WM library at //https://github.com/khoih-prog/Blynk_WM
// In order to enable (USE_BLYNK_WM = true). Otherwise, use (USE_BLYNK_WM = false)
#define USE_BLYNK_WM true
-//#define USE_BLYNK_WM false
-
-//#define USE_SSL true
#define USE_SSL false
#if USE_BLYNK_WM
+ /////////////////////////////////////////////
+
+ // Add customs headers from v1.2.0
+ #define USING_CUSTOMS_STYLE true
+ #define USING_CUSTOMS_HEAD_ELEMENT true
+ #define USING_CORS_FEATURE true
+
+ /////////////////////////////////////////////
+
+ // Force some params in Blynk, only valid for library version 1.0.1 and later
+ #define TIMEOUT_RECONNECT_WIFI 10000L
+ #define RESET_IF_CONFIG_TIMEOUT true
+
+ #define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+
+ // Config Timeout 120s (default 60s)
+ #define CONFIG_TIMEOUT 120000L
+
+ #define USE_DYNAMIC_PARAMETERS true
+ // Those above #define's must be placed before #include and
+ //////////////////////////////////////////
+
#if USE_SSL
#include //https://github.com/khoih-prog/Blynk_WM
#else
diff --git a/examples/DHT11ESP32_SSL/DHT11ESP32_SSL.ino b/examples/DHT11ESP32_SSL/DHT11ESP32_SSL.ino
index 2a902cb..83f6b2b 100644
--- a/examples/DHT11ESP32_SSL/DHT11ESP32_SSL.ino
+++ b/examples/DHT11ESP32_SSL/DHT11ESP32_SSL.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -107,6 +108,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(LED_BUILTIN, OUTPUT);
@@ -155,6 +161,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -193,29 +215,25 @@ void setup()
}
#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
-void displayCredentials(void)
+void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -229,5 +247,17 @@ void loop()
}
}
}
-#endif
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
+ displayCredentialsInLoop();
+#endif
}
diff --git a/examples/DHT11ESP32_SSL/defines.h b/examples/DHT11ESP32_SSL/defines.h
index 59825ba..bdb983e 100644
--- a/examples/DHT11ESP32_SSL/defines.h
+++ b/examples/DHT11ESP32_SSL/defines.h
@@ -28,9 +28,15 @@
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
-#define USE_LITTLEFS true
-#define USE_SPIFFS false
-
+#if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+#else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+#endif
#if !( USE_SPIFFS || USE_LITTLEFS)
// EEPROM_SIZE must be <= 2048 and >= CONFIG_DATA_SIZE (currently 172 bytes)
@@ -38,24 +44,36 @@
// EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
#define EEPROM_START 0
#endif
-// Force some params in Blynk, only valid for library version 1.0.1 and later
-#define TIMEOUT_RECONNECT_WIFI 10000L
-#define RESET_IF_CONFIG_TIMEOUT true
-#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
-
-#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
//You have to download Blynk WiFiManager Blynk_WM library at //https://github.com/khoih-prog/Blynk_WM
// In order to enable (USE_BLYNK_WM = true). Otherwise, use (USE_BLYNK_WM = false)
#define USE_BLYNK_WM true
-//#define USE_BLYNK_WM false
-
#define USE_SSL true
-//#define USE_SSL false
#if USE_BLYNK_WM
+ /////////////////////////////////////////////
+
+ // Add customs headers from v1.2.0
+ #define USING_CUSTOMS_STYLE true
+ #define USING_CUSTOMS_HEAD_ELEMENT true
+ #define USING_CORS_FEATURE true
+
+ /////////////////////////////////////////////
+
+ // Force some params in Blynk, only valid for library version 1.0.1 and later
+ #define TIMEOUT_RECONNECT_WIFI 10000L
+ #define RESET_IF_CONFIG_TIMEOUT true
+
+ #define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+
+ // Config Timeout 120s (default 60s)
+ #define CONFIG_TIMEOUT 120000L
+
+ #define USE_DYNAMIC_PARAMETERS true
+ // Those above #define's must be placed before #include and
+ //////////////////////////////////////////
+
#if USE_SSL
#include //https://github.com/khoih-prog/Blynk_WM
#else
@@ -82,7 +100,6 @@
#endif
#define USE_LOCAL_SERVER true
- //#define USE_LOCAL_SERVER false
// If local server
#if USE_LOCAL_SERVER
diff --git a/examples/DHT11ESP8266/DHT11ESP8266.ino b/examples/DHT11ESP8266/DHT11ESP8266.ino
index 282d176..16ac6a7 100644
--- a/examples/DHT11ESP8266/DHT11ESP8266.ino
+++ b/examples/DHT11ESP8266/DHT11ESP8266.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -107,6 +108,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(PIN_LED, OUTPUT);
@@ -155,6 +161,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -195,29 +217,25 @@ void setup()
}
#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
-void displayCredentials(void)
+void displayCredentials()
{
- Serial.println("\nYour stored Credentials :");
+ Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -231,5 +249,17 @@ void loop()
}
}
}
-#endif
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
+ displayCredentialsInLoop();
+#endif
}
diff --git a/examples/DHT11ESP8266/defines.h b/examples/DHT11ESP8266/defines.h
index 5197afc..07e41db 100644
--- a/examples/DHT11ESP8266/defines.h
+++ b/examples/DHT11ESP8266/defines.h
@@ -13,7 +13,7 @@
#define defines_h
#ifndef ESP8266
-#error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
+ #error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
#endif
#define BLYNK_PRINT Serial
@@ -34,77 +34,89 @@
//#define USE_SPIFFS true
#if USE_LITTLEFS
-//LittleFS has higher priority
-#define CurrentFileFS "LittleFS"
-#ifdef USE_SPIFFS
-#undef USE_SPIFFS
-#endif
-#define USE_SPIFFS false
+ //LittleFS has higher priority
+ #define CurrentFileFS "LittleFS"
+ #ifdef USE_SPIFFS
+ #undef USE_SPIFFS
+ #endif
+ #define USE_SPIFFS false
#elif USE_SPIFFS
-#define CurrentFileFS "SPIFFS"
+ #define CurrentFileFS "SPIFFS"
#endif
#if !( USE_LITTLEFS || USE_SPIFFS)
-// EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
-#define EEPROM_SIZE (4 * 1024)
-// EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
-#define EEPROM_START 768
+ // EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
+ #define EEPROM_SIZE (4 * 1024)
+ // EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
+ #define EEPROM_START 768
#endif
-// Force some params in Blynk, only valid for library version 1.0.1 and later
-#define TIMEOUT_RECONNECT_WIFI 10000L
-#define RESET_IF_CONFIG_TIMEOUT true
-#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
-
-#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+//////////////////////////////////////////
//You have to download Blynk WiFiManager Blynk_WM library at //https://github.com/khoih-prog/Blynk_WM
// In order to enable (USE_BLYNK_WM = true). Otherwise, use (USE_BLYNK_WM = false)
-#define USE_BLYNK_WM true
-//#define USE_BLYNK_WM false
+#define USE_BLYNK_WM true
-//#define USE_SSL true
-#define USE_SSL false
+#define USE_SSL false
#if USE_BLYNK_WM
-#if USE_SSL
-#include //https://github.com/khoih-prog/Blynk_WM
-#else
-#include //https://github.com/khoih-prog/Blynk_WM
-#endif
-
-#include "Credentials.h"
-#include "dynamicParams.h"
+ /////////////////////////////////////////////
+
+ // Add customs headers from v1.2.0
+ #define USING_CUSTOMS_STYLE true
+ #define USING_CUSTOMS_HEAD_ELEMENT true
+ #define USING_CORS_FEATURE true
+
+ /////////////////////////////////////////////
+
+ // Force some params in Blynk, only valid for library version 1.0.1 and later
+ #define TIMEOUT_RECONNECT_WIFI 10000L
+ #define RESET_IF_CONFIG_TIMEOUT true
+
+ #define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+
+ // Config Timeout 120s (default 60s)
+ #define CONFIG_TIMEOUT 120000L
+
+ #define USE_DYNAMIC_PARAMETERS true
+
+ // Those above #define's must be placed before #include and
+ #if USE_SSL
+ #include //https://github.com/khoih-prog/Blynk_WM
+ #else
+ #include //https://github.com/khoih-prog/Blynk_WM
+ #endif
+
+ #include "Credentials.h"
+ #include "dynamicParams.h"
#else
-#if USE_SSL
-#include
-#define BLYNK_HARDWARE_PORT 9443
-#else
-#include
-#define BLYNK_HARDWARE_PORT 8080
-#endif
+ #if USE_SSL
+ #include
+ #define BLYNK_HARDWARE_PORT 9443
+ #else
+ #include
+ #define BLYNK_HARDWARE_PORT 8080
+ #endif
#endif
#if !USE_BLYNK_WM
-#ifndef LED_BUILTIN
-#define LED_BUILTIN 2 // Pin D2 control on-board LED
-#endif
-
-#define USE_LOCAL_SERVER true
-//#define USE_LOCAL_SERVER false
-
-// If local server
-#if USE_LOCAL_SERVER
-char blynk_server[] = "yourname.duckdns.org";
-#endif
-
-char auth[] = "***";
-char ssid[] = "***";
-char pass[] = "***";
+ #ifndef LED_BUILTIN
+ #define LED_BUILTIN 2 // Pin D2 control on-board LED
+ #endif
+
+ #define USE_LOCAL_SERVER true
+
+ // If local server
+ #if USE_LOCAL_SERVER
+ char blynk_server[] = "yourname.duckdns.org";
+ #endif
+
+ char auth[] = "***";
+ char ssid[] = "***";
+ char pass[] = "***";
#endif
diff --git a/examples/DHT11ESP8266_Debug/DHT11ESP8266_Debug.ino b/examples/DHT11ESP8266_Debug/DHT11ESP8266_Debug.ino
index 650182e..3d27da7 100644
--- a/examples/DHT11ESP8266_Debug/DHT11ESP8266_Debug.ino
+++ b/examples/DHT11ESP8266_Debug/DHT11ESP8266_Debug.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -107,6 +108,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(PIN_LED, OUTPUT);
@@ -120,7 +126,7 @@ void setup()
#if ( USE_LITTLEFS || USE_SPIFFS)
Serial.print(F("\nStarting DHT11ESP8266_Debug using "));
Serial.print(CurrentFileFS);
-#else)
+#else
Serial.print(F("\nStarting DHT11ESP8266_Debug using EEPROM");
#endif
@@ -155,6 +161,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -195,29 +217,25 @@ void setup()
}
#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
-void displayCredentials(void)
+void displayCredentials()
{
- Serial.println("\nYour stored Credentials :");
+ Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -231,5 +249,17 @@ void loop()
}
}
}
-#endif
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
+ displayCredentialsInLoop();
+#endif
}
diff --git a/examples/DHT11ESP8266_Debug/defines.h b/examples/DHT11ESP8266_Debug/defines.h
index 2f546b2..d55c4cc 100644
--- a/examples/DHT11ESP8266_Debug/defines.h
+++ b/examples/DHT11ESP8266_Debug/defines.h
@@ -13,7 +13,7 @@
#define defines_h
#ifndef ESP8266
-#error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
+ #error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
#endif
#define BLYNK_PRINT Serial
@@ -34,77 +34,89 @@
//#define USE_SPIFFS true
#if USE_LITTLEFS
-//LittleFS has higher priority
-#define CurrentFileFS "LittleFS"
-#ifdef USE_SPIFFS
-#undef USE_SPIFFS
-#endif
-#define USE_SPIFFS false
+ //LittleFS has higher priority
+ #define CurrentFileFS "LittleFS"
+ #ifdef USE_SPIFFS
+ #undef USE_SPIFFS
+ #endif
+ #define USE_SPIFFS false
#elif USE_SPIFFS
-#define CurrentFileFS "SPIFFS"
+ #define CurrentFileFS "SPIFFS"
#endif
#if !( USE_LITTLEFS || USE_SPIFFS)
-// EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
-#define EEPROM_SIZE (4 * 1024)
-// EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
-#define EEPROM_START 768
+ // EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
+ #define EEPROM_SIZE (4 * 1024)
+ // EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
+ #define EEPROM_START 768
#endif
-// Force some params in Blynk, only valid for library version 1.0.1 and later
-#define TIMEOUT_RECONNECT_WIFI 10000L
-#define RESET_IF_CONFIG_TIMEOUT true
-#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
-
-#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+//////////////////////////////////////////
//You have to download Blynk WiFiManager Blynk_WM library at //https://github.com/khoih-prog/Blynk_WM
// In order to enable (USE_BLYNK_WM = true). Otherwise, use (USE_BLYNK_WM = false)
-#define USE_BLYNK_WM true
-//#define USE_BLYNK_WM false
+#define USE_BLYNK_WM true
-//#define USE_SSL true
-#define USE_SSL false
+#define USE_SSL false
#if USE_BLYNK_WM
-#if USE_SSL
-#include //https://github.com/khoih-prog/Blynk_WM
-#else
-#include //https://github.com/khoih-prog/Blynk_WM
-#endif
-
-#include "Credentials.h"
-#include "dynamicParams.h"
+ /////////////////////////////////////////////
+
+ // Add customs headers from v1.2.0
+ #define USING_CUSTOMS_STYLE true
+ #define USING_CUSTOMS_HEAD_ELEMENT true
+ #define USING_CORS_FEATURE true
+
+ /////////////////////////////////////////////
+
+ // Force some params in Blynk, only valid for library version 1.0.1 and later
+ #define TIMEOUT_RECONNECT_WIFI 10000L
+ #define RESET_IF_CONFIG_TIMEOUT true
+
+ #define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+
+ // Config Timeout 120s (default 60s)
+ #define CONFIG_TIMEOUT 120000L
+
+ #define USE_DYNAMIC_PARAMETERS true
+ // Those above #define's must be placed before #include and
+
+ #if USE_SSL
+ #include //https://github.com/khoih-prog/Blynk_WM
+ #else
+ #include //https://github.com/khoih-prog/Blynk_WM
+ #endif
+
+ #include "Credentials.h"
+ #include "dynamicParams.h"
#else
-#if USE_SSL
-#include
-#define BLYNK_HARDWARE_PORT 9443
-#else
-#include
-#define BLYNK_HARDWARE_PORT 8080
-#endif
+ #if USE_SSL
+ #include
+ #define BLYNK_HARDWARE_PORT 9443
+ #else
+ #include
+ #define BLYNK_HARDWARE_PORT 8080
+ #endif
#endif
#if !USE_BLYNK_WM
-#ifndef LED_BUILTIN
-#define LED_BUILTIN 2 // Pin D2 control on-board LED
-#endif
-
-#define USE_LOCAL_SERVER true
-//#define USE_LOCAL_SERVER false
-
-// If local server
-#if USE_LOCAL_SERVER
-char blynk_server[] = "yourname.duckdns.org";
-#endif
-
-char auth[] = "***";
-char ssid[] = "***";
-char pass[] = "***";
+ #ifndef LED_BUILTIN
+ #define LED_BUILTIN 2 // Pin D2 control on-board LED
+ #endif
+
+ #define USE_LOCAL_SERVER true
+
+ // If local server
+ #if USE_LOCAL_SERVER
+ char blynk_server[] = "yourname.duckdns.org";
+ #endif
+
+ char auth[] = "***";
+ char ssid[] = "***";
+ char pass[] = "***";
#endif
diff --git a/examples/DHT11ESP8266_SSL/DHT11ESP8266_SSL.ino b/examples/DHT11ESP8266_SSL/DHT11ESP8266_SSL.ino
index 3427e03..318efec 100644
--- a/examples/DHT11ESP8266_SSL/DHT11ESP8266_SSL.ino
+++ b/examples/DHT11ESP8266_SSL/DHT11ESP8266_SSL.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -107,6 +108,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(PIN_LED, OUTPUT);
@@ -154,6 +160,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -194,29 +216,25 @@ void setup()
}
#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
-void displayCredentials(void)
+void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -230,5 +248,17 @@ void loop()
}
}
}
-#endif
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if (USE_BLYNK_WM && USE_DYNAMIC_PARAMETERS)
+ displayCredentialsInLoop();
+#endif
}
diff --git a/examples/DHT11ESP8266_SSL/defines.h b/examples/DHT11ESP8266_SSL/defines.h
index b27fe94..73d4d27 100644
--- a/examples/DHT11ESP8266_SSL/defines.h
+++ b/examples/DHT11ESP8266_SSL/defines.h
@@ -13,7 +13,7 @@
#define defines_h
#ifndef ESP8266
-#error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
+ #error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
#endif
#define BLYNK_PRINT Serial
@@ -29,82 +29,92 @@
// Select USE_LITTLEFS (higher priority) or USE_SPIFFS
#define USE_LITTLEFS true
-//#define USE_LITTLEFS false
#define USE_SPIFFS false
-//#define USE_SPIFFS true
#if USE_LITTLEFS
-//LittleFS has higher priority
-#define CurrentFileFS "LittleFS"
-#ifdef USE_SPIFFS
-#undef USE_SPIFFS
-#endif
-#define USE_SPIFFS false
+ //LittleFS has higher priority
+ #define CurrentFileFS "LittleFS"
+ #ifdef USE_SPIFFS
+ #undef USE_SPIFFS
+ #endif
+ #define USE_SPIFFS false
#elif USE_SPIFFS
-#define CurrentFileFS "SPIFFS"
+ #define CurrentFileFS "SPIFFS"
#endif
#if !( USE_LITTLEFS || USE_SPIFFS)
-// EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
-#define EEPROM_SIZE (4 * 1024)
-// EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
-#define EEPROM_START 0
+ // EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
+ #define EEPROM_SIZE (4 * 1024)
+ // EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
+ #define EEPROM_START 0
#endif
-// Force some params in Blynk, only valid for library version 1.0.1 and later
-#define TIMEOUT_RECONNECT_WIFI 10000L
-#define RESET_IF_CONFIG_TIMEOUT true
-#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
-
-#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+//////////////////////////////////////////
//You have to download Blynk WiFiManager Blynk_WM library at //https://github.com/khoih-prog/Blynk_WM
// In order to enable (USE_BLYNK_WM = true). Otherwise, use (USE_BLYNK_WM = false)
#define USE_BLYNK_WM true
-//#define USE_BLYNK_WM false
#define USE_SSL true
-//#define USE_SSL false
#if USE_BLYNK_WM
-#if USE_SSL
-#include //https://github.com/khoih-prog/Blynk_WM
-#else
-#include //https://github.com/khoih-prog/Blynk_WM
-#endif
-
-#include "Credentials.h"
-#include "dynamicParams.h"
+ /////////////////////////////////////////////
+
+ // Add customs headers from v1.2.0
+ #define USING_CUSTOMS_STYLE true
+ #define USING_CUSTOMS_HEAD_ELEMENT true
+ #define USING_CORS_FEATURE true
+
+ /////////////////////////////////////////////
+
+ // Force some params in Blynk, only valid for library version 1.0.1 and later
+ #define TIMEOUT_RECONNECT_WIFI 10000L
+ #define RESET_IF_CONFIG_TIMEOUT true
+
+ #define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+
+ // Config Timeout 120s (default 60s)
+ #define CONFIG_TIMEOUT 120000L
+
+ #define USE_DYNAMIC_PARAMETERS true
+ // Those above #define's must be placed before #include and
+
+ #if USE_SSL
+ #include //https://github.com/khoih-prog/Blynk_WM
+ #else
+ #include //https://github.com/khoih-prog/Blynk_WM
+ #endif
+
+ #include "Credentials.h"
+ #include "dynamicParams.h"
#else
-#if USE_SSL
-#include
-#define BLYNK_HARDWARE_PORT 9443
-#else
-#include
-#define BLYNK_HARDWARE_PORT 8080
-#endif
+ #if USE_SSL
+ #include
+ #define BLYNK_HARDWARE_PORT 9443
+ #else
+ #include
+ #define BLYNK_HARDWARE_PORT 8080
+ #endif
#endif
#if !USE_BLYNK_WM
-#ifndef LED_BUILTIN
-#define LED_BUILTIN 2 // Pin D2 control on-board LED
-#endif
-
-#define USE_LOCAL_SERVER true
-//#define USE_LOCAL_SERVER false
-
-// If local server
-#if USE_LOCAL_SERVER
-char blynk_server[] = "yourname.duckdns.org";
-#endif
-
-char auth[] = "***";
-char ssid[] = "***";
-char pass[] = "***";
+ #ifndef LED_BUILTIN
+ #define LED_BUILTIN 2 // Pin D2 control on-board LED
+ #endif
+
+ #define USE_LOCAL_SERVER true
+
+ // If local server
+ #if USE_LOCAL_SERVER
+ char blynk_server[] = "yourname.duckdns.org";
+ #endif
+
+ char auth[] = "***";
+ char ssid[] = "***";
+ char pass[] = "***";
#endif
diff --git a/examples/ESP32WM_Config/ESP32WM_Config.ino b/examples/ESP32WM_Config/ESP32WM_Config.ino
index a240d14..b1552de 100644
--- a/examples/ESP32WM_Config/ESP32WM_Config.ino
+++ b/examples/ESP32WM_Config/ESP32WM_Config.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -112,6 +113,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(LED_BUILTIN, OUTPUT);
@@ -156,6 +162,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -185,25 +207,21 @@ void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if USE_DYNAMIC_PARAMETERS
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -217,5 +235,17 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if USE_DYNAMIC_PARAMETERS
+ displayCredentialsInLoop();
#endif
}
diff --git a/examples/ESP32WM_Config/defines.h b/examples/ESP32WM_Config/defines.h
index 8fc2f98..28fdd30 100644
--- a/examples/ESP32WM_Config/defines.h
+++ b/examples/ESP32WM_Config/defines.h
@@ -25,8 +25,15 @@
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
-#define USE_LITTLEFS true
-#define USE_SPIFFS false
+#if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+#else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+#endif
#if !( USE_SPIFFS || USE_LITTLEFS)
@@ -36,13 +43,27 @@
#define EEPROM_START 0
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
+
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
-#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
+#define USE_DYNAMIC_PARAMETERS true
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
//#define USE_SSL true
#define USE_SSL false
diff --git a/examples/ESP32WM_ForcedConfig/ESP32WM_ForcedConfig.ino b/examples/ESP32WM_ForcedConfig/ESP32WM_ForcedConfig.ino
index 9a11aaa..7a1abce 100644
--- a/examples/ESP32WM_ForcedConfig/ESP32WM_ForcedConfig.ino
+++ b/examples/ESP32WM_ForcedConfig/ESP32WM_ForcedConfig.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -145,6 +146,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(LED_BUILTIN, OUTPUT);
@@ -189,6 +195,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -218,25 +240,21 @@ void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if USE_DYNAMIC_PARAMETERS
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -250,5 +268,17 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if USE_DYNAMIC_PARAMETERS
+ displayCredentialsInLoop();
#endif
}
diff --git a/examples/ESP32WM_ForcedConfig/defines.h b/examples/ESP32WM_ForcedConfig/defines.h
index 672a348..ad67495 100644
--- a/examples/ESP32WM_ForcedConfig/defines.h
+++ b/examples/ESP32WM_ForcedConfig/defines.h
@@ -26,8 +26,15 @@
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
-#define USE_LITTLEFS true
-#define USE_SPIFFS false
+#if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+#else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+#endif
#if !( USE_SPIFFS || USE_LITTLEFS)
@@ -37,16 +44,29 @@
#define EEPROM_START 0
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
+
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
#define USE_SSL true
-//#define USE_SSL false
#if USE_SSL
#include
diff --git a/examples/ESP32WM_MRD_Config/ESP32WM_MRD_Config.ino b/examples/ESP32WM_MRD_Config/ESP32WM_MRD_Config.ino
index 53339d0..3fedf8b 100644
--- a/examples/ESP32WM_MRD_Config/ESP32WM_MRD_Config.ino
+++ b/examples/ESP32WM_MRD_Config/ESP32WM_MRD_Config.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -112,6 +113,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(LED_BUILTIN, OUTPUT);
@@ -161,6 +167,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
diff --git a/examples/ESP32WM_MRD_Config/defines.h b/examples/ESP32WM_MRD_Config/defines.h
index c6576f5..0ccc5db 100644
--- a/examples/ESP32WM_MRD_Config/defines.h
+++ b/examples/ESP32WM_MRD_Config/defines.h
@@ -60,8 +60,15 @@
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
-#define USE_LITTLEFS true
-#define USE_SPIFFS false
+#if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+#else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+#endif
#if !( USE_SPIFFS || USE_LITTLEFS)
// EEPROM_SIZE must be <= 2048 and >= CONFIG_DATA_SIZE (currently 172 bytes)
@@ -70,22 +77,35 @@
#define EEPROM_START 0
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
-//#define USE_SSL true
-#define USE_SSL false
+#define USE_SSL true
+//#define USE_SSL false
#if USE_SSL
-#include
+ #include
#else
-#include
+ #include
#endif
#define PIN_D22 22 // Pin D22 mapped to pin GPIO22/SCL of ESP32
diff --git a/examples/ESP32WM_MRD_ForcedConfig/ESP32WM_MRD_ForcedConfig.ino b/examples/ESP32WM_MRD_ForcedConfig/ESP32WM_MRD_ForcedConfig.ino
index 38dd877..2b8a28d 100644
--- a/examples/ESP32WM_MRD_ForcedConfig/ESP32WM_MRD_ForcedConfig.ino
+++ b/examples/ESP32WM_MRD_ForcedConfig/ESP32WM_MRD_ForcedConfig.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -145,6 +146,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(LED_BUILTIN, OUTPUT);
@@ -194,6 +200,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -223,25 +245,21 @@ void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if USE_DYNAMIC_PARAMETERS
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -255,5 +273,17 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if USE_DYNAMIC_PARAMETERS
+ displayCredentialsInLoop();
#endif
}
diff --git a/examples/ESP32WM_MRD_ForcedConfig/defines.h b/examples/ESP32WM_MRD_ForcedConfig/defines.h
index 1ba4920..0ccc5db 100644
--- a/examples/ESP32WM_MRD_ForcedConfig/defines.h
+++ b/examples/ESP32WM_MRD_ForcedConfig/defines.h
@@ -60,8 +60,15 @@
// (USE_LITTLEFS == false) and (USE_SPIFFS == true) => using SPIFFS for configuration data in WiFiManager
// Those above #define's must be placed before #include
-#define USE_LITTLEFS true
-#define USE_SPIFFS false
+#if ( ARDUINO_ESP32S2_DEV || ARDUINO_FEATHERS2 || ARDUINO_PROS2 || ARDUINO_MICROS2 )
+ // Currently, ESP32-S2 only supporting EEPROM. Will fix to support LittleFS and SPIFFS
+ #define USE_LITTLEFS false
+ #define USE_SPIFFS false
+ #warning ESP32-S2 only support supporting EEPROM now.
+#else
+ #define USE_LITTLEFS true
+ #define USE_SPIFFS false
+#endif
#if !( USE_SPIFFS || USE_LITTLEFS)
// EEPROM_SIZE must be <= 2048 and >= CONFIG_DATA_SIZE (currently 172 bytes)
@@ -70,22 +77,35 @@
#define EEPROM_START 0
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
#define USE_SSL true
//#define USE_SSL false
#if USE_SSL
-#include
+ #include
#else
-#include
+ #include
#endif
#define PIN_D22 22 // Pin D22 mapped to pin GPIO22/SCL of ESP32
diff --git a/examples/ESP8266WM_Config/ESP8266WM_Config.ino b/examples/ESP8266WM_Config/ESP8266WM_Config.ino
index c60244c..4761ff6 100644
--- a/examples/ESP8266WM_Config/ESP8266WM_Config.ino
+++ b/examples/ESP8266WM_Config/ESP8266WM_Config.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -115,6 +116,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(PIN_LED, OUTPUT);
@@ -158,6 +164,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -184,29 +206,25 @@ void setup()
}
#if USE_DYNAMIC_PARAMETERS
-void displayCredentials(void)
+void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if USE_DYNAMIC_PARAMETERS
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -220,5 +238,17 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if USE_DYNAMIC_PARAMETERS
+ displayCredentialsInLoop();
#endif
}
diff --git a/examples/ESP8266WM_Config/defines.h b/examples/ESP8266WM_Config/defines.h
index 3e593a8..809d478 100644
--- a/examples/ESP8266WM_Config/defines.h
+++ b/examples/ESP8266WM_Config/defines.h
@@ -29,9 +29,7 @@
// Select USE_LITTLEFS (higher priority) or USE_SPIFFS
#define USE_LITTLEFS true
-//#define USE_LITTLEFS false
#define USE_SPIFFS false
-//#define USE_SPIFFS true
#if USE_LITTLEFS
//LittleFS has higher priority
@@ -52,15 +50,28 @@
#define EEPROM_START 768
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
+
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
-//#define USE_SSL true
#define USE_SSL false
#if USE_SSL
diff --git a/examples/ESP8266WM_ForcedConfig/ESP8266WM_ForcedConfig.ino b/examples/ESP8266WM_ForcedConfig/ESP8266WM_ForcedConfig.ino
index a3f8993..fda1a3f 100644
--- a/examples/ESP8266WM_ForcedConfig/ESP8266WM_ForcedConfig.ino
+++ b/examples/ESP8266WM_ForcedConfig/ESP8266WM_ForcedConfig.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
*****************************************************************************************************************************/
#include "defines.h"
@@ -148,6 +149,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(PIN_LED, OUTPUT);
@@ -191,6 +197,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -217,29 +239,25 @@ void setup()
}
#if USE_DYNAMIC_PARAMETERS
-void displayCredentials(void)
+void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if USE_DYNAMIC_PARAMETERS
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -253,5 +271,17 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if USE_DYNAMIC_PARAMETERS
+ displayCredentialsInLoop();
#endif
}
diff --git a/examples/ESP8266WM_ForcedConfig/defines.h b/examples/ESP8266WM_ForcedConfig/defines.h
index cb7352b..b79b33d 100644
--- a/examples/ESP8266WM_ForcedConfig/defines.h
+++ b/examples/ESP8266WM_ForcedConfig/defines.h
@@ -13,7 +13,7 @@
#define defines_h
#ifndef ESP8266
-#error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
+ #error This code is intended to run on the ESP8266 platform! Please check your Tools->Board setting.
#endif
#define BLYNK_PRINT Serial
@@ -29,44 +29,56 @@
// Select USE_LITTLEFS (higher priority) or USE_SPIFFS
#define USE_LITTLEFS true
-//#define USE_LITTLEFS false
#define USE_SPIFFS false
-//#define USE_SPIFFS true
#if USE_LITTLEFS
-//LittleFS has higher priority
-#define CurrentFileFS "LittleFS"
-#ifdef USE_SPIFFS
-#undef USE_SPIFFS
-#endif
-#define USE_SPIFFS false
+ //LittleFS has higher priority
+ #define CurrentFileFS "LittleFS"
+ #ifdef USE_SPIFFS
+ #undef USE_SPIFFS
+ #endif
+ #define USE_SPIFFS false
#elif USE_SPIFFS
-#define CurrentFileFS "SPIFFS"
+ #define CurrentFileFS "SPIFFS"
#endif
#if !( USE_LITTLEFS || USE_SPIFFS)
-// EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
-#define EEPROM_SIZE (4 * 1024)
-// EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
-#define EEPROM_START 768
+ // EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
+ #define EEPROM_SIZE (4 * 1024)
+ // EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
+ #define EEPROM_START 768
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
+
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
-#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
+#define USE_DYNAMIC_PARAMETERS true
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
//#define USE_SSL true
#define USE_SSL false
#if USE_SSL
-#include
+ #include
#else
-#include
+ #include
#endif
#define PIN_LED 2 // Pin D4 mapped to pin GPIO2/TXD1 of ESP8266, NodeMCU and WeMoS, control on-board LED
diff --git a/examples/ESP8266WM_MRD_Config/ESP8266WM_MRD_Config.ino b/examples/ESP8266WM_MRD_Config/ESP8266WM_MRD_Config.ino
index c9df984..ec0c172 100644
--- a/examples/ESP8266WM_MRD_Config/ESP8266WM_MRD_Config.ino
+++ b/examples/ESP8266WM_MRD_Config/ESP8266WM_MRD_Config.ino
@@ -7,7 +7,7 @@
Forked from Blynk library v0.6.1 https://github.com/blynkkk/blynk-library/releases
Built by Khoi Hoang https://github.com/khoih-prog/Blynk_WM
Licensed under MIT license
- Version: 1.1.3
+ Version: 1.2.0
Version Modified By Date Comments
------- ----------- ---------- -----------
@@ -32,6 +32,7 @@
1.1.1 K Hoang 16/01/2021 Add functions to control Config Portal from software or Virtual Switches
1.1.2 K Hoang 28/01/2021 Fix Config Portal and Dynamic Params bugs
1.1.3 K Hoang 31/01/2021 To permit autoreset after timeout if DRD/MRD or non-persistent forced-CP
+ 1.2.0 K Hoang 24/02/2021 Add customs HTML header feature and support to ESP32-S2.
********************************************************************************************************************************/
#include "defines.h"
@@ -115,6 +116,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(PIN_LED, OUTPUT);
@@ -163,6 +169,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
@@ -193,25 +215,21 @@ void displayCredentials()
{
Serial.println(F("\nYour stored Credentials :"));
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
- Serial.println(String(myMenuItems[i].displayName) + " = " + myMenuItems[i].pdata);
+ Serial.print(myMenuItems[i].displayName);
+ Serial.print(F(" = "));
+ Serial.println(myMenuItems[i].pdata);
}
}
-#endif
-void loop()
+void displayCredentialsInLoop()
{
- Blynk.run();
- timer.run();
- check_status();
-
-#if USE_DYNAMIC_PARAMETERS
static bool displayedCredentials = false;
if (!displayedCredentials)
{
- for (int i = 0; i < NUM_MENU_ITEMS; i++)
+ for (uint16_t i = 0; i < NUM_MENU_ITEMS; i++)
{
if (!strlen(myMenuItems[i].pdata))
{
@@ -225,5 +243,17 @@ void loop()
}
}
}
+}
+
+#endif
+
+void loop()
+{
+ Blynk.run();
+ timer.run();
+ check_status();
+
+#if USE_DYNAMIC_PARAMETERS
+ displayCredentialsInLoop();
#endif
}
diff --git a/examples/ESP8266WM_MRD_Config/defines.h b/examples/ESP8266WM_MRD_Config/defines.h
index 5261d1a..add7de4 100644
--- a/examples/ESP8266WM_MRD_Config/defines.h
+++ b/examples/ESP8266WM_MRD_Config/defines.h
@@ -61,44 +61,56 @@
// Select USE_LITTLEFS (higher priority) or USE_SPIFFS
#define USE_LITTLEFS true
-//#define USE_LITTLEFS false
#define USE_SPIFFS false
-//#define USE_SPIFFS true
#if USE_LITTLEFS
-//LittleFS has higher priority
-#define CurrentFileFS "LittleFS"
-#ifdef USE_SPIFFS
-#undef USE_SPIFFS
-#endif
-#define USE_SPIFFS false
+ //LittleFS has higher priority
+ #define CurrentFileFS "LittleFS"
+ #ifdef USE_SPIFFS
+ #undef USE_SPIFFS
+ #endif
+ #define USE_SPIFFS false
#elif USE_SPIFFS
-#define CurrentFileFS "SPIFFS"
+ #define CurrentFileFS "SPIFFS"
#endif
#if !( USE_LITTLEFS || USE_SPIFFS)
-// EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
-#define EEPROM_SIZE (4 * 1024)
-// EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
-#define EEPROM_START 768
+ // EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
+ #define EEPROM_SIZE (4 * 1024)
+ // EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
+ #define EEPROM_START 768
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
+
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
//#define USE_SSL true
#define USE_SSL false
#if USE_SSL
-#include
+ #include
#else
-#include
+ #include
#endif
#define PIN_LED 2 // Pin D4 mapped to pin GPIO2/TXD1 of ESP8266, NodeMCU and WeMoS, control on-board LED
diff --git a/examples/ESP8266WM_MRD_ForcedConfig/ESP8266WM_MRD_ForcedConfig.ino b/examples/ESP8266WM_MRD_ForcedConfig/ESP8266WM_MRD_ForcedConfig.ino
index 223cb7d..7abd1e1 100644
--- a/examples/ESP8266WM_MRD_ForcedConfig/ESP8266WM_MRD_ForcedConfig.ino
+++ b/examples/ESP8266WM_MRD_ForcedConfig/ESP8266WM_MRD_ForcedConfig.ino
@@ -148,6 +148,11 @@ void check_status()
}
}
+#if USING_CUSTOMS_STYLE
+const char NewCustomsStyle[] /*PROGMEM*/ = "";
+#endif
+
void setup()
{
pinMode(PIN_LED, OUTPUT);
@@ -196,6 +201,22 @@ void setup()
//Blynk.setSTAStaticIPConfig(IPAddress(192, 168, 2, 220), IPAddress(192, 168, 2, 1), IPAddress(255, 255, 255, 0),
// IPAddress(4, 4, 4, 4), IPAddress(8, 8, 8, 8));
+//////////////////////////////////////////////
+
+#if USING_CUSTOMS_STYLE
+ Blynk.setCustomsStyle(NewCustomsStyle);
+#endif
+
+#if USING_CUSTOMS_HEAD_ELEMENT
+ Blynk.setCustomsHeadElement("");
+#endif
+
+#if USING_CORS_FEATURE
+ Blynk.setCORSHeader("Your Access-Control-Allow-Origin");
+#endif
+
+ //////////////////////////////////////////////
+
// Use this to default DHCP hostname to ESP8266-XXXXXX or ESP32-XXXXXX
//Blynk.begin();
// Use this to personalize DHCP hostname (RFC952 conformed)
diff --git a/examples/ESP8266WM_MRD_ForcedConfig/defines.h b/examples/ESP8266WM_MRD_ForcedConfig/defines.h
index 5261d1a..27507cb 100644
--- a/examples/ESP8266WM_MRD_ForcedConfig/defines.h
+++ b/examples/ESP8266WM_MRD_ForcedConfig/defines.h
@@ -61,44 +61,56 @@
// Select USE_LITTLEFS (higher priority) or USE_SPIFFS
#define USE_LITTLEFS true
-//#define USE_LITTLEFS false
#define USE_SPIFFS false
-//#define USE_SPIFFS true
#if USE_LITTLEFS
-//LittleFS has higher priority
-#define CurrentFileFS "LittleFS"
-#ifdef USE_SPIFFS
-#undef USE_SPIFFS
-#endif
-#define USE_SPIFFS false
+ //LittleFS has higher priority
+ #define CurrentFileFS "LittleFS"
+ #ifdef USE_SPIFFS
+ #undef USE_SPIFFS
+ #endif
+ #define USE_SPIFFS false
#elif USE_SPIFFS
-#define CurrentFileFS "SPIFFS"
+ #define CurrentFileFS "SPIFFS"
#endif
#if !( USE_LITTLEFS || USE_SPIFFS)
-// EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
-#define EEPROM_SIZE (4 * 1024)
-// EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
-#define EEPROM_START 768
+ // EEPROM_SIZE must be <= 4096 and >= CONFIG_DATA_SIZE (currently 172 bytes)
+ #define EEPROM_SIZE (4 * 1024)
+ // EEPROM_START + CONFIG_DATA_SIZE must be <= EEPROM_SIZE
+ #define EEPROM_START 768
#endif
+/////////////////////////////////////////////
+
+// Add customs headers from v1.2.0
+#define USING_CUSTOMS_STYLE true
+#define USING_CUSTOMS_HEAD_ELEMENT true
+#define USING_CORS_FEATURE true
+
+/////////////////////////////////////////////
+
// Force some params in Blynk, only valid for library version 1.0.1 and later
#define TIMEOUT_RECONNECT_WIFI 10000L
#define RESET_IF_CONFIG_TIMEOUT true
+
#define CONFIG_TIMEOUT_RETRYTIMES_BEFORE_RESET 5
+// Config Timeout 120s (default 60s)
+#define CONFIG_TIMEOUT 120000L
+
#define USE_DYNAMIC_PARAMETERS true
-// Those above #define's must be placed before #include
+// Those above #define's must be placed before #include and
+//////////////////////////////////////////
-//#define USE_SSL true
-#define USE_SSL false
+#define USE_SSL true
+//#define USE_SSL false
#if USE_SSL
-#include
+ #include
#else
-#include
+ #include
#endif
#define PIN_LED 2 // Pin D4 mapped to pin GPIO2/TXD1 of ESP8266, NodeMCU and WeMoS, control on-board LED
diff --git a/keywords.txt b/keywords.txt
index a09536e..a174884 100644
--- a/keywords.txt
+++ b/keywords.txt
@@ -1,6 +1,7 @@
#######################################
# Data types (KEYWORD1)
#######################################
+
Blynk KEYWORD1
BlynkTimer KEYWORD1
WidgetBridge KEYWORD1
@@ -21,6 +22,7 @@ Blynk_WM_Configuration KEYWORD1
#######################################
# Methods and Functions (KEYWORD2)
#######################################
+
begin KEYWORD2
config KEYWORD2
run KEYWORD2
@@ -57,8 +59,17 @@ getFullConfigData KEYWORD2
clearConfigData KEYWORD2
resetAndEnterConfigPortal KEYWORD2
resetAndEnterConfigPortalPersistent KEYWORD2
+setCustomsStyle KEYWORD2
+getCustomsStyle KEYWORD2
+setCustomsHeadElement KEYWORD2
+getCustomsHeadElement KEYWORD2
+setCORSHeader KEYWORD2
+getCORSHeader KEYWORD2
+
+#############################
+# Handler helpers (KEYWORD2)
+#############################
-# Handler helpers
BLYNK_READ KEYWORD2
BLYNK_WRITE KEYWORD2
BLYNK_READ_DEFAULT KEYWORD2
@@ -74,13 +85,19 @@ BLYNK_INPUT KEYWORD2
BLYNK_OUTPUT_DEFAULT KEYWORD2
BLYNK_INPUT_DEFAULT KEYWORD2
-# Variables binding
+###############################
+# Variables binding (KEYWORD2)
+###############################
+
BLYNK_VAR_INT KEYWORD2
BLYNK_VAR_LONG KEYWORD2
BLYNK_VAR_DOUBLE KEYWORD2
BLYNK_VAR_STRING KEYWORD2
-# Special defines
+###############################
+# Special defines (KEYWORD2)
+###############################
+
BLYNK_DEBUG KEYWORD2
BLYNK_DEBUG_ALL KEYWORD2
BLYNK_PRINT KEYWORD2
@@ -95,7 +112,9 @@ BLYNK_USE_DIRECT_CONNECT KEYWORD2
BLYNK_MAX_SENDBYTES KEYWORD2
BLYNK_MAX_READBYTES KEYWORD2
-# Periodic actions
+###############################
+# Periodic actions (KEYWORD2)
+###############################
#BLYNK_EVERY_N_MILLIS KEYWORD2
#BLYNK_EVERY_N_SECONDS KEYWORD2
#BLYNK_EVERY_N_MINUTES KEYWORD2
diff --git a/library.json b/library.json
index d08a9d2..ebb18b7 100644
--- a/library.json
+++ b/library.json
@@ -1,8 +1,8 @@
{
"name": "Blynk_WM",
- "version": "1.1.3",
- "description": "Library for configuring/auto(re)connecting ESP8266/ESP32 modules to best or available MultiWiFi APs and MultiBlynk servers at runtime. Enable adding dynamic custom parameters from sketch and input using the same Config Portal. Config Portal will be auto-adjusted to match the number of dynamic parameters. Optional default Credentials to be autoloaded into Config Portal to use or change instead of manually input. Static STA IP and DHCP Hostname as well as Config Portal AP channel, IP, SSID, Password can be configured. Multi, Double DetectDetector or Virtual ConfigPortal Switch feature permits entering Config Portal as requested.",
- "keywords": "sensors, control, device, smartphone, mobile, app, web, cloud, communication, protocol, iot, m2m, wifi, ble, bluetooth, ethernet, usb, serial, gsm, gprs, 3g, data, esp8266, esp32, http, drd, mrd, double-reset, multi-reset, configportal, portal, credentials",
+ "version": "1.2.0",
+ "description": "Library for configuring/auto(re)connecting ESP32 (including ESP32-S2), ESP8266 modules to best or available MultiWiFi APs and MultiBlynk servers at runtime. Enable adding dynamic custom parameters from sketch and input using the same Config Portal (CP). CP will be auto-adjusted to match the number of dynamic parameters. Optional default Credentials to be autoloaded into CP to use or change instead of manually input. Static STA IP and DHCP Hostname as well as Config Portal AP channel, IP, SSID, Password can be configured. Config. Data saved in ESP8266/ESP32 LittleFS, SPIFFS or EEPROM. Multi, Double DetectDetector or Virtual CP Switch feature permits entering CP as requested. Configurable Customs HTML Headers, including Customs Style, Customs Head Elements, CORS Header.",
+ "keywords": "sensors, control, device, smartphone, mobile, app, web, cloud, communication, protocol, iot, m2m, wifi, ble, bluetooth, ethernet, usb, serial, gsm, gprs, 3g, data, esp8266, esp32, esp32-s2, http, drd, mrd, double-reset, multi-reset, configportal, config-portal, portal, credentials, Manager, DynamicParameters, dynamic-params, dynamic, customs-header",
"authors":
{
"name": "Khoi Hoang",
diff --git a/library.properties b/library.properties
index b2fd21d..a3bec29 100644
--- a/library.properties
+++ b/library.properties
@@ -1,10 +1,10 @@
name=Blynk_WiFiManager
-version=1.1.3
+version=1.2.0
author=Khoi Hoang
license=MIT
maintainer=Khoi Hoang
-sentence=Simple WiFiManager for Blynk and ESP8266/ESP32 with or without SSL, configuration data saved in either LittleFS, SPIFFS or EEPROM
-paragraph=Library for configuring/auto(re)connecting ESP8266/ESP32 modules to best or available MultiWiFi APs and MultiBlynk servers at runtime. Enable adding dynamic custom parameters from sketch and input using the same Config Portal. Config Portal will be auto-adjusted to match the number of dynamic parameters. Optional default Credentials to be autoloaded into Config Portal to use or change instead of manually input. Static STA IP and DHCP Hostname as well as Config Portal AP channel, IP, SSID, Password can be configured. Multi, Double DetectDetector or Virtual ConfigPortal Switch feature permits entering Config Portal as requested.
+sentence=Simple WiFiManager for Blynk and ESP32 (including ESP32-S2), ESP8266 with or without SSL, configuration data saved in either LittleFS, SPIFFS or EEPROM
+paragraph=Library for configuring/auto(re)connecting ESP32 (including ESP32-S2), ESP8266 modules to best or available MultiWiFi APs and MultiBlynk servers at runtime. Enable adding dynamic custom parameters from sketch and input using the same Config Portal. Config Portal will be auto-adjusted to match the number of dynamic parameters. Optional default Credentials to be autoloaded into Config Portal to use or change instead of manually input. Static STA IP and DHCP Hostname as well as Config Portal AP channel, IP, SSID, Password can be configured. Multi, Double DetectDetector or Virtual ConfigPortal Switch feature permits entering Config Portal as requested. Configurable Customs HTML Headers, including Customs Style, Customs Head Elements, CORS Header.
category=Communication
url=https://github.com/khoih-prog/Blynk_WM
architectures=esp8266,esp32
diff --git a/pics/esp32_s2_Core_Unzipped.png b/pics/esp32_s2_Core_Unzipped.png
new file mode 100644
index 0000000000000000000000000000000000000000..76286a20ed5d904cfefaa4e97ff5d6294cfdd67d
GIT binary patch
literal 45169
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