srhinow/schwarmalarm-bundle

Möglichkeit Imker und Bienenschwarmfänger zu verwalten.

Maintainers

Package info

gitlab.com/srhinow/schwarmalarm-bundle

Issues

Type:contao-bundle

pkg:composer/srhinow/schwarmalarm-bundle

Statistics

Installs: 15

Dependents: 0

Suggesters: 0

Stars: 0

3.2.0 2026-05-09 23:18 UTC

This package is not auto-updated.

Last update: 2026-05-15 03:06:27 UTC


README

Contao-Bundle zur Verwaltung von Imkern und Bienenschwarmfängern. Ermöglicht die Erfassung von Imker-Einträgen mit Geo-Koordinaten sowie die öffentliche Suche über PLZ/Ort mit Kartenansicht.

Voraussetzungen

AbhängigkeitVersion
PHP^8.3
Contao^5.3
Guzzle HTTP^7.0

Installation

composer require srhinow/schwarmalarm-bundle

Nach der Installation:

php vendor/bin/contao-console contao:migrate
php vendor/bin/contao-console cache:clear

Backend-Module

Das Bundle fügt unter Schwarmalarm folgende Backend-Bereiche hinzu:

ModulTabelleFunktion
Imkertl_schwarmalarm_beekeeperImker-Einträge verwalten, Geo-Koordinaten setzen, veröffentlichen
Einstellungentl_schwarmalarm_propertiesAPI-Zugangsdaten, E-Mail-Benachrichtigung
PLZ-Koordinatentl_zip_coordinatesPLZ → Geo-Koordinaten-Mapping für die Autocomplete-Suche

CSV-Export

Im Imker-Modul steht ein CSV-Export aller Einträge zur Verfügung (Button in der Kopfzeile der Liste).

Frontend-Module

ModultypBeschreibung
beekeeper_search_formSuchformular mit PLZ/Ort-Autocomplete und Entfernungsauswahl
beekeeper_search_listErgebnisliste der gefundenen Imker mit optionaler Entfernungsanzeige
beekeeper_search_mapLeaflet-Kartenansicht der Suchergebnisse (OpenStreetMap)
beekeeper_verify_linkVerifizierungsseite für Opt-out-Links per E-Mail

Suchformular

Das Suchformular (beekeeper_search_form) speichert PLZ/Ort, Entfernung und ermittelte Geo-Koordinaten in der Contao-Session. Alle anderen Module lesen diese Session aus, sodass Formular und Ergebnisliste/Karte auf verschiedenen Seiten oder Seitenbereichen platziert werden können.

Die Autocomplete-Suche greift auf die tl_zip_coordinates-Tabelle zurück und liefert Vorschläge ab zwei eingegebenen Zeichen.

Schwarmzeit-Einschränkung

Die Ergebnisliste kann auf eine konfigurierbare Schwarmzeit eingeschränkt werden. Start und Ende werden im Backend-Modul als Datum im Format TT.MM (z. B. 01.04 für den 1. April) hinterlegt. Außerhalb der Saison zeigt das Modul einen Hinweistext statt der Ergebnisse.

Templates

Alle Frontend-Templates liegen als Twig-Dateien in contao/templates/ und können in der Contao-Templateverwaltung überschrieben werden:

TemplateVerwendung
mod_beekeeper_search_form.html.twigSuchformular
mod_beekeeper_search_shortform.html.twigKompaktes Suchformular (alternative Auswahl)
mod_beekeeper_search_list.html.twigErgebnisliste
mod_beekeeper_search_map.html.twigKartenansicht
mod_beekeeper_message.html.twigEinzelne Statusmeldung
mod_beekeeper_entries_empty.html.twigMeldung bei leerer Ergebnisliste
item_html_list.html.twigEinzelner Tabelleneintrag in der Ergebnisliste

Alle sichtbaren Texte in den Templates werden über Sprachdateien definiert (TL_LANG['MSC']['bk_*']) und sind in Deutsch und Englisch enthalten.

Sprachdateien

Das Bundle liefert vollständige Sprachdateien für Deutsch (de) und Englisch (en) für alle DCA-Tabellen sowie Frontend-Texte.

Notification Center — Insert Tags

Das Bundle stellt folgenden Insert Tag für das Notification Center bereit:

E-Mail-Verifizierung (beekeeper_verify_link)

Das Modul liest den URL-Parameter ?key=... aus, sucht den zugehörigen Imker-Eintrag und setzt bei Erfolg verified = 1. Sind darüber hinaus Geo-Koordinaten vorhanden (lat und lon ≠ 0), wird der Eintrag automatisch auf published = 1 gesetzt und erscheint damit in den Suchergebnissen.

Konfigurierbare Meldungen im Modul:

  • Kein/ungültiger Keymessage_false_url
  • Eintrag nicht gefundenmessage_no_entry
  • Bereits verifiziertmessage_allready_verified
  • Weiterleitung — optionale jumpTo-Seite nach erfolgreicher Verifizierung

Der Aktivierungslink wird über das Notification Center versendet. Der Verifikations-Key wird serverseitig bei der Formularabgabe über den prepareFormData-Hook generiert (bin2hex(random_bytes(16))) und steht in NC-Nachrichten als ##form_key## zur Verfügung:

{{link_url::PAGE_ID}}?key=##form_key##

{{beekeeper_edit_link::EMAIL}}

Erzeugt einen absoluten Backend-Deeplink zur Bearbeitung des Imker-Eintrags mit der angegebenen E-Mail-Adresse.

Verwendung in NC-Benachrichtigungen:

{{beekeeper_edit_link::##form_email##}}

Das NC ersetzt ##form_email## zuerst durch die tatsächliche E-Mail-Adresse, anschließend löst Contao den Insert Tag auf und gibt eine vollständige URL zurück, z. B.:

https://example.com/contao?do=tl_schwarmalarm_beekeeper&act=edit&id=42

Wird keine übereinstimmende E-Mail gefunden, gibt der Tag eine leere Zeichenkette zurück.

Services

ServiceKlasseFunktion
srhinow.schwarmalarm.service.beekeeperBeekeeperServiceGeo-Suche, Entfernungsberechnung, Schwarmzeit-Prüfung
srhinow.schwarmalarm.service.osm_geodataOsmGeoDataNominatim-Abfrage für Adresse → Koordinaten
srhinow.schwarmalarm.service.be_csv_exportBeCSVExportCSV-Export der Imker-Tabelle

Entwicklung

composer install
vendor/bin/phpunit

Lizenz

LGPL-3.0-or-later — siehe LICENSE.