Tool zum Anzeigen und Bearbeiten von Solr-Dokumenten.
Project description
Slub SolrHelper
Willkommen beim Slub SolrHelper!
Dieses Tool hilft Bibliothekaren und Softwareentwicklern dabei, Dokumente in einem Solr-Index einfach anzusehen und zu bearbeiten.
Es handelt sich um eine kleine Webanwendung, die lokal gestartet werden kann.
Features
Innovatives Verbindungsmanagement
- Dynamische Verbindungen: Wechseln Sie zwischen verschiedenen Solr-Servern ohne Neustart
- Browser-Speicher: Verbindungen werden lokal im Browser gespeichert
- Import/Export: Teilen Sie Verbindungseinstellungen mit Kollegen
- Automatische Tests: Verbindungen werden vor der Verwendung getestet
- Standard-Verbindung: Markieren Sie eine Verbindung als Standard für den App-Start
Erweiterte Suchfunktionen
- Feldspezifische Suche: Durchsuchen Sie gezielt einzelne Felder
- Intelligente Feldauswahl: Suggest-Funktion filtert verfügbare Felder beim Tippen
- Substring-Suche: Findet Teilbegriffe (z.B. "Buch" findet "Lehrbuch", "Buchhandlung")
- Solr Highlighting: Hervorgehobene Suchbegriffe in Suchergebnissen
- Live-Suche: HTMX-basierte Suche ohne Seitenneuladen
Dokumentenbearbeitung
- Atomare Updates: Sichere Feldbearbeitung ohne Datenverlust (wenn vom Server unterstützt)
- Dynamische Felder: Erkennt und zeigt alle Dokumentfelder an, auch die nicht im Schema definierten
- Neue Felder hinzufügen: Erweitern Sie Dokumente um zusätzliche Informationen
- Warnsystem: Automatische Warnungen bei potenziellem Datenverlust
- Modal-Bearbeitung: Benutzerfreundliche Popup-Fenster für Feldbearbeitung
Technische Features
- Debug-Modus: Detaillierte Logging-Ausgaben für Entwicklung (
--debug) - Responsive Design: Funktioniert auf Desktop und mobilen Geräten
- Toast-Benachrichtigungen: Elegante Erfolgs- und Fehlermeldungen
- Modulare Architektur: Saubere Code-Organisation für einfache Wartung
Installation
Die empfohlene Methode zur Installation und Ausführung des solr-helper ist die Verwendung von uv, einem extrem schnellen Python-Paketmanager.
1. uv installieren
Falls du uv noch nicht installiert hast, kannst du dies mit einem der folgenden Befehle tun:
Linux und macOS:
curl -LsSf https://astral.sh/uv/install.sh | sh
Windows:
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
Weitere Installationsmethoden findest du in der offiziellen uv Dokumentation.
2. solr-helper ausführen
Es gibt zwei empfohlene Wege, den solr-helper zu nutzen:
Option A: Direkte Ausführung mit uvx (Empfohlen)
uvx ist ein Werkzeug, das npx aus der Node.js-Welt ähnelt. Es lädt das Paket in eine temporäre, isolierte Umgebung herunter, führt es aus und räumt danach wieder auf. So bleibt dein System sauber.
uvx solr-helper start-web --solr-url http://dein-solr:8983 --core dein-core
Option B: Permanente Installation
Wenn du das Tool systemweit oder in einer bestimmten virtuellen Umgebung installieren möchtest:
uv pip install solr-helper
Danach kannst du es direkt aufrufen:
solr-helper start-web --solr-url http://dein-solr:8983 --core dein-core
Schnellstart für Bibliothekare
Flexibler Start (empfohlen für mehrere Server)
# Starten ohne feste Verbindung - ermöglicht dynamisches Verbindungsmanagement
uvx solr-helper --no-connection-check start-web
# Oder mit permanenter Installation:
solr-helper --no-connection-check start-web
Die Anwendung ist dann unter http://127.0.0.1:5000 erreichbar.
Start mit fester Verbindung
# Direkt mit bekannter Verbindung starten
uvx solr-helper start-web --solr-url http://dein-solr:8983 --core dein-core
Debug-Modus für Entwicklung
# Detaillierte Logs und Flask-Debug-Modus
solr-helper --debug --no-connection-check start-web
Verbindungsmanagement
Neue Verbindung hinzufügen
- Gehen Sie zu
/connectionsim Webinterface - Klicken Sie "Neue Verbindung hinzufügen"
- Geben Sie Server-URL (z.B.
http://solr-server:8983) und Core-Name ein - Vergeben Sie einen aussagekräftigen Namen
- Testen Sie die Verbindung mit dem Test-Button
- Speichern und verwenden
Verbindungen verwalten
- Verwenden: Sofortiger Wechsel zu einer Verbindung (ohne Standard zu ändern)
- Standard setzen: Verbindung als Standard für App-Start markieren
- Bearbeiten: Verbindungsdetails ändern
- Löschen: Nicht mehr benötigte Verbindungen entfernen
Verbindungen teilen (Import/Export)
// Export aller Verbindungen (Browser-Konsole F12)
console.log(localStorage.getItem('solr_connections'))
// Import von Verbindungen (Browser-Konsole F12)
localStorage.setItem('solr_connections', 'JSON-String-hier-einfügen')
Erweiterte Suchfunktionen
Feldspezifische Suche
- Wählen Sie "Textsuche" (statt ID-Suche)
- Intelligente Feldauswahl: Tippen Sie Feldname (z.B. "title") → Dropdown filtert automatisch alle passenden Felder
- Wählen Sie das gewünschte Feld aus der Liste
- Geben Sie Ihren Suchbegriff ein
- Substring-Suche: "Buch" findet "Lehrbuch", "Buchhandlung", "Buch der Bücher"
- Erhalten Sie Ergebnisse mit hervorgehobenen Suchbegriffen
ID-Suche
- Direkte Suche nach Dokument-IDs
- Sofortige Weiterleitung zum Dokument
- Ideal für bekannte Dokument-Identifikatoren
Live-Suchergebnisse
- Kompakte Vorschau der ersten 5 Treffer
- Link zu vollständigen Ergebnissen
- Keine Seitenneuladen dank HTMX
Dokumentenbearbeitung
Felder bearbeiten
- Öffnen Sie ein Dokument durch Klick auf eine ID
- Klicken Sie "Edit" bei dem Feld, das Sie ändern möchten
- Modal-Fenster öffnet sich mit dem aktuellen Wert
- Ändern Sie den Wert nach Bedbedarf
- Automatische Speicherung:
- Atomare Updates (wenn Server unterstützt): Nur das geänderte Feld wird aktualisiert
- Full-Document-Update (Fallback): Warnung wird angezeigt vor potenziellem Datenverlust
Neue Felder hinzufügen
- Scrollen Sie zum Ende der Dokumentansicht
- Sektion "Neues Feld hinzufügen"
- Feldname: z.B. "kommentar_str", "notiz_txt"
- Feldwert: Ihr gewünschter Inhalt
- Klicken Sie "Hinzufügen" → Feld wird sofort zum Dokument hinzugefügt
Sicherheitsfeatures
- Warnsystem: Automatische Warnungen wenn atomare Updates nicht möglich
- Datenschutz: Nur
stored=falseFelder gehen bei Full-Updates verloren - Backup: Original-Dokument wird vor Änderungen gesichert
- Atomic Updates: Bevorzugte Methode verhindert Datenverlust
Konfiguration
Die Verbindung zu Solr kann auf drei Arten konfiguriert werden (Priorität: CLI > ENV > config.toml > Default):
- CLI-Optionen:
--solr-url(z.B.http://localhost:8983)--core(z.B.testing)- Beispiel:
solr-helper show-schema --solr-url http://sdvdmgtestsolr01.slub-dresden.de:8984 --core ahn-release
- Umgebungsvariablen:
SOLRHELPER_SOLR_URLSOLRHELPER_CORE
- Konfigurationsdatei:
config.tomlim Projektverzeichnis oder~/.solrhelper/config.toml- Beispiel-Inhalt:
solr_url = "http://localhost:8983" core = "testing"
- Defaults:
solr_url = "http://localhost:8983"core = "testing"
Entwicklung
Lokale Entwicklungsumgebung
# Repository klonen
git clone https://github.com/thomsbe/SolrHelper.git
cd SolrHelper
# Mit uv (empfohlen)
uv sync
# Oder mit traditionellem venv
python -m venv .venv
source .venv/bin/activate # Linux/Mac
# .venv\Scripts\activate # Windows
pip install -e .
Entwicklung starten
# Debug-Modus mit detaillierten Logs
uv run solr-helper --debug --no-connection-check start-web
# Oder direkt:
solr-helper --debug --no-connection-check start-web
CLI-Befehle für Entwicklung
# Verbindung testen
solr-helper test-connection --solr-url http://dein-solr:8983 --core dein-core
# Schema anzeigen
solr-helper show-schema --solr-url http://dein-solr:8983 --core dein-core
# Web-Oberfläche starten (Produktion)
solr-helper start-web --solr-url http://dein-solr:8983 --core dein-core
# Web-Oberfläche starten (Debug)
solr-helper --debug start-web --solr-url http://dein-solr:8983 --core dein-core
Architektur-Überblick
- Modularer Aufbau: Separate Module für Routes, Utils, Templates
- Flask Blueprints: Saubere Code-Organisation (connection, search, record, api)
- HTMX-Integration: Moderne Web-UX ohne komplexes JavaScript
- Alpine.js: Reaktive UI-Komponenten für Verbindungsmanagement
- DaisyUI: Konsistentes Design-System
- Loguru: Strukturiertes Logging
Code-Qualität
- 300-Zeilen-Regel: Alle Dateien unter 300 Zeilen für LLM-Kompatibilität
- Blueprint-basiert: Klare Trennung der Verantwortlichkeiten
- Type Hints: Vollständige Typisierung für bessere Wartbarkeit
- Error Handling: Robuste Fehlerbehandlung mit aussagekräftigen Meldungen
Testing
# Tests ausführen
pytest
# Mit Coverage
pytest --cov=src/solr_helper
Siehe docs/technical.md für detaillierte technische Informationen.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file solr_helper-1.5.0.tar.gz.
File metadata
- Download URL: solr_helper-1.5.0.tar.gz
- Upload date:
- Size: 40.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1026ac6364cf42ce3423b31e31cbabfc6315991242858a6f181d2627248b1564
|
|
| MD5 |
e850c3304b24d9fe6e342bf1be5d28e9
|
|
| BLAKE2b-256 |
1e9a06be35f54d0fa0df62e96f5ab67e6b025baf67f251de86dff51a500cdbfb
|
File details
Details for the file solr_helper-1.5.0-py3-none-any.whl.
File metadata
- Download URL: solr_helper-1.5.0-py3-none-any.whl
- Upload date:
- Size: 44.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
acb31d56164a1fa065e5595e9400cbe4bb1f3ee2ca1b61dbcf503a1fcf85af15
|
|
| MD5 |
c5d69ca09db1f3dd8ad72bdafb1da39d
|
|
| BLAKE2b-256 |
a8a066c1468d6dfda55eee39b4e322b00a635384b07852fb92a970e6f6ab7036
|