2023-08-18 10:14:53 +02:00
|
|
|
from easysnmp import Session, TrapSender
|
2023-08-17 15:55:32 +02:00
|
|
|
|
|
|
|
####
|
|
|
|
# Define global variables dict, used in functions as default values.
|
|
|
|
# Its values can be changed.
|
|
|
|
#########################################################################################
|
|
|
|
|
|
|
|
_GLOBAL_VARIABLES = {
|
|
|
|
'hostname' : '',
|
|
|
|
'version' : 3,
|
|
|
|
'community' : 'public',
|
|
|
|
'user' : '',
|
|
|
|
'auth_protocol' : "",
|
|
|
|
'auth_password' : "",
|
|
|
|
'privacy_protocol' : "",
|
|
|
|
'privacy_password' : "",
|
|
|
|
'security_level' : "authPriv",
|
|
|
|
'timeout' : 2,
|
|
|
|
'retries' : 1,
|
|
|
|
'remote_port' : 161,
|
|
|
|
}
|
|
|
|
|
|
|
|
def create_snmp_session():
|
|
|
|
host = _GLOBAL_VARIABLES['hostname']
|
|
|
|
version = _GLOBAL_VARIABLES['version']
|
|
|
|
community = _GLOBAL_VARIABLES['community']
|
|
|
|
user = _GLOBAL_VARIABLES['user']
|
|
|
|
auth_protocol = _GLOBAL_VARIABLES['auth_protocol']
|
|
|
|
auth_password = _GLOBAL_VARIABLES['auth_password']
|
|
|
|
privacy_protocol = _GLOBAL_VARIABLES['privacy_protocol']
|
|
|
|
privacy_password = _GLOBAL_VARIABLES['privacy_password']
|
|
|
|
security_level = _GLOBAL_VARIABLES['security_level']
|
|
|
|
timeout = _GLOBAL_VARIABLES['timeout']
|
|
|
|
retries = _GLOBAL_VARIABLES['retries']
|
|
|
|
remote_port = _GLOBAL_VARIABLES['remote_port']
|
|
|
|
|
|
|
|
session_kwargs = {
|
|
|
|
"hostname": host,
|
|
|
|
"version": version,
|
|
|
|
"use_numeric": True,
|
|
|
|
"timeout": timeout,
|
|
|
|
"retries": retries,
|
|
|
|
"remote_port": remote_port
|
|
|
|
}
|
|
|
|
|
|
|
|
if version == 1 or version == 2:
|
|
|
|
session_kwargs["community"] = community
|
|
|
|
elif version == 3:
|
|
|
|
session_kwargs["security_username"] = user
|
|
|
|
|
|
|
|
if security_level == "authPriv":
|
|
|
|
session_kwargs.update({
|
|
|
|
"auth_protocol": auth_protocol,
|
|
|
|
"auth_password": auth_password,
|
|
|
|
"privacy_protocol": privacy_protocol,
|
|
|
|
"privacy_password": privacy_password,
|
|
|
|
"security_level": "auth_with_privacy"
|
|
|
|
})
|
|
|
|
elif security_level == "authNoPriv":
|
|
|
|
session_kwargs.update({
|
|
|
|
"auth_protocol": auth_protocol,
|
|
|
|
"auth_password": auth_password,
|
|
|
|
"security_level": "auth_without_privacy"
|
|
|
|
})
|
|
|
|
elif security_level == "noAuthNoPriv":
|
|
|
|
session_kwargs["security_level"] = "no_auth_or_privacy"
|
|
|
|
|
|
|
|
return Session(**session_kwargs)
|
|
|
|
|
2023-08-18 10:35:59 +02:00
|
|
|
def snmp_get(
|
|
|
|
session: Session,
|
|
|
|
oid: str
|
|
|
|
) -> str:
|
|
|
|
"""
|
|
|
|
Performs an SNMP GET operation to retrieve the value of a specified OID.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
session (Session): The SNMP session to use for the operation.
|
|
|
|
oid (str): The OID (Object Identifier) for the SNMP GET operation.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
str: The value retrieved from the specified OID.
|
|
|
|
"""
|
2023-08-17 15:55:32 +02:00
|
|
|
return session.get(oid)
|
|
|
|
|
2023-08-18 10:35:59 +02:00
|
|
|
def snmp_walk(
|
|
|
|
session: Session,
|
|
|
|
oid: str
|
|
|
|
) -> list:
|
|
|
|
"""
|
|
|
|
Performs an SNMP WALK operation to retrieve a list of values from a subtree of the MIB.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
session (Session): The SNMP session to use for the operation.
|
|
|
|
oid (str): The OID (Object Identifier) representing the root of the subtree.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
list: A list of values retrieved from the specified subtree.
|
|
|
|
"""
|
2023-08-17 15:55:32 +02:00
|
|
|
return session.walk(oid)
|
2023-08-18 10:14:53 +02:00
|
|
|
|
2023-08-18 10:35:59 +02:00
|
|
|
def send_trap(
|
|
|
|
trap_oid: str,
|
|
|
|
trap_value: str,
|
|
|
|
destination_ip: str,
|
|
|
|
community: str
|
|
|
|
) -> None:
|
|
|
|
"""
|
|
|
|
Sends an SNMP trap to the specified destination IP using the given OID, value, and community.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
trap_oid (str): The OID (Object Identifier) for the SNMP trap.
|
|
|
|
trap_value (str): The value associated with the trap.
|
|
|
|
destination_ip (str): The IP address of the trap's destination.
|
|
|
|
community (str): The SNMP community string for authentication.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
None
|
|
|
|
"""
|
2023-08-18 10:14:53 +02:00
|
|
|
trap = TrapSender()
|
|
|
|
|
|
|
|
trap.trap_oid = trap_oid
|
|
|
|
trap.trap_value = trap_value
|
|
|
|
trap.destination_ip = destination_ip
|
|
|
|
trap.community = community
|
|
|
|
|
|
|
|
trap.send_trap()
|