Skip to content

Spoolman with bambulab NFC tags inspired by openspool

License

Notifications You must be signed in to change notification settings

jcortenbach/openspoolman

 
 

Repository files navigation

logo OpenSpoolMan

Use any filament like Bambu filaments with automatic recognition and filament usage updates in your AMS!

No need for cloud or any special hardware, just your phone and some NFC tags!

Similar functionality to https://github.com/spuder/OpenSpool using only your phone, server and NFC tags integrated with SpoolMan

Everything works locally without cloud access, you can use scripts/init_bambulab.py script to access your PRINTER_ID and PRINTER_CODE if it is not available on your printer.

News

0.1.3 - 22.12.2024 - Added manual assignment for empty slots

Main features

Information about your AMS Assign NFC tags to your spools in SpoolMan Write the URL of the Spool detail to NFC tag directly from the browser
Information about your AMS Assign NFC tags to your spools in SpoolMan NFC write success
Bring Phone close to the NFC tag and open the spool detail Pick the AMS slot where you want the spool to be loaded
Open NFC link Spool info Pick tray
Automatically track the usage of your filaments based on the slicer estimates in SpoolMan Track Bambu filaments without additional NFC Tags Resolve issues with few clicks (soon)
Slicer estimate Bambu filament usgae tracking Resolve issues

What you need:

How to setup:

  • Rename config.env.template to config.env or set environment properies and:
    • set OPENSPOOLMAN_BASE_URL - that is the URL where OpenSpoolMan will be available on your network. Must be https for NFC write to work. without trailing slash
    • set PRINTER_ID - On your printer clicking on Setting -> Device -> Printer SN
    • set PRINTER_ACCESS_CODE - On your printer clicking on Setting -> Lan Only Mode -> Access Code (you don't need to enable the LAN Only Mode)
    • set PRINTER_IP - On your printer clicking on Setting -> Lan Only Mode -> IP Address (you don't need to enable the LAN Only Mode)
    • set SPOOLMAN_BASE_URL - according to your SpoolMan installation without trailing slash
    • set AUTO_SPEND - to True if you want for system to track your filament spending (check AUTO_SPEND issues below) default to False
  • Run the server (wsgi.py)
  • Run Spool Man
  • Add following extra Fields to your SpoolMan:
    • Filaments
      • "type","Type","Choice","Basic","Silk, Basic, High Speed, Matte, Plus, Flexible, Translucent","No"
      • "nozzle_temperature","Nozzle Temperature","Integer Range","°C","190 – 230"
    • Spools
      • "tag","tag","Text"
      • "active_tray","Active Tray","Text
  • Add your Manufacturers, Filaments and Spools to Spool Man (when adding filament you can try "Import from External" for faster workflow)
  • Open the server base url in browser on your mobile phone
  • Optionally add Bambu Lab RFIDs to extra tag on your Bambu Spools so they will be matching. You can get the tag id from logs or from browser in AMS info.
  • For non Bambu Lab filaments click on the filament and click Write and hold empty NFC tag to your phone (allow NFC in popup if prompted)
  • Attach NFC tag to your filament
  • Load filament to your AMS by loading it and then putting your phone near NFC tag and allowing your phone to open the website
  • On the website pick the slot you put your filament in
  • Done

Deployment

Run locally in venv by configuring environment properties and running wsgi.py, supports adhoc ssl.

Run in docker by configuring config.env and running compose.yaml, you will need more setup/config to run ssl.

Run in kubernetes using helm chart, where you can configure the ingress with SSL. https://github.com/truecharts/public/blob/master/charts/library/common/values.yaml

AUTO SPEND - Automatic filament usage based on slicer estimate

You can turn this feature on to automatically update the spool usage in SpoolMan. This feature is using slicer information about predicted filament weight usage (and in future correlating it with the progress of the printer to compute the estimate of filament used).

This feature has currently following issues/drawbacks:

  • Spending on the start of the print
  • Not spending according to print process and spending full filament weight even if print fails
  • Don't know if it works with LAN mode, since it downloads the 3MF file from cloud
  • Doesn't work if you print from SD card
  • Not tested with multiple AMS systems
  • External spool spending not yet implemented
  • Not handling the mismatch between the SpoolMan and AMS (if you don't have the Active Tray information correct in spoolman it won't work properly)

Notes:

  • If you change the BASE_URL of this app, you will need to reconfigure all NFC TAGS

TBD:

  • Filament remaining in AMS (I have only AMS lite, if you have AMS we can test together)
  • Filament spending based on printing
    • TODO: handle situation when the print doesn't finish
    • TODO: what about locally run file?
    • TODO: test with multiple AMS
    • TODO: filament usage in external spool
  • Code cleanup
  • Video showcase
  • Docker compose SSL
  • Logs
  • TODOs
  • Click to resolve issue
  • Better Tray naming
  • Reduce the amount of files in docker container
  • Cloud service for controlled redirect so you don't have to reconfigure NFC tags
  • Handle printer offline
  • QR codes
  • Add search to list of spools

About

Spoolman with bambulab NFC tags inspired by openspool

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 64.4%
  • HTML 33.7%
  • Dockerfile 1.9%