168 lines
4.8 KiB
Python
168 lines
4.8 KiB
Python
import os
|
|
import re
|
|
import csv
|
|
from datetime import datetime
|
|
|
|
from netmiko import ConnectHandler
|
|
from netmiko.exceptions import NetmikoTimeoutException, NetmikoAuthenticationException
|
|
|
|
def get_aruba_clients(host, username, password):
|
|
"""
|
|
Connects to an Aruba switch via SSH, gets hostname and client info,
|
|
and returns a list of dictionaries, each representing a client.
|
|
"""
|
|
device = {
|
|
'device_type': 'aruba_aoscx',
|
|
'host': host,
|
|
'username': username,
|
|
'password': password,
|
|
}
|
|
|
|
all_clients_data = []
|
|
print(f"Csatlakozás a(z) {host} eszközhöz...")
|
|
try:
|
|
with ConnectHandler(**device) as net_connect:
|
|
print("Sikeres csatlakozás. Adatok lekérdezése...")
|
|
|
|
prompt = net_connect.find_prompt()
|
|
switch_hostname = prompt.strip('#> ')
|
|
|
|
output = net_connect.send_command('show client ip')
|
|
ip_pattern = re.compile(r'^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$')
|
|
|
|
if isinstance(output, str):
|
|
lines = output.splitlines()
|
|
for line in lines[2:]:
|
|
columns = line.split()
|
|
if len(columns) >= 4:
|
|
potential_ip = columns[-1]
|
|
if ip_pattern.match(potential_ip):
|
|
client_data = {
|
|
'switch_name': switch_hostname,
|
|
'mac_address': columns[0],
|
|
'interface': columns[1],
|
|
'vlan': columns[2],
|
|
'ip_address': potential_ip,
|
|
}
|
|
all_clients_data.append(client_data)
|
|
return all_clients_data
|
|
|
|
print("Hiba: A parancs kimenete nem volt a várt formátumban.")
|
|
return None
|
|
|
|
except NetmikoTimeoutException:
|
|
print(f"Hiba: Időtúllépés a(z) {host} eszközhöz való csatlakozáskor.")
|
|
return None
|
|
except NetmikoAuthenticationException:
|
|
print(f"Hiba: Sikertelen hitelesítés a(z) {host} eszközön. Ellenőrizd a jelszót.")
|
|
return None
|
|
except Exception as e:
|
|
print(f"Váratlan hiba történt: {e}")
|
|
return None
|
|
|
|
if __name__ == "__main__":
|
|
|
|
# --- IDE DEFINIÁLD A SWITCH-EK IP CÍMEIT ---
|
|
|
|
SWITCH_IPS = [
|
|
|
|
"10.220.1.84", # NET-SW01
|
|
"10.220.1.85", # NET-SW02
|
|
"10.220.1.86", # NET-SW04
|
|
"10.220.1.87", # NET-SW05
|
|
"10.220.1.88", # NET-SW06
|
|
"10.220.1.89", # NET-SW01 - Core
|
|
"10.220.1.90", # NET-SW07
|
|
"10.220.1.91", # NET-SW08
|
|
"10.220.1.92", # NET-SW09
|
|
"10.220.1.93", # NET-SW10
|
|
"10.220.1.94", # NET-SW11
|
|
"10.220.1.96", # NET-SW13
|
|
"10.220.1.98", # NET-SW16 - HA
|
|
"10.220.1.99", # NET-SW17
|
|
|
|
]
|
|
|
|
USERNAME = os.getenv('ARUBA_USER', 'svc.operator') # Felhasználónév környezeti változóból, alapértelmezett értékkel
|
|
if not USERNAME:
|
|
print("Hiba: Az ARUBA_USER környezeti változó nincs beállítva.")
|
|
exit()
|
|
|
|
|
|
|
|
# A kimeneti mappa a konténeren belül
|
|
|
|
OUTPUT_DIR = "/data"
|
|
|
|
timestamp = datetime.now().strftime("%Y-%m-%d_%H-%M-%S")
|
|
|
|
CSV_FILENAME = os.path.join(OUTPUT_DIR, f"aruba_clients_ALL_{timestamp}.csv")
|
|
|
|
|
|
|
|
|
|
PASSWORD = os.getenv('ARUBA_PASSWORD')
|
|
if not PASSWORD:
|
|
print("Hiba: Az ARUBA_PASSWORD környezeti változó nincs beállítva.")
|
|
exit()
|
|
|
|
|
|
|
|
all_switches_clients = []
|
|
|
|
|
|
|
|
for ip in SWITCH_IPS:
|
|
|
|
print(f"\n--- Feldolgozás: {ip} ---")
|
|
|
|
clients_from_one_switch = get_aruba_clients(ip, USERNAME, PASSWORD)
|
|
|
|
if clients_from_one_switch:
|
|
|
|
all_switches_clients.extend(clients_from_one_switch)
|
|
|
|
print(f"Sikeresen lekérdezve {len(clients_from_one_switch)} kliens a(z) {ip} switch-ről.")
|
|
|
|
else:
|
|
|
|
print(f"Nem sikerült adatot lekérdezni a(z) {ip} switch-ről.")
|
|
|
|
|
|
|
|
if all_switches_clients:
|
|
|
|
print(f"\nÖsszesen {len(all_switches_clients)} kliens adat gyűjtve. Mentés a(z) {CSV_FILENAME} fájlba...")
|
|
|
|
|
|
|
|
fieldnames = all_switches_clients[0].keys()
|
|
|
|
|
|
|
|
try:
|
|
|
|
# Biztosítjuk, hogy a kimeneti mappa létezzen
|
|
|
|
os.makedirs(OUTPUT_DIR, exist_ok=True)
|
|
|
|
with open(CSV_FILENAME, 'w', newline='', encoding='utf-8') as csvfile:
|
|
|
|
writer = csv.DictWriter(csvfile, fieldnames=fieldnames)
|
|
|
|
writer.writeheader()
|
|
|
|
writer.writerows(all_switches_clients)
|
|
|
|
print(f"Sikeres mentés a(z) '{CSV_FILENAME}' fájlba.")
|
|
|
|
except IOError as e:
|
|
|
|
print(f"Hiba történt a CSV fájl írása közben: {e}")
|
|
|
|
|
|
|
|
else:
|
|
|
|
print("\nEgyetlen switch-ről sem sikerült adatot gyűjteni.")
|