added OTA support for deploying without USB cable
This commit is contained in:
parent
8778a57189
commit
1256612ff8
@ -13,3 +13,5 @@ platform = espressif32
|
|||||||
board = nodemcu-32s
|
board = nodemcu-32s
|
||||||
framework = arduino
|
framework = arduino
|
||||||
monitor_speed = 115200
|
monitor_speed = 115200
|
||||||
|
upload_protocol = espota
|
||||||
|
upload_port = 192.168.1.166
|
||||||
|
65
ESP32/src/OTA.cpp
Normal file
65
ESP32/src/OTA.cpp
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
#include "OTA.h"
|
||||||
|
|
||||||
|
#include <ArduinoOTA.h>
|
||||||
|
|
||||||
|
detail::OTA OTA;
|
||||||
|
|
||||||
|
namespace detail
|
||||||
|
{
|
||||||
|
OTA::OTA()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
OTA::~OTA()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void OTA::begin()
|
||||||
|
{
|
||||||
|
// Port defaults to 3232
|
||||||
|
// ArduinoOTA.setPort(3232);
|
||||||
|
|
||||||
|
// Hostname defaults to esp3232-[MAC]
|
||||||
|
// ArduinoOTA.setHostname("myesp32");
|
||||||
|
|
||||||
|
// No authentication by default
|
||||||
|
// ArduinoOTA.setPassword("admin");
|
||||||
|
|
||||||
|
// Password can be set with it's md5 value as well
|
||||||
|
// MD5(admin) = 21232f297a57a5a743894a0e4a801fc3
|
||||||
|
// ArduinoOTA.setPasswordHash("21232f297a57a5a743894a0e4a801fc3");
|
||||||
|
|
||||||
|
ArduinoOTA
|
||||||
|
.onStart([]() {
|
||||||
|
String type;
|
||||||
|
if (ArduinoOTA.getCommand() == U_FLASH)
|
||||||
|
type = "sketch";
|
||||||
|
else // U_SPIFFS
|
||||||
|
type = "filesystem";
|
||||||
|
|
||||||
|
// NOTE: if updating SPIFFS this would be the place to unmount SPIFFS using SPIFFS.end()
|
||||||
|
Serial.println("Start updating " + type);
|
||||||
|
})
|
||||||
|
.onEnd([]() {
|
||||||
|
Serial.println("\nEnd");
|
||||||
|
})
|
||||||
|
.onProgress([](unsigned int progress, unsigned int total) {
|
||||||
|
Serial.printf("Progress: %u%%\r", (progress / (total / 100)));
|
||||||
|
})
|
||||||
|
.onError([](ota_error_t error) {
|
||||||
|
Serial.printf("Error[%u]: ", error);
|
||||||
|
if (error == OTA_AUTH_ERROR) Serial.println("Auth Failed");
|
||||||
|
else if (error == OTA_BEGIN_ERROR) Serial.println("Begin Failed");
|
||||||
|
else if (error == OTA_CONNECT_ERROR) Serial.println("Connect Failed");
|
||||||
|
else if (error == OTA_RECEIVE_ERROR) Serial.println("Receive Failed");
|
||||||
|
else if (error == OTA_END_ERROR) Serial.println("End Failed");
|
||||||
|
});
|
||||||
|
|
||||||
|
ArduinoOTA.begin();
|
||||||
|
}
|
||||||
|
|
||||||
|
void OTA::handle()
|
||||||
|
{
|
||||||
|
ArduinoOTA.handle();
|
||||||
|
}
|
||||||
|
}
|
14
ESP32/src/OTA.h
Normal file
14
ESP32/src/OTA.h
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
namespace detail
|
||||||
|
{
|
||||||
|
class OTA
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
OTA();
|
||||||
|
~OTA();
|
||||||
|
|
||||||
|
void begin();
|
||||||
|
void handle();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
extern detail::OTA OTA;
|
@ -8,6 +8,7 @@
|
|||||||
#include <ESPAsyncWebServer.h>
|
#include <ESPAsyncWebServer.h>
|
||||||
|
|
||||||
#include "ADC.h"
|
#include "ADC.h"
|
||||||
|
#include "OTA.h"
|
||||||
|
|
||||||
#include "wifi-credentials.h"
|
#include "wifi-credentials.h"
|
||||||
|
|
||||||
@ -138,6 +139,8 @@ void setup()
|
|||||||
|
|
||||||
// Also connect as a station (if the configured remote access point is in range)
|
// Also connect as a station (if the configured remote access point is in range)
|
||||||
connectWifi();
|
connectWifi();
|
||||||
|
|
||||||
|
OTA.begin();
|
||||||
|
|
||||||
server.on("/api/status", HTTP_GET, [](AsyncWebServerRequest *request){
|
server.on("/api/status", HTTP_GET, [](AsyncWebServerRequest *request){
|
||||||
int v = batteryVoltage;
|
int v = batteryVoltage;
|
||||||
@ -162,6 +165,8 @@ void setup()
|
|||||||
|
|
||||||
void loop()
|
void loop()
|
||||||
{
|
{
|
||||||
|
OTA.handle();
|
||||||
|
|
||||||
wl_status_t newWifiStatus = WiFi.status();
|
wl_status_t newWifiStatus = WiFi.status();
|
||||||
if(newWifiStatus != wifi_STA_status)
|
if(newWifiStatus != wifi_STA_status)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user