Collecter les journaux Cyolo OT
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
- Connectez-vous à la console Google SecOps.
- Accédez à Paramètres du SIEM > Agents de collecte.
- Téléchargez le fichier d'authentification d'ingestion.
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
- Connectez-vous à la console Google SecOps.
- Accédez à Paramètres SIEM> Profil.
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
- Ouvrez l'invite de commandes ou PowerShell en tant qu'administrateur.
Exécutez la commande suivante :
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quietAttendez la fin de l'installation.
Vérifiez l'installation en exécutant la commande suivante :
sc query observiq-otel-collectorLe service doit être indiqué comme RUNNING (EN COURS D'EXÉCUTION).
Installation de Linux
- Ouvrez un terminal avec les droits root ou sudo.
Exécutez la commande suivante :
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.shAttendez la fin de l'installation.
Vérifiez l'installation en exécutant la commande suivante :
sudo systemctl status observiq-otel-collectorLe 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.yamlWindows :
notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
Modifiez le fichier de configuration
Remplacez l'intégralité du contenu de
config.yamlpar 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.0pour écouter sur toutes les interfaces (recommandé)- Le port
514est le port syslog standard (nécessite la racine sous Linux ; utilisez1514pour 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
- Linux :
customer_id: ID client copié depuis la console Google SecOpsendpoint: 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.
- États-Unis :
Enregistrez le fichier de configuration.
- Après avoir modifié le fichier, enregistrez-le :
- Linux : appuyez sur
Ctrl+O, puis surEnter, puis surCtrl+X. - Windows : cliquez sur Fichier > Enregistrer.
- Linux : appuyez sur
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-collectorVérifiez que le service est en cours d'exécution :
sudo systemctl status observiq-otel-collectorRecherchez 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-collectorConsole Services :
- Appuyez sur
Win+R, saisissezservices.msc, puis appuyez sur Entrée. - Localisez observIQ OpenTelemetry Collector.
- Effectuez un clic droit, puis sélectionnez Redémarrer.
Vérifiez que le service est en cours d'exécution :
sc query observiq-otel-collectorRecherchez les erreurs dans les journaux :
type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
- Appuyez sur
Configurer syslog sur Cyolo
- Connectez-vous à la console d'administration Cyolo.
- Accédez à Monitoring > Settings (Surveillance > Paramètres).
- Activez l'option Exporter les journaux vers le protocole de journalisation système (Syslog).
- Accédez à Intégrations> Serveur Syslog.
- 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.
- Nom du serveur : saisissez un nom explicite pour ce serveur (par exemple,
- 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 disconnected → MACHINE |
syslog_object_name |
extensions.auth.type |
Mappé : login → MACHINE |
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é : rdp → RDP |
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é : 1 → LOW |
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.