Collecter les journaux Cyolo OT

Compatible avec :

Ce document explique comment ingérer les journaux Cyolo Secure Remote Access for OT dans Google Security Operations à l'aide de l'agent Bindplane.

Cyolo fournit un accès à distance sécurisé aux environnements de technologie opérationnelle (TO). La plate-forme génère des messages syslog pour les événements d'accès, l'authentification et les activités de session. L'analyseur extrait les champs et les mappe au modèle de données unifié (UDM).

Avant de commencer

Assurez-vous de remplir les conditions suivantes :

  • Une instance Google SecOps
  • Windows Server 2016 ou version ultérieure, ou hôte Linux avec systemd
  • Connectivité réseau entre l'agent Bindplane et la plate-forme Cyolo
  • Si vous exécutez l'agent derrière un proxy, assurez-vous que les ports de pare-feu sont ouverts conformément aux exigences de l'agent Bindplane.
  • Accès privilégié à la console d'administration Cyolo

Obtenir le fichier d'authentification d'ingestion Google SecOps

  1. Connectez-vous à la console Google SecOps.
  2. Accédez à Paramètres du SIEM > Agents de collecte.
  3. Téléchargez le fichier d'authentification d'ingestion.
  4. Enregistrez le fichier de manière sécurisée sur le système sur lequel l'agent Bindplane sera installé.

Obtenir l'ID client Google SecOps

  1. Connectez-vous à la console Google SecOps.
  2. Accédez à Paramètres SIEM> Profil.
  3. Copiez et enregistrez le numéro client de la section Informations sur l'organisation.

Installer l'agent Bindplane

Installez l'agent Bindplane sur votre système d'exploitation Windows ou Linux en suivant les instructions ci-dessous.

Installation de fenêtres

  1. Ouvrez l'invite de commandes ou PowerShell en tant qu'administrateur.
  2. Exécutez la commande suivante :

    msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
    
  3. Attendez la fin de l'installation.

  4. Vérifiez l'installation en exécutant la commande suivante :

    sc query observiq-otel-collector
    

    Le service doit être indiqué comme RUNNING (EN COURS D'EXÉCUTION).

Installation de Linux

  1. Ouvrez un terminal avec les droits root ou sudo.
  2. Exécutez la commande suivante :

    sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
    
  3. Attendez la fin de l'installation.

  4. Vérifiez l'installation en exécutant la commande suivante :

    sudo systemctl status observiq-otel-collector
    

    Le service doit être indiqué comme actif (en cours d'exécution).

Ressources d'installation supplémentaires

Pour obtenir d'autres options d'installation et des conseils de dépannage, consultez le guide d'installation de l'agent Bindplane.

Configurer l'agent Bindplane pour ingérer les journaux syslog et les envoyer à Google SecOps

Localiser le fichier de configuration

  • Linux :

    sudo nano /etc/bindplane-agent/config.yaml
    
  • Windows :

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

Modifiez le fichier de configuration

  • Remplacez l'intégralité du contenu de config.yaml par la configuration suivante :

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

Paramètres de configuration

Remplacez les espaces réservés suivants :

  • Configuration du récepteur :

    • listen_address : adresse IP et port à écouter :
      • 0.0.0.0 pour écouter sur toutes les interfaces (recommandé)
      • Le port 514 est le port syslog standard (nécessite la racine sous Linux ; utilisez 1514 pour les utilisateurs non racine).
  • Configuration de l'exportateur :

    • creds_file_path : chemin d'accès complet au fichier d'authentification de l'ingestion :
      • Linux : /etc/bindplane-agent/ingestion-auth.json
      • Windows : C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
    • customer_id : ID client copié depuis la console Google SecOps
    • endpoint : URL du point de terminaison régional :
      • États-Unis : malachiteingestion-pa.googleapis.com
      • Europe : europe-malachiteingestion-pa.googleapis.com
      • Asie : asia-southeast1-malachiteingestion-pa.googleapis.com
      • Pour obtenir la liste complète, consultez Points de terminaison régionaux.

Enregistrez le fichier de configuration.

  • Après avoir modifié le fichier, enregistrez-le :
    • Linux : appuyez sur Ctrl+O, puis sur Enter, puis sur Ctrl+X.
    • Windows : cliquez sur Fichier > Enregistrer.

Redémarrez l'agent Bindplane pour appliquer les modifications.

  • Pour redémarrer l'agent Bindplane sous Linux, exécutez la commande suivante :

    sudo systemctl restart observiq-otel-collector
    
    1. Vérifiez que le service est en cours d'exécution :

      sudo systemctl status observiq-otel-collector
      
    2. Recherchez les erreurs dans les journaux :

      sudo journalctl -u observiq-otel-collector -f
      
  • Pour redémarrer l'agent Bindplane dans Windows, choisissez l'une des options suivantes :

    • Invite de commandes ou PowerShell en tant qu'administrateur :

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

      1. Appuyez sur Win+R, saisissez services.msc, puis appuyez sur Entrée.
      2. Localisez observIQ OpenTelemetry Collector.
      3. Effectuez un clic droit, puis sélectionnez Redémarrer.
      4. Vérifiez que le service est en cours d'exécution :

        sc query observiq-otel-collector
        
      5. Recherchez les erreurs dans les journaux :

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

Configurer syslog sur Cyolo

  1. Connectez-vous à la console d'administration Cyolo.
  2. Accédez à Monitoring > Settings (Surveillance > Paramètres).
  3. Activez l'option Exporter les journaux vers le protocole de journalisation système (Syslog).
  4. Accédez à Intégrations> Serveur Syslog.
  5. Fournissez les informations de configuration suivantes :
    • Nom du serveur : saisissez un nom explicite pour ce serveur (par exemple, Google SecOps Bindplane).
    • Sites : sélectionnez un seul site ou plusieurs sites dans le menu déroulant.
    • Adresse IP : saisissez l'adresse IP de l'agent Bindplane.
    • Port : saisissez le numéro de port de l'agent Bindplane pour la connexion UDP.
  6. Cliquez sur Enregistrer.

Table de mappage UDM

Champ de journal Mappage UDM Logique
_field additional.fields Fusionné
authority_id_label additional.fields Fusionné
authority_kind_label additional.fields Fusionné
authority_name_label additional.fields Fusionné
data_field additional.fields Fusionné
duration_label additional.fields Fusionné
kind_label additional.fields Fusionné
log_level_label additional.fields Fusionné
object_id_label additional.fields Fusionné
object_kind_label additional.fields Fusionné
object_name_label additional.fields Fusionné
rules_label additional.fields Fusionné
site_id_label additional.fields Fusionné
subject_id_label additional.fields Fusionné
subject_kind_label additional.fields Fusionné
message extensions.auth.type Mappé : user disconnectedMACHINE
syslog_object_name extensions.auth.type Mappé : loginMACHINE
inter_host intermediary.asset.hostname Mappé directement
inter_host intermediary.hostname Mappé directement
message metadata.description Mappé directement
msg metadata.description Mappé directement
syslog_message metadata.description Mappé directement
syslog_timestamp metadata.event_timestamp Analysé en tant que ISO8601
time metadata.event_timestamp Analysé en tant que MMM d HH:mm:ss
timestamp metadata.event_timestamp Analysé en tant que ISO8601
event_type metadata.event_type Mappé directement
kind metadata.product_event_type Mappé directement
prod_type metadata.product_event_type Mappé directement
id metadata.product_log_id Mappé directement
syslog_event_id metadata.product_log_id Mappé directement
product_version metadata.product_version Mappé directement
message network.application_protocol Mappé : rdpRDP
client network.http.parsed_user_agent Mappé directement
cyolouagent network.http.parsed_user_agent Mappé directement
client network.http.user_agent Mappé directement
cyolouagent network.http.user_agent Mappé directement
syslog_client network.http.user_agent Mappé directement
cyolosessionid network.session_id Mappé directement
session_id network.session_id Mappé directement
hostname observer.hostname Mappé directement
container_id_label observer.resource.attribute.labels Fusionné
internal_event_id_label observer.resource.attribute.labels Fusionné
log_source_label observer.resource.attribute.labels Fusionné
site_id_label observer.resource.attribute.labels Fusionné
site_name_label observer.resource.attribute.labels Fusionné
transaction_id_label observer.resource.attribute.labels Fusionné
node_id observer.resource.product_object_id Mappé directement
syslog_hostname principal.asset.hostname Mappé directement
remote_address principal.asset.ip Fusionné
syslog_remote_address principal.asset.ip Fusionné
syslog_hostname principal.hostname Mappé directement
remote_address principal.ip Fusionné
syslog_remote_address principal.ip Fusionné
country_code principal.location.country_or_region Mappé directement
cyolocountrycode principal.location.country_or_region Mappé directement
syslog_country_code principal.location.country_or_region Mappé directement
node_id_label principal.resource.attribute.labels Fusionné
site_name_label principal.resource.attribute.labels Fusionné
transaction_id_label principal.resource.attribute.labels Fusionné
cyolosubjectkind principal.resource.resource_subtype Mappé directement
credentials_id_label principal.user.attribute.labels Fusionné
credentials_name_label principal.user.attribute.labels Fusionné
credentials_origin_label principal.user.attribute.labels Fusionné
cyolosubjectid principal.user.product_object_id Mappé directement
subject_id principal.user.product_object_id Mappé directement
syslog_session_id principal.user.product_object_id Mappé directement
cyolosubjectname principal.user.userid Mappé directement
subject_name principal.user.userid Mappé directement
syslog_id principal.user.userid Mappé directement
action security_result.action Fusionné
result security_result.action Mappé : failure → sr_action, success → sr_action
sr_action security_result.action Fusionné
syslog_result security_result.action_details Mappé directement
_field security_result.detection_fields Fusionné
field security_result.detection_fields Fusionné
key security_result.detection_fields Mappé : "cyoloauthkind", "cyolokind","cyoloresult"_field
result security_result.outcome Mappé : failure → FAIL, success → PASS
authority_id security_result.rule_id Mappé directement
cyoloauthid security_result.rule_id Mappé directement
authority_name security_result.rule_name Mappé directement
cyoloauthname security_result.rule_name Mappé directement
severity security_result.severity Mappé : 1LOW
cyoloobjname target.application Mappé directement
object_name target.application Mappé directement
asset_id target.asset.asset_id Mappé directement
destination_host target.asset.hostname Mappé directement
dst target.asset.ip Fusionné
asset_name target.asset.product_object_id Mappé directement
destination_host target.hostname Mappé directement
dst target.ip Fusionné
destination_port target.port Mappé directement
_field target.resource.attribute.labels Fusionné
key target.resource.attribute.labels Mappé : cyolodstid_field
cyoloobjid target.resource.product_object_id Mappé directement
object_id target.resource.product_object_id Mappé directement
cyoloobjkind target.resource.resource_subtype Mappé directement
syslog_subject_name target.user.userid Mappé directement
N/A extensions.auth.type Constante : MACHINE
N/A metadata.product_name Constante : CYOLO_OT
N/A metadata.vendor_name Constante : CYOLO_OT
N/A network.application_protocol Constante : RDP
N/A network.http.parsed_user_agent Constante : parseduseragent
N/A security_result.outcome Constante : FAIL
N/A security_result.severity Constante : LOW

Vous avez encore besoin d'aide ? Obtenez des réponses de membres de la communauté et de professionnels Google SecOps.