Ein intelligentes Haushalts-Inventarsystem zur Verwaltung von Lebensmitteln mit Barcode-Scanner, Einkaufslisten und umfangreicher Statistik.
- Features
- Installation
- Verwendung
- Technologie-Stack
- API-Dokumentation
- Datenbank-Schema
- Raspberry Pi Setup
- Entwicklung
- Barcode-Scanner: EAN-Codes scannen mit Kamera oder manueller Eingabe
- Open Food Facts Integration: Automatisches Abrufen von Produktinformationen
- Produktverwaltung: Hinzufügen, Bearbeiten, Löschen von Produkten
- Kamera-Integration: Direkte Kameraaufnahme für Produktfotos mit Live-Vorschau
- Bild-Kompression: Automatische Optimierung für Raspberry Pi (max 200KB)
- Dateisystem-Storage: Bilder werden in
static/uploads/gespeichert, nicht in der Datenbank
- Duplikat-Erkennung: Warnt beim Hinzufügen bereits vorhandener Produkte
- Einkaufsliste:
- Manuelles Hinzufügen von Artikeln
- Automatische Generierung aus abgelaufenen/niedrigen Beständen
- Abhaken und Löschen erledigter Einkäufe
- Barcode-Verlauf:
- Speichert alle gescannten Produkte mit vollständigen Metadaten
- Quick-Add Funktion für bereits gelöschte Produkte
- Persistenz auch nach Produkt-Löschung
- Kategorien & Tags:
- Automatische Kategorisierung via Open Food Facts API
- Manuelle Tags für eigene Organisation
- Preis-Tracking: Gesamtwert des Inventars und Kostenübersicht
Basis-Statistiken:
- Gesamtanzahl Produkte
- Abgelaufene Produkte
- Bald ablaufende Produkte (innerhalb 7 Tage)
- Gesamtwert des Inventars
Erweiterte Statistiken:
- Verschwendungs-Tracking (Wert abgelaufener Produkte)
- Kategorie-Breakdown mit Anzahl pro Kategorie
- Top 5 gescannte Produkte
- Wöchentliche Trends
- Dark Mode: Automatische Erkennung des System-Themes
- Mobile-First: Optimiert für Smartphone-Nutzung
- Responsive Design: Separate Layouts für Desktop und Mobile
- Collapsible Search: Platzsparende mobile Suche mit Slide-Animation
- Touch-optimiert: Große Buttons und Checkboxen für mobile Geräte
- Burger-Menu: Kompakte Filter-Sidebar
- Glass-Panel Design: Moderne Optik mit Backdrop-Blur-Effekten
- Input-Sanitization: Schutz vor SQL-Injection und XSS
- EAN-Validierung: Format-Prüfung für Barcodes (8-13 Stellen)
- Datei-System Storage: Effiziente Bild-Speicherung mit automatischer Löschung
- Automatische Migrations: Nahtlose Datenbank-Updates beim Start
- Indizierte Suche: Optimierte Abfragen auf Name, Standort und Ablaufdatum
- Size Limits: Max 1MB Request-Größe, Bild-Kompression auf ~50-200KB
- Python 3.8 oder höher
- SQLite3 (im Python-Standard enthalten)
- Internetverbindung (für Open Food Facts API)
- Repository klonen/herunterladen
cd /pfad/zu/deinem/ordner- Virtuelle Umgebung erstellen (empfohlen)
python3 -m venv venv
source venv/bin/activate # Linux/Mac/Raspberry Pi
# oder
venv\Scripts\activate # Windows- Dependencies installieren
pip install -r requirements.txt
# Oder manuell:
# pip install flask requests gunicorn- Server starten
Entwicklung (Testing):
python app.pyProduction (Raspberry Pi 24/7):
gunicorn -w 4 -b 0.0.0.0:5000 app:app
# -w 4 = 4 Worker-Prozesse (für Raspberry Pi 4)
# -w 2 = für Raspberry Pi Zero/3Die Datenbank wird automatisch beim ersten Start erstellt.
Die App ist bereits für 0.0.0.0 konfiguriert, sodass du von jedem Gerät im Netzwerk zugreifen kannst:
http://<raspberry-pi-ip>:5000
Production-Server mit Gunicorn (empfohlen):
# Mehr Worker für bessere Performance
gunicorn -w 4 -b 0.0.0.0:5000 --timeout 120 app:app
# Mit Logging
gunicorn -w 4 -b 0.0.0.0:5000 --access-logfile - --error-logfile - app:app- Barcode scannen: Kamera-Button drücken oder EAN manuell eingeben
- Produktdaten: Open Food Facts lädt automatisch Name, Kategorie, Bild
- Optional: Eigenes Foto mit Kamera aufnehmen (Live-Vorschau)
- Details eingeben: Ablaufdatum, Standort, Menge, Preis
- Speichern: Produkt wird zur Datenbank hinzugefügt
Gelöschte Produkte schnell wieder hinzufügen:
- Barcode scannen (auch von gelöschten Produkten)
- Verlauf-Button klicken (📜 Icon)
- Alle jemals gescannten Produkte werden angezeigt
- Quick Add klicken → alle gespeicherten Daten werden vorausgefüllt
- Nur Ablaufdatum aktualisieren und speichern
Vorteile:
- Keine Daten gehen verloren, auch nach Löschung
- Scan-Count zeigt Häufigkeit
- Kategorien, Tags, Diät-Flags bleiben erhalten
- Einkaufsliste-Button öffnen (🛒 Icon)
- Manuell hinzufügen: Artikel-Name, Menge, optional Kategorie
- Auto-Generieren: System findet automatisch:
- Abgelaufene Produkte
- Produkte mit Menge ≤ 2
- Abhaken: Erledigte Einkäufe markieren
- Löschen: Abgehakte Artikel entfernen
Burger-Menu öffnen (☰) für:
- Standort: Nach Lagerort filtern (Kühlschrank, Vorratsschrank, Gefrierschrank)
- Ablauf: Nur abgelaufene/bald ablaufende anzeigen
- Vegetarisch/Vegan: Ernährungsfilter
- Suche: Nach Name oder EAN durchsuchen
Basis-Statistiken (📊 Icon):
- Produkt-Übersicht
- Ablauf-Status
- Gesamtwert
Erweiterte Statistiken (📊 im Modal):
- Verschwendungs-Wert
- Kategorie-Verteilung
- Top-Produkte
- Wöchentliche Entwicklung
- Flask 3.0.0: Python Web Framework
- SQLite3: Leichtgewichtige Datenbank mit automatischen Migrations
- Requests: HTTP-Client für Open Food Facts API
- UUID: Generierung eindeutiger Dateinamen für Bilder
- Base64: Bild-Encoding für Upload
- Vue.js 3: Reaktives JavaScript Framework (Global Production Build)
- Tailwind CSS: Utility-First CSS Framework
- Font Awesome: Icon-Bibliothek
- HTML5-QRCode: Barcode-Scanner Library
- MediaDevices API: Kamera-Zugriff mit Stream-Verwaltung
- Open Food Facts API: Produktdaten-Abruf (Name, Kategorie, Bild, Nährwerte)
- MediaDevices API: getUserMedia() für Kamera-Zugriff
- Browser Notifications API: Push-Benachrichtigungen
Alle Produkte abrufen
[
{
"id": 1,
"ean": "4025127020997",
"name": "Milch 3.5%",
"expiry_date": "2025-12-01",
"purchase_date": "2025-11-20",
"location": "Kühlschrank",
"quantity": 2,
"weight_volume": "1L",
"notes": "",
"is_vegetarian": 1,
"is_vegan": 0,
"price": 1.29,
"image_url": "/static/uploads/abc123def456.jpg",
"category": "Milchprodukte",
"tags": "bio,regional",
"scan_count": 3,
"last_scanned": "2025-11-26T10:30:00",
"created_at": "2025-11-20T14:22:00"
}
]Neues Produkt erstellen
{
"ean": "4025127020997",
"name": "Milch",
"expiry_date": "2025-12-01",
"purchase_date": "2025-11-26",
"location": "Kühlschrank",
"quantity": 2,
"weight_volume": "1L",
"notes": "Bio-Qualität",
"is_vegetarian": true,
"is_vegan": false,
"price": 1.29,
"image_url": "...",
"category": "Milchprodukte",
"tags": "bio,regional"
}Response: 201 Created mit ID
Besonderheit: Base64-Bilder werden automatisch in static/uploads/ gespeichert und die URL wird zu /static/uploads/{uuid}.jpg konvertiert.
Produkt aktualisieren (gleiche Felder wie POST)
Besonderheit: Alte Bilder werden automatisch gelöscht bei Ersetzung.
Produkt löschen
Wichtig:
- Produkt wird aus Datenbank entfernt
- Barcode-Verlauf bleibt erhalten (für Quick-Add)
- Bild-Datei wird gelöscht
- Metadaten werden in
barcode_historyaktualisiert
Duplikat-Check vor Hinzufügen
{
"ean": "4025127020997"
}Response:
{
"exists": true,
"product": { /* vollständiges Produkt-Objekt */ }
}Produktinfo von Open Food Facts abrufen
{
"found": true,
"name": "Milch 3.5% Frische Vollmilch",
"image_url": "https://images.openfoodfacts.org/...",
"quantity": "1L",
"brands": "Weihenstephan",
"category": "Milchprodukte"
}Automatische Aktionen:
- Barcode-Verlauf wird aktualisiert
- Scan-Count wird erhöht
- Kategorie wird extrahiert
- Vegetarisch/Vegan wird erkannt
Scan-Verlauf abrufen (enthält auch gelöschte Produkte!)
[
{
"id": 1,
"ean": "4025127020997",
"name": "Milch 3.5%",
"category": "Milchprodukte",
"weight_volume": "1L",
"tags": "bio,regional",
"is_vegetarian": 1,
"is_vegan": 0,
"scan_count": 5,
"last_scanned": "2025-11-26T10:30:00"
}
]Use Case: Gelöschte Produkte können über Quick-Add mit allen ursprünglichen Daten wieder hinzugefügt werden.
Alle Einkaufslisten-Einträge
[
{
"id": 1,
"name": "Milch",
"quantity": 2,
"category": "Milchprodukte",
"checked": 0,
"notes": "Bio",
"created_at": "2025-11-26T09:00:00"
}
]Artikel hinzufügen
{
"name": "Eier",
"quantity": 12,
"category": "Tierprodukte",
"notes": "Freiland"
}Artikel aktualisieren (z.B. abhaken)
{
"checked": 1
}Einzelnen Artikel löschen
Automatisch generieren
{
"items_added": 3,
"message": "3 Artikel zur Einkaufsliste hinzugefügt"
}Findet automatisch:
- Abgelaufene Produkte
- Produkte mit Menge ≤ 2
Alle abgehakten Artikel löschen
{
"deleted": 5,
"message": "5 erledigte Artikel gelöscht"
}Basis-Statistiken
{
"total": 42,
"expired": 3,
"expiring_soon": 5,
"total_value": 127.50,
"by_location": {
"Kühlschrank": 15,
"Vorratsschrank": 20,
"Gefrierschrank": 7
}
}Erweiterte Statistiken
{
"waste_value": 12.50,
"waste_count": 3,
"category_breakdown": [
{"category": "Milchprodukte", "count": 8},
{"category": "Gemüse", "count": 12}
],
"top_scanned": [
{"name": "Milch 3.5%", "scan_count": 15},
{"name": "Eier", "scan_count": 10}
],
"weekly_additions": 8
}Haupt-Produkttabelle mit allen Informationen
CREATE TABLE products (
id INTEGER PRIMARY KEY AUTOINCREMENT,
ean TEXT, -- EAN-Barcode (8-13 Stellen)
name TEXT NOT NULL, -- Produktname (max 200 Zeichen)
expiry_date TEXT, -- Ablaufdatum (YYYY-MM-DD)
purchase_date TEXT, -- Kaufdatum (YYYY-MM-DD)
location TEXT, -- Lagerort (max 100 Zeichen)
quantity INTEGER DEFAULT 1, -- Menge (1-9999)
weight_volume TEXT, -- Gewicht/Volumen (z.B. "1L", "500g")
notes TEXT, -- Notizen (max 1000 Zeichen)
is_vegetarian INTEGER DEFAULT 0, -- Vegetarisch (0/1)
is_vegan INTEGER DEFAULT 0, -- Vegan (0/1)
price REAL DEFAULT 0.0, -- Preis in Euro
image_url TEXT, -- Pfad zum Bild (/static/uploads/...)
category TEXT, -- Kategorie (von API oder manuell)
tags TEXT, -- Tags (kommasepariert)
scan_count INTEGER DEFAULT 0, -- Anzahl Scans
last_scanned TEXT, -- Letzter Scan (ISO-Format)
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
-- Indizes für Performance
CREATE INDEX idx_expiry_date ON products(expiry_date);
CREATE INDEX idx_location ON products(location);
CREATE INDEX idx_name ON products(name);Persistente Speicherung aller Scans (bleibt nach Löschung erhalten)
CREATE TABLE barcode_history (
id INTEGER PRIMARY KEY AUTOINCREMENT,
ean TEXT NOT NULL, -- EAN-Barcode
name TEXT, -- Produktname
category TEXT, -- Kategorie
weight_volume TEXT, -- Gewicht/Volumen
tags TEXT, -- Tags
is_vegetarian INTEGER DEFAULT 0, -- Vegetarisch
is_vegan INTEGER DEFAULT 0, -- Vegan
scan_count INTEGER DEFAULT 1, -- Anzahl Scans
last_scanned TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);Wichtig: Diese Tabelle wird nie gelöscht, auch nicht beim Löschen von Produkten! Ermöglicht Quick-Add für gelöschte Produkte.
Einkaufsliste mit manuellen und auto-generierten Einträgen
CREATE TABLE shopping_list (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT NOT NULL, -- Artikel-Name
quantity INTEGER DEFAULT 1, -- Menge
category TEXT, -- Kategorie
checked INTEGER DEFAULT 0, -- Abgehakt (0/1)
notes TEXT, -- Notizen
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);- Raspberry Pi 4 (2GB+ RAM empfohlen)
- 32GB+ SD-Karte (Class 10 oder UHS-I)
- Kamera-Modul oder USB-Webcam (optional für Desktop-Modus)
- Gehäuse mit Lüfter (bei dauerhaftem Betrieb)
- System aktualisieren
sudo apt update && sudo apt upgrade -y
sudo apt install python3 python3-pip python3-venv -y- Projekt kopieren
cd /home/pi
# Projekt-Dateien hierher kopieren
cd HeimInventar- Virtuelle Umgebung erstellen
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt- Server starten
Testing (Development):
python app.pyProduction (24/7 mit Gunicorn):
gunicorn -w 2 -b 0.0.0.0:5000 --timeout 120 app:app
# -w 2 = 2 Worker (für Pi Zero/3)
# -w 4 = 4 Worker (für Pi 4/5)- Service-Datei erstellen
sudo nano /etc/systemd/system/nexosync.service- Konfiguration einfügen
[Unit]
Description=NexoSync Smart Kitchen Inventory
After=network.target
[Service]
Type=notify
User=pi
WorkingDirectory=/home/pi/HeimInventar
Environment="PATH=/home/pi/HeimInventar/venv/bin"
ExecStart=/home/pi/HeimInventar/venv/bin/gunicorn -w 4 -b 0.0.0.0:5000 --timeout 120 app:app
Restart=always
RestartSec=10
[Install]
WantedBy=multi-user.targetAnpassungen je nach Raspberry Pi Modell:
- Pi Zero/3:
-w 2(2 Worker) - Pi 4 (2GB):
-w 3(3 Worker) - Pi 4 (4GB+):
-w 4(4 Worker) - Pi 5:
-w 6(6 Worker)
- Service aktivieren
sudo systemctl daemon-reload
sudo systemctl enable nexosync
sudo systemctl start nexosync
sudo systemctl status nexosync- Service-Befehle
sudo systemctl stop nexosync # Stoppen
sudo systemctl restart nexosync # Neustarten
sudo journalctl -u nexosync -f # Logs anzeigen
sudo systemctl status nexosync # Status prüfenSQLite optimieren:
sqlite3 inventory.db "VACUUM;"
sqlite3 inventory.db "ANALYZE;"Swap erweitern (bei wenig RAM):
sudo dphys-swapfile swapoff
sudo nano /etc/dphys-swapfile
# CONF_SWAPSIZE=1024
sudo dphys-swapfile setup
sudo dphys-swapfile swaponAlte Bilder aufräumen (optional):
# Bilder älter als 90 Tage löschen
find /home/pi/HeimInventar/static/uploads -type f -mtime +90 -deleteDatenbank sichern:
# Manuelles Backup
cp inventory.db inventory_backup_$(date +%Y%m%d).db
# Automatisches Backup (Crontab)
crontab -e
# Täglich um 3 Uhr
0 3 * * * cp /home/pi/HeimInventar/inventory.db /home/pi/backups/inventory_$(date +\%Y\%m\%d).dbBilder sichern:
tar -czf uploads_backup_$(date +%Y%m%d).tar.gz static/uploads/Moderne Browser benötigen HTTPS oder localhost für Kamera-Zugriff.
Workaround für Android/Chrome:
- Öffne
chrome://flags/#unsafely-treat-insecure-origin-as-secure - Füge
http://<RASPBERRY-PI-IP>:5000hinzu - Flag aktivieren und Chrome neu starten
Bessere Lösung: HTTPS mit Let's Encrypt (siehe Sicherheitshinweise)
HeimInventar/
├── app.py # Flask Backend (850+ Zeilen)
├── inventory.db # SQLite Datenbank
├── requirements.txt # Python Dependencies
├── README.md # Diese Datei
├── static/
│ ├── css/
│ │ └── style.css # Custom Styles (170+ Zeilen)
│ ├── js/
│ │ └── app.js # Vue.js Frontend (500+ Zeilen)
│ └── uploads/ # Produkt-Bilder (automatisch erstellt)
└── templates/
└── index.html # Haupt-Template (900+ Zeilen)
# In app.py (letzte Zeilen)
if __name__ == '__main__':
app.run(host='0.0.0.0', port=5000, debug=True) # debug=TrueDebug-Features:
- Auto-Reload bei Code-Änderungen
- Detaillierte Fehler im Browser
- Flask Debug Toolbar (optional)
# Am Anfang von app.py hinzufügen
import logging
logging.basicConfig(
level=logging.DEBUG,
format='%(asctime)s %(levelname)s: %(message)s',
handlers=[
logging.FileHandler('nexosync.log'),
logging.StreamHandler()
]
)# SQLite Shell öffnen
sqlite3 inventory.db
# Nützliche Befehle:
.tables # Tabellen anzeigen
.schema products # Schema anzeigen
SELECT * FROM products; # Alle Produkte
SELECT * FROM barcode_history; # Verlauf anzeigen
DELETE FROM products WHERE id=1; # Produkt löschen
.exit # BeendenVue.js DevTools (Chrome Extension) installieren für:
- Komponenten-Inspektion
- State-Management Debugging
- Event-Tracking
Tailwind CSS Klassen nachschlagen:
Manuelles Testing:
# Produkt hinzufügen
curl -X POST http://localhost:5000/api/products \
-H "Content-Type: application/json" \
-d '{"name":"Test","quantity":1}'
# Produkte abrufen
curl http://localhost:5000/api/products
# Barcode scannen
curl http://localhost:5000/api/scan/4025127020997Datenbank resetten:
rm inventory.db
python app.py # Erstellt neue DB-
✅ Barcode-Verlauf mit vollständigen Metadaten
- Speichert Name, Kategorie, Tags, Diät-Flags
- Persistenz auch nach Produkt-Löschung
- Quick-Add Funktion für gelöschte Produkte
-
✅ Dateisystem-basierte Bild-Speicherung
- Bilder in
static/uploads/statt Datenbank - UUID-basierte Dateinamen
- Automatische Löschung bei Ersetzung/Entfernung
- Deutlich bessere Performance
- Bilder in
-
✅ Einkaufslisten-Generator
- Automatische Erkennung niedriger Bestände
- Abgelaufene Produkte automatisch hinzufügen
- Abhaken und Löschen erledigter Einkäufe
-
✅ Erweiterte Statistiken
- Verschwendungs-Tracking
- Kategorie-Breakdown
- Top gescannte Produkte
- Wöchentliche Trends
-
✅ Kategorien & Tags Support
- Automatische Kategorisierung via Open Food Facts
- Manuelle Tags für Organisation
- Filter nach Kategorie
- Bild-Speicherung optimiert (keine Speicherprobleme mehr)
- Barcode-Verlauf bleibt nach Löschung erhalten
- Automatische Migrations für alle Tabellen
- 3-Tabellen-Architektur (products, shopping_list, barcode_history)
- Erweiterte API mit 15+ Endpoints
- Base64 → File-System Konvertierung
- Automatische Bild-Cleanup
- ✅ Basis-Produktverwaltung
- ✅ Barcode-Scanner mit Open Food Facts
- ✅ Dark Mode (automatisch)
- ✅ Kamera-Integration
- ✅ Duplikat-Erkennung
- ✅ Mobile-First Design
- ✅ Filter & Suche
- ✅ Preis-Tracking
- ✅ Basis-Statistiken
NICHT für öffentliches Internet ohne zusätzliche Sicherheit!
Empfohlene Maßnahmen:
- Reverse Proxy (Nginx/Apache) mit HTTPS
- Authentifizierung (Basic Auth oder OAuth)
- Firewall-Regeln (nur lokales Netzwerk)
- Rate Limiting (gegen Brute-Force)
server {
listen 80;
server_name nexosync.local;
location / {
auth_basic "NexoSync Login";
auth_basic_user_file /etc/nginx/.htpasswd;
proxy_pass http://127.0.0.1:5000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}sudo apt install certbot python3-certbot-nginx
sudo certbot --nginx -d nexosync.example.comQ: Funktioniert das offline?
A: Ja, grundsätzlich. Nur der Barcode-Scanner benötigt Internet für Open Food Facts API. Bereits gespeicherte Produkte funktionieren offline.
Q: Kann ich das mit mehreren Personen nutzen?
A: Ja, alle Geräte im gleichen Netzwerk können auf den Raspberry Pi zugreifen. Die Datenbank ist für mehrere gleichzeitige Nutzer ausgelegt.
Q: Wie viele Produkte kann ich speichern?
A: Praktisch unbegrenzt. SQLite skaliert bis zu Millionen Einträge. Auf einem Raspberry Pi mit 32GB SD-Karte sind 10.000+ Produkte problemlos möglich.
Q: Was passiert mit gelöschten Produkten?
A: Die Produkt-Daten werden aus der Haupttabelle entfernt, aber der Barcode-Verlauf bleibt erhalten. Du kannst gelöschte Produkte jederzeit wieder scannen und mit "Quick Add" hinzufügen.
Q: Wie groß werden die Bilder?
A: Automatisch komprimiert auf ~50-200KB (max 400×400px, JPEG 0.7). Optimiert für Raspberry Pi Storage.
Q: Kann ich eigene Kategorien erstellen?
A: Ja, beim manuellen Hinzufügen kannst du beliebige Kategorien und Tags eingeben. Die API-Kategorien werden automatisch erkannt.
Q: Unterstützt das Barcode-Typen außer EAN?
A: Aktuell nur EAN-8, EAN-13 und kompatible Formate (UPC). Erweiterung für QR-Codes ist geplant.
Q: Kann ich die Daten exportieren?
A: Die Datenbank ist SQLite-Standard. Export via:
sqlite3 inventory.db ".mode csv" ".output products.csv" "SELECT * FROM products;"Contributions sind willkommen!
Pull Requests bitte mit:
- Beschreibung der Änderung
- Testing-Nachweis
- Code-Kommentare (Deutsch oder Englisch)
Feature-Requests:
- Issue öffnen mit [FEATURE] im Titel
- Use-Case beschreiben
- Mockups/Screenshots (optional)
MIT License - Copyright (c) 2025 NexoSync
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software.
- Open Food Facts - Produktdaten-API
- Tailwind CSS - UI Framework
- Vue.js - Frontend Framework
- Font Awesome - Icons
- HTML5-QRCode - Barcode-Scanner Library
Bei Problemen:
- Issues auf GitHub öffnen
- Logs prüfen:
journalctl -u nexosync -f - Debug-Modus aktivieren
🏠 NexoSync - Dein smartes Zuhause beginnt hier!
Entwickelt mit ❤️ für smarte Haushalte | Optimiert für Raspberry Pi | Mobile-First Design | Open Source
_ _ ____
| \ | | _____ _____ / ___| _ _ _ __ ___
| \| |/ _ \ \/ / _ \___ \| | | | '_ \ / __|
| |\ | __/> < (_) |__) | |_| | | | | (__
|_| \_|\___/_/\_\___/____/ \__, |_| |_|\___|
|___/
Viel Spaß beim Organisieren! 🚀🎉