Launch Week Day 5: Introducing Reachability for PHP.Learn More
Socket
Book a DemoSign in
Socket

solr-helper

Package Overview
Dependencies
Maintainers
0
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

solr-helper

Tool zum Anzeigen und Bearbeiten von Solr-Dokumenten.

pipPyPI
Version
1.5.0
Maintainers
0

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 /connections im 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=false Felder 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_URL
    • SOLRHELPER_CORE
  • Konfigurationsdatei:
    • config.toml im 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.

Keywords

solr

FAQs

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts