From 72fd0faa310b97559d4be4dd1aafacd095f7b421 Mon Sep 17 00:00:00 2001 From: CharlesLR-sekoia Date: Fri, 27 Jun 2025 15:18:10 +0200 Subject: [PATCH 1/2] add_stix_to_xsiam_template --- playbooks/templates/playbooks.json | 221 +++++++++++++++----- playbooks/templates/push_iocs_to_xsiam.json | 77 +++++++ 2 files changed, 244 insertions(+), 54 deletions(-) create mode 100644 playbooks/templates/push_iocs_to_xsiam.json diff --git a/playbooks/templates/playbooks.json b/playbooks/templates/playbooks.json index 53a3df2..419686e 100644 --- a/playbooks/templates/playbooks.json +++ b/playbooks/templates/playbooks.json @@ -6,7 +6,7 @@ "alerts", "IOC Collection", "blocklist" - ], + ], "workspace": "Operation Center", "description": "Add the destination ip addresses from the events linked to the alert to an IOC collection" }, @@ -17,7 +17,7 @@ "alerts", "IOC Collection", "blocklist" - ], + ], "workspace": "Operation Center", "description": "Add the source ip addresses from the events linked to the alert to an IOC collection" }, @@ -31,7 +31,7 @@ ], "workspace": "Operation Center", "description": "Add the domains from the events linked to the alert to an IOC collection" - }, + }, { "file": "create_jira_ticket_on_alert.json", "name": "Jira ticket on alert", @@ -41,7 +41,9 @@ "Jira" ], "description": "Create Jira ticket when new alerts are created.", - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "msteams_notification.json", @@ -52,7 +54,9 @@ "MS Teams" ], "description": "Notify by Microsoft Teams when new alerts are created.", - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "URL_scan_VirusTotal_Enrichement.json", @@ -62,7 +66,9 @@ "alerts", "enrichement" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "HTTP_request_Remediation.json", @@ -72,7 +78,9 @@ "alerts", "webhook" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "email_notification_on_alert_webhook.json", @@ -83,7 +91,9 @@ "notifications", "webhook" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "mattermost_notification_on_alert.json", @@ -93,7 +103,9 @@ "alerts", "notifications" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "alert_webhook_internet_scan.json", @@ -103,7 +115,9 @@ "alerts", "webhook" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "playbook_adware.json", @@ -112,7 +126,9 @@ "tags": [ "alerts" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "urgency_to_0_on_rejected.json", @@ -121,7 +137,9 @@ "tags": [ "alerts" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "VirusTotal_Enrichement.json", @@ -131,14 +149,21 @@ "alerts", "enrichment" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "Enrich_alerts_with_VirusTotal_Hash.json", "name": "Scan for hash on VirusTotal", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Enrich to check if this file.hash.sha1 is known from VirusTotal, directly from SEKOIA.IO.", - "tags": ["alerts", "enrichement"] + "tags": [ + "alerts", + "enrichement" + ] }, { "file": "Reject_old_alerts.json", @@ -148,7 +173,9 @@ "alerts", "cron" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "Enrich_with_IKnow_What_You_Download.json", @@ -159,7 +186,9 @@ "webhook", "enrichment" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "Enrich_alerts_with_hostnames.json", @@ -169,23 +198,29 @@ "alerts", "enrichment" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "Shodan_search_to_observables.json", "name": "Shodan search to observables", - "workspace": ["Intelligence Center"], + "workspace": [ + "Intelligence Center" + ], "description": "Get IP addresses from a shodan search and add it to Observable data base with a tag", "tags": [ - "observable", - "shodan", - "TIP" + "observable", + "shodan", + "TIP" ] }, { "file": "OSINT_to_observables.json", "name": "Generic Fetch OSINT to observable", - "workspace": ["Intelligence Center"], + "workspace": [ + "Intelligence Center" + ], "description": "Retrieve observables from an OSINT to add it to observable database with a tag (eg: https://github.com/MISP/misp-warninglists/tree/main/lists)", "tags": [ "observable", @@ -196,25 +231,37 @@ { "file": "create_alert_on_the_hive_automatic.json", "name": "Automatically create an alert on TheHive", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Automatically create an alert on TheHive when a new alert is raised in SEKOIA.IO.", - "tags": ["alerts", "thehive"] + "tags": [ + "alerts", + "thehive" + ] }, { "file": "create_alert_on_the_hive_manual.json", "name": "Manually create an Alert on TheHive", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Create an alert on TheHive via the alert page.", - "tags": ["alerts", "thehive"] + "tags": [ + "alerts", + "thehive" + ] }, { "file": "DigitalShadows_SearchLight_fetch_alerts.json", "name": "Fetch alerts from Digital Shadows SearchLight", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Synchronise alerts from Digital Shadows SearchLight to SEKOIA.IO events", "tags": [ - "alerts", - "osint" + "alerts", + "osint" ] }, { @@ -231,48 +278,73 @@ { "file": "imperva_waf_fetch_logs.json", "name": "Imperva WAF fetch logs", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Fetch events from Imperva Web Application Firewall and forward them to SEKOIA.IO intake", - "tags": ["events"] + "tags": [ + "events" + ] }, { "file": "forward_vadesecure_records.json", "name": "Forward Vade M365 email Events to SEKOIA.IO", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "This playbook collect logs from 'Vade for M365' then push them to SEKOIA.IO", - "tags": ["events"] + "tags": [ + "events" + ] }, { "file": "Tranco_top_domains_to_observables.json", "name": "Tranco top domains to observables", - "workspace": ["Intelligence Center"], + "workspace": [ + "Intelligence Center" + ], "tags": [ "observables", "tranco", "TIP" - ], - "description": "Automatically import Tranco's top 1 000 000 domain names to observable database" + ], + "description": "Automatically import Tranco's top 1 000 000 domain names to observable database" }, { "file": "forward_google_pubsub_events.json", "name": "Forward Google Pubsub records to SEKOIA.IO", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "This playbook consumes records from Google Pubsub and push them to SEKOIA.IO", - "tags": ["google", "events"] + "tags": [ + "google", + "events" + ] }, { "file": "Enrich_alerts_with_AbuseIPDB.json", "name": "Enrich alerts with AbuseIPDB", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Enrich with AbuseIPDB to check if the IP is known from this service, directly from SEKOIA.IO.", - "tags": ["alerts", "enrichment"] + "tags": [ + "alerts", + "enrichment" + ] }, { "file": "Alerts_Shodan_Enrichment.json", "name": "Enrich with Shodan", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Enrich with Shodan to check if the IP is known from this service, directly from SEKOIA.IO.", - "tags": ["alerts", "enrichment"] + "tags": [ + "alerts", + "enrichment" + ] }, { "file": "slack_notification_on_alert.json", @@ -282,14 +354,24 @@ "alerts", "notifications" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "get_data_and_enrich_with_cloudflare.json", "name": "Get data from OSINT and enrich DNS names with cloudflare DNS over HTTPs API", "description": "Playbook to get data from OSINT and enrich it with CloudFlare DNS over HTTPs API. The playbook then upload observables to database.\n\nPlease configure 'Fetch Osint' node and 'Get domains from Fetch OSINT' jpath to get domains.", - "tags": ["observable", "cloudflare", "fetch osint", "enrich","TIP"], - "workspace": ["Intelligence Center"] + "tags": [ + "observable", + "cloudflare", + "fetch osint", + "enrich", + "TIP" + ], + "workspace": [ + "Intelligence Center" + ] }, { "file": "CrowdSec_alert_enrichment.json", @@ -300,7 +382,9 @@ "alerts", "enrichment" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "Crowdstrike_dissemination.json", @@ -310,7 +394,10 @@ "CrowdStrike", "Dissemination" ], - "workspace": ["Operation Center", "Intelligence Center"] + "workspace": [ + "Operation Center", + "Intelligence Center" + ] }, { "file": "create_incident_on_cortex_xsoar.json", @@ -320,20 +407,46 @@ "alerts", "XSOAR" ], - "workspace": ["Operation Center"] + "workspace": [ + "Operation Center" + ] }, { "file": "send_alert_to_nybble_hub.json", "name": "Automatically send an alert to Nybble Hub", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Automatically send an alert to Nybble Hub when a new alert is raised in SEKOIA.IO.", - "tags": ["alerts", "nybble"] + "tags": [ + "alerts", + "nybble" + ] }, { "file": "get_additional_harfang_telemetry.json", "name": "HarfangLab telemetry events", - "workspace": ["Operation Center"], + "workspace": [ + "Operation Center" + ], "description": "Retrieve additional telemetry when an HarfangLab alert is raised", - "tags": ["alerts", "enrich", "events"] + "tags": [ + "alerts", + "enrich", + "events" + ] + }, + { + "file": "push_iocs_to_xsiam.json", + "name": "Push Sekoia.io IOCs to Palo Alto XSIAM Collection", + "workspace": [ + "Intelligence Center" + ], + "tags": [ + "observables", + "XSIAM", + "Dissemination" + ], + "description": "Add Sekoia active IOCs in Palo Alto XSIAM Collection for detection" } -] +] \ No newline at end of file diff --git a/playbooks/templates/push_iocs_to_xsiam.json b/playbooks/templates/push_iocs_to_xsiam.json new file mode 100644 index 0000000..6858b92 --- /dev/null +++ b/playbooks/templates/push_iocs_to_xsiam.json @@ -0,0 +1,77 @@ +{ + "name": "Push Sekoia.io IOCs to Palo Alto XSIAM Collection", + "nodes": { + "0": { + "icon": "", + "name": "Feed Consumption", + "type": "trigger", + "outputs": { + "default": [ + "1" + ] + }, + "position": { + "x": -520, + "y": -150 + }, + "module_uuid": "92d8bb47-7c51-445d-81de-ae04edbb6f0a", + "trigger_uuid": "ac6100ed-3fb7-4355-83ac-049c14aa44fd" + }, + "1": { + "icon": "", + "name": "Transform Sekoia STIX to XSIAM", + "type": "action", + "outputs": { + "default": [ + "2" + ] + }, + "position": { + "x": -518, + "y": 28 + }, + "arguments": { + "comment": "Valid from {valid_from} AND STIX Pattern: {pattern}", + "class_override": "{id}", + "stix_objects_path": "{{ node.0.stix_objects_path }}" + }, + "action_uuid": "68a6bdfa-e0bc-46c6-9580-76a2b44163b0", + "module_uuid": "537e1880-5b6c-4b46-ae6c-f228cfc6c6e4" + }, + "2": { + "icon": "", + "name": "Send batch to XSIAM", + "type": "action", + "outputs": { + "default": [] + }, + "position": { + "x": -516, + "y": 220 + }, + "arguments": { + "url": "https://api-xxxxxxxxxxxxyourfqdn/public_api/v1/indicators/insert_jsons", + "json": "{\n \"request_data\": {{ node.1.data }},\n \"validate\": True\n}", + "method": "post", + "headers": { + "Accept": "application/json", + "Content-Type": "application/json", + "Authorization": "REDACTED_TO_REPLACED_WITH_API_KEY", + "x-xdr-auth-id": "REPLACE_WITH_API_ID" + }, + "verify_ssl": false, + "fail_on_http_error": true + }, + "action_uuid": "40bcf3c0-aa8b-4111-9b4e-f3caffccb4e5", + "module_uuid": "5894985f-91eb-46db-9306-cc5ac6463d3d" + } + }, + "description": "Add Sekoia active IOCs in Palo Alto XSIAM Collection for detection", + "workspace": "Operation Center", + "tags": [ + "observables", + "XSIAM", + "Dissemination" + ], + "uuid": "7b81c7f7-7c9a-4882-ac26-5cb35446e1a0" +} \ No newline at end of file From 6bbf9e540df77f91defaaf2489beff7a6abe6843 Mon Sep 17 00:00:00 2001 From: Charles LE REUN <77982369+CharlesLR-sekoia@users.noreply.github.com> Date: Fri, 27 Jun 2025 15:58:19 +0200 Subject: [PATCH 2/2] typo fixing --- playbooks/templates/push_iocs_to_xsiam.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/playbooks/templates/push_iocs_to_xsiam.json b/playbooks/templates/push_iocs_to_xsiam.json index 6858b92..82a48cd 100644 --- a/playbooks/templates/push_iocs_to_xsiam.json +++ b/playbooks/templates/push_iocs_to_xsiam.json @@ -56,7 +56,7 @@ "headers": { "Accept": "application/json", "Content-Type": "application/json", - "Authorization": "REDACTED_TO_REPLACED_WITH_API_KEY", + "Authorization": "REPLACE_WITH_API_KEY", "x-xdr-auth-id": "REPLACE_WITH_API_ID" }, "verify_ssl": false, @@ -74,4 +74,4 @@ "Dissemination" ], "uuid": "7b81c7f7-7c9a-4882-ac26-5cb35446e1a0" -} \ No newline at end of file +}