Fortinet FortiMail 로그 수집
이 문서에서는 Bindplane을 사용하여 Fortinet FortiMail 로그를 수집하는 방법을 설명합니다. 파서는 키-값 쌍을 추출하고 타임스탬프 및 IP 주소와 같은 다양한 필드를 정규화한 후 Google Security Operations의 통합 데이터 모델 (UDM)에 매핑하여 사용 가능한 정보를 기반으로 이벤트 유형을 분류합니다.
시작하기 전에
- Google Security Operations 인스턴스가 있는지 확인합니다.
- Windows 2016 이상 또는
systemd
를 사용하는 Linux 호스트를 사용하고 있는지 확인합니다. - 프록시 뒤에서 실행하는 경우 방화벽 포트가 열려 있는지 확인합니다.
- Fortinet Fortimail에 대한 권한이 있는지 확인합니다.
Google SecOps 처리 인증 파일 가져오기
- Google SecOps 콘솔에 로그인합니다.
- SIEM 설정 > 수집 에이전트로 이동합니다.
- 처리 인증 파일을 다운로드합니다. Bindplane가 설치될 시스템에 파일을 안전하게 저장합니다.
Google SecOps 고객 ID 가져오기
- Google SecOps 콘솔에 로그인합니다.
- SIEM 설정 > 프로필로 이동합니다.
- 조직 세부정보 섹션에서 고객 ID를 복사하여 저장합니다.
Bindplane 에이전트 설치
Windows 설치
- 관리자 권한으로 명령 프롬프트 또는 PowerShell을 엽니다.
다음 명령어를 실행합니다.
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
Linux 설치
- 루트 또는 sudo 권한으로 터미널을 엽니다.
다음 명령어를 실행합니다.
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
추가 설치 리소스
- 추가 설치 옵션은 이 설치 가이드를 참고하세요.
Syslog를 수집하고 Google SecOps로 전송하도록 Bindplane 에이전트 구성
구성 파일에 액세스합니다.
config.yaml
파일을 찾습니다. 일반적으로 Linux의/etc/bindplane-agent/
디렉터리 또는 Windows의 설치 디렉터리에 있습니다.- 텍스트 편집기 (예:
nano
,vi
, 메모장)를 사용하여 파일을 엽니다.
다음과 같이
config.yaml
파일을 수정합니다.```yaml receivers: udplog: # Replace the port and IP address as required listen_address: "0.0.0.0:5252" 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: SYSLOG namespace: fortinet_fortimail raw_log_field: body service: pipelines: logs/source0__chronicle_w_labels-0: receivers: - udplog exporters: - chronicle/chronicle_w_labels ```
인프라에서 필요에 따라 포트와 IP 주소를 바꿉니다.
<customer_id>
를 실제 고객 ID로 바꿉니다./path/to/ingestion-authentication-file.json
를 Google SecOps 처리 인증 파일 가져오기 섹션에서 인증 파일이 저장된 경로로 업데이트합니다.
Bindplane 에이전트를 다시 시작하여 변경사항 적용
Linux에서 Bindplane 에이전트를 다시 시작하려면 다음 명령어를 실행합니다.
sudo systemctl restart bindplane-agent
Windows에서 Bindplane 에이전트를 다시 시작하려면 서비스 콘솔을 사용하거나 다음 명령어를 입력하면 됩니다.
net stop BindPlaneAgent && net start BindPlaneAgent
Fortinet FortiMail syslog 구성
- FortiMail 기기 웹 인터페이스에 로그인합니다.
- 로그 및 보고서 > 로그 설정 > 원격을 선택합니다.
- 새로 만들기를 클릭하여 새 항목을 만듭니다.
- 대화상자가 표시되면 사용 설정을 선택하여 원격 호스트에 로깅을 허용합니다.
- 다음 세부정보를 제공합니다.
- 이름: 고유하고 의미 있는 이름을 입력합니다.
- 서버 이름/IP: Bindplane IP 주소를 입력합니다.
- 서버 포트: Bindplane UDP 포트 번호를 입력합니다.
- 수준: 심각도 수준으로 정보를 선택합니다.
- 시설: 고유한 시설 식별자를 입력하고 다른 네트워크 기기에서 동일한 시설 식별자를 사용하지 않는지 확인합니다.
- CSV 형식을 선택 해제합니다.
- 로그 프로토콜: Syslog를 선택합니다.
- 로깅 정책 구성: 모든 유형의 이벤트 또는 로그를 전달하도록 사용 설정합니다.
- 만들기를 클릭합니다.
UDM 매핑 표
로그 필드 | UDM 매핑 | 논리 |
---|---|---|
authid | read_only_udm.target.user.email_addresses | authid 필드에 @ 가 포함된 경우 이 필드에 매핑합니다. |
authid | read_only_udm.target.user.userid | authid 필드를 이 필드에 매핑 |
암호화 | read_only_udm.network.tls.cipher | cipher 필드를 이 필드에 매핑 |
client_ip | read_only_udm.principal.ip | client_ip 필드를 이 필드에 매핑 |
client_name | read_only_udm.principal.hostname | client_name 필드를 이 필드에 매핑 |
세부정보 | read_only_udm.security_result.summary | detail 필드를 이 필드에 매핑 |
device_id | read_only_udm.principal.resource.id | device_id 필드를 이 필드에 매핑 |
devname | read_only_udm.principal.resource.name | devname 필드를 이 필드에 매핑 |
direction | read_only_udm.network.direction | direction 필드가 out 와 같으면 값 OUTBOUND 를 매핑하고, direction 필드가 in 와 같으면 값 INBOUND 를 매핑하고, 그 외의 경우에는 값 UNKNOWN_DIRECTION 를 매핑합니다. |
disposition | read_only_udm.security_result.detection_fields.value | 키 필드가 Disposition 과 같은 경우 disposition 필드를 이 필드에 매핑합니다. |
도메인 | read_only_udm.principal.administrative_domain | domain 필드를 이 필드에 매핑 |
dst_ip | read_only_udm.target.ip | dst_ip 필드를 이 필드에 매핑 |
출처: | read_only_udm.network.email.from | from 필드에 @ 가 포함된 경우 이 필드에 매핑합니다. |
log_id | read_only_udm.metadata.product_log_id | log_id 필드를 이 필드에 매핑 |
message_id | read_only_udm.network.email.mail_id | message_id 필드를 이 필드에 매핑 |
message_length | read_only_udm.additional.fields.value.number_value | 키 필드가 message_length 과 같은 경우 message_length 필드를 이 필드에 매핑합니다. |
msg | read_only_udm.security_result.description | msg 필드를 이 필드에 매핑 |
polid | read_only_udm.security_result.detection_fields.value | 키 필드가 Polid 과 같은 경우 polid 필드를 이 필드에 매핑합니다. |
relay | read_only_udm.intermediary.ip | relay 필드를 이 필드에 매핑 |
해결됨 | read_only_udm.security_result.detection_fields.value | 키 필드가 Resolved 과 같은 경우 resolved 필드를 이 필드에 매핑합니다. |
session_id | read_only_udm.network.session_id | session_id 필드를 이 필드에 매핑 |
src_type | read_only_udm.additional.fields.value.string_value | 키 필드가 src_type 과 같은 경우 src_type 필드를 이 필드에 매핑합니다. |
stat | read_only_udm.metadata.description | stat 필드를 이 필드에 매핑 |
subject | read_only_udm.network.email.subject | subject 필드를 이 필드에 매핑 |
~ | read_only_udm.network.email.to | to 필드에 @ 가 포함된 경우 이 필드에 매핑합니다. |
사용자 | read_only_udm.principal.user.userid | user 필드를 이 필드에 매핑 |
해당 사항 없음 | read_only_udm.extensions.auth.mechanism | 이 필드의 값은 authid 필드가 있는 경우 파서 코드에 USERNAME_PASSWORD 로 하드코딩됩니다. |
해당 사항 없음 | read_only_udm.extensions.auth.type | 이 필드의 값은 authid 필드가 있는 경우 파서 코드에 AUTHTYPE_UNSPECIFIED 로 하드코딩됩니다. |
해당 사항 없음 | read_only_udm.metadata.event_type | 이 필드의 값은 사용 가능한 필드 조합을 기반으로 파서 로직에 의해 결정됩니다. from 필드가 있으면 값은 EMAIL_TRANSACTION 이고, to 필드가 있으면 값은 EMAIL_UNCATEGORIZED 이고, client_ip 필드와 dst_ip 필드가 모두 있으면 값은 NETWORK_CONNECTION 이고, authid 필드가 있으면 값은 USER_LOGIN 이고, user 필드가 있으면 값은 USER_UNCATEGORIZED 이고, client_ip 필드가 있으면 값은 STATUS_UPDATE 이고, 그 외의 경우에는 값은 GENERIC_EVENT 입니다. |
해당 사항 없음 | read_only_udm.metadata.log_type | 이 필드의 값은 파서 코드에 FORTINET_FORTIMAIL 로 하드코딩되어 있습니다. |
해당 사항 없음 | read_only_udm.metadata.product_name | 이 필드의 값은 파서 코드에 FORTINET_FORTIMAIL 로 하드코딩되어 있습니다. |
해당 사항 없음 | read_only_udm.metadata.vendor_name | 이 필드의 값은 파서 코드에 FORTINET 로 하드코딩되어 있습니다. |
해당 사항 없음 | read_only_udm.principal.resource.resource_type | 이 필드의 값은 파서 코드에 DEVICE 로 하드코딩되어 있습니다. |
변경사항
2023-09-06
개선사항:
- 데이터를 추출하고 실패한 KV 로그를 파싱하는 Grok 패턴을 추가했습니다.
2023-05-23
- 파서를 새로 만들었습니다.
도움이 더 필요하신가요? 커뮤니티 회원 및 Google SecOps 전문가의 답변을 받으세요.