mirror of
https://github.com/khoih-prog/AsyncHTTPRequest_Generic.git
synced 2025-06-25 01:31:32 +02:00
### Releases v1.10.2 1. Default to reconnect to the same `host:port` after connected for new HTTP sites. Check [Host/Headers not always sent with 1.10.1 #44](https://github.com/khoih-prog/AsyncHTTPRequest_Generic/issues44) 2. Update `Packages' Patches`
249 lines
6.6 KiB
C++
249 lines
6.6 KiB
C++
/****************************************************************************************************************************
|
|
AsyncHTTPRequest_ESP_Multi.ino - Dead simple AsyncHTTPRequest for ESP8266, ESP32 and currently STM32 with built-in LAN8742A Ethernet
|
|
|
|
For ESP8266, ESP32 and STM32 with built-in LAN8742A Ethernet (Nucleo-144, DISCOVERY, etc)
|
|
|
|
AsyncHTTPRequest_Generic is a library for the ESP8266, ESP32 and currently STM32 run built-in Ethernet WebServer
|
|
|
|
Based on and modified from asyncHTTPrequest Library (https://github.com/boblemaire/asyncHTTPrequest)
|
|
|
|
Built by Khoi Hoang https://github.com/khoih-prog/AsyncHTTPRequest_Generic
|
|
Licensed under MIT license
|
|
|
|
Copyright (C) <2018> <Bob Lemaire, IoTaWatt, Inc.>
|
|
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License
|
|
as published bythe Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
|
This program 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 General Public License for more details.
|
|
You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*****************************************************************************************************************************/
|
|
|
|
#if !( defined(ESP8266) || defined(ESP32) )
|
|
#error This code is intended to run on the ESP8266 or ESP32 platform! Please check your Tools->Board setting.
|
|
#endif
|
|
|
|
// Level from 0-4
|
|
#define ASYNC_HTTP_DEBUG_PORT Serial
|
|
|
|
#define _ASYNC_HTTP_LOGLEVEL_ 1
|
|
|
|
// 300s = 5 minutes to not flooding
|
|
#define HTTP_REQUEST_INTERVAL 300
|
|
|
|
// 10s
|
|
#define HEARTBEAT_INTERVAL 10
|
|
|
|
int status; // the Wifi radio's status
|
|
|
|
const char* ssid = "your_ssid";
|
|
const char* password = "your_pass";
|
|
|
|
#if (ESP8266)
|
|
#include <ESP8266WiFi.h>
|
|
#elif (ESP32)
|
|
#include <WiFi.h>
|
|
#endif
|
|
|
|
// Seconds for timeout, default is 3s
|
|
#define DEFAULT_RX_TIMEOUT 10
|
|
|
|
// Uncomment for certain HTTP site to optimize
|
|
//#define NOT_SEND_HEADER_AFTER_CONNECTED true
|
|
|
|
// To be included only in main(), .ino with setup() to avoid `Multiple Definitions` Linker Error
|
|
#include <AsyncHTTPRequest_Generic.h> // https://github.com/khoih-prog/AsyncHTTPRequest_Generic
|
|
|
|
#include <Ticker.h>
|
|
|
|
#define NUM_DIFFERENT_SITES 2
|
|
|
|
const char* addreses[][NUM_DIFFERENT_SITES] =
|
|
{
|
|
{"http://worldtimeapi.org/api/timezone/America/Toronto.txt", "http://worldtimeapi.org/api/timezone/Europe/Prague.txt"},
|
|
{"http://www.myexternalip.com/raw"}
|
|
};
|
|
|
|
#define NUM_ENTRIES_SITE_0 2
|
|
#define NUM_ENTRIES_SITE_1 1
|
|
|
|
byte reqCount[NUM_DIFFERENT_SITES] = { NUM_ENTRIES_SITE_0, NUM_ENTRIES_SITE_1 };
|
|
bool readySend[NUM_DIFFERENT_SITES] = { true, true };
|
|
|
|
AsyncHTTPRequest request[NUM_DIFFERENT_SITES];
|
|
|
|
void requestCB0(void* optParm, AsyncHTTPRequest* thisRequest, int readyState);
|
|
void requestCB1(void* optParm, AsyncHTTPRequest* thisRequest, int readyState);
|
|
|
|
void sendRequest0();
|
|
void sendRequest1();
|
|
|
|
typedef void (*requestCallback)(void* optParm, AsyncHTTPRequest* thisRequest, int readyState);
|
|
typedef void (*sendCallback)();
|
|
|
|
requestCallback requestCB [NUM_DIFFERENT_SITES] = { requestCB0, requestCB1 };
|
|
sendCallback sendRequestCB [NUM_DIFFERENT_SITES] = { sendRequest0, sendRequest1 };
|
|
|
|
Ticker ticker;
|
|
Ticker ticker1;
|
|
|
|
void heartBeatPrint()
|
|
{
|
|
static int num = 1;
|
|
|
|
if (WiFi.status() == WL_CONNECTED)
|
|
Serial.print(F("H")); // H means connected to WiFi
|
|
else
|
|
Serial.print(F("F")); // F means not connected to WiFi
|
|
|
|
if (num == 80)
|
|
{
|
|
Serial.println();
|
|
num = 1;
|
|
}
|
|
else if (num++ % 10 == 0)
|
|
{
|
|
Serial.print(F(" "));
|
|
}
|
|
}
|
|
|
|
void sendRequest(uint16_t index)
|
|
{
|
|
static bool requestOpenResult;
|
|
|
|
reqCount[index]--;
|
|
readySend[index] = false;
|
|
|
|
requestOpenResult = request[index].open("GET", addreses[index][reqCount[index]]);
|
|
|
|
if (requestOpenResult)
|
|
{
|
|
// Only send() if open() returns true, or crash
|
|
Serial.print("\nSending request: ");
|
|
request[index].send();
|
|
}
|
|
else
|
|
{
|
|
Serial.print("\nCan't send bad request : ");
|
|
}
|
|
|
|
Serial.println(addreses[index][reqCount[index]]);
|
|
}
|
|
|
|
void sendRequest0()
|
|
{
|
|
sendRequest(0);
|
|
}
|
|
|
|
void sendRequest1()
|
|
{
|
|
sendRequest(1);
|
|
}
|
|
|
|
void sendRequests()
|
|
{
|
|
reqCount[0] = NUM_ENTRIES_SITE_0;
|
|
reqCount[1] = NUM_ENTRIES_SITE_1;
|
|
}
|
|
|
|
void requestCB0(void* optParm, AsyncHTTPRequest* thisRequest, int readyState)
|
|
{
|
|
(void) optParm;
|
|
|
|
if (readyState == readyStateDone)
|
|
{
|
|
AHTTP_LOGWARN(F("\n**************************************"));
|
|
AHTTP_LOGWARN1(F("Response Code = "), request->responseHTTPString());
|
|
|
|
if (request->responseHTTPcode() == 200)
|
|
{
|
|
Serial.println(F("\n**************************************"));
|
|
Serial.println(request->responseText());
|
|
Serial.println(F("**************************************"));
|
|
}
|
|
else
|
|
{
|
|
AHTTP_LOGERROR(F("Response error"));
|
|
}
|
|
|
|
thisRequest->setDebug(false);
|
|
readySend[0] = true;
|
|
}
|
|
}
|
|
|
|
void requestCB1(void* optParm, AsyncHTTPRequest* thisRequest, int readyState)
|
|
{
|
|
(void) optParm;
|
|
|
|
if (readyState == readyStateDone)
|
|
{
|
|
AHTTP_LOGWARN(F("\n**************************************"));
|
|
AHTTP_LOGWARN1(F("Response Code = "), request->responseHTTPString());
|
|
|
|
if (request->responseHTTPcode() == 200)
|
|
{
|
|
Serial.println(F("\n**************************************"));
|
|
Serial.println(request->responseText());
|
|
Serial.println(F("**************************************"));
|
|
}
|
|
else
|
|
{
|
|
AHTTP_LOGERROR(F("Response error"));
|
|
}
|
|
|
|
thisRequest->setDebug(false);
|
|
readySend[1] = true;
|
|
}
|
|
}
|
|
|
|
void setup()
|
|
{
|
|
// put your setup code here, to run once:
|
|
Serial.begin(115200);
|
|
|
|
while (!Serial && millis() < 5000);
|
|
|
|
Serial.print("\nStart AsyncHTTPRequest_ESP_Multi on ");
|
|
Serial.println(ARDUINO_BOARD);
|
|
Serial.println(ASYNC_HTTP_REQUEST_GENERIC_VERSION);
|
|
|
|
WiFi.mode(WIFI_STA);
|
|
|
|
WiFi.begin(ssid, password);
|
|
|
|
Serial.println("Connecting to WiFi SSID: " + String(ssid));
|
|
|
|
while (WiFi.status() != WL_CONNECTED)
|
|
{
|
|
delay(1000);
|
|
Serial.print(".");
|
|
}
|
|
|
|
Serial.print(F("\nAsyncHTTPSRequest @ IP : "));
|
|
Serial.println(WiFi.localIP());
|
|
|
|
for (int index = 0; index < NUM_DIFFERENT_SITES; index++)
|
|
{
|
|
request[index].setDebug(false);
|
|
|
|
request[index].onReadyStateChange(requestCB[index]);
|
|
}
|
|
|
|
ticker.attach(HTTP_REQUEST_INTERVAL, sendRequests);
|
|
|
|
ticker1.attach(HEARTBEAT_INTERVAL, heartBeatPrint);
|
|
}
|
|
|
|
void loop()
|
|
{
|
|
for (int index = 0; index < NUM_DIFFERENT_SITES; index++)
|
|
{
|
|
if ((reqCount[index] > 0) && readySend[index])
|
|
{
|
|
sendRequestCB[index]();
|
|
|
|
// Don't send too fast
|
|
delay(1000);
|
|
}
|
|
}
|
|
}
|