* Asyncwebserver * Squashed commit of the following: commit 575ef02f593918ec6654c87407a4d11fc17071b8 Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 17:56:11 2024 +0200 merge master commit 35e5adf4ecd80f9829e8801181f35dd2c1d94759 Merge: a2cc7be221adca01Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 17:41:04 2024 +0200 Merge branch 'master' of github.com:technyon/nuki_hub into DM9051 commit a2cc7be2954cbd8767ab8186296c0b14134d1d0b Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 10:51:50 2024 +0200 update nuki ble commit 20c809f3dca28b29b219d1ff3a183f1981316de5 Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 10:44:46 2024 +0200 backup commit dd41c218efb5270f5efeb734e64dff695920db16 Merge: 153000b5e84b944aAuthor: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 10:40:03 2024 +0200 Merge branch 'master' of github.com:technyon/nuki_hub into DM9051 commit 153000b5b1af7df1fbeb5263df94eb26f689cc0a Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 10:23:07 2024 +0200 fix linker error commit a93bbfbfc4301e46ff3696a763dd13c6c89efefb Author: technyon <j.o.schuemann@gmx.de> Date: Sun Aug 11 11:27:07 2024 +0200 backup commit f611c75ce8c35f829bcad6cf7e86188f4b3ec331 Merge: f1964917063fbab6Author: technyon <j.o.schuemann@gmx.de> Date: Sun Aug 11 11:24:47 2024 +0200 merge master commit f1964917b4dade3920f1ecdb699c58630199e6da Author: technyon <j.o.schuemann@gmx.de> Date: Sat Aug 10 15:17:45 2024 +0200 update platformio.ini commit f448e5e8a7e93be38e09e2ab0b622199a3721af6 Author: technyon <j.o.schuemann@gmx.de> Date: Sat Aug 10 11:28:09 2024 +0200 add SPIClass instance for DM9051 commit 1f190e9aa08033535a2eb442a92e6e20409bbda1 Author: technyon <j.o.schuemann@gmx.de> Date: Sat Aug 10 11:22:26 2024 +0200 add definitions and constructor for DM9051 commit 726b3602ae91594ee1210ad5b6714f75cc5e42a7 Merge: 50a2eb134af90cbcAuthor: technyon <j.o.schuemann@gmx.de> Date: Sat Aug 10 10:19:34 2024 +0200 merge master commit 50a2eb136d75d90921f1c6974f18bc107bddc123 Author: technyon <j.o.schuemann@gmx.de> Date: Fri Aug 9 11:52:09 2024 +0200 add comment commit 9437e485cae169efdf8e5a7bf188a1c7e792d1e5 Author: technyon <j.o.schuemann@gmx.de> Date: Sun Aug 4 08:29:21 2024 +0200 move LAN8720 definitions to seperate file * Remove Core 2 Ethernet library * Custom Ethernet * GPIO and Preferences * H2
158 lines
6.9 KiB
C++
158 lines
6.9 KiB
C++
/*
|
|
Asynchronous WebServer library for Espressif MCUs
|
|
|
|
Copyright (c) 2016 Hristo Gochkov. All rights reserved.
|
|
This file is part of the esp8266 core for Arduino environment.
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with this library; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
#ifndef ASYNCWEBSERVERRESPONSEIMPL_H_
|
|
#define ASYNCWEBSERVERRESPONSEIMPL_H_
|
|
|
|
#ifdef Arduino_h
|
|
// arduino is not compatible with std::vector
|
|
#undef min
|
|
#undef max
|
|
#endif
|
|
#include <memory>
|
|
#include <vector>
|
|
#include "literals.h"
|
|
|
|
// It is possible to restore these defines, but one can use _min and _max instead. Or std::min, std::max.
|
|
|
|
class AsyncBasicResponse : public AsyncWebServerResponse {
|
|
private:
|
|
String _content;
|
|
|
|
public:
|
|
explicit AsyncBasicResponse(int code, const char* contentType = asyncsrv::empty, const char* content = asyncsrv::empty);
|
|
AsyncBasicResponse(int code, const String& contentType, const String& content = emptyString) : AsyncBasicResponse(code, contentType.c_str(), content.c_str()) {}
|
|
void _respond(AsyncWebServerRequest* request);
|
|
size_t _ack(AsyncWebServerRequest* request, size_t len, uint32_t time);
|
|
bool _sourceValid() const { return true; }
|
|
};
|
|
|
|
class AsyncAbstractResponse : public AsyncWebServerResponse {
|
|
private:
|
|
String _head;
|
|
// Data is inserted into cache at begin().
|
|
// This is inefficient with vector, but if we use some other container,
|
|
// we won't be able to access it as contiguous array of bytes when reading from it,
|
|
// so by gaining performance in one place, we'll lose it in another.
|
|
std::vector<uint8_t> _cache;
|
|
size_t _readDataFromCacheOrContent(uint8_t* data, const size_t len);
|
|
size_t _fillBufferAndProcessTemplates(uint8_t* buf, size_t maxLen);
|
|
|
|
protected:
|
|
AwsTemplateProcessor _callback;
|
|
|
|
public:
|
|
AsyncAbstractResponse(AwsTemplateProcessor callback = nullptr);
|
|
void _respond(AsyncWebServerRequest* request);
|
|
size_t _ack(AsyncWebServerRequest* request, size_t len, uint32_t time);
|
|
bool _sourceValid() const { return false; }
|
|
virtual size_t _fillBuffer(uint8_t* buf __attribute__((unused)), size_t maxLen __attribute__((unused))) { return 0; }
|
|
};
|
|
|
|
#ifndef TEMPLATE_PLACEHOLDER
|
|
#define TEMPLATE_PLACEHOLDER '%'
|
|
#endif
|
|
|
|
#define TEMPLATE_PARAM_NAME_LENGTH 32
|
|
class AsyncFileResponse : public AsyncAbstractResponse {
|
|
using File = fs::File;
|
|
using FS = fs::FS;
|
|
|
|
private:
|
|
File _content;
|
|
String _path;
|
|
void _setContentTypeFromPath(const String& path);
|
|
|
|
public:
|
|
AsyncFileResponse(FS& fs, const String& path, const char* contentType = asyncsrv::empty, bool download = false, AwsTemplateProcessor callback = nullptr);
|
|
AsyncFileResponse(FS& fs, const String& path, const String& contentType, bool download = false, AwsTemplateProcessor callback = nullptr) : AsyncFileResponse(fs, path, contentType.c_str(), download, callback) {}
|
|
AsyncFileResponse(File content, const String& path, const char* contentType = asyncsrv::empty, bool download = false, AwsTemplateProcessor callback = nullptr);
|
|
AsyncFileResponse(File content, const String& path, const String& contentType, bool download = false, AwsTemplateProcessor callack = nullptr) : AsyncFileResponse(content, path, contentType.c_str(), download, callack) {}
|
|
~AsyncFileResponse();
|
|
bool _sourceValid() const { return !!(_content); }
|
|
virtual size_t _fillBuffer(uint8_t* buf, size_t maxLen) override;
|
|
};
|
|
|
|
class AsyncStreamResponse : public AsyncAbstractResponse {
|
|
private:
|
|
Stream* _content;
|
|
|
|
public:
|
|
AsyncStreamResponse(Stream& stream, const char* contentType, size_t len, AwsTemplateProcessor callback = nullptr);
|
|
AsyncStreamResponse(Stream& stream, const String& contentType, size_t len, AwsTemplateProcessor callback = nullptr) : AsyncStreamResponse(stream, contentType.c_str(), len, callback) {}
|
|
bool _sourceValid() const { return !!(_content); }
|
|
virtual size_t _fillBuffer(uint8_t* buf, size_t maxLen) override;
|
|
};
|
|
|
|
class AsyncCallbackResponse : public AsyncAbstractResponse {
|
|
private:
|
|
AwsResponseFiller _content;
|
|
size_t _filledLength;
|
|
|
|
public:
|
|
AsyncCallbackResponse(const char* contentType, size_t len, AwsResponseFiller callback, AwsTemplateProcessor templateCallback = nullptr);
|
|
AsyncCallbackResponse(const String& contentType, size_t len, AwsResponseFiller callback, AwsTemplateProcessor templateCallback = nullptr) : AsyncCallbackResponse(contentType.c_str(), len, callback, templateCallback) {}
|
|
bool _sourceValid() const { return !!(_content); }
|
|
virtual size_t _fillBuffer(uint8_t* buf, size_t maxLen) override;
|
|
};
|
|
|
|
class AsyncChunkedResponse : public AsyncAbstractResponse {
|
|
private:
|
|
AwsResponseFiller _content;
|
|
size_t _filledLength;
|
|
|
|
public:
|
|
AsyncChunkedResponse(const char* contentType, AwsResponseFiller callback, AwsTemplateProcessor templateCallback = nullptr);
|
|
AsyncChunkedResponse(const String& contentType, AwsResponseFiller callback, AwsTemplateProcessor templateCallback = nullptr) : AsyncChunkedResponse(contentType.c_str(), callback, templateCallback) {}
|
|
bool _sourceValid() const { return !!(_content); }
|
|
virtual size_t _fillBuffer(uint8_t* buf, size_t maxLen) override;
|
|
};
|
|
|
|
class AsyncProgmemResponse : public AsyncAbstractResponse {
|
|
private:
|
|
const uint8_t* _content;
|
|
size_t _readLength;
|
|
|
|
public:
|
|
AsyncProgmemResponse(int code, const char* contentType, const uint8_t* content, size_t len, AwsTemplateProcessor callback = nullptr);
|
|
AsyncProgmemResponse(int code, const String& contentType, const uint8_t* content, size_t len, AwsTemplateProcessor callback = nullptr) : AsyncProgmemResponse(code, contentType.c_str(), content, len, callback) {}
|
|
bool _sourceValid() const { return true; }
|
|
virtual size_t _fillBuffer(uint8_t* buf, size_t maxLen) override;
|
|
};
|
|
|
|
class cbuf;
|
|
|
|
class AsyncResponseStream : public AsyncAbstractResponse, public Print {
|
|
private:
|
|
std::unique_ptr<cbuf> _content;
|
|
|
|
public:
|
|
AsyncResponseStream(const char* contentType, size_t bufferSize);
|
|
AsyncResponseStream(const String& contentType, size_t bufferSize) : AsyncResponseStream(contentType.c_str(), bufferSize) {}
|
|
~AsyncResponseStream();
|
|
bool _sourceValid() const { return (_state < RESPONSE_END); }
|
|
virtual size_t _fillBuffer(uint8_t* buf, size_t maxLen) override;
|
|
size_t write(const uint8_t* data, size_t len);
|
|
size_t write(uint8_t data);
|
|
using Print::write;
|
|
};
|
|
|
|
#endif /* ASYNCWEBSERVERRESPONSEIMPL_H_ */
|