mirror of
https://github.com/jokob-sk/NetAlertX.git
synced 2025-12-07 09:36:05 -08:00
171 lines
5.6 KiB
Python
Executable File
171 lines
5.6 KiB
Python
Executable File
#!/usr/bin/env python
|
|
|
|
# Example call
|
|
# python3 /home/pi/pialert/front/plugins/snmp_discovery/script.py routers='snmpwalk -v 2c -c public -OXsq 192.168.1.1 .1.3.6.1.2.1.3.1.1.2'
|
|
|
|
from __future__ import unicode_literals
|
|
from time import sleep, time, strftime
|
|
import requests
|
|
from requests import Request, Session, packages
|
|
import pathlib
|
|
import threading
|
|
import subprocess
|
|
import socket
|
|
import json
|
|
import argparse
|
|
import io
|
|
import sys
|
|
from requests.packages.urllib3.exceptions import InsecureRequestWarning
|
|
import pwd
|
|
import os
|
|
|
|
|
|
curPath = str(pathlib.Path(__file__).parent.resolve())
|
|
log_file = curPath + '/script.log'
|
|
last_run = curPath + '/last_result.log'
|
|
|
|
# Workflow
|
|
|
|
def main():
|
|
|
|
# init global variables
|
|
global ROUTERS
|
|
|
|
# empty file
|
|
open(last_run , 'w').close()
|
|
|
|
last_run_logfile = open(last_run, 'a')
|
|
|
|
|
|
parser = argparse.ArgumentParser(description='This plugin is used to discover devices via the arp table(s) of a RFC1213 compliant router or switch.')
|
|
|
|
parser.add_argument('routers', action="store", help="IP(s) of routers, separated by comma (,) if passing multiple")
|
|
|
|
values = parser.parse_args()
|
|
|
|
# parse output
|
|
newEntries = []
|
|
|
|
if values.routers:
|
|
|
|
ROUTERS = values.routers.split('=')[1].replace('\'','')
|
|
|
|
newEntries = get_entries(newEntries)
|
|
|
|
for e in newEntries:
|
|
# Insert list into the log
|
|
service_monitoring_log(e.primaryId, e.secondaryId, e.created, e.watched1, e.watched2, e.watched3, e.watched4, e.extra, e.foreignKey )
|
|
|
|
# -----------------------------------------------------------------------------
|
|
def get_entries(newEntries):
|
|
|
|
routers = []
|
|
|
|
if ',' in ROUTERS:
|
|
# multiple
|
|
routers = ROUTERS.split(',')
|
|
|
|
else:
|
|
# only one
|
|
routers.append(ROUTERS)
|
|
|
|
for router in routers:
|
|
# snmpwalk -v 2c -c public -OXsq 192.168.1.1 .1.3.6.1.2.1.3.1.1.2
|
|
|
|
print(router)
|
|
|
|
timeoutSec = 10
|
|
|
|
snmpwalkArgs = router.split(' ')
|
|
|
|
# Execute N probes and insert in list
|
|
probes = 1 # N probes
|
|
newLines = []
|
|
for _ in range(probes):
|
|
output = subprocess.check_output (snmpwalkArgs, universal_newlines=True, stderr=subprocess.STDOUT, timeout=(timeoutSec ))
|
|
newLines = newLines + output.split("\n")
|
|
|
|
# Process outputs
|
|
# Sample: iso.3.6.1.2.1.3.1.1.2.3.1.192.168.1.2 "6C 6C 6C 6C 6C 6C "
|
|
|
|
with open(log_file, 'a') as run_logfile:
|
|
for line in newLines:
|
|
# debug
|
|
run_logfile.write(line)
|
|
|
|
tmpSplt = line.split('"')
|
|
|
|
if len(tmpSplt) == 3:
|
|
|
|
ipStr = tmpSplt[0].split('.') # contains IP
|
|
|
|
macStr = tmpSplt[1].split(' ') # contains MAC
|
|
|
|
if 'iso.' in line and len(ipStr) == 16:
|
|
tmpEntry = plugin_object_class(
|
|
f'{macStr[0]}:{macStr[1]}:{macStr[2]}:{macStr[3]}:{macStr[4]}:{macStr[5]}',
|
|
f'{ipStr[12]}.{ipStr[13]}.{ipStr[14]}.{ipStr[15]}'.strip(),
|
|
watched1='(unknown)',
|
|
watched2=snmpwalkArgs[6], # router IP
|
|
extra=line
|
|
)
|
|
newEntries.append(tmpEntry)
|
|
|
|
return newEntries
|
|
|
|
|
|
# -------------------------------------------------------------------
|
|
class plugin_object_class:
|
|
def __init__(self, primaryId = '',secondaryId = '', watched1 = '',watched2 = '',watched3 = '',watched4 = '',extra = '',foreignKey = ''):
|
|
self.pluginPref = ''
|
|
self.primaryId = primaryId
|
|
self.secondaryId = secondaryId
|
|
self.created = strftime("%Y-%m-%d %H:%M:%S")
|
|
self.changed = ''
|
|
self.watched1 = watched1
|
|
self.watched2 = watched2
|
|
self.watched3 = watched3
|
|
self.watched4 = watched4
|
|
self.status = ''
|
|
self.extra = extra
|
|
self.userData = ''
|
|
self.foreignKey = foreignKey
|
|
|
|
# -----------------------------------------------------------------------------
|
|
def service_monitoring_log(primaryId, secondaryId, created, watched1, watched2 = 'null', watched3 = 'null', watched4 = 'null', extra ='null', foreignKey ='null' ):
|
|
|
|
if watched1 == '':
|
|
watched1 = 'null'
|
|
if watched2 == '':
|
|
watched2 = 'null'
|
|
if watched3 == '':
|
|
watched3 = 'null'
|
|
if watched4 == '':
|
|
watched4 = 'null'
|
|
if extra == '':
|
|
extra = 'null'
|
|
if foreignKey == '':
|
|
foreignKey = 'null'
|
|
|
|
with open(last_run, 'a') as last_run_logfile:
|
|
last_run_logfile.write("{}|{}|{}|{}|{}|{}|{}|{}|{}\n".format(
|
|
primaryId,
|
|
secondaryId,
|
|
created,
|
|
watched1,
|
|
watched2,
|
|
watched3,
|
|
watched4,
|
|
extra,
|
|
foreignKey
|
|
)
|
|
)
|
|
|
|
|
|
#===============================================================================
|
|
# BEGIN
|
|
#===============================================================================
|
|
if __name__ == '__main__':
|
|
main()
|
|
|