feat: update version to v1.2.1 and change upgrade link to OTA in HTML files; modify updateSpoolTagId function to return boolean
This commit is contained in:
parent
3cd0798186
commit
f877f43d90
@ -12,7 +12,7 @@
|
|||||||
<div style="display: flex; align-items: center; gap: 2rem;">
|
<div style="display: flex; align-items: center; gap: 2rem;">
|
||||||
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
||||||
<div class="logo-text">
|
<div class="logo-text">
|
||||||
<h1>FilaMan<span class="version">v1.2.0</span></h1>
|
<h1>FilaMan<span class="version">v1.2.1</span></h1>
|
||||||
<h4>Filament Management Tool</h4>
|
<h4>Filament Management Tool</h4>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
<div style="display: flex; align-items: center; gap: 2rem;">
|
<div style="display: flex; align-items: center; gap: 2rem;">
|
||||||
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
||||||
<div class="logo-text">
|
<div class="logo-text">
|
||||||
<h1>FilaMan<span class="version">v1.2.0</span></h1>
|
<h1>FilaMan<span class="version">v1.2.1</span></h1>
|
||||||
<h4>Filament Management Tool</h4>
|
<h4>Filament Management Tool</h4>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -21,7 +21,7 @@
|
|||||||
<a href="/waage">Scale</a>
|
<a href="/waage">Scale</a>
|
||||||
<a href="/spoolman">Spoolman/Bambu</a>
|
<a href="/spoolman">Spoolman/Bambu</a>
|
||||||
<a href="/about">About</a>
|
<a href="/about">About</a>
|
||||||
<a href="/upgrade">Upgrade</a>
|
<a href="/ota">Upgrade</a>
|
||||||
</nav>
|
</nav>
|
||||||
<div class="status-container">
|
<div class="status-container">
|
||||||
<div class="status-item">
|
<div class="status-item">
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
<div style="display: flex; align-items: center; gap: 2rem;">
|
<div style="display: flex; align-items: center; gap: 2rem;">
|
||||||
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
||||||
<div class="logo-text">
|
<div class="logo-text">
|
||||||
<h1>FilaMan<span class="version">v1.2.0</span></h1>
|
<h1>FilaMan<span class="version">v1.2.1</span></h1>
|
||||||
<h4>Filament Management Tool</h4>
|
<h4>Filament Management Tool</h4>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -21,7 +21,7 @@
|
|||||||
<a href="/waage">Scale</a>
|
<a href="/waage">Scale</a>
|
||||||
<a href="/spoolman">Spoolman/Bambu</a>
|
<a href="/spoolman">Spoolman/Bambu</a>
|
||||||
<a href="/about">About</a>
|
<a href="/about">About</a>
|
||||||
<a href="/upgrade">Upgrade</a>
|
<a href="/ota">Upgrade</a>
|
||||||
</nav>
|
</nav>
|
||||||
<div class="status-container">
|
<div class="status-container">
|
||||||
<div class="status-item">
|
<div class="status-item">
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
<div style="display: flex; align-items: center; gap: 2rem;">
|
<div style="display: flex; align-items: center; gap: 2rem;">
|
||||||
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
||||||
<div class="logo-text">
|
<div class="logo-text">
|
||||||
<h1>FilaMan<span class="version">v1.2.0</span></h1>
|
<h1>FilaMan<span class="version">v1.2.1</span></h1>
|
||||||
<h4>Filament Management Tool</h4>
|
<h4>Filament Management Tool</h4>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -21,7 +21,7 @@
|
|||||||
<a href="/waage">Scale</a>
|
<a href="/waage">Scale</a>
|
||||||
<a href="/spoolman">Spoolman/Bambu</a>
|
<a href="/spoolman">Spoolman/Bambu</a>
|
||||||
<a href="/about">About</a>
|
<a href="/about">About</a>
|
||||||
<a href="/upgrade">Upgrade</a>
|
<a href="/ota">Upgrade</a>
|
||||||
</nav>
|
</nav>
|
||||||
<div class="status-container">
|
<div class="status-container">
|
||||||
<div class="status-item">
|
<div class="status-item">
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
<div style="display: flex; align-items: center; gap: 2rem;">
|
<div style="display: flex; align-items: center; gap: 2rem;">
|
||||||
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
||||||
<div class="logo-text">
|
<div class="logo-text">
|
||||||
<h1>FilaMan<span class="version">v1.2.0</span></h1>
|
<h1>FilaMan<span class="version">v1.2.1</span></h1>
|
||||||
<h4>Filament Management Tool</h4>
|
<h4>Filament Management Tool</h4>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -21,7 +21,7 @@
|
|||||||
<a href="/waage">Scale</a>
|
<a href="/waage">Scale</a>
|
||||||
<a href="/spoolman">Spoolman/Bambu</a>
|
<a href="/spoolman">Spoolman/Bambu</a>
|
||||||
<a href="/about">About</a>
|
<a href="/about">About</a>
|
||||||
<a href="/upgrade">Upgrade</a>
|
<a href="/ota">Upgrade</a>
|
||||||
</nav>
|
</nav>
|
||||||
<div class="status-container">
|
<div class="status-container">
|
||||||
<div class="status-item">
|
<div class="status-item">
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
<div style="display: flex; align-items: center; gap: 2rem;">
|
<div style="display: flex; align-items: center; gap: 2rem;">
|
||||||
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
<img src="/logo.png" alt="FilaMan Logo" class="logo">
|
||||||
<div class="logo-text">
|
<div class="logo-text">
|
||||||
<h1>FilaMan<span class="version">v1.2.0</span></h1>
|
<h1>FilaMan<span class="version">v1.2.1</span></h1>
|
||||||
<h4>Filament Management Tool</h4>
|
<h4>Filament Management Tool</h4>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -21,7 +21,7 @@
|
|||||||
<a href="/waage">Scale</a>
|
<a href="/waage">Scale</a>
|
||||||
<a href="/spoolman">Spoolman/Bambu</a>
|
<a href="/spoolman">Spoolman/Bambu</a>
|
||||||
<a href="/about">About</a>
|
<a href="/about">About</a>
|
||||||
<a href="/upgrade">Upgrade</a>
|
<a href="/ota">Upgrade</a>
|
||||||
</nav>
|
</nav>
|
||||||
<div class="status-container">
|
<div class="status-container">
|
||||||
<div class="status-item">
|
<div class="status-item">
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
; https://docs.platformio.org/page/projectconf.html
|
; https://docs.platformio.org/page/projectconf.html
|
||||||
|
|
||||||
[common]
|
[common]
|
||||||
version = "1.2.0"
|
version = "1.2.1"
|
||||||
|
|
||||||
[env:esp32dev]
|
[env:esp32dev]
|
||||||
platform = espressif32
|
platform = espressif32
|
||||||
|
10
src/api.cpp
10
src/api.cpp
@ -175,20 +175,20 @@ void sendToApi(void *parameter) {
|
|||||||
vTaskDelete(NULL);
|
vTaskDelete(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t updateSpoolTagId(String uidString, const char* payload) {
|
bool updateSpoolTagId(String uidString, const char* payload) {
|
||||||
JsonDocument doc;
|
JsonDocument doc;
|
||||||
DeserializationError error = deserializeJson(doc, payload);
|
DeserializationError error = deserializeJson(doc, payload);
|
||||||
|
|
||||||
if (error) {
|
if (error) {
|
||||||
Serial.print("Fehler beim JSON-Parsing: ");
|
Serial.print("Fehler beim JSON-Parsing: ");
|
||||||
Serial.println(error.c_str());
|
Serial.println(error.c_str());
|
||||||
return 0;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Überprüfe, ob die erforderlichen Felder vorhanden sind
|
// Überprüfe, ob die erforderlichen Felder vorhanden sind
|
||||||
if (!doc.containsKey("sm_id") || doc["sm_id"] == "") {
|
if (!doc.containsKey("sm_id") || doc["sm_id"] == "") {
|
||||||
Serial.println("Keine Spoolman-ID gefunden.");
|
Serial.println("Keine Spoolman-ID gefunden.");
|
||||||
return 0;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
String spoolsUrl = spoolmanUrl + apiUrl + "/spool/" + doc["sm_id"].as<String>();
|
String spoolsUrl = spoolmanUrl + apiUrl + "/spool/" + doc["sm_id"].as<String>();
|
||||||
@ -207,7 +207,7 @@ uint8_t updateSpoolTagId(String uidString, const char* payload) {
|
|||||||
SendToApiParams* params = new SendToApiParams();
|
SendToApiParams* params = new SendToApiParams();
|
||||||
if (params == nullptr) {
|
if (params == nullptr) {
|
||||||
Serial.println("Fehler: Kann Speicher für Task-Parameter nicht allokieren.");
|
Serial.println("Fehler: Kann Speicher für Task-Parameter nicht allokieren.");
|
||||||
return 0;
|
return false;
|
||||||
}
|
}
|
||||||
params->httpType = "PATCH";
|
params->httpType = "PATCH";
|
||||||
params->spoolsUrl = spoolsUrl;
|
params->spoolsUrl = spoolsUrl;
|
||||||
@ -223,7 +223,7 @@ uint8_t updateSpoolTagId(String uidString, const char* payload) {
|
|||||||
NULL // Task-Handle (nicht benötigt)
|
NULL // Task-Handle (nicht benötigt)
|
||||||
);
|
);
|
||||||
|
|
||||||
return 1;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t updateSpoolWeight(String spoolId, uint16_t weight) {
|
uint8_t updateSpoolWeight(String spoolId, uint16_t weight) {
|
||||||
|
@ -17,7 +17,7 @@ bool checkSpoolmanExtraFields(); // Neue Funktion zum Überprüfen der Extrafeld
|
|||||||
JsonDocument fetchSpoolsForWebsite(); // API-Funktion für die Webseite
|
JsonDocument fetchSpoolsForWebsite(); // API-Funktion für die Webseite
|
||||||
JsonDocument fetchAllSpoolsInfo();
|
JsonDocument fetchAllSpoolsInfo();
|
||||||
void sendAmsData(AsyncWebSocketClient *client); // Neue Funktion zum Senden von AMS-Daten
|
void sendAmsData(AsyncWebSocketClient *client); // Neue Funktion zum Senden von AMS-Daten
|
||||||
uint8_t updateSpoolTagId(String uidString, const char* payload); // Neue Funktion zum Aktualisieren eines Spools
|
bool updateSpoolTagId(String uidString, const char* payload); // Neue Funktion zum Aktualisieren eines Spools
|
||||||
uint8_t updateSpoolWeight(String spoolId, uint16_t weight); // Neue Funktion zum Aktualisieren des Gewichts
|
uint8_t updateSpoolWeight(String spoolId, uint16_t weight); // Neue Funktion zum Aktualisieren des Gewichts
|
||||||
bool initSpoolman(); // Neue Funktion zum Initialisieren von Spoolman
|
bool initSpoolman(); // Neue Funktion zum Initialisieren von Spoolman
|
||||||
|
|
||||||
|
79
src/nfc.cpp
79
src/nfc.cpp
@ -93,14 +93,6 @@ bool formatNdefTag() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
uint8_t ntag2xx_WriteNDEF(const char *payload) {
|
uint8_t ntag2xx_WriteNDEF(const char *payload) {
|
||||||
/*
|
|
||||||
if (!formatNdefTag()) {
|
|
||||||
Serial.println("Fehler beim Formatieren des NDEF-Tags.");
|
|
||||||
hasReadRfidTag = 2;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
uint8_t tagSize = 240; // 144 bytes is maximum for NTAG213
|
uint8_t tagSize = 240; // 144 bytes is maximum for NTAG213
|
||||||
Serial.print("Tag Size: ");Serial.println(tagSize);
|
Serial.print("Tag Size: ");Serial.println(tagSize);
|
||||||
|
|
||||||
@ -137,9 +129,6 @@ uint8_t ntag2xx_WriteNDEF(const char *payload) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Serial.println();
|
|
||||||
//Serial.print("Header Size: ");Serial.println(sizeof(pageHeader));
|
|
||||||
|
|
||||||
// Kombiniere Header und Payload
|
// Kombiniere Header und Payload
|
||||||
int totalSize = sizeof(pageHeader) + len;
|
int totalSize = sizeof(pageHeader) + len;
|
||||||
uint8_t* combinedData = (uint8_t*) malloc(totalSize);
|
uint8_t* combinedData = (uint8_t*) malloc(totalSize);
|
||||||
@ -149,37 +138,10 @@ uint8_t ntag2xx_WriteNDEF(const char *payload) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Überprüfe die Kombination von Header und Payload
|
|
||||||
/*
|
|
||||||
Serial.print("Header: ");
|
|
||||||
for (int i = 0; i < sizeof(pageHeader); i++) {
|
|
||||||
Serial.print(pageHeader[i], HEX);
|
|
||||||
Serial.print(" ");
|
|
||||||
}
|
|
||||||
Serial.println();
|
|
||||||
|
|
||||||
Serial.print("Payload: ");
|
|
||||||
for (int i = 0; i < len; i++) {
|
|
||||||
Serial.print(payload[i], HEX);
|
|
||||||
Serial.print(" ");
|
|
||||||
}
|
|
||||||
Serial.println();
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Kombiniere Header und Payload
|
// Kombiniere Header und Payload
|
||||||
memcpy(combinedData, pageHeader, sizeof(pageHeader));
|
memcpy(combinedData, pageHeader, sizeof(pageHeader));
|
||||||
memcpy(&combinedData[sizeof(pageHeader)], payload, len);
|
memcpy(&combinedData[sizeof(pageHeader)], payload, len);
|
||||||
|
|
||||||
// Überprüfe die Kombination von Header und Payload
|
|
||||||
/*
|
|
||||||
Serial.print("Kombinierte Daten: ");
|
|
||||||
for (int i = 0; i < totalSize; i++) {
|
|
||||||
Serial.print(combinedData[i], HEX);
|
|
||||||
Serial.print(" ");
|
|
||||||
}
|
|
||||||
Serial.println();
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Schreibe die Seiten
|
// Schreibe die Seiten
|
||||||
uint8_t a = 0;
|
uint8_t a = 0;
|
||||||
uint8_t i = 0;
|
uint8_t i = 0;
|
||||||
@ -188,21 +150,9 @@ uint8_t ntag2xx_WriteNDEF(const char *payload) {
|
|||||||
int bytesToWrite = (totalSize < 4) ? totalSize : 4;
|
int bytesToWrite = (totalSize < 4) ? totalSize : 4;
|
||||||
memcpy(pageBuffer, combinedData + a, bytesToWrite);
|
memcpy(pageBuffer, combinedData + a, bytesToWrite);
|
||||||
|
|
||||||
// Überprüfe die Schreibung der Seiten
|
//uint8_t uid[] = { 0, 0, 0, 0, 0, 0, 0 }; // Buffer to store the returned UID
|
||||||
/*
|
//uint8_t uidLength;
|
||||||
Serial.print("Seite ");
|
//nfc.readPassiveTargetID(PN532_MIFARE_ISO14443A, uid, &uidLength, 100);
|
||||||
Serial.print(i);
|
|
||||||
Serial.print(": ");
|
|
||||||
for (int j = 0; j < bytesToWrite; j++) {
|
|
||||||
Serial.print(pageBuffer[j], HEX);
|
|
||||||
Serial.print(" ");
|
|
||||||
}
|
|
||||||
Serial.println();
|
|
||||||
*/
|
|
||||||
uint8_t uid[] = { 0, 0, 0, 0, 0, 0, 0 }; // Buffer to store the returned UID
|
|
||||||
uint8_t uidLength;
|
|
||||||
nfc.readPassiveTargetID(PN532_MIFARE_ISO14443A, uid, &uidLength, 500);
|
|
||||||
//Serial.print("Schreibe Seite: ");Serial.println(i);
|
|
||||||
|
|
||||||
if (!(nfc.ntag2xx_WritePage(4+i, pageBuffer)))
|
if (!(nfc.ntag2xx_WritePage(4+i, pageBuffer)))
|
||||||
{
|
{
|
||||||
@ -211,8 +161,6 @@ uint8_t ntag2xx_WriteNDEF(const char *payload) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Serial.print("Seite geschrieben: ");Serial.println(i);
|
|
||||||
|
|
||||||
yield();
|
yield();
|
||||||
//esp_task_wdt_reset();
|
//esp_task_wdt_reset();
|
||||||
|
|
||||||
@ -285,11 +233,15 @@ void writeJsonToTag(void *parameter) {
|
|||||||
|
|
||||||
// Gib die erstellte NDEF-Message aus
|
// Gib die erstellte NDEF-Message aus
|
||||||
Serial.println("Erstelle NDEF-Message...");
|
Serial.println("Erstelle NDEF-Message...");
|
||||||
|
Serial.println(payload);
|
||||||
|
|
||||||
hasReadRfidTag = 3;
|
hasReadRfidTag = 3;
|
||||||
vTaskSuspend(RfidReaderTask);
|
vTaskSuspend(RfidReaderTask);
|
||||||
|
vTaskDelay(500 / portTICK_PERIOD_MS);
|
||||||
//pauseBambuMqttTask = true;
|
//pauseBambuMqttTask = true;
|
||||||
// aktualisieren der Website wenn sich der Status ändert
|
// aktualisieren der Website wenn sich der Status ändert
|
||||||
sendNfcData(nullptr);
|
sendNfcData(nullptr);
|
||||||
|
oledShowMessage("Waiting for NFC-Tag");
|
||||||
|
|
||||||
// Wait 10sec for tag
|
// Wait 10sec for tag
|
||||||
uint8_t success = 0;
|
uint8_t success = 0;
|
||||||
@ -326,13 +278,21 @@ void writeJsonToTag(void *parameter) {
|
|||||||
Serial.println("NDEF-Message erfolgreich auf den Tag geschrieben");
|
Serial.println("NDEF-Message erfolgreich auf den Tag geschrieben");
|
||||||
//oledShowMessage("NFC-Tag written");
|
//oledShowMessage("NFC-Tag written");
|
||||||
oledShowIcon("success");
|
oledShowIcon("success");
|
||||||
vTaskDelay(2000 / portTICK_PERIOD_MS);
|
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
||||||
hasReadRfidTag = 5;
|
hasReadRfidTag = 5;
|
||||||
// aktualisieren der Website wenn sich der Status ändert
|
// aktualisieren der Website wenn sich der Status ändert
|
||||||
sendNfcData(nullptr);
|
sendNfcData(nullptr);
|
||||||
vTaskResume(RfidReaderTask);
|
|
||||||
pauseBambuMqttTask = false;
|
pauseBambuMqttTask = false;
|
||||||
updateSpoolTagId(uidString, payload);
|
if (updateSpoolTagId(uidString, payload)) {
|
||||||
|
uint8_t uid[] = { 0, 0, 0, 0, 0, 0, 0 }; // Buffer to store the returned UID
|
||||||
|
uint8_t uidLength;
|
||||||
|
oledShowIcon("success");
|
||||||
|
while (nfc.readPassiveTargetID(PN532_MIFARE_ISO14443A, uid, &uidLength, 500)) {
|
||||||
|
yield();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
vTaskResume(RfidReaderTask);
|
||||||
|
vTaskDelay(500 / portTICK_PERIOD_MS);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -362,6 +322,8 @@ void writeJsonToTag(void *parameter) {
|
|||||||
void startWriteJsonToTag(const char* payload) {
|
void startWriteJsonToTag(const char* payload) {
|
||||||
char* payloadCopy = strdup(payload);
|
char* payloadCopy = strdup(payload);
|
||||||
|
|
||||||
|
// Task nicht mehrfach starten
|
||||||
|
if (hasReadRfidTag != 3) {
|
||||||
// Erstelle die Task
|
// Erstelle die Task
|
||||||
xTaskCreate(
|
xTaskCreate(
|
||||||
writeJsonToTag, // Task-Funktion
|
writeJsonToTag, // Task-Funktion
|
||||||
@ -371,6 +333,7 @@ void startWriteJsonToTag(const char* payload) {
|
|||||||
rfidWriteTaskPrio, // Priorität
|
rfidWriteTaskPrio, // Priorität
|
||||||
NULL // Task-Handle (nicht benötigt)
|
NULL // Task-Handle (nicht benötigt)
|
||||||
);
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void scanRfidTask(void * parameter) {
|
void scanRfidTask(void * parameter) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user