Compare commits

..

No commits in common. "04a7c2cce36837455da914fc6e068d64dfe413be" and "312f75fc5f41d8f468144401f52b85ed4b836b0e" have entirely different histories.

3 changed files with 20 additions and 42 deletions

View File

@ -1,12 +1,5 @@
# Changelog # Changelog
## [1.3.44] - 2025-02-22
### Changed
- update webpages for version v1.3.44
- update header title to 'Hollo Lollo Trollo'
- update header title to 'Filament Management Tool' and improve update response messages
## [1.3.43] - 2025-02-22 ## [1.3.43] - 2025-02-22
### Changed ### Changed
- update webpages for version v1.3.43 - update webpages for version v1.3.43

View File

@ -9,7 +9,7 @@
; https://docs.platformio.org/page/projectconf.html ; https://docs.platformio.org/page/projectconf.html
[common] [common]
version = "1.3.44" version = "1.3.43"
#test #test

View File

@ -368,11 +368,11 @@ void setupWebserver(AsyncWebServer &server) {
[](AsyncWebServerRequest *request) { [](AsyncWebServerRequest *request) {
// Nach Update-Abschluss // Nach Update-Abschluss
bool success = !Update.hasError(); bool success = !Update.hasError();
String message = success ? "Update successful" : String("Update failed: ") + Update.errorString();
AsyncWebServerResponse *response = request->beginResponse( AsyncWebServerResponse *response = request->beginResponse(
success ? 200 : 400, success ? 200 : 400,
"application/json", "application/json",
"{\"success\":" + String(success ? "true" : "false") + ",\"message\":\"" + message + "\"}" success ? "{\"success\":true,\"message\":\"Update successful\"}"
: "{\"success\":false,\"message\":\"Update failed\"}"
); );
response->addHeader("Connection", "close"); response->addHeader("Connection", "close");
request->send(response); request->send(response);
@ -392,46 +392,33 @@ void setupWebserver(AsyncWebServer &server) {
oledShowMessage("Upgrade please wait"); oledShowMessage("Upgrade please wait");
// TODO: Backup
if (!index) { if (!index) {
updateSize = request->contentLength(); updateSize = request->contentLength();
command = (filename.indexOf("spiffs") > -1) ? U_SPIFFS : U_FLASH; command = (filename.indexOf("spiffs") > -1) ? U_SPIFFS : U_FLASH;
Serial.printf("Update Start: %s\nSize: %u\nCommand: %d\n", filename.c_str(), updateSize, command);
// Überprüfe die SPIFFS-Größe if (command == U_SPIFFS) {
if (command == U_SPIFFS && updateSize > 0x30000) { // Backup JSON config files before SPIFFS update
String errorMsg = "SPIFFS update too large. Maximum size is 192KB"; backupJsonConfigs();
Serial.println(errorMsg); }
// Setze spezifische Update-Flags für SPIFFS-Updates
if (!Update.begin(updateSize, command, command == U_SPIFFS ? true : false, command == U_SPIFFS ? 0 : -1)) {
if (command == U_SPIFFS) {
// Restore JSON config files if update fails at start
restoreJsonConfigs();
}
String errorMsg = String("Update begin failed: ") + Update.errorString();
request->send(400, "application/json", "{\"success\":false,\"message\":\"" + errorMsg + "\"}"); request->send(400, "application/json", "{\"success\":false,\"message\":\"" + errorMsg + "\"}");
return; return;
} }
if (command == U_SPIFFS) {
Serial.println("Backup JSON configs...");
backupJsonConfigs();
if (!Update.begin(updateSize, command, false)) {
Serial.printf("Update Begin Error: %s\n", Update.errorString());
Serial.println("Restoring JSON configs...");
restoreJsonConfigs();
String errorMsg = String("Update begin failed: ") + Update.errorString();
request->send(400, "application/json", "{\"success\":false,\"message\":\"" + errorMsg + "\"}");
return;
}
} else {
if (!Update.begin(updateSize, command)) {
Serial.printf("Update Begin Error: %s\n", Update.errorString());
String errorMsg = String("Update begin failed: ") + Update.errorString();
request->send(400, "application/json", "{\"success\":false,\"message\":\"" + errorMsg + "\"}");
return;
}
}
} }
if (len) { if (len) {
if (Update.write(data, len) != len) { if (Update.write(data, len) != len) {
Serial.printf("Update Write Error: %s\n", Update.errorString());
if (command == U_SPIFFS) { if (command == U_SPIFFS) {
Serial.println("Restoring JSON configs..."); // Restore JSON config files if update fails during write
restoreJsonConfigs(); restoreJsonConfigs();
} }
String errorMsg = String("Write failed: ") + Update.errorString(); String errorMsg = String("Write failed: ") + Update.errorString();
@ -439,23 +426,21 @@ void setupWebserver(AsyncWebServer &server) {
return; return;
} }
Serial.printf("Progress: %u/%u\n", index + len, updateSize); // Sende den Fortschritt als JSON, um unerwünschte Zeilenumbrüche zu vermeiden
String progress = "{\"progress\":" + String((index + len) * 100 / updateSize) + "}"; String progress = "{\"progress\":" + String((index + len) * 100 / updateSize) + "}";
request->send(200, "application/json", progress); request->send(200, "application/json", progress);
} }
if (final) { if (final) {
if (!Update.end(true)) { if (!Update.end(true)) {
Serial.printf("Update End Error: %s\n", Update.errorString());
if (command == U_SPIFFS) { if (command == U_SPIFFS) {
Serial.println("Restoring JSON configs..."); // Restore JSON config files if update fails at end
restoreJsonConfigs(); restoreJsonConfigs();
} }
String errorMsg = String("Update end failed: ") + Update.errorString(); String errorMsg = String("Update end failed: ") + Update.errorString();
request->send(400, "application/json", "{\"success\":false,\"message\":\"" + errorMsg + "\"}"); request->send(400, "application/json", "{\"success\":false,\"message\":\"" + errorMsg + "\"}");
return; return;
} }
Serial.println("Update Success!");
} }
} }
); );