fucodo / contact-securitycenter
Installs: 280
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:neos-package
Requires
- kaystrobach/backend: *
- matomo/device-detector: ^6.3
- neos/flow: ^6 || ^7 || ^8
README
- adds a security center to a kaystrobach.backend application
Usage
- just composer req the lib
External libraries
Functionality
- hooks into repositories to log changes
- allows to track logins and login failures per user
Securitycenter
- adds a security center to a kaystrobach.backend application
Usage
- just composer req the lib
External libraries
Functionality
- hooks into repositories to log changes
- allows to track logins and login failures per user
Konzept
Security Center Logging System
Inhaltsverzeichnis
- Einleitung
- Features
- Installationsanleitung
- Event- / Slot-Pattern
- Datenmodell
- Beispielimplementierung
- Konfiguration
- Nutzung
- Erweiterbarkeit
- Troubleshooting
Einleitung
Das Security Center Logging System ist ein Werkzeug zur Protokollierung und Analyse von sicherheitsrelevanten Aktivitäten. Es ermöglicht es, verdächtige Ereignisse zu erfassen, zu kategorisieren und geeignete Aktionen basierend auf festgelegten Regeln zu initiieren.
Features
- Kategorisierung von Aktivitäten: Aktivitäten werden mit vier Schweregraden klassifiziert (
Notice
,Warning
,Error
,OK
). - Erweiterbares Event- / Slot-Pattern: Ermöglicht das Hinzufügen spezifischer Ereignisse und zugehöriger Aktionen.
- Datenpersistenz: Unterstützt Speicherung mit Entity-Klassen und eingebetteten Objekten.
- Benutzer- und Admin-Interaktion: Verwaltung von Benutzer- und Admin-Genehmigungen.
- Unterstützung mehrerer Datenquellen: Aktivitäten können aus internen oder externen Quellen kommen.
Installationsanleitung
- Installieren Sie die benötigten PHP-Abhängigkeiten mittels Composer:
composer install
- Fügen Sie die Konfiguration für die Berechtigungen die
Policy.yaml
hinzu. - Führen Sie Migrationen aus, um die Datenbanktabellen zu erstellen:
./flow doctrine:migrate
- Stellen Sie sicher, dass der Signal-Slot-Dispatcher aktiviert ist.
Event- / Slot-Pattern
Das Logging-System nutzt das Event- / Slot-Pattern, um Aktivitäten zu erfassen.
Das Signal-Slot
-Modul wird verwendet, um Ereignisse mit Listenern zu verbinden.
Beispiel: Login-Tracking
- Signal: Ein Benutzer wird authentifiziert.
- Slot: Ein Log-Eintrag wird erstellt.
Verbindung:
$dispatcher->connect( AuthenticationProviderManager::class, 'authenticatedToken', LoginSlot::class, 'trackLogin' );
Datenmodell
Die zentrale Klasse ist ActivityLogEntry
. Sie speichert die Details zu einer Aktivität.
Attribute:
severity
: Schweregrad der Aktivität (Notice
,Warning
,Error
,OK
).createdAt
: Zeitpunkt der Erstellung.expiresAt
: Zeitpunkt der Löschung.title
: Titel der Aktivität.message
: Menschenlesbare Notizen oder Hinweise aus dem Systemcode
: Nummer des Fehlers / NachrichtentypsuserIdentity
: Benutzerkennung.networkAddress
: IP-Adresse und Netzwerkdetails (bestehend aus IP-Adresse und Hostname).device
: Gerätedetails (bestehend aus clientFamily, clientVersion, clientEngine, osFamily, osInfo, osVersion, deviceName, brandName, model, bot). https://github.com/matomo-org/device-detectorparentLogEntry
: Referenz zu einem vorherigen Log-Eintrag (für verknüpfte Ereignisse).source
: Meistensinternal
kann aber auch ein externe Webhook für andere Anwendungen sein.- `sourceIdentifier': Technischer Identifier der Quelle.
data
: Zusärtliche Technische Daten als InformationreviewNotes
: Menschenlesbare Notizen oder Hinweise nach einem Review
Zusätzlich werden noch die folgenden Prüfungsanfragen erfasst:
userApproval
: Nutzer soll das Ereignis bestätigen / prüfenadminApproval
: Admin / Support soll das Ereignis bestätigen / prüfen
Zu jeder Prüfungsanfrage werden die folgenden Daten erfasst:
needed
: Prüfung erforderlich?doneAt
: Wann erfolgte die PrüfungsignalUri
: Externer Dienst, der bei Statusänderung informiert werden solldoneBy
: Externer Dienst, der bei Statusänderung informiert werden soll
Backendmodul für Nutzer
Das System bietet ein Backendmodul, in dem Benutzer alle mit ihnen verbundenen Log-Einträge einsehen können. Hierbei werden detaillierte Informationen zu den Aktivitäten angezeigt, wie z. B. Zeitpunkt, Schweregrad und Beschreibung. Benutzer haben die Möglichkeit, eine Überprüfung durch den Support anzufordern, indem sie direkt in der Oberfläche eine Review-Anfrage erstellen. Das Modul stellt Filter- und Suchfunktionen bereit, um spezifische Einträge schnell zu finden.
Backendmodul für Support und Administration
Ein zweites Modul ist speziell für Administratoren konzipiert. Es ermöglicht den Admins, alle eingereichten Review-Anfragen von Benutzern einzusehen und diese zu bearbeiten. Administratoren können den Status der Anfragen ändern, Kommentare hinzufügen und gegebenenfalls Maßnahmen ergreifen. Das Modul bietet eine klare Übersicht über alle offenen und abgeschlossenen Anfragen sowie Filtermöglichkeiten, um nach Schweregrad oder Benutzer zu sortieren. Dadurch wird ein effizienter und strukturierter Bearbeitungsprozess gewährleistet.
Beispielimplementierung
LoginSlot:
public function trackLogin(TokenInterface $token): void { $identifier = $token->getAccount()->getAccountIdentifier(); $log = new ActivityLogEntry(); $log->setTitle('Login'); $log->setSeverity(ActivityLogEntry::SEVERITY_NOTICE); $log->setUserIdentity($identifier); $this->persistenceManager->allowObject($log); $this->persistenceManager->add($log); $this->persistenceManager->persistAllowedObjects(); }
Konfiguration
Konfigurieren Sie den Dispatcher in der Package.php
:
$dispatcher->connect( AuthenticationProviderManager::class, 'authenticatedToken', LoginSlot::class, 'trackLogin' );
Löschung
Jeder Eintrag enthält ein expiresAt
Attribut.
Einträge deren Ablaufdatum erreicht ist werden regelmäßig durch einen Hintergrundjob gelöscht.
Es kann zusätzlich in der Konfiguration ein maximaler Zeitraum bis zum Ablauf angegeben werden. Kein Einträg kann älter
werden, als diese Angabe.
Nutzung
- Implementieren Sie neue Slots für benutzerdefinierte Ereignisse.
- Binden Sie die Slots an Signale über den Dispatcher.
- Überprüfen Sie die Log-Einträge im entsprechenden Datenbank-Repository.
Erweiterbarkeit
- Neue Ereignisse hinzufügen: Implementieren Sie zusätzliche Slots und verbinden Sie diese mit relevanten Signalen.
- Anpassung von Log-Daten: Passen Sie die
ActivityLogEntry
-Klasse an, um zusätzliche Felder zu unterstützen. - Hooks: Eingehende und Ausgehende Webhooks für weitere Anbindungen
Troubleshooting
- Keine Logs erstellt: Überprüfen Sie, ob der Dispatcher korrekt konfiguriert ist.
- Datenbankfehler: Vergewissern Sie sich, dass die Migrationen erfolgreich durchgeführt wurden.
- Fehlerhafte Slots: Stellen Sie sicher, dass die Methoden-Signaturen der Slots korrekt mit den Signalen übereinstimmen.