Veridium ID-Logs erfassen

Unterstützt in:

In diesem Dokument wird beschrieben, wie Sie Veridium ID-Logs mit dem Bindplane-Agent in Google Security Operations aufnehmen.

Veridium ID ist eine biometrische Authentifizierungsplattform, die Syslog-Meldungen für Authentifizierungsereignisse, Kontoverwaltung, Geräteregistrierung und administrative Aktionen generiert. Der Parser extrahiert Felder aus Syslog-Nachrichten mithilfe von Grok-Mustern und Schlüssel-Wert-Parsing und ordnet sie dem Unified Data Model (UDM) zu.

Hinweis

Prüfen Sie, ob folgende Voraussetzungen erfüllt sind:

  • Eine Google SecOps-Instanz
  • Windows Server 2016 oder höher oder Linux-Host mit systemd
  • Netzwerkverbindung zwischen dem Bindplane-Agent und dem Veridium ID-Host
  • Wenn Sie den Agent hinter einem Proxy ausführen, müssen die Firewallports gemäß den Anforderungen des Bindplane-Agents geöffnet sein.
  • Privilegierter Zugriff auf Veridium ID

Authentifizierungsdatei für die Google SecOps-Datenaufnahme abrufen

  1. Melden Sie sich in der Google SecOps-Konsole an.
  2. Rufen Sie die SIEM-Einstellungen > Collection Agents auf.
  3. Laden Sie die Authentifizierungsdatei für die Datenaufnahme herunter.
  4. Speichern Sie die Datei sicher auf dem System, auf dem BindPlane installiert wird.

Google SecOps-Kundennummer abrufen

  1. Melden Sie sich in der Google SecOps-Konsole an.
  2. Rufen Sie die SIEM-Einstellungen > Profile auf.
  3. Kopieren und speichern Sie die Kunden-ID aus dem Bereich Organisationsdetails.

BindPlane-Agent installieren

Installieren Sie den Bindplane-Agent auf Ihrem Windows- oder Linux-Betriebssystem gemäß der folgenden Anleitung.

Fenstereinbau

  1. Öffnen Sie die Eingabeaufforderung oder PowerShell als Administrator.
  2. Führen Sie dazu diesen Befehl aus:

    msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
    
  3. Warten Sie, bis die Installation abgeschlossen ist.

  4. Überprüfen Sie die Installation mit folgendem Befehl:

    sc query observiq-otel-collector
    

    Der Dienst sollte als RUNNING (Wird ausgeführt) angezeigt werden.

Linux-Installation

  1. Öffnen Sie ein Terminal mit Root- oder Sudo-Berechtigungen.
  2. Führen Sie dazu diesen Befehl aus:

    sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
    
  3. Warten Sie, bis die Installation abgeschlossen ist.

  4. Überprüfen Sie die Installation mit folgendem Befehl:

    sudo systemctl status observiq-otel-collector
    

    Der Dienst sollte als aktiv (wird ausgeführt) angezeigt werden.

Zusätzliche Installationsressourcen

Weitere Installationsoptionen und Informationen zur Fehlerbehebung finden Sie in der Installationsanleitung für den Bindplane-Agent.

BindPlane-Agent zum Erfassen von Syslog-Daten und Senden an Google SecOps konfigurieren

Konfigurationsdatei suchen

  • Linux:

    sudo nano /opt/observiq-otel-collector/config.yaml
    
  • Windows:

    notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
    

Konfigurationsdatei bearbeiten

  • Ersetzen Sie den gesamten Inhalt von config.yaml durch die folgende Konfiguration:

    receivers:
        tcplog:
            listen_address: "0.0.0.0:514"
    
    exporters:
        chronicle/veridium_id:
            compression: gzip
            creds_file_path: '/etc/bindplane-agent/ingestion-auth.json'
            customer_id: '<customer_id>'
            endpoint: malachiteingestion-pa.googleapis.com
            log_type: VERIDIUM_ID
            raw_log_field: body
    
    service:
        pipelines:
            logs/veridium_id_to_chronicle:
                receivers:
                    - tcplog
                exporters:
                    - chronicle/veridium_id
    

Konfigurationsparameter

Ersetzen Sie die folgenden Platzhalter:

  • Empfängerkonfiguration:

    • listen_address: IP-Adresse und Port, auf die gewartet werden soll:
      • 0.0.0.0, um alle Schnittstellen zu überwachen (empfohlen)
      • Port 514 ist der Standard-Syslog-Port (erfordert Root unter Linux; verwenden Sie 1514 für Nicht-Root).
      • Veridium ID verwendet TCP (@@ in rsyslog), daher ist ein tcplog-Empfänger erforderlich.
  • Exporter-Konfiguration:

    • creds_file_path: Vollständiger Pfad zur Datei für die Authentifizierung bei der Aufnahme:
      • Linux: /etc/bindplane-agent/ingestion-auth.json
      • Windows: C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
    • customer_id: Die Kundennummer, die aus der Google SecOps Console kopiert wurde
    • endpoint: Regionale Endpunkt-URL:
      • USA: malachiteingestion-pa.googleapis.com
      • Europa: europe-malachiteingestion-pa.googleapis.com
      • Asien: asia-southeast1-malachiteingestion-pa.googleapis.com
      • Eine vollständige Liste finden Sie unter Regionale Endpunkte.

Konfigurationsdatei speichern

  • Speichern Sie die Datei nach der Bearbeitung:
    • Linux: Drücken Sie Ctrl+O, dann Enter und dann Ctrl+X.
    • Windows: Klicken Sie auf Datei > Speichern.

Bindplane-Agent neu starten, um die Änderungen zu übernehmen

  • Führen Sie den folgenden Befehl aus, um den Bindplane-Agent unter Linux neu zu starten:

    sudo systemctl restart observiq-otel-collector
    
    1. Prüfen Sie, ob der Dienst ausgeführt wird:

      sudo systemctl status observiq-otel-collector
      
    2. Logs auf Fehler prüfen:

      sudo journalctl -u observiq-otel-collector -f
      
  • Wählen Sie eine der folgenden Optionen aus, um den Bindplane-Agent unter Windows neu zu starten:

    • Eingabeaufforderung oder PowerShell als Administrator:

      net stop observiq-otel-collector && net start observiq-otel-collector
      
    • Services-Konsole:

      1. Drücken Sie Win+R, geben Sie services.msc ein und drücken Sie die Eingabetaste.
      2. Suchen Sie nach observIQ OpenTelemetry Collector.
      3. Klicken Sie mit der rechten Maustaste und wählen Sie Neu starten aus.
      4. Prüfen Sie, ob der Dienst ausgeführt wird:

        sc query observiq-otel-collector
        
      5. Logs auf Fehler prüfen:

        type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
        

Syslog für Veridium ID konfigurieren

  1. Melden Sie sich über SSH oder die CLI auf dem Veridium ID-Host an.
  2. Bearbeiten Sie die Datei /etc/rsyslog.conf oder /etc/rsyslog.d/events.conf:

    vi /etc/rsyslog.conf
    
  3. Fügen Sie die folgende Konfiguration hinzu und ersetzen Sie <bindplane-ip> und <bindplane-port> durch die tatsächlichen Bindplane-Agent-Details:

    module(load="imfile" PollingInterval="10")
    
    input(type="imfile"
      File="/var/log/veridiumid/websecadmin/events.log"
      Tag="ver-adminevents"
      reopenOnTruncate="on")
    
    input(type="imfile"
      File="/var/log/veridiumid/tomcat/events.log"
      Tag="ver-events"
      reopenOnTruncate="on")
    
    if $programname == 'ver-events' then @@<bindplane-ip>:<bindplane-port>
    if $programname == 'ver-adminevents' then @@<bindplane-ip>:<bindplane-port>
    
  4. Speichern Sie die Datei und schließen Sie sie.

UDM-Zuordnungstabelle

Logfeld UDM-Zuordnung Logik
_caller.accountId principal.user.userid Direkt aus dem Feld _caller.accountId zugeordnet.
_caller.accountEmailAddressInfo principal.user.email_addresses Direkt aus dem Feld _caller.accountEmailAddressInfo zugeordnet.
_caller.accountExternalId principal.user.email_addresses Direkt aus dem Feld _caller.accountExternalId zugeordnet.
_caller.accountStatus principal.user.attribute.labels[account_status].value Direkt aus dem Feld _caller.accountStatus zugeordnet.
_caller.deviceId principal.asset.asset_id Beginnt mit „VERIDIUM_ID:“ und wird aus dem Feld _caller.deviceId zugeordnet.
_caller.deviceDescription principal.asset.attribute.labels[device_description].value Direkt aus dem Feld _caller.deviceDescription zugeordnet.
_caller.deviceManufacturer principal.asset.attribute.labels[device_manufacturer].value Direkt aus dem Feld _caller.deviceManufacturer zugeordnet.
_caller.deviceName principal.asset.attribute.labels[device_name].value Direkt aus dem Feld _caller.deviceName zugeordnet.
_caller.deviceOs principal.asset.platform_software.platform Wird aus dem Feld _caller.deviceOs zugeordnet. Wenn der Wert „iOS“ ist, wird er „IOS“ zugeordnet. Wenn der Wert „Android“ ist, wird er „ANDROID“ zugeordnet. Wenn der Wert „WIN“ oder „Windows“ ist, wird er „WINDOWS“ zugeordnet.
_caller.deviceStatus principal.asset.attribute.labels[device_status].value Direkt aus dem Feld _caller.deviceStatus zugeordnet.
_caller.deviceType principal.asset.attribute.labels[device_type].value Direkt aus dem Feld _caller.deviceType zugeordnet.
actionDate additional.fields[action_date].value.string_value Direkt aus dem Feld actionDate zugeordnet.
actionName metadata.product_event_type Direkt aus dem Feld actionName zugeordnet.
accountEmail principal.user.email_addresses Direkt aus dem Feld accountEmail zugeordnet.
accountExternalId principal.user.email_addresses Direkt aus dem Feld accountExternalId zugeordnet.
accountId principal.user.userid Direkt aus dem Feld accountId zugeordnet.
authenticatorDeviceContext.deviceMake intermediary.asset.hardware.manufacturer Direkt aus dem Feld authenticatorDeviceContext.deviceMake zugeordnet.
authenticatorDeviceContext.ip intermediary.ip Direkt aus dem Feld authenticatorDeviceContext.ip zugeordnet.
authenticatorDeviceContext.location.city intermediary.asset.location.city Direkt aus dem Feld authenticatorDeviceContext.location.coordinates.latitude zugeordnet.
authenticatorDeviceContext.location.coordinates.latitude intermediary.asset.location.region_latitude Direkt aus dem Feld authenticatorDeviceContext.location.coordinates.latitude zugeordnet.
authenticatorDeviceContext.location.coordinates.longitude intermediary.asset.location.region_longitude Direkt aus dem Feld authenticatorDeviceContext.location.coordinates.longitude zugeordnet.
authenticatorDeviceContext.location.countryName intermediary.asset.location.country_or_region Direkt aus dem Feld authenticatorDeviceContext.location.countryName zugeordnet.
authenticatorDeviceContext.location.ip intermediary.ip Direkt aus dem Feld authenticatorDeviceContext.location.ip zugeordnet.
authenticationDeviceDescription intermediary.asset.attribute.labels[authentication_device_description].value Direkt aus dem Feld authenticationDeviceDescription zugeordnet.
authenticationDeviceName intermediary.asset.asset_id Beginnt mit „VERIDIUM_ID:“ und wird aus dem Feld authenticationDeviceName zugeordnet.
authenticationDeviceOs intermediary.asset.platform_software.platform Wird aus dem Feld authenticationDeviceOs zugeordnet. Wenn der Wert „iOS“ ist, wird er „IOS“ zugeordnet. Wenn der Wert „Android“ ist, wird er „ANDROID“ zugeordnet. Wenn der Wert „WIN“ oder „Windows“ ist, wird er „WINDOWS“ zugeordnet.
authenticationDeviceOsVersion intermediary.asset.platform_software.platform_version Direkt aus dem Feld authenticationDeviceOsVersion zugeordnet.
authenticationDevicePhone intermediary.asset.attribute.labels[authentication_device_phone].value Direkt aus dem Feld authenticationDevicePhone zugeordnet.
authenticationDevicePhoneModel intermediary.asset.attribute.labels[authentication_device_phone_model].value Direkt aus dem Feld authenticationDevicePhoneModel zugeordnet.
authenticationDeviceRegistrationTime intermediary.asset.attribute.labels[authentication_device_registeration_time].value Direkt aus dem Feld authenticationDeviceRegistrationTime zugeordnet.
authenticationDeviceType intermediary.asset.attribute.labels[authentication_device_type].value Direkt aus dem Feld authenticationDeviceType zugeordnet.
authenticationResult extensions.auth.auth_details Direkt aus dem Feld authenticationResult zugeordnet.
context.deviceMake principal.asset.hardware.manufacturer Direkt aus dem Feld context.deviceMake zugeordnet.
context.ip principal.ip Direkt aus dem Feld context.ip zugeordnet.
context.location.countryName principal.location.country_or_region Direkt aus dem Feld context.location.countryName zugeordnet.
context.location.ip principal.ip Direkt aus dem Feld context.location.ip zugeordnet.
context.osVersion principal.asset.platform_software.platform_version Direkt aus dem Feld context.osVersion zugeordnet.
context.userAgentRaw network.http.user_agent Direkt aus dem Feld context.userAgentRaw zugeordnet.
exploiterDeviceContext.deviceMake src.asset.hardware.manufacturer Direkt aus dem Feld exploiterDeviceContext.deviceMake zugeordnet.
exploiterDeviceContext.ip src.ip Direkt aus dem Feld exploiterDeviceContext.ip zugeordnet.
exploiterDeviceContext.location.city src.asset.location.city Direkt aus dem Feld exploiterDeviceContext.location.city zugeordnet.
exploiterDeviceContext.location.coordinates.latitude src.asset.location.region_latitude Direkt aus dem Feld exploiterDeviceContext.location.coordinates.latitude zugeordnet.
exploiterDeviceContext.location.coordinates.longitude src.asset.location.region_longitude Direkt aus dem Feld exploiterDeviceContext.location.coordinates.longitude zugeordnet.
exploiterDeviceContext.location.countryName src.asset.location.country_or_region Direkt aus dem Feld exploiterDeviceContext.location.countryName zugeordnet.
exploiterDeviceContext.location.ip src.ip Direkt aus dem Feld exploiterDeviceContext.location.ip zugeordnet.
exploiterDeviceContext.osName src.asset.platform_software.platform Wird aus dem Feld exploiterDeviceContext.osName zugeordnet. Wenn der Wert „WIN“ oder „Windows“ ist, wird er „WINDOWS“ zugeordnet. Wenn der Wert „iOS“ ist, wird er „IOS“ zugeordnet. Wenn der Wert „Android“ ist, wird er „ANDROID“ zugeordnet.
exploiterDeviceContext.osVersion src.asset.platform_software.platform_version Direkt aus dem Feld exploiterDeviceContext.osVersion zugeordnet.
exploiterDeviceName src.asset.attribute.labels[exploiter_device_name].value Direkt aus dem Feld exploiterDeviceName zugeordnet.
hostname principal.hostname Direkt aus dem Feld hostname zugeordnet.
ipAddress principal.ip Direkt aus dem Feld ipAddress zugeordnet.
location principal.location.city Direkt aus dem Feld location zugeordnet.
location.city about.location.city Direkt aus dem Feld location.city zugeordnet.
location.coordinates.latitude about.location.region_latitude Direkt aus dem Feld location.coordinates.latitude zugeordnet.
location.coordinates.longitude about.location.region_longitude Direkt aus dem Feld location.coordinates.longitude zugeordnet.
location.countryName about.location.country_or_region Direkt aus dem Feld location.countryName zugeordnet.
location.ip about.ip Direkt aus dem Feld location.ip zugeordnet.
metadata.collected_timestamp metadata.collected_timestamp Direkt aus dem Feld collected_time zugeordnet.
metadata.event_timestamp metadata.event_timestamp Direkt aus dem Feld event_time zugeordnet.
metadata.event_type metadata.event_type Legen Sie diesen Wert auf „USER_UNCATEGORIZED“ fest.
metadata.product_event_type metadata.product_event_type Direkt aus dem Feld actionName zugeordnet.
metadata.product_name metadata.product_name Legen Sie diesen Wert auf „VERIDIUM_ID“ fest.
namespace principal.namespace Direkt aus dem Feld namespace zugeordnet.
pid principal.process.pid Direkt aus dem Feld pid zugeordnet.
request.context.userAgentRaw network.http.user_agent Direkt aus dem Feld request.context.userAgentRaw zugeordnet.
request.sessionId network.session_id Direkt aus dem Feld request.sessionId zugeordnet.
requestMethod network.http.method Direkt aus dem Feld requestMethod zugeordnet.
requestURI network.http.referral_url Direkt aus dem Feld requestURI zugeordnet.
security_result.severity security_result.severity Wird aus dem Feld severity zugeordnet. Wenn der Wert „INFO“ ist, wird er „INFORMATIONAL“ zugeordnet.
principal.application Direkt aus dem Feld application zugeordnet.
principal.asset.hostname Direkt aus dem Feld hostname zugeordnet.

Änderungsprotokoll

Änderungsprotokoll für diesen Parser ansehen

Benötigen Sie weitere Hilfe? Antworten von Community-Mitgliedern und Google SecOps-Experten erhalten