CSV
Version de l'intégration : 31.0
Conditions préalables concernant les autorisations
Pour travailler avec des fichiers à l'aide de l'intégration, vous devez disposer des autorisations appropriées. Exécutez la commande suivante pour accorder les autorisations appropriées à un dossier : chown scripting:scripting "directory_path"
Configurer l'intégration CSV dans Google Security Operations
Pour obtenir des instructions détaillées sur la configuration d'une intégration dans Google SecOps, consultez Configurer des intégrations.
Paramètres d'intégration
Utilisez les paramètres suivants pour configurer l'intégration :
Nom à afficher du paramètre | Type | Valeur par défaut | Obligatoire | Description |
---|---|---|---|---|
Nom de l'instance | Chaîne | N/A | Non | Nom de l'instance pour laquelle vous souhaitez configurer l'intégration. |
Description | Chaîne | N/A | Non | Description de l'instance. |
Exécuter à distance | Case à cocher | Décochée | Non | Cochez le champ pour exécuter l'intégration configurée à distance. Une fois la case cochée, l'option permettant de sélectionner l'utilisateur distant (agent) s'affiche. |
Actions
Enregistrer JSON au format CSV
Description
Enregistrez un objet JSON au format CSV.
Paramètres
Nom du paramètre | Type | Valeur par défaut | Obligatoire | Description |
---|---|---|---|---|
Objet JSON | JSON | N/A | Oui | Spécifie l'objet JSON à enregistrer au format CSV. |
Remplacer | Booléen | Faux | Non | Si cette option est activée, l'action écrase le fichier existant. |
Chemin d'accès au fichier | Chaîne | N/A | Oui | Indique le chemin d'accès absolu du fichier CSV nouvellement créé. Si seul le nom de fichier est fourni, l'action stocke le fichier dans un dossier /tmp/ . |
Exécuter sur
N/A
Résultats de l'action
Résultat du script
Nom du résultat du script | Valeur |
---|---|
is_success | Vrai/Faux |
Résultat JSON
{"filepath": "{file name}"}
Mur des cas
L'action fournit les messages de sortie suivants :
Message affiché | Description du message |
---|---|
L'objet JSON a été transformé et enregistré dans le chemin d'accès au fichier fourni. | L'action a réussi. |
Le fichier est introuvable pour le chemin d'accès fourni. | Le fichier n'existe pas. |
Aucune activité n'a été trouvée pour les comptes de service fournis dans Google Cloud Policy Intelligence. | L'action n'a trouvé aucune donnée pour les comptes de service listés. |
Erreur lors de l'exécution de l'action "Enregistrer le fichier JSON au format CSV". | L'action a renvoyé une erreur. Vérifiez la connexion au serveur, les paramètres d'entrée ou les identifiants. |
Rechercher par chaîne
Description
Recherchez des chaînes dans les fichiers CSV.
Paramètres
Nom du paramètre | Type | Valeur par défaut | Obligatoire | Description |
---|---|---|---|---|
Chemin d'accès au fichier CSV | Chaîne | N/A | Oui | Spécifiez le chemin d'accès au fichier CSV ou à un dossier contenant tous les fichiers CSV. Si un dossier est fourni, l'action itère sur tous les fichiers CSV du dossier. |
Colonne CSV | Chaîne | N/A | Non | Spécifiez une liste de colonnes séparées par une virgule pouvant contenir des informations sur les entités. Si vous ne fournissez aucune information, l'action effectue une recherche dans toutes les colonnes. |
Jours en arrière | Chaîne | 10 | Non | Spécifiez le nombre de jours en arrière pour traiter les fichiers CSV. |
Valeur de recherche | Chaîne | N/A | Non | Spécifiez une chaîne à rechercher. Si l'option "Rechercher plusieurs chaînes" est activée, ce paramètre est traité comme une liste de chaînes à rechercher, séparées par une virgule. |
Ne renvoyez que la première ligne. | Case à cocher | Décochée | Non | Si cette option est activée, l'action ne renverra qu'une seule ligne dans le premier fichier correspondant à l'entité. |
Types d'encodages de fichiers | Chaîne | utf-8, latin-1, iso-8859-1 | Oui | Liste des types d'encodage CSV utilisés pour décoder vos fichiers CSV, séparés par une virgule (par exemple, utf-8, latin-1, iso-8859-1, utf-16, etc.). L'ordre dans lequel les types d'encodage sont indiqués définit l'ordre dans lequel ils sont utilisés pour décoder les fichiers.Par exemple (à partir de l'exemple ci-dessus), l'encodage UTF-8 a la priorité la plus élevée et sera utilisé principalement pour décoder tous les fichiers. S'il existe un fichier CSV qui utilise un autre encodage, l'encodage latin-1 sera utilisé, et ainsi de suite, jusqu'à ce que le dernier encodage soit utilisé. |
Rechercher plusieurs chaînes | Case à cocher | Décochée | Non | Si cette option est activée, "Valeur de recherche" fonctionnera comme une liste de valeurs séparées par une virgule, au lieu d'une seule chaîne. |
Champs à renvoyer | CSV | N/A | Non | Spécifiez une liste de valeurs séparées par une virgule qui doivent être renvoyées. |
Cas d'utilisation
Recherchez des chaînes dans les fichiers CSV.
Exécuter sur
Cette action s'exécute sur toutes les entités.
Résultats de l'action
Résultat du script
Nom du résultat du script | Options de valeur | Exemple |
---|---|---|
count_rows_csv | Nombre illimité de lignes | count_rows += 1 |
Résultat JSON
[
{
"EntityResult": {
"Field2": "Value2",
"Field3": "Value3",
"Field1": "Value1",
"Field4": "Value4",
"Field5": "Value5"
},
"Entity": "host"
}, {
"EntityResult": {
"Field2": "Value2",
"Field3": "Value3",
"Field1": "Value1",
"Field4": "Value4",
"Field5": "Value5"
}, "Entity": "1.1.1.1"
}
]
Mur des cas
Type de résultat | Valeur / Description | Type |
---|---|---|
Message de sortie* | Pour les enregistrements trouvés : "Informations trouvées pour les chaînes suivantes : \n (search_string)" Si aucun enregistrement n'est trouvé pour certaines chaînes : "L'action n'a pas pu trouver d'informations sur les chaînes suivantes :" Si aucune information n'est trouvée pour chaque enregistrement : "Aucune information n'a été trouvée pour les éléments fournis." Si tous les encodages ne sont pas valides : "Erreur lors de l'exécution de l'action "Recherche CSV par chaîne". Les encodages fournis ne sont pas valides. Veuillez vérifier l'orthographe." |
Général |
Rechercher par entité
Description
Recherchez des entités dans des fichiers CSV et enrichissez-les.
Paramètres
Nom du paramètre | Type | Valeur par défaut | Obligatoire | Description |
---|---|---|---|---|
Chemin d'accès au fichier CSV | Chaîne | N/A | Oui | Spécifiez le chemin d'accès au fichier CSV ou à un dossier contenant tous les fichiers CSV. Si un dossier est fourni, l'action itère sur tous les fichiers CSV du dossier. |
Colonne CSV | Chaîne | N/A | Oui | Spécifiez une liste de colonnes séparées par une virgule pouvant contenir des informations sur les entités. Si vous ne fournissez aucune information, l'action effectue une recherche dans toutes les colonnes. |
Jours précédents | Chaîne | 10 | Oui | Spécifiez le nombre de jours en arrière pour traiter les fichiers CSV. |
Marquer comme suspect | Case à cocher | Décochée | Non | Si cette option est activée, l'action marquera l'entité comme suspecte si elle a été trouvée dans le fichier. |
Ne renvoyez que la première ligne. | Case à cocher | Décochée | Non | Si cette option est activée, l'action ne renverra qu'une seule ligne dans le premier fichier correspondant à l'entité. |
Types d'encodages de fichiers | Chaîne | utf-8, latin-1, iso-8859-1 | Oui | Liste des types d'encodage CSV utilisés pour décoder vos fichiers CSV, séparés par une virgule (par exemple, utf-8, latin-1, iso-8859-1, utf-16, etc.). L'ordre dans lequel les types d'encodage sont indiqués définit l'ordre dans lequel ils sont utilisés pour décoder les fichiers.Par exemple (à partir de l'exemple ci-dessus), l'encodage UTF-8 a la priorité la plus élevée et sera utilisé principalement pour décoder tous les fichiers. S'il existe un fichier CSV qui utilise un autre encodage, l'encodage latin-1 sera utilisé, et ainsi de suite, jusqu'à ce que le dernier encodage soit utilisé. |
Enrichir les entités | Case à cocher | Cochée | Non | Si cette option est activée, l'action ajoutera les informations du fichier CSV à la table d'enrichissement de l'entité. |
Créer un insight | Case à cocher | Cochée | Non | Si cette option est activée, une action créera un insight si une entité a été trouvée dans le fichier. |
Champs à renvoyer | CSV | N/A | Non | Spécifiez une liste de valeurs séparées par une virgule qui doivent être renvoyées. |
Exécuter sur
Cette action s'exécute sur toutes les entités.
Résultats de l'action
Résultat du script
Nom du résultat du script | Options de valeur | Exemple |
---|---|---|
count_rows_csv | Nombre illimité de lignes | count_rows += 1 |
Résultat JSON
[
{
"EntityResult": [{
"domain": "example.dom",
"fileHash": "cbbc5aea3d4c7ec193aa2ff3b52df36ebb12338b18c9bb53fc4896115efaf78d",
"reporter": "Symantec Antivirus",
"app": "Arcsight",
"id": "1011",
"eventTime": "9/4/2017 10:00",
"antivirusAction": "blocked",
"virusName": "ECAT",
"rule": "malicious",
"eventName": "Virus detected",
"User": "Ziv",
"eventHostName": "WS-ZivDevComp",
"File Source Path": "C:\\\\Users\\\\Default\\\\Desktop\\\\stringTimeRaw.csv",
"machineAddress": "192.168.11.11"
}, {
"domain": "SmartCompany.dom",
"fileHash": "cbbc5aea3d4c7ec193aa2ff3b52df36ebb12338b18c9bb53fc4896115efaf78d",
"reporter": "Symantec Antivirus",
"app": "ESM",
"id": "1012",
"eventTime": "9/4/2017 10:00",
"antivirusAction": "allowed",
"virusName": "ECAT",
"rule": "malicious",
"eventName": "Virus detected",
"User": "GG",
"eventHostName": "WS-GGDevComp",
"File Source Path": "C:\\\\Users\\\\Default\\\\Desktop\\\\stringTimeRaw.csv",
"machineAddress": "192.168.11.11"
}],
"Entity": "192.168.11.11"
}
]
Mur des cas
Type de résultat | Valeur / Description | Type |
---|---|---|
Message de sortie* | Pour les entités trouvées : "Informations trouvées pour les entités suivantes : \n (entity.identifier)" Pour les entités introuvables : "Aucune information n'a été trouvée sur les entités suivantes : \n (entity.identifier)" Si aucune entité n'est trouvée : "Aucune information n'a été trouvée pour les entités fournies." Si tous les encodages sont incorrects : "Erreur lors de l'exécution de l'action "Recherche CSV par chaîne". Les encodages fournis ne sont pas valides. Veuillez vérifier l'orthographe." |
Général |
Ping
Description
Testez la connectivité.
Paramètres
N/A
Exécuter sur
Cette action s'exécute sur toutes les entités.
Résultats de l'action
Résultat du script
N/A
Résultat JSON
N/A
Connecteurs
Connecteur CSV
Description
Récupérer les données des fichiers CSV situés dans un dossier spécifique et les convertir en alertes dans le système Google SecOps.
Cette rubrique illustre le mécanisme et la configuration par lesquels Google SecOps produit des fichiers CSV, ainsi que les flux de travail et les actions compatibles effectués dans la plate-forme.
Cas d'utilisation
Un client dispose de fichiers CSV provenant d'un système, et ces fichiers peuvent être issus de différents encodages.
* Add support for comma-separated encodings in the Encoding field in the
connector.
* The connector should try the different encodings by their order in
the field (first encoding - highest priority, last - lowest
priority) with try/except. If no matching encoding was found -
consider the file as an error and notify.
* Put a default value for the fields - a list of most common CSV
encodings by priority (utf8, latin1, and iso...)
Accès aux fichiers CSV
Accès de Google SecOps aux fichiers CSV : configurez un dossier pour les fichiers CSV.
Transfert des enregistrements CSV vers Google SecOps
Travailler avec des enregistrements de fichiers CSV
Lorsque vous configurez Google SecOps pour qu'il fonctionne avec des fichiers CSV comme source d'alertes, vous êtes invité à fournir un dossier spécifique à partir duquel les fichiers CSV seront extraits. Les équipes Google SecOps récupèrent tous les enregistrements d'un fichier CSV et les transmettent pour qu'ils soient traduits et contextualisés sous forme d'alertes pour les demandes.
Mapper la gravité dans le connecteur
Pour mapper la gravité, vous devez spécifier le champ à utiliser pour obtenir la valeur de la gravité dans le paramètre "Nom du champ de gravité". La réponse peut contenir trois types de valeurs : des entiers, des nombres à virgule flottante et des chaînes. Pour les nombres entiers et à virgule flottante, aucune configuration supplémentaire n'est requise. Le connecteur lira ces valeurs et les mappera conformément aux normes Google SecOps. Pour rappel, voici comment les valeurs entières sont mises en correspondance :
- 100 – Critique
- 100 > x >= 80 : élevé
- 80 > x >=60 : moyenne
- 60 > x >=40 : faible
- 40 > x Informational
Si la réponse contient des chaînes, une configuration supplémentaire est requise. Dans le dossier où se trouvent les scripts du connecteur, vous trouverez un fichier de configuration nommé severity_map_config.json. Ce fichier définit les règles de mappage pour la gravité.
Au début, le fichier se présente comme suit : 1 2 3
{ "Default": 50 }
Imaginez une situation où les valeurs requises se trouvent dans event.severity. event.severity peut contenir les valeurs suivantes : "Malicious", "Benign" et "Unknown".
Tout d'abord, nous devons spécifier dans le paramètre "Nom du champ de gravité" que nous allons utiliser event.severity. Ensuite, nous devons mettre à jour le fichier de configuration. Après les modifications, le fichier severity_map_config.json devrait ressembler à ceci : 1 2 3 4 5 6 7 8
{
"event.severity": { "Malicious": 100, "Unknown": 60, "Benign": -1 }, "Default":
50 }
Désormais, lorsque le connecteur recevra un événement avec event.severity
= "Malicious", il lui attribuera le niveau de gravité "Critique".
Configurer le connecteur CSV dans Google SecOps
Pour obtenir des instructions détaillées sur la configuration d'un connecteur dans Google SecOps, consultez Configurer le connecteur.
Paramètres du connecteur
Utilisez les paramètres suivants pour configurer le connecteur :
Nom du paramètre | Type | Valeur par défaut | Obligatoire | Description |
---|---|---|---|---|
Nom du champ de produit | Chaîne | device_product | Oui | Nom du champ utilisé pour déterminer le produit de l'appareil. |
Nom du champ d'événement | Chaîne | nom | Non | Nom du champ utilisé pour déterminer le nom (sous-type) de l'événement. |
Délai avant expiration du script (en secondes) | Chaîne | 60 | Oui | Délai limite (en secondes) pour le processus Python exécutant le script actuel. |
Chemin d'accès au dossier CSV | Chaîne | N/A | Oui | Chemin d'accès au dossier contenant tous les fichiers CSV à ingérer. |
Limite CSV | Chaîne | N/A | Non | Nombre de fichiers CSV à traiter par itération. |
Nom du champ du générateur de règles | Chaîne | N/A | Non | Nom du champ contenant des informations sur le générateur de règles. |
Nom du champ temporel | Chaîne | N/A | Non | Nom du champ contenant des informations sur l'heure de l'événement. |
Le fichier CSV comporte un en-tête | Case à cocher | Cochée | Oui | Indique si le fichier CSV comporte un en-tête. |
Type d'encodage de fichier | Chaîne | utf-8 | Oui | Définissez le type d'encodage CSV (par exemple, iso-8859-1, latin1, utf-8 ou utf-16). |
Nom du champ d'alerte | Chaîne | N/A | Non | Nom du champ contenant des informations sur le nom de l'alerte. |
Nom du champ de gravité | Chaîne | N/A | Non | Nom du champ contenant des informations sur la gravité. |
Règles du connecteur
Assistance de proxy
Le connecteur n'est pas compatible avec le proxy.
Vous avez encore besoin d'aide ? Obtenez des réponses de membres de la communauté et de professionnels Google SecOps.