Barracuda WAF 로그 수집
이 문서에서는 Bindplane을 사용하여 Barracuda 웹 애플리케이션 방화벽 (WAF) 로그를 수집하는 방법을 설명합니다. 파서는 로그에서 JSON 및 Syslog 형식의 필드를 추출하고, 정규화하고, 통합 데이터 모델 (UDM)에 매핑합니다. 다양한 로그 유형 (트래픽, 웹 방화벽)을 처리하고 IP 주소/호스트 이름 확인, 방향 매핑, 심각도 표준화 등 필드 값을 기반으로 조건부 변환을 실행합니다.
시작하기 전에
- Google Security Operations 인스턴스가 있는지 확인합니다.
- Windows 2016 이상 또는
systemd
를 사용하는 Linux 호스트를 사용하고 있는지 확인합니다. - 프록시 뒤에서 실행하는 경우 방화벽 포트가 열려 있는지 확인합니다.
- Barracuda WAF에 대한 권한이 있는지 확인합니다.
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
파일을 수정합니다.receivers: tcplog: # Replace the port and IP address as required listen_address: "0.0.0.0:54525" 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: barracuda_waf raw_log_field: body service: pipelines: logs/source0__chronicle_w_labels-0: receivers: - tcplog 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
Barracuda WAF 구성
- 관리자 사용자 인증 정보로 Barracuda WAF 콘솔에 로그인합니다.
- 고급 탭 > 로그 내보내기를 클릭합니다.
- 로그 내보내기 섹션에서 내보내기 로그 서버 추가를 클릭합니다.
- 다음 값을 제공합니다.
- 이름: Google SecOps 포워더의 이름을 입력합니다.
- 로그 서버 유형: 시스템로그를 선택합니다.
- IP 주소 또는 호스트 이름:
Bindplane
IP 주소를 입력합니다. - 포트:
Bindplane
포트를 입력합니다. - 연결 유형:
TCP
연결 유형을 선택합니다 (TCP 권장). 하지만 UDP 또는 SSL 프로토콜을 사용할 수도 있습니다. - 서버 인증서 유효성 검사: 아니요를 선택합니다.
- 클라이언트 인증서: 없음을 선택합니다.
- 타임스탬프 및 호스트 이름 로깅: 예를 선택합니다.
- 추가를 클릭합니다.
UDM 매핑 표
로그 필드 | UDM 매핑 | 논리 |
---|---|---|
action |
security_result.action |
action 이 DENY 이면 BLOCK 로 설정합니다. 그 외의 경우에는 ALLOW 로 설정합니다 (특히 WF 로그 유형의 경우). 일반 방화벽 이벤트에도 사용됩니다. |
appProtocol |
network.application_protocol |
appProtocol 이 TLSv 과 일치하면 HTTPS 로 설정합니다. 그렇지 않으면 appProtocol 값을 사용합니다. |
attackDetails |
security_result.description |
WF 로그 유형의 원시 로그에서 추출됩니다. |
attackType |
security_result.summary |
security_result.summary 의 일부로, ruleType 와 결합됩니다. |
bytesReceived |
network.received_bytes |
부호 없는 정수로 변환되고 TR 로그 유형에 매핑됩니다. |
bytesSent |
network.sent_bytes |
부호 없는 정수로 변환되고 TR 로그 유형에 매핑됩니다. |
hostName |
target.hostname |
hostName 가 IP 주소가 아닌 경우 값을 사용합니다. 그렇지 않으면 target.ip 에 병합됩니다. |
httpMethod loginId |
principal.user.userid |
emptyToken 와 같지 않으면 TR 로그 유형에 매핑됩니다. |
logType |
metadata.product_event_type |
TR 이면 metadata.product_event_type 를 Barracuda Access Log 로 설정합니다. WF 이면 Barracuda Web Firewall Log 로 설정합니다. |
message |
metadata.description |
desc 가 비어 있지 않은 경우에 사용됩니다. |
referrer |
network.http.referral_url |
emptyToken 와 같지 않으면 TR 로그 유형에 매핑됩니다. |
responseCode |
network.http.response_code |
정수로 변환되고 TR 로그 유형에 매핑됩니다. |
rule |
security_result.rule_name |
WF 로그 유형에 매핑됩니다. |
ruleType |
security_result.summary |
security_result.summary 의 일부로, attackType 와 결합됩니다. |
sec_desc |
security_result.rule_name |
일반 방화벽 이벤트에 사용됩니다. |
server |
target.ip |
target.ip 에 병합되었습니다. |
serv |
target.ip |
target.ip 에 병합되었습니다. |
severity |
security_result.severity , is_alert , is_significant |
WF 로그 유형: 대문자로 변환됩니다. EMERGENCY , ALER 또는 CRITICAL 인 경우 security_result.severity 를 CRITICAL 로, is_alert 를 true로, is_significant 를 true로 설정합니다. ERROR 이면 HIGH 로 설정합니다. WARNING 이면 MEDIUM 로 설정합니다. NOTICE 이면 LOW 로 설정합니다. 그렇지 않으면 INFORMATIONAL 로 설정합니다. |
src |
principal.ip |
일반 방화벽 이벤트 및 일부 상태 업데이트에도 사용됩니다. |
srcPort |
principal.port |
정수로 변환됩니다. |
target targetPort |
target.port |
정수로 변환됩니다. |
time |
metadata.event_timestamp.seconds , metadata.event_timestamp.nanos , timestamp.seconds , timestamp.nanos |
tz 와 결합되고 파싱되어 이벤트 타임스탬프를 만듭니다. 초와 나노초가 추출되어 각 필드에 채워집니다. |
url urlParams |
target.url |
TR 로그 유형의 경우 emptyToken 와 같지 않으면 url 에 추가됩니다. |
userAgent userName |
target.user.userid , target.user.user_display_name |
일반 방화벽 이벤트에 사용됩니다. TR 로그 유형의 경우 emptyToken 와 같지 않으면 target.user.user_display_name 에 매핑됩니다. Barracuda 로 하드코딩되었습니다. src 와 target 가 모두 있는 경우 NETWORK_HTTP 로 설정합니다. src 만 있는 경우 STATUS_UPDATE 로 설정합니다. 기본값으로 또는 CEF 파싱과 같은 다른 시나리오의 경우 GENERIC_EVENT 로 설정합니다. BARRACUDA_WAF 로 하드코딩되었습니다. |
변경사항
2023-07-19
버그 수정:
- Grok 패턴을 사용하여 파싱되지 않은 원시 로그를 파싱했습니다.
- 'server'가 'target.ip'에 매핑되었습니다.
2022-09-09
- 기본 파서를 만들고 커스텀 파서를 기본 파서로 마이그레이션했습니다.
- 다음 필드가 매핑됩니다.
- 'duser'가 'target.user.user_display_name'에 매핑되었습니다.
- 'suser'가 '.principal.user.user_display_name'에 매핑되었습니다.
- 'suid'가 'principal.user.userid'에 매핑되었습니다.
- 'src'가 'principal.ip'에 매핑되었습니다.
- 'dst'가 'target.ip'에 매핑되었습니다.
- 'shost'가 'principal.hostname'에 매핑되었습니다.
- 'severity'가 'security_result.severity'에 매핑되었습니다.
- 'action'이 'security_result.action'에 매핑되었습니다.
- 'user_name'이 'target.user.userid'에 매핑되었습니다.
- 'domain_name'이 'target.domain.name'에 매핑되었습니다.
- 'mac_address'가 'principal.mac'에 매핑되었습니다.
- 'direction'이 'network.direction'에 매핑되었습니다.
- 'ip_protocol'이 'network.ip_protocol'에 매핑되었습니다.
- 'summary'가 'security_result.summary'에 매핑되었습니다.
도움이 더 필요하신가요? 커뮤니티 회원 및 Google SecOps 전문가의 답변을 받으세요.