Нет описания

maziggy c960b91f2a Fixed bug where printer's hour counter was not updated, if backend was restarted 4 месяцев назад
.github a0c4106aef Deleted .github/FUNDING.yml 4 месяцев назад
backend c960b91f2a Fixed bug where printer's hour counter was not updated, if backend was restarted 4 месяцев назад
demo-video 815866c364 Demo video 4 месяцев назад
deploy a7319f0e70 Fix browser freeze on print completion with camera stream open 5 месяцев назад
docs 021318437d Updated screenshots 4 месяцев назад
frontend 6794846ac0 Fixed timer issue in debug log collection 4 месяцев назад
icons 53eff03fb5 Added debug logging for printer's hour counter and current active AMS slot mapping 4 месяцев назад
mockup 83cbac04b7 - Add interactive API Browser to Settings > API Keys 4 месяцев назад
scripts 83cbac04b7 - Add interactive API Browser to Settings > API Keys 4 месяцев назад
static 6794846ac0 Fixed timer issue in debug log collection 4 месяцев назад
tests 83cbac04b7 - Add interactive API Browser to Settings > API Keys 4 месяцев назад
.coverage ff53e62ef8 Add comprehensive automated testing infrastructure 5 месяцев назад
.dockerignore 83d8c4e865 Added Docker support 5 месяцев назад
.env.example 28a5e786e9 Added configurable logging; Major improvements and bugfixes 5 месяцев назад
.gitignore 6fb71de6a2 Add firmware update helper for LAN-only printers 4 месяцев назад
.pre-commit-config.yaml 929c4c8cd6 - Fix total print hours calculation in set_total_hours to include all 5 месяцев назад
CHANGELOG.md 50fd0c018b Add support bundle feature for issue reporting 4 месяцев назад
CODE_OF_CONDUCT.md ac6cbd757a - Added 4 месяцев назад
CONTRIBUTING.md ac6cbd757a - Added 4 месяцев назад
Dockerfile 29f1fa9732 - Improved Docker environment 4 месяцев назад
Dockerfile.test 88bd020dc9 Improved Docker support; Added Docker test suite 5 месяцев назад
LICENSE 8a85147713 Initial commit 6 месяцев назад
PLAN.md 6d71261de7 Renaming app to Bambuddy 5 месяцев назад
README.md 50fd0c018b Add support bundle feature for issue reporting 4 месяцев назад
SECURITY.md ac6cbd757a - Added 4 месяцев назад
build_docker.sh 6cd9cb7033 Fixed docker build warnings 5 месяцев назад
docker-compose.test.yml 88bd020dc9 Improved Docker support; Added Docker test suite 5 месяцев назад
docker-compose.yml bb37a8c8a8 Fix virtual printer model codes and serial prefixes 4 месяцев назад
docker-publish.sh 29f1fa9732 - Improved Docker environment 4 месяцев назад
pyproject.toml 58c98b1075 Added docker test suite 5 месяцев назад
requirements-dev.txt 58c98b1075 Added docker test suite 5 месяцев назад
requirements.txt 88e84ca45a - Add Virtual Printer feature - emulate Bambu printer on network 5 месяцев назад
test_backend.sh ff53e62ef8 Add comprehensive automated testing infrastructure 5 месяцев назад
test_docker.sh 88bd020dc9 Improved Docker support; Added Docker test suite 5 месяцев назад
test_frontend.sh ff53e62ef8 Add comprehensive automated testing infrastructure 5 месяцев назад
update_website_wiki.sh 4f2fa7685a Minor fixes 4 месяцев назад

README.md

Bambuddy Logo

Bambuddy

Self-hosted print archive and management system for Bambu Lab 3D printers

Release License Stars Issues Visitors

FeaturesScreenshotsQuick StartDocumentationContributing


Testers Needed! I only have X1C and H2D devices. Help make Bambuddy work with all Bambu Lab printers by reporting your experience!

Why Bambuddy?

  • Own your data — All print history stored locally, no cloud dependency
  • Works offline — Uses LAN Mode for direct printer communication
  • Full automation — Schedule prints, auto power-off, get notified when done
  • Multi-printer support — Manage your entire print farm from one interface

✨ Features

### 📦 Print Archive - Automatic 3MF archiving with metadata - 3D model preview (Three.js) - Duplicate detection & full-text search - Photo attachments & failure analysis - Timelapse editor (trim, speed, music) - Re-print to any connected printer with AMS filament preview - Archive comparison (side-by-side diff) ### 📊 Monitoring & Control - Real-time printer status via WebSocket - Live camera streaming (MJPEG) & snapshots - Fan status monitoring (part cooling, auxiliary, chamber) - Printer control (stop, pause, resume) - Resizable printer cards (S/M/L/XL) - Skip objects during print - AMS slot RFID re-read - HMS error monitoring with history - Print success rates & trends - Filament usage tracking - Cost analytics & failure analysis - CSV/Excel export ### ⏰ Scheduling & Automation - Print queue with drag-and-drop - Scheduled prints (date/time) - Queue Only mode (stage without auto-start) - Smart plug integration (Tasmota) - Energy consumption tracking - Auto power-on before print - Auto power-off after cooldown ### 📁 Projects - Group related prints (e.g., "Voron Build") - Track progress with target counts - Quantity tracking for batch prints - Color-coded project badges - Assign archives via context menu ### 🔔 Notifications - WhatsApp, Telegram, Discord - Email, Pushover, ntfy - Custom webhooks - Quiet hours & daily digest - Customizable message templates ### 🔧 Integrations - [Spoolman](https://github.com/Donkie/Spoolman) filament sync - Bambu Cloud profile management - K-profiles (pressure advance) - External sidebar links - Webhooks & API keys - Interactive API browser with live testing ### 🖨️ Virtual Printer - Emulates a Bambu Lab printer on your network - Send prints directly from Bambu Studio/Orca Slicer - Configurable printer model (X1C, P1S, A1, H2D, etc.) - Queue mode or auto-start mode - SSDP discovery (appears in slicer automatically) - Secure TLS/MQTT communication ### 🛠️ Maintenance & Support - Maintenance scheduling & tracking - Interval reminders (hours/days) - Print time accuracy stats - File manager for printer storage - Firmware update helper (LAN-only printers) - Debug logging toggle with live indicator - Support bundle generator (privacy-filtered)

Plus: Customizable themes (style, background, accent) • Mobile responsive • Keyboard shortcuts • Multi-language (EN/DE) • Auto updates • Database backup/restore • System info dashboard


📸 Screenshots

Click to expand screenshots

Printers
Real-time printer monitoring with AMS status

Archives
Print archive with 3D preview and project assignment

Reprint AMS Mapping
Re-print with AMS filament mapping preview

Timelapse Editor
Built-in timelapse editor with trim, speed, and music

Projects
Group related prints into projects

Project Detail
Project detail view with assigned archives

Project Detail Timeline
Project timeline and print history

Queue
Print scheduling and queue management

Schedule Print
Schedule prints for specific date and time

Statistics
Customizable statistics dashboard

Maintenance
Maintenance tracking per printer

Maintenance Settings
Configure maintenance types and intervals

Cloud Profiles
Bambu Cloud filament profiles

Cloud Profiles Edit
Edit filament preset settings

K-Profiles
Pressure advance (K-factor) profiles

K-Profiles Edit
Edit K-factor profile settings

Settings
General configuration and integrations

Smart Plugs
Smart plug control and energy monitoring

Notifications
Multi-provider notification system

API Keys
API keys and webhook endpoints

Virtual Printer Settings
Virtual printer configuration

Slicer Virtual Printer
Virtual printer appears in Bambu Studio/Orca Slicer

MQTT Debug Log
MQTT debug logging for troubleshooting

Quick Power Plug
Quick power plug control in sidebar


🚀 Quick Start

Requirements

  • Python 3.10+ (3.11/3.12 recommended)
  • Bambu Lab printer with LAN Mode enabled
  • Same local network as printer

Installation

Docker (Recommended)

Option A: Pre-built image (fastest)

mkdir bambuddy && cd bambuddy
curl -O https://raw.githubusercontent.com/maziggy/bambuddy/main/docker-compose.yml
docker compose up -d

Option B: Build from source

git clone https://github.com/maziggy/bambuddy.git
cd bambuddy
docker compose up -d --build

Open http://localhost:8000 in your browser.

Multi-architecture support: Pre-built images are available for linux/amd64 and linux/arm64 (Raspberry Pi 4/5).

macOS/Windows users: Docker Desktop doesn't support network_mode: host. Edit docker-compose.yml: comment out network_mode: host and uncomment the ports: section. Printer discovery won't work - add printers manually by IP.

Docker Configuration & Commands **Environment Variables:** | Variable | Default | Description | |----------|---------|-------------| | `TZ` | `UTC` | Your timezone (e.g., `America/New_York`, `Europe/Berlin`) | | `DEBUG` | `false` | Enable debug logging | | `LOG_LEVEL` | `INFO` | Log level: `DEBUG`, `INFO`, `WARNING`, `ERROR` | **Data Persistence:** | Volume | Purpose | |--------|---------| | `bambuddy.db` | SQLite database with all your print data | | `archive/` | Archived 3MF files and thumbnails | | `logs/` | Application logs | **Updating:** ```bash # Pre-built image: just pull the latest docker compose pull && docker compose up -d # From source: rebuild after pulling changes cd bambuddy && git pull && docker compose up -d --build ``` **Useful Commands:** ```bash # View logs docker compose logs -f # Stop/Start docker compose down docker compose up -d # Shell access docker compose exec bambuddy /bin/bash ``` **Custom Port:** ```yaml ports: - "3000:8000" # Access on port 3000 ``` **Reverse Proxy (Nginx):** ```nginx server { listen 443 ssl http2; server_name bambuddy.yourdomain.com; ssl_certificate /path/to/cert.pem; ssl_certificate_key /path/to/key.pem; location / { proxy_pass http://localhost:8000; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_read_timeout 86400; } } ``` > **Note:** WebSocket support is required for real-time printer updates. **Network Mode Host** (required for printer discovery and camera streaming): ```yaml services: bambuddy: build: . network_mode: host ``` > **Note:** Docker's default bridge networking cannot receive SSDP multicast packets for automatic printer discovery. When using `network_mode: host`, Bambuddy can discover printers via subnet scanning - enter your network range (e.g., `192.168.1.0/24`) in the Add Printer dialog.

Manual Installation

# Clone and setup
git clone https://github.com/maziggy/bambuddy.git
cd bambuddy
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt

# Run
uvicorn backend.app.main:app --host 0.0.0.0 --port 8000

Open http://localhost:8000 and add your printer!

Need detailed instructions? See the Installation Guide

Enabling LAN Mode

  1. On printer: SettingsNetworkLAN Mode
  2. Enable LAN Mode and note the Access Code
  3. Find IP address in network settings
  4. Find Serial Number in device info

📚 Documentation

Full documentation available at wiki.bambuddy.cool:


🖨️ Supported Printers

Series Models Status
H2 H2C, H2D, H2S ✅ Tested (H2D)
X1 X1, X1 Carbon ✅ Tested (X1C)
P1 P1P, P1S 🧪 Needs testing
A1 A1, A1 Mini 🧪 Needs testing

🛠️ Tech Stack

Component Technology
Backend Python, FastAPI, SQLAlchemy
Frontend React, TypeScript, Tailwind CSS
Database SQLite
3D Viewer Three.js
Communication MQTT (TLS), FTPS

🤝 Contributing

Contributions welcome! Here's how to help:

  1. Test — Report issues with your printer model
  2. Translate — Add new languages
  3. Code — Submit PRs for bugs or features
  4. Document — Improve wiki and guides

    # Development setup
    git clone https://github.com/maziggy/bambuddy.git
    cd bambuddy
    
    # Backend
    python3 -m venv venv && source venv/bin/activate
    pip install -r requirements.txt
    DEBUG=true uvicorn backend.app.main:app --reload
    
    # Frontend (separate terminal)
    cd frontend && npm install && npm run dev
    

See CONTRIBUTING.md for guidelines.


📄 License

MIT License — see LICENSE for details.


🙏 Acknowledgments

  • Bambu Lab for amazing printers
  • The reverse engineering community for protocol documentation
  • All testers and contributors

Made with ❤️ for the 3D printing community

Report BugRequest FeatureDocumentation