收集 ForgeRock OpenAM 記錄
本文說明如何使用 Bindplane,將 ForgeRock OpenAM 記錄匯入 Google 安全作業。剖析器會從 CSV、Syslog + KV 或 JSON 格式的記錄中擷取欄位,並將其標準化,再對應至統一資料模型 (UDM)。它會處理各種 OpenAM 事件類型,包括登入/登出、存取結果和一般記錄,並利用使用者、群組和網路資訊豐富資料,同時針對不同的記錄格式和事件類型執行特定轉換。剖析器會優先剖析 JSON,然後改為 Syslog+KV,最後再改為 CSV,並捨棄不支援的格式記錄。
事前準備
請確認您已具備下列必要條件:
- Google SecOps 執行個體
- Windows 2016 以上版本,或支援
systemd
的 Linux 主機 - 如果在 Proxy 後方執行,防火牆通訊埠會開啟
- 具備 ForgeRock OpenAM 的特殊存取權 (例如 amAdmin)
取得 Google SecOps 擷取驗證檔案
- 登入 Google SecOps 控制台。
- 依序前往「SIEM 設定」>「收集代理程式」。
- 下載攝入驗證檔案。在要安裝 Bindplane 的系統上安全地儲存檔案。
取得 Google SecOps 客戶 ID
- 登入 Google SecOps 控制台。
- 依序前往「SIEM 設定」>「設定檔」。
- 複製並儲存「機構詳細資料」部分中的客戶 ID。
安裝 Bindplane 代理程式
請按照下列操作說明,在 Windows 或 Linux 作業系統上安裝 Bindplane 代理程式。
Windows 安裝
- 以系統管理員身分開啟命令提示字元或 PowerShell。
執行下列指令:
msiexec /i "https://github.com/observIQ/bindplane-agent/releases/latest/download/observiq-otel-collector.msi" /quiet
Linux 安裝
- 開啟具有 root 或 sudo 權限的終端機。
執行下列指令:
sudo sh -c "$(curl -fsSlL https://github.com/observiq/bindplane-agent/releases/latest/download/install_unix.sh)" install_unix.sh
其他安裝資源
如需其他安裝選項,請參閱安裝指南。
設定 Bindplane 代理程式,以便擷取 syslog 並傳送至 Google SecOps
- 存取設定檔:
- 找出
config.yaml
檔案。通常位於 Linux 的/etc/bindplane-agent/
目錄或 Windows 的安裝目錄中。 - 使用文字編輯器 (例如
nano
、vi
或記事本) 開啟檔案。
- 找出
按照下列方式編輯
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 ingestion_labels: log_type: 'OPENAM' raw_log_field: body service: pipelines: logs/source0__chronicle_w_labels-0: receivers: - udplog exporters: - chronicle/chronicle_w_labels
視基礎架構需求替換通訊埠和 IP 位址。
將
<customer_id>
替換為實際的客戶 ID。在「取得 Google SecOps 攝入驗證檔案」部分,將
/path/to/ingestion-authentication-file.json
更新為驗證檔案的儲存路徑。
重新啟動 Bindplane 代理程式以套用變更
如要在 Linux 中重新啟動 Bindplane 代理程式,請執行下列指令:
sudo systemctl restart bindplane-agent
如要在 Windows 中重新啟動 Bindplane 代理程式,您可以使用「Services」主控台,或輸入下列指令:
net stop BindPlaneAgent && net start BindPlaneAgent
在 ForgeRock OpenAM 中設定稽核記錄
- 登入 AM 控制台。
- 依序前往「設定」>「全球服務」>「稽核記錄」。
- 啟用稽核記錄功能,開始使用稽核記錄功能。
- 在「欄位許可清單篩選器」和「欄位封鎖清單篩選器」清單中,輸入要納入稽核事件記錄的值 (許可清單) 或要排除的值 (封鎖清單)。
- 按一下 [儲存]。
設定 Forgerock OpenAM 的 Syslog 處理常式
- 以管理員身分 (例如 amAdmin) 登入 AM 控制台。
- 如要在全域設定中建立事件處理常式,請依序前往「設定」>「全球服務」>「稽核記錄」。
- 如要在Realm 中建立事件處理常式,請依序前往「Realm」>「Realm 名稱」>「服務」>「稽核記錄」。
- 依序點選「新增次要設定」>「Syslog」。
- 提供下列設定詳細資料:
- 名稱:輸入事件處理常式的名稱 (例如 Google SecOps
Syslog Event Handler
)。 - 伺服器主機名稱:輸入 Bindplane 代理程式 IP 位址。
- 伺服器通訊埠:輸入 Bindplane 代理程式通訊埠編號 (例如 UDP 的
514
)。 - 傳輸通訊協定:選取「UDP」。
- 連線逾時:輸入連線的秒數 (例如
120
)。 - 選用:啟用「Buffering」選項。
- 名稱:輸入事件處理常式的名稱 (例如 Google SecOps
- 按一下 [建立]。
- 建立 syslog 稽核事件處理程序後,系統會顯示多個設定分頁。
- 在「一般處理常規設定」分頁中,選取「已啟用」,啟用事件處理常規 (如果未啟用)。
- 選取稽核記錄的主題:
- 存取
- 活動
- 驗證
- 設定
- 按一下 [儲存]。
- 在「Syslog Configuration」分頁中,提供下列設定詳細資料:
- 伺服器主機名稱:輸入 Bindplane 代理程式 IP 位址。
- 伺服器通訊埠:輸入 Bindplane 代理程式通訊埠號碼。
- 連線逾時:輸入連線的秒數 (例如
120
)。 - 傳輸通訊協定:選取「UDP」UDP。
- 設施:選取「Local0」Local0。
- 所有主題都將嚴重性設為「資訊」。
- 按一下 [儲存]。
在「緩衝」分頁中,選取「啟用緩衝」即可啟用。
按一下 [儲存]。
UDM 對應表
記錄欄位 | UDM 對應 | 邏輯 |
---|---|---|
client.ip |
principal.ip |
提出要求的用戶端 IP 位址。 |
client.ip |
principal.asset.ip |
提出要求的用戶端資產 IP 位址。 |
client.port |
principal.port |
提出要求的用戶端所使用的通訊埠。 |
entries[0].info.authLevel |
principal.resource.resource_subtype |
與事件相關聯的驗證層級。開頭為「authLevel:」。 |
entries[0].info.displayName |
security_result.description |
驗證樹狀結構中節點的描述性名稱。 |
entries[0].info.ipAddress |
principal.asset.ip |
與事件中主要使用者相關聯的 IP 位址。 |
entries[0].info.ipAddress |
principal.ip |
與事件中主要使用者相關聯的 IP 位址。 |
entries[0].info.nodeId |
principal.resource.id |
驗證樹狀結構中的節點專屬 ID。前面加上「nodeId:」。 |
entries[0].info.nodeOutcome |
principal.resource.attribute.labels.value |
驗證樹狀圖中的節點結果。 |
entries[0].info.nodeType |
principal.resource.type |
驗證樹狀結構中的節點類型。前面會加上「nodeType:」。 |
entries[0].info.treeName |
principal.resource.name |
驗證樹狀結構的名稱。前面加上「treeName:」。 |
eventName |
metadata.product_event_type |
OpenAM 記錄檔中的原始事件名稱。 |
http.request.headers.host[0] |
target.asset.hostname |
從 host 標頭中擷取的目標伺服器主機名稱。 |
http.request.headers.host[0] |
target.hostname |
從 host 標頭中擷取的目標伺服器主機名稱。 |
http.request.headers.user-agent[0] |
network.http.user_agent |
HTTP 要求的使用者代理程式。 |
http.request.method |
network.http.method |
要求中使用的 HTTP 方法。 |
http.request.path |
target.url |
HTTP 要求網址的路徑。 |
info.failureReason |
security_result.summary |
驗證失敗的原因。已硬式編碼為「SSO」。取決於根據 eventName 和其他欄位建立的邏輯。可以是 GENERIC_EVENT 、USER_LOGIN 、USER_LOGOUT 、NETWORK_HTTP 或 STATUS_UPDATE 。已硬式編碼為「OPENAM」。已硬式編碼為「OpenAM」。已硬式編碼為「ForgeRock」。 |
principal |
target.user.userid |
事件中涉及的使用者 ID,可從 userId 、principal 或 runAs 欄位中擷取。 |
result |
security_result.action_details |
事件的結果 (例如「SUCCESSFUL」或「FAILED」)。 |
response.detail.reason |
security_result.summary |
存取結果事件失敗的原因。 |
response.status |
security_result.action_details |
存取結果事件中的回應狀態。 |
runAs |
target.user.userid |
事件中涉及的使用者 ID,可從 userId 、principal 或 runAs 欄位擷取。 |
security_result.action |
security_result.action |
安全性事件的結果 (例如「ALLOW」、「BLOCK」)。 |
server.ip |
target.asset.ip |
目標伺服器的 IP 位址。 |
server.ip |
target.ip |
目標伺服器的 IP 位址。 |
server.port |
target.port |
目標伺服器的通訊埠。 |
timestamp |
metadata.event_timestamp |
事件的時間戳記。 |
trackingIds |
metadata.product_log_id |
與事件相關聯的追蹤 ID。 |
transactionId |
metadata.product_deployment_id |
與事件相關聯的交易 ID。 |
userId |
target.user.userid |
事件中涉及的使用者 ID,可從 userId 、principal 或 runAs 欄位中擷取。 |
userId |
target.user.group_identifiers |
與使用者相關聯的群組 ID。 |
am_group |
target.user.group_identifiers |
與使用者相關聯的群組 ID。 |
am_user |
target.user.email_addresses |
使用者的電子郵件地址 (如果在 am_user 欄位中出現)。 |
loginID[0] |
target.user.userid |
事件中使用的登入 ID。 |
loginID[0] |
target.user.email_addresses |
用於登入的電子郵件地址 (如果在 loginID 欄位中出現)。 |
hostip |
intermediary.hostname |
中介裝置的主機名稱。 |
hostip |
intermediary.ip |
中介裝置的 IP 位址。 |
src_ip |
principal.asset.ip |
來源 IP 位址。 |
src_ip |
principal.ip |
來源 IP 位址。 |
desc |
metadata.description |
事件的說明。 |
payload |
metadata.description |
事件的酬載。 |
還有其他問題嗎?向社群成員和 Google SecOps 專家尋求解答。