Update to version 3.7.4
This commit is contained in:
parent
b12c714d5e
commit
7757b92aeb
@ -38,7 +38,7 @@ It is also deployed in these registries:
|
||||
|
||||
- Arduino Library Registry: [https://github.com/arduino/library-registry](https://github.com/arduino/library-registry)
|
||||
|
||||
- ESP Component Registry [https://components.espressif.com/components/esp32async/espasyncbebserver/](https://components.espressif.com/components/esp32async/espasyncbebserver/)
|
||||
- ESP Component Registry [https://components.espressif.com/components/esp32async/espasyncwebserver](https://components.espressif.com/components/esp32async/espasyncwebserver)
|
||||
|
||||
- PlatformIO Registry: [https://registry.platformio.org/libraries/esp32async/ESPAsyncWebServer](https://registry.platformio.org/libraries/esp32async/ESPAsyncWebServer)
|
||||
|
||||
@ -100,7 +100,7 @@ platform = https://github.com/maxgerhardt/platform-raspberrypi.git
|
||||
board = rpipicow
|
||||
board_build.core = earlephilhower
|
||||
lib_deps =
|
||||
ayushsharma82/RPAsyncTCP@^1.3.1
|
||||
ayushsharma82/RPAsyncTCP@^1.3.2
|
||||
ESP32Async/ESPAsyncWebServer
|
||||
lib_ignore =
|
||||
lwIP_ESPHost
|
||||
|
66
examples/ServerState/ServerState.ino
Normal file
66
examples/ServerState/ServerState.ino
Normal file
@ -0,0 +1,66 @@
|
||||
// SPDX-License-Identifier: LGPL-3.0-or-later
|
||||
// Copyright 2016-2025 Hristo Gochkov, Mathieu Carbou, Emil Muratov
|
||||
|
||||
//
|
||||
// Server state example
|
||||
//
|
||||
|
||||
#include <Arduino.h>
|
||||
#ifdef ESP32
|
||||
#include <AsyncTCP.h>
|
||||
#include <WiFi.h>
|
||||
#elif defined(ESP8266)
|
||||
#include <ESP8266WiFi.h>
|
||||
#include <ESPAsyncTCP.h>
|
||||
#elif defined(TARGET_RP2040) || defined(TARGET_RP2350) || defined(PICO_RP2040) || defined(PICO_RP2350)
|
||||
#include <RPAsyncTCP.h>
|
||||
#include <WiFi.h>
|
||||
#endif
|
||||
|
||||
#include <ESPAsyncWebServer.h>
|
||||
|
||||
static AsyncWebServer server1(80);
|
||||
static AsyncWebServer server2(80);
|
||||
|
||||
void setup() {
|
||||
Serial.begin(115200);
|
||||
|
||||
#ifndef CONFIG_IDF_TARGET_ESP32H2
|
||||
WiFi.mode(WIFI_AP);
|
||||
WiFi.softAP("esp-captive");
|
||||
#endif
|
||||
|
||||
// server state returns one of the tcp_state enum values:
|
||||
// enum tcp_state {
|
||||
// CLOSED = 0,
|
||||
// LISTEN = 1,
|
||||
// SYN_SENT = 2,
|
||||
// SYN_RCVD = 3,
|
||||
// ESTABLISHED = 4,
|
||||
// FIN_WAIT_1 = 5,
|
||||
// FIN_WAIT_2 = 6,
|
||||
// CLOSE_WAIT = 7,
|
||||
// CLOSING = 8,
|
||||
// LAST_ACK = 9,
|
||||
// TIME_WAIT = 10
|
||||
// };
|
||||
|
||||
assert(server1.state() == tcp_state::CLOSED);
|
||||
assert(server2.state() == tcp_state::CLOSED);
|
||||
|
||||
server1.begin();
|
||||
|
||||
assert(server1.state() == tcp_state::LISTEN);
|
||||
assert(server2.state() == tcp_state::CLOSED);
|
||||
|
||||
server2.begin();
|
||||
|
||||
assert(server1.state() == tcp_state::LISTEN);
|
||||
assert(server2.state() == tcp_state::CLOSED);
|
||||
|
||||
Serial.println("Done!");
|
||||
}
|
||||
|
||||
void loop() {
|
||||
delay(100);
|
||||
}
|
@ -105,6 +105,22 @@ void setup() {
|
||||
f.close();
|
||||
}
|
||||
|
||||
LittleFS.mkdir("/files");
|
||||
|
||||
{
|
||||
File f = LittleFS.open("/files/a.txt", "w");
|
||||
assert(f);
|
||||
f.print("Hello from a.txt");
|
||||
f.close();
|
||||
}
|
||||
|
||||
{
|
||||
File f = LittleFS.open("/files/b.txt", "w");
|
||||
assert(f);
|
||||
f.print("Hello from b.txt");
|
||||
f.close();
|
||||
}
|
||||
|
||||
// curl -v http://192.168.4.1/
|
||||
server.on("/", HTTP_GET, [](AsyncWebServerRequest *request) {
|
||||
request->redirect("/index.html");
|
||||
@ -113,6 +129,12 @@ void setup() {
|
||||
// curl -v http://192.168.4.1/index.html
|
||||
server.serveStatic("/index.html", LittleFS, "/index.html");
|
||||
|
||||
// Example to serve a directory content
|
||||
// curl -v http://192.168.4.1/base/ => serves a.txt
|
||||
// curl -v http://192.168.4.1/base/a.txt => serves a.txt
|
||||
// curl -v http://192.168.4.1/base/b.txt => serves b.txt
|
||||
server.serveStatic("/base", LittleFS, "/files").setDefaultFile("a.txt");
|
||||
|
||||
server.begin();
|
||||
}
|
||||
|
||||
|
@ -26,7 +26,7 @@ files:
|
||||
- "pre-commit.requirements.txt"
|
||||
dependencies:
|
||||
esp32async/asynctcp:
|
||||
version: "^3.3.6"
|
||||
version: "^3.3.8"
|
||||
require: public
|
||||
bblanchon/arduinojson:
|
||||
version: "^7.3.1"
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "ESPAsyncWebServer",
|
||||
"version": "3.7.2",
|
||||
"version": "3.7.4",
|
||||
"description": "Asynchronous HTTP and WebSocket Server Library for ESP32, ESP8266 and RP2040. Supports: WebSocket, SSE, Authentication, Arduino Json 7, File Upload, Static File serving, URL Rewrite, URL Redirect, etc.",
|
||||
"keywords": "http,async,websocket,webserver",
|
||||
"homepage": "https://github.com/ESP32Async/ESPAsyncWebServer",
|
||||
@ -24,7 +24,7 @@
|
||||
{
|
||||
"owner": "ESP32Async",
|
||||
"name": "AsyncTCP",
|
||||
"version": "^3.3.6",
|
||||
"version": "^3.3.8",
|
||||
"platforms": "espressif32"
|
||||
},
|
||||
{
|
||||
@ -40,7 +40,7 @@
|
||||
{
|
||||
"owner": "ayushsharma82",
|
||||
"name": "RPAsyncTCP",
|
||||
"version": "^1.3.1",
|
||||
"version": "^1.3.2",
|
||||
"platforms": "raspberrypi"
|
||||
}
|
||||
],
|
||||
|
@ -1,6 +1,6 @@
|
||||
name=ESP Async WebServer
|
||||
includes=ESPAsyncWebServer.h
|
||||
version=3.7.2
|
||||
version=3.7.4
|
||||
author=ESP32Async
|
||||
maintainer=ESP32Async
|
||||
sentence=Asynchronous HTTP and WebSocket Server Library for ESP32, ESP8266 and RP2040
|
||||
|
@ -17,7 +17,7 @@ monitor_filters = esp32_exception_decoder, log2file
|
||||
lib_compat_mode = strict
|
||||
lib_ldf_mode = chain
|
||||
lib_deps =
|
||||
ESP32Async/AsyncTCP @ 3.3.6
|
||||
ESP32Async/AsyncTCP @ 3.3.8
|
||||
ESP32Async/ESpAsyncWebServer @ 3.7.0
|
||||
|
||||
custom_sdkconfig = CONFIG_LWIP_MAX_ACTIVE_TCP=32
|
||||
|
@ -25,6 +25,7 @@ src_dir = examples/PerfTests
|
||||
; src_dir = examples/ResumableDownload
|
||||
; src_dir = examples/Rewrite
|
||||
; src_dir = examples/ServerSentEvents
|
||||
; src_dir = examples/ServerState
|
||||
; src_dir = examples/SkipServerMiddleware
|
||||
; src_dir = examples/SlowChunkResponse
|
||||
; src_dir = examples/StaticFile
|
||||
@ -55,7 +56,7 @@ lib_compat_mode = strict
|
||||
lib_ldf_mode = chain
|
||||
lib_deps =
|
||||
bblanchon/ArduinoJson @ 7.3.1
|
||||
ESP32Async/AsyncTCP @ 3.3.6
|
||||
ESP32Async/AsyncTCP @ 3.3.8
|
||||
board_build.partitions = partitions-4MB.csv
|
||||
board_build.filesystem = littlefs
|
||||
|
||||
@ -69,7 +70,7 @@ platform = https://github.com/pioarduino/platform-espressif32/releases/download/
|
||||
|
||||
[env:arduino-3-no-json]
|
||||
lib_deps =
|
||||
ESP32Async/AsyncTCP @ 3.3.6
|
||||
ESP32Async/AsyncTCP @ 3.3.8
|
||||
|
||||
[env:arduino-3-latest-asynctcp]
|
||||
lib_deps =
|
||||
@ -98,7 +99,7 @@ board = rpipicow
|
||||
board_build.core = earlephilhower
|
||||
lib_deps =
|
||||
bblanchon/ArduinoJson @ 7.3.0
|
||||
ayushsharma82/RPAsyncTCP@^1.3.1
|
||||
ayushsharma82/RPAsyncTCP@^1.3.2
|
||||
lib_ignore =
|
||||
lwIP_ESPHost
|
||||
build_flags = ${env.build_flags}
|
||||
@ -120,7 +121,7 @@ board = ${sysenv.PIO_BOARD}
|
||||
[env:ci-arduino-3-no-json]
|
||||
board = ${sysenv.PIO_BOARD}
|
||||
lib_deps =
|
||||
ESP32Async/AsyncTCP @ 3.3.6
|
||||
ESP32Async/AsyncTCP @ 3.3.8
|
||||
|
||||
[env:ci-arduino-3-latest-asynctcp]
|
||||
lib_deps =
|
||||
@ -144,7 +145,7 @@ board = ${sysenv.PIO_BOARD}
|
||||
board_build.core = earlephilhower
|
||||
lib_deps =
|
||||
bblanchon/ArduinoJson @ 7.3.0
|
||||
ayushsharma82/RPAsyncTCP@^1.3.1
|
||||
ayushsharma82/RPAsyncTCP@^1.3.2
|
||||
lib_ignore =
|
||||
lwIP_ESPHost
|
||||
build_flags = ${env.build_flags}
|
||||
|
@ -12,7 +12,7 @@ extern "C" {
|
||||
/** Minor version number (x.X.x) */
|
||||
#define ASYNCWEBSERVER_VERSION_MINOR 7
|
||||
/** Patch version number (x.x.X) */
|
||||
#define ASYNCWEBSERVER_VERSION_PATCH 2
|
||||
#define ASYNCWEBSERVER_VERSION_PATCH 4
|
||||
|
||||
/**
|
||||
* Macro to convert version number into an integer
|
||||
|
@ -4,9 +4,10 @@
|
||||
#ifndef _ESPAsyncWebServer_H_
|
||||
#define _ESPAsyncWebServer_H_
|
||||
|
||||
#include "Arduino.h"
|
||||
#include <Arduino.h>
|
||||
#include <FS.h>
|
||||
#include <lwip/tcpbase.h>
|
||||
|
||||
#include "FS.h"
|
||||
#include <algorithm>
|
||||
#include <deque>
|
||||
#include <functional>
|
||||
@ -468,7 +469,9 @@ public:
|
||||
}
|
||||
|
||||
AsyncWebServerResponse *beginChunkedResponse(const char *contentType, AwsResponseFiller callback, AwsTemplateProcessor templateCallback = nullptr);
|
||||
AsyncWebServerResponse *beginChunkedResponse(const String &contentType, AwsResponseFiller callback, AwsTemplateProcessor templateCallback = nullptr);
|
||||
AsyncWebServerResponse *beginChunkedResponse(const String &contentType, AwsResponseFiller callback, AwsTemplateProcessor templateCallback = nullptr) {
|
||||
return beginChunkedResponse(contentType.c_str(), callback, templateCallback);
|
||||
}
|
||||
|
||||
AsyncResponseStream *beginResponseStream(const char *contentType, size_t bufferSize = RESPONSE_STREAM_BUFFER_SIZE);
|
||||
AsyncResponseStream *beginResponseStream(const String &contentType, size_t bufferSize = RESPONSE_STREAM_BUFFER_SIZE) {
|
||||
@ -537,6 +540,9 @@ public:
|
||||
* @return const AsyncWebParameter*
|
||||
*/
|
||||
const AsyncWebParameter *getParam(size_t num) const;
|
||||
const AsyncWebParameter *getParam(int num) const {
|
||||
return num < 0 ? nullptr : getParam((size_t)num);
|
||||
}
|
||||
|
||||
size_t args() const {
|
||||
return params();
|
||||
@ -551,9 +557,15 @@ public:
|
||||
#ifdef ESP8266
|
||||
const String &arg(const __FlashStringHelper *data) const; // get request argument value by F(name)
|
||||
#endif
|
||||
const String &arg(size_t i) const; // get request argument value by number
|
||||
const String &arg(size_t i) const; // get request argument value by number
|
||||
const String &arg(int i) const {
|
||||
return i < 0 ? emptyString : arg((size_t)i);
|
||||
};
|
||||
const String &argName(size_t i) const; // get request argument name by number
|
||||
bool hasArg(const char *name) const; // check if argument exists
|
||||
const String &argName(int i) const {
|
||||
return i < 0 ? emptyString : argName((size_t)i);
|
||||
};
|
||||
bool hasArg(const char *name) const; // check if argument exists
|
||||
bool hasArg(const String &name) const {
|
||||
return hasArg(name.c_str());
|
||||
};
|
||||
@ -562,6 +574,9 @@ public:
|
||||
#endif
|
||||
|
||||
const String &ASYNCWEBSERVER_REGEX_ATTRIBUTE pathArg(size_t i) const;
|
||||
const String &ASYNCWEBSERVER_REGEX_ATTRIBUTE pathArg(int i) const {
|
||||
return i < 0 ? emptyString : pathArg((size_t)i);
|
||||
}
|
||||
|
||||
// get request header value by name
|
||||
const String &header(const char *name) const;
|
||||
@ -573,8 +588,14 @@ public:
|
||||
const String &header(const __FlashStringHelper *data) const; // get request header value by F(name)
|
||||
#endif
|
||||
|
||||
const String &header(size_t i) const; // get request header value by number
|
||||
const String &header(size_t i) const; // get request header value by number
|
||||
const String &header(int i) const {
|
||||
return i < 0 ? emptyString : header((size_t)i);
|
||||
};
|
||||
const String &headerName(size_t i) const; // get request header name by number
|
||||
const String &headerName(int i) const {
|
||||
return i < 0 ? emptyString : headerName((size_t)i);
|
||||
};
|
||||
|
||||
size_t headers() const; // get header count
|
||||
|
||||
@ -596,6 +617,9 @@ public:
|
||||
#endif
|
||||
|
||||
const AsyncWebHeader *getHeader(size_t num) const;
|
||||
const AsyncWebHeader *getHeader(int num) const {
|
||||
return num < 0 ? nullptr : getHeader((size_t)num);
|
||||
};
|
||||
|
||||
const std::list<AsyncWebHeader> &getHeaders() const {
|
||||
return _headers;
|
||||
@ -1075,6 +1099,15 @@ public:
|
||||
void begin();
|
||||
void end();
|
||||
|
||||
tcp_state state() const {
|
||||
#ifdef ESP8266
|
||||
// ESPAsyncTCP and RPAsyncTCP methods are not corrected declared with const for immutable ones.
|
||||
return static_cast<tcp_state>(const_cast<AsyncWebServer *>(this)->_server.status());
|
||||
#else
|
||||
return static_cast<tcp_state>(_server.status());
|
||||
#endif
|
||||
}
|
||||
|
||||
#if ASYNC_TCP_SSL_ENABLED
|
||||
void onSslFileRequest(AcSSlFileHandler cb, void *arg);
|
||||
void beginSecure(const char *cert, const char *private_key_file, const char *password);
|
||||
|
@ -19,7 +19,6 @@ class AsyncStaticWebHandler : public AsyncWebHandler {
|
||||
private:
|
||||
bool _getFile(AsyncWebServerRequest *request) const;
|
||||
bool _searchFile(AsyncWebServerRequest *request, const String &path);
|
||||
uint8_t _countBits(const uint8_t value) const;
|
||||
|
||||
protected:
|
||||
FS _fs;
|
||||
|
@ -187,15 +187,6 @@ bool AsyncStaticWebHandler::_searchFile(AsyncWebServerRequest *request, const St
|
||||
return found;
|
||||
}
|
||||
|
||||
uint8_t AsyncStaticWebHandler::_countBits(const uint8_t value) const {
|
||||
uint8_t w = value;
|
||||
uint8_t n;
|
||||
for (n = 0; w != 0; n++) {
|
||||
w &= w - 1;
|
||||
}
|
||||
return n;
|
||||
}
|
||||
|
||||
void AsyncStaticWebHandler::handleRequest(AsyncWebServerRequest *request) {
|
||||
// Get the filename from request->_tempObject and free it
|
||||
String filename((char *)request->_tempObject);
|
||||
|
Loading…
x
Reference in New Issue
Block a user