Mengumpulkan log ManageEngine ADManager Plus

Didukung di:

Dokumen ini menjelaskan cara menyerap log ManageEngine ADManager Plus ke Google Security Operations menggunakan agen Bindplane.

ManageEngine ADManager Plus menawarkan solusi berbasis web untuk pengelolaan AD yang disederhanakan, termasuk pembuatan dan modifikasi pengguna, keamanan berbasis peran, dan laporan mendetail. Integrasi ADManager Plus dengan server Splunk dan Syslog memungkinkan organisasi meneruskan log semua tindakan pengelolaan Active Directory, Microsoft 365, dan Google Workspace yang dilakukan di ADManager Plus.

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 ManageEngine ADManager Plus
  • Jika beroperasi dari balik proxy, pastikan port firewall terbuka sesuai dengan persyaratan agen Bindplane
  • Akses istimewa ke konsol pengelolaan ManageEngine ADManager Plus

Mendapatkan file autentikasi penyerapan Google SecOps

  1. Login ke konsol Google SecOps.
  2. Buka Setelan SIEM > Agen Pengumpulan.
  3. Klik Download untuk mendownload File Autentikasi Penyerapan.
  4. Simpan file dengan aman di sistem tempat agen BindPlane akan diinstal.

Mendapatkan ID pelanggan Google SecOps

  1. Login ke konsol Google SecOps.
  2. Buka Setelan SIEM > Profil.
  3. 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

  1. Buka Command Prompt atau PowerShell sebagai administrator.
  2. Jalankan perintah berikut:

    msiexec /i "https://github.com/observIQ/bindplane-otel-collector/releases/latest/download/observiq-otel-collector.msi" /quiet
    
  3. Tunggu hingga penginstalan selesai.

  4. Verifikasi penginstalan dengan menjalankan:

    sc query observiq-otel-collector
    

Layanan akan ditampilkan sebagai RUNNING.

Penginstalan Linux

  1. Buka terminal dengan hak istimewa root atau sudo.
  2. Jalankan perintah berikut:

    sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-otel-collector/releases/latest/download/install_unix.sh)" install_unix.sh
    
  3. Tunggu hingga penginstalan selesai.

  4. Verifikasi penginstalan dengan menjalankan:

    sudo systemctl status observiq-otel-collector
    

Layanan 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.yaml
    
  • Windows:

    notepad "C:\Program Files\observIQ OpenTelemetry Collector\config.yaml"
    

Edit file konfigurasi

  1. Ganti seluruh konten config.yaml dengan konfigurasi berikut:

    receivers:
      tcplog:
        listen_address: "0.0.0.0:514"
    
    exporters:
      chronicle/admanager_plus:
        compression: gzip
        creds_file_path: '<CREDS_FILE_PATH>'
        customer_id: '<CUSTOMER_ID>'
        endpoint: malachiteingestion-pa.googleapis.com
        log_type: ADMANAGER_PLUS
        raw_log_field: body
        ingestion_labels:
          log_source: admanager_plus
    
    service:
      pipelines:
        logs/admanager_to_chronicle:
          receivers:
            - tcplog
          exporters:
            - chronicle/admanager_plus
    
  2. Ganti placeholder berikut:

    • Konfigurasi penerima:

      • Penerima menggunakan tcplog untuk menerima data syslog di port TCP 514.
      • listen_address: Setel ke 0.0.0.0:514 untuk memproses semua antarmuka di port 514.
    • Konfigurasi eksportir:

      • <CREDS_FILE_PATH>: Jalur lengkap ke file autentikasi penyerapan:
        • Linux: /opt/observiq-otel-collector/ingestion-auth.json
        • Windows: C:\\Program Files\\observIQ OpenTelemetry Collector\\ingestion-auth.json
      • <CUSTOMER_ID>: ID Pelanggan dari langkah sebelumnya.
      • endpoint: 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.
      • log_type: Tetapkan ke ADMANAGER_PLUS persis seperti yang muncul di Chronicle.
      • ingestion_labels: Label opsional dalam format YAML.

Simpan file konfigurasi

Setelah mengedit, simpan file:

  • Linux: Tekan Ctrl+O, lalu Enter, lalu Ctrl+X
  • Windows: Klik File > Save

Mulai ulang agen Bindplane untuk menerapkan perubahan

Linux

  1. Untuk memulai ulang agen Bindplane di Linux, jalankan perintah berikut:

    sudo systemctl restart observiq-otel-collector
    
  2. Pastikan layanan sedang berjalan:

    sudo systemctl status observiq-otel-collector
    
  3. Periksa log untuk mengetahui error:

    sudo journalctl -u observiq-otel-collector -f
    

Windows

  1. Untuk memulai ulang agen Bindplane di Windows, pilih salah satu opsi berikut:

    • Menggunakan Command Prompt atau PowerShell sebagai administrator:

      net stop observiq-otel-collector && net start observiq-otel-collector
      
    • Menggunakan konsol Layanan:

      1. Tekan Win+R, ketik services.msc, lalu tekan Enter.
      2. Temukan observIQ Distro for OpenTelemetry Collector.
      3. Klik kanan, lalu pilih Mulai Ulang.
  2. Pastikan layanan sedang berjalan:

    sc query observiq-otel-collector
    
  3. Periksa log untuk mengetahui error:

    type "C:\Program Files\observIQ OpenTelemetry Collector\log\collector.log"
    

Mengonfigurasi penerusan syslog ManageEngine ADManager Plus

  1. Login ke ADManager Plus.
  2. Buka tab Admin.
  3. Di bagian System Settings, klik Integrations.
  4. Di bagian Log Forwarding, klik Syslog.

  5. Konfigurasi kolom berikut:

    • Syslog Server: Masukkan nama server syslog. Masukkan alamat IP atau nama host dari host agen Bindplane.
    • Port: Masukkan nomor port. Masukkan 514.
    • Protocol: Pilih protokol yang sesuai, TCP atau UDP, untuk meneruskan log. Pilih TCP.
    • Standar Syslog: Pilih format pesan syslog yang diinginkan, RFC 3164, RFC 5424, atau RawLog. Pilih RFC 5424 (direkomendasikan).
    • Format Data: Masukkan format data. Konfigurasi format data sesuai kebutuhan untuk lingkungan Anda.
  6. Klik Simpan untuk menyimpan konfigurasi.

Setelah konfigurasi, ADManager Plus akan mulai meneruskan log tindakan pengelolaan ke agen BindPlane, yang kemudian akan mengirimkannya ke Google SecOps.

Tabel pemetaan UDM

Kolom Log Pemetaan UDM Logika
ipPhone event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "ipPhone" dan nilai dari ipPhone jika ipPhone != ""
l event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "l" dan nilai dari l jika l != ""
lockoutTime event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "lockoutTime" dan nilai dari lockoutTime jika lockoutTime != ""
Pindah Dari event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "Pindah Dari" dan nilai dari Move_From jika Move_From != ""
Pindah Ke event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "Pindahkan Ke" dan nilai dari Move_To jika Move_To != ""
msg event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "member" dan nilai dari msg jika msg != ""
sn event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "sn" dan nilai dari sn jika sn != ""
st event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "st" dan nilai dari st jika st != ""
Nama Template event.idm.read_only_udm.additional.fields Digabungkan sebagai label dengan kunci "Template Name" dan nilai dari Template_Name jika Template_Name != ""
Status event.idm.read_only_udm.metadata.description Nilai diambil dari Status jika Status != ""
waktu event.idm.read_only_udm.metadata.event_timestamp Dikonversi dari format waktu ke stempel waktu jika waktu != ""
event.idm.read_only_udm.metadata.event_type Turunan: jika has_principal_user == "true" maka "USER_UNCATEGORIZED"; else if has_principal == "true" maka "STATUS_UPDATE"; else "GENERIC_EVENT"
TechnicianName event.idm.read_only_udm.metadata.product_event_type Nilai diambil dari TechnicianName jika TechnicianName != ""
event.idm.read_only_udm.metadata.product_name Disetel ke "ADMANAGER_PLUS"
event.idm.read_only_udm.metadata.vendor_name Disetel ke "ADMANAGER_PLUS"
Nama Domain event.idm.read_only_udm.principal.administrative_domain Nilai diambil dari Domain_Name jika Domain_Name != ""
hostname event.idm.read_only_udm.principal.asset.hostname Nilai diambil dari nama host jika nama host != ""
mail event.idm.read_only_udm.principal.email Nilai diambil dari email jika email != ""
hostname event.idm.read_only_udm.principal.hostname Nilai diambil dari nama host jika nama host != ""
co event.idm.read_only_udm.principal.location.city Nilai diambil dari co jika co != ""
Tugas event.idm.read_only_udm.principal.resource.name Nilai diambil dari Tugas jika Tugas != ""
wWWHomePage event.idm.read_only_udm.principal.url Nilai diambil dari wWWHomePage jika wWWHomePage != ""
Jenis Sandi event.idm.read_only_udm.principal.user.attribute.labels Digabungkan sebagai label dengan kunci "Password Type" dan nilai dari Password_Type jika Password_Type != ""
kodeNegara event.idm.read_only_udm.principal.user.attribute.labels Digabungkan sebagai label dengan kunci "countryCode" dan nilai dari countryCode jika countryCode != ""
sandi event.idm.read_only_udm.principal.user.attribute.labels Digabungkan sebagai label dengan kunci "password" dan nilai dari sandi jika sandi != ""
postalCode event.idm.read_only_udm.principal.user.attribute.labels Digabungkan sebagai label dengan kunci "postalCode" dan nilai dari postalCode jika postalCode != ""
primaryGroupID event.idm.read_only_udm.principal.user.attribute.labels Digabungkan sebagai label dengan kunci "primaryGroupID" dan nilai dari primaryGroupID jika primaryGroupID != ""
userAccountControl event.idm.read_only_udm.principal.user.attribute.labels Digabungkan sebagai label dengan kunci "userAccountControl" dan nilai dari userAccountControl jika userAccountControl != ""
userPrincipalName event.idm.read_only_udm.principal.user.attribute.labels Digabungkan sebagai label dengan kunci "userPrincipalName" dan nilai dari userPrincipalName jika userPrincipalName != ""
company event.idm.read_only_udm.principal.user.company_name Nilai diambil dari perusahaan jika perusahaan != ""
department event.idm.read_only_udm.principal.user.department Digabungkan dengan departemen jika departemen != ""
givenName event.idm.read_only_udm.principal.user.first_name Nilai diambil dari givenName jika givenName != ""
physicalDeliveryOfficeName event.idm.read_only_udm.principal.user.office_address.name Nilai diambil dari physicalDeliveryOfficeName jika physicalDeliveryOfficeName != ""
streetAddress event.idm.read_only_udm.principal.user.personal_address.name Nilai diambil dari streetAddress jika streetAddress != ""
homePhone event.idm.read_only_udm.principal.user.phone_numbers Digabungkan dengan homePhone jika homePhone != ""
Nama Pengguna event.idm.read_only_udm.principal.user.user_display_name Nilai diambil dari User_Name jika User_Name != ""; atau dari Object_Name jika Object_Name != ""
sAMAccountName event.idm.read_only_udm.principal.user.userid Nilai diambil dari sAMAccountName jika sAMAccountName != ""
TINDAKAN event.idm.read_only_udm.security_result.action_details Nilai diambil dari ACTION jika ACTION != ""
deskripsi event.idm.read_only_udm.security_result.description Nilai diambil dari deskripsi jika deskripsi != ""
Nama Container event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok container_Name: digabungkan sebagai label dengan kunci "Container_Name_DC_value1" dan nilai dari dc_label_1 jika dc_label_1 != ""
Nama Container event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok container_Name: digabungkan sebagai label dengan kunci "Container_Name_DC_value2" dan nilai dari dc_label_2 jika dc_label_2 != ""
Nama Container event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok container_Name: digabungkan sebagai label dengan kunci "Container_Name_OU_value1" dan nilai dari ou_label_1 jika ou_label_1 != ""
Nama Container event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok container_Name: digabungkan sebagai label dengan kunci "Container_Name_OU_value2" dan nilai dari ou_label_2 jika ou_label_2 != ""
Nama Container event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok container_Name: digabungkan sebagai label dengan kunci "Container_Name_OU_value3" dan nilai dari ou_label_3 jika ou_label_3 != ""
Grup Utama event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok Primary_Group: digabungkan sebagai label dengan kunci "Primary_Group_CN_value1" dan nilai dari cn_label_1 jika cn_label_1 != ""
Grup Utama event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok Primary_Group: digabungkan sebagai label dengan kunci "Primary_Group_CN_value2" dan nilai dari cn_label_2 jika cn_label_2 != ""
Grup Utama event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok Primary_Group: digabungkan sebagai label dengan kunci "Primary_Group_DC_value1" dan nilai dari primary_dc_label_1 jika primary_dc_label_1 != ""
Grup Utama event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok Primary_Group: digabungkan sebagai label dengan kunci "Primary_Group_DC_value2" dan nilai dari primary_dc_label_2 jika primary_dc_label_2 != ""
accountExpires event.idm.read_only_udm.security_result.detection_fields Digabungkan sebagai label dengan kunci "accountExpires" dan nilai dari accountExpires jika accountExpires != ""
pengelola event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok pengelola: digabungkan sebagai label dengan kunci "manager_cn_value1" dan nilai dari manager_cn_value1 jika manager_cn_value1 != ""
pengelola event.idm.read_only_udm.security_result.detection_fields Diperoleh dari pemahaman pengelola: digabungkan sebagai label dengan kunci "manager_dc_value1" dan nilai dari manager_dc_value1 jika manager_dc_value1 != ""
pengelola event.idm.read_only_udm.security_result.detection_fields Diperoleh dari pemahaman pengelola: digabungkan sebagai label dengan kunci "manager_dc_value2" dan nilai dari manager_dc_value2 jika manager_dc_value2 != ""
pengelola event.idm.read_only_udm.security_result.detection_fields Diperoleh dari grok pengelola: digabungkan sebagai label dengan kunci "manager_ou_value1" dan nilai dari manager_ou_value1 jika manager_ou_value1 != ""
pengelola event.idm.read_only_udm.security_result.detection_fields Diperoleh dari pemahaman pengelola: digabungkan sebagai label dengan kunci "manager_ou_value2" dan nilai dari manager_ou_value2 jika manager_ou_value2 != ""
pengelola event.idm.read_only_udm.security_result.detection_fields Diperoleh dari pemahaman pengelola: digabungkan sebagai label dengan kunci "manager_ou_value3" dan nilai dari manager_ou_value3 jika manager_ou_value3 != ""
pwdLastSet event.idm.read_only_udm.security_result.detection_fields Digabungkan sebagai label dengan kunci "pwdLastSet" dan nilai dari pwdLastSet jika pwdLastSet != ""
ModuleName event.idm.read_only_udm.target.resource.name Nilai diambil dari ModuleName jika ModuleName != ""

Perlu bantuan lebih lanjut? Dapatkan jawaban dari anggota Komunitas dan profesional Google SecOps.