自訂轉換函式和邏輯運算子
您可以在 IDE 中直接建立以 Python 為基礎的自訂轉換函式和邏輯運算子,並在應對手冊中使用,因應複雜多變的使用情境。
擴充包
擴充功能套件是一種特殊整合類型,可做為自訂轉換函式和邏輯運算子的容器。與標準整合不同,擴充功能套件不需要執行個體設定,可以直接從 IDE 建立。
擴充功能套件的最佳做法
- 合併:建立一個主要擴充功能套件,並在其中新增多個轉換函式或邏輯運算子。
- 分離:需要一組可能與主要套件衝突的不同 Python 程式庫 (依附元件) 時,請建立新的擴充套件。
建立擴充功能套件
如要建立新的擴充功能套件,請按照下列步驟操作:
- 依序前往「回應」> IDE。
- 按一下「新增」 「建立新項目」。
- 從下拉式選單中選取「擴充套件」。
- 為擴充套件提供專屬名稱。
- 按一下 [儲存]。
上傳依附元件
與標準整合功能一樣,擴充套件會在虛擬環境中執行,您可以在其中管理 Python 程式庫。
如要管理程式庫,請按照下列步驟操作:
- 在 IDE 中開啟 Extension Pack 設定。
- 從 PyPi 新增必要的 Python 程式庫,或從電腦上傳。
這個特定擴充功能套件中的所有轉換器和邏輯運算子,都能使用這些依附元件。
匯入與匯出
您可以在 IDE 介面中手動匯入及匯出擴充功能套件。
自訂轉換器
自訂轉換器是使用者定義的 Python 函式,可擴充運算式建立工具中的預先建構函式。您可以在 IDE 中直接建立這些函式,用於擷取及處理資料,並與現有的內建函式搭配使用。
建立自訂轉換器
如要定義新的自訂轉換器,請按照下列步驟操作:
- 在 IDE 中,找出目標擴充功能套件。
- 選取目標擴充功能套件,在套件下方新增項目。
- 選取「自訂轉換函式」。
- 輸入名稱。
- 新增說明 (如有需要)。將游標懸停在運算式製作工具中的自訂轉換器上時,就會顯示這項資訊。
- 使用 Python 定義指令碼邏輯。您可以從提供的預設範本開始著手。
- 如預先定義的範本所示,指令碼必須包含
main函式。 - 指令碼必須使用 SDK
end函式,將結果傳回給運算式建構工具。 - 自訂轉換器的輸入內容可以是不同類型 (例如字串或清單)。請務必在
main函式中,將其轉換為預期類型。 - 您只能在 IDE 中使用 SDK 方法的子集,用於轉換器:
transformer.extract_param("ParamName"):用於擷取輸入值。transformer.LOGGER:用於寫入偵錯記錄。transformer.end(result):傳回轉換後的值。
- 如預先定義的範本所示,指令碼必須包含
- 建立參數:
- 每個自訂轉換器函式都包含預設的 Input 參數。這個參數代表輸入資料,也就是函式套用的預留位置。您無法刪除這項參數。
- 此外,您也可以新增要在函式中使用的選用參數。
- 文件 (選用):為運算式產生器定義產品內文件:
- 預期輸入:說明函式預期接收的轉換器資料類型 (例如「字串」或「字串清單」)。
- 預期輸出內容:說明函式預期會為這個轉換器傳回的資料類型 (例如「布林值」)。
- 使用範例:提供如何叫用函式的範例 (例如
if_empty("new_value"))。
您可以在 IDE 中直接測試自訂轉換函式邏輯,再將其用於劇本。這可讓您確認 Python 指令碼是否能正確處理各種輸入類型和參數,並傳回預期結果。
逾時
- 預設逾時時間:1 分鐘。
- 最長逾時時間:3 分鐘。
在運算式建立工具中使用自訂轉換器
儲存後,自訂轉換器會與內建函式一起顯示在運算式建構工具的函式清單中。格式如下:
ExtensionPackName.TransformerName。將游標懸停在函式上,即可查看根據參數說明產生的說明文件。
支援所有預留位置 (JSON 和非 JSON)
運算式建構工具支援 Playbook 設計工具中顯示的所有預留位置,包括非 JSON 結果。
非 JSON 預留位置:
- 您可以在運算式產生器中手動輸入範例資料,針對各種輸入類型 (字串、清單 (以半形逗號分隔的值) 和 JSON) 測試邏輯。
- 使用輸入型別進行測試,無法保證預留位置會在執行階段傳回該特定型別。
- 大多數預留位置都會解析為字串,但特定類型會根據數量解析為字串或清單 (例如
entity.identifier)。建議一律將這些類型的輸入內容視為清單。
處理錯誤
如果自訂轉換函式在執行期間發生錯誤,使用該轉換器的劇本動作就會失敗。Python 指令碼產生的特定錯誤訊息會顯示在劇本執行檢視畫面中,方便您直接排解邏輯問題。
自訂邏輯運算子
自訂邏輯運算子可讓您定義自己的布林邏輯,用於比較值。
建立自訂邏輯運算子
如要定義新的邏輯運算子,請按照下列步驟操作:
- 在 IDE 中找出目標「擴充功能套件」。
- 選取「自訂邏輯運算子」。
- 輸入名稱。
- 選用:在 Playbook 設計工具中,為邏輯運算子選單新增說明。
- 使用 Python 定義指令碼邏輯。您可以從提供的預先定義範本開始著手。
- 指令碼必須包含
main函式。 - 指令碼必須使用 SDK
end函式,將布林結果傳回條件。 - 您只能在 IDE 中使用 SDK 方法的子集,用於邏輯運算子:
logical_operator.extract_param("ParamName"):用於擷取輸入值。logical_operator.LOGGER:用於寫入偵錯記錄。logical_operator.end(result):結果為布林值 (true或false)。
- 指令碼必須包含
您可以在 IDE 中直接測試自訂邏輯運算子邏輯。您可以輸入引數的測試值,並根據定義的條件,驗證函式是否傳回正確的布林值 (True 或 False) 結果。
參數
自訂邏輯運算子會接受兩個參數:「左側」 (必要且無法編輯) 和「右側」 (選用,使用者可以停用)。
- 範例 1:
if [left side] not in [right side] - 範例 2:
if [left side] is greater than 80(右側沒有)。
逾時
- 預設逾時時間:1 分鐘。
- 最長逾時時間:3 分鐘。
用於應對手冊
自訂邏輯運算子會顯示在「劇本條件」、「先前動作條件」和「實體選取」的運算子選單中。
自訂邏輯運算子可與標準運算子 (例如「等於」或「包含」) 一併選取。
處理錯誤
如果自訂邏輯運算子函式在執行期間發生錯誤,使用該運算子的劇本條件或步驟就會失敗。Python 指令碼傳回的錯誤訊息會顯示在劇本執行檢視畫面中,協助排解問題。
限制
- 觸發條件或網路鉤子不支援自訂轉換函式和邏輯運算子。
還有其他問題嗎?向社群成員和 Google SecOps 專業人員尋求答案。