Collect Sophos DHCP logs

Supported in:

This document explains how to ingest Sophos DHCP logs to Google Security Operations using Bindplane.

The parser extracts fields from Sophos DHCP syslog formatted logs using grok and/or kv. It maps these values to the Unified Data Model (UDM) and sets default metadata values for the event source and type.

Before you begin

Make sure you have the following prerequisites:

  • A Google SecOps instance.
  • A Windows 2016 or later or Linux host with systemd.
  • Network connectivity: If running behind a proxy, ensure firewall ports are open per the Bindplane agent requirements.
  • Privileged access to the Sophos Firewall/UTM administrator UI.

Get Google SecOps ingestion authentication file

  1. Sign in to the Google SecOps console.
  2. Go to SIEM Settings > Collection Agent.
  3. Download the Ingestion Authentication File.
    • Save the file securely on the system where Bindplane will be installed.

Get Google SecOps customer ID

  1. Sign in to the Google SecOps console.
  2. Go to SIEM Settings > Profile.
  3. Copy and save the Customer ID from the Organization Details section.

Install the Bindplane agent

Install the Bindplane agent on your Windows or Linux operating system according to the following instructions.

Windows installation

  1. Open the Command Prompt or PowerShell as an administrator.
  2. Run the following command:

    msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
    

Linux installation

  1. Open a terminal with root or sudo privileges.
  2. 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 this installation guide.

Configure the Bindplane agent to ingest Syslog and send to Google SecOps

  1. Access the Configuration File:

    • Locate the config.yaml file. Typically, it's in the /opt/observiq-otel-collector directory on Linux or in the installation directory on Windows.
    • Open the file using a text editor (for example, nano, vi, or Notepad).
  2. Edit the config.yaml file 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_file_path: '/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
        log_type: 'SOPHOS_DHCP'
        raw_log_field: body
        ingestion_labels:
    
    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 your actual Customer ID.
  • Update /path/to/ingestion-authentication-file.json to the file path where the authentication file was saved in Step 1.

Restart the Bindplane agent to apply the changes

  1. To restart the Bindplane agent in Linux, run the following command:

    /opt/observiq-otel-collector/config.yaml
    
  2. 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 forwarding on Sophos DHCP

  1. Sign in to the Sophos Firewall/UTM admin UI with administrator privileges.
  2. Navigate to the syslog settings:
    • Sophos Firewall: System services > Log settings.
    • Sophos UTM: Logging & Reporting > Log Settings > Remote Syslog Server.
  3. Click Add under Syslog servers and provide the following details:
    • Name: A descriptive name (e.g., GoogleSecOps-BindPlane).
    • IP address/Domain: The IP address of the Bindplane Agent host.
    • Port: The Bindplane Agent port (e.g., 514).
    • Facility: DAEMON.
    • Severity level: Information (adjust per your internal policy).
    • Format: Device standard format (key=value) to align with SYSLOG + KV.
  4. Click Save/Apply to start forwarding DHCP-related logs.

UDM mapping table

Log Field UDM Mapping Logic
msg metadata.description Directly mapped
sub metadata.description Directly mapped
log_date metadata.event_timestamp Parsed as yyyy:MM:dd-HH:mm:ss
log_date_inner metadata.event_timestamp Parsed as MMM dd HH:mm:ss
event_type metadata.event_type Directly mapped
msg metadata.event_type Mapped: call=newGENERIC_EVENT
process_type metadata.event_type Mapped: "confd","ulogd"GENERIC_EVENT, dhcpdGENERIC_EVENT, dhcpd → `NETWORK_D...
id metadata.product_event_type Directly mapped
process_type metadata.product_event_type Directly mapped
msg metadata.product_name Mapped: call=newSOPHOS_DHCP
process_type metadata.product_name Mapped: "confd","ulogd"SOPHOS_DHCP
msg metadata.vendor_name Mapped: call=newSOPHOS
process_type metadata.vendor_name Mapped: "confd","ulogd"SOPHOS
process_type network.application_protocol Mapped: dhcpdDHCP
src_mac network.dhcp.chaddr Directly mapped
src_ip network.dhcp.ciaddr Directly mapped
src_host network.dhcp.client_hostname Directly mapped
dhcp_type network.dhcp.opcode Mapped: DHCPREQUESTBOOTREQUEST, DHCPACKBOOTREPLY, DHCPOFFERBOOTREPLY, `...
process_type network.dhcp.opcode Mapped: dhcpdBOOTREQUEST, dhcpdBOOTREPLY
dhcp_type network.dhcp.type Mapped: DHCPREQUESTREQUEST, DHCPACKACK, DHCPOFFEROFFER, DHCPNAKNAK
process_type network.dhcp.type Mapped: dhcpdREQUEST, dhcpdACK, dhcpdOFFER, dhcpdNAK
src_ip network.dhcp.yiaddr Directly mapped
ip_protocol_out network.ip_protocol Directly mapped
src_host observer.hostname Directly mapped
dhcp_type observer.ip Mapped: DHCPREQUESTsrc_ip
process_type observer.ip Mapped: dhcpdsrc_ip
src_ip observer.ip Merged
client principal.hostname Directly mapped
src_host principal.hostname Directly mapped
dhcp_type principal.ip Mapped: DHCPREQUESTsrc_ip, DHCPNAKsrc_ip
ip principal.ip Merged
msg principal.ip Mapped: call=newsrcip
oldattr_address principal.ip Merged
process_type principal.ip Mapped: "confd","ulogd"srcip, "confd","ulogd"oldattr_address, `"confd","ulogd"...
src_ip principal.ip Merged
srcip principal.ip Merged
dhcp_type principal.mac Mapped: DHCPREQUESTsrc_mac, DHCPNAKsrc_mac
process_type principal.mac Mapped: "confd","ulogd"srcmac, dhcpdsrc_mac
src_mac principal.mac Merged
srcmac principal.mac Merged
srcport principal.port Directly mapped
pid principal.process.pid Directly mapped
objname principal.resource.name Directly mapped
user principal.user.userid Directly mapped
msg security_result Mapped: call=newsec_result
process_type security_result Mapped: "confd","ulogd"sec_result, "confd","ulogd"security_result
sec_result security_result Merged
initf_label security_result.about.labels Merged
outitf_label security_result.about.labels Merged
process_type security_result.about.labels Mapped: "confd","ulogd"initf_label, "confd","ulogd"outitf_label, `"confd","ulo...
sid_label security_result.about.labels Merged
tcpflags_label security_result.about.labels Merged
action security_result.action_details Directly mapped
action security_result.category Mapped: portscancategory
category security_result.category Merged
process_type security_result.category Mapped: "confd","ulogd"category
info security_result.description Directly mapped
name security_result.description Directly mapped
fwrule security_result.rule_id Directly mapped
process_type security_result.severity Mapped: "confd","ulogd"INFORMATIONAL, "confd","ulogd"MEDIUM
severity security_result.severity Mapped: "info","debug"INFORMATIONAL, warnMEDIUM
call security_result.summary Directly mapped
attr_address target.ip Merged
dstip target.ip Merged
ip target.ip Merged
process_type target.ip Mapped: "confd","ulogd"dstip, "confd","ulogd"attr_address, "confd","ulogd" →...
dstmac target.mac Merged
process_type target.mac Mapped: "confd","ulogd"dstmac
dstport target.port Directly mapped
N/A metadata.event_type Constant: GENERIC_EVENT
N/A metadata.product_name Constant: SOPHOS_DHCP
N/A metadata.vendor_name Constant: SOPHOS
N/A network.application_protocol Constant: DHCP
N/A network.dhcp.opcode Constant: BOOTREQUEST
N/A network.dhcp.type Constant: REQUEST
N/A security_result.severity Constant: INFORMATIONAL

Need more help? Get answers from Community members and Google SecOps professionals.