Thanks to visit codestin.com
Credit goes to Github.com

Skip to content

maziggy/bambuddy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Bambuddy Logo

Bambuddy

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

Release License Stars Issues Visitors

Features β€’ Screenshots β€’ Quick Start β€’ Documentation β€’ Contributing


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
  • Re-print to any connected printer
  • Archive comparison (side-by-side diff)

πŸ“Š Monitoring & Stats

  • Real-time printer status via WebSocket
  • Live camera streaming (MJPEG) & snapshots
  • 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)
  • 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
  • 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 filament sync
  • Bambu Cloud profile management
  • K-profiles (pressure advance)
  • External sidebar links
  • Webhooks & API keys

πŸ› οΈ Maintenance

  • Maintenance scheduling & tracking
  • Interval reminders (hours/days)
  • Print time accuracy stats
  • File manager for printer storage

πŸŽ›οΈ Printer Control

  • AMS/AMS-HT temperature & humidity monitoring
  • Chamber temperature & light control
  • Speed profiles & fan controls
  • AI detection modules (spaghetti, first layer)
  • Automated calibration (bed level, vibration)
  • Dual nozzle support

Plus: Dark/light theme β€’ 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

Projects
Group related prints into projects

Queue
Print scheduling and queue management

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


πŸš€ 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)

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

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

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:

cd bambuddy && git pull && docker compose up -d --build

Useful Commands:

# 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:

ports:
  - "3000:8000"  # Access on port 3000

Reverse Proxy (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 (for easier printer discovery):

services:
  bambuddy:
    build: .
    network_mode: host

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: Settings β†’ Network β†’ LAN 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 Bug β€’ Request Feature β€’ Documentation