fix(策略对象新增):关键字单元,扩展类字符串单元修改为dict方式传入
This commit is contained in:
@@ -4,6 +4,7 @@ Library Collections
|
||||
Resource ../../../03-Variable/BifangApiVariable.txt
|
||||
Resource ../../../03-Variable/PolicyObjectDefault.txt
|
||||
Resource ../../tsg_common/ManageObjectBody.robot
|
||||
*** Variables ***
|
||||
*** Keywords ***
|
||||
ObjectListOperation
|
||||
[Documentation]
|
||||
@@ -14,7 +15,7 @@ ObjectListOperation
|
||||
... 多个对象处理
|
||||
|
||||
[Arguments] ${returnData} ${objectList} ${opAction}
|
||||
Log To Console Call ObjectListOperation
|
||||
Log Call ObjectListOperation
|
||||
${objectListJson} Set Variable [
|
||||
FOR ${object} IN @{objectList}
|
||||
${json} ObjectOrganize ${object} ${opAction}
|
||||
@@ -37,7 +38,7 @@ ObjectOperation
|
||||
... 单个策略处理
|
||||
|
||||
[Arguments] ${returnData} ${object} ${opAction}
|
||||
Log To Console Call ObjectOperation
|
||||
Log Call ObjectOperation
|
||||
${json} ObjectOrganize ${object} ${opAction}
|
||||
# 转为json结构并返回
|
||||
${dict} Create Dictionary opAction=${opAction} returnData=${returnData} objectList=replace:objectList
|
||||
@@ -62,7 +63,7 @@ ObjectOrganize
|
||||
... 其它参数默认值见../../03-Variable/PolicyObjectDefault.txt
|
||||
... 单个策略转换为json
|
||||
[Arguments] ${object} ${opAction}
|
||||
Log To Console Call ObjectOrganize
|
||||
Log Call ObjectOrganize
|
||||
${emptyList} Create List
|
||||
${returnDict} Create Dictionary
|
||||
# 断言必传参数
|
||||
@@ -108,7 +109,9 @@ ObjectOrganize
|
||||
${return} ${subObjectIds} Run Keyword And Ignore Error Get From Dictionary ${object} subObjectIds
|
||||
Run Keyword If "${return}"!="FAIL" and "${subObjectIds}"!="${EMPTY}" and "${subObjectIds}"!="${None}" Set To Dictionary ${returnDict} subObjectIds=${subObjectIds}
|
||||
... ELSE Set Variable ${emptyList}
|
||||
|
||||
|
||||
${return} ${iconColor} Run Keyword And Ignore Error Set Variable ${object['iconColor']}
|
||||
Run Keyword If "${return}"!="FAIL" Set To Dictionary ${returnDict} iconColor=${iconColor}
|
||||
#补充ip learning对象
|
||||
${return} ${fromFqdns} Run Keyword And Ignore Error Get From Dictionary ${object} fromFqdns
|
||||
Run Keyword If "${return}"!="FAIL" Set To Dictionary ${returnDict} fromFqdns=${fromFqdns}
|
||||
@@ -131,11 +134,11 @@ ObjectOrganize
|
||||
#... ELSE Set To Dictionary ${returnDict} learnedIpLimit=${Default_learnedIpLimit}
|
||||
# 处理AddItemList
|
||||
${return} ${addItemList} Run Keyword And Ignore Error Get From Dictionary ${object} addItemList
|
||||
Run Keyword If "${return}"!="FAIL" and "${addItemList}"!="${EMPTY}" ManageAddItemList ${object} ${returnDict}
|
||||
Run Keyword If "${return}"!="FAIL" and "${addItemList}"!="${EMPTY}" ManageAddItemListNew ${addItemList} ${returnDict} ${objectTypeV} ${objectSubType}
|
||||
|
||||
# 处理UpdateItemList
|
||||
${return} ${updateItemList} Run Keyword And Ignore Error Get From Dictionary ${object} updateItemList
|
||||
Run Keyword If "${opAction}"=="update" and "${return}"!="FAIL" and "${updateItemList}"!="${EMPTY}" ManageUpdateItemList ${updateItemList} ${returnDict}
|
||||
Run Keyword If "${opAction}"=="update" and "${return}"!="FAIL" and "${updateItemList}"!="${EMPTY}" ManageUpdateItemList ${updateItemList} ${returnDict} ${objectTypeV} ${objectSubType}
|
||||
# 处理deleteItemIds
|
||||
${return} ${deleteItemIds} Run Keyword And Ignore Error Get From Dictionary ${object} deleteItemIds
|
||||
Run Keyword If "${opAction}"=="update" and "${return}"!="FAIL" and "${deleteItemIds}"!="${EMPTY}" ManageDeleteItemIds ${deleteItemIds} ${returnDict}
|
||||
@@ -152,11 +155,137 @@ ManageEnableAndDisable
|
||||
${json} json.Dumps ${returnDict} ensure_ascii=False
|
||||
Log Object-${json}
|
||||
[Return] ${json}
|
||||
ManageAddItemListNew
|
||||
# 处理addItemList数组
|
||||
[Arguments] ${addItemList} ${returnDict} ${type} ${subType}
|
||||
Log Call ManageAddItemListNew
|
||||
${itemList} Create List
|
||||
FOR ${item} IN @{addItemList}
|
||||
${itemNew} Run Keyword If '${type}'=='ip' ManageIpItem ${item} ${subType} add
|
||||
... ELSE IF '${type}'=='url' or '${type}'=='fqdn' or '${type}'=='keywords' or '${type}'=='subscriberid' or '${type}'=='fqdn_category' or '${type}'=='account' or '${type}'=='app_id'
|
||||
... ManageStrItem ${item} ${type} add
|
||||
... ELSE IF '${type}'=='file_type' ManageFileItem ${item} ${type} add
|
||||
... ELSE IF '${type}'=='http_signature' ManageExtensionStrItem ${item} ${type} add
|
||||
... ELSE IF '${type}'=='file_size' or '${type}'=='file_integrity_rate' ManageNumberItem ${item} ${type} add
|
||||
... ELSE Fail
|
||||
Append To List ${itemList} ${itemNew}
|
||||
END
|
||||
Set To Dictionary ${returnDict} addItemList=${itemList}
|
||||
|
||||
ManageUpdateItemList
|
||||
[Documentation]
|
||||
... 处理updateItemList
|
||||
[Arguments] ${updateItemList} ${returnDict}
|
||||
Set To Dictionary ${returnDict} updateItemList=${updateItemList}
|
||||
[Arguments] ${updateItemList} ${returnDict} ${type} ${subType}
|
||||
${itemList} Create List
|
||||
FOR ${item} IN @{updateItemList}
|
||||
${itemId} Get From Dictionary ${item} itemId
|
||||
|
||||
${itemNew} Run Keyword If '${type}'=='ip' ManageIpItem ${item} ${subType} update
|
||||
... ELSE IF '${type}'=='url' or '${type}'=='fqdn' or '${type}'=='keywords' or '${type}'=='subscriberid' or '${type}'=='fqdn_category' or '${type}'=='account' or '${type}'=='app_id'
|
||||
... ManageStrItem ${item} ${type} update
|
||||
... ELSE IF '${type}'=='file_type' ManageFileItem ${item} ${type} update
|
||||
... ELSE IF '${type}'=='http_signature' ManageExtensionStrItem ${item} ${type} update
|
||||
... ELSE IF '${type}'=='file_size' or '${type}'=='file_integrity_rate' ManageNumberItem ${item} ${type} update
|
||||
... ELSE Fail
|
||||
Set To Dictionary ${itemNew} itemId=${itemId}
|
||||
#由于接口更新时是否内置字段会导致40014001,策略对象单元不可改是否为内置(isInitialize)参数状态,这里去掉是否内置字段
|
||||
Remove From Dictionary ${itemNew} isInitialize
|
||||
Append To List ${itemList} ${itemNew}
|
||||
END
|
||||
Set To Dictionary ${returnDict} updateItemList=${itemList}
|
||||
ManageIpItem
|
||||
[Documentation]
|
||||
... ip item处理
|
||||
[Arguments] ${item} ${subType} ${action}
|
||||
Log Call ManageIpItem
|
||||
${return} ${isSession} Run Keyword And Ignore Error Get From Dictionary ${item} isSession
|
||||
${isSession} Run Keyword If "${return}"!="FAIL" Set Variable ${isSession} ELSE Set Variable ${EMPTY}
|
||||
Run Keyword If "${action}"=="add" Should Not Be Empty ${isSession}
|
||||
${return} ${ip} Run Keyword And Ignore Error Get From Dictionary ${item} ip
|
||||
${ip} Run Keyword If "${return}"!="FAIL" Set Variable ${ip} ELSE Set Variable ${EMPTY}
|
||||
Run Keyword If "${action}"=="add" Should Not Be Empty ${ip}
|
||||
${return} ${port} Run Keyword And Ignore Error Get From Dictionary ${item} port
|
||||
Run Keyword If "${action}"=="add" Should Not Be Empty ${port}
|
||||
Run Keyword If "${action}"=="add" Dictionary Should Contain Key ${item} direction
|
||||
${return} ${direction} Run Keyword And Ignore Error Get From Dictionary ${item} direction
|
||||
${direction} Run Keyword If "${return}"!="FAIL" Set Variable ${direction} ELSE Set Variable ${EMPTY}
|
||||
Run Keyword If "${action}"=="add" Dictionary Should Contain Key ${item} protocol
|
||||
${return} ${protocol} Run Keyword And Ignore Error Get From Dictionary ${item} protocol
|
||||
${protocol} Run Keyword If "${return}"!="FAIL" Set Variable ${protocol} ELSE Set Variable ${EMPTY}
|
||||
${return} ${isInitialize} Run Keyword And Ignore Error Set Variable ${item['isInitialize']}
|
||||
${isInitialize} Run Keyword If "${return}"!="FAIL" Set Variable ${isInitialize}
|
||||
... ELSE Set Variable ${EMPTY}
|
||||
${return} ${itemName} Run Keyword And Ignore Error Set Variable ${item['itemName']}
|
||||
${itemName} Run Keyword If "${return}"!="FAIL" Set Variable ${itemName}
|
||||
... ELSE Set Variable ${EMPTY}
|
||||
${return} ${itemDesc} Run Keyword And Ignore Error Set Variable ${item['itemDesc']}
|
||||
${itemDesc} Run Keyword If "${return}"!="FAIL" Set Variable ${itemDesc}
|
||||
... ELSE Set Variable ${EMPTY}
|
||||
${itemNew} Create Dictionary
|
||||
Run Keyword If "${isSession}"!="${EMPTY}" Set To Dictionary ${itemNew} isSession=${isSession}
|
||||
Run Keyword If "${ip}"!="${EMPTY}" Set To Dictionary ${itemNew} ip=${ip}
|
||||
Run Keyword If "${port}"!="${EMPTY}" Set To Dictionary ${itemNew} port=${port}
|
||||
Run Keyword If "${direction}"!="${EMPTY}" Set To Dictionary ${itemNew} direction=${direction}
|
||||
Run Keyword If "${protocol}"!="${EMPTY}" Set To Dictionary ${itemNew} protocol=${protocol}
|
||||
Run Keyword If "${isInitialize}"!="${EMPTY}" Set To Dictionary ${itemNew} isInitialize=${isInitialize}
|
||||
Run Keyword If "${itemName}"!="${EMPTY}" Set To Dictionary ${itemNew} itemName=${itemName}
|
||||
Run Keyword If "${itemDesc}"!="${EMPTY}" Set To Dictionary ${itemNew} itemDesc=${itemDesc}
|
||||
[Return] ${itemNew}
|
||||
ManageStrItem
|
||||
[Documentation]
|
||||
... 字符串item处理
|
||||
[Arguments] ${item} ${type} ${action}
|
||||
Log Call ManageStrItem
|
||||
${return} ${keywordArray} Run Keyword And Ignore Error Set Variable ${item['keywordArray']}
|
||||
${keywordArray} Run Keyword If "${return}"!="FAIL" Set Variable ${keywordArray} ELSE Set Variable ${EMPTY}
|
||||
Run Keyword If "${action}"=="add" Should Not Be Empty ${keywordArray}
|
||||
${array} Evaluate re.split('[,]', '${keywordArray}') re
|
||||
|
||||
Run Keyword If "${action}"=="add" Dictionary Should Contain Key ${item} isHexbin
|
||||
${return} ${isHexbin} Run Keyword And Ignore Error Get From Dictionary ${item} isHexbin
|
||||
${isHexbin} Run Keyword If "${return}"!="FAIL" Set Variable ${isHexbin}
|
||||
... ELSE Set Variable ${EMPTY}
|
||||
|
||||
${return} ${isInitialize} Run Keyword And Ignore Error Set Variable ${item['isInitialize']}
|
||||
${isInitialize} Run Keyword If "${return}"!="FAIL" Set Variable ${isInitialize}
|
||||
... ELSE Set Variable ${EMPTY}
|
||||
${return} ${itemName} Run Keyword And Ignore Error Set Variable ${item['itemName']}
|
||||
${itemName} Run Keyword If "${return}"!="FAIL" Set Variable ${itemName}
|
||||
... ELSE Set Variable ${EMPTY}
|
||||
${return} ${itemDesc} Run Keyword And Ignore Error Set Variable ${item['itemDesc']}
|
||||
${itemDesc} Run Keyword If "${return}"!="FAIL" Set Variable ${itemDesc}
|
||||
... ELSE Set Variable ${EMPTY}
|
||||
|
||||
${itemNew} Create Dictionary
|
||||
Run Keyword If "${keywordArray}"!="${EMPTY}" Set To Dictionary ${itemNew} keywordArray=${array}
|
||||
Run Keyword If "${isHexbin}"!="${EMPTY}" Set To Dictionary ${itemNew} isHexbin=${isHexbin}
|
||||
Run Keyword If "${isInitialize}"!="${EMPTY}" Set To Dictionary ${itemNew} isInitialize=${isInitialize}
|
||||
Run Keyword If "${itemName}"!="${EMPTY}" Set To Dictionary ${itemNew} itemName=${itemName}
|
||||
Run Keyword If "${itemDesc}"!="${EMPTY}" Set To Dictionary ${itemNew} itemDesc=${itemDesc}
|
||||
[Return] ${itemNew}
|
||||
ManageFileItem
|
||||
[Documentation]
|
||||
... 接口未说明,待接口说明字段类型之后再完善
|
||||
[Arguments] ${item} ${type} ${action}
|
||||
Log Call ManageFileItem
|
||||
[Return] ${item}
|
||||
ManageExtensionStrItem
|
||||
[Documentation]
|
||||
... http_signature参数说明
|
||||
[Arguments] ${item} ${type} ${action}
|
||||
Log Call ManageExtensionStrItem
|
||||
${return} ${district} Run Keyword And Ignore Error Get From Dictionary ${item} district
|
||||
${district} Run Keyword If "${return}"!="FAIL" Set Variable ${district} ELSE Set Variable ${EMPTY}
|
||||
Run Keyword If "${action}"=="add" Should Not Be Empty ${district}
|
||||
${itemNew} ManageStrItem ${item} ${type} ${action}
|
||||
Run Keyword If "${district}"!="${EMPTY}" Set To Dictionary ${itemNew} district=${district}
|
||||
[Return] ${itemNew}
|
||||
ManageNumberItem
|
||||
[Documentation]
|
||||
... 接口未说明,待接口说明字段类型之后再完善
|
||||
[Arguments] ${item} ${type} ${action}
|
||||
Log Call ManageNumberItem
|
||||
[Return] ${item}
|
||||
ManageDeleteItemIds
|
||||
[Documentation]
|
||||
... 处理deleteItemIds
|
||||
|
||||
Reference in New Issue
Block a user