Mengumpulkan log Fortinet Web Proxy
Dokumen ini menjelaskan cara menyerap log Fortinet Web Proxy ke Google Security Operations menggunakan agen Bindplane.
Proxy web Fortinet FortiGate membuat log untuk sesi proxy eksplisit dan transparan, yang mencatat traffic HTTP/HTTPS, keputusan pemfilteran URL, dan peristiwa akses web. Log menggunakan format nilai kunci syslog dan mencakup metadata jaringan, tindakan keamanan, dan informasi identitas pengguna.
Sebelum memulai
Pastikan Anda memiliki prasyarat berikut:
- Instance Google SecOps
- Windows Server 2016 atau yang lebih baru, atau host Linux dengan
systemd - Konektivitas jaringan antara agen Bindplane dan perangkat FortiGate
- Jika beroperasi dari balik proxy, pastikan port firewall terbuka sesuai dengan persyaratan agen Bindplane
- Akses istimewa ke perangkat FortiGate dengan izin administrator
Mendapatkan file autentikasi penyerapan Google SecOps
- Login ke konsol Google SecOps.
- Buka Setelan SIEM > Agen Pengumpulan.
- Download File Autentikasi Penyerapan.
Simpan file dengan aman di sistem tempat BindPlane akan diinstal.
Mendapatkan ID pelanggan Google SecOps
- Login ke konsol Google SecOps.
- Buka Setelan SIEM > Profil.
Salin dan simpan ID Pelanggan dari bagian Detail Organisasi.
Menginstal agen Bindplane
Instal agen Bindplane di sistem operasi Windows atau Linux Anda sesuai dengan petunjuk berikut.
Penginstalan Windows
- Buka Command Prompt atau PowerShell sebagai administrator.
Jalankan perintah berikut:
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quietTunggu hingga penginstalan selesai.
Verifikasi penginstalan dengan menjalankan:
sc query observiq-otel-collectorLayanan akan ditampilkan sebagai RUNNING.
Penginstalan Linux
- Buka terminal dengan hak istimewa root atau sudo.
Jalankan perintah berikut:
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.shTunggu hingga penginstalan selesai.
Verifikasi penginstalan dengan menjalankan:
sudo systemctl status observiq-otel-collectorLayanan akan ditampilkan sebagai aktif (berjalan).
Referensi penginstalan tambahan
Untuk opsi penginstalan dan pemecahan masalah tambahan, lihat Panduan penginstalan agen BindPlane.
Mengonfigurasi agen Bindplane untuk menyerap syslog dan mengirimkannya ke Google SecOps
Cari file konfigurasi
Linux:
sudo nano /opt/observiq-otel-collector/config.yamlWindows:
notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
Edit file konfigurasi
Ganti seluruh konten
config.yamldengan konfigurasi berikut:receivers: udplog: listen_address: "0.0.0.0:514" exporters: chronicle/fortinet_webproxy: compression: gzip creds_file_path: '/etc/bindplane-agent/ingestion-auth.json' customer_id: '<customer_id>' endpoint: malachiteingestion-pa.googleapis.com log_type: FORTINET_WEBPROXY raw_log_field: body ingestion_labels: env: production service: pipelines: logs/webproxy_to_chronicle: receivers: - udplog exporters: - chronicle/fortinet_webproxy
Parameter konfigurasi
Ganti placeholder berikut:
Konfigurasi penerima:
udplog: Jenis penerima berdasarkan protokol:udploguntuk syslog UDPtcploguntuk syslog TCP
0.0.0.0: Alamat IP yang akan didengarkan:0.0.0.0untuk mendengarkan di semua antarmuka (direkomendasikan)- Alamat IP tertentu untuk memproses permintaan di satu antarmuka
514: Nomor port yang akan diproses (misalnya,514,1514,6514)
Konfigurasi eksportir:
fortinet_webproxy: Nama deskriptif untuk eksportircreds_file_path: Jalur lengkap ke file autentikasi penyerapan:- Linux:
/etc/bindplane-agent/ingestion-auth.json - Windows:
C:\Program Files\observIQ OpenTelemetry Collector\ingestion-auth.json
- Linux:
<customer_id>: ID Pelanggan dari langkah sebelumnyaendpoint: URL endpoint regional:- Amerika Serikat:
malachiteingestion-pa.googleapis.com - Eropa:
europe-malachiteingestion-pa.googleapis.com - Asia:
asia-southeast1-malachiteingestion-pa.googleapis.com - Lihat Endpoint Regional untuk mengetahui daftar lengkapnya
- Amerika Serikat:
FORTINET_WEBPROXY: Jenis log persis seperti yang muncul di Chronicleingestion_labels: Label opsional dalam format YAML (misalnya,env: production)
Konfigurasi pipeline:
webproxy_to_chronicle: Nama deskriptif untuk pipeline
Simpan file konfigurasi
- Setelah mengedit, simpan file:
- Linux: Tekan
Ctrl+O, laluEnter, laluCtrl+X - Windows: Klik File > Save
- Linux: Tekan
Mulai ulang agen Bindplane untuk menerapkan perubahan
Untuk memulai ulang agen Bindplane di Linux, jalankan perintah berikut:
sudo systemctl restart observiq-otel-collectorPastikan layanan sedang berjalan:
sudo systemctl status observiq-otel-collectorPeriksa log untuk mengetahui error:
sudo journalctl -u observiq-otel-collector -f
Untuk memulai ulang agen Bindplane di Windows, pilih salah satu opsi berikut:
Command Prompt atau PowerShell sebagai administrator:
net stop observiq-otel-collector && net start observiq-otel-collectorKonsol layanan:
- Tekan
Win+R, ketikservices.msc, lalu tekan Enter. - Temukan observIQ OpenTelemetry Collector.
- Klik kanan, lalu pilih Mulai Ulang.
Pastikan layanan sedang berjalan:
sc query observiq-otel-collectorPeriksa log untuk mengetahui error:
type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
- Tekan
Mengonfigurasi penerusan syslog proxy web Fortinet FortiGate
- Login ke antarmuka web FortiGate.
- Buka Log & Report > Log Settings.
- Scroll ke bawah ke bagian Logging dan Pengarsipan Jarak Jauh.
- Di bagian Syslog, klik Tambahkan.
- Berikan detail konfigurasi berikut:
- Name: Masukkan nama deskriptif (misalnya,
Chronicle-Bindplane). - IP Address/FQDN: Masukkan alamat IP host agen Bindplane (misalnya,
192.168.1.100). - Port: Masukkan
514(harus cocok dengan port penerima agen BindPlane). - Protocol: Pilih UDP.
- Tingkat Minimum: Pilih Informasi atau Pemberitahuan.
- Name: Masukkan nama deskriptif (misalnya,
Pastikan kategori log Web Proxy diaktifkan. Atau, gunakan CLI untuk mengonfigurasi filter syslog:
config log syslogd setting set status enable set server <BINDPLANE_AGENT_IP> set port 514 end config log syslogd filter set filter "logid(0300)" set filter-type include end- Rentang ID log
0300mencakup peristiwa proxy web. Sesuaikan filter sesuai dengan lingkungan Anda. - Ganti
<BINDPLANE_AGENT_IP>dengan alamat IP host agen Bindplane.
- Rentang ID log
Klik Oke untuk menyimpan.
Klik Terapkan di kanan atas untuk menerapkan konfigurasi.
Pastikan pesan syslog diterima dengan memeriksa log agen Bindplane.
Tabel pemetaan UDM
| Kolom Log | Pemetaan UDM | Logika |
|---|---|---|
| group, profile, agent, subtype, catdesc, reqtype | additional.fields | Digabungkan dengan label yang dibuat dari setiap kolom |
| action, has_network, has_principal, has_target | metadata.event_type | Ditetapkan ke USER_LOGIN jika tindakan adalah auth-logon, atau NETWORK_HTTP jika has_network benar (true), atau NETWORK_CONNECTION jika has_principal dan has_target benar (true), atau STATUS_UPDATE jika has_principal benar (true), atau GENERIC_EVENT |
| eventtype | metadata.product_event_type | Nilai disalin secara langsung |
| logid | metadata.product_log_id | Nilai disalin secara langsung |
| metadata.product_name | Tetapkan ke "FORTINET_WEBPROXY" | |
| metadata.vendor_name | Tetapkan ke "FORTINET_WEBPROXY" | |
| pelanggan | network.application_protocol | Nilai disalin secara langsung jika layanan dalam HTTP, HTTPS |
| direction | network.direction | Disetel ke INBOUND jika arahnya masuk, masuk, respons, atau OUTBOUND jika keluar, keluar |
| httpmethod | network.http.method | Nilai disalin langsung jika httpmethod di GET, POST |
| referralurl | network.http.referral_url | Nilai disalin secara langsung |
| proto, subtype, service | network.ip_protocol | Disetel ke UDP jika proto=17, TCP jika proto=6 atau subtype=wad, IP6IN4 jika proto=41, ICMP jika service=PING atau proto=1 atau service cocok dengan ICMP |
| rcvdbyte | network.received_bytes | Dikonversi menjadi bilangan bulat tidak bertanda |
| sentbyte | network.sent_bytes | Dikonversi menjadi bilangan bulat tidak bertanda |
| sessionid | network.session_id | Nilai disalin secara langsung |
| devname | principal.asset.hostname | Nilai disalin secara langsung |
| srcip | principal.asset.ip | Nilai disalin secara langsung |
| devname | principal.hostname | Nilai disalin secara langsung |
| srcip | principal.ip | Nilai disalin secara langsung |
| srccountry | principal.location.country_or_region | Nilai disalin langsung jika tidak Dicadangkan dan tidak kosong |
| srcport | principal.port | Dikonversi ke bilangan bulat |
| srcuuid | principal.user.product_object_id | Nilai disalin secara langsung |
| vd | principal.user.user_display_name | Nilai disalin secara langsung |
| pengguna | principal.user.userid | Nilai disalin secara langsung |
| filtername | security_result.about.resource.attribute.labels | Digabungkan dengan label yang dibuat dari nama filter jika tidak kosong dan bukan - |
| tindakan | security_result.action | Disetel ke BLOCK jika action=blocked, ALLOW jika action di accept, passthrough |
| devid, policyid, srcintf, srcintfrole, ratemethod, cat | security_result.detection_fields | Digabungkan dengan label yang dibuat dari setiap kolom |
| msg | security_result.description | Nilai disalin secara langsung |
| poluuid | security_result.rule_id | Nilai disalin secara langsung |
| policytype | security_result.rule_type | Nilai disalin secara langsung |
| level | security_result.severity | Ditetapkan ke TINGGI jika level=peringatan, SEDANG jika level=pemberitahuan |
| jenis | security_result.summary | Nilai disalin secara langsung |
| dstip | target.asset.ip | Nilai disalin secara langsung |
| filename | target.file.full_path | Nilai disalin secara langsung |
| filetype | target.file.mime_type | Nilai disalin secara langsung |
| filesize | target.file.size | Dikonversi menjadi bilangan bulat tidak bertanda |
| hostname | target.hostname | Nilai disalin secara langsung |
| dstip | target.ip | Nilai disalin secara langsung |
| dstcountry | target.location.country_or_region | Nilai disalin secara langsung |
| dstport | target.port | Dikonversi ke bilangan bulat |
| dstintf, dstintfrole | target.resource.attribute.labels | Digabungkan dengan label yang dibuat dari setiap kolom |
| dstuuid | target.resource.product_object_id | Nilai disalin secara langsung |
| url | target.url | Nilai disalin secara langsung |
Perlu bantuan lain? Dapatkan jawaban dari anggota Komunitas dan profesional Google SecOps.