No Description

maziggy dbcbde0b16 Improved email notification provider 5 months ago
.github e6b01d8ead Added issue/pull request templates 5 months ago
backend dbcbde0b16 Improved email notification provider 5 months ago
docs 09bdb183b9 Updated README; Added new screenshots 5 months ago
frontend dbcbde0b16 Improved email notification provider 5 months ago
icons 07f4d4482f Moved documentation to it's own repository 5 months ago
mockup 06bfaa3c74 Completely removed control page and all it's related code 5 months ago
scripts 6de875582a Completely refactored k-profile module 5 months ago
static d1518083fc ## New Features 5 months ago
tests 107d94e938 Added playwright tests 5 months ago
._.DS_Store ef927985e4 Added filament spool fill levels to printer card 5 months ago
.dockerignore 83d8c4e865 Added Docker support 5 months ago
.env.example 28a5e786e9 Added configurable logging; Major improvements and bugfixes 5 months ago
.gitignore 5b6a449663 Cleanup 5 months ago
CHANGELOG.md 60ec159c97 Added CHANGELOG.md 5 months ago
Dockerfile 0194a0498e Added Docker support 5 months ago
LICENSE 8a85147713 Initial commit 6 months ago
PLAN.md 6d71261de7 Renaming app to Bambuddy 5 months ago
README.md 9cdce0d603 Updated README; Added new screenshots 5 months ago
build_docker.sh 0194a0498e Added Docker support 5 months ago
docker-compose.yml 83d8c4e865 Added Docker support 5 months ago
requirements.txt d1518083fc ## New Features 5 months ago

README.md

Bambuddy Logo

Bambuddy

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

Release License Stars Issues

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 - Re-print to any connected printer - Archive comparison (side-by-side diff) ### 📊 Monitoring & Stats - Real-time printer status via WebSocket - HMS error monitoring - 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) - 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](https://github.com/Donkie/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

Plus: Dark/light theme • Mobile responsive • Keyboard shortcuts • Multi-language (EN/DE) • Auto updates


📸 Screenshots

Click to expand screenshots

Printers
Real-time printer monitoring with AMS status

Archives
Print archive with context menu and project assignment

Projects
Group related prints into projects

Queue
Print scheduling and queue management

Statistics
Customizable statistics dashboard

Maintenance Status
Maintenance tracking per printer

Maintenance Overdue
Overdue maintenance alerts

Maintenance Settings
Configure maintenance types and intervals

Profiles Create
Create new filament presets

Profiles Edit
Edit filament preset settings

K-Profiles
Pressure advance (K-factor) profiles

Settings
Configuration and integrations

Smart Plugs
Smart plug control and automation

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

# 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 in the Wiki:


🖨️ 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