Compare commits
	
		
			24 Commits
		
	
	
		
			v1.5.12-be
			...
			v1.5.12-be
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| bda8c3dd98 | |||
| 8702469020 | |||
| 2a0f999f3b | |||
| c89adb6256 | |||
| 1f21954703 | |||
| 3e59ce1366 | |||
| 1f880fc8f1 | |||
| 69bf5f90fa | |||
| 382caeaced | |||
| 47bdf022ec | |||
| 02febfa943 | |||
| 257f4df800 | |||
| bff6e72219 | |||
| 26e905050d | |||
| 046f770a52 | |||
| 2587227e78 | |||
| 0f19dc4f46 | |||
| 721dac1ead | |||
| 08abd1a37f | |||
| da78861613 | |||
| 9231a303f3 | |||
| d12e766cd7 | |||
| af7bc23703 | |||
| de39892f64 | 
							
								
								
									
										51
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										51
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,56 @@ | ||||
| # Changelog | ||||
|  | ||||
| ## [1.5.12-beta15] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta15 | ||||
| - enhance NFC write operation diagnostics and improve error handling | ||||
| - enhance NFC write operation handling and prevent tag operations during write | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta14] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta14 | ||||
| - optimize JSON payload structure and enhance NFC tag validation process | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta13] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta13 | ||||
| - reorganize clearUserDataArea function for improved clarity and safety | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta12] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta12 | ||||
|  | ||||
| ### Fixed | ||||
| - reset NFC state on API send failure to allow retry | ||||
| - update createdFilamentId reset value to 65535 for better task handling | ||||
| - update createdVendorId reset value to 65535 for improved API handling | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta11] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta11 | ||||
|  | ||||
| ### Fixed | ||||
| - update spoolman ID reset values to 65535 for better API response detection | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta10] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta10 | ||||
| - streamline task creation in checkVendor and checkFilament functions | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta9] - 2025-08-29 | ||||
| ### Added | ||||
| - update vendor and filament ID handling to use NULL and add delays for stability | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta9 | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta8] - 2025-08-29 | ||||
| ### Added | ||||
| - add delay to ensure proper setting of vendor and filament IDs after API state changes | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
| ; https://docs.platformio.org/page/projectconf.html | ||||
|  | ||||
| [common] | ||||
| version = "1.5.12-beta8" | ||||
| version = "1.5.12-beta15" | ||||
| to_old_version = "1.5.0" | ||||
|  | ||||
| ## | ||||
|   | ||||
							
								
								
									
										96
									
								
								src/api.cpp
									
									
									
									
									
								
							
							
						
						
									
										96
									
								
								src/api.cpp
									
									
									
									
									
								
							| @@ -5,6 +5,7 @@ | ||||
| #include <Preferences.h> | ||||
| #include "debug.h" | ||||
| #include "scale.h" | ||||
| #include "nfc.h" | ||||
| #include <time.h> | ||||
| volatile spoolmanApiStateType spoolmanApiState = API_IDLE; | ||||
|  | ||||
| @@ -151,7 +152,7 @@ void sendToApi(void *parameter) { | ||||
|     else httpCode = http.PUT(updatePayload); | ||||
|  | ||||
|     if (httpCode == HTTP_CODE_OK) { | ||||
|         Serial.println("Spoolman erfolgreich aktualisiert"); | ||||
|         Serial.println("Spoolman Abfrage erfolgreich"); | ||||
|  | ||||
|         // Restgewicht der Spule auslesen | ||||
|         String payload = http.getString(); | ||||
| @@ -345,9 +346,8 @@ void sendToApi(void *parameter) { | ||||
|             break; | ||||
|         } | ||||
|         Serial.println("Fehler beim Senden an Spoolman! HTTP Code: " + String(httpCode)); | ||||
|  | ||||
|         // TBD: really required? | ||||
|         vTaskDelay(2000 / portTICK_PERIOD_MS); | ||||
|         nfcReaderState = NFC_IDLE; // Reset NFC state to allow retry | ||||
|     } | ||||
|  | ||||
|     http.end(); | ||||
| @@ -617,7 +617,7 @@ uint16_t createVendor(String vendor) { | ||||
|     // Create new vendor in Spoolman database using task system | ||||
|     // Note: Due to async nature, the ID will be stored in createdVendorId global variable | ||||
|     // Note: This function assumes that the caller has already ensured API is IDLE | ||||
|     createdVendorId = 0; // Reset previous value | ||||
|     createdVendorId = 65535; // Reset previous value | ||||
|      | ||||
|     String spoolsUrl = spoolmanUrl + apiUrl + "/vendor"; | ||||
|     Serial.print("Create vendor with URL: "); | ||||
| @@ -667,8 +667,8 @@ uint16_t createVendor(String vendor) { | ||||
|      | ||||
|     // Wait for task completion and return the created vendor ID | ||||
|     // Note: createdVendorId will be set by sendToApi when response is received | ||||
|     while(spoolmanApiState != API_IDLE) { | ||||
|         vTaskDelay(100 / portTICK_PERIOD_MS); | ||||
|     while(createdVendorId == 65535) { | ||||
|         vTaskDelay(50 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|      | ||||
|     return createdVendorId; | ||||
| @@ -676,7 +676,7 @@ uint16_t createVendor(String vendor) { | ||||
|  | ||||
| uint16_t checkVendor(String vendor) { | ||||
|     // Check if vendor exists using task system | ||||
|     foundVendorId = 0; // Reset previous value | ||||
|     foundVendorId = 65535; // Reset to invalid value to detect when API response is received | ||||
|      | ||||
|     String vendorName = vendor; | ||||
|     vendorName.trim(); | ||||
| @@ -696,7 +696,11 @@ uint16_t checkVendor(String vendor) { | ||||
|     params->updatePayload = ""; // Empty for GET request | ||||
|  | ||||
|     // Check if API is idle before creating task | ||||
|     if(spoolmanApiState == API_IDLE){ | ||||
|     while (spoolmanApiState != API_IDLE) | ||||
|     { | ||||
|         vTaskDelay(100 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|      | ||||
|     // Erstelle die Task | ||||
|     BaseType_t result = xTaskCreate( | ||||
|         sendToApi,                // Task-Funktion | ||||
| @@ -706,19 +710,12 @@ uint16_t checkVendor(String vendor) { | ||||
|         0,                        // Priorität | ||||
|         NULL                      // Task-Handle (nicht benötigt) | ||||
|     ); | ||||
|     } else { | ||||
|         Serial.println("Not spawning new task, API still active!"); | ||||
|         delete params; | ||||
|         return 0; | ||||
|     } | ||||
|      | ||||
|     // Wait for task completion | ||||
|     while(spoolmanApiState != API_IDLE) { | ||||
|         vTaskDelay(100 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|      | ||||
|     // Additional delay to ensure foundVendorId is properly set after API state becomes IDLE | ||||
|     // Wait until foundVendorId is updated by the API response (not 65535 anymore) | ||||
|     while (foundVendorId == 65535) | ||||
|     { | ||||
|         vTaskDelay(50 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|  | ||||
|     // Check if vendor was found | ||||
|     if (foundVendorId == 0) { | ||||
| @@ -743,7 +740,7 @@ uint16_t createFilament(uint16_t vendorId, const JsonDocument& payload) { | ||||
|     // Create new filament in Spoolman database using task system | ||||
|     // Note: Due to async nature, the ID will be stored in createdFilamentId global variable | ||||
|     // Note: This function assumes that the caller has already ensured API is IDLE | ||||
|     createdFilamentId = 0; // Reset previous value | ||||
|     createdFilamentId = 65535; // Reset previous value | ||||
|      | ||||
|     String spoolsUrl = spoolmanUrl + apiUrl + "/filament"; | ||||
|     Serial.print("Create filament with URL: "); | ||||
| @@ -759,8 +756,8 @@ uint16_t createFilament(uint16_t vendorId, const JsonDocument& payload) { | ||||
|     filamentDoc["weight"] = String(weight); | ||||
|     filamentDoc["spool_weight"] = payload["spool_weight"].as<String>(); | ||||
|     filamentDoc["article_number"] = payload["artnr"].as<String>(); | ||||
|     filamentDoc["extruder_temp"] = payload["extruder_temp"].is<String>() ? payload["extruder_temp"].as<String>() : ""; | ||||
|     filamentDoc["bed_temp"] = payload["bed_temp"].is<String>() ? payload["bed_temp"].as<String>() : ""; | ||||
|     filamentDoc["settings_extruder_temp"] = payload["extruder_temp"].is<String>() ? payload["extruder_temp"].as<String>() : ""; | ||||
|     filamentDoc["settings_bed_temp"] = payload["bed_temp"].is<String>() ? payload["bed_temp"].as<String>() : ""; | ||||
|      | ||||
|     if (payload["artnr"].is<String>()) | ||||
|     { | ||||
| @@ -818,8 +815,8 @@ uint16_t createFilament(uint16_t vendorId, const JsonDocument& payload) { | ||||
|      | ||||
|     // Wait for task completion and return the created filament ID | ||||
|     // Note: createdFilamentId will be set by sendToApi when response is received | ||||
|     while(spoolmanApiState != API_IDLE) { | ||||
|         vTaskDelay(100 / portTICK_PERIOD_MS); | ||||
|     while(createdFilamentId == 65535) { | ||||
|         vTaskDelay(50 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|      | ||||
|     return createdFilamentId; | ||||
| @@ -827,7 +824,7 @@ uint16_t createFilament(uint16_t vendorId, const JsonDocument& payload) { | ||||
|  | ||||
| uint16_t checkFilament(uint16_t vendorId, const JsonDocument& payload) { | ||||
|     // Check if filament exists using task system | ||||
|     foundFilamentId = 0; // Reset previous value | ||||
|     foundFilamentId = 65535; // Reset to invalid value to detect when API response is received | ||||
|  | ||||
|     String spoolsUrl = spoolmanUrl + apiUrl + "/filament?vendor.id=" + String(vendorId) + "&external_id=" + String(payload["artnr"].as<String>()); | ||||
|     Serial.print("Check filament with URL: "); | ||||
| @@ -843,8 +840,6 @@ uint16_t checkFilament(uint16_t vendorId, const JsonDocument& payload) { | ||||
|     params->spoolsUrl = spoolsUrl; | ||||
|     params->updatePayload = ""; // Empty for GET request | ||||
|  | ||||
|     // Check if API is idle before creating task | ||||
|     if(spoolmanApiState == API_IDLE){ | ||||
|      // Erstelle die Task | ||||
|     BaseType_t result = xTaskCreate( | ||||
|         sendToApi,                // Task-Funktion | ||||
| @@ -854,19 +849,11 @@ uint16_t checkFilament(uint16_t vendorId, const JsonDocument& payload) { | ||||
|         0,                        // Priorität | ||||
|         NULL                      // Task-Handle (nicht benötigt) | ||||
|     ); | ||||
|     } else { | ||||
|         Serial.println("Not spawning new task, API still active!"); | ||||
|         delete params; | ||||
|         return 0; | ||||
|     } | ||||
|      | ||||
|     // Wait for task completion | ||||
|     while(spoolmanApiState != API_IDLE) { | ||||
|         vTaskDelay(100 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|      | ||||
|     // Additional delay to ensure foundFilamentId is properly set after API state becomes IDLE | ||||
|     // Wait until foundFilamentId is updated by the API response (not 65535 anymore) | ||||
|     while (foundFilamentId == 65535) { | ||||
|         vTaskDelay(50 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|  | ||||
|     // Check if filament was found | ||||
|     if (foundFilamentId == 0) { | ||||
| @@ -891,22 +878,21 @@ uint16_t createSpool(uint16_t vendorId, uint16_t filamentId, JsonDocument& paylo | ||||
|     // Create new spool in Spoolman database using task system | ||||
|     // Note: Due to async nature, the ID will be stored in createdSpoolId global variable | ||||
|     // Note: This function assumes that the caller has already ensured API is IDLE | ||||
|     createdSpoolId = 0; // Reset previous value | ||||
|     createdSpoolId = 65535; // Reset to invalid value to detect when API response is received | ||||
|      | ||||
|     String spoolsUrl = spoolmanUrl + apiUrl + "/spool"; | ||||
|     Serial.print("Create spool with URL: "); | ||||
|     Serial.println(spoolsUrl); | ||||
|     String currentDate = getCurrentDateISO8601(); | ||||
|     //String currentDate = getCurrentDateISO8601(); | ||||
|  | ||||
|     // Create JSON payload for spool creation | ||||
|     JsonDocument spoolDoc; | ||||
|     //spoolDoc["first_used"] = String(currentDate); | ||||
|     //spoolDoc["last_used"] = String(currentDate); | ||||
|     spoolDoc["filament_id"] = String(filamentId); | ||||
|     spoolDoc["initial_weight"] = weight > 10 ? String(weight) : "1000"; | ||||
|     spoolDoc["initial_weight"] = weight > 10 ? String(weight-payload["spool_weight"].as<int>()) : "1000"; | ||||
|     spoolDoc["spool_weight"] = (payload["spool_weight"].is<String>() && payload["spool_weight"].as<String>().length() > 0) ? payload["spool_weight"].as<String>() : "180"; | ||||
|     spoolDoc["remaining_weight"] = (payload["weight"].is<String>() && payload["weight"].as<String>().length() > 0) ? payload["weight"].as<String>() : "1000"; | ||||
|     spoolDoc["used_weight"] = "0"; | ||||
|     spoolDoc["lot_nr"] = (payload["lotnr"].is<String>() && payload["lotnr"].as<String>().length() > 0) ? payload["lotnr"].as<String>() : ""; | ||||
|     spoolDoc["comment"] = "automatically generated"; | ||||
|     spoolDoc["extra"]["nfc_id"] = "\"" + uidString + "\""; | ||||
| @@ -946,16 +932,34 @@ uint16_t createSpool(uint16_t vendorId, uint16_t filamentId, JsonDocument& paylo | ||||
|      | ||||
|     // Wait for task completion and return the created spool ID | ||||
|     // Note: createdSpoolId will be set by sendToApi when response is received | ||||
|     while(spoolmanApiState != API_IDLE) { | ||||
|         vTaskDelay(100 / portTICK_PERIOD_MS); | ||||
|     while(createdSpoolId == 65535) { | ||||
|         vTaskDelay(50 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|  | ||||
|     // Write data to tag with startWriteJsonToTag | ||||
|     // void startWriteJsonToTag(const bool isSpoolTag, const char* payload); | ||||
|     payload["sm_id"].set(String(createdSpoolId)); | ||||
|      | ||||
|     // Create optimized JSON structure with sm_id at the beginning for fast-path detection | ||||
|     JsonDocument optimizedPayload; | ||||
|     optimizedPayload["sm_id"] = String(createdSpoolId);  // Place sm_id first for fast scanning | ||||
|      | ||||
|     // Copy all other fields from original payload (excluding sm_id if it exists) | ||||
|     for (JsonPair kv : payload.as<JsonObject>()) { | ||||
|         if (strcmp(kv.key().c_str(), "sm_id") != 0) {  // Skip sm_id to avoid duplication | ||||
|             optimizedPayload[kv.key()] = kv.value(); | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     String payloadString; | ||||
|     serializeJson(payload, payloadString); | ||||
|     serializeJson(optimizedPayload, payloadString); | ||||
|      | ||||
|     Serial.println("Optimized JSON with sm_id first:"); | ||||
|     Serial.println(payloadString); | ||||
|      | ||||
|     optimizedPayload.clear(); | ||||
|      | ||||
|     nfcReaderState = NFC_IDLE; | ||||
|     vTaskDelay(50 / portTICK_PERIOD_MS); | ||||
|     startWriteJsonToTag(true, payloadString.c_str()); | ||||
|  | ||||
|     return createdSpoolId; | ||||
|   | ||||
							
								
								
									
										982
									
								
								src/nfc.cpp
									
									
									
									
									
								
							
							
						
						
									
										982
									
								
								src/nfc.cpp
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -16,6 +16,7 @@ typedef enum{ | ||||
| void startNfc(); | ||||
| void scanRfidTask(void * parameter); | ||||
| void startWriteJsonToTag(const bool isSpoolTag, const char* payload); | ||||
| bool quickSpoolIdCheck(String uidString); | ||||
|  | ||||
| extern TaskHandle_t RfidReaderTask; | ||||
| extern String nfcJsonData; | ||||
| @@ -23,6 +24,7 @@ extern String activeSpoolId; | ||||
| extern String lastSpoolId; | ||||
| extern volatile nfcReaderStateType nfcReaderState; | ||||
| extern volatile bool pauseBambuMqttTask; | ||||
| extern volatile bool nfcWriteInProgress; | ||||
| extern bool tagProcessed; | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -49,8 +49,7 @@ void scale_loop(void * parameter) { | ||||
|   Serial.println("++++++++++++++++++++++++++++++"); | ||||
|  | ||||
|   vTaskDelay(pdMS_TO_TICKS(500)); | ||||
|   scale.tare(); | ||||
|   vTaskDelay(pdMS_TO_TICKS(500)); | ||||
|   scale_tare_counter = 10; // damit beim Starten der Waage automatisch getart wird | ||||
|    | ||||
|   for(;;) { | ||||
|     if (scale.is_ready())  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user