Collecter les journaux des flux d'événements CrowdStrike Falcon
Ce document explique comment ingérer les journaux CrowdStrike Falcon Event Streams dans Google Security Operations à l'aide de Google Cloud Storage V2. CrowdStrike Falcon Event Streams fournit une API de flux en temps réel qui transmet les données d'événements de sécurité de la plate-forme Falcon, y compris les événements de détection, les événements d'audit, l'activité d'authentification et les mises à jour des incidents. L'API Event Streams utilise une connexion HTTP persistante avec le point de terminaison /sensors/entities/datafeed/v2 pour envoyer des événements en temps quasi réel. Elle prend en charge la reprise basée sur le décalage pour une diffusion fiable.
Avant de commencer
Assurez-vous de remplir les conditions suivantes :
- Instance Google SecOps.
- Un projet GCP avec l'API Cloud Storage activée.
- Autorisations permettant de créer et de gérer des buckets GCS.
- Autorisations permettant de gérer les stratégies IAM sur les buckets GCS.
- Autorisations permettant de créer des services Cloud Run, des sujets Pub/Sub et des tâches Cloud Scheduler.
- Accès privilégié à la console CrowdStrike Falcon avec les autorisations nécessaires pour créer des clients API.
Créer un bucket Google Cloud Storage
- Accédez à la console Google Cloud.
- Sélectionnez votre projet ou créez-en un.
- Dans le menu de navigation, accédez à Cloud Storage > Buckets.
- Cliquez sur Créer un bucket.
Fournissez les informations de configuration suivantes :
Paramètre Valeur Nommer votre bucket Saisissez un nom unique (par exemple, cs-stream-logs).Type d'emplacement Choisissez en fonction de vos besoins (région, birégion ou multirégion). Emplacement Sélectionnez l'emplacement (par exemple, us-central1).Classe de stockage Standard (recommandé pour les journaux auxquels vous accédez fréquemment) Access control (Contrôle des accès) Uniforme (recommandé) Outils de protection Facultatif : Activez la gestion des versions des objets ou une règle de conservation. Cliquez sur Créer.
Configurer l'accès à l'API CrowdStrike Falcon
Créer un client API
- Connectez-vous à la console CrowdStrike Falcon.
- Dans le menu de navigation, accédez à Assistance et ressources > Ressources et outils > Clés et clients API.
- Cliquez sur Créer un client API.
- Fournissez les informations de configuration suivantes :
- Nom du client : saisissez un nom descriptif (par exemple,
Google SecOps Event Streams Integration). - Description (facultatif) : saisissez une description (par exemple,
API client for streaming events to GCS).
- Nom du client : saisissez un nom descriptif (par exemple,
- Dans la section Champs d'application de l'API, sélectionnez l'autorisation suivante :
- Flux d'événements : sélectionnez Lire (obligatoire pour utiliser l'API de streaming).
- Cliquez sur Créer.
Enregistrer les identifiants de l'API
Une fois le client API créé, vous recevez les identifiants suivants :
- ID client : chaîne hexadécimale de 32 caractères en minuscules.
- Code secret du client : chaîne alphanumérique de 40 caractères.
- URL de base : nom de domaine complet de l'API CrowdStrike (par exemple,
api.crowdstrike.comouapi.us-2.crowdstrike.com).
Important : Copiez et enregistrez immédiatement le code secret du client. Elle ne s'affiche qu'une seule fois et ne peut pas être récupérée ultérieurement.
Points de terminaison régionaux
CrowdStrike opère dans plusieurs régions avec différents points de terminaison d'API :
| Région | URL de base |
|---|---|
| US-1 | api.crowdstrike.com |
| US-2 | api.us-2.crowdstrike.com |
| EU-1 | api.eu-1.crowdstrike.com |
| US-GOV-1 | api.laggar.gcw.crowdstrike.com |
Important : Utilisez l'URL de base qui correspond à la région de connexion de votre console CrowdStrike Falcon.
Vérifier les autorisations
Pour vérifier que le client API dispose des autorisations requises :
- Connectez-vous à la console CrowdStrike Falcon.
- Accédez à Assistance et ressources> Ressources et outils> Clés et clients API.
- Recherchez le client API que vous avez créé et vérifiez que le niveau d'accès Lecture est indiqué pour le champ Flux d'événements.
Tester l'accès à l'API
Testez vos identifiants avant de procéder à l'intégration :
CLIENT_ID="<your-client-id>" CLIENT_SECRET="<your-client-secret>" BASE_URL="https://api.crowdstrike.com" # Get OAuth2 token TOKEN=$(curl -s -X POST "${BASE_URL}/oauth2/token" \ -H "Content-Type: application/x-www-form-urlencoded" \ -d "client_id=${CLIENT_ID}&client_secret=${CLIENT_SECRET}" | python3 -c "import sys,json; print(json.load(sys.stdin)['access_token'])") # Test Event Streams API access (discover available data feeds) curl -s -H "Authorization: Bearer ${TOKEN}" \ "${BASE_URL}/sensors/entities/datafeed/v2?appId=secops-test&format=flatjson"
Une réponse réussie renvoie un objet JSON contenant resources avec les champs dataFeedURL et sessionToken pour chaque partition de flux disponible.
Créer un compte de service pour la fonction Cloud Run
La fonction Cloud Run a besoin d'un compte de service disposant des autorisations nécessaires pour écrire dans le bucket GCS et être appelée par Pub/Sub.
Créer un compte de service
- Dans la console GCP, accédez à IAM et administration > Comptes de service.
- Cliquez sur Créer un compte de service.
- Fournissez les informations de configuration suivantes :
- Nom du compte de service : saisissez
cs-stream-collector-sa. - Description du compte de service : saisissez
Service account for Cloud Run function to collect CrowdStrike Event Streams logs.
- Nom du compte de service : saisissez
- Cliquez sur Créer et continuer.
- Dans la section Autoriser ce compte de service à accéder au projet, ajoutez les rôles suivants :
- Cliquez sur Sélectionner un rôle.
- Recherchez et sélectionnez Administrateur des objets de l'espace de stockage.
- Cliquez sur + Ajouter un autre rôle.
- Recherchez et sélectionnez Demandeur Cloud Run.
- Cliquez sur + Ajouter un autre rôle.
- Recherchez et sélectionnez Demandeur Cloud Functions.
- Cliquez sur Continuer.
- Cliquez sur OK.
Ces rôles sont requis pour :
- Administrateur des objets Storage : écrire des journaux dans un bucket GCS et gérer les fichiers d'état
- Demandeur Cloud Run : autorise Pub/Sub à appeler la fonction
- Demandeur Cloud Functions : autorise l'appel de fonctions
Accorder des autorisations IAM sur un bucket GCS
Accordez au compte de service des autorisations d'écriture sur le bucket GCS :
- Accédez à Cloud Storage > Buckets.
- Cliquez sur le nom de votre bucket (par exemple,
cs-stream-logs). - Accédez à l'onglet Autorisations.
- Cliquez sur Accorder l'accès.
- Fournissez les informations de configuration suivantes :
- Ajouter des comptes principaux : saisissez l'adresse e-mail du compte de service (par exemple,
cs-stream-collector-sa@PROJECT_ID.iam.gserviceaccount.com). - Attribuer des rôles : sélectionnez Administrateur des objets Storage.
- Ajouter des comptes principaux : saisissez l'adresse e-mail du compte de service (par exemple,
- Cliquez sur Enregistrer.
Créer un sujet Pub/Sub
Créez un sujet Pub/Sub auquel Cloud Scheduler publiera des messages et auquel la fonction Cloud Run s'abonnera.
- Dans la console GCP, accédez à Pub/Sub > Sujets.
- Cliquez sur Create topic (Créer un sujet).
- Fournissez les informations de configuration suivantes :
- ID du sujet : saisissez
cs-stream-trigger. - Conservez les valeurs par défaut des autres paramètres.
- ID du sujet : saisissez
- Cliquez sur Créer.
Créer une fonction Cloud Run pour collecter les journaux
La fonction Cloud Run sera déclenchée par les messages Pub/Sub de Cloud Scheduler pour se connecter à l'API CrowdStrike Event Streams, consommer des événements et les écrire dans GCS.
- Dans la console GCP, accédez à Cloud Run.
- Cliquez sur Créer un service.
- Sélectionnez Fonction (utilisez un éditeur intégré pour créer une fonction).
Dans la section Configurer, fournissez les informations de configuration suivantes :
Paramètre Valeur Nom du service cs-stream-collectorRégion Sélectionnez la région correspondant à votre bucket GCS (par exemple, us-central1).Durée d'exécution Sélectionnez Python 3.12 ou version ultérieure. Dans la section Déclencheur (facultatif) :
- Cliquez sur + Ajouter un déclencheur.
- Sélectionnez Cloud Pub/Sub.
- Dans Sélectionner un sujet Cloud Pub/Sub, sélectionnez
cs-stream-trigger. - Cliquez sur Enregistrer.
Dans la section Authentification :
- Sélectionnez Exiger l'authentification.
- Consultez Identity and Access Management (IAM).
Faites défiler la page vers le bas, puis développez Conteneurs, mise en réseau, sécurité.
Accédez à l'onglet Sécurité :
- Compte de service : sélectionnez
cs-stream-collector-sa.
- Compte de service : sélectionnez
Accédez à l'onglet Conteneurs :
- Cliquez sur Variables et secrets.
- Cliquez sur + Ajouter une variable pour chaque variable d'environnement :
Nom de la variable Exemple de valeur Description GCS_BUCKETcs-stream-logsNom du bucket GCS GCS_PREFIXcrowdstrike/streamPréfixe des fichiers journaux STATE_KEYcrowdstrike/stream/state.jsonChemin d'accès au fichier d'état CS_BASE_URLhttps://api.crowdstrike.comURL de base de l'API CrowdStrike CS_CLIENT_IDyour-client-idID client de l'API CS_CLIENT_SECRETyour-client-secretCode secret du client de l'API CS_APP_IDsecops-stream-collectorID unique de l'application pour les flux d'événements (32 caractères alphanumériques maximum) STREAM_TIMEOUT300Délai avant expiration de la lecture du flux en secondes MAX_RECORDS10000Nombre maximal d'enregistrements par exécution Dans la section Variables et secrets, faites défiler la page jusqu'à Requêtes :
- Délai avant expiration de la requête : saisissez
600secondes (10 minutes).
- Délai avant expiration de la requête : saisissez
Accédez à l'onglet Paramètres :
- Dans la section Ressources :
- Mémoire : sélectionnez 512 Mio ou plus.
- CPU : sélectionnez 1.
- Dans la section Ressources :
Dans la section Scaling de révision :
- Nombre minimal d'instances : saisissez
0. - Nombre maximal d'instances : saisissez
1(un seul consommateur de flux doit s'exécuter à la fois).
- Nombre minimal d'instances : saisissez
Cliquez sur Créer.
Attendez que le service soit créé (1 à 2 minutes).
Une fois le service créé, l'éditeur de code intégré s'ouvre automatiquement.
Ajouter un code de fonction
- Saisissez main dans le champ Point d'entrée.
Dans l'éditeur de code intégré, créez deux fichiers :
main.py:
import functions_framework from google.cloud import storage import json import os import urllib3 from datetime import datetime, timezone # Initialize HTTP client with timeouts http = urllib3.PoolManager( timeout=urllib3.Timeout(connect=5.0, read=30.0), retries=False, ) # Initialize Storage client storage_client = storage.Client() # Environment variables GCS_BUCKET = os.environ.get('GCS_BUCKET') GCS_PREFIX = os.environ.get('GCS_PREFIX', 'crowdstrike/stream') STATE_KEY = os.environ.get('STATE_KEY', 'crowdstrike/stream/state.json') CS_BASE_URL = os.environ.get('CS_BASE_URL', 'https://api.crowdstrike.com') CS_CLIENT_ID = os.environ.get('CS_CLIENT_ID') CS_CLIENT_SECRET = os.environ.get('CS_CLIENT_SECRET') CS_APP_ID = os.environ.get('CS_APP_ID', 'secops-stream-collector') STREAM_TIMEOUT = int(os.environ.get('STREAM_TIMEOUT', '300')) MAX_RECORDS = int(os.environ.get('MAX_RECORDS', '10000')) def get_oauth_token(base_url: str, client_id: str, client_secret: str) -> str: """Get CrowdStrike OAuth2 access token.""" token_url = f"{base_url}/oauth2/token" body = f"client_id={client_id}&client_secret={client_secret}" response = http.request( 'POST', token_url, body=body.encode('utf-8'), headers={'Content-Type': 'application/x-www-form-urlencoded'} ) if response.status != 200: raise Exception(f"OAuth token request failed: {response.status}") data = json.loads(response.data.decode('utf-8')) return data['access_token'] def refresh_stream_session(base_url: str, token: str, app_id: str, partition: int = 0): """Refresh an active stream session to keep it alive.""" refresh_url = ( f"{base_url}/sensors/entities/datafeed-actions/v1/{partition}" f"?appId={app_id}&action_name=refresh_active_stream_session" ) response = http.request( 'POST', refresh_url, headers={ 'Authorization': f'Bearer {token}', 'Content-Type': 'application/json', } ) if response.status == 200: print("Stream session refreshed successfully") else: print(f"Warning: Stream session refresh returned {response.status}") @functions_framework.cloud_event def main(cloud_event): """ Cloud Run function triggered by Pub/Sub to fetch CrowdStrike Event Streams data and write to GCS. """ if not all([GCS_BUCKET, CS_BASE_URL, CS_CLIENT_ID, CS_CLIENT_SECRET]): print('Error: Missing required environment variables') return try: bucket = storage_client.bucket(GCS_BUCKET) # Load state state = load_state(bucket, STATE_KEY) # Get OAuth token token = get_oauth_token(CS_BASE_URL, CS_CLIENT_ID, CS_CLIENT_SECRET) headers = { 'Authorization': f'Bearer {token}', 'Accept': 'application/json', } # Discover available data feeds discover_url = ( f"{CS_BASE_URL}/sensors/entities/datafeed/v2" f"?appId={CS_APP_ID}&format=flatjson" ) response = http.request('GET', discover_url, headers=headers) if response.status != 200: print(f"Failed to discover data feed: {response.status}") print(f"Response: {response.data.decode('utf-8')}") return feed_data = json.loads(response.data.decode('utf-8')) resources = feed_data.get('resources', []) if not resources: print("No data feed resources available") return feed_url = resources[0].get('dataFeedURL', '') session_token = resources[0].get( 'sessionToken', {} ).get('token', '') if not feed_url or not session_token: print("Missing feed URL or session token") return # Build stream URL with offset if available stream_url = feed_url offset = state.get('offset') if offset: stream_url = f"{feed_url}&offset={offset}" # Connect to Event Stream stream_headers = { 'Authorization': f'Token {session_token}', 'Accept': 'application/json', 'Connection': 'keep-alive', } stream_http = urllib3.PoolManager( timeout=urllib3.Timeout( connect=10.0, read=float(STREAM_TIMEOUT) ), retries=False, ) print(f"Connecting to Event Stream...") resp = stream_http.request( 'GET', stream_url, headers=stream_headers, preload_content=False ) if resp.status != 200: print(f"Stream connection failed: {resp.status}") return records = [] latest_offset = offset now = datetime.now(timezone.utc) for line in resp.stream(4096): decoded = line.decode('utf-8').strip() if not decoded: continue try: event = json.loads(decoded) records.append(event) event_offset = event.get( 'metadata', {} ).get('offset') if event_offset is not None: latest_offset = event_offset if len(records) >= MAX_RECORDS: print( f"Reached max records limit ({MAX_RECORDS})" ) break except json.JSONDecodeError: continue resp.release_conn() if not records: print("No new events found in stream.") # Refresh stream session to keep it alive refresh_stream_session( CS_BASE_URL, token, CS_APP_ID ) return # Write to GCS as NDJSON timestamp = now.strftime('%Y%m%d_%H%M%S') object_key = f"{GCS_PREFIX}/logs_{timestamp}.ndjson" blob = bucket.blob(object_key) ndjson = '\n'.join( [json.dumps(r, ensure_ascii=False) for r in records] ) + '\n' blob.upload_from_string( ndjson, content_type='application/x-ndjson' ) print( f"Wrote {len(records)} records to " f"gs://{GCS_BUCKET}/{object_key}" ) # Save state with latest offset new_state = { 'offset': latest_offset, 'last_run': now.isoformat() } save_state(bucket, STATE_KEY, new_state) # Refresh stream session to keep it alive refresh_stream_session( CS_BASE_URL, token, CS_APP_ID ) print(f"Successfully processed {len(records)} events") except Exception as e: print(f'Error processing logs: {str(e)}') raise def load_state(bucket, key): """Load state from GCS.""" try: blob = bucket.blob(key) if blob.exists(): state_data = blob.download_as_text() return json.loads(state_data) except Exception as e: print(f"Warning: Could not load state: {e}") return {} def save_state(bucket, key, state: dict): """Save state to GCS.""" try: blob = bucket.blob(key) blob.upload_from_string( json.dumps(state, indent=2), content_type='application/json' ) print(f"Saved state: {state}") except Exception as e: print(f"Warning: Could not save state: {e}")
requirements.txt:
```none functions-framework==3.* google-cloud-storage==2.* urllib3>=2.0.0 ```Cliquez sur Déployer pour enregistrer et déployer la fonction.
Attendez la fin du déploiement (deux à trois minutes).
Créer une tâche Cloud Scheduler
Cloud Scheduler publie des messages sur le sujet Pub/Sub à intervalles réguliers, ce qui déclenche la fonction Cloud Run.
- Dans la console GCP, accédez à Cloud Scheduler.
- Cliquez sur Créer une tâche.
Fournissez les informations de configuration suivantes :
Paramètre Valeur Nom cs-stream-collector-scheduledRégion Sélectionnez la même région que la fonction Cloud Run. Fréquence */15 * * * *(toutes les 15 minutes)Fuseau horaire Sélectionnez un fuseau horaire (UTC recommandé). Type de cible Pub/Sub Thème Sélectionner cs-stream-triggerCorps du message {}(objet JSON vide)Cliquez sur Créer.
Tester l'intégration
- Dans la console Cloud Scheduler, recherchez votre job.
- Cliquez sur Exécuter de force pour déclencher le job manuellement.
- Patientez quelques secondes.
- Accédez à Cloud Run > Services.
- Cliquez sur
cs-stream-collector. - Cliquez sur l'onglet Journaux.
Vérifiez que la fonction s'est exécutée correctement. Par exemple :
Connecting to Event Stream... Wrote X records to gs://cs-stream-logs/crowdstrike/stream/logs_YYYYMMDD_HHMMSS.ndjson Stream session refreshed successfully Successfully processed X eventsAccédez à Cloud Storage > Buckets.
Cliquez sur
cs-stream-logs.Accédez au dossier
crowdstrike/stream/.Vérifiez qu'un fichier
.ndjsona été créé avec le code temporel actuel.
Si vous constatez des erreurs dans les journaux :
- HTTP 401 : vérifiez les identifiants de l'API dans les variables d'environnement
- HTTP 403 : vérifiez que le client API dispose du champ d'application Flux d'événements : lecture.
- HTTP 429 : limitation du débit. Ajustez la fréquence du planificateur ou augmentez
STREAM_TIMEOUT. - Variables d'environnement manquantes : vérifiez que toutes les variables requises sont définies.
- Aucune ressource de flux de données n'est disponible : vérifiez que
CS_APP_IDest unique et ne dépasse pas 32 caractères alphanumériques.
Récupérer le compte de service Google SecOps
Google SecOps utilise un compte de service unique pour lire les données de votre bucket GCS. Vous devez accorder à ce compte de service l'accès à votre bucket.
Obtenir l'adresse e-mail du compte de service
- Accédez à Paramètres SIEM> Flux.
- Cliquez sur Add New Feed (Ajouter un flux).
- Cliquez sur Configurer un flux unique.
- Dans le champ Nom du flux, saisissez un nom pour le flux (par exemple,
CrowdStrike Event Streams logs). - Sélectionnez Google Cloud Storage V2 comme Type de source.
- Sélectionnez CrowdStrike Falcon Streaming comme Type de journal.
- Cliquez sur Obtenir un compte de service.
Une adresse e-mail unique pour le compte de service s'affiche, par exemple :
chronicle-12345678@chronicle-gcp-prod.iam.gserviceaccount.comCopiez cette adresse e-mail pour l'utiliser à l'étape suivante.
Cliquez sur Suivant.
Spécifiez les valeurs des paramètres d'entrée suivants :
URL du bucket de stockage : saisissez l'URI du bucket GCS avec le chemin d'accès au préfixe :
gs://cs-stream-logs/crowdstrike/stream/
Option de suppression de la source : sélectionnez l'option de suppression de votre choix :
- Jamais : ne supprime jamais aucun fichier après les transferts (recommandé pour les tests).
- Supprimer les fichiers transférés : supprime les fichiers une fois le transfert réussi.
Supprimer les fichiers transférés et les répertoires vides : supprime les fichiers et les répertoires vides après un transfert réussi.
Âge maximal des fichiers : incluez les fichiers modifiés au cours des derniers jours (180 jours par défaut).
Espace de noms de l'élément : espace de noms de l'élément
Libellés d'ingestion : libellé à appliquer aux événements de ce flux
Cliquez sur Suivant.
Vérifiez la configuration de votre nouveau flux sur l'écran Finaliser, puis cliquez sur Envoyer.
Accorder des autorisations IAM au compte de service Google SecOps
Le compte de service Google SecOps a besoin du rôle Lecteur des objets Storage sur votre bucket GCS.
- Accédez à Cloud Storage > Buckets.
- Cliquez sur
cs-stream-logs. - Accédez à l'onglet Autorisations.
- Cliquez sur Accorder l'accès.
- Fournissez les informations de configuration suivantes :
- Ajouter des comptes principaux : collez l'adresse e-mail du compte de service Google SecOps.
- Attribuer des rôles : sélectionnez Lecteur des objets de l'espace de stockage.
Cliquez sur Enregistrer.
Vous avez encore besoin d'aide ?
Pour en savoir plus sur les flux Google Security Operations, consultez la documentation sur les flux Google Security Operations. Pour en savoir plus sur les exigences associées à chaque type de flux, consultez Configuration des flux par type.
Pour référence, consultez la documentation sur l'analyseur de flux d'événements CrowdStrike Falcon.
Table de mappage UDM
| Champ de journal | Mappage UDM | Logique |
|---|---|---|
event_data.AssociatedFile |
about.file.full_path |
Mappé directement |
event_data.IOCValue |
about.file.sha256 |
Mappé directement |
ActivityId_label |
additional.fields |
Fusionné |
ActivityOperatingSystem_label |
additional.fields |
Fusionné |
ModelAnomalyIndicators_label |
additional.fields |
Fusionné |
SourceEndpointIpReputation_label |
additional.fields |
Fusionné |
SourceIpIspClassification_label |
additional.fields |
Fusionné |
SourceIpIspDomain_label |
additional.fields |
Fusionné |
additional_deviceCustomDate1 |
additional.fields |
Fusionné |
additional_domainname |
additional.fields |
Fusionné |
commands_label |
additional.fields |
Fusionné |
data_domains_label |
additional.fields |
Fusionné |
dns_request_domain_name_label |
additional.fields |
Fusionné |
dns_request_type_label |
additional.fields |
Fusionné |
dnsrequest_interface_index_label |
additional.fields |
Fusionné |
dnsrequest_load_time_label |
additional.fields |
Fusionné |
eventType |
additional.fields |
Valeurs mappées (8 au total, par exemple "EppDetectionSummaryEvent","IdpDetectionSummaryEvent" → `file... |
event_data_ContextTimeStamp_id_label |
additional.fields |
Fusionné |
event_data_MobileDetectionId_id_label |
additional.fields |
Fusionné |
field1 |
additional.fields |
Fusionné |
fileaccessed_full_path_label |
additional.fields |
Fusionné |
fileaccessed_timestamp_label |
additional.fields |
Fusionné |
filewritten_full_path_label |
additional.fields |
Fusionné |
filewritten_timestamp_label |
additional.fields |
Fusionné |
reputation_label_list_values |
additional.fields |
Fusionné |
sourceipasncode_label |
additional.fields |
Fusionné |
sourceipasnorg_label |
additional.fields |
Fusionné |
eventType |
extensions.auth.mechanism |
Mappé : "saml2Assert", "twoFactorAuthenticate" → mechanism |
mechanism |
extensions.auth.mechanism |
Fusionné |
eventType |
extensions.auth.type |
Mappé : "assert", "userAuthenticate" → AUTHTYPE_UNSPECIFIED |
description |
metadata.description |
Mappé directement |
event_data.Description |
metadata.description |
Mappé directement |
incidentDescription |
metadata.description |
Mappé directement |
msg |
metadata.description |
Mappé directement |
name |
metadata.description |
Mappé directement |
serviceName |
metadata.description |
Mappé directement |
devTime |
metadata.event_timestamp |
Analysé comme yyyy-MM-dd HH:mm:ss |
deviceCustomDate1 |
metadata.event_timestamp |
Analysé comme MMM dd yyyy HH:mm:ss |
event_data.UTCTimestamp |
metadata.event_timestamp |
Analysé comme UNIX_MS |
meta.eventCreationTime |
metadata.event_timestamp |
Analysé comme UNIX_MS |
meta.event_dataCreationTime |
metadata.event_timestamp |
Analysé comme UNIX_MS |
timestamp |
metadata.event_timestamp |
Analysé comme UNIX_MS |
eventType |
metadata.event_type |
Valeurs mappées (6 au total, par exemple "saml2Assert", "twoFactorAuthenticate" → USER_LOGIN, "r... |
has_principal |
metadata.event_type |
Mappé : true → STATUS_UPDATE, true → SCAN_FILE |
has_user |
metadata.event_type |
Mappé : false → GENERIC_EVENT |
cid |
metadata.product_deployment_id |
Mappé directement |
eventType |
metadata.product_event_type |
Mappé directement |
event_data_simpleName |
metadata.product_event_type |
Mappé directement |
event_data.AgentId |
metadata.product_log_id |
Mappé directement |
id |
metadata.product_log_id |
Mappé directement |
product |
metadata.product_name |
Mappé directement |
meta.version |
metadata.product_version |
Mappé directement |
version |
metadata.product_version |
Mappé directement |
cs6 |
metadata.url_back_to_product |
Mappé directement |
url |
metadata.url_back_to_product |
Mappé directement |
vendor |
metadata.vendor_name |
Mappé directement |
connectionDirection |
network.direction |
Mappé : 0 → OUTBOUND, 1 → INBOUND |
event_data.Attributes.request_method |
network.http.method |
Mappé directement |
event_data.FalconHostLink |
network.http.referral_url |
Mappé directement |
request |
network.http.referral_url |
Mappé directement |
event_data.Attributes.status_code |
network.http.response_code |
Mappé directement |
event_data.Attributes.user_agent |
network.http.user_agent |
Mappé directement |
protocol |
network.ip_protocol |
Mappé : 6 → TCP, 17 → UDP, 58 → ICMP |
event_data.Attributes.trace_id |
network.session_id |
Mappé directement |
event_data.SessionId |
network.session_id |
Mappé directement |
value_issuer |
network.tls.server.certificate.issuer |
Mappé directement |
domain |
principal.administrative_domain |
Mappé directement |
event_data.DataDomains |
principal.administrative_domain |
Mappé directement |
event_data.SourceAccountDomain |
principal.administrative_domain |
Mappé directement |
event_data_ActivityBrowser |
principal.application |
Mappé directement |
aid |
principal.asset.asset_id |
Mappé directement |
event_data.AgentIdString |
principal.asset.asset_id |
Mappé directement |
event_data_SensorId |
principal.asset.asset_id |
Mappé directement |
ComputerName |
principal.asset.hostname |
Mappé directement |
endpointName |
principal.asset.hostname |
Mappé directement |
event_data.EndpointName |
principal.asset.hostname |
Mappé directement |
event_data.Hostname |
principal.asset.hostname |
Mappé directement |
event_data.HostnameField |
principal.asset.hostname |
Mappé directement |
event_data.SourceEndpointHostName |
principal.asset.hostname |
Mappé directement |
event_data_ComputerName |
principal.asset.hostname |
Mappé directement |
hostName |
principal.asset.hostname |
Mappé directement |
ClientIP |
principal.asset.ip |
Fusionné |
LocalAddressIP4 |
principal.asset.ip |
Fusionné |
aip |
principal.asset.ip |
Fusionné |
event_data.EndpointIp |
principal.asset.ip |
Fusionné |
event_data.LocalIP |
principal.asset.ip |
Fusionné |
event_data.LocalIPv6 |
principal.asset.ip |
Fusionné |
event_data.SourceEndpointIpAddress |
principal.asset.ip |
Fusionné |
event_data.UserIp |
principal.asset.ip |
Fusionné |
ip |
principal.asset.ip |
Fusionné |
localAddress |
principal.asset.ip |
Fusionné |
remoteAddress |
principal.asset.ip |
Fusionné |
src |
principal.asset.ip |
Fusionné |
event_data.MACAddress |
principal.asset.mac |
Fusionné |
event_data_SensorId |
principal.asset_id |
Mappé directement |
ComputerName |
principal.hostname |
Mappé directement |
endpointName |
principal.hostname |
Mappé directement |
event_data.EndpointName |
principal.hostname |
Mappé directement |
event_data.Hostname |
principal.hostname |
Mappé directement |
event_data.HostnameField |
principal.hostname |
Mappé directement |
event_data.SourceEndpointHostName |
principal.hostname |
Mappé directement |
event_data_ComputerName |
principal.hostname |
Mappé directement |
hostName |
principal.hostname |
Mappé directement |
ClientIP |
principal.ip |
Fusionné |
LocalAddressIP4 |
principal.ip |
Fusionné |
aip |
principal.ip |
Fusionné |
event_data.EndpointIp |
principal.ip |
Fusionné |
event_data.LocalIP |
principal.ip |
Fusionné |
event_data.LocalIPv6 |
principal.ip |
Fusionné |
event_data.SourceEndpointIpAddress |
principal.ip |
Fusionné |
event_data.UserIp |
principal.ip |
Fusionné |
ip |
principal.ip |
Fusionné |
localAddress |
principal.ip |
Fusionné |
remoteAddress |
principal.ip |
Fusionné |
src |
principal.ip |
Fusionné |
event_data_LocationCountryCode |
principal.location.country_or_region |
Mappé directement |
event_data.MACAddress |
principal.mac |
Fusionné |
srcMAC |
principal.mac |
Fusionné |
event_data_platformName |
principal.platform |
Mappé : (?i)Linux → LINUX, (?i)Windows → WINDOWS, (?i)mac/ios → MAC |
localPort |
principal.port |
Mappé directement |
exeWrittenFilePath |
principal.process.file.full_path |
Mappé directement |
event_data.ParentCommandLine |
principal.process.parent_process.command_line |
Mappé directement |
event_data.ParentImageFilePath |
principal.process.parent_process.file.full_path |
Mappé directement |
eventType |
principal.process.parent_process.file.names |
Mappé : "EppDetectionSummaryEvent","IdpDetectionSummaryEvent" → `event_data.ParentImageFil... |
event_data.ParentImageFileName |
principal.process.parent_process.file.names |
Fusionné |
event_data.ParentProcessId |
principal.process.parent_process.pid |
Mappé directement |
event_data.ProcessId |
principal.process.pid |
Mappé directement |
event_data.Attributes.assign_to_user_id |
principal.user.email_addresses |
Fusionné |
event_data.SourceAccountUpn |
principal.user.email_addresses |
Fusionné |
userName |
principal.user.email_addresses |
Mappé : ^.+@.+$ → userName |
user_email |
principal.user.email_addresses |
Fusionné |
eventType |
principal.user.group_identifiers |
Mappé : "EppDetectionSummaryEvent","IdpDetectionSummaryEvent" → event_data.LogonDomain |
event_data.LogonDomain |
principal.user.group_identifiers |
Fusionné |
event_data.Attributes.assign_to_name |
principal.user.user_display_name |
Mappé directement |
event_data.UserName |
principal.user.user_display_name |
Mappé directement |
event_data.SourceAccountName |
principal.user.userid |
Mappé directement |
event_data.UserId |
principal.user.userid |
Mappé directement |
userName |
principal.user.userid |
Mappé directement |
usrName |
principal.user.userid |
Mappé directement |
event_data.SourceAccountObjectSid |
principal.user.windows_sid |
Mappé directement |
_security_result |
security_result |
Fusionné |
applicationName |
target.application |
Mappé directement |
event_data.Source |
target.application |
Mappé directement |
event_data_SsoApplicationIdentifier |
target.application |
Mappé directement |
serviceName |
target.application |
Mappé directement |
event_data.CompositeId |
target.asset.asset_id |
Mappé directement |
dhost |
target.asset.hostname |
Mappé directement |
event_data.TargetEndpointHostName |
target.asset.hostname |
Mappé directement |
IP |
target.asset.ip |
Fusionné |
dst |
target.asset.ip |
Fusionné |
event_data.IOCValue |
target.asset.ip |
Fusionné |
event_data.TargetEndpointIpAddress |
target.asset.ip |
Fusionné |
TargetFileName |
target.file.full_path |
Mappé directement |
event_data.FilePath |
target.file.full_path |
Mappé directement |
event_data.MD5String |
target.file.md5 |
Mappé directement |
eventType |
target.file.names |
Mappé : "EppDetectionSummaryEvent","IdpDetectionSummaryEvent" → fileaccessed.FileName, `... |
event_data.FileName |
target.file.names |
Fusionné |
exeWrittenFileName |
target.file.names |
Fusionné |
fileName |
target.file.names |
Fusionné |
fileaccessed.FileName |
target.file.names |
Fusionné |
filewritten.FileName |
target.file.names |
Fusionné |
event_data.SHA1String |
target.file.sha1 |
Mappé directement |
event_data.SHA256String |
target.file.sha256 |
Mappé directement |
sha256 |
target.file.sha256 |
Mappé directement |
Size |
target.file.size |
Mappé directement |
dhost |
target.hostname |
Mappé directement |
event_data.TargetEndpointHostName |
target.hostname |
Mappé directement |
IP |
target.ip |
Fusionné |
dst |
target.ip |
Fusionné |
event_data.IOCValue |
target.ip |
Fusionné |
event_data.TargetEndpointIpAddress |
target.ip |
Fusionné |
dpt |
target.port |
Renommé/Mappé |
remotePort |
target.port |
Renommé/Mappé |
cmdLine |
target.process.command_line |
Mappé directement |
commandLine |
target.process.command_line |
Mappé directement |
event_data.CommandLine |
target.process.command_line |
Mappé directement |
filePath |
target.process.file.full_path |
Mappé directement |
md5 |
target.process.file.md5 |
Mappé directement |
event_data_itempostedtimestamp_label |
target.resource.attribute.labels |
Fusionné |
event_data_itemtype_label |
target.resource.attribute.labels |
Fusionné |
resource |
target.resource.name |
Mappé directement |
event_data_itemid |
target.resource.product_object_id |
Mappé directement |
eventType |
target.resource.type |
Mappé : "remove_group", "update_group" → GROUP, delete_group → GROUP |
event_data.Attributes.request_path |
target.url |
Mappé directement |
eventType |
target.user.email_addresses |
Mappé : "saml2Assert", "twoFactorAuthenticate", "assert", "userAuthenticate" → user_email |
user_email |
target.user.email_addresses |
Fusionné |
usrName |
target.user.userid |
Mappé directement |
event_data.TargetEndpointAccountObjectSid |
target.user.windows_sid |
Mappé directement |
| N/A | extensions.auth.type |
Constante : AUTHTYPE_UNSPECIFIED |
| N/A | metadata.event_type |
Constante : GENERIC_EVENT |
| N/A | metadata.product_name |
Constante : FalconHost |
| N/A | metadata.vendor_name |
Constante : CrowdStrike |
| N/A | network.direction |
Constante : OUTBOUND |
| N/A | network.ip_protocol |
Constante : TCP |
| N/A | principal.platform |
Constante : LINUX |
| N/A | target.resource.type |
Constante : GROUP |
Vous avez encore besoin d'aide ? Obtenez des réponses de membres de la communauté et de professionnels Google SecOps.