Python简单脚本调用Symantec API (1) - 管理fingerprint list - Python helper

本文介绍了如何使用Python 3.6.x调用Symantec Endpoint Protection Manager的API,涉及查询、创建、更新和删除Fingerprint列表。详细讲解了V1和V2 API的区别,并提供了基础代码示例。
摘要由CSDN通过智能技术生成

前言

有时候我们需要在SOAR/SOC中集成对Endpoint protection的控制。
本文将介绍如何用python来调用SEP的API。

环境

  • Python 3.6.x
  • Symantec Endpoint Protection Manager
  • Postman(API测试工具)

根据Symantec SEP的version不同,API亦有V1, V2 的区别。
在测试时发现fingerprint list api v1, v2 差别比较大,以下会详细介绍。

参考链接

  1. Broadcom - Symantec API
  2. Broadcom - SEP blacklist API
  3. https://{SEPM host}:{port}/sepm/restapidocs.html

正文

废话不多说直接上代码…

基础部分

  1. 导入基础模块
import requests
import json
import logging
import re
# Disable requests' warnings for insecure connections
from requests.packages.urllib3.exceptions import InsecureRequestWarning
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
#因为没有SSL verify 会报 warning,很难看,就把它disable了

log = logging.getLogger(__name__)
  1. 初始类

class SepClient:

    def __init__(self, host, port=8446):
        self.host = host  #SEPM的IP
        self.port = port
        self.base_url = "https://{0}:{1}".format(self.host, self.port)
        self.base_path = "/sepm/api/v1"
        self.v2_base_path = "/sepm/api/v2"
        self.auth_path = "/sepm/api/v1/identity/authenticate"

        self._endpoints = {
   
            "auth": self.auth_path,
            "domains": self.base_path+"/domains",
            "fingerprints_list_v1": self.base_path+"/policy-objects/fingerprints",
            "fingerprints_list_by_id_v1": self.base_path+"/policy-objects/fingerprints/{}",
            "fingerprints_list_v2": self.v2_base_path+"/policy-objects/fingerprints",
            "fingerprints_list_by_id_v2": self.v2_base_path+"/policy-objects/fingerprints/{}"  
        }
        
        self._headers = {
   "content-type": "application/json", "Authorization": "Bearer {0}".format(self.login("username", "password"))}        

  1. AUTH
    (返回一个Token)
    def login(self, username, password, domain="Default"):
        url = self.base_url + self.auth_path
        
        #username and password in SEPM
        json = 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值