Compare commits
	
		
			330 Commits
		
	
	
		
			v1.5.6
			...
			v2.0.0-bet
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 63fafa2463 | |||
| f664e85933 | |||
| 7bf9868d79 | |||
| b9e488d675 | |||
| 2e3fc19741 | |||
| 4d84169b29 | |||
| 10aeb9bc52 | |||
| 00b9bc08af | |||
| dfe9e4dbe9 | |||
| 79eacae225 | |||
| d5d7358f58 | |||
| 9b362b3c73 | |||
| bc51956793 | |||
| 5666a58da2 | |||
| a35f15eca5 | |||
| f28b34e427 | |||
| 9215560558 | |||
| 7f6bce1699 | |||
| 2a4f8bb679 | |||
| 480e2da23e | |||
| ba22602767 | |||
| b2c68d5aac | |||
| 52a7f6b5b6 | |||
| 4cce9f8d5d | |||
| f0eced8585 | |||
| 02e31878ee | |||
| 7ff499f984 | |||
| fcd637cc30 | |||
| 587485d0de | |||
| e0cc99e993 | |||
| d9a8388ac7 | |||
| cb77112976 | |||
| 1c0ddb52ba | |||
| 17f03e9472 | |||
| 213b9c099c | |||
| 687e57b77a | |||
| aea11e0c06 | |||
| bd8f4606c6 | |||
| ac91e71c14 | |||
| 0d3503f4f1 | |||
| 1460c6e5f9 | |||
| fef7e5aa4b | |||
| bda8c3dd98 | |||
| 8702469020 | |||
| 2a0f999f3b | |||
| c89adb6256 | |||
| 1f21954703 | |||
| 3e59ce1366 | |||
| 1f880fc8f1 | |||
| 69bf5f90fa | |||
| 382caeaced | |||
| 47bdf022ec | |||
| 02febfa943 | |||
| 257f4df800 | |||
| bff6e72219 | |||
| 26e905050d | |||
| 046f770a52 | |||
| 2587227e78 | |||
| 0f19dc4f46 | |||
| 721dac1ead | |||
| 08abd1a37f | |||
| da78861613 | |||
| 9231a303f3 | |||
| d12e766cd7 | |||
| af7bc23703 | |||
| de39892f64 | |||
| 40cb835e51 | |||
| eb9d9e74f4 | |||
| d8af3f45e5 | |||
| 96bb8f9c7c | |||
| b8b6893cd0 | |||
| 0a246c1fe4 | |||
| 965ea5da1e | |||
| b8b6f637f2 | |||
| 12044b657b | |||
| 95433b4842 | |||
| 54275f2ac9 | |||
| fbd9cb66f1 | |||
| f1cdd3f41d | |||
| d897817020 | |||
| 686eb22232 | |||
| a2816da654 | |||
| cc8f1cfd7b | |||
| d195f76d5e | |||
| 6bed3b086c | |||
| 3dd4b82710 | |||
| bc41205f15 | |||
| f450d1efdf | |||
| 6e94092a74 | |||
| ece510099e | |||
| 1f01af4da9 | |||
| c5d24d5972 | |||
| 48556b9519 | |||
| 2ac8effe04 | |||
| 4e58407af8 | |||
| d776956c5e | |||
| 25233f70d5 | |||
| b4584364d6 | |||
| 33ea062773 | |||
| 771b0a4839 | |||
| c48003e1b2 | |||
| 83dec4c876 | |||
| dca9ef8d08 | |||
| 513e02b867 | |||
| 99babe2b4a | |||
| c17ab2c434 | |||
| ec7386922e | |||
| 1eb81fad5d | |||
| 9d406e3428 | |||
| 5c2db22a90 | |||
| 164c7b2af5 | |||
| cd1c93c485 | |||
| 15219fa1e4 | |||
| 206db69e6d | |||
| 9e67af7343 | |||
| 9e58b042c8 | |||
| 55200d31cd | |||
| 65967ca047 | |||
| 86e5f7e48a | |||
| e4d1ba6c1c | |||
| 7ccdde8489 | |||
| 88598611c5 | |||
| 619979ab14 | |||
| 377f4bc146 | |||
| 174c48f734 | |||
| 7cbd34bc91 | |||
| fdeb6d5b61 | |||
| f7484f635e | |||
| fb7dca38f0 | |||
| 90ce30215f | |||
|  | 69ae5cab5f | ||
|  | 5fa93f2695 | ||
|  | 0e00fd8b91 | ||
|  | 4706152022 | ||
|  | accb02ab80 | ||
|  | 5509d98969 | ||
|  | d7ee52ba1f | ||
|  | a7c99d3f26 | ||
|  | 0a02912e4a | ||
|  | 89a5728cc0 | ||
|  | f133a1b321 | ||
|  | b95497aec2 | ||
| 876e9c62d8 | |||
| 765cb5319d | |||
| 9a9ed175dd | |||
| a156cac18e | |||
|  | 5b04c2eb80 | ||
|  | 09f4c43f89 | ||
|  | b94db80321 | ||
|  | ec0e544f30 | ||
|  | d815733550 | ||
|  | b6d82c8afe | ||
|  | afef544c66 | ||
|  | 97a1368747 | ||
|  | 6b6aec07b3 | ||
|  | 85a9bcf8bd | ||
|  | 852a2f4c69 | ||
|  | c450df59aa | ||
|  | 4b81703e38 | ||
|  | 722ef421cb | ||
| 7ba0c4f933 | |||
| b0cd731c5a | |||
| d0b793a300 | |||
| f022bee578 | |||
| 7c320a87fe | |||
| 3286b64836 | |||
| 0777b6371d | |||
| fcdf91071c | |||
| ffb1117150 | |||
| c317610229 | |||
| 73c3457f40 | |||
| cf62e12aa4 | |||
|  | b583ef71ad | ||
|  | b991f2ee27 | ||
|  | e2e0a23f0a | ||
|  | 537f452601 | ||
|  | faaffee391 | ||
|  | d536181a73 | ||
| e38220739d | |||
| fc48d6e67c | |||
| aeb61ba462 | |||
|  | 7f25f3e14f | ||
| 150a178038 | |||
| 8b43f34a86 | |||
| 7a85ce6a04 | |||
| 68fa1e77a1 | |||
| 9c06fe6725 | |||
| 1cf392c1cd | |||
|  | 69d6ba4bcb | ||
|  | 21ec4e0ff3 | ||
| c2a09b21a0 | |||
| 0937a9e9f0 | |||
| 818b8387c0 | |||
| 3f2beb6f54 | |||
| 56248ff2cb | |||
| 6a4945666e | |||
| 97d1519489 | |||
| f608c4a19b | |||
| aa2eb91d64 | |||
| 35d2445c6c | |||
| 537607ed40 | |||
| 7e330dca1a | |||
| d943d15c0a | |||
| a345b76cd2 | |||
| 836e48bde2 | |||
| a6a8c69aee | |||
| ddb4cd8e53 | |||
| d45313a3ff | |||
| 70350e19f8 | |||
| 7613effccf | |||
| 7280d5be7f | |||
| ada4a84942 | |||
| e32aa6ec51 | |||
| 04a18469b5 | |||
| 1c4d5f3874 | |||
| a2eb57cd7a | |||
| 1c619c5bcb | |||
| 2e05651f88 | |||
| f1b803a3c1 | |||
| 5c4ba9f0ba | |||
| 19d70301f5 | |||
| 4fa21d3c0e | |||
| f22a01127c | |||
| 92d377713d | |||
| 8732c81bb9 | |||
| e7bbf45a9f | |||
| a8ce964add | |||
|  | 69f01d1e57 | ||
|  | 99231786a5 | ||
| 8536b4f8fa | |||
| c84c5fa734 | |||
| 2a60e149b9 | |||
| 7e486191b7 | |||
| 610479bc5a | |||
| b7fa53da7e | |||
| 629b4276cf | |||
| cb15dae87e | |||
|  | abed1c9806 | ||
| db1f33c2b6 | |||
| 174a58906c | |||
| 20cc9b196b | |||
| ff80b05502 | |||
| edfdef53f4 | |||
| 89a3fed7a9 | |||
| f44173824f | |||
| 169d73bfc0 | |||
| c78f36d21a | |||
| 054bc43f65 | |||
| 31c41576ee | |||
| 3a744bc1e6 | |||
| 42f76fc20a | |||
|  | 124f326670 | ||
| af34ce45dd | |||
| c0cb3ff5c9 | |||
| 4c754d84ff | |||
| d2c85018f5 | |||
| 8dac49ea9e | |||
| 5365c0e1b9 | |||
|  | 4abe9d6d33 | ||
| e5d0334714 | |||
| 16364cbd86 | |||
| 1b63ab668f | |||
| f67ef8e905 | |||
| a490b77860 | |||
| 52d063b619 | |||
| d5c005d6f7 | |||
| 68866f1632 | |||
| a4200e469d | |||
| e5e14dfc99 | |||
| 863d591a17 | |||
| 69675f3c06 | |||
| 2ae3df1aab | |||
| 3910da9fb5 | |||
| 26d53929ac | |||
| 64e3461264 | |||
| bc04db91b8 | |||
| f500f8bd11 | |||
| 84391faffd | |||
| aae93de7dd | |||
| 0f847a2731 | |||
| aa7fc7e64b | |||
|  | e0f5f48cc4 | ||
|  | 0b79891f83 | ||
|  | 11c5ca3383 | ||
|  | e3c3b3f42d | ||
|  | 8db7765e7e | ||
|  | dc97740ddc | ||
|  | ababe8b842 | ||
|  | 62bcbb2ae8 | ||
|  | 62330a3fd8 | ||
|  | 4556730c6e | ||
|  | c92a8b0957 | ||
|  | b08da071c2 | ||
|  | 9c949e74e8 | ||
|  | 17fcf765fd | ||
|  | 95a03f92e2 | ||
|  | d9e69d8c14 | ||
|  | 1ec09ebf3a | ||
|  | 7ef0cc44d5 | ||
|  | fe962b2bfa | ||
|  | aec07f3c6d | ||
|  | b5cb5b17ea | ||
|  | c3e7758920 | ||
|  | 66395028a6 | ||
|  | 64403b9599 | ||
|  | ebf6688701 | ||
|  | 073a5f4539 | ||
|  | 69bd5c3eb2 | ||
| a328fbc6a6 | |||
| 6f52cd1686 | |||
| c1122ad87d | |||
|  | 1aeced76a2 | ||
| 967ec35c6a | |||
| f60113aa83 | |||
| 63a7398979 | |||
| 40cb504251 | |||
| 41a4f8af4a | |||
| e122224472 | |||
| 5d3a8d971f | |||
| e62e5e7062 | |||
| 726a60882d | |||
| 2918b4ca77 | |||
| 955ba0f001 | |||
| 8cf7dc0b77 | |||
| 33e4b371ed | |||
| fd832d8808 | |||
| c0e213a4ac | |||
| bcc00f711b | |||
| 78f336d5d7 | |||
| ee7f8ff517 | 
							
								
								
									
										40
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										40
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,8 +1,42 @@ | ||||
| .pio | ||||
| .vscode/.browse.c_cpp.db* | ||||
| .vscode/ | ||||
| .aider* | ||||
| .DS_Store | ||||
| ._* | ||||
| **/.DS_Store | ||||
| **/.Spotlight-V100 | ||||
| **/.Trashes | ||||
| **/.fseventsd | ||||
| .AppleDouble | ||||
| **/.DS_Store | ||||
| **/.Spotlight-V100 | ||||
| **/.Trashes | ||||
| **/.fseventsd | ||||
| .AppleDouble | ||||
| .aider.chat.history.md | ||||
| .aider.input.history | ||||
| .DS_Store | ||||
| .gitignore | ||||
| .aider.tags.cache.v3/cache.db | ||||
| .aider.tags.cache.v3/cache.db-shm | ||||
| .aider.tags.cache.v3/cache.db-wal | ||||
| .vscode/c_cpp_properties.json | ||||
| .vscode/launch.json | ||||
| .vscode/ipch | ||||
| .vscode/extensions.json | ||||
| .vscode/settings.json | ||||
| data | ||||
| .vscode/launch.json | ||||
| include/README | ||||
| lib/README | ||||
| test/README | ||||
| .aider* | ||||
| data/* | ||||
| !data/ | ||||
| !data/.gitkeep | ||||
| # important | ||||
| html/bambu_credentials.json | ||||
| html/spoolman_url.json | ||||
| _local/* | ||||
| website/* | ||||
| release.sh | ||||
| .github/copilot-instructions.md | ||||
| data | ||||
							
								
								
									
										775
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										775
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,780 @@ | ||||
| # Changelog | ||||
|  | ||||
| ## [2.0.0-beta8] - 2025-08-30 | ||||
| ### Breaking Changes | ||||
| - enhance commit categorization for breaking changes | ||||
| - Handling of Spools with Tags from Vendors. fix: improve get_last_tag function to handle non-beta tags and fallback to newest tag | ||||
|  | ||||
| ### Added | ||||
| - implement robust page reading with error recovery for NFC tags | ||||
| - enhance NFC tag reading with robust error recovery and JSON optimization for fast-path detection | ||||
| - implement robust page reading and safe tag detection with error recovery | ||||
| - add Manufacturer Tags support documentation in German and English | ||||
| - add display delay for vendor, filament, and spool creation processes | ||||
| - add progress bar updates for vendor and filament creation processes | ||||
| - update vendor and filament ID handling to use NULL and add delays for stability | ||||
| - add delay to ensure proper setting of vendor and filament IDs after API state changes | ||||
| - enhance NDEF decoding with detailed validation and debugging output | ||||
| - enhance NDEF decoding to validate structure and extract JSON payload | ||||
| - add logging for decoded JSON data in NFC processing | ||||
| - implement filament and spool creation in Spoolman API | ||||
| - Add JSON structure comments for filament and spool creation | ||||
| - Add vendor and filament management to API; implement recycling factory handling in NFC | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v2.0.0-beta8 | ||||
| - update changelog and header for version v2.0.0-beta7 | ||||
| - update platformio.ini for beta version v2.0.0-beta7 | ||||
| - update changelog and header for version v2.0.0-beta6 | ||||
| - update changelog and header for version v2.0.0-beta6 | ||||
| - update platformio.ini for beta version v2.0.0-beta6 | ||||
| - update changelog and header for version v2.0.0-beta5 | ||||
| - update platformio.ini for beta version v2.0.0-beta5 | ||||
| - update changelog and header for version v2.0.0-beta4 | ||||
| - update platformio.ini for beta version v2.0.0-beta4 | ||||
| - update changelog and header for version v2.0.0-beta3 | ||||
| - update platformio.ini for beta version v2.0.0-beta3 | ||||
| - update createVendor and checkVendor functions to accept JsonDocument payload | ||||
| - update changelog and header for version v2.0.0-beta2 | ||||
| - update platformio.ini for beta version v2.0.0-beta2 | ||||
| - clarify product URL description for Manufacturer Tags in German and English documentation | ||||
| - update changelog and header for version v2.0.0-beta1 | ||||
| - update platformio.ini for beta version v2.0.0-beta1 | ||||
| - update version to 2.0.0 in platformio.ini | ||||
| - update changelog and header for version v1.5.12-beta18 | ||||
| - update platformio.ini for beta version v1.5.12-beta18 | ||||
| - update changelog and header for version v1.5.12-beta17 | ||||
| - update platformio.ini for beta version v1.5.12-beta17 | ||||
| - optimize page limit detection and remove redundant verification code | ||||
| - update changelog and header for version v1.5.12-beta16 | ||||
| - update platformio.ini for beta version v1.5.12-beta16 | ||||
| - Refactor NFC interface handling and improve error diagnostics | ||||
| - update changelog and header for version v1.5.12-beta15 | ||||
| - 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 | ||||
| - update changelog and header for version v1.5.12-beta14 | ||||
| - update platformio.ini for beta version v1.5.12-beta14 | ||||
| - optimize JSON payload structure and enhance NFC tag validation process | ||||
| - update changelog and header for version v1.5.12-beta13 | ||||
| - update platformio.ini for beta version v1.5.12-beta13 | ||||
| - reorganize clearUserDataArea function for improved clarity and safety | ||||
| - update changelog and header for version v1.5.12-beta12 | ||||
| - update platformio.ini for beta version v1.5.12-beta12 | ||||
| - update changelog and header for version v1.5.12-beta11 | ||||
| - update platformio.ini for beta version v1.5.12-beta11 | ||||
| - update changelog and header for version v1.5.12-beta10 | ||||
| - update platformio.ini for beta version v1.5.12-beta10 | ||||
| - streamline task creation in checkVendor and checkFilament functions | ||||
| - update changelog and header for version v1.5.12-beta9 | ||||
| - update platformio.ini for beta version v1.5.12-beta9 | ||||
| - update changelog and header for version v1.5.12-beta8 | ||||
| - update platformio.ini for beta version v1.5.12-beta8 | ||||
| - update changelog and header for version v1.5.12-beta7 | ||||
| - update platformio.ini for beta version v1.5.12-beta7 | ||||
| - update changelog and header for version v1.5.12-beta6 | ||||
| - update platformio.ini for beta version v1.5.12-beta6 | ||||
| - improve task synchronization in vendor, filament, and spool creation functions | ||||
| - update changelog and header for version v1.5.12-beta5 | ||||
| - update platformio.ini for beta version v1.5.12-beta5 | ||||
| - update changelog and header for version v1.5.12-beta4 | ||||
| - update platformio.ini for beta version v1.5.12-beta4 | ||||
| - update changelog and header for version v1.5.12-beta3 | ||||
| - update platformio.ini for beta version v1.5.12-beta3 | ||||
| - update changelog and header for version v1.5.12-beta2 | ||||
| - update platformio.ini for beta version v1.5.12-beta2 | ||||
| - update changelog and header for version v1.5.12-beta1 | ||||
| - update platformio.ini for beta version v1.5.12-beta1 | ||||
| - Merge branch 'main' into recyclingfabrik | ||||
| - Merge branch 'main' into recyclingfabrik | ||||
|  | ||||
| ### Fixed | ||||
| - call scale.tare() in setup after starting scale | ||||
| - update createVendor function to use external_id as comment instead of static text | ||||
| - update to_old_version in platformio.ini to reflect correct previous version | ||||
| - increase delay in start_scale function for improved stability | ||||
| - replace progress bar with message display for remaining weight in sendToApi function | ||||
| - update vendor check to use shorthand key in payload | ||||
| - 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 | ||||
| - update spoolman ID reset values to 65535 for better API response detection | ||||
| - correct color_hex key usage and comment out unused date fields in spool creation | ||||
| - improve API state handling and vendor name formatting | ||||
| - enhance filament creation logic to include dynamic comments based on payload | ||||
|  | ||||
|  | ||||
| ## [2.0.0-beta7] - 2025-08-30 | ||||
| ### Breaking Changes | ||||
| - enhance commit categorization for breaking changes | ||||
| - Handling of Spools with Tags from Vendors. fix: improve get_last_tag function to handle non-beta tags and fallback to newest tag | ||||
|  | ||||
| ### Added | ||||
| - enhance NFC tag reading with robust error recovery and JSON optimization for fast-path detection | ||||
| - implement robust page reading and safe tag detection with error recovery | ||||
| - add Manufacturer Tags support documentation in German and English | ||||
| - add display delay for vendor, filament, and spool creation processes | ||||
| - add progress bar updates for vendor and filament creation processes | ||||
| - update vendor and filament ID handling to use NULL and add delays for stability | ||||
| - add delay to ensure proper setting of vendor and filament IDs after API state changes | ||||
| - enhance NDEF decoding with detailed validation and debugging output | ||||
| - enhance NDEF decoding to validate structure and extract JSON payload | ||||
| - add logging for decoded JSON data in NFC processing | ||||
| - implement filament and spool creation in Spoolman API | ||||
| - Add JSON structure comments for filament and spool creation | ||||
| - Add vendor and filament management to API; implement recycling factory handling in NFC | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v2.0.0-beta7 | ||||
| - update changelog and header for version v2.0.0-beta6 | ||||
| - update changelog and header for version v2.0.0-beta6 | ||||
| - update platformio.ini for beta version v2.0.0-beta6 | ||||
| - update changelog and header for version v2.0.0-beta5 | ||||
| - update platformio.ini for beta version v2.0.0-beta5 | ||||
| - update changelog and header for version v2.0.0-beta4 | ||||
| - update platformio.ini for beta version v2.0.0-beta4 | ||||
| - update changelog and header for version v2.0.0-beta3 | ||||
| - update platformio.ini for beta version v2.0.0-beta3 | ||||
| - update createVendor and checkVendor functions to accept JsonDocument payload | ||||
| - update changelog and header for version v2.0.0-beta2 | ||||
| - update platformio.ini for beta version v2.0.0-beta2 | ||||
| - clarify product URL description for Manufacturer Tags in German and English documentation | ||||
| - update changelog and header for version v2.0.0-beta1 | ||||
| - update platformio.ini for beta version v2.0.0-beta1 | ||||
| - update version to 2.0.0 in platformio.ini | ||||
| - update changelog and header for version v1.5.12-beta18 | ||||
| - update platformio.ini for beta version v1.5.12-beta18 | ||||
| - update changelog and header for version v1.5.12-beta17 | ||||
| - update platformio.ini for beta version v1.5.12-beta17 | ||||
| - optimize page limit detection and remove redundant verification code | ||||
| - update changelog and header for version v1.5.12-beta16 | ||||
| - update platformio.ini for beta version v1.5.12-beta16 | ||||
| - Refactor NFC interface handling and improve error diagnostics | ||||
| - update changelog and header for version v1.5.12-beta15 | ||||
| - 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 | ||||
| - update changelog and header for version v1.5.12-beta14 | ||||
| - update platformio.ini for beta version v1.5.12-beta14 | ||||
| - optimize JSON payload structure and enhance NFC tag validation process | ||||
| - update changelog and header for version v1.5.12-beta13 | ||||
| - update platformio.ini for beta version v1.5.12-beta13 | ||||
| - reorganize clearUserDataArea function for improved clarity and safety | ||||
| - update changelog and header for version v1.5.12-beta12 | ||||
| - update platformio.ini for beta version v1.5.12-beta12 | ||||
| - update changelog and header for version v1.5.12-beta11 | ||||
| - update platformio.ini for beta version v1.5.12-beta11 | ||||
| - update changelog and header for version v1.5.12-beta10 | ||||
| - update platformio.ini for beta version v1.5.12-beta10 | ||||
| - streamline task creation in checkVendor and checkFilament functions | ||||
| - update changelog and header for version v1.5.12-beta9 | ||||
| - update platformio.ini for beta version v1.5.12-beta9 | ||||
| - update changelog and header for version v1.5.12-beta8 | ||||
| - update platformio.ini for beta version v1.5.12-beta8 | ||||
| - update changelog and header for version v1.5.12-beta7 | ||||
| - update platformio.ini for beta version v1.5.12-beta7 | ||||
| - update changelog and header for version v1.5.12-beta6 | ||||
| - update platformio.ini for beta version v1.5.12-beta6 | ||||
| - improve task synchronization in vendor, filament, and spool creation functions | ||||
| - update changelog and header for version v1.5.12-beta5 | ||||
| - update platformio.ini for beta version v1.5.12-beta5 | ||||
| - update changelog and header for version v1.5.12-beta4 | ||||
| - update platformio.ini for beta version v1.5.12-beta4 | ||||
| - update changelog and header for version v1.5.12-beta3 | ||||
| - update platformio.ini for beta version v1.5.12-beta3 | ||||
| - update changelog and header for version v1.5.12-beta2 | ||||
| - update platformio.ini for beta version v1.5.12-beta2 | ||||
| - update changelog and header for version v1.5.12-beta1 | ||||
| - update platformio.ini for beta version v1.5.12-beta1 | ||||
| - Merge branch 'main' into recyclingfabrik | ||||
| - Merge branch 'main' into recyclingfabrik | ||||
|  | ||||
| ### Fixed | ||||
| - call scale.tare() in setup after starting scale | ||||
| - update createVendor function to use external_id as comment instead of static text | ||||
| - update to_old_version in platformio.ini to reflect correct previous version | ||||
| - increase delay in start_scale function for improved stability | ||||
| - replace progress bar with message display for remaining weight in sendToApi function | ||||
| - update vendor check to use shorthand key in payload | ||||
| - 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 | ||||
| - update spoolman ID reset values to 65535 for better API response detection | ||||
| - correct color_hex key usage and comment out unused date fields in spool creation | ||||
| - improve API state handling and vendor name formatting | ||||
| - enhance filament creation logic to include dynamic comments based on payload | ||||
|  | ||||
|  | ||||
| ## [2.0.0-beta6] - 2025-08-30 | ||||
| ### Breaking Changes | ||||
| - enhance commit categorization for breaking changes | ||||
| - Handling of Spools with Tags from Vendors. fix: improve get_last_tag function to handle non-beta tags and fallback to newest tag | ||||
|  | ||||
| ### Added | ||||
| - implement robust page reading and safe tag detection with error recovery | ||||
| - add Manufacturer Tags support documentation in German and English | ||||
| - add display delay for vendor, filament, and spool creation processes | ||||
| - add progress bar updates for vendor and filament creation processes | ||||
| - update vendor and filament ID handling to use NULL and add delays for stability | ||||
| - add delay to ensure proper setting of vendor and filament IDs after API state changes | ||||
| - enhance NDEF decoding with detailed validation and debugging output | ||||
| - enhance NDEF decoding to validate structure and extract JSON payload | ||||
| - add logging for decoded JSON data in NFC processing | ||||
| - implement filament and spool creation in Spoolman API | ||||
| - Add JSON structure comments for filament and spool creation | ||||
| - Add vendor and filament management to API; implement recycling factory handling in NFC | ||||
|  | ||||
| ### Changed | ||||
| - update changelog and header for version v2.0.0-beta6 | ||||
| - update platformio.ini for beta version v2.0.0-beta6 | ||||
| - update changelog and header for version v2.0.0-beta5 | ||||
| - update platformio.ini for beta version v2.0.0-beta5 | ||||
| - update changelog and header for version v2.0.0-beta4 | ||||
| - update platformio.ini for beta version v2.0.0-beta4 | ||||
| - update changelog and header for version v2.0.0-beta3 | ||||
| - update platformio.ini for beta version v2.0.0-beta3 | ||||
| - update createVendor and checkVendor functions to accept JsonDocument payload | ||||
| - update changelog and header for version v2.0.0-beta2 | ||||
| - update platformio.ini for beta version v2.0.0-beta2 | ||||
| - clarify product URL description for Manufacturer Tags in German and English documentation | ||||
| - update changelog and header for version v2.0.0-beta1 | ||||
| - update platformio.ini for beta version v2.0.0-beta1 | ||||
| - update version to 2.0.0 in platformio.ini | ||||
| - update changelog and header for version v1.5.12-beta18 | ||||
| - update platformio.ini for beta version v1.5.12-beta18 | ||||
| - update changelog and header for version v1.5.12-beta17 | ||||
| - update platformio.ini for beta version v1.5.12-beta17 | ||||
| - optimize page limit detection and remove redundant verification code | ||||
| - update changelog and header for version v1.5.12-beta16 | ||||
| - update platformio.ini for beta version v1.5.12-beta16 | ||||
| - Refactor NFC interface handling and improve error diagnostics | ||||
| - update changelog and header for version v1.5.12-beta15 | ||||
| - 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 | ||||
| - update changelog and header for version v1.5.12-beta14 | ||||
| - update platformio.ini for beta version v1.5.12-beta14 | ||||
| - optimize JSON payload structure and enhance NFC tag validation process | ||||
| - update changelog and header for version v1.5.12-beta13 | ||||
| - update platformio.ini for beta version v1.5.12-beta13 | ||||
| - reorganize clearUserDataArea function for improved clarity and safety | ||||
| - update changelog and header for version v1.5.12-beta12 | ||||
| - update platformio.ini for beta version v1.5.12-beta12 | ||||
| - update changelog and header for version v1.5.12-beta11 | ||||
| - update platformio.ini for beta version v1.5.12-beta11 | ||||
| - update changelog and header for version v1.5.12-beta10 | ||||
| - update platformio.ini for beta version v1.5.12-beta10 | ||||
| - streamline task creation in checkVendor and checkFilament functions | ||||
| - update changelog and header for version v1.5.12-beta9 | ||||
| - update platformio.ini for beta version v1.5.12-beta9 | ||||
| - update changelog and header for version v1.5.12-beta8 | ||||
| - update platformio.ini for beta version v1.5.12-beta8 | ||||
| - update changelog and header for version v1.5.12-beta7 | ||||
| - update platformio.ini for beta version v1.5.12-beta7 | ||||
| - update changelog and header for version v1.5.12-beta6 | ||||
| - update platformio.ini for beta version v1.5.12-beta6 | ||||
| - improve task synchronization in vendor, filament, and spool creation functions | ||||
| - update changelog and header for version v1.5.12-beta5 | ||||
| - update platformio.ini for beta version v1.5.12-beta5 | ||||
| - update changelog and header for version v1.5.12-beta4 | ||||
| - update platformio.ini for beta version v1.5.12-beta4 | ||||
| - update changelog and header for version v1.5.12-beta3 | ||||
| - update platformio.ini for beta version v1.5.12-beta3 | ||||
| - update changelog and header for version v1.5.12-beta2 | ||||
| - update platformio.ini for beta version v1.5.12-beta2 | ||||
| - update changelog and header for version v1.5.12-beta1 | ||||
| - update platformio.ini for beta version v1.5.12-beta1 | ||||
| - Merge branch 'main' into recyclingfabrik | ||||
| - Merge branch 'main' into recyclingfabrik | ||||
|  | ||||
| ### Fixed | ||||
| - call scale.tare() in setup after starting scale | ||||
| - update createVendor function to use external_id as comment instead of static text | ||||
| - update to_old_version in platformio.ini to reflect correct previous version | ||||
| - increase delay in start_scale function for improved stability | ||||
| - replace progress bar with message display for remaining weight in sendToApi function | ||||
| - update vendor check to use shorthand key in payload | ||||
| - 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 | ||||
| - update spoolman ID reset values to 65535 for better API response detection | ||||
| - correct color_hex key usage and comment out unused date fields in spool creation | ||||
| - improve API state handling and vendor name formatting | ||||
| - enhance filament creation logic to include dynamic comments based on payload | ||||
|  | ||||
| ## [2.0.0-beta5] - 2025-08-30 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v2.0.0-beta5 | ||||
|  | ||||
| ### Fixed | ||||
| - call scale.tare() in setup after starting scale | ||||
|  | ||||
|  | ||||
| ## [2.0.0-beta4] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v2.0.0-beta4 | ||||
|  | ||||
| ### Fixed | ||||
| - update createVendor function to use external_id as comment instead of static text | ||||
| - update to_old_version in platformio.ini to reflect correct previous version | ||||
|  | ||||
|  | ||||
| ## [2.0.0-beta3] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v2.0.0-beta3 | ||||
| - update createVendor and checkVendor functions to accept JsonDocument payload | ||||
|  | ||||
|  | ||||
| ## [2.0.0-beta2] - 2025-08-29 | ||||
| ### Added | ||||
| - add Manufacturer Tags support documentation in German and English | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v2.0.0-beta2 | ||||
| - clarify product URL description for Manufacturer Tags in German and English documentation | ||||
|  | ||||
| ### Fixed | ||||
| - increase delay in start_scale function for improved stability | ||||
|  | ||||
|  | ||||
| ## [2.0.0-beta1] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v2.0.0-beta1 | ||||
| - update version to 2.0.0 in platformio.ini | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta18] - 2025-08-29 | ||||
| ### Added | ||||
| - add display delay for vendor, filament, and spool creation processes | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta18 | ||||
|  | ||||
| ### Fixed | ||||
| - replace progress bar with message display for remaining weight in sendToApi function | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta17] - 2025-08-29 | ||||
| ### Added | ||||
| - add progress bar updates for vendor and filament creation processes | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta17 | ||||
| - optimize page limit detection and remove redundant verification code | ||||
|  | ||||
| ### Fixed | ||||
| - update vendor check to use shorthand key in payload | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta16] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta16 | ||||
| - Refactor NFC interface handling and improve error diagnostics | ||||
|  | ||||
|  | ||||
| ## [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 | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta8 | ||||
|  | ||||
| ### Fixed | ||||
| - correct color_hex key usage and comment out unused date fields in spool creation | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta7] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta7 | ||||
|  | ||||
| ### Fixed | ||||
| - improve API state handling and vendor name formatting | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta6] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta6 | ||||
| - improve task synchronization in vendor, filament, and spool creation functions | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta5] - 2025-08-29 | ||||
| ### Added | ||||
| - enhance NDEF decoding with detailed validation and debugging output | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta5 | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta4] - 2025-08-29 | ||||
| ### Added | ||||
| - enhance NDEF decoding to validate structure and extract JSON payload | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta4 | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta3] - 2025-08-29 | ||||
| ### Added | ||||
| - add logging for decoded JSON data in NFC processing | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta3 | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta2] - 2025-08-29 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta2 | ||||
|  | ||||
| ### Fixed | ||||
| - enhance filament creation logic to include dynamic comments based on payload | ||||
|  | ||||
|  | ||||
| ## [1.5.12-beta1] - 2025-08-28 | ||||
| ### Added | ||||
| - implement filament and spool creation in Spoolman API | ||||
| - Add JSON structure comments for filament and spool creation | ||||
| - Add vendor and filament management to API; implement recycling factory handling in NFC | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.12-beta1 | ||||
| - Merge branch 'main' into recyclingfabrik | ||||
| - Merge branch 'main' into recyclingfabrik | ||||
|  | ||||
|  | ||||
| ## [1.5.12] - 2025-08-28 | ||||
| ### Added | ||||
| - add numbering to update sections in upgrade.html refactor: improve readability of checkSpoolmanInstance function | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for version v1.5.12 | ||||
| - clean up library dependencies in platformio.ini | ||||
|  | ||||
|  | ||||
| ## [1.5.11-beta4] - 2025-08-28 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.11-beta4 | ||||
|  | ||||
| ### Fixed | ||||
| - remove debug logging from checkSpoolmanInstance function | ||||
|  | ||||
|  | ||||
| ## [1.5.11-beta3] - 2025-08-28 | ||||
| ### Added | ||||
| - add logging for spoolman status in checkSpoolmanInstance function | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.11-beta3 | ||||
|  | ||||
|  | ||||
| ## [1.5.11-beta2] - 2025-08-28 | ||||
| ### Added | ||||
| - add logging for healthy spoolman instance check | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.11-beta2 | ||||
|  | ||||
|  | ||||
| ## [1.5.11-beta1] - 2025-08-28 | ||||
| ### Changed | ||||
| - update platformio.ini for beta version v1.5.11-beta1 | ||||
|  | ||||
| ### Fixed | ||||
| - adjust spacing in loop structure and enable tare function in scale loop | ||||
|  | ||||
|  | ||||
| ## [1.5.11] - 2025-08-27 | ||||
| ### Changed | ||||
| - update platformio.ini for version v1.5.11 | ||||
|  | ||||
|  | ||||
| ## [1.5.10] - 2025-08-27 | ||||
| ### Added | ||||
| - improve weight processing logic and add auto-send feature for Bambu spool ID | ||||
| - improve weight processing logic and add auto-send feature for Bambu spool ID | ||||
| - Adds a link to the spool in spoolman when reading a spool tag | ||||
| - Fixes types and some issues in the new graphics | ||||
| - Adds ENABLE_HEAP_DEBUGGING define as comment to the build flags | ||||
| - Adds data directory and further .vscode files to to .gitignore | ||||
| - Introduces new heap debugging feature and fixes some memory leaks in website feature | ||||
| - Fixes some issues with the new location tags | ||||
| - Adds new feature to write and read location tags | ||||
| - Adds slight debouncing to the scale loop weight logic | ||||
| - add loadcell desc. | ||||
| - implement multi-color filament display and styles for dropdown options | ||||
| - add remaining weight logging for PUT requests and improve error reporting in sendToApi function | ||||
| - add remaining weight logging and display after successful spool update | ||||
| - add weight field to update payload in updateSpoolTagId function | ||||
| - add auto-tare functionality and update scale handling based on touch sensor connection | ||||
| - add touch sensor connection check and update logic | ||||
| - add manual tare functionality for scale | ||||
| - add debounce handling for TTP223 touch sensor | ||||
| - add TTP223 touch sensor support and wiring configuration | ||||
| - Renamed states of NFC state machine and introduced new state machine for spoolman API | ||||
| - add forced cache refresh after removing and saving Bambu credentials | ||||
| - add functionality to remove Bambu credentials and update API handling | ||||
| - add rfid_bambu.html and update bambu connection handling | ||||
| - add error handling for missing vendor IDs in filament data | ||||
| - add WiFi connection check and restart Bambu if not connected | ||||
| - added new .step, now with correct individual parts | ||||
| - added changelog | ||||
| - Add files via upload | ||||
| - added .stp files of modifications | ||||
| - added merged picture | ||||
| - added pictures of components bought from AliE | ||||
| - Add files via upload | ||||
| - added pictures for heat insert location | ||||
| - added pictures showing heat insert location | ||||
| - remove unnecessary delay in MQTT setup and add delay before restart | ||||
| - add new 3D print file for Filaman scale | ||||
| - added Discord Server | ||||
| - add support for Spoolman Octoprint Plugin in README files | ||||
| - add OctoPrint integration with configurable fields and update functionality | ||||
| - add version comparison function and check for outdated versions before updates | ||||
| - remove unused version and protocol fields from JSON output; add error message for insufficient memory | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for version v1.5.10 | ||||
| - Merge branch 'main' of https://gitlab.fire-devils.org/3D-Druck/Filaman | ||||
| - Changed Amazon Link for PN532 | ||||
| - Changed Amazon Link for PN532 | ||||
| - update changelog and header for version v1.5.9 | ||||
| - update platformio.ini for version v1.5.9 | ||||
| - Enhance API to support weight updates after successful spool tag updates | ||||
| - update changelog and header for version v1.5.8 | ||||
| - update platformio.ini for version v1.5.8 | ||||
| - Merge pull request #45 from janecker/nfc_write_improvements | ||||
| - Introduces periodic Spoolman Healthcheck | ||||
| - Improves init - NFC reading now only starts after boot is finished | ||||
| - Further improvements on NFC writing | ||||
| - Merge pull request #44 from janecker/graphics_rework | ||||
| - Graphic rework of the NFC writing process | ||||
| - Remove unused parameter of sendNfcData() | ||||
| - Reworks startup graphics and timings | ||||
| - update changelog and header for version v1.5.7 | ||||
| - update platformio.ini for version v1.5.7 | ||||
| - clean up unused variables and improve .gitignore entries | ||||
| - update changelog and header for version v1.5.6 | ||||
| - update webpages for version v1.5.6 | ||||
| - update platformio.ini for version v1.5.6 | ||||
| - Merge pull request #42 from janecker/configuration_nvs_storage | ||||
| - Merge branch 'main' into configuration_nvs_storage | ||||
| - Changes configuration storage of spoolman and bambu values | ||||
| - update changelog and header for version v1.5.5 | ||||
| - update platformio.ini for version v1.5.5 | ||||
| - update changelog and header for version v1.5.4 | ||||
| - update platformio.ini for version v1.5.4 | ||||
| - Merge branch 'main' of github.com:ManuelW77/Filaman | ||||
| - Merge pull request #39 from janecker/location_tags | ||||
| - Merge pull request #38 from janecker/scale_debouncing | ||||
| - update changelog and header for version v1.5.3 | ||||
| - update platformio.ini for version v1.5.3 | ||||
| - Affiliate Links | ||||
| - update changelog and header for version v1.5.2 | ||||
| - update platformio.ini for version v1.5.2 | ||||
| - update changelog and header for version v1.5.1 | ||||
| - update version to 1.5.1 and improve OTA update handling with task management | ||||
| - update changelog and header for version v1.4.14 | ||||
| - update platformio.ini for version v1.4.14 | ||||
| - update changelog and header for version v1.4.13 | ||||
| - update platformio.ini for version v1.4.13 | ||||
| - update changelog and header for version v1.4.12 | ||||
| - update platformio.ini for version v1.4.12 | ||||
| - update README files to clarify PN532 DIP switch settings | ||||
| - update changelog and header for version v1.4.11 | ||||
| - update platformio.ini for version v1.4.11 | ||||
| - Merge branch 'main' of github.com:ManuelW77/Filaman | ||||
| - update changelog and header for version v1.4.10 | ||||
| - update platformio.ini for version v1.4.10 | ||||
| - Merge pull request #31 from janecker/nfc_rework | ||||
| - Introducing enum for handling the NFC state to improve code readability | ||||
| - update changelog and header for version v1.4.9 | ||||
| - update platformio.ini for version v1.4.9 | ||||
| - update changelog and header for version v1.4.8 | ||||
| - update platformio.ini for version v1.4.8 | ||||
| - Merge pull request #30 from janecker/main | ||||
| - Merge branch 'testing' into main | ||||
| - update changelog and header for version v1.4.7 | ||||
| - update platformio.ini for version v1.4.7 | ||||
| - Merge branch 'testing' | ||||
| - update remove button for Bambu credentials with red background | ||||
| - Merge pull request #28 from tugsi/main | ||||
| - update changelog and header for version v1.4.6 | ||||
| - update platformio.ini for version v1.4.6 | ||||
| - update changelog and header for version v1.4.5 | ||||
| - update platformio.ini for version v1.4.5 | ||||
| - Merge branch 'testing' | ||||
| - remove unused request_topic subscription and reduce MQTT task stack size | ||||
| - Merge pull request #26 from tugsi/main | ||||
| - rename report_topic to topic and update MQTT subscription logic, switched publish topic to request | ||||
| - update changelog and header for version v1.4.4 | ||||
| - update platformio.ini for version v1.4.4 | ||||
| - update changelog and header for version v1.4.3 | ||||
| - update platformio.ini for version v1.4.3 | ||||
| - update changelog and header for version v1.4.2 | ||||
| - update platformio.ini for version v1.4.2 | ||||
| - increase stack size for BambuMqtt task | ||||
| - update Discord Link | ||||
| - update Discord Link | ||||
| - remove commented-out subscription topic in MQTT setup | ||||
| - update changelog and header for version v1.4.1 | ||||
| - update platformio.ini for version v1.4.1 | ||||
| - refactor length calculation to convert total length to meters before formatting | ||||
| - Merge pull request #16 from spitzbirne32/main | ||||
| - improved housing to show display better | ||||
| - removed CAD, as they were all duplicates | ||||
| - typo in AliE link | ||||
| - Delete usermod/spitzbirne32/STL/README.md | ||||
| - Update README.md | ||||
| - moved pictures of parts into dedicated folders | ||||
| - Update README.md | ||||
| - Update README.md | ||||
| - Update README.md | ||||
| - Delete usermod/spitzbirne32/STL/ScaleTop_Heatinsert_Location_usermod_spitzbirne32_.png | ||||
| - Delete usermod/spitzbirne32/STL/Housing_Heatinsert_Location_usermod_spitzbirne32_.png | ||||
| - created folders | ||||
| - Update README.md | ||||
| - Update README.md | ||||
| - Create README.md | ||||
| - Update README.md | ||||
| - Update README.md | ||||
| - Create README.md | ||||
| - Merge pull request #15 from ManuelW77/main | ||||
| - Merge pull request #14 from janecker/scale-calibration-rework | ||||
| - Reworks the scale calibration handling | ||||
| - remove redundant scale calibration checks and enhance task management | ||||
| - enhance AMS data handling and streamline spool auto-setting logic | ||||
| - adjust stack size and improve scale calibration logic | ||||
| - update labels and input types for better clarity and functionality | ||||
| - update documentation for clarity and accuracy | ||||
| - update changelog and header for version v1.4.0 | ||||
| - update NFC tag references to include NTAG213 and clarify storage capacity | ||||
| - bump version to 1.4.0 | ||||
| - remove unused version and protocol fields from NFC data packet | ||||
| - sort vendors alphabetically in the dropdown list | ||||
| - Merge pull request #10 from janecker/nfc-improvements | ||||
|  | ||||
| ### Fixed | ||||
| - Fixes issue that scale not calibrated message was not shown | ||||
| - Improves NFC writing workaround and removes debug output | ||||
| - Fixes typos in upgrade page | ||||
| - Reworks graphics of tag reading and some api fixes | ||||
| - Replaces usage of String with const char* in heap debug function | ||||
| - Merge pull request #41 from janecker/memory_leak_fixes | ||||
| - Fixes compiler warnings in nfc | ||||
| - Memory leak fixes in api and nfc, location tag fix | ||||
| - Merge pull request #40 from janecker/location_bambu_fix | ||||
| - uncomment monitor_port configuration in platformio.ini | ||||
| - update spool weight conditionally based on NFC ID | ||||
| - update weight field in update payload to only include values greater than 10 | ||||
| - increase stack size for sendToApi task to improve stability | ||||
| - adjust tare weight tolerance to ignore deviations of 2g | ||||
| - improve weight stability check before sending to API | ||||
| - update touch sensor connection logic to correctly identify connection status | ||||
| - update TTP223 pin configuration and adjust touch sensor logic | ||||
| - enhance HTTP method handling in sendToApi function | ||||
| - improve HTTP client configuration and clear update documents after API calls | ||||
| - Fixes memory leak in HTTPClient by disabling connection reuse | ||||
| - update reload logic after removing and saving Bambu credentials for better cache handling | ||||
| - handle Bambu connection state by introducing bambuDisabled flag | ||||
| - handle potential undefined value for tray_info_idx in handleSpoolIn function, by @tugsi | ||||
| - Fix rfid.js-Failure with X1-Series, if you wanna send a Spool to AMS:  - Uncaught TypeError: Cannot read properties of undefined (reading 'replace')     at handleSpoolIn (rfid.js:493:67)     at HTMLButtonElement.onclick ((Index):1:1) handleSpoolIn	@	rfid.js:493 onclick	@	(Index):1 | ||||
| - increase MQTT buffer size and adjust task stack size | ||||
| - Fix BufferSize for larger JSONs from X-Series | ||||
| - adjust weight threshold for tare check to allow negative values | ||||
| - use unique client ID for MQTT connection to avoid conflicts | ||||
| - reload page after firmware update completion | ||||
| - increase WiFi connection timeout from 5 to 10 seconds | ||||
| - ensure valid URL format and remove trailing slash in setupWebserver | ||||
| - correct typo in console log for total length | ||||
|  | ||||
|  | ||||
| ## [1.5.9] - 2025-08-11 | ||||
| ### Changed | ||||
| - update platformio.ini for version v1.5.9 | ||||
| - Enhance API to support weight updates after successful spool tag updates | ||||
|  | ||||
|  | ||||
| ## [1.5.8] - 2025-08-10 | ||||
| ### Added | ||||
| - Adds a link to the spool in spoolman when reading a spool tag | ||||
| - Fixes types and some issues in the new graphics | ||||
|  | ||||
| ### Changed | ||||
| - update platformio.ini for version v1.5.8 | ||||
| - Merge pull request #45 from janecker/nfc_write_improvements | ||||
| - Introduces periodic Spoolman Healthcheck | ||||
| - Improves init - NFC reading now only starts after boot is finished | ||||
| - Further improvements on NFC writing | ||||
| - Merge pull request #44 from janecker/graphics_rework | ||||
| - Graphic rework of the NFC writing process | ||||
| - Remove unused parameter of sendNfcData() | ||||
| - Reworks startup graphics and timings | ||||
|  | ||||
| ### Fixed | ||||
| - Fixes issue that scale not calibrated message was not shown | ||||
| - Improves NFC writing workaround and removes debug output | ||||
| - Fixes typos in upgrade page | ||||
| - Reworks graphics of tag reading and some api fixes | ||||
| - Replaces usage of String with const char* in heap debug function | ||||
|  | ||||
|  | ||||
| ## [1.5.7] - 2025-07-28 | ||||
| ### Changed | ||||
| - update platformio.ini for version v1.5.7 | ||||
| - clean up unused variables and improve .gitignore entries | ||||
|  | ||||
|  | ||||
| ## [1.5.6] - 2025-07-28 | ||||
| ### Added | ||||
| - Adds ENABLE_HEAP_DEBUGGING define as comment to the build flags | ||||
|   | ||||
							
								
								
									
										30
									
								
								README.de.md
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								README.de.md
									
									
									
									
									
								
							| @@ -27,6 +27,7 @@ Discord Server: [https://discord.gg/my7Gvaxj2v](https://discord.gg/my7Gvaxj2v) | ||||
|     - Filamentdaten auf NFC-Tags schreiben. | ||||
|     - Verwendet das NFC-Tag-Format von [Openspool](https://github.com/spuder/OpenSpool) | ||||
|     - Ermöglicht automatische Spulenerkennung im AMS | ||||
|     - **Hersteller Tag Unterstützung:** Automatische Erstellung von Spoolman-Einträgen aus Hersteller NFC-Tags ([Mehr erfahren](README_ManufacturerTags_DE.md)) | ||||
| - **Bambulab AMS-Integration:**  | ||||
|   - Anzeige der aktuellen AMS-Fachbelegung. | ||||
|   - Zuordnung von Filamenten zu AMS-Slots. | ||||
| @@ -39,8 +40,35 @@ Discord Server: [https://discord.gg/my7Gvaxj2v](https://discord.gg/my7Gvaxj2v) | ||||
|   - Unterstützt das Spoolman Octoprint Plugin | ||||
|  | ||||
| ### Wenn Sie meine Arbeit unterstützen möchten, freue ich mich über einen Kaffee | ||||
|  | ||||
| <a href="https://www.buymeacoffee.com/manuelw" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt="Buy Me A Coffee" style="height: 30px !important;width: 108px !important;" ></a> | ||||
|  | ||||
| ## Hersteller Tags Unterstützung | ||||
|  | ||||
| 🎉 **Aufregende Neuigkeiten!** FilaMan unterstützt jetzt **Hersteller Tags** - NFC-Tags, die direkt von Filament-Herstellern vorprogrammiert geliefert werden! | ||||
|  | ||||
| ### Erster Hersteller-Partner: RecyclingFabrik | ||||
|  | ||||
| Wir freuen uns anzukündigen, dass [**RecyclingFabrik**](https://www.recyclingfabrik.de) der **erste Filament-Hersteller** sein wird, der FilaMan unterstützt, indem sie NFC-Tags im FilaMan-Format auf ihren Spulen anbieten! | ||||
|  | ||||
| **Demnächst verfügbar:** RecyclingFabrik-Spulen werden NFC-Tags enthalten, die sich automatisch in Ihr FilaMan-System integrieren, manuelle Einrichtung überflüssig machen und perfekte Kompatibilität gewährleisten. | ||||
|  | ||||
| ### Wie Hersteller Tags funktionieren | ||||
|  | ||||
| Wenn Sie zum ersten Mal einen Hersteller NFC-Tag scannen: | ||||
| 1. **Automatische Markenerkennung:** FilaMan erkennt den Hersteller und erstellt die Marke in Spoolman | ||||
| 2. **Filament-Typ Erstellung:** Alle Materialspezifikationen werden automatisch hinzugefügt | ||||
| 3. **Spulen-Registrierung:** Ihre spezifische Spule wird mit korrektem Gewicht und Spezifikationen registriert | ||||
| 4. **Zukünftige Schnellerkennung:** Nachfolgende Scans verwenden Fast-Path-Erkennung für sofortige Gewichtsmessung | ||||
|  | ||||
| **Für detaillierte technische Informationen:** [Hersteller Tags Dokumentation](README_ManufacturerTags_DE.md) | ||||
|  | ||||
| ### Vorteile für Benutzer | ||||
| - ✅ **Null manuelle Einrichtung** - Einfach scannen und wiegen | ||||
| - ✅ **Perfekte Datengenauigkeit** - Hersteller-verifizierte Spezifikationen | ||||
| - ✅ **Sofortige Integration** - Nahtlose Spoolman-Kompatibilität | ||||
| - ✅ **Zukunftssicher** - Tags funktionieren mit jedem FilaMan-kompatiblen System | ||||
|  | ||||
| ## Detaillierte Funktionalität | ||||
|  | ||||
| ### ESP32-Funktionalität | ||||
| @@ -62,7 +90,7 @@ Discord Server: [https://discord.gg/my7Gvaxj2v](https://discord.gg/my7Gvaxj2v) | ||||
| - **OLED 0.96 Zoll I2C white/yellow Display:** 128x64 SSD1306. | ||||
| [Amazon Link](https://amzn.to/445aaa9) | ||||
| - **PN532 NFC NXP RFID-Modul V3:** For NFC tag operations. | ||||
| [Amazon Link](https://amzn.to/4iO6CO4) | ||||
| [Amazon Link](https://amzn.eu/d/gy9vaBX) | ||||
| - **NFC Tags NTAG213 NTAG215:** RFID Tag | ||||
| [Amazon Link](https://amzn.to/3E071xO) | ||||
| - **TTP223 Touch Sensor (optional):** For reTARE per Button/Touch | ||||
|   | ||||
							
								
								
									
										30
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								README.md
									
									
									
									
									
								
							| @@ -31,6 +31,7 @@ Discord Server: [https://discord.gg/my7Gvaxj2v](https://discord.gg/my7Gvaxj2v) | ||||
| 	- Write filament data to NFC tags. | ||||
| 	- uses NFC-Tag Format of [Openspool](https://github.com/spuder/OpenSpool) | ||||
| 	- so you can use it with automatic Spool detection in AMS | ||||
| 	- **Manufacturer Tag Support:** Automatic creation of Spoolman entries from manufacturer NFC tags ([Learn more](README_ManufacturerTags_EN.md)) | ||||
| - **Bambulab AMS Integration:**  | ||||
|   - Display current AMS tray contents. | ||||
|   - Assign filaments to AMS slots. | ||||
| @@ -43,8 +44,35 @@ Discord Server: [https://discord.gg/my7Gvaxj2v](https://discord.gg/my7Gvaxj2v) | ||||
|   - Supports Spoolman Octoprint Plugin | ||||
|  | ||||
| ### If you want to support my work, i would be happy to get a coffe | ||||
|  | ||||
| <a href="https://www.buymeacoffee.com/manuelw" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt="Buy Me A Coffee" style="height: 30px !important;width: 108px !important;" ></a> | ||||
|  | ||||
| ## Manufacturer Tags Support | ||||
|  | ||||
| 🎉 **Exciting News!** FilaMan now supports **Manufacturer Tags** - NFC tags that come pre-programmed directly from filament manufacturers! | ||||
|  | ||||
| ### First Manufacturer Partner: RecyclingFabrik | ||||
|  | ||||
| We're thrilled to announce that [**RecyclingFabrik**](https://www.recyclingfabrik.de) will be the **first filament manufacturer** to support FilaMan by offering NFC tags in the FilaMan format on their spools! | ||||
|  | ||||
| **Coming Soon:** RecyclingFabrik spools will include NFC tags that automatically integrate with your FilaMan system, eliminating manual setup and ensuring perfect compatibility. | ||||
|  | ||||
| ### How Manufacturer Tags Work | ||||
|  | ||||
| When you scan a manufacturer NFC tag for the first time: | ||||
| 1. **Automatic Brand Detection:** FilaMan recognizes the manufacturer and creates the brand in Spoolman | ||||
| 2. **Filament Type Creation:** All material specifications are automatically added | ||||
| 3. **Spool Registration:** Your specific spool is registered with proper weight and specifications | ||||
| 4. **Future Fast Recognition:** Subsequent scans use fast-path detection for instant weight measurement | ||||
|  | ||||
| **For detailed technical information:** [Manufacturer Tags Documentation](README_ManufacturerTags_EN.md) | ||||
|  | ||||
| ### Benefits for Users | ||||
| - ✅ **Zero Manual Setup** - Just scan and weigh | ||||
| - ✅ **Perfect Data Accuracy** - Manufacturer-verified specifications | ||||
| - ✅ **Instant Integration** - Seamless Spoolman compatibility | ||||
| - ✅ **Future-Proof** - Tags work with any FilaMan-compatible system | ||||
|  | ||||
| ## Detailed Functionality | ||||
|  | ||||
| ### ESP32 Functionality | ||||
| @@ -66,7 +94,7 @@ Discord Server: [https://discord.gg/my7Gvaxj2v](https://discord.gg/my7Gvaxj2v) | ||||
| - **OLED 0.96 Zoll I2C white/yellow Display:** 128x64 SSD1306. | ||||
| [Amazon Link](https://amzn.to/445aaa9) | ||||
| - **PN532 NFC NXP RFID-Modul V3:** For NFC tag operations. | ||||
| [Amazon Link](https://amzn.to/4iO6CO4) | ||||
| [Amazon Link](https://amzn.eu/d/gy9vaBX) | ||||
| - **NFC Tags NTAG213 NTAG215:** RFID Tag | ||||
| [Amazon Link](https://amzn.to/3E071xO) | ||||
| - **TTP223 Touch Sensor (optional):** For reTARE per Button/Touch | ||||
|   | ||||
							
								
								
									
										159
									
								
								README_ManufacturerTags_DE.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										159
									
								
								README_ManufacturerTags_DE.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,159 @@ | ||||
| # Hersteller Tags - Deutsche Dokumentation | ||||
|  | ||||
| ## Überblick | ||||
|  | ||||
| Das FilaMan NFC-System unterstützt **Hersteller Tags**, die es Filament-Produzenten ermöglichen, standardisierte NFC-Tags für ihre Produkte zu erstellen. Beim Scannen dieser Tags werden automatisch die notwendigen Einträge in Spoolman (Marke, Filament-Typ und Spule) erstellt, ohne dass eine manuelle Einrichtung erforderlich ist. | ||||
|  | ||||
| ## Funktionsweise der Hersteller Tags | ||||
|  | ||||
| ### Ablauf | ||||
|  | ||||
| 1. **Tag-Erkennung**: Wenn ein Tag ohne `sm_id` gescannt wird, prüft das System auf Hersteller Tag Format | ||||
| 2. **Marken-Erstellung/Suche**: Das System sucht die Marke in Spoolman oder erstellt sie, falls sie nicht existiert | ||||
| 3. **Filament-Typ-Erstellung/Suche**: Der Filament-Typ wird basierend auf Marke, Material und Spezifikationen erstellt oder gefunden | ||||
| 4. **Spulen-Erstellung**: Ein neuer Spulen-Eintrag wird automatisch mit der Tag-UID als Referenz erstellt | ||||
| 5. **Tag-Update**: Der Tag wird mit der neuen Spoolman Spulen-ID (`sm_id`) aktualisiert | ||||
|  | ||||
| ### Warum Hersteller Tags verwenden? | ||||
|  | ||||
| - **Automatische Integration**: Keine manuelle Dateneingabe erforderlich | ||||
| - **Standardisiertes Format**: Konsistente Produktinformationen verschiedener Hersteller | ||||
| - **Lagerverwaltung**: Automatische Erstellung vollständiger Spoolman-Einträge | ||||
| - **Rückverfolgbarkeit**: Direkte Verbindung zwischen physischem Produkt und digitalem Inventar | ||||
|  | ||||
| ## Tag-Format Spezifikation | ||||
|  | ||||
| ### JSON-Struktur | ||||
|  | ||||
| Hersteller Tags müssen eine JSON-Payload mit spezifischen Feldern enthalten, die **kurze Schlüssel** verwenden, um die Tag-Größe zu minimieren: | ||||
|  | ||||
| ```json | ||||
| { | ||||
|     "b": "Marke/Hersteller Name", | ||||
|     "an": "Artikelnummer", | ||||
|     "t": "Filament Typ (PLA, PETG, etc)", | ||||
|     "c": "Filament Farbe ohne # (FF5733)", | ||||
|     "mc": "Optional Mehrfarben-Filament Farben ohne # (FF0000,00FF00,0000FF)", | ||||
|     "mcd": "Optional Mehrfarben-Richtung als Wort (coaxial, longitudinal)", | ||||
|     "cn": "Farbname (rot, Blaubeere, Arktisches Blau)", | ||||
|     "et": "Extruder Temp als Zahl in C° (230)", | ||||
|     "bt": "Bett Temp als Zahl in C° (60)", | ||||
|     "di": "Durchmesser als Float (1.75)", | ||||
|     "de": "Dichte als Float (1.24)", | ||||
|     "sw": "Leeres Spulengewicht als Zahl in g (180)", | ||||
|     "u": "URL zum Filament mit der Artikelnummer" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ### Pflichtfelder | ||||
|  | ||||
| - **`b`** (brand): Hersteller/Markenname | ||||
| - **`an`** (article number): Eindeutige Produktkennung | ||||
| - **`t`** (type): Materialtyp (PLA, PETG, ABS, etc.) | ||||
| - **`c`** (color): Hex-Farbcode ohne # | ||||
| - **`cn`** (color name): Lesbare Farbbezeichnung | ||||
| - **`et`** (extruder temp): Empfohlene Extruder-Temperatur in Celsius | ||||
| - **`bt`** (bed temp): Empfohlene Bett-Temperatur in Celsius | ||||
| - **`di`** (diameter): Filamentdurchmesser in mm | ||||
| - **`de`** (density): Materialdichte in g/cm³ | ||||
| - **`sw`** (spool weight): Leeres Spulengewicht in Gramm | ||||
|  | ||||
| ### Optionale Felder | ||||
|  | ||||
| - **`mc`** (multicolor): Komma-getrennte Hex-Farben für Mehrfarben-Filamente | ||||
| - **`mcd`** (multicolor direction): Richtung für Mehrfarben (coaxial, longitudinal) | ||||
| - **`u`** (url): Produkt-URL mit direktem Link zum Artikel zB für Nachbestellung | ||||
|  | ||||
| ### Beispiel Tag | ||||
|  | ||||
| ```json | ||||
| {"b":"Recycling Fabrik","an":"FX1_PETG-S175-1000-DAEM00055","t":"PETG","c":"FF5733","cn":"Lebendiges Orange","et":"230","bt":"70","di":"1.75","de":"1.24","sw":"180","u":"https://www.recyclingfabrik.com/search?q="} | ||||
| ``` | ||||
|  | ||||
| ## Implementierungsrichtlinien | ||||
|  | ||||
| ### Für Hersteller | ||||
|  | ||||
| 1. **Tag-Kodierung**: NDEF-Format mit MIME-Typ `application/json` verwenden | ||||
| 2. **Datenminimierung**: Kompaktes JSON-Format für Tag-Größenbegrenzungen nutzen | ||||
| 3. **Qualitätskontrolle**: Sicherstellen, dass alle Pflichtfelder vorhanden und korrekt formatiert sind | ||||
| 4. **Testen**: Tags vor der Produktion mit dem FilaMan-System verifizieren | ||||
|  | ||||
| ### Tag-Größe Überlegungen | ||||
|  | ||||
| - **NTAG213**: 144 Bytes Nutzerdaten (geeignet für einfache Tags) | ||||
| - **NTAG215**: 504 Bytes Nutzerdaten (empfohlen für umfassende Daten) | ||||
| - **NTAG216**: 888 Bytes Nutzerdaten (maximale Kompatibilität) | ||||
|  | ||||
| ### Best Practices | ||||
|  | ||||
| - Markennamen über alle Produkte hinweg konsistent halten | ||||
| - Standardisierte Materialtypnamen verwenden (PLA, PETG, ABS, etc.) | ||||
| - Genaue Temperaturempfehlungen angeben | ||||
| - Aussagekräftige Farbnamen für bessere Benutzererfahrung verwenden | ||||
| - Tags vor Massenproduktion mit dem FilaMan-System testen | ||||
|  | ||||
| ## System-Integration | ||||
|  | ||||
| ### Spoolman Datenbankstruktur | ||||
|  | ||||
| Bei der Verarbeitung eines Hersteller Tags erstellt das System: | ||||
|  | ||||
| 1. **Lieferanten-Eintrag**: Markeninformationen in der Spoolman Lieferanten-Datenbank | ||||
| 2. **Filament-Eintrag**: Materialspezifikationen und Eigenschaften | ||||
| 3. **Spulen-Eintrag**: Einzelne Spule mit Gewicht und NFC-Tag-Referenz | ||||
|  | ||||
| ### Fast-Path Erkennung | ||||
|  | ||||
| Sobald ein Tag verarbeitet und mit `sm_id` aktualisiert wurde, nutzt er das Fast-Path-Erkennungssystem für schnelle nachfolgende Scans. | ||||
|  | ||||
| ## Fehlerbehebung | ||||
|  | ||||
| ### Häufige Probleme | ||||
|  | ||||
| - **Tag zu klein**: NTAG215 oder NTAG216 für größere JSON-Payloads verwenden | ||||
| - **Fehlende Felder**: Sicherstellen, dass alle Pflichtfelder vorhanden sind | ||||
| - **Ungültiges Format**: JSON-Syntax und Feldtypen überprüfen | ||||
| - **Spoolman-Verbindung**: Sicherstellen, dass FilaMan mit der Spoolman API verbinden kann | ||||
|  | ||||
| ### Validierung | ||||
|  | ||||
| Das System validiert: | ||||
|  | ||||
| - JSON-Format Korrektheit | ||||
| - Vorhandensein der Pflichtfelder | ||||
| - Datentyp-Konformität | ||||
| - Tag-Größe Kompatibilität | ||||
|  | ||||
| ## Technische Details | ||||
|  | ||||
| ### Verarbeitungsalgorithmus | ||||
|  | ||||
| 1. Tag-Scan erkennt kein `sm_id` Feld | ||||
| 2. System prüft auf `b` (Marke) und `an` (Artikelnummer) Felder | ||||
| 3. `checkVendor()` erstellt oder findet Marke in Spoolman | ||||
| 4. `checkFilament()` erstellt oder findet Filament-Typ | ||||
| 5. `createSpool()` erstellt neuen Spulen-Eintrag | ||||
| 6. Tag wird mit neuer `sm_id` aktualisiert | ||||
|  | ||||
| ### Fehlerbehandlung | ||||
|  | ||||
| - Graceful Fallback bei Netzwerkproblemen | ||||
| - Detaillierte Protokollierung für Debugging | ||||
| - Benutzer-Feedback bei fehlgeschlagenen Operationen | ||||
| - Wiederholungsmechanismen für temporäre Fehler | ||||
|  | ||||
| ### Systemverhalten | ||||
|  | ||||
| #### Bei fehlendem sm_id: | ||||
| - System prüft auf `b` (brand) und `an` (artnr) Felder | ||||
| - Falls vorhanden → Hersteller Tag erkannt | ||||
| - Automatische Erstellung von Lieferant, Filament und Spule in Spoolman | ||||
| - Tag wird mit neuer `sm_id` beschrieben | ||||
|  | ||||
| #### Bei vorhandenem sm_id: | ||||
| - Fast-Path Erkennung für bekannte Spulen | ||||
| - Sofortige Gewichtsmessung ohne vollständige Tag-Analyse | ||||
| - Optimierte Performance für häufig verwendete Tags | ||||
|  | ||||
| Dieses System ermöglicht eine nahtlose Integration von Hersteller-Filamentprodukten in das FilaMan-Ökosystem unter Beibehaltung von Datenkonsistenz und Benutzererfahrung. | ||||
							
								
								
									
										145
									
								
								README_ManufacturerTags_EN.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										145
									
								
								README_ManufacturerTags_EN.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,145 @@ | ||||
| # Manufacturer Tags - English Documentation | ||||
|  | ||||
| ## Overview | ||||
|  | ||||
| The FilaMan NFC system supports **Manufacturer Tags** that allow filament producers to create standardized NFC tags for their products. When scanned, these tags automatically create the necessary entries in Spoolman (brand, filament type, and spool) without requiring manual setup. | ||||
|  | ||||
| ## How Manufacturer Tags Work | ||||
|  | ||||
| ### Process Flow | ||||
|  | ||||
| 1. **Tag Detection**: When a tag without `sm_id` is scanned, the system checks for manufacturer tag format | ||||
| 2. **Brand Creation/Lookup**: The system searches for the brand in Spoolman or creates it if it doesn't exist | ||||
| 3. **Filament Type Creation/Lookup**: The filament type is created or found based on brand, material, and specifications | ||||
| 4. **Spool Creation**: A new spool entry is automatically created with the tag's UID as reference | ||||
| 5. **Tag Update**: The tag is updated with the new Spoolman spool ID (`sm_id`) | ||||
|  | ||||
| ### Why Use Manufacturer Tags? | ||||
|  | ||||
| - **Automatic Integration**: No manual data entry required | ||||
| - **Standardized Format**: Consistent product information across different manufacturers | ||||
| - **Inventory Management**: Automatic creation of complete Spoolman entries | ||||
| - **Traceability**: Direct link between physical product and digital inventory | ||||
|  | ||||
| ## Tag Format Specification | ||||
|  | ||||
| ### JSON Structure | ||||
|  | ||||
| Manufacturer tags must contain a JSON payload with specific fields using **short keys** to minimize tag size: | ||||
|  | ||||
| ```json | ||||
| { | ||||
|     "b": "Brand/Vendor Name", | ||||
|     "an": "Article Number", | ||||
|     "t": "Filament Type (PLA, PETG, etc)", | ||||
|     "c": "Filament Color without # (FF5733)", | ||||
|     "mc": "Optional Multicolor Filament Colors without # (FF0000,00FF00,0000FF)", | ||||
|     "mcd": "Optional Multicolor Direction as Word (coaxial, longitudinal)", | ||||
|     "cn": "Color Name (red, Blueberry, Arctic Blue)", | ||||
|     "et": "Extruder Temp as Number in C° (230)", | ||||
|     "bt": "Bed Temp as Number in C° (60)", | ||||
|     "di": "Diameter as Float (1.75)", | ||||
|     "de": "Density as Float (1.24)", | ||||
|     "sw": "Empty Spool Weight as Number in g (180)", | ||||
|     "u": "URL to get the Filament with the Article Number" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ### Required Fields | ||||
|  | ||||
| - **`b`** (brand): Manufacturer/brand name | ||||
| - **`an`** (article number): Unique product identifier | ||||
| - **`t`** (type): Material type (PLA, PETG, ABS, etc.) | ||||
| - **`c`** (color): Hex color code without # | ||||
| - **`cn`** (color name): Human-readable color name | ||||
| - **`et`** (extruder temp): Recommended extruder temperature in Celsius | ||||
| - **`bt`** (bed temp): Recommended bed temperature in Celsius | ||||
| - **`di`** (diameter): Filament diameter in mm | ||||
| - **`de`** (density): Material density in g/cm³ | ||||
| - **`sw`** (spool weight): Empty spool weight in grams | ||||
|  | ||||
| ### Optional Fields | ||||
|  | ||||
| - **`mc`** (multicolor): Comma-separated hex colors for multicolor filaments | ||||
| - **`mcd`** (multicolor direction): Direction for multicolor (coaxial, longitudinal) | ||||
| - **`u`** (url): Product URL with direct link to the article e.g. for reordering | ||||
|  | ||||
| ### Example Tag | ||||
|  | ||||
| ```json | ||||
| {"b":"Recycling Fabrik","an":"FX1_PETG-S175-1000-DAEM00055","t":"PETG","c":"FF5733","cn":"Vibrant Orange","et":"230","bt":"70","di":"1.75","de":"1.24","sw":"180","u":"https://www.recyclingfabrik.com/search?q="} | ||||
| ``` | ||||
|  | ||||
| ## Implementation Guidelines | ||||
|  | ||||
| ### For Manufacturers | ||||
|  | ||||
| 1. **Tag Encoding**: Use NDEF format with MIME type `application/json` | ||||
| 2. **Data Minimization**: Use the compact JSON format to fit within tag size limits | ||||
| 3. **Quality Control**: Ensure all required fields are present and correctly formatted | ||||
| 4. **Testing**: Verify tags work with FilaMan system before production | ||||
|  | ||||
| ### Tag Size Considerations | ||||
|  | ||||
| - **NTAG213**: 144 bytes user data (suitable for basic tags) | ||||
| - **NTAG215**: 504 bytes user data (recommended for comprehensive data) | ||||
| - **NTAG216**: 888 bytes user data (maximum compatibility) | ||||
|  | ||||
| ### Best Practices | ||||
|  | ||||
| - Keep brand names consistent across all products | ||||
| - Use standardized material type names (PLA, PETG, ABS, etc.) | ||||
| - Provide accurate temperature recommendations | ||||
| - Include meaningful color names for user experience | ||||
| - Test tags with the FilaMan system before mass production | ||||
|  | ||||
| ## System Integration | ||||
|  | ||||
| ### Spoolman Database Structure | ||||
|  | ||||
| When a manufacturer tag is processed, the system creates: | ||||
|  | ||||
| 1. **Vendor Entry**: Brand information in Spoolman vendor database | ||||
| 2. **Filament Entry**: Material specifications and properties | ||||
| 3. **Spool Entry**: Individual spool with weight and NFC tag reference | ||||
|  | ||||
| ### Fast-Path Recognition | ||||
|  | ||||
| Once a tag is processed and updated with `sm_id`, it uses the fast-path recognition system for quick subsequent scans. | ||||
|  | ||||
| ## Troubleshooting | ||||
|  | ||||
| ### Common Issues | ||||
|  | ||||
| - **Tag Too Small**: Use NTAG215 or NTAG216 for larger JSON payloads | ||||
| - **Missing Fields**: Ensure all required fields are present | ||||
| - **Invalid Format**: Verify JSON syntax and field types | ||||
| - **Spoolman Connection**: Ensure FilaMan can connect to Spoolman API | ||||
|  | ||||
| ### Validation | ||||
|  | ||||
| The system validates: | ||||
| - JSON format correctness | ||||
| - Required field presence | ||||
| - Data type compliance | ||||
| - Tag size compatibility | ||||
|  | ||||
| ## Technical Details | ||||
|  | ||||
| ### Processing Algorithm | ||||
|  | ||||
| 1. Tag scan detects no `sm_id` field | ||||
| 2. System checks for `b` (brand) and `an` (article number) fields | ||||
| 3. `checkVendor()` creates or finds brand in Spoolman | ||||
| 4. `checkFilament()` creates or finds filament type | ||||
| 5. `createSpool()` creates new spool entry | ||||
| 6. Tag is updated with new `sm_id` | ||||
|  | ||||
| ### Error Handling | ||||
|  | ||||
| - Graceful fallback for network issues | ||||
| - Detailed logging for debugging | ||||
| - User feedback for failed operations | ||||
| - Retry mechanisms for temporary failures | ||||
|  | ||||
| This system enables seamless integration of manufacturer filament products into the FilaMan ecosystem while maintaining data consistency and user experience. | ||||
							
								
								
									
										133
									
								
								html/rfid.js
									
									
									
									
									
								
							
							
						
						
									
										133
									
								
								html/rfid.js
									
									
									
									
									
								
							| @@ -7,6 +7,7 @@ let heartbeatTimer = null; | ||||
| let lastHeartbeatResponse = Date.now(); | ||||
| const HEARTBEAT_TIMEOUT = 20000; | ||||
| let reconnectTimer = null; | ||||
| let spoolDetected = false; | ||||
|  | ||||
| // WebSocket Funktionen | ||||
| function startHeartbeat() { | ||||
| @@ -508,12 +509,15 @@ function updateNfcStatusIndicator(data) { | ||||
|     if (data.found === 0) { | ||||
|         // Kein NFC Tag gefunden | ||||
|         indicator.className = 'status-circle'; | ||||
|         spoolDetected = false; | ||||
|     } else if (data.found === 1) { | ||||
|         // NFC Tag erfolgreich gelesen | ||||
|         indicator.className = 'status-circle success'; | ||||
|         spoolDetected = true; | ||||
|     } else { | ||||
|         // Fehler beim Lesen | ||||
|         indicator.className = 'status-circle error'; | ||||
|         spoolDetected = true; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -574,7 +578,7 @@ function updateNfcData(data) { | ||||
|         `; | ||||
|  | ||||
|         // Spoolman ID anzeigen | ||||
|         html += `<p><strong>Spoolman ID:</strong> ${data.sm_id || 'No Spoolman ID'}</p>`; | ||||
|         html += `<p><strong>Spoolman ID:</strong> ${data.sm_id} (<a href="${spoolmanUrl}/spool/show/${data.sm_id}">Open in Spoolman</a>)</p>`; | ||||
|      } | ||||
|      else if(data.location) | ||||
|      { | ||||
| @@ -618,76 +622,83 @@ function updateNfcData(data) { | ||||
| } | ||||
|  | ||||
| function writeNfcTag() { | ||||
|     const selectedText = document.getElementById("selected-filament").textContent; | ||||
|     if (selectedText === "Please choose...") { | ||||
|         alert('Please select a Spool first.'); | ||||
|         return; | ||||
|     } | ||||
|     if(!spoolDetected || confirm("Are you sure you want to overwrite the Tag?") == true){ | ||||
|         const selectedText = document.getElementById("selected-filament").textContent; | ||||
|         if (selectedText === "Please choose...") { | ||||
|             alert('Please select a Spool first.'); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|     const spoolsData = window.getSpoolData(); | ||||
|     const selectedSpool = spoolsData.find(spool =>  | ||||
|         `${spool.id} | ${spool.filament.name} (${spool.filament.material})` === selectedText | ||||
|     ); | ||||
|         const spoolsData = window.getSpoolData(); | ||||
|         const selectedSpool = spoolsData.find(spool =>  | ||||
|             `${spool.id} | ${spool.filament.name} (${spool.filament.material})` === selectedText | ||||
|         ); | ||||
|  | ||||
|     if (!selectedSpool) { | ||||
|         alert('Ausgewählte Spule konnte nicht gefunden werden.'); | ||||
|         return; | ||||
|     } | ||||
|         if (!selectedSpool) { | ||||
|             alert('Ausgewählte Spule konnte nicht gefunden werden.'); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|     // Temperaturwerte korrekt extrahieren | ||||
|     let minTemp = "175"; | ||||
|     let maxTemp = "275"; | ||||
|      | ||||
|     if (Array.isArray(selectedSpool.filament.nozzle_temperature) &&  | ||||
|         selectedSpool.filament.nozzle_temperature.length >= 2) { | ||||
|         minTemp = String(selectedSpool.filament.nozzle_temperature[0]); | ||||
|         maxTemp = String(selectedSpool.filament.nozzle_temperature[1]); | ||||
|     } | ||||
|         // Temperaturwerte korrekt extrahieren | ||||
|         let minTemp = "175"; | ||||
|         let maxTemp = "275"; | ||||
|          | ||||
|         if (Array.isArray(selectedSpool.filament.nozzle_temperature) &&  | ||||
|             selectedSpool.filament.nozzle_temperature.length >= 2) { | ||||
|             minTemp = String(selectedSpool.filament.nozzle_temperature[0]); | ||||
|             maxTemp = String(selectedSpool.filament.nozzle_temperature[1]); | ||||
|         } | ||||
|  | ||||
|     // Erstelle das NFC-Datenpaket mit korrekten Datentypen | ||||
|     const nfcData = { | ||||
|         color_hex: selectedSpool.filament.color_hex || "FFFFFF", | ||||
|         type: selectedSpool.filament.material, | ||||
|         min_temp: minTemp, | ||||
|         max_temp: maxTemp, | ||||
|         brand: selectedSpool.filament.vendor.name, | ||||
|         sm_id: String(selectedSpool.id) // Konvertiere zu String | ||||
|     }; | ||||
|         // Erstelle das NFC-Datenpaket mit korrekten Datentypen | ||||
|         const nfcData = { | ||||
|             color_hex: selectedSpool.filament.color_hex || "FFFFFF", | ||||
|             type: selectedSpool.filament.material, | ||||
|             min_temp: minTemp, | ||||
|             max_temp: maxTemp, | ||||
|             brand: selectedSpool.filament.vendor.name, | ||||
|             sm_id: String(selectedSpool.id) // Konvertiere zu String | ||||
|         }; | ||||
|  | ||||
|     if (socket?.readyState === WebSocket.OPEN) { | ||||
|         const writeButton = document.getElementById("writeNfcButton"); | ||||
|         writeButton.classList.add("writing"); | ||||
|         writeButton.textContent = "Writing"; | ||||
|         socket.send(JSON.stringify({ | ||||
|             type: 'writeNfcTag', | ||||
|             payload: nfcData | ||||
|         })); | ||||
|     } else { | ||||
|         alert('Not connected to Server. Please check connection.'); | ||||
|         if (socket?.readyState === WebSocket.OPEN) { | ||||
|             const writeButton = document.getElementById("writeNfcButton"); | ||||
|             writeButton.classList.add("writing"); | ||||
|             writeButton.textContent = "Writing"; | ||||
|             socket.send(JSON.stringify({ | ||||
|                 type: 'writeNfcTag', | ||||
|                 tagType: 'spool', | ||||
|                 payload: nfcData | ||||
|             })); | ||||
|         } else { | ||||
|             alert('Not connected to Server. Please check connection.'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| function writeLocationNfcTag() { | ||||
|     const selectedText = document.getElementById("locationSelect").value; | ||||
|     if (selectedText === "Please choose...") { | ||||
|         alert('Please select a location first.'); | ||||
|         return; | ||||
|     } | ||||
|     // Erstelle das NFC-Datenpaket mit korrekten Datentypen | ||||
|     const nfcData = { | ||||
|         location: String(selectedText) | ||||
|     }; | ||||
|     if(!spoolDetected || confirm("Are you sure you want to overwrite the Tag?") == true){ | ||||
|         const selectedText = document.getElementById("locationSelect").value; | ||||
|         if (selectedText === "Please choose...") { | ||||
|             alert('Please select a location first.'); | ||||
|             return; | ||||
|         } | ||||
|         // Erstelle das NFC-Datenpaket mit korrekten Datentypen | ||||
|         const nfcData = { | ||||
|             location: String(selectedText) | ||||
|         }; | ||||
|  | ||||
|     if (socket?.readyState === WebSocket.OPEN) { | ||||
|         const writeButton = document.getElementById("writeLocationNfcButton"); | ||||
|         writeButton.classList.add("writing"); | ||||
|         writeButton.textContent = "Writing"; | ||||
|         socket.send(JSON.stringify({ | ||||
|             type: 'writeNfcTag', | ||||
|             payload: nfcData | ||||
|         })); | ||||
|     } else { | ||||
|         alert('Not connected to Server. Please check connection.'); | ||||
|  | ||||
|         if (socket?.readyState === WebSocket.OPEN) { | ||||
|             const writeButton = document.getElementById("writeLocationNfcButton"); | ||||
|             writeButton.classList.add("writing"); | ||||
|             writeButton.textContent = "Writing"; | ||||
|             socket.send(JSON.stringify({ | ||||
|                 type: 'writeNfcTag', | ||||
|                 tagType: 'location', | ||||
|                 payload: nfcData | ||||
|             })); | ||||
|         } else { | ||||
|             alert('Not connected to Server. Please check connection.'); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -56,8 +56,8 @@ | ||||
|  | ||||
|         <div class="update-options"> | ||||
|             <div class="update-section"> | ||||
|                 <h2>Firmware Update</h2> | ||||
|                 <p>Upload a new firmware file (filaman_*.bin)</p> | ||||
|                 <h2>1) Firmware Update</h2> | ||||
|                 <p>Upload a new firmware file (upgrade_filaman_firmware_*.bin)</p> | ||||
|                 <div class="update-form"> | ||||
|                     <form id="firmwareForm" enctype='multipart/form-data' data-type="firmware"> | ||||
|                         <input type='file' name='update' accept='.bin' required> | ||||
| @@ -67,8 +67,8 @@ | ||||
|             </div> | ||||
|  | ||||
|             <div class="update-section"> | ||||
|                 <h2>Webpage Update</h2> | ||||
|                 <p>Upload a new webpage file (webpage_*.bin)</p> | ||||
|                 <h2>2) Webpage Update</h2> | ||||
|                 <p>Upload a new webpage file (upgrade_filaman_website_*.bin)</p> | ||||
|                 <div class="update-form"> | ||||
|                     <form id="webpageForm" enctype='multipart/form-data' data-type="webpage"> | ||||
|                         <input type='file' name='update' accept='.bin' required> | ||||
|   | ||||
| @@ -9,8 +9,8 @@ | ||||
| ; https://docs.platformio.org/page/projectconf.html | ||||
|  | ||||
| [common] | ||||
| version = "1.5.6" | ||||
| to_old_version = "1.5.0" | ||||
| version = "2.0.0-beta8" | ||||
| to_old_version = "1.5.10" | ||||
|  | ||||
| ## | ||||
| [env:esp32dev] | ||||
| @@ -23,10 +23,7 @@ monitor_speed = 115200 | ||||
| lib_deps = | ||||
|     tzapu/WiFiManager @ ^2.0.17 | ||||
|     https://github.com/me-no-dev/ESPAsyncWebServer.git#master | ||||
|     #me-no-dev/AsyncTCP @ ^1.1.1 | ||||
|     https://github.com/esphome/AsyncTCP.git | ||||
|     #mathieucarbou/ESPAsyncWebServer @ ^3.6.0 | ||||
|     #esp32async/AsyncTCP @ ^3.3.5 | ||||
|     bogde/HX711 @ ^0.7.5 | ||||
|     adafruit/Adafruit SSD1306 @ ^2.5.13 | ||||
|     adafruit/Adafruit GFX Library @ ^1.11.11 | ||||
| @@ -36,7 +33,6 @@ lib_deps = | ||||
|     digitaldragon/SSLClient @ ^1.3.2 | ||||
|      | ||||
| ; Enable SPIFFS upload | ||||
| #board_build.filesystem = spiffs | ||||
| board_build.filesystem = littlefs | ||||
| ; Update partition settings | ||||
| board_build.partitions = partitions.csv | ||||
|   | ||||
| @@ -14,17 +14,39 @@ def get_version(): | ||||
|         return version_match.group(1) if version_match else None | ||||
|  | ||||
| def get_last_tag(): | ||||
|     """Get the last non-beta tag for changelog generation""" | ||||
|     try: | ||||
|         result = subprocess.run(['git', 'describe', '--tags', '--abbrev=0'],  | ||||
|         # Get all tags sorted by version | ||||
|         result = subprocess.run(['git', 'tag', '-l', '--sort=-version:refname'],  | ||||
|                               capture_output=True, text=True) | ||||
|         return result.stdout.strip() | ||||
|         if result.returncode != 0: | ||||
|             return None | ||||
|              | ||||
|         tags = result.stdout.strip().split('\n') | ||||
|          | ||||
|         # Find the first (newest) non-beta tag | ||||
|         for tag in tags: | ||||
|             if tag and not '-beta' in tag.lower(): | ||||
|                 print(f"Using last stable tag for changelog: {tag}") | ||||
|                 return tag | ||||
|          | ||||
|         # Fallback: if no non-beta tags found, use the newest tag | ||||
|         print("No stable tags found, using newest tag") | ||||
|         if tags and tags[0]: | ||||
|             return tags[0] | ||||
|         return None | ||||
|     except subprocess.CalledProcessError: | ||||
|         return None | ||||
|  | ||||
| def categorize_commit(commit_msg): | ||||
|     """Categorize commit messages based on conventional commits""" | ||||
|     lower_msg = commit_msg.lower() | ||||
|     if any(x in lower_msg for x in ['feat', 'add', 'new']): | ||||
|      | ||||
|     # Check for breaking changes first | ||||
|     if ('!' in commit_msg and any(x in lower_msg for x in ['feat!', 'fix!', 'chore!', 'refactor!'])) or \ | ||||
|        'breaking change' in lower_msg or 'breaking:' in lower_msg: | ||||
|         return 'Breaking Changes' | ||||
|     elif any(x in lower_msg for x in ['feat', 'add', 'new']): | ||||
|         return 'Added' | ||||
|     elif any(x in lower_msg for x in ['fix', 'bug']): | ||||
|         return 'Fixed' | ||||
| @@ -34,6 +56,7 @@ def categorize_commit(commit_msg): | ||||
| def get_changes_from_git(): | ||||
|     """Get changes from git commits since last tag""" | ||||
|     changes = { | ||||
|         'Breaking Changes': [], | ||||
|         'Added': [], | ||||
|         'Changed': [], | ||||
|         'Fixed': [] | ||||
| @@ -55,7 +78,9 @@ def get_changes_from_git(): | ||||
|             if commit: | ||||
|                 category = categorize_commit(commit) | ||||
|                 # Clean up commit message | ||||
|                 clean_msg = re.sub(r'^(feat|fix|chore|docs|style|refactor|perf|test)(\(.*\))?:', '', commit).strip() | ||||
|                 clean_msg = re.sub(r'^(feat|fix|chore|docs|style|refactor|perf|test)(\(.*\))?!?:', '', commit).strip() | ||||
|                 # Remove BREAKING CHANGE prefix if present | ||||
|                 clean_msg = re.sub(r'^breaking change:\s*', '', clean_msg, flags=re.IGNORECASE).strip() | ||||
|                 changes[category].append(clean_msg) | ||||
|                  | ||||
|     except subprocess.CalledProcessError: | ||||
|   | ||||
							
								
								
									
										1065
									
								
								src/api.cpp
									
									
									
									
									
								
							
							
						
						
									
										1065
									
								
								src/api.cpp
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										12
									
								
								src/api.h
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								src/api.h
									
									
									
									
									
								
							| @@ -17,17 +17,24 @@ typedef enum { | ||||
|     API_REQUEST_BAMBU_UPDATE, | ||||
|     API_REQUEST_SPOOL_TAG_ID_UPDATE, | ||||
|     API_REQUEST_SPOOL_WEIGHT_UPDATE, | ||||
|     API_REQUEST_SPOOL_LOCATION_UPDATE | ||||
|     API_REQUEST_SPOOL_LOCATION_UPDATE, | ||||
|     API_REQUEST_VENDOR_CREATE, | ||||
|     API_REQUEST_VENDOR_CHECK, | ||||
|     API_REQUEST_FILAMENT_CHECK, | ||||
|     API_REQUEST_FILAMENT_CREATE, | ||||
|     API_REQUEST_SPOOL_CREATE | ||||
| } SpoolmanApiRequestType; | ||||
|  | ||||
| extern volatile spoolmanApiStateType spoolmanApiState; | ||||
| extern bool spoolman_connected; | ||||
| extern String spoolmanUrl; | ||||
| extern bool octoEnabled; | ||||
| extern bool sendOctoUpdate; | ||||
| extern String octoUrl; | ||||
| extern String octoToken; | ||||
| extern bool spoolmanConnected; | ||||
|  | ||||
| bool checkSpoolmanInstance(const String& url); | ||||
| bool checkSpoolmanInstance(); | ||||
| bool saveSpoolmanUrl(const String& url, bool octoOn, const String& octoWh, const String& octoTk); | ||||
| String loadSpoolmanUrl(); // Neue Funktion zum Laden der URL | ||||
| bool checkSpoolmanExtraFields(); // Neue Funktion zum Überprüfen der Extrafelder | ||||
| @@ -38,5 +45,6 @@ uint8_t updateSpoolLocation(String spoolId, String location); | ||||
| bool initSpoolman(); // Neue Funktion zum Initialisieren von Spoolman | ||||
| bool updateSpoolBambuData(String payload); // Neue Funktion zum Aktualisieren der Bambu-Daten | ||||
| bool updateSpoolOcto(int spoolId); // Neue Funktion zum Aktualisieren der Octo-Daten | ||||
| bool createBrandFilament(JsonDocument& payload, String uidString); | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -33,6 +33,7 @@ AMSData ams_data[MAX_AMS];  // Definition des Arrays; | ||||
| bool removeBambuCredentials() { | ||||
|     if (BambuMqttTask) { | ||||
|         vTaskDelete(BambuMqttTask); | ||||
|         BambuMqttTask = NULL; | ||||
|     } | ||||
|      | ||||
|     Preferences preferences; | ||||
| @@ -63,6 +64,7 @@ bool removeBambuCredentials() { | ||||
| bool saveBambuCredentials(const String& ip, const String& serialnr, const String& accesscode, bool autoSend, const String& autoSendTime) { | ||||
|     if (BambuMqttTask) { | ||||
|         vTaskDelete(BambuMqttTask); | ||||
|         BambuMqttTask = NULL; | ||||
|     } | ||||
|  | ||||
|     bambuCredentials.ip = ip.c_str(); | ||||
| @@ -593,6 +595,7 @@ void reconnect() { | ||||
|                 Serial.println("Disable Bambu MQTT Task after 5 retries"); | ||||
|                 //vTaskSuspend(BambuMqttTask); | ||||
|                 vTaskDelete(BambuMqttTask); | ||||
|                 BambuMqttTask = NULL; | ||||
|                 break; | ||||
|             } | ||||
|  | ||||
| @@ -627,6 +630,7 @@ bool setupMqtt() { | ||||
|  | ||||
|     if (bambuCredentials.ip != "" && bambuCredentials.accesscode != "" && bambuCredentials.serial != "")  | ||||
|     { | ||||
|         oledShowProgressBar(4, 7, DISPLAY_BOOT_TEXT, "Bambu init"); | ||||
|         bambuDisabled = false; | ||||
|         sslClient.setCACert(root_ca); | ||||
|         sslClient.setInsecure(); | ||||
| @@ -680,6 +684,7 @@ void bambu_restart() { | ||||
|  | ||||
|     if (BambuMqttTask) { | ||||
|         vTaskDelete(BambuMqttTask); | ||||
|         BambuMqttTask = NULL; | ||||
|         delay(10); | ||||
|     } | ||||
|     setupMqtt(); | ||||
|   | ||||
| @@ -16,7 +16,6 @@ const uint8_t LOADCELL_DOUT_PIN = 16; //16; | ||||
| const uint8_t LOADCELL_SCK_PIN = 17; //17; | ||||
| const uint8_t calVal_eepromAdress = 0; | ||||
| const uint16_t SCALE_LEVEL_WEIGHT = 500; | ||||
| uint16_t defaultScaleCalibrationValue = 430; | ||||
| // ***** HX711 | ||||
|  | ||||
| // ***** TTP223 (Touch Sensor) | ||||
| @@ -26,16 +25,11 @@ const uint8_t TTP223_PIN = 25; | ||||
|  | ||||
|  | ||||
| // ***** Display | ||||
| // Declaration for an SSD1306 display connected to I2C (SDA, SCL pins) | ||||
| // On an ESP32:   21(SDA),  22(SCL) | ||||
| const int8_t OLED_RESET = -1; // Reset pin # (or -1 if sharing Arduino reset pin) | ||||
| const uint8_t SCREEN_ADDRESS = 0x3C; ///< See datasheet for Address; 0x3D for 128x64, 0x3C for 128x32 | ||||
| const uint8_t SCREEN_WIDTH = 128; // OLED display width, in pixels | ||||
| const uint8_t SCREEN_HEIGHT = 64; // OLED display height, in pixels | ||||
| const uint8_t OLED_TOP_START = 0; | ||||
| const uint8_t OLED_TOP_END = 16; | ||||
| const uint8_t OLED_DATA_START = 17; | ||||
| const uint8_t OLED_DATA_END = SCREEN_HEIGHT; | ||||
|  | ||||
| // ***** Display | ||||
|  | ||||
| // ***** Webserver | ||||
|   | ||||
							
								
								
									
										47
									
								
								src/config.h
									
									
									
									
									
								
							
							
						
						
									
										47
									
								
								src/config.h
									
									
									
									
									
								
							| @@ -3,28 +3,39 @@ | ||||
|  | ||||
| #include <Arduino.h> | ||||
|  | ||||
| #define BAMBU_DEFAULT_AUTOSEND_TIME 60 | ||||
| #define BAMBU_DEFAULT_AUTOSEND_TIME         60 | ||||
|  | ||||
| #define NVS_NAMESPACE_API                   "api" | ||||
| #define NVS_KEY_SPOOLMAN_URL                "spoolmanUrl" | ||||
| #define NVS_KEY_OCTOPRINT_ENABLED           "octoEnabled" | ||||
| #define NVS_KEY_OCTOPRINT_URL               "octoUrl" | ||||
| #define NVS_KEY_OCTOPRINT_TOKEN             "octoToken" | ||||
|  | ||||
| #define NVS_NAMESPACE_API "api" | ||||
| #define NVS_KEY_SPOOLMAN_URL "spoolmanUrl" | ||||
| #define NVS_KEY_OCTOPRINT_ENABLED "octoEnabled" | ||||
| #define NVS_KEY_OCTOPRINT_URL "octoUrl" | ||||
| #define NVS_KEY_OCTOPRINT_TOKEN "octoToken" | ||||
| #define NVS_NAMESPACE_BAMBU                 "bambu" | ||||
| #define NVS_KEY_BAMBU_IP                    "bambuIp" | ||||
| #define NVS_KEY_BAMBU_ACCESSCODE            "bambuCode" | ||||
| #define NVS_KEY_BAMBU_SERIAL                "bambuSerial" | ||||
| #define NVS_KEY_BAMBU_AUTOSEND_ENABLE       "autosendEnable" | ||||
| #define NVS_KEY_BAMBU_AUTOSEND_TIME         "autosendTime" | ||||
|  | ||||
| #define NVS_NAMESPACE_BAMBU "bambu" | ||||
| #define NVS_KEY_BAMBU_IP "bambuIp" | ||||
| #define NVS_KEY_BAMBU_ACCESSCODE "bambuCode" | ||||
| #define NVS_KEY_BAMBU_SERIAL "bambuSerial" | ||||
| #define NVS_KEY_BAMBU_AUTOSEND_ENABLE "autosendEnable" | ||||
| #define NVS_KEY_BAMBU_AUTOSEND_TIME "autosendTime" | ||||
| #define NVS_NAMESPACE_SCALE                 "scale" | ||||
| #define NVS_KEY_CALIBRATION                 "cal_value" | ||||
| #define NVS_KEY_AUTOTARE                    "auto_tare" | ||||
| #define SCALE_DEFAULT_CALIBRATION_VALUE     430.0f; | ||||
|  | ||||
| #define NVS_NAMESPACE_SCALE "scale" | ||||
| #define NVS_KEY_CALIBRATION "cal_value" | ||||
| #define NVS_KEY_AUTOTARE "auto_tare" | ||||
| #define BAMBU_USERNAME                      "bblp" | ||||
|  | ||||
| #define BAMBU_USERNAME "bblp" | ||||
| #define OLED_RESET                          -1      // Reset pin # (or -1 if sharing Arduino reset pin) | ||||
| #define SCREEN_ADDRESS                      0x3CU   // See datasheet for Address; 0x3D for 128x64, 0x3C for 128x32 | ||||
| #define SCREEN_WIDTH                        128U | ||||
| #define SCREEN_HEIGHT                       64U | ||||
| #define SCREEN_TOP_BAR_HEIGHT               16U | ||||
| #define SCREEN_PROGRESS_BAR_HEIGHT          12U | ||||
| #define DISPLAY_BOOT_TEXT                   "FilaMan" | ||||
|  | ||||
| #define WIFI_CHECK_INTERVAL                 60000U | ||||
| #define DISPLAY_UPDATE_INTERVAL             1000U | ||||
| #define SPOOLMAN_HEALTHCHECK_INTERVAL       60000U | ||||
|  | ||||
| extern const uint8_t PN532_IRQ; | ||||
| extern const uint8_t PN532_RESET; | ||||
| @@ -36,10 +47,6 @@ extern const uint16_t SCALE_LEVEL_WEIGHT; | ||||
|  | ||||
| extern const uint8_t TTP223_PIN; | ||||
|  | ||||
| extern const int8_t OLED_RESET; | ||||
| extern const uint8_t SCREEN_ADDRESS; | ||||
| extern const uint8_t SCREEN_WIDTH; | ||||
| extern const uint8_t SCREEN_HEIGHT; | ||||
| extern const uint8_t OLED_TOP_START; | ||||
| extern const uint8_t OLED_TOP_END; | ||||
| extern const uint8_t OLED_DATA_START; | ||||
|   | ||||
| @@ -7,6 +7,6 @@ | ||||
|     #define HEAP_DEBUG_MESSAGE(location)  | ||||
| #endif | ||||
|  | ||||
| inline void printHeapDebugData(String location){ | ||||
| inline void printHeapDebugData(const char *location){ | ||||
|     Serial.println("Heap: " + String(ESP.getMinFreeHeap()/1024) + "\t" + String(ESP.getFreeHeap()/1024) + "\t" + String(ESP.getMaxAllocHeap()/1024) + "\t" + location); | ||||
| } | ||||
| @@ -2,10 +2,12 @@ | ||||
| #include "api.h" | ||||
| #include <vector> | ||||
| #include "icons.h" | ||||
| #include "main.h" | ||||
|  | ||||
| Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, OLED_RESET); | ||||
|  | ||||
| bool wifiOn = false; | ||||
| bool iconToggle = false; | ||||
|  | ||||
| void setupDisplay() { | ||||
|     if (!display.begin(SSD1306_SWITCHCAPVCC, SCREEN_ADDRESS)) { | ||||
| @@ -14,15 +16,10 @@ void setupDisplay() { | ||||
|     } | ||||
|     display.setTextColor(WHITE); | ||||
|     display.clearDisplay(); | ||||
|     display.display(); | ||||
|  | ||||
|     // Show initial display buffer contents on the screen -- | ||||
|     // the library initializes this with an Adafruit splash screen. | ||||
|     display.setTextColor(WHITE); | ||||
|     display.display(); | ||||
|  | ||||
|     oledShowTopRow(); | ||||
|     oledShowMessage("FilaMan v" + String(VERSION)); | ||||
|     vTaskDelay(2000 / portTICK_PERIOD_MS); | ||||
|     oledShowProgressBar(0, 7, DISPLAY_BOOT_TEXT, "Display init"); | ||||
| } | ||||
|  | ||||
| void oledclearline() { | ||||
| @@ -45,14 +42,14 @@ void oledcleardata() { | ||||
|     //display.display(); | ||||
| } | ||||
|  | ||||
| int oled_center_h(String text) { | ||||
| int oled_center_h(const String &text) { | ||||
|     int16_t x1, y1; | ||||
|     uint16_t w, h; | ||||
|     display.getTextBounds(text, 0, 0, &x1, &y1, &w, &h); | ||||
|     return (SCREEN_WIDTH - w) / 2; | ||||
| } | ||||
|  | ||||
| int oled_center_v(String text) { | ||||
| int oled_center_v(const String &text) { | ||||
|     int16_t x1, y1; | ||||
|     uint16_t w, h; | ||||
|     display.getTextBounds(text, 0, OLED_DATA_START, &x1, &y1, &w, &h); | ||||
| @@ -60,7 +57,7 @@ int oled_center_v(String text) { | ||||
|     return OLED_DATA_START + ((OLED_DATA_END - OLED_DATA_START - h) / 2); | ||||
| } | ||||
|  | ||||
| std::vector<String> splitTextIntoLines(String text, uint8_t textSize) { | ||||
| std::vector<String> splitTextIntoLines(const String &text, uint8_t textSize) { | ||||
|     std::vector<String> lines; | ||||
|     display.setTextSize(textSize); | ||||
|      | ||||
| @@ -120,7 +117,7 @@ std::vector<String> splitTextIntoLines(String text, uint8_t textSize) { | ||||
|     return lines; | ||||
| } | ||||
|  | ||||
| void oledShowMultilineMessage(String message, uint8_t size) { | ||||
| void oledShowMultilineMessage(const String &message, uint8_t size) { | ||||
|     std::vector<String> lines; | ||||
|     int maxLines = 3;  // Maximale Anzahl Zeilen für size 2 | ||||
|      | ||||
| @@ -148,7 +145,7 @@ void oledShowMultilineMessage(String message, uint8_t size) { | ||||
|     display.display(); | ||||
| } | ||||
|  | ||||
| void oledShowMessage(String message, uint8_t size) { | ||||
| void oledShowMessage(const String &message, uint8_t size) { | ||||
|     oledcleardata(); | ||||
|     display.setTextSize(size); | ||||
|     display.setTextWrap(false); | ||||
| @@ -171,22 +168,46 @@ void oledShowMessage(String message, uint8_t size) { | ||||
| void oledShowTopRow() { | ||||
|     oledclearline(); | ||||
|  | ||||
|     if (bambu_connected == 1) { | ||||
|         display.drawBitmap(50, 0, bitmap_bambu_on , 16, 16, WHITE); | ||||
|     } else { | ||||
|         display.drawBitmap(50, 0, bitmap_off , 16, 16, WHITE); | ||||
|     } | ||||
|     display.setTextSize(1); | ||||
|     display.setCursor(0, 4); | ||||
|     display.print("v"); | ||||
|     display.print(VERSION); | ||||
|  | ||||
|     if (spoolmanApiState != API_INIT) { | ||||
|         display.drawBitmap(80, 0, bitmap_spoolman_on , 16, 16, WHITE); | ||||
|     } else { | ||||
|         display.drawBitmap(80, 0, bitmap_off , 16, 16, WHITE); | ||||
|     } | ||||
|     iconToggle = !iconToggle; | ||||
|  | ||||
|     if (wifiOn == 1) { | ||||
|         display.drawBitmap(107, 0, wifi_on , 16, 16, WHITE); | ||||
|     } else { | ||||
|         display.drawBitmap(107, 0, wifi_off , 16, 16, WHITE); | ||||
|     // Do not show status indicators during boot | ||||
|     if(!booting){ | ||||
|         if(bambuDisabled == false) { | ||||
|             if (bambu_connected == 1) { | ||||
|                 display.drawBitmap(50, 0, bitmap_bambu_on , 16, 16, WHITE); | ||||
|             } else { | ||||
|                 if(iconToggle){ | ||||
|                     display.drawBitmap(50, 0, bitmap_bambu_on , 16, 16, WHITE); | ||||
|                     display.drawLine(50, 15, 66, 0, WHITE); | ||||
|                     display.drawLine(51, 15, 67, 0, WHITE); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (spoolmanConnected) { | ||||
|             display.drawBitmap(80, 0, bitmap_spoolman_on , 16, 16, WHITE); | ||||
|         } else { | ||||
|             if(iconToggle){ | ||||
|                 display.drawBitmap(80, 0, bitmap_spoolman_on , 16, 16, WHITE); | ||||
|                 display.drawLine(80, 15, 96, 0, WHITE); | ||||
|                 display.drawLine(81, 15, 97, 0, WHITE); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (wifiOn == 1) { | ||||
|             display.drawBitmap(107, 0, wifi_on , 16, 16, WHITE); | ||||
|         } else { | ||||
|             if(iconToggle){ | ||||
|                 display.drawBitmap(107, 0, wifi_on , 16, 16, WHITE); | ||||
|                 display.drawLine(107, 15, 123, 0, WHITE); | ||||
|                 display.drawLine(108, 15, 124, 0, WHITE); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|      | ||||
|     display.display(); | ||||
| @@ -214,6 +235,27 @@ void oledShowIcon(const char* icon) { | ||||
|     display.display(); | ||||
| } | ||||
|  | ||||
| void oledShowProgressBar(const uint8_t step, const uint8_t numSteps, const char* largeText, const char* statusMessage) { | ||||
|     assert(step <= numSteps); | ||||
|  | ||||
|     // clear data and bar area | ||||
|     display.fillRect(0, OLED_DATA_START, SCREEN_WIDTH, SCREEN_HEIGHT-16, BLACK); | ||||
|  | ||||
|      | ||||
|     display.setTextWrap(false); | ||||
|     display.setTextSize(2); | ||||
|     display.setCursor(0, OLED_DATA_START+4); | ||||
|     display.print(largeText); | ||||
|     display.setTextSize(1); | ||||
|     display.setCursor(0, OLED_DATA_END-SCREEN_PROGRESS_BAR_HEIGHT-10); | ||||
|     display.print(statusMessage); | ||||
|  | ||||
|     const int barLength = ((SCREEN_WIDTH-2)*step)/numSteps; | ||||
|     display.drawRoundRect(0, SCREEN_HEIGHT-SCREEN_PROGRESS_BAR_HEIGHT, SCREEN_WIDTH, 12, 6, WHITE); | ||||
|     display.fillRoundRect(1, SCREEN_HEIGHT-SCREEN_PROGRESS_BAR_HEIGHT+1, barLength, 10, 6, WHITE); | ||||
|     display.display(); | ||||
| } | ||||
|  | ||||
| void oledShowWeight(uint16_t weight) { | ||||
|     // Display Gewicht | ||||
|     oledcleardata(); | ||||
|   | ||||
| @@ -13,11 +13,13 @@ extern bool wifiOn; | ||||
| void setupDisplay(); | ||||
| void oledclearline(); | ||||
| void oledcleardata(); | ||||
| int oled_center_h(String text); | ||||
| int oled_center_v(String text); | ||||
| int oled_center_h(const String &text); | ||||
| int oled_center_v(const String &text); | ||||
|  | ||||
| void oledShowProgressBar(const uint8_t step, const uint8_t numSteps, const char* largeText, const char* statusMessage); | ||||
|  | ||||
| void oledShowWeight(uint16_t weight); | ||||
| void oledShowMessage(String message, uint8_t size = 2); | ||||
| void oledShowMessage(const String &message, uint8_t size = 2); | ||||
| void oledShowTopRow(); | ||||
| void oledShowIcon(const char* icon); | ||||
|  | ||||
|   | ||||
							
								
								
									
										160
									
								
								src/main.cpp
									
									
									
									
									
								
							
							
						
						
									
										160
									
								
								src/main.cpp
									
									
									
									
									
								
							| @@ -16,6 +16,7 @@ | ||||
| bool mainTaskWasPaused = 0; | ||||
| uint8_t scaleTareCounter = 0; | ||||
| bool touchSensorConnected = false; | ||||
| bool booting = true; | ||||
|  | ||||
| // ##### SETUP ##### | ||||
| void setup() { | ||||
| @@ -58,11 +59,13 @@ void setup() { | ||||
|  | ||||
|   // Scale | ||||
|   start_scale(touchSensorConnected); | ||||
|   scale.tare(); | ||||
|  | ||||
|   // WDT initialisieren mit 10 Sekunden Timeout | ||||
|   bool panic = true; // Wenn true, löst ein WDT-Timeout einen System-Panik aus | ||||
|   esp_task_wdt_init(10, panic); | ||||
|  | ||||
|   booting = false; | ||||
|   // Aktuellen Task (loopTask) zum Watchdog hinzufügen | ||||
|   esp_task_wdt_add(NULL); | ||||
| } | ||||
| @@ -95,7 +98,8 @@ int16_t lastWeight = 0; | ||||
|  | ||||
| // WIFI check variables | ||||
| unsigned long lastWifiCheckTime = 0; | ||||
| const unsigned long wifiCheckInterval = 60000; // Überprüfe alle 60 Sekunden (60000 ms) | ||||
| unsigned long lastTopRowUpdateTime = 0; | ||||
| unsigned long lastSpoolmanHealcheckTime = 0; | ||||
|  | ||||
| // Button debounce variables | ||||
| unsigned long lastButtonPress = 0; | ||||
| @@ -113,11 +117,23 @@ void loop() { | ||||
|   } | ||||
|  | ||||
|   // Überprüfe regelmäßig die WLAN-Verbindung | ||||
|   if (intervalElapsed(currentMillis, lastWifiCheckTime, wifiCheckInterval))  | ||||
|   if (intervalElapsed(currentMillis, lastWifiCheckTime, WIFI_CHECK_INTERVAL))  | ||||
|   { | ||||
|     checkWiFiConnection(); | ||||
|   } | ||||
|  | ||||
|   // Periodic display update | ||||
|   if (intervalElapsed(currentMillis, lastTopRowUpdateTime, DISPLAY_UPDATE_INTERVAL))  | ||||
|   { | ||||
|     oledShowTopRow(); | ||||
|   } | ||||
|  | ||||
|   // Periodic spoolman health check | ||||
|   if (intervalElapsed(currentMillis, lastSpoolmanHealcheckTime, SPOOLMAN_HEALTHCHECK_INTERVAL))  | ||||
|   { | ||||
|     checkSpoolmanInstance(); | ||||
|   } | ||||
|  | ||||
|   // Wenn Bambu auto set Spool aktiv | ||||
|   if (bambuCredentials.autosend_enable && autoSetToBambuSpoolId > 0)  | ||||
|   { | ||||
| @@ -148,88 +164,96 @@ void loop() { | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   // Wenn Waage nicht Kalibriert | ||||
|   if (scaleCalibrated == 3)  | ||||
|   // If scale is not calibrated, only show a warning | ||||
|   if (!scaleCalibrated)  | ||||
|   { | ||||
|     oledShowMessage("Scale not calibrated!"); | ||||
|     vTaskDelay(5000 / portTICK_PERIOD_MS); | ||||
|     yield(); | ||||
|     esp_task_wdt_reset(); | ||||
|      | ||||
|     return; | ||||
|   }  | ||||
|  | ||||
|   // Ausgabe der Waage auf Display | ||||
|   if(pauseMainTask == 0) | ||||
|   { | ||||
|     if (mainTaskWasPaused || (weight != lastWeight && nfcReaderState == NFC_IDLE && (!bambuCredentials.autosend_enable || autoSetToBambuSpoolId == 0))) | ||||
|     { | ||||
|       (weight < 2) ? ((weight < -2) ? oledShowMessage("!! -0") : oledShowWeight(0)) : oledShowWeight(weight); | ||||
|     // Do not show the warning if the calibratin process is onging | ||||
|     if(!scaleCalibrationActive){ | ||||
|       oledShowMessage("Scale not calibrated"); | ||||
|       vTaskDelay(1000 / portTICK_PERIOD_MS); | ||||
|     } | ||||
|     mainTaskWasPaused = false; | ||||
|   } | ||||
|   else | ||||
|   }  | ||||
|   else  | ||||
|   { | ||||
|     mainTaskWasPaused = true; | ||||
|   } | ||||
|  | ||||
|  | ||||
|   // Wenn Timer abgelaufen und nicht gerade ein RFID-Tag geschrieben wird | ||||
|   if (currentMillis - lastWeightReadTime >= weightReadInterval && nfcReaderState < NFC_WRITING) | ||||
|   { | ||||
|     lastWeightReadTime = currentMillis; | ||||
|  | ||||
|     // Prüfen ob die Waage korrekt genullt ist | ||||
|     // Abweichung von 2g ignorieren | ||||
|     if (autoTare && (weight > 2 && weight < 7) || weight < -2) | ||||
|     // Ausgabe der Waage auf Display | ||||
|     if(pauseMainTask == 0) | ||||
|     { | ||||
|       scale_tare_counter++; | ||||
|       if (mainTaskWasPaused || (weight != lastWeight && nfcReaderState == NFC_IDLE && (!bambuCredentials.autosend_enable || autoSetToBambuSpoolId == 0))) | ||||
|       { | ||||
|         (weight < 2) ? ((weight < -2) ? oledShowMessage("!! -0") : oledShowWeight(0)) : oledShowWeight(weight); | ||||
|       } | ||||
|       mainTaskWasPaused = false; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       scale_tare_counter = 0; | ||||
|       mainTaskWasPaused = true; | ||||
|     } | ||||
|  | ||||
|     // Prüfen ob das Gewicht gleich bleibt und dann senden | ||||
|     if (abs(weight - lastWeight) <= 2 && weight > 5) | ||||
|     { | ||||
|       weigthCouterToApi++; | ||||
|     }  | ||||
|     else  | ||||
|     { | ||||
|       weigthCouterToApi = 0; | ||||
|       weightSend = 0; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   // reset weight counter after writing tag | ||||
|   // TBD: what exactly is the logic behind this? | ||||
|   if (currentMillis - lastWeightReadTime >= weightReadInterval && nfcReaderState != NFC_IDLE && nfcReaderState != NFC_READ_SUCCESS) | ||||
|   { | ||||
|     weigthCouterToApi = 0; | ||||
|   } | ||||
|    | ||||
|   lastWeight = weight; | ||||
|  | ||||
|   // Wenn ein Tag mit SM id erkannte wurde und der Waage Counter anspricht an SM Senden | ||||
|   if (activeSpoolId != "" && weigthCouterToApi > 3 && weightSend == 0 && nfcReaderState == NFC_READ_SUCCESS) { | ||||
|     oledShowIcon("loading"); | ||||
|     if (updateSpoolWeight(activeSpoolId, weight))  | ||||
|     // Wenn Timer abgelaufen und nicht gerade ein RFID-Tag geschrieben wird | ||||
|     if (currentMillis - lastWeightReadTime >= weightReadInterval && nfcReaderState < NFC_WRITING) | ||||
|     { | ||||
|       oledShowIcon("success"); | ||||
|       vTaskDelay(2000 / portTICK_PERIOD_MS); | ||||
|       weightSend = 1; | ||||
|       autoSetToBambuSpoolId = activeSpoolId.toInt(); | ||||
|       lastWeightReadTime = currentMillis; | ||||
|  | ||||
|       if (octoEnabled)  | ||||
|       // Prüfen ob die Waage korrekt genullt ist | ||||
|       // Abweichung von 2g ignorieren | ||||
|       if (autoTare && (weight > 2 && weight < 7) || weight < -2) | ||||
|       { | ||||
|         updateSpoolOcto(autoSetToBambuSpoolId); | ||||
|         scale_tare_counter++; | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|         scale_tare_counter = 0; | ||||
|       } | ||||
|  | ||||
|       // Prüfen ob das Gewicht gleich bleibt und dann senden | ||||
|       if (abs(weight - lastWeight) <= 2 && weight > 5) | ||||
|       { | ||||
|         weigthCouterToApi++; | ||||
|       }  | ||||
|       else  | ||||
|       { | ||||
|         weigthCouterToApi = 0; | ||||
|         weightSend = 0; | ||||
|       } | ||||
|     } | ||||
|     else | ||||
|  | ||||
|     // reset weight counter after writing tag | ||||
|     // TBD: what exactly is the logic behind this? | ||||
|     if (currentMillis - lastWeightReadTime >= weightReadInterval && nfcReaderState != NFC_IDLE && nfcReaderState != NFC_READ_SUCCESS) | ||||
|     { | ||||
|       oledShowIcon("failed"); | ||||
|       vTaskDelay(2000 / portTICK_PERIOD_MS); | ||||
|       weigthCouterToApi = 0; | ||||
|     } | ||||
|      | ||||
|     lastWeight = weight; | ||||
|  | ||||
|     // Wenn ein Tag mit SM id erkannte wurde und der Waage Counter anspricht an SM Senden | ||||
|     if (activeSpoolId != "" && weigthCouterToApi > 3 && weightSend == 0 && nfcReaderState == NFC_READ_SUCCESS && tagProcessed == false && spoolmanApiState == API_IDLE)  | ||||
|     { | ||||
|       // set the current tag as processed to prevent it beeing processed again | ||||
|       tagProcessed = true; | ||||
|  | ||||
|       if (updateSpoolWeight(activeSpoolId, weight))  | ||||
|       { | ||||
|         weightSend = 1; | ||||
|          | ||||
|         // Set Bambu spool ID for auto-send if enabled | ||||
|         if (bambuCredentials.autosend_enable)  | ||||
|         { | ||||
|           autoSetToBambuSpoolId = activeSpoolId.toInt(); | ||||
|         } | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|         oledShowIcon("failed"); | ||||
|         vTaskDelay(2000 / portTICK_PERIOD_MS); | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     if(octoEnabled && sendOctoUpdate && spoolmanApiState == API_IDLE) | ||||
|     { | ||||
|       updateSpoolOcto(autoSetToBambuSpoolId); | ||||
|       sendOctoUpdate = false; | ||||
|     } | ||||
|   } | ||||
|    | ||||
|   | ||||
							
								
								
									
										9
									
								
								src/main.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/main.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| #ifndef MAIN_H | ||||
| #define MAIN_H | ||||
|  | ||||
| #include <Arduino.h> | ||||
|  | ||||
|  | ||||
| extern bool booting; | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										1797
									
								
								src/nfc.cpp
									
									
									
									
									
								
							
							
						
						
									
										1797
									
								
								src/nfc.cpp
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -15,7 +15,8 @@ typedef enum{ | ||||
|  | ||||
| void startNfc(); | ||||
| void scanRfidTask(void * parameter); | ||||
| void startWriteJsonToTag(const char* payload); | ||||
| void startWriteJsonToTag(const bool isSpoolTag, const char* payload); | ||||
| bool quickSpoolIdCheck(String uidString); | ||||
|  | ||||
| extern TaskHandle_t RfidReaderTask; | ||||
| extern String nfcJsonData; | ||||
| @@ -23,6 +24,8 @@ extern String activeSpoolId; | ||||
| extern String lastSpoolId; | ||||
| extern volatile nfcReaderStateType nfcReaderState; | ||||
| extern volatile bool pauseBambuMqttTask; | ||||
| extern volatile bool nfcWriteInProgress; | ||||
| extern bool tagProcessed; | ||||
|  | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -224,7 +224,7 @@ void handleUpdate(AsyncWebServer &server) { | ||||
|             static int lastProgress = -1; | ||||
|             if (currentProgress != lastProgress && (currentProgress % 10 == 0 || final)) { | ||||
|                 sendUpdateProgress(currentProgress, "uploading"); | ||||
|                 oledShowMessage("Update: " + String(currentProgress) + "%"); | ||||
|                 oledShowProgressBar(currentProgress, 100, "Update", "Download"); | ||||
|                 vTaskDelay(50 / portTICK_PERIOD_MS); | ||||
|                 lastProgress = currentProgress; | ||||
|             } | ||||
|   | ||||
| @@ -17,8 +17,9 @@ uint8_t weigthCouterToApi = 0; | ||||
| uint8_t scale_tare_counter = 0; | ||||
| bool scaleTareRequest = false; | ||||
| uint8_t pauseMainTask = 0; | ||||
| uint8_t scaleCalibrated = 1; | ||||
| bool scaleCalibrated; | ||||
| bool autoTare = true; | ||||
| bool scaleCalibrationActive = false; | ||||
|  | ||||
| // ##### Funktionen für Waage ##### | ||||
| uint8_t setAutoTare(bool autoTareValue) { | ||||
| @@ -88,7 +89,13 @@ void start_scale(bool touchSensorConnected) { | ||||
|   // NVS lesen | ||||
|   Preferences preferences; | ||||
|   preferences.begin(NVS_NAMESPACE_SCALE, true); // true = readonly | ||||
|   calibrationValue = preferences.getFloat(NVS_KEY_CALIBRATION, defaultScaleCalibrationValue); | ||||
|   if(preferences.isKey(NVS_KEY_CALIBRATION)){ | ||||
|     calibrationValue = preferences.getFloat(NVS_KEY_CALIBRATION); | ||||
|     scaleCalibrated = true; | ||||
|   }else{ | ||||
|     calibrationValue = SCALE_DEFAULT_CALIBRATION_VALUE; | ||||
|     scaleCalibrated = false; | ||||
|   } | ||||
|    | ||||
|   // auto Tare | ||||
|   // Wenn Touch Sensor verbunden, dann autoTare auf false setzen | ||||
| @@ -103,31 +110,21 @@ void start_scale(bool touchSensorConnected) { | ||||
|  | ||||
|   scale.begin(LOADCELL_DOUT_PIN, LOADCELL_SCK_PIN); | ||||
|  | ||||
|   if (isnan(calibrationValue) || calibrationValue < 1) { | ||||
|     calibrationValue = defaultScaleCalibrationValue; | ||||
|     scaleCalibrated = 0; | ||||
|  | ||||
|     oledShowMessage("Scale not calibrated!"); | ||||
|     for (uint16_t i = 0; i < 50000; i++) { | ||||
|       yield(); | ||||
|       vTaskDelay(pdMS_TO_TICKS(1)); | ||||
|       esp_task_wdt_reset(); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   oledShowMessage("Scale Tare Please remove all"); | ||||
|   for (uint16_t i = 0; i < 2000; i++) { | ||||
|   oledShowProgressBar(6, 7, DISPLAY_BOOT_TEXT, "Tare scale"); | ||||
|   for (uint16_t i = 0; i < 3000; i++) { | ||||
|     yield(); | ||||
|     vTaskDelay(pdMS_TO_TICKS(1)); | ||||
|     esp_task_wdt_reset(); | ||||
|   } | ||||
|  | ||||
|   if (scale.wait_ready_timeout(1000)) | ||||
|   { | ||||
|     scale.set_scale(calibrationValue); // this value is obtained by calibrating the scale with known weights; see the README for details | ||||
|     scale.tare(); | ||||
|   while(!scale.is_ready()) { | ||||
|     vTaskDelay(pdMS_TO_TICKS(5000)); | ||||
|   } | ||||
|  | ||||
|   scale.set_scale(calibrationValue); | ||||
|   //vTaskDelay(pdMS_TO_TICKS(5000)); | ||||
|   //scale.tare(); | ||||
|  | ||||
|   // Display Gewicht | ||||
|   oledShowWeight(0); | ||||
|  | ||||
| @@ -152,6 +149,8 @@ uint8_t calibrate_scale() { | ||||
|   uint8_t returnState = 0; | ||||
|   float newCalibrationValue; | ||||
|  | ||||
|   scaleCalibrationActive = true; | ||||
|  | ||||
|   vTaskSuspend(RfidReaderTask); | ||||
|   vTaskSuspend(ScaleTask); | ||||
|  | ||||
| @@ -162,7 +161,7 @@ uint8_t calibrate_scale() { | ||||
|   { | ||||
|      | ||||
|     scale.set_scale(); | ||||
|     oledShowMessage("Step 1 empty Scale"); | ||||
|     oledShowProgressBar(0, 3, "Scale Cal.", "Empty Scale"); | ||||
|  | ||||
|     for (uint16_t i = 0; i < 5000; i++) { | ||||
|       yield(); | ||||
| @@ -174,7 +173,7 @@ uint8_t calibrate_scale() { | ||||
|     Serial.println("Tare done..."); | ||||
|     Serial.print("Place a known weight on the scale..."); | ||||
|  | ||||
|     oledShowMessage("Step 2 Place the weight"); | ||||
|     oledShowProgressBar(1, 3, "Scale Cal.", "Place the weight"); | ||||
|  | ||||
|     for (uint16_t i = 0; i < 5000; i++) { | ||||
|       yield(); | ||||
| @@ -207,9 +206,7 @@ uint8_t calibrate_scale() { | ||||
|       Serial.print("Verified stored value: "); | ||||
|       Serial.println(verifyValue); | ||||
|  | ||||
|       Serial.println("End calibration, remove weight"); | ||||
|  | ||||
|       oledShowMessage("Remove weight"); | ||||
|       oledShowProgressBar(2, 3, "Scale Cal.", "Remove weight"); | ||||
|  | ||||
|       scale.set_scale(newCalibrationValue); | ||||
|       for (uint16_t i = 0; i < 2000; i++) { | ||||
| @@ -218,7 +215,7 @@ uint8_t calibrate_scale() { | ||||
|         esp_task_wdt_reset(); | ||||
|       } | ||||
|        | ||||
|       oledShowMessage("Scale calibrated"); | ||||
|       oledShowProgressBar(3, 3, "Scale Cal.", "Completed"); | ||||
|  | ||||
|       // For some reason it is not possible to re-tare the scale here, it will result in a wdt timeout. Instead let the scale loop do the taring | ||||
|       //scale.tare(); | ||||
| @@ -230,23 +227,21 @@ uint8_t calibrate_scale() { | ||||
|         esp_task_wdt_reset(); | ||||
|       } | ||||
|  | ||||
|       scaleCalibrated = true; | ||||
|       returnState = 1; | ||||
|     } | ||||
|     | ||||
|     else | ||||
|     { | ||||
|       { | ||||
|         Serial.println("Calibration value is invalid. Please recalibrate."); | ||||
|       Serial.println("Calibration value is invalid. Please recalibrate."); | ||||
|  | ||||
|         oledShowMessage("Calibration ERROR Try again"); | ||||
|       oledShowProgressBar(3, 3, "Failure", "Calibration error"); | ||||
|  | ||||
|         for (uint16_t i = 0; i < 50000; i++) { | ||||
|           yield(); | ||||
|           vTaskDelay(pdMS_TO_TICKS(1)); | ||||
|           esp_task_wdt_reset(); | ||||
|         } | ||||
|         returnState = 0; | ||||
|       for (uint16_t i = 0; i < 50000; i++) { | ||||
|         yield(); | ||||
|         vTaskDelay(pdMS_TO_TICKS(1)); | ||||
|         esp_task_wdt_reset(); | ||||
|       } | ||||
|       returnState = 0; | ||||
|     }  | ||||
|   } | ||||
|   else  | ||||
| @@ -267,6 +262,7 @@ uint8_t calibrate_scale() { | ||||
|   vTaskResume(ScaleTask); | ||||
|   pauseBambuMqttTask = false; | ||||
|   pauseMainTask = 0; | ||||
|   scaleCalibrationActive = false; | ||||
|  | ||||
|   return returnState; | ||||
| } | ||||
|   | ||||
| @@ -15,8 +15,9 @@ extern uint8_t weigthCouterToApi; | ||||
| extern uint8_t scale_tare_counter; | ||||
| extern uint8_t scaleTareRequest; | ||||
| extern uint8_t pauseMainTask; | ||||
| extern uint8_t scaleCalibrated; | ||||
| extern bool scaleCalibrated; | ||||
| extern bool autoTare; | ||||
| extern bool scaleCalibrationActive; | ||||
|  | ||||
| extern TaskHandle_t ScaleTask; | ||||
|  | ||||
|   | ||||
| @@ -34,7 +34,7 @@ void onWsEvent(AsyncWebSocket *server, AsyncWebSocketClient *client, AwsEventTyp | ||||
|         Serial.println("Neuer Client verbunden!"); | ||||
|         // Sende die AMS-Daten an den neuen Client | ||||
|         if (!bambuDisabled) sendAmsData(client); | ||||
|         sendNfcData(client); | ||||
|         sendNfcData(); | ||||
|         foundNfcTag(client, 0); | ||||
|         sendWriteResult(client, 3); | ||||
|  | ||||
| @@ -48,11 +48,15 @@ void onWsEvent(AsyncWebSocket *server, AsyncWebSocketClient *client, AwsEventTyp | ||||
|     } else if (type == WS_EVT_PONG) { | ||||
|         Serial.printf("WebSocket Client #%u pong\n", client->id()); | ||||
|     } else if (type == WS_EVT_DATA) { | ||||
|         String message = String((char*)data); | ||||
|         JsonDocument doc; | ||||
|         deserializeJson(doc, message); | ||||
|         DeserializationError error = deserializeJson(doc, (char*)data, len); | ||||
|         //String message = String((char*)data); | ||||
|         //deserializeJson(doc, message); | ||||
|  | ||||
|         bool spoolmanConnected = (spoolmanApiState != API_INIT); | ||||
|         if (error) { | ||||
|             Serial.println("JSON deserialization failed: " + String(error.c_str())); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         if (doc["type"] == "heartbeat") { | ||||
|             // Sende Heartbeat-Antwort | ||||
| @@ -69,7 +73,8 @@ void onWsEvent(AsyncWebSocket *server, AsyncWebSocketClient *client, AwsEventTyp | ||||
|                 // Versuche NFC-Daten zu schreiben | ||||
|                 String payloadString; | ||||
|                 serializeJson(doc["payload"], payloadString); | ||||
|                 startWriteJsonToTag(payloadString.c_str()); | ||||
|  | ||||
|                 startWriteJsonToTag((doc["tagType"] == "spool") ? true : false, payloadString.c_str()); | ||||
|             } | ||||
|         } | ||||
|  | ||||
| @@ -150,11 +155,11 @@ void sendWriteResult(AsyncWebSocketClient *client, uint8_t success) { | ||||
| void foundNfcTag(AsyncWebSocketClient *client, uint8_t success) { | ||||
|     if (success == lastSuccess) return; | ||||
|     ws.textAll("{\"type\":\"nfcTag\", \"payload\":{\"found\": " + String(success) + "}}"); | ||||
|     sendNfcData(nullptr); | ||||
|     sendNfcData(); | ||||
|     lastSuccess = success; | ||||
| } | ||||
|  | ||||
| void sendNfcData(AsyncWebSocketClient *client) { | ||||
| void sendNfcData() { | ||||
|     if (lastnfcReaderState == nfcReaderState) return; | ||||
|     // TBD: Why is there no status for reading the tag? | ||||
|     switch(nfcReaderState){ | ||||
| @@ -189,6 +194,7 @@ void sendAmsData(AsyncWebSocketClient *client) { | ||||
| } | ||||
|  | ||||
| void setupWebserver(AsyncWebServer &server) { | ||||
|     oledShowProgressBar(2, 7, DISPLAY_BOOT_TEXT, "Webserver init"); | ||||
|     // Deaktiviere alle Debug-Ausgaben | ||||
|     Serial.setDebugOutput(false); | ||||
|      | ||||
| @@ -273,8 +279,6 @@ void setupWebserver(AsyncWebServer &server) { | ||||
|         html.replace("{{autoSendToBambu}}", bambuCredentials.autosend_enable ? "checked" : ""); | ||||
|         html.replace("{{autoSendTime}}", (bambuCredentials.autosend_time != 0) ? String(bambuCredentials.autosend_time) : String(BAMBU_DEFAULT_AUTOSEND_TIME)); | ||||
|  | ||||
|         doc.clear(); | ||||
|  | ||||
|         request->send(200, "text/html", html); | ||||
|     }); | ||||
|  | ||||
|   | ||||
| @@ -24,7 +24,7 @@ void setupWebserver(AsyncWebServer &server); | ||||
|  | ||||
| // WebSocket-Funktionen | ||||
| void sendAmsData(AsyncWebSocketClient *client); | ||||
| void sendNfcData(AsyncWebSocketClient *client); | ||||
| void sendNfcData(); | ||||
| void foundNfcTag(AsyncWebSocketClient *client, uint8_t success); | ||||
| void sendWriteResult(AsyncWebSocketClient *client, uint8_t success); | ||||
|  | ||||
|   | ||||
| @@ -61,8 +61,7 @@ void initWiFi() { | ||||
|   wm.setWiFiAutoReconnect(true); | ||||
|   wm.setConnectTimeout(10); | ||||
|  | ||||
|   oledShowTopRow(); | ||||
|   oledShowMessage("WiFi Setup"); | ||||
|   oledShowProgressBar(1, 7, DISPLAY_BOOT_TEXT, "WiFi init"); | ||||
|    | ||||
|   //bool res = wm.autoConnect("FilaMan"); // anonymous ap | ||||
|   if(!wm.autoConnect("FilaMan")) { | ||||
| @@ -80,9 +79,6 @@ void initWiFi() { | ||||
|     Serial.println(WiFi.localIP()); | ||||
|  | ||||
|     oledShowTopRow(); | ||||
|     display.display(); | ||||
|  | ||||
|     vTaskDelay(500 / portTICK_PERIOD_MS); | ||||
|  | ||||
|     // mDNS | ||||
|     startMDNS(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user