Collecter les journaux Carbon Black App Control

Compatible avec:

Ce document explique comment collecter les journaux Carbon Black App Control. L'analyseur est compatible avec les formats CEF et JSON. Il tente d'abord d'analyser l'entrée au format JSON. En cas d'échec, il traite l'entrée en tant que CEF, effectue des substitutions de texte, extrait les champs CEF, les met en correspondance avec l'UDM et définit le type d'événement sur GENERIC_EVENT. Sinon, il utilise un fichier d'inclusion de mappage UDM spécifique au format JSON.

Avant de commencer

  • Assurez-vous de disposer d'une instance Google Security Operations.
  • Assurez-vous d'utiliser Windows 2016 ou une version ultérieure, ou un hôte Linux avec systemd.
  • Si vous exécutez l'application derrière un proxy, assurez-vous que les ports du pare-feu sont ouverts.
  • Serveur Carbon Black App Control (CB Protection) (version 8.x ou ultérieure recommandée)
  • Assurez-vous de disposer d'un accès privilégié à Carbon Black App Control.

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. Enregistrez le fichier de manière sécurisée sur le système sur lequel Bindplane sera installé.

Obtenir le numéro client Google SecOps

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

Installer l'agent Bindplane

Installation de Windows

  1. Ouvrez l'invite de commande 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
    

Installation de Linux

  1. Ouvrez un terminal avec des 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
    

Autres ressources d'installation

Configurer l'agent Bindplane pour qu'il ingère les journaux Syslog et les envoie à Google SecOps

  1. Accédez au fichier de configuration:

    1. Recherchez le fichier config.yaml. En règle générale, il se trouve dans le répertoire /etc/bindplane-agent/ sous Linux ou dans le répertoire d'installation sous Windows.
    2. Ouvrez le fichier à l'aide d'un éditeur de texte (nano, vi ou Bloc-notes, par exemple).
  2. Modifiez le fichier config.yaml comme suit :

    receivers:
        tcplog:
            # Replace the port and IP address as required
            listen_address: "0.0.0.0:11592"
    
    exporters:
        chronicle/chronicle_w_labels:
            compression: gzip
            # Adjust the path to the credentials file you downloaded in Step 1
            creds: '/path/to/ingestion-authentication-file.json'
            # Replace with your actual customer ID from Step 2
            customer_id: <customer_id>
            endpoint: malachiteingestion-pa.googleapis.com
            # Add optional ingestion labels for better organization
            ingestion_labels:
                log_type: JSON
                namespace: cb_app_control
                raw_log_field: body
    
    service:
        pipelines:
            logs/source0__chronicle_w_labels-0:
                receivers:
                    - tcplog
                exporters:
                    - chronicle/chronicle_w_labels
    
    
  3. Remplacez le port et l'adresse IP dans votre infrastructure si nécessaire.

  4. Remplacez <customer_id> par le numéro client réel.

  5. Remplacez /path/to/ingestion-authentication-file.json par le chemin d'accès où le fichier d'authentification a été enregistré dans la section Obtenir le fichier d'authentification d'ingestion Google SecOps.

Redémarrer l'agent Bindplane pour appliquer les modifications

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

    sudo systemctl restart bindplane-agent
    
  • Pour redémarrer l'agent Bindplane sous Windows, vous pouvez utiliser la console Services ou saisir la commande suivante:

    net stop BindPlaneAgent && net start BindPlaneAgent
    

Configurer CB App Control pour envoyer des journaux Syslog

  1. Connectez-vous à la console de contrôle des applications CB avec un compte administrateur.
  2. Accédez à Administration > Configuration système > Journalisation externe.
  3. Dans la section "Enregistrement des événements externes" :
    • Activer la journalisation Syslog: cochez la case Syslog activé.
    • Server Address (Adresse du serveur) : <Bindplane Server IP>.
    • Port : <Bindplane Server PORT>.
    • Protocole: sélectionnez TCP.
    • Format Syslog: sélectionnez JSON.
  4. Sous Options de journalisation des événements, sélectionnez les types de journaux à envoyer :
    • Non-respect des règles
    • Événements de surveillance de l'intégrité des fichiers (FIM)
    • Événements d'authentification des utilisateurs
    • Données de renseignement sur les menaces
  5. Cliquez sur Enregistrer.

Tableau de mappage UDM

Champ de journal Mappage UDM Logique
ABId principal.asset.asset_id Le ABId du journal JSON est utilisé dans l'ID de l'asset au format PRODUCT_SPECIFIC_ID:{ABId}-{Bit9Server}.
Bit9Server principal.asset.asset_id Utilisé dans l'ID de l'entité principale, combiné à ABId. Permet également de créer le champ metadata.url_back_to_product.
CommandLine about.process.command_line Mappage direct.
EventType metadata.product_event_type Mappé avec le EventTypeId correspondant entre crochets (par exemple, [5] - Discovery).
EventTypeId metadata.product_event_type Utilisé avec EventType pour renseigner metadata.product_event_type.
EventSubType metadata.description Ajouté au champ metadata.description.
EventSubTypeId metadata.description Non mappé explicitement, mais peut contribuer à la description en fonction de la logique interne de l'analyseur.
externalId metadata.product_log_id Mappage direct.
FileHash about.file.sha256 Mappage direct.
FileName additional.fields (avec la clé FileName) Ajouté en tant que champ supplémentaire. Utilisé également dans les informations de fichier dans metadata.description pour certains événements.
FilePath about.file.full_path Mappage direct.
FileThreat additional.fields (avec la clé fileThreat) Ajouté en tant que champ supplémentaire.
FileTrust additional.fields (avec la clé fileTrust) Ajouté en tant que champ supplémentaire.
HostId principal.asset.asset_id Permet de créer l'URL de retour vers le produit dans metadata.url_back_to_product.
HostName target.hostname Mappage direct.
HostIP target.ip Mappage direct.
Message metadata.description Mappage direct.
PathName about.file.full_path Mappage direct.
Platform target.platform Mappé sur la valeur d'énumération WINDOWS.
Policy additional.fields (avec la clé Policy) Ajouté en tant que champ supplémentaire.
PolicyId additional.fields (avec la clé PolicyId) Ajouté en tant que champ supplémentaire.
ProcessKey additional.fields (avec la clé ProcessKey) Ajouté en tant que champ supplémentaire.
ProcessPath about.process.command_line Mappage direct.
ProcessPathName about.process.command_line Mappage direct.
ProcessThreat additional.fields (avec la clé ProcessThreat) Ajouté en tant que champ supplémentaire.
ProcessTrust additional.fields (avec la clé ProcessTrust) Ajouté en tant que champ supplémentaire.
RuleName additional.fields (avec la clé ruleName) Ajouté en tant que champ supplémentaire.
Timestamp metadata.event_timestamp Mappage direct.
UserName target.user.user_display_name Mappage direct.
UserSid principal.user.userid Mappage direct.
agent.ephemeral_id observer.labels (avec la clé ephemeral_id) Ajouté en tant que libellé d'observateur.
agent.name principal.hostname, observer.hostname, observer.user.userid Mappé sur plusieurs champs.
agent.type observer.application Mappage direct.
agent.version metadata.product_version Mappage direct pour les journaux JSON. Pour les journaux CEF, extraits du message CEF.
cat security_result.category_details Mappage direct.
cs1 additional.fields (avec la clé rootHash ou un autre cs1Label) Ajouté en tant que champ supplémentaire avec la clé définie par cs1Label.
cs1Label additional.fields Utilisé comme clé pour le champ supplémentaire renseigné par cs1.
cs2 additional.fields (avec la clé installerFilename ou un autre cs2Label) Ajouté en tant que champ supplémentaire avec la clé définie par cs2Label.
cs2Label additional.fields Utilisé comme clé pour le champ supplémentaire renseigné par cs2.
cs3 additional.fields (avec la clé Policy ou un autre cs3Label) Ajouté en tant que champ supplémentaire avec la clé définie par cs3Label.
cs3Label additional.fields Utilisé comme clé pour le champ supplémentaire renseigné par cs3.
cs5 additional.fields (avec la clé ruleName ou un autre cs5Label) Ajouté en tant que champ supplémentaire avec la clé définie par cs5Label.
cs5Label additional.fields Utilisé comme clé pour le champ supplémentaire renseigné par cs5.
cfp1 additional.fields (avec la clé fileTrust ou un autre cfp1Label) Ajouté en tant que champ supplémentaire avec la clé définie par cfp1Label.
cfp1Label additional.fields Utilisé comme clé pour le champ supplémentaire renseigné par cfp1.
cfp2 additional.fields (avec la clé processTrust ou un autre cfp2Label) Ajouté en tant que champ supplémentaire avec la clé définie par cfp2Label.
cfp2Label additional.fields Utilisé comme clé pour le champ supplémentaire renseigné par cfp2.
deviceProcessName about.process.command_line Mappage direct.
dhost target.hostname Mappage direct.
dst target.ip Mappage direct.
duser target.user.user_display_name Mappage direct.
dvchost about.hostname Mappage direct.
eventId additional.fields (avec la clé eventId) Ajouté en tant que champ supplémentaire.
fileHash about.file.sha256 Mappage direct.
flexString1 additional.fields (avec la clé fileThreat ou un autre flexString1Label) Ajouté en tant que champ supplémentaire avec la clé définie par flexString1Label.
flexString1Label additional.fields Utilisé comme clé pour le champ supplémentaire renseigné par flexString1.
flexString2 additional.fields (avec la clé processThreat ou une autre flexString2Label) Ajouté en tant que champ supplémentaire avec la clé définie par flexString2Label.
flexString2Label additional.fields Utilisé comme clé pour le champ supplémentaire renseigné par flexString2.
fname additional.fields (avec la clé fname) Ajouté en tant que champ supplémentaire. Utilisé également dans les informations de fichier dans metadata.description pour certains événements.
host.architecture target.asset.hardware.cpu_platform Mappage direct.
host.hostname target.asset.asset_id Utilisé dans l'ID de l'asset cible (Host Id: {host.hostname}). Également mappé sur target.hostname.
host.id target.asset.asset_id Utilisé dans l'ID d'asset cible (Host Id: {host.id}).
host.ip target.asset.ip Mappage direct.
host.mac target.mac Mappage direct.
host.name target.hostname Mappage direct.
host.os.build target.platform_patch_level Mappage direct.
host.os.kernel target.platform_patch_level Ajouté à target.platform_patch_level.
host.os.platform target.platform Mappé sur la valeur d'énumération WINDOWS.
host.os.type target.platform Mappé sur la valeur d'énumération WINDOWS.
host.os.version target.platform_version Mappage direct.
log.file.path target.file.full_path Mappage direct.
metadata.event_type metadata.event_type Définissez la valeur sur GENERIC_EVENT pour les journaux CEF et SYSTEM_AUDIT_LOG_UNCATEGORIZED pour les journaux JSON.
metadata.log_type metadata.log_type Variable définie sur CB_EDR.
metadata.product_log_id metadata.product_log_id Mappé à partir de externalId pour les journaux CEF. Non applicable aux journaux JSON.
metadata.product_name metadata.product_name Définissez la valeur sur App Control pour les journaux CEF et CB_APP_CONTROL pour les journaux JSON.
metadata.product_version metadata.product_version Extrait du message CEF pour les journaux CEF. Mappé à partir de agent.version pour les journaux JSON.
metadata.vendor_name metadata.vendor_name Variable définie sur Carbon Black.
msg metadata.description, additional.fields Permet de renseigner metadata.description et éventuellement d'autres champs en fonction de la logique de l'analyseur.
sproc principal.process.command_line Mappage direct.
metadata.url_back_to_product metadata.url_back_to_product Construit à l'aide des champs Bit9Server et HostId pour les journaux JSON. Non applicable aux journaux CEF.
security_result.severity security_result.severity Variable définie sur MEDIUM.
timestamp events.timestamp Mappage direct pour les journaux JSON. Pour les journaux CEF, la logique de l'analyseur détermine le code temporel en fonction du champ rt du journal brut, le cas échéant, ou du collection_time si rt n'est pas présent.

Modifications

2022-07-01

  • Amélioration
  • Mappage du champ "agent.type" sur "observer.application".
  • Mappage du champ "agent.name" sur "observer.user.userid".
  • Mappage du champ "host.name" sur "observer.hostname".
  • Mappage des champs "agent.type" et "agent.name" sur "observer.asset_id".
  • Mise en correspondance du champ "agent.ephemeral_id" avec "observer.labels".
  • Mappage du champ "host.os.platform" sur "target.platform".
  • Mappage du champ "host.os.version" sur "target.platform_version".
  • Mappage du champ "host.os.kernel" sur "target.platform_patch_level".
  • Le champ "cloud.instance.id" a été mappé sur "principal.resource.product_object_id".
  • Mappage du champ "cloud.instance.name" sur "principal.resource.name".
  • Le champ "host.mac" a été mappé sur "target.mac".
  • Mappage du champ "host.ip" sur "target.asset.ip".
  • Mappage du champ "host.id" sur "target.asset.asset_id".
  • Mappage du champ "host.architecture" sur "target.asset.hardware".
  • Mappage du champ "message.UserSID" sur "principal.user.userid".
  • Mappage du champ "message.ProcessPath" sur "about.process.command_line".
  • Mappage des champs "cloud.machine.type" et "cloud.provider" sur "principal.resource.attribute.labels".
  • Ajout de vérifications conditionnelles pour "message.Bit9Server" et "message.HostId" mappés sur "metadata.url_back_to_product".

2022-06-22

  • Correction de bugs
  • Mappage de l'ID d'hôte sur principal.asset_id
  • Association de la combinaison Bit9Server et HostId à metadata.url_back_to_product

2022-05-19

  • Correction de bugs
  • analysé les journaux demandés dans le bug ;
  • journaux d'échec de l'API analysés

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