Netmiko
from pprint import pprint
from netmiko import ConnectHandler
from time import time
import json, os, threading, sys
def config_worker( ip, username, password, extra ):
#---- Connect to the device ----
print ("---- Connecting to device {0}".format( ip ))
#---- Connect to the device
session = ConnectHandler( device_type = "cisco_s300", ip = ip, username = username, password = password, global_delay_factor=2 )
if extra == "extra":
#---- Use CLI command to get configuration data from device
print ("---- Retrieving result of extra command")
config_data = session.send_command("show mac address-table",expect_string=r"#",delay_factor=6)
#---- Write out configuration information to file
print ("---- Storing extra command output: ", basepath + "extra/" + ip)
with open( basepath + "extra/" + ip, "w" ) as config_out: config_out.write( config_data )
else:
#---- Use CLI command to get configuration data from device
print ("---- Retrieving configuration from device")
config_data = session.send_command("show run",expect_string=r"#",delay_factor=6)
#---- Use CLI command to save configuration on device
session.send_command("wr",expect_string=r"Overwrite file",delay_factor=6)
session.send_command("Y",expect_string=r"Copy succeeded",delay_factor=6)
#---- Write out configuration information to file
print ("---- Storing configuration: ", basepath + "configs/" + ip)
with open( basepath + "configs/" + ip, "w" ) as config_out: config_out.write( config_data )
session.disconnect()
return
#==============================================================================
# ---- Main: Get Configuration
#==============================================================================
#---- Define base path to run from anywhere
basepath = os.path.abspath(os.path.dirname(__file__)) + "/"
#---- Retrieve arguments if passed
if len(sys.argv) > 1:
extra = sys.argv[1]
else:
extra = None
#---- Retrieve creds from file
with open(basepath + "creds.json", "r") as f:
creds = json.load(f)
username = creds["CISCO"]["USERNAME"]
password = creds["CISCO"]["PASSWORD"]
#---- Retrieve list of IPs from file
ips = [line.rstrip("\n") for line in open( basepath + "devices-cisco")]
starting_time = time()
config_threads_list = []
for ip in ips:
print ("---- Creating thread for: ", ip)
config_threads_list.append( threading.Thread( target=config_worker, args=( ip, username, password, extra, ) ) )
print ("---- Begin get config threading ----")
for config_thread in config_threads_list:
config_thread.start()
for config_thread in config_threads_list:
config_thread.join()
print ("---- End get config threading, elapsed time=", time() - starting_time)
title: Netmiko - backup-cron.sh.md
category: Automation
#!/bin/bash
python3 /x/backup-fortigate.py
python3 /x/backup-cisco.py
OUTPUT=`su -s /bin/bash -c 'cd /x/configs && git status 2>&1' x 2>&1`;
if [[ $OUTPUT != *"nothing to commit, working directory clean"* ]]; then
OUTPUT2=`su -s /bin/bash -c 'cd /x/configs && git add . 2>&1 && git commit -m "nemiko Bash Auto Git Push" 2>&1 && git push 2>&1' x 2>&1`;
eval $(echo $OUTPUT2 | mail -s "netmiko Bash Auto Git Push" [email protected]);
curl -H "Content-Type: application/json" -d "{\"title\": \"netmiko Bash Auto Git Push\", \"text\": \"***** *****\n\n $OUTPUT2 \", \"themeColor\": \"EA4300\", \"type\": \"\" }" https://x;
else
exit;
fi
title: Netmiko - backup-fortigate.py.md
category: Automation
from scp import SCPClient
import os, paramiko, json
def fortigate_backup(ip, username, password):
ssh = paramiko.client.SSHClient()
ssh.set_missing_host_key_policy(paramiko.client.AutoAddPolicy())
print ("---- Connecting to device {0}".format( ip ))
ssh.connect(ip, username = username, password = password, timeout = 180)
with SCPClient(ssh.get_transport(), socket_timeout = 180) as scp:
config_filename = basepath + "configs/" + ip
print ("---- Getting and writing configuration from device: " + config_filename)
scp.get("sys_config", config_filename)
print ("---- Configuration stored from device: " + config_filename)
return
#---- Define base path to run from anywhere
basepath = os.path.abspath(os.path.dirname(__file__)) + "/"
#---- Retrieve creds from file
with open(basepath + "creds.json", "r") as f:
creds = json.load(f)
username = creds["FORTIGATE"]["USERNAME"]
password = creds["FORTIGATE"]["PASSWORD"]
#---- Retrieve list of IPs from file
ips = [line.rstrip("\n") for line in open(basepath + "devices-fortigate")]
for ip in ips:
fortigate_backup(ip, username, password)
title: Netmiko - config-cisco.py.md
category: Automation
from pprint import pprint
from netmiko import ConnectHandler
from time import time
import json, os, threading, sys
def config_worker( ip, username, password ):
#---- Connect to the device ----
print ("---- Connecting to device {0}".format( ip ))
#---- Connect to the device
session = ConnectHandler( device_type = "cisco_s300", ip = ip, username = username, password = password, global_delay_factor=2 )
#---- Use CLI command to set configuration data on device
print ("---- Setting configuration on device")
config_data = session.config_mode()
config_data += session.send_command("no ip telnet server",expect_string=r"#",delay_factor=6)
# config_data += session.send_command_timing("clock timezone " " 0 minutes 0 \n",strip_command = False)
# config_data += session.send_command_timing("clock summer-time web recurring eu \n",strip_command = False)
# config_data += session.send_command_timing("clock source sntp \n",strip_command = False)
# config_data += session.send_command_timing("sntp unicast client enable \n",strip_command = False)
# config_data += session.send_command_timing("sntp unicast client poll \n",strip_command = False)
# config_data += session.send_command_timing("sntp server x.x.x.x poll \n",strip_command = False)
# config_data += session.send_command_timing("logging host x.x.x.x port 6514 \n",strip_command = False)
# config_data += session.send_command_timing("logging origin-id hostname \n",strip_command = False)
# config_data += session.send_command_timing("no logging console \n",strip_command = False)
# config_data += session.send_command_timing("no passwords complexity enable \n",strip_command = False)
# config_data += session.send_command_timing("passwords aging 0 \n",strip_command = False)
# config_data += session.send_command_timing("snmp-server server \n",strip_command = False)
# config_data += session.send_command_timing("snmp-server community public ro x.x.x.x view Default \n",strip_command = False)
# config_data += session.send_command_timing("no ip http server \n",strip_command = False)
# config_data += session.send_command_timing("encrypted radius-server key x \n",strip_command = False)
# config_data += session.send_command_timing("encrypted radius-server host x.x.x.x key x \n",strip_command = False)
# config_data += session.send_command_timing("ip http authentication aaa login-authentication radius local \n",strip_command = False)
# config_data += session.send_command_timing("aaa authentication login SSH radius local \n",strip_command = False)
# config_data += session.send_command_timing("aaa authentication login Telnet local \n",strip_command = False)
# config_data += session.send_command_timing("aaa authentication login Console local \n",strip_command = False)
# config_data += session.send_command_timing("aaa accounting login start-stop group radius \n",strip_command = False)
# config_data += session.send_command_timing("line ssh \n",strip_command = False)
# config_data += session.send_command_timing("login authentication SSH \n",strip_command = False)
# config_data += session.send_command_timing("password x encrypted \n",strip_command = False)
# config_data += session.send_command_timing("exit \n",strip_command = False)
# config_data += session.exit_config_mode()
# config_data += session.send_command_timing("wr",strip_command = False)
# config_data += session.send_command_timing("Y",strip_command = False)
print (config_data)
session.disconnect()
return
#==============================================================================
# ---- Main: Get Configuration
#==============================================================================
#---- Define base path to run from anywhere
basepath = os.path.abspath(os.path.dirname(__file__)) + "/"
#---- Retrieve creds from file
with open(basepath + "creds.json", "r") as f:
creds = json.load(f)
username = creds["CISCO"]["USERNAME"]
password = creds["CISCO"]["PASSWORD"]
#---- Retrieve list of IPs from file
ips = [line.rstrip("\n") for line in open( basepath + "devices-cisco")]
starting_time = time()
config_threads_list = []
for ip in ips:
print ("---- Creating thread for: ", ip)
config_threads_list.append( threading.Thread( target=config_worker, args=( ip, username, password, ) ) )
print ("---- Begin get config threading ----")
for config_thread in config_threads_list:
config_thread.start()
for config_thread in config_threads_list:
config_thread.join()
print ("---- End get config threading, elapsed time=", time() - starting_time)
title: Netmiko - creds.json.sample.md
category: Automation
{
"CISCO": {
"USERNAME": "cisco_radius_ro",
"PASSWORD": "12345"
},
"FORTIGATE": {
"USERNAME": "fortigate_scp_ro",
"PASSWORD": "12345"
}
}
title: Netmiko - crontab.md
category: Automation
00 1 * * * root /x/backup-cron.sh
title: Netmiko - devices-cisco.sample
category: Automation
192.168.0.1
title: Netmiko - devices-fortigate.sample.md
category: Automation
192.168.0.2