diff --git a/lib/libesp32/Berry-HttpClientLight/src/HttpClientLight.cpp b/lib/libesp32/Berry-HttpClientLight/src/HttpClientLight.cpp index 420cbfb71..e24bee87a 100644 --- a/lib/libesp32/Berry-HttpClientLight/src/HttpClientLight.cpp +++ b/lib/libesp32/Berry-HttpClientLight/src/HttpClientLight.cpp @@ -46,10 +46,10 @@ #endif // USE_WEBCLIENT_HTTPS // #ifdef HTTPCLIENT_1_1_COMPATIBLE -class TransportTraits +class TransportTraitsLight { public: - virtual ~TransportTraits() + virtual ~TransportTraitsLight() { } @@ -72,7 +72,7 @@ public: #ifdef USE_WEBCLIENT_HTTPS static const uint8_t _fingerprint_any[] = { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }; -class BearSSLTraits : public TransportTraits +class BearSSLTraits : public TransportTraitsLight { public: BearSSLTraits(int recv, int xmit) : @@ -221,7 +221,7 @@ bool HTTPClientLight::begin(String url, const char* CAcert) } _secure = true; #ifdef USE_WEBCLIENT_HTTPS - _transportTraits = TransportTraitsPtr(new BearSSLTraits(16384, 0)); + _transportTraits = TransportTraitsLightPtr(new BearSSLTraits(16384, 0)); // set buffer to 16KB half duplex, so we won't lose responses bigger than 16KB // half duplex is well suited for HTTPS: one request followed by responses #else @@ -251,7 +251,7 @@ bool HTTPClientLight::begin(String url) if (!beginInternal(url, "http")) { return begin(url, (const char*)NULL); } - _transportTraits = TransportTraitsPtr(new TransportTraits()); + _transportTraits = TransportTraitsLightPtr(new TransportTraitsLight()); if(!_transportTraits) { log_e("could not create transport traits"); return false; @@ -328,7 +328,7 @@ bool HTTPClientLight::beginInternal(String url, const char* expectedProtocol) // _host = host; // _port = port; // _uri = uri; -// // _transportTraits = TransportTraitsPtr(new TransportTraits()); TODO +// // _transportTraits = TransportTraitsLightPtr(new TransportTraitsLight()); TODO // _transportTraits = nullptr; // log_d("host: %s port: %d uri: %s", host.c_str(), port, uri.c_str()); // return true; @@ -351,7 +351,7 @@ bool HTTPClientLight::beginInternal(String url, const char* expectedProtocol) // return false; // } // _secure = true; -// _transportTraits = TransportTraitsPtr(new TLSTraits(CAcert)); +// _transportTraits = TransportTraitsLightPtr(new TLSTraits(CAcert)); // return true; // } @@ -372,7 +372,7 @@ bool HTTPClientLight::beginInternal(String url, const char* expectedProtocol) // return false; // } // _secure = true; -// _transportTraits = TransportTraitsPtr(new TLSTraits(CAcert, cli_cert, cli_key)); +// _transportTraits = TransportTraitsLightPtr(new TLSTraits(CAcert, cli_cert, cli_key)); // return true; // } #endif // HTTPCLIENT_1_1_COMPATIBLE diff --git a/lib/libesp32/Berry-HttpClientLight/src/HttpClientLight.h b/lib/libesp32/Berry-HttpClientLight/src/HttpClientLight.h index dc2bc0e58..a6d3be7eb 100644 --- a/lib/libesp32/Berry-HttpClientLight/src/HttpClientLight.h +++ b/lib/libesp32/Berry-HttpClientLight/src/HttpClientLight.h @@ -141,6 +141,11 @@ // } followRedirects_t; +#ifdef HTTPCLIENT_1_1_COMPATIBLE +class TransportTraitsLight; +typedef std::unique_ptr TransportTraitsLightPtr; +#endif + class HTTPClientLight { @@ -231,7 +236,7 @@ protected: #ifdef HTTPCLIENT_1_1_COMPATIBLE - TransportTraitsPtr _transportTraits; + TransportTraitsLightPtr _transportTraits; std::unique_ptr _tcpDeprecated; #endif diff --git a/lib/libesp32/berry_tasmota/src/be_tasmotalib.c b/lib/libesp32/berry_tasmota/src/be_tasmotalib.c index c662b39b9..a3f6c8f54 100644 --- a/lib/libesp32/berry_tasmota/src/be_tasmotalib.c +++ b/lib/libesp32/berry_tasmota/src/be_tasmotalib.c @@ -4,12 +4,12 @@ * To use: `import tasmota` *******************************************************************/ #include "be_constobj.h" +#include "be_ctypes.h" -struct dummy_struct {}; // we need a struct name but don't need any meaningful content, we just take the address extern struct TasmotaGlobal_t TasmotaGlobal; extern struct TSettings * Settings; -extern struct dummy_struct be_tasmota_global_struct; -extern struct dummy_struct be_tasmota_settings_struct; +extern const be_ctypes_structure_t be_tasmota_global_struct; +extern const be_ctypes_structure_t be_tasmota_settings_struct; extern int l_getFreeHeap(bvm *vm); extern int l_arch(bvm *vm);