-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathmain_menu.py
735 lines (711 loc) · 34.8 KB
/
main_menu.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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
#!/usr/bin/env python
import os
import getpass
import urllib2
import ssl
import json
import sys
import threading
import time
import traceback
import pdb
from localutils.custom_utils import clear_screen, refreshToken, custom_raw_input
import localutils.sshleafutil
#import fabric_access.create_vpc as create_vpc
import fabric_access.display_switch_to_leaf_structure as display_switch_to_leaf_structure
import interfaces.change_interface_state as shut_noshut_interfaces
import interfaces.assign_epg_interfaces as assign_epg_interfaces
import interfaces.remove_epgs_interfaces as remove_egps
import interfaces.vlan_epg_to_ports as show_epgs
import interfaces.show_all_endpoints_on_interface as show_all_endpoints_on_interface
import interfaces.portsanddescriptions as portsanddescriptions
import interfaces.interfacecounters as showinterface
import interfaces.switch_port_view as switch_port_view
#import interfaces.switchpreviewutil as switchpreviewutil
import interfaces.clonevpcanddeploy as clonevpcanddeploy
import interfaces.autodeploy as autodeploy
import interfaces.portchannel_to_phy_interfaces as portchannel_to_phy_interfaces
import interfaces.short_vlan_epg_to_ports as short_vlan_epg_to_ports
import interfaces.show_interface_attributes as show_interface_attributes
import interfaces.configure_and_deploy as configure_and_deploy
import information.switchandapicinfo as switchandapicinfo
import information.endpoint_per_leaf as endpoint_per_leaf
import information.top_interface_problems as top_interface_problems
import information.bd_epg_relations as bd_epg_relations
import faults_and_logs.new_important_faults as fault_summary
import faults_and_logs.most_recent_port_down as recent_port_down
import faults_and_logs.most_recent_fault_changes as most_recent_fault_changes
import faults_and_logs.most_recent_admin_changes as most_recent_admin_changes
import faults_and_logs.most_recent_event_changes as most_recent_event_changes
import faults_and_logs.alleventsbetweendates as alleventsbetweendates
import faults_and_logs.alleventsbetweendates_fulldetail as alleventsbetweendates_fulldetail
import information.endpoint_search as ipendpoint_search
import information.zoning_rules_checking as zoning_rules_checking
#import information.routetranslation as epg_troubleshooting
#import information.routetranslation as routetranslation
#import information.routetrace as check_routing
import information.show_static_routes as show_static_routes
import configuration.create_local_span_session as create_local_span_session
import configuration.span_to_server as span_to_server
import localutils.program_globals
import logging
from logging.handlers import RotatingFileHandler
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('-l','--level', type=str, nargs='?', choices=["debug","info","warning","error","critical"], default="info", help='modifiy the logger in logger tree')
parser.add_argument('-c','--console-level', type=str, nargs='?', choices=["debug","info","warning","error","critical"], default="critical", help='modifiy the console logger in logger tree')
parser.add_argument('-f','--file-level', type=str, nargs='?', choices=["debug","info","warning","error","critical"], default="info", help='modifiy the file logger in logger tree')
args = parser.parse_args()
# Create a custom logger
# Allows logging to state detailed info such as module where code is running and
# specifiy logging levels for file vs console. Set default level to DEBUG to allow more
# grainular logging levels
logger = logging.getLogger('aciops')
if args.level:
logger.setLevel(eval('logging.' + args.level.upper()))
# Define logging handler for file and console logging. Console logging can be desplayed during
# program run time, similar to print. Program can display or write to log file if more debug
# info needed. DEBUG is lowest and will display all logging messages in program.
c_handler = logging.StreamHandler()
f_handler = RotatingFileHandler('aciops.log', maxBytes=10000000, backupCount=1)
c_handler.setLevel(eval('logging.' + args.console_level.upper()))
f_handler.setLevel(eval('logging.' + args.file_level.upper()))
# Create formatters and add it to handlers. This creates custom logging format such as timestamp,
# module running, function, debug level, and custom text info (message) like print.
c_format = logging.Formatter('%(name)s - %(levelname)s - %(message)s')
f_format = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(funcName)s - %(message)s')
c_handler.setFormatter(c_format)
f_handler.setFormatter(f_format)
# Add handlers to the parent custom logger
logger.addHandler(c_handler)
logger.addHandler(f_handler)
# getToken is used if application is run on local machine and not directly on APIC server
# apic key word will be a string ipaddress
def getToken(apic, user, pwd):
# Set ssl certificate to automatically verify and proceed
ssl._create_default_https_context = ssl._create_unverified_context
# url POST request to login to APIC and recieve cookie hash
url = "https://{apic}/api/aaaLogin.json".format(apic=apic)
logger.info(url)
# POST Login requires user creds provided in the data section of url request
payload = '{"aaaUser":{"attributes":{"name":"%(user)s","pwd":"%(pwd)s"}}}' % {"pwd":pwd,"user":user}
request = urllib2.Request(url, data=payload)
# If APIC is unreachable within 4 sec cancel URL request to server, prevents long timeouts on wrong input
response = urllib2.urlopen(request, timeout=4)
# If successful response transfer informaton to a dictionary format using 'loads'
token = json.loads(response.read())
# Set global variable to access 'cookie' everywhere in current module
global cookie
cookie = token["imdata"][0]["aaaLogin"]["attributes"]["token"]
return cookie
# Allows automatic APIC session cookie for URL requests if ssh to server
# and program run directly on server, prevents two logins
def getCookie():
# location of session token/cookie, open as read-only
with open('/.aci/.sessions/.token', 'r') as f:
# Set global variable to access 'cookie' everywhere in current module
global cookie
cookie = f.read()
# Currently unnecessary but 'return' provided until decision for global to be removed or not
return cookie # str
# Test if script is run on APIC or on local computer
# login function that will evaluate location of login and ask/retrieve credientals
# Evaluates if cookie can be found locally, else check environment variables, then final asking ask for apic IP and creds
def localOrRemote(error=False):
clear_screen()
if not error:
# If path exisits the program is running on APIC server and bypass login
if os.path.isfile('/.aci/.sessions/.token'):
logger.info('Logging in using local apic cookie')
# APIC requires IP in urlpath to use a loopback address with said token above
apic = "localhost"
# Set global variable to access 'cookie' everywhere in current module
global cookie
cookie = getCookie()
user = getpass.getuser()
# return apic hostname and discovered cookie
localutils.program_globals.APIC = apic
return apic, user, cookie # str , str
else:
# Automatic login if environment variables in terminal/cmd are set
try:
if os.environ.get('apic'):
print('Logging in using Environment Variables...')
logger.info('Logging in using Environment Variables...')
# find evnironment 'apic','user','pwd' pas to getToken function to retrieve cookie via REST POST Call
apic = os.environ.get('apic')
user = os.environ.get('user')
pwd = os.environ.get('password')
# POST REST call to APIC to get cookie/token for API calls
cookie = getToken(apic,user,pwd)
# some parts of the program needs apic address, username, and cookie for varise tasks
return apic, user, cookie
else:
# if '.token' file doesn't exist than prompt APIC ip and username/password login.
# Set defaults variables before login, allow variable to change if login attempts fail.
# if both are False the first to 'if' conditions will not match, cause haven't attempted login.
unauthenticated = False
timedout = False
# error value required to prevent Exception stating error variable not defined for use below
error = ''
# Loop for login Attempts, requires 'break' to exit loop
while True:
# Clear console ouput creating clean login screen for login attempt
clear_screen()
if unauthenticated:
# print error reason after cleared console screen
print(error)
# reset unauthenticated to prevent 'if' capture if failure is a different reason
unauthenticated = False
# Server doesn't respond in time to login request (unreachable default 4 sec)
elif timedout:
# print error reason after cleared console screen
print(error)
# re-ask IP in cause IP typed incorrectly
apic = raw_input("\nEnter IP address or FQDN of APIC: ")
# reset timedout to False to prevent loop from accidently catching without timeout problem
timedout = False
elif error:
# Catch any unforeseen errors and prompt for relogin
print(error)
apic = raw_input("\nEnter IP address or FQDN of APIC: ")
else:
# if no errors ask for APIC address
apic = raw_input("\nEnter IP address or FQDN of APIC: ")
try:
user = raw_input('\nUsername: ')
pwd = getpass.getpass('Password: ')
getToken(apic, user,pwd)
except urllib2.HTTPError:
unauthenticated = True
error = '\n\x1b[1;31;40mAuthentication failed\x1b[0m\n'
continue
except urllib2.URLError as e:
timedout = True
error = "\n\x1b[1;31;40mThere was an '%s' error connecting to APIC '%s'\x1b[0m\n" % (e.reason,apic)
continue
except KeyboardInterrupt:
print("\nEnding Program\n")
exit()
except Exception as e:
error = '\x1b[1;31;40m ' + str(e)
error += "\nError has occured, please try again\x1b[0m\n"
continue
break
except urllib2.HTTPError as e:
unauthenticated = True
print('hit')
print('\n\x1b[1;31;40mAuthentication failed\x1b[0m\n')
exit()
except urllib2.URLError as e:
timedout = True
print("\n\x1b[1;31;40mThere was an '{}' error connecting to APIC {}\x1b[0m\n".format(e.reason,apic))
exit()
except KeyboardInterrupt:
print("\nEnding Program\n")
exit()
except Exception as e:
error = '\x1b[1;31;40m ' + str(e)
error += "\nError has occured, please try again\x1b[0m\n"
print(error)
exit()
else:
logger.info('Logging in using ip, user, password')
return apic, user, cookie
# The difference between localOrRemote function is that reauthenticate() presents error info
def reauthenticate(apic, error):
unauthenticated = True
timedout = False
while True:
clear_screen()
if unauthenticated:
print(error)
unauthenticated = False
elif timedout:
print(error)
apic = raw_input("Enter IP address or FQDN of APIC: ")
timedout = False
try:
if os.environ.get('apic'):
print('\nLogging back into APIC...')
time.sleep(1)
apic = os.environ.get('apic')
user = os.environ.get('user')
pwd = os.environ.get('password')
cookie = getToken(apic,user,pwd)
elif os.path.isfile('/.aci/.sessions/.token'):
print('\nLogging back into APIC...')
time.sleep(1)
apic, user, cookie = localOrRemote()
else:
user = raw_input('\nUsername: ')
pwd = getpass.getpass('Password: ')
cookie = getToken(apic, user,pwd)
except urllib2.HTTPError:
unauthenticated = True
error = '\n\x1b[1;31;40mAuthentication failed\x1b[0m\n'
continue
except urllib2.URLError as e:
timedout = True
error = "\n\x1b[1;31;40mThere was an '%s' error connecting to APIC '%s'\x1b[0m\n" % (e.reason,apic)
continue
except Exception as e:
error = '\x1b[1;31;40m ' + str(e)
error += "\nError has occured, please try again\x1b[0m\n"
continue
return cookie
class AuthenticationFailure(Exception):
"""Authentication Failure"""
pass
#def associate_permissions_to_role(rolerightsdict, userdomainlist):
# # import pdb; pdb.set_trace()
# for domain,rights in userdomainlist.items():
# for x in rolerightsdict:
# for num,right in enumerate(rights):
# if right.get(x):
# # import pdb; pdb.set_trace()
# print(domain, rights[num])
#
#def checkwritepermissions(permissionlist):
# # for permission in permissionlist:
# # #print(permission)
# # if permission.get('all'):
# # #print(permission)
# # for usertype,role in permission['all'].items():
# # if usertype == 'admin' and role == 'writePriv':
# # return True
# # # import pdb; pdb.set_trace()
# # # print(role)
# # # for x in role:
# # # if x['admin'] == 'writePriv':
## # # if permission['all'] == 'writePriv':
# # return False
# return True
def settimer():
timertest = time.time()
def main():
global timertest
timertest = time.time()
apic, current_user, cookie = localOrRemote()
localutils.program_globals.APIC = apic
unauthenticated = False
keyinterrupt = False
# url = """https://{}/api/node/mo/uni/userext/user-{}.json?rsp-subtree=full""".format(apic,current_user)
# user_rights = GetResponseData(url, cookie)
# url = """https://{}/api/node/class/aaaRole.json""".format(apic,current_user)
# role_rights = GetResponseData(url, cookie)
# print(role_rights)
# rolerightsdict = {x['aaaRole']['attributes']['dn'][12:]:x['aaaRole']['attributes'] for x in role_rights}
# import pdb; pdb.set_trace()
clear_screen()
print('')
print('\x1b[1;33;40m -----------------------------\x1b[0m')
print('\x1b[1;33;40m| Hint: |\x1b[0m')
print('\x1b[1;33;40m| Type "exit" on any input |\x1b[0m')
print('\x1b[1;33;40m| to return to main menu |\x1b[0m')
print('\x1b[1;33;40m -----------------------------\x1b[0m')
print('\n')
print('Disclaimer: The Author is not held responsible for any service disruptions')
print(' or damages that results from this program. This project was')
print(' created to help make ACI easier to troubleshoot and automate.')
print(' Please test in lab before trying in production environments.')
print('')
custom_raw_input('\n\nEnter to continue...')
while True:
try:
clear_screen()
if unauthenticated:
error = '\n\x1b[1;31;40mAuthentication Failed or timed out...restarting program\x1b[0m'
cookie = reauthenticate(apic, error)
unauthenticated = False
clear_screen()
#import pdb; pdb.set_trace()
#for domain in user_rights[0]['aaaUser']['children']:
# if domain.get('aaaUserDomain') and domain['aaaUserDomain'].get('children'):
# for role in domain['aaaUserDomain']['children']:
# if userdomainlist.get(domain['aaaUserDomain']['attributes']['name']):
# userdomainlist[domain['aaaUserDomain']['attributes']['name']].append({role['aaaUserRole']['attributes']['rn']:role['aaaUserRole']['attributes']['privType']})
# else:
# userdomainlist[domain['aaaUserDomain']['attributes']['name']] = [
# {role['aaaUserRole']['attributes']['rn']:role['aaaUserRole']['attributes']['privType']}]
#associate_permissions_to_role(rolerightsdict, userdomainlist)
if keyinterrupt:
pass #cookie = refreshToken(apic, cookie)
print('\n What would you like to do?:\n\n' +
'\t\x1b[1;32;40m [INTERFACES]\n'+
'\t ---------------------------------------------------\n' +
'\t| 1.) Shut/NoShut interfaces\n' +
'\t| 2.) Add EPGs to interfaces\n' +
'\t| 3.) Remove EPGs from interfaces\n' +
'\t| 4.) Show interface status\n' +
'\t| 5.) Show single interface counters and EPGs\n' +
'\t| 6.) Show leaf port view\n' +
'\t| 7.) Show leaf port view (Detail)\n' +
'\t| 8.) Show EPG --> Interface (Operational)\n' +
'\t| 9.) Show EPG --> Interface (Tagged or Native)\n' +
'\t| 10.) Show Endpoints on interface\n' +
'\t ---------------------------------------------------\n\n' +
'\t [FAULTS and LOGS]\n'
'\t ---------------------------------------------------\n' +
'\t| 11.) Important Faults Summary\n' +
'\t| 12.) Recent Port up/down intefaces\n'
'\t| 13.) Recent Faults\n' +
'\t| 14.) Recent Admin Changes\n' +
'\t| 15.) Recent Events\n' +
'\t| 16.) Faults/Admin/Events Between Dates\n' +
'\t| 17.) Faults/Admin/Events Between Dates (Detail)\n' +
'\t ---------------------------------------------------\n\n' +
'\t [INFORMATION]\n'
'\t ---------------------------------------------------\n' +
'\t| 18.) IP/Endpoint Search\n' +
'\t| 19.) Show ACI infrustructure status\n' +
'\t| 20.) Show all IPs in a Bridge Domain\n' +
'\t| 21.) Show Port-channel location\n' +
'\t| 22.) Show Static Routes (with add/remove)\n '+
'\t| 23.) Show Physical Interface Profiles \n' +
'\t| 24.) Show Top 50 counters\n' +
'\t| 25.) Show BD --> EPG Relationships\n' +
#'\t| 26.) Show Contract Rules and Hits\n' +
#'\t| 16.) Show Leaf/Spine/APIC info (Not Available)\n' +
#'\t| 17.) EPG to EPG troubleshooting (alpha)\n' +
#'\t| 18.) Route lookup to endpoint (alpha)\n' +
#'\t| 17.) Show all static routes\n' +
'\t ---------------------------------------------------\n\n' +
'\t [CONFIGURATION]\n'
'\t ---------------------------------------------------\n' +
'\t| 26.) Configure Local Span\n' +
'\t| 27.) Capture server traffic ERSPAN to server (Beta)\n' +
'\t| 28.) Interface Deployment Wizard (Beta)\n' +
#'\t| 20.) Create EPGs (Not Available)\n' +
'\t ---------------------------------------------------\n\n' +
'\t [TROUBLESHOOTING]\n'
'\t ---------------------------------------------------\n' +
'\t| 29.) Tools (PING, Clear Endpoint(s) on leaf)\n' +
'\t ---------------------------------------------------\x1b[0m')
cookie = refreshToken(apic, cookie)
while True:
chosen = custom_raw_input('\nSelect a number: ')
if chosen == '1':
try:
shut_noshut_interfaces.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '888':
try:
zoning_rules_checking.main()
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '28':
try:
configure_and_deploy.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '24':
try:
top_interface_problems.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '25':
try:
bd_epg_relations.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '9':
try:
show_epgs.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '29':
try:
localutils.sshleafutil.main(apic,cookie,user=current_user)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '333':
try:
autodeploy.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '2':
try:
assign_epg_interfaces.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '3':
try:
remove_egps.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '4':
try:
portsanddescriptions.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '5':
try:
showinterface.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '8':
try:
short_vlan_epg_to_ports.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '20':
try:
endpoint_per_leaf.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '23':
try:
show_interface_attributes.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '555':
try:
display_switch_to_leaf_structure.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
#elif chosen == '28':
# try:
# clonevpcanddeploy.main(apic,cookie)
# keyinterrupt = False
# except KeyboardInterrupt as k:
# print('\nExit to Main menu\n')
# keyinterrupt = True
# break
elif chosen == '19':
try:
switchandapicinfo.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '21':
try:
portchannel_to_phy_interfaces.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '6':
try:
switch_port_view.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '7':
try:
switch_port_view.main_detail(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '10':
try:
show_all_endpoints_on_interface.main(apic,cookie)
keyinterrupt = False
break
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '11':
try:
fault_summary.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '12':
try:
recent_port_down.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '13':
try:
most_recent_fault_changes.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '14':
try:
most_recent_admin_changes.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '15':
try:
most_recent_event_changes.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '16':
try:
alleventsbetweendates.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '17':
try:
alleventsbetweendates_fulldetail.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '18':
try:
ipendpoint_search.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '111':
try:
epg_troubleshooting.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
#elif chosen == '17':
#
# # break
# try:
# epg_troubleshooting.main(apic,cookie)
# keyinterrupt = False
# except KeyboardInterrupt as k:
# print('\nExit to Main menu\n')
# keyinterrupt = True
# continue
#elif chosen == '18':
#
# # break
# try:
# routetranslation.main(apic,cookie)
# keyinterrupt = False
# continue
# except KeyboardInterrupt as k:
# print('\nExit to Main menu\n')
# keyinterrupt = True
# continue
#elif chosen == '18':
#
# # break
# try:
# check_routing.main(apic,cookie)
# keyinterrupt = False
# except KeyboardInterrupt as k:
# print('\nExit to Main menu\n')
# keyinterrupt = True
# continue
elif chosen == '22':
try:
show_static_routes.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
elif chosen == '26':
try:
create_local_span_session.main(apic,cookie)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
#elif chosen == 'exit':
# raise KeyboardInterrupt
elif chosen == '27':
try:
span_to_server.main(apic,cookie,current_user)
keyinterrupt = False
except KeyboardInterrupt as k:
print('\nExit to Main menu\n')
keyinterrupt = True
break
break
except urllib2.HTTPError:
logger.exception('HTTPError')
unauthenticated = True
continue
except KeyboardInterrupt:
logger.exception('main KeyboardInterrupt')
print('\nEnding Program\n')
exit()
except Exception:
logger.exception('Critical Failure')
raise
if __name__ == '__main__':
try:
main()
except KeyboardInterrupt as k:
print('\nEnding Program\n')
exit()