-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig_capture.py
91 lines (73 loc) · 2.49 KB
/
config_capture.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#!/usr/bin/env python
'''
Script to record pre-change and post-change captures using Netmiko and Paramiko.
Reads CI's in from a text file: "CHG000xxxx.txt" in the local directory
Prompts the user for the text file name. Change number is used for output capture files.
Model and DIR commands are predefined.
Script runs standard commands and saves a copy of the running config on router
according to the standard.
Script creates output text file int the following format:
"CHG000xxxx_CINAME_DATETIME.txt"
'''
import netmiko
import time
import datetime
import sys
from os.path import exists
def open_file(ci_file):
'''
Open the CI file
'''
ci_lines = [] # Blank list to add CI's
# Check to see if cmd_file exists
if exists(ci_file):
file_exists = True
else:
file_exists = False
sys.exit("\nSorry, the input file: %s does not exist.\n" % ci_file)
# Open the file and read the contents into the list
with open(ci_file) as f:
ci_lines = f.read().splitlines()
# strip change name from file name.
change_num = ci_file.split(".")[0]
# Close the file
#ci_file_pointer.close()
# test print the command data (remove)
print "\nTest print the CI list."
print ci_lines
print "\nPrint change number."
print change_num
print
return (ci_lines, change_num)
def write_log(router_data, ci_item, change_num):
'''
#Write out the log file based on Change number, CI and datetime
'''
# Write logs
now = datetime.datetime.now()
stamp = now.strftime("_%Y_%m_%d_%H_%M_%S")
log_file_name = change_num + '_' + ci_item + stamp + ".log"
log_file = open(log_file_name, 'w')
log_file.write(router_data)
return log_file_name
def main():
'''
Open the text file and iterate through the CI's.
Open a connection to each CI and run commands.
Check model and specify DIR command.
Write output to file using YAML or JSON
'''
# prompt for input of ci_file
ci_file = raw_input("\nEnter the CI filename: ")
ci_lines, change_num = open_file(ci_file)
# Write test log file
print "\nCreating test log file."
router_data = "Test router data."
# ci_item = "sat-ex1-itc2-wr5"
ci_item = ci_lines[0]
print ci_item
log_file_name = write_log(router_data, ci_item, change_num)
print "Done: %s" % log_file_name
# show flash:
if __name__ == '__main__':
main()