Collect Check Point EDR logs
This document explains how to ingest Check Point Antivirus logs to Google Security Operations using Bindplane. The parser handles logs from Check Point SandBlast, converting both SYSLOG + KV and SYSLOG + CEF formatted logs into the Unified Data Model (UDM). The parser extracts fields from CEF messages using included modules and maps them to UDM fields, handling various event types and enriching the data with additional context from the raw logs. For non-CEF messages, the parser uses key-value extraction, grok patterns, and conditional logic to map relevant fields to the EDR UDM schema.
Before you begin
Make sure you have the following prerequisites:
- Google SecOps instance
- Windows 2016 or later, or a Linux host with systemd
- If running behind a proxy, firewall ports are open
- Privileged access to Check Point Appliance with SandBlast
Get Google SecOps ingestion authentication file
- Sign in to the Google SecOps console.
- Go to SIEM Settings > Collection Agents.
- Download the Ingestion Authentication File. Save the file securely on the system where Bindplane will be installed.
Get Google SecOps customer ID
- Sign in to the Google SecOps console.
- Go to SIEM Settings > Profile.
- Copy and save the Customer ID from the Organization Details section.
Install the Bindplane agent
Windows installation
- Open the Command Prompt or PowerShell as an administrator.
- Run the following command: - msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
Linux installation
- Open a terminal with root or sudo privileges.
- Run the following command: - sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
Additional installation resources
For additional installation options, consult the installation guide.
Configure the Bindplane agent to ingest Syslog and send to Google SecOps
- Access the configuration file:
- Locate the config.yamlfile. Typically, it's in the/etc/bindplane-agent/directory on Linux or in the installation directory on Windows.
- Open the file using a text editor (for example, nano,vi, or Notepad).
 
- Locate the 
- Edit the - config.yamlfile as follows:- receivers: udplog: # Replace the port and IP address as required listen_address: "0.0.0.0:514" 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: 'CHECKPOINT_EDR' raw_log_field: body service: pipelines: logs/source0__chronicle_w_labels-0: receivers: - udplog exporters: - chronicle/chronicle_w_labels
- Replace the port and IP address as required in your infrastructure. 
- Replace - <customer_id>with the actual customer ID.
- Update - /path/to/ingestion-authentication-file.jsonto the path where the authentication file was saved in the Get Google SecOps ingestion authentication file section.
Restart the BindPlane agent to apply the changes
- To restart the Bindplane agent in Linux, run the following command: - sudo systemctl restart bindplane-agent
- To restart the Bindplane agent in Windows, you can either use the Services console or enter the following command: - net stop BindPlaneAgent && net start BindPlaneAgent
Configure Syslog in Checkpoint 1500 Appliance Series
- Sign in to the Checkpoint Appliance.
- Go to Logs & Monitoring > Log Servers > Syslog Servers.
- Click Configure.
- Provide the following configuration details:
- Protocol: Select UDP.
- Name: Enter a descriptive name.
- IP Address: Enter the Bindplane agent IP address.
- Port: Enter the Bindplane agent port number.
- Select Enable log server.
- Select logs to forward: Both system and security logs.
 
- Click Apply.
UDM mapping table
| Log Field | UDM Mapping | Logic | 
|---|---|---|
| action | event.idm.read_only_udm.security_result.action | Directly mapped from the actionCEF field. | 
| action_comment | event.idm.read_only_udm.additional.fields[<N>].key:action_commentevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofaction_comment | Directly mapped from the action_commentfield. | 
| action_details | event.idm.read_only_udm.security_result.action_details | Directly mapped from the action_detailsCEF field. | 
| additional_info | event.idm.read_only_udm.additional.fields[<N>].key:additional_infoevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofadditional_info | Directly mapped from the additional_infofield. | 
| am_update_proxy | event.idm.read_only_udm.intermediary.domain.name | Directly mapped from the am_update_proxyfield. | 
| am_update_source | event.idm.read_only_udm.target.url | Directly mapped from the am_update_sourcefield. | 
| client_version | event.idm.read_only_udm.metadata.product_version | Directly mapped from the client_versionfield. | 
| cn1 | event.idm.read_only_udm.security_result.severity | Mapped from the cn1CEF field and converted to UDM severity values (CRITICAL, HIGH, MEDIUM, LOW, INFO). | 
| cs1 | event.idm.read_only_udm.additional.fields[<N>].key:Connectivity Stateevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofcs1 | Directly mapped from the cs1field. | 
| description | event.idm.read_only_udm.metadata.description | Directly mapped from the descriptionCEF field. | 
| deviceDirection | event.idm.read_only_udm.network.direction | Mapped from the deviceDirectionfield. A value of0is mapped toINBOUND, other values are not mapped. | 
| deviceFacility | event.idm.read_only_udm.additional.fields[<N>].key:deviceFacilityevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofdeviceFacility | Directly mapped from the deviceFacilityfield. | 
| dst | event.idm.read_only_udm.network.target.ip | Directly mapped from the dstfield whenevent_typeisFirewall. | 
| engine_ver | event.idm.read_only_udm.additional.fields[<N>].key:engine_verevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofengine_ver | Directly mapped from the engine_verfield. | 
| ep_rule_id | event.idm.read_only_udm.firewall.firewall_rule_id | Directly mapped from the ep_rule_idfield whenevent_typeisFirewall. | 
| event_type | event.idm.read_only_udm.metadata.product_event_type | Directly mapped from the event_typeCEF field. | 
| failed_updates | event.idm.read_only_udm.additional.fields[<N>].key:failed_updatesevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value offailed_updates | Directly mapped from the failed_updatesfield. | 
| file_md5 | event.idm.read_only_udm.source_file.hash_md5 | Directly mapped from the file_md5field whenevent_typeisTE Event. | 
| file_name | event.idm.read_only_udm.source_file.file_name | Directly mapped from the file_namefield whenevent_typeisTE Event. | 
| file_sha1 | event.idm.read_only_udm.source_file.hash_sha1 | Directly mapped from the file_sha1field whenevent_typeisTE Event. | 
| file_sha256 | event.idm.read_only_udm.source_file.hash_sha256 | Directly mapped from the file_sha256field whenevent_typeisTE Event. | 
| host_type | event.idm.read_only_udm.principal.asset.type | Mapped from the host_typefield.Desktopis converted toWORKSTATION, then the value is uppercased. | 
| ifdir | event.idm.read_only_udm.network.direction | Directly mapped from the ifdirfield and uppercased whenevent_typeisFirewall. | 
| installed_products | event.idm.read_only_udm.principal.asset.software.name | Directly mapped from the installed_productsfield. | 
| is_scanned | sec_res.detection_fields[<N>].key:is_scannedsec_res.detection_fields[<N>].value: Value ofis_scanned | Directly mapped from the is_scannedfield. | 
| local_time | event.idm.read_only_udm.additional.fields[<N>].key:local_timeevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value oflocal_time | Directly mapped from the local_timefield. | 
| log_type | event.idm.read_only_udm.metadata.log_type | Directly mapped from the log_typefield. | 
| loguid | event.idm.read_only_udm.metadata.product_log_id | Directly mapped from the loguidfield. | 
| machine_guid | event.idm.read_only_udm.principal.asset.product_object_id | Directly mapped from the machine_guidfield. | 
| media_authorized | event.idm.read_only_udm.additional.fields[<N>].key:media_authorizedevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofmedia_authorized | Directly mapped from the media_authorizedfield. | 
| media_class_id | event.idm.read_only_udm.additional.fields[<N>].key:media_class_idevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofmedia_class_id | Directly mapped from the media_class_idfield. | 
| media_description | event.idm.read_only_udm.additional.fields[<N>].key:media_descriptionevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofmedia_description | Directly mapped from the media_descriptionfield. | 
| media_encrypted | event.idm.read_only_udm.additional.fields[<N>].key:media_encryptedevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofmedia_encrypted | Directly mapped from the media_encryptedfield. | 
| media_manufacturer | event.idm.read_only_udm.additional.fields[<N>].key:media_manufacturerevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofmedia_manufacturer | Directly mapped from the media_manufacturerfield. | 
| media_type | event.idm.read_only_udm.additional.fields[<N>].key:media_typeevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofmedia_type | Directly mapped from the media_typefield. | 
| msg | event.idm.read_only_udm.metadata.description | Directly mapped from the msgCEF field. | 
| origin | event.idm.read_only_udm.about.ip | Directly mapped from the originCEF field. | 
| os_name | event.idm.read_only_udm.additional.fields[<N>].key:os_nameevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofos_name | Directly mapped from the os_namefield. | 
| os_version | event.idm.read_only_udm.principal.asset.platform_software.platform_version | Directly mapped from the os_versionfield. | 
| policy_date | event.idm.read_only_udm.additional.fields[<N>].key:policy_dateevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofpolicy_date | Directly mapped from the policy_datefield. | 
| policy_guid | event.idm.read_only_udm.principal.resource.product_object_id | Directly mapped from the policy_guidfield. | 
| policy_name | event.idm.read_only_udm.principal.resource.name | Directly mapped from the policy_namefield. | 
| policy_number | event.idm.read_only_udm.principal.resource.product_object_id | Directly mapped from the policy_numberfield. | 
| policy_type | event.idm.read_only_udm.additional.fields[<N>].key:policy_typeevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofpolicy_type | Directly mapped from the policy_typefield. | 
| policy_version | event.idm.read_only_udm.additional.fields[<N>].key:policy_versionevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofpolicy_version | Directly mapped from the policy_versionfield. | 
| product | event.idm.read_only_udm.metadata.product_name | Directly mapped from the productCEF field. | 
| proto | event.idm.read_only_udm.network.protocol | Directly mapped from the protofield whenevent_typeisFirewall. | 
| reading_data_access | event.idm.read_only_udm.additional.fields[<N>].key:reading_data_accessevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofreading_data_access | Directly mapped from the reading_data_accessfield. | 
| requestClientApplication | event.idm.read_only_udm.network.http.user_agent | Directly mapped from the requestClientApplicationfield. | 
| result | event.idm.read_only_udm.security_result.summary | Directly mapped from the resultfield. | 
| rt | event.idm.read_only_udm.metadata.event_timestamp.seconds | Mapped from the rtfield, divided by 1000, and the integer part is taken as seconds. | 
| rule_name | event.idm.read_only_udm.firewall.firewall_rule | Directly mapped from the rule_namefield whenevent_typeisFirewall. | 
| s_port | event.idm.read_only_udm.network.client.port | Directly mapped from the s_portfield whenevent_typeisFirewall. | 
| sequencenum | event.idm.read_only_udm.additional.fields[<N>].key:sequencenumevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofsequencenum | Directly mapped from the sequencenumfield. | 
| service | event.idm.read_only_udm.network.target.port | Directly mapped from the servicefield whenevent_typeisFirewall. | 
| severity | event.idm.read_only_udm.security_result.severity | Mapped from the severityfield and converted to UDM severity values (CRITICAL, HIGH, MEDIUM, LOW, INFO). | 
| shost | event.idm.read_only_udm.principal.hostname | Directly mapped from the shostCEF field. | 
| sig_ver | event.idm.read_only_udm.additional.fields[<N>].key:sig_verevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofsig_ver | Directly mapped from the sig_verfield. | 
| src | event.idm.read_only_udm.principal.ip | Directly mapped from the srcCEF field. | 
| src_machine_name | event.idm.read_only_udm.principal.hostname | Directly mapped from the src_machine_namefield whenevent_typeis empty. | 
| subject | event.idm.read_only_udm.task.task_name | Directly mapped from the subjectfield whenevent_typeis empty. | 
| suser | event.idm.read_only_udm.principal.user.user_display_name | Directly mapped from the suserCEF field. | 
| time | event.idm.read_only_udm.metadata.event_timestamp.seconds | Directly mapped from the timefield and converted to Unix epoch seconds. | 
| user_name | event.idm.read_only_udm.principal.user.email_addresses | Directly mapped from the user_nameCEF field. | 
| user_sid | event.idm.read_only_udm.principal.user.windows_sid | Directly mapped from the user_sidfield. | 
| version | event.idm.read_only_udm.additional.fields[<N>].key:versionevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofversion | Directly mapped from the versionfield. | 
| writing_data_access | event.idm.read_only_udm.additional.fields[<N>].key:writing_data_accessevent.idm.read_only_udm.additional.fields[<N>].value.string_value: Value ofwriting_data_access | Directly mapped from the writing_data_accessfield. | 
| N/A | event.idm.read_only_udm.metadata.event_type | Set to GENERIC_EVENTif none ofprincipal.ip,principal.hostname, orprincipal.macare present in the raw log, otherwise set toSTATUS_UPDATE. | 
| N/A | event.idm.read_only_udm.metadata.vendor_name | Constant value: Check Point. | 
| N/A | event.idm.read_only_udm.metadata.log_type | Constant value: CHECKPOINT_EDR. | 
| N/A | event.idm.read_only_udm.principal.asset.platform_software.platform | Set to WINDOWSifos_namecontainsWINDOWSorWindows. | 
| N/A | event.idm.read_only_udm.network.http.user_agent | Set to Check Point Endpoint Security ClientifrequestClientApplicationis present. | 
| N/A | event.edr.data_source | Constant value: CHECKPOINT_SANDBLASTwhenmessagedoesn't containCEF. | 
Need more help? Get answers from Community members and Google SecOps professionals.