Imperva CEF ログを収集する

以下でサポートされています。

このドキュメントでは、Bindplane を使用して Imperva CEF ログを Google Security Operations に取り込む方法について説明します。パーサーは、Syslog メッセージから CEF 形式のログを抽出し、UDM 形式に変換します。さまざまなログ形式を処理し、ペイロードから Key-Value ペアを抽出し、データ変換と拡充を行い、抽出されたフィールドを対応する UDM フィールド(ネットワーク情報、ユーザーの詳細、位置情報、セキュリティ結果など)にマッピングします。

始める前に

次の前提条件を満たしていることを確認してください。

  • Google SecOps インスタンス
  • Windows 2016 以降、または systemd を使用する Linux ホスト
  • プロキシの背後で実行している場合は、Bindplane エージェントの要件に従ってファイアウォール ポートが開いていることを確認します。
  • Imperva 管理コンソールまたはアプライアンスへの特権アクセス

Google SecOps の取り込み認証ファイルを取得する

  1. Google SecOps コンソールにログインします。
  2. [SIEM 設定] > [コレクション エージェント] に移動します。
  3. Ingestion Authentication File をダウンロードします。Bindplane をインストールするシステムにファイルを安全に保存します。

Google SecOps のお客様 ID を取得する

  1. Google SecOps コンソールにログインします。
  2. [SIEM 設定] > [プロファイル] に移動します。
  3. [組織の詳細情報] セクションから [お客様 ID] をコピーして保存します。

Bindplane エージェントをインストールする

次の手順に沿って、Windows または Linux オペレーティング システムに Bindplane エージェントをインストールします。

Windows のインストール

  1. 管理者として コマンド プロンプトまたは PowerShell を開きます。
  2. 次のコマンドを実行します。

    msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
    

Linux のインストール

  1. root 権限または sudo 権限でターミナルを開きます。
  2. 次のコマンドを実行します。

    sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
    

その他のインストール リソース

Syslog を取り込んで Google SecOps に送信するように Bindplane エージェントを構成する

  1. 構成ファイルにアクセスします。

    1. config.yaml ファイルを見つけます。通常、Linux では /etc/bindplane-agent/ ディレクトリに、Windows ではインストール ディレクトリにあります。
    2. テキスト エディタ(nanovi、メモ帳など)を使用してファイルを開きます。
  2. config.yaml ファイルを次のように編集します。

    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: 'IMPERVA_CEF'
        raw_log_field: body
        ingestion_labels:
    
    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 エージェントを再起動するには、Services コンソールを使用するか、次のコマンドを入力します。

    net stop BindPlaneAgent && net start BindPlaneAgent
    

syslog 経由で CEF を送信するように Imperva WAF Gateway(SecureSphere)を構成する

  1. MX コンソールで、アクション セットを作成します。

    • [Policies](ポリシー) > [Action Sets](アクション セット) に移動します。
    • [新規] をクリックして名前を付けます(例: Google SecOps CEF)。
  2. CEF syslog アクション インターフェースを追加します。

    • [利用可能なアクション インターフェース] で [システムログ] を開き、必要に応じて次の 1 つ以上を追加します。
      • CEF 標準を使用してセキュリティ イベントをシステムログ(syslog)に記録する
      • CEF 標準を使用してネットワーク セキュリティ イベントをシステムログ(syslog)に記録する
      • CEF 標準を使用してシステム イベントをシステムログ(syslog)に記録する
      • CEF 標準を使用してカスタム セキュリティ イベントをシステムログ(syslog)に記録する
  3. Action Interface のパラメータを構成します。

    • Syslog ホスト: Bindplane エージェントの IP アドレスを入力します。デフォルト以外のポートを使用するには、:PORT を追加します(指定しない場合のデフォルトは 514 です)。例: 10.0.0.10:514
    • ファシリティ / ログレベル: ポリシーの要件に従って設定します。
    • メッセージ: カスタム マッピングがない限り、CEF のベンダーのデフォルトのままにします。
  4. アクション セットをポリシーにアタッチします。

    • セキュリティ / ネットワーク セキュリティ イベントの場合: 関連するポリシーを開き、[実行されたアクション] をアクション セットに設定します。
    • システム イベントの場合: システム イベント ポリシーを作成または確認し、[Followed Action] をアクション セットに設定して、これらのイベントも CEF 経由で送信されるようにします。
  5. 省略可: ゲートウェイ固有のターゲットを構成します。

    • 異なるゲートウェイ グループが異なる syslog サーバーに送信する必要がある場合は、各 [Gateway Group] > [External Logger] を構成し、ポリシーで [Use gateway configuration if exists] を有効にします。

UDM マッピング テーブル

ログフィールド UDM マッピング ロジック
act security_result.action 派生。act が「allowed」、「alert」、「REQ_PASSED」で始まる、または「REQ_CACHED」で始まる場合、action は「ALLOW」です。act が「deny」、「blocked」、「REQ_BLOCKED」で始まる文字列、または「REQ_CHALLENGE」で始まる文字列の場合、action は「BLOCK」になります。act が正規表現 (?i)REQ_BAD と一致する場合、action は「FAIL」になります。それ以外の場合、action は「UNKNOWN_ACTION」になります。次に、security_result.actionaction の値に設定されます。
act security_result.action_details 派生。act の値に基づいて、詳細な説明が生成されます。例: 「REQ_CACHED_FRESH: レスポンスがデータセンターのキャッシュから返されました」、「REQ_BLOCKED: リクエストがブロックされました」。
app network.application_protocol 大文字に変換された後、直接マッピングされます。
cs1 security_result.detection_fields.value cs1 が空でないか「NA」でない場合、条件付きでマッピングされます。security_result.detection_fields.keycs1Label の値に設定されます。
cs1Label security_result.detection_fields.key cs1 が空でないか「NA」でない場合、条件付きでマッピングされます。security_result.detection_fields.valuecs1 の値に設定されます。
cs2 security_result.detection_fields.value 空でない場合は条件付きでマッピングされます。security_result.detection_fields.keycs2Label の値に設定されます。
cs2Label security_result.detection_fields.key cs2 が空でない場合は条件付きでマッピングされます。security_result.detection_fields.valuecs2 の値に設定されます。
cs3 security_result.detection_fields.value 空でないか「-」でない場合、条件付きでマッピングされます。security_result.detection_fields.keycs3Label の値に設定されます。
cs3Label security_result.detection_fields.key cs3 が空でないか「-」でない場合、条件付きでマッピングされます。security_result.detection_fields.valuecs3 の値に設定されます。
cs4 security_result.detection_fields.value 空でない場合は条件付きでマッピングされます。security_result.detection_fields.keycs4Label の値に設定されます。
cs4Label security_result.detection_fields.key cs4 が空でない場合は条件付きでマッピングされます。security_result.detection_fields.valuecs4 の値に設定されます。
cs5 security_result.detection_fields.value 空でない場合は条件付きでマッピングされます。security_result.detection_fields.keycs5Label の値に設定されます。
cs5Label security_result.detection_fields.key cs5 が空でない場合は条件付きでマッピングされます。security_result.detection_fields.valuecs5 の値に設定されます。
cs6 security_result.detection_fields.value 空でない場合は条件付きでマッピングされます。security_result.detection_fields.keycs6Label の値に設定されます。
cs6Label security_result.detection_fields.key cs6 が空でない場合は条件付きでマッピングされます。security_result.detection_fields.valuecs6 の値に設定されます。
cs7 principal.location.region_latitude cs7Label が「latitude」の場合、条件付きでマッピングされます。
cs8 principal.location.region_longitude cs8Label が「longitude」の場合、条件付きでマッピングされます。
cn1 security_result.detection_fields.value 空でなく、cn1Label が空でない場合、条件付きでマッピングされます。security_result.detection_fields.keycn1Label の値に設定されます。
cn1Label security_result.detection_fields.key cn1cn1Label が空でない場合、条件付きでマッピングされます。security_result.detection_fields.valuecn1 の値に設定されます。
fileType security_result.detection_fields.value 空でない場合は条件付きでマッピングされます。security_result.detection_fields.key は「fileType」に設定されます。
filePermission security_result.detection_fields.value 空でない場合は条件付きでマッピングされます。security_result.detection_fields.key は「filePermission」に設定されます。
request target.url 直接マッピングされます。
requestClientApplication network.http.user_agent 空でない場合は条件付きでマッピングされます。CEF ペイロードの requestContext または requestClientApplication Key-Value ペアから抽出された user_agent フィールドからマッピングされた値を上書きします。
requestMethod network.http.method 直接マッピングされます。
siteid security_result.detection_fields.value 空でない場合は条件付きでマッピングされます。security_result.detection_fields.key は「siteid」に設定されています。
sourceServiceName target.hostname 直接マッピングされます。dhost が存在する場合は、その値を上書きします。
src principal.ip 直接マッピングされます。
start metadata.event_timestamp.seconds Grok パターンを使用して抽出され、タイムスタンプに変換されます。deviceReceiptTime が存在しない場合、フォールバックとして使用されます。deviceReceiptTimestart の両方が空の場合、ログのタイムスタンプが使用されます。
suid principal.user.userid 空でない場合、条件付きでマッピングされます。
なし metadata.event_type 「NETWORK_HTTP」にハードコードされています。
なし metadata.log_type 最上位の log_type フィールドから直接マッピングされます。
なし metadata.product_event_type 空でない場合、csv.event_id からマッピングされます。
なし metadata.product_name 「Web Application Firewall」にハードコードされています。
なし metadata.vendor_name 「Imperva」にハードコードされています。

さらにサポートが必要な場合 コミュニティ メンバーや Google SecOps のプロフェッショナルから回答を得ることができます。