Recolha registos CEF do ArcSight
Este documento explica como carregar registos CEF (Common Event Format) do ArcSight para o Google Security Operations através do Bindplane. O analisador transforma os dados não processados num formato de modelo de dados unificado (UDM) estruturado. Extrai campos do cabeçalho e das extensões do CEF, mapeia-os para campos do UDM e executa uma lógica específica para categorizar eventos como inícios de sessão de utilizadores, ligações de rede e acessos a recursos com base nas informações extraídas.
Antes de começar
Certifique-se de que tem os seguintes pré-requisitos:
- Instância do Google SecOps
- Um anfitrião Windows 2016 ou posterior, ou um anfitrião Linux com
systemd - Se estiver a ser executado através de um proxy, as portas da firewall estão abertas
- ArcSight SmartConnector 8.4 (ou posterior) instalado num anfitrião com acesso à rede do agente Bindplane
- Acesso privilegiado ao portal da OpenText
Obtenha o ficheiro de autenticação de carregamento do Google SecOps
- Inicie sessão na consola Google SecOps.
- Aceda a Definições do SIEM > Agentes de recolha.
- Transfira o ficheiro de autenticação de carregamento. Guarde o ficheiro de forma segura no sistema onde o Bindplane vai ser instalado.
Obtenha o ID de cliente do Google SecOps
- Inicie sessão na consola Google SecOps.
- Aceda a Definições do SIEM > Perfil.
- Copie e guarde o ID do cliente da secção Detalhes da organização.
Instale o agente do Bindplane
Instale o agente do Bindplane no seu sistema operativo Windows ou Linux de acordo com as seguintes instruções.
Instalação do Windows
- Abra a Linha de comandos ou o PowerShell como administrador.
Execute o seguinte comando:
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
Instalação do Linux
- Abra um terminal com privilégios de raiz ou sudo.
Execute o seguinte comando:
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
Recursos de instalação adicionais
Para ver opções de instalação adicionais, consulte o guia de instalação.
Configure o agente Bindplane para carregar o Syslog e enviá-lo para o Google SecOps
- Aceda ao ficheiro de configuração:
- Localize o ficheiro
config.yaml. Normalmente, encontra-se no diretório/etc/bindplane-agent/no Linux ou no diretório de instalação no Windows. - Abra o ficheiro com um editor de texto (por exemplo,
nano,viou Bloco de notas).
- Localize o ficheiro
Edite o ficheiro
config.yamlda seguinte forma: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: 'ARCSIGHT_CEF' raw_log_field: body ingestion_labels: service: pipelines: logs/source0__chronicle_w_labels-0: receivers: - udplog exporters: - chronicle/chronicle_w_labels- Substitua a porta e o endereço IP conforme necessário na sua infraestrutura.
- Substitua
<customer_id>pelo ID de cliente real. - Atualize
/path/to/ingestion-authentication-file.jsonpara o caminho onde o ficheiro de autenticação foi guardado na secção Obtenha o ficheiro de autenticação de carregamento do Google SecOps.
Reinicie o agente do Bindplane para aplicar as alterações
Para reiniciar o agente do Bindplane no Linux, execute o seguinte comando:
sudo systemctl restart bindplane-agentPara reiniciar o agente Bindplane no Windows, pode usar a consola Serviços ou introduzir o seguinte comando:
net stop BindPlaneAgent && net start BindPlaneAgent
Transfira o ArcSight SmartConnector
- Inicie sessão no portal de apoio técnico da OpenText.
- Encontre e transfira o ArcSight SmartConnector mais recente para Linux.
- Nome do ficheiro de exemplo:
ArcSight-Connector-Linux64-8.4.0.8499.0.bin.
Instale o ArcSight SmartConnector
Carregue o ficheiro
.binpara o servidor do SmartConnector:scp ArcSight-Connector-Linux64-8.4.0.8499.0.bin user@your-smartconnector-host:/tmpInicie sessão no servidor SmartConnector através de SSH e execute o seguinte comando:
cd /tmp chmod +x ArcSight-Connector-Linux64-8.4.0.8499.0.bin ./ArcSight-Connector-Linux64-8.4.0.8499.0.binSiga o instalador interativo:
- Selecione o diretório de instalação (por exemplo,
/opt/arcsight/connectors/current). - Aceite a licença.
- Selecione Instalar conetor quando lhe for pedido.
- Selecione o diretório de instalação (por exemplo,
Configure o ArcSight SmartConnector para enviar CEF para o Syslog
No anfitrião do SmartConnector, inicie o assistente de destino:
cd /opt/arcsight/connectors/current/bin ./arcsight connectorsNo assistente, faça o seguinte:
- Selecione Adicionar destino.
- Selecione CEF Syslog.
Faculte os seguintes detalhes de configuração:
- Anfitrião/IP: introduza o endereço IP do agente do Bindplane.
- Porta: introduza o número da porta do agente do Bindplane.
- Protocolo: selecione UDP.
Conclua a configuração e reinicie o conetor:
./arcsight agentsExecute uma verificação da conetividade (por exemplo, procure:
Successfully connected to syslog: X.X.X.X:514).tail -f /opt/arcsight/connectors/current/logs/agent.log
Tabela de mapeamento do UDM
| Campo de registo | Mapeamento do UDM | Lógica |
|---|---|---|
| agir | security_result.action_details | Mapeado diretamente a partir do campo act. |
| agt | principal.ip | Mapeado diretamente a partir do campo agt. |
| agt | principal.asset.ip | Mapeado diretamente a partir do campo agt. |
| app | network.application_protocol | Mapeado diretamente a partir do campo app. |
| arte | metadata.event_timestamp.seconds | Mapeado diretamente a partir do campo art. |
| cs2 | additional.fields.value.string_value | Mapeado diretamente a partir do campo cs2 quando cs2Label é EventlogCategory. |
| cs2Label | additional.fields.key | Mapeado diretamente a partir do campo cs2Label quando o respetivo valor é EventlogCategory. |
| cs3 | additional.fields.value.string_value | Mapeado diretamente a partir do campo cs3 quando cs3Label é Process ID. |
| cs3Label | additional.fields.key | Mapeado diretamente a partir do campo cs3Label quando o respetivo valor é Process ID. |
| cs5 | additional.fields.value.string_value | Mapeado diretamente a partir do campo cs5 quando cs5Label é Authentication Package Name. |
| cs5Label | additional.fields.key | Mapeado diretamente a partir do campo cs5Label quando o respetivo valor é Authentication Package Name. |
| cs6 | additional.fields.value.string_value | Mapeado diretamente a partir do campo cs6 quando cs6Label é Logon GUID. |
| cs6Label | additional.fields.key | Mapeado diretamente a partir do campo cs6Label quando o respetivo valor é Logon GUID. |
| dhost | about.hostname | Mapeado diretamente a partir do campo dhost. |
| dhost | target.hostname | Mapeado diretamente a partir do campo dhost. |
| dntdom | about.administrative_domain | Mapeado diretamente a partir do campo dntdom. |
| dntdom | target.administrative_domain | Mapeado diretamente a partir do campo dntdom. |
| dproc | about.process.command_line | Mapeado diretamente a partir do campo dproc. |
| dproc | target.process.command_line | Mapeado diretamente a partir do campo dproc. |
| dst | principal.ip | Mapeado diretamente a partir do campo dst. |
| dst | principal.asset.ip | Mapeado diretamente a partir do campo dst. |
| dst | target.ip | Mapeado diretamente a partir do campo dst. |
| duid | target.user.userid | Mapeado diretamente a partir do campo duid. |
| duser | target.user.user_display_name | Mapeado diretamente a partir do campo duser. |
| dvc | about.ip | Mapeado diretamente a partir do campo dvc. |
| dvchost | about.hostname | Mapeado diretamente a partir do campo dvchost. |
| eventId | additional.fields.value.string_value | Mapeado diretamente a partir do campo eventId. |
| externalId | metadata.product_log_id | Mapeado diretamente a partir do campo externalId. |
| fname | additional.fields.value.string_value | Mapeado diretamente a partir do campo fname. |
| msg | metadata.description | Mapeado diretamente a partir do campo msg. |
| proto | network.ip_protocol | Mapeado diretamente a partir do campo proto. Traduz os nomes dos protocolos nas respetivas constantes (por exemplo, tcp a TCP). |
| rt | metadata.event_timestamp.seconds | Mapeado diretamente a partir do campo rt. |
| shost | about.hostname | Mapeado diretamente a partir do campo shost. |
| shost | principal.hostname | Mapeado diretamente a partir do campo shost. |
| src | principal.ip | Mapeado diretamente a partir do campo src. |
| src | principal.asset.ip | Mapeado diretamente a partir do campo src. |
| src | target.ip | Mapeado diretamente a partir do campo src. |
| sproc | principal.process.command_line | Mapeado diretamente a partir do campo sproc. |
| spt | principal.port | Mapeado diretamente a partir do campo spt. |
| spt | target.port | Mapeado diretamente a partir do campo spt. |
| additional.EventRecordID | additional.fields.value.string_value | Mapeado diretamente a partir do campo ad.EventRecordID. |
| additional.ThreadID | additional.fields.value.string_value | Mapeado diretamente a partir do campo ad.ThreadID. |
| additional.Opcode | additional.fields.value.string_value | Mapeado diretamente a partir do campo ad.Opcode. |
| additional.ProcessID | additional.fields.value.string_value | Mapeado diretamente a partir do campo ad.ProcessID. |
| additional.TargetDomainName | additional.fields.value.string_value | Mapeado diretamente a partir do campo ad.TargetDomainName. |
| additional.Version | additional.fields.value.string_value | Mapeado diretamente a partir do campo ad.Version. |
| deviceExternalId | about.asset.hardware.serial_number | Mapeado diretamente a partir do campo deviceExternalId. |
| deviceInboundInterface | additional.fields.value.string_value | Mapeado diretamente a partir do campo deviceInboundInterface. |
| deviceOutboundInterface | additional.fields.value.string_value | Mapeado diretamente a partir do campo deviceOutboundInterface. |
| PanOSConfigVersion | security_result.detection_fields.value | Mapeado diretamente a partir do campo PanOSConfigVersion. |
| PanOSContentVersion | security_result.detection_fields.value | Mapeado diretamente a partir do campo PanOSContentVersion. |
| PanOSDGHierarchyLevel1 | security_result.detection_fields.value | Mapeado diretamente a partir do campo PanOSDGHierarchyLevel1. |
| PanOSDestinationLocation | target.location.country_or_region | Mapeado diretamente a partir do campo PanOSDestinationLocation. |
| PanOSRuleUUID | metadata.product_log_id | Mapeado diretamente a partir do campo PanOSRuleUUID. |
| PanOSThreatCategory | security_result.category_details | Mapeado diretamente a partir do campo PanOSThreatCategory. |
| PanOSThreatID | security_result.threat_id | Mapeado diretamente a partir do campo PanOSThreatID. |
| about.asset.asset_id | Gerado através da concatenação de Palo Alto Networks., o nome do fornecedor (LF) e o campo deviceExternalId. |
|
| extensions.auth.type | Defina como AUTHTYPE_UNSPECIFIED se o campo event_name contiver logged on. |
|
| metadata.description | Se o campo description contiver by seguido de um endereço IP, o endereço IP é extraído e mapeado para principal.ip e principal.asset.ip. |
|
| metadata.event_type | Determinado com base numa série de verificações condicionais em vários campos, incluindo event_name, principal_*, target_* e device_event_class_id. A lógica determina o tipo de evento mais adequado com base nas informações disponíveis. |
|
| metadata.log_type | Definido como ARCSIGHT_CEF. |
|
| metadata.product_event_type | Gerado através da concatenação de \[, the device_event_class_id field, \] - e do campo name. |
|
| metadata.product_name | Defina como NGFW se o campo product_name for LF. |
|
| principal.asset.ip | Se o campo description contiver by seguido de um endereço IP, o endereço IP é extraído e mapeado para principal.ip e principal.asset.ip. |
|
| principal.ip | Se o campo description contiver by seguido de um endereço IP, o endereço IP é extraído e mapeado para principal.ip e principal.asset.ip. |
|
| security_result.action | Definido como ALLOW se o campo act for alert; caso contrário, é definido como BLOCK. |
|
| security_result.severity | Definido como HIGH se o campo sev for superior ou igual a 7. Caso contrário, é definido como LOW. |
Precisa de mais ajuda? Receba respostas de membros da comunidade e profissionais da Google SecOps.