mirror of
https://github.com/jokob-sk/NetAlertX.git
synced 2026-01-24 06:38:20 -05:00
CHECKMK script
This commit is contained in:
@@ -3,7 +3,7 @@
|
||||
[](https://github.com/jokob-sk/NetAlertX/releases)
|
||||
[](https://discord.gg/NczTUTWyRr)
|
||||
|
||||
# 🖧🔍 Network scanner & notification framework
|
||||
# NetAlertX - Network scanner & notification framework
|
||||
|
||||
Get visibility of what's going on on your WIFI/LAN network. Schedule scans for devices, port changes and get alerts if unknown devices or changes are found. Write your own [Plugins](https://github.com/jokob-sk/NetAlertX/tree/main/front/plugins#readme) with auto-generated UI and in-build notification system. Build out and easily maintain your network source of truth (NSoT).
|
||||
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
[](https://discord.gg/NczTUTWyRr)
|
||||
|
||||
|
||||
# NetAlertX 🖧🔍 Network scanner & notification framework
|
||||
# NetAlertX - Network scanner & notification framework
|
||||
|
||||
| [📑 Docker guide](https://github.com/jokob-sk/NetAlertX/blob/main/dockerfiles/README.md) | [🚀 Releases](https://github.com/jokob-sk/NetAlertX/releases) | [📚 Docs](https://github.com/jokob-sk/NetAlertX/tree/main/docs) | [🔌 Plugins](https://github.com/jokob-sk/NetAlertX/blob/main/front/plugins/README.md) | [🤖 Ask AI](https://gurubase.io/g/netalertx)
|
||||
|----------------------| ----------------------| ----------------------| ----------------------| ----------------------|
|
||||
|
||||
@@ -34,6 +34,12 @@ Confirm SNMP enabled
|
||||
show snmp
|
||||
````
|
||||
|
||||
### Setup for (old) procurve switches
|
||||
|
||||
```
|
||||
snmpwalk -v 2c -c XXXXXX -On -Ovq 192.168.45.58 .1.3.6.1.2.1.4.22.1.3.102
|
||||
```
|
||||
|
||||
### Notes
|
||||
|
||||
- Only IPv4 supported.
|
||||
|
||||
24
scripts/checkmk/README.md
Executable file
24
scripts/checkmk/README.md
Executable file
@@ -0,0 +1,24 @@
|
||||
# NetAlertX-New-Devices-Checkmk-Script
|
||||
|
||||
This script retrieves the list of all devices from NetAlertX by reading the `/app/api/table_devices.json` file within the "NetAlertX" Docker container. It then checks if there are any new devices (`devIsNew == 1`).
|
||||
|
||||
- If new devices are found, a warning state is reported.
|
||||
- Otherwise, an OK state is returned.
|
||||
|
||||
## Checkmk Local Check Format
|
||||
|
||||
The script follows the Checkmk local check format:
|
||||
|
||||
```
|
||||
<status> <service_name> <perfdata> <message>
|
||||
```
|
||||
|
||||
For more details, see the [Checkmk Local Checks Documentation](https://docs.checkmk.com/latest/en/localchecks.html).
|
||||
|
||||
### Other info
|
||||
|
||||
- Date : 08-Jan-2025 - version 1.0
|
||||
- Author: N/A
|
||||
|
||||
> [!NOTE]
|
||||
> This is a community supplied script and not maintained.
|
||||
74
scripts/checkmk/script.py
Executable file
74
scripts/checkmk/script.py
Executable file
@@ -0,0 +1,74 @@
|
||||
|
||||
YABin
|
||||
|
||||
#!/usr/bin/env python3
|
||||
# -*- coding: utf-8 -*-
|
||||
"""
|
||||
NetAlertX-New-Devices-Checkmk-Script
|
||||
|
||||
Dieses Skript ruft die Liste aller Devices aus NetAlertX ab, indem es innerhalb
|
||||
des Docker-Containers "NetAlertX" die Datei /app/api/table_devices.json ausliest.
|
||||
Anschließend wird geprüft, ob neue Geräte vorhanden sind (devIsNew == 1).
|
||||
Falls ja, wird ein Warning-Zustand gemeldet, sonst OK.
|
||||
|
||||
Checkmk-Local-Check-Format:
|
||||
<status> <service_name> <perfdata> <message>
|
||||
Siehe: https://docs.checkmk.com/latest/de/localchecks.html
|
||||
"""
|
||||
|
||||
import subprocess
|
||||
import json
|
||||
|
||||
def check_new_devices():
|
||||
try:
|
||||
# Rufe die JSON-Datei aus dem Docker-Container ab
|
||||
result = subprocess.run(
|
||||
['docker', 'exec', 'NetAlertX', 'cat', '/app/api/table_devices.json'],
|
||||
capture_output=True,
|
||||
text=True,
|
||||
check=True
|
||||
)
|
||||
data_str = result.stdout
|
||||
except subprocess.CalledProcessError as e:
|
||||
# Wenn der Docker-Command fehlschlägt -> UNKNOWN (3)
|
||||
print(f"3 NetAlertX_New_Devices - UNKNOWN - Docker command failed: {e}")
|
||||
return
|
||||
except Exception as e:
|
||||
# Allgemeiner Fehler -> UNKNOWN
|
||||
print(f"3 NetAlertX_New_Devices - UNKNOWN - Error while running docker command: {e}")
|
||||
return
|
||||
|
||||
# JSON-Daten laden
|
||||
try:
|
||||
data = json.loads(data_str)
|
||||
except json.JSONDecodeError as e:
|
||||
# Wenn das JSON nicht gelesen werden kann -> UNKNOWN
|
||||
print(f"3 NetAlertX_New_Devices - UNKNOWN - JSON decode error: {e}")
|
||||
return
|
||||
|
||||
# Prüfen, ob das 'data'-Attribut vorhanden ist
|
||||
if "data" not in data:
|
||||
print("3 NetAlertX_New_Devices - UNKNOWN - Unexpected JSON format (no 'data' key).")
|
||||
return
|
||||
|
||||
new_devices = []
|
||||
for device in data["data"]:
|
||||
# Prüfen, ob das Attribut 'devIsNew' existiert und == 1 ist
|
||||
if "devIsNew" in device and device["devIsNew"] == 1:
|
||||
new_devices.append(device)
|
||||
|
||||
# Wenn keine neuen Geräte gefunden
|
||||
if len(new_devices) == 0:
|
||||
# Status 0 = OK
|
||||
print("0 NetAlertX_New_Devices - OK - No new devices found")
|
||||
else:
|
||||
# Status 1 = WARNING
|
||||
device_list_str = ", ".join(
|
||||
f"{dev.get('devName', 'UnknownName')}({dev.get('devMac', 'UnknownMAC')}) IP:{dev.get('devLastIP', 'UnknownIP')}"
|
||||
for dev in new_devices
|
||||
)
|
||||
print(f"1 NetAlertX_New_Devices - WARNING - Found {len(new_devices)} new device(s): {device_list_str}")
|
||||
|
||||
if __name__ == "__main__":
|
||||
check_new_devices()
|
||||
|
||||
@@ -35,4 +35,8 @@ For each MAC or IP address provided, the script:
|
||||
### Other info
|
||||
|
||||
- Date : 23-Dec-2024 - version 1.0
|
||||
- Author: [laxduke](https://github.com/laxduke)
|
||||
- Author: [laxduke](https://github.com/laxduke)
|
||||
|
||||
|
||||
> [!NOTE]
|
||||
> This is a community supplied script and not maintained.
|
||||
@@ -203,8 +203,13 @@ def get_plugins_configs(loadAll):
|
||||
|
||||
plugJson = json.loads(get_file_content(config_path))
|
||||
|
||||
# only load plugin if needed
|
||||
if loadAll or plugJson["unique_prefix"] in conf.LOADED_PLUGINS:
|
||||
# Only load plugin if needed
|
||||
# Fetch the list of enabled plugins from the config, default to an empty list if not set
|
||||
enabledPlugins = getattr(conf, "LOADED_PLUGINS", [])
|
||||
|
||||
# Load all plugins if `loadAll` is True, the plugin is in the enabled list,
|
||||
# or no specific plugins are enabled (enabledPlugins is empty)
|
||||
if loadAll or plugJson["unique_prefix"] in enabledPlugins or enabledPlugins == []:
|
||||
|
||||
# Load the contents of the config.json file as a JSON object and append it to pluginsList
|
||||
pluginsList.append(plugJson)
|
||||
|
||||
Reference in New Issue
Block a user