#! /usr/bin/python import sys import logging import requests import json from datetime import datetime import time gmux_ip = '' logging.basicConfig(level=logging.DEBUG, format='%(message)s') logger = logging.getLogger('') headers = {'Content-Type': 'application/json', 'Accept': 'application/json'} auth = 'admin', 'admin' base_url = '' def list_interface(): url = base_url logger.info(url) r = requests.get(url, headers=headers, auth=auth) logger.debug(r) response = r.json() logger.debug('---------------------------------------------------------------') logger.debug(json.dumps(response, indent=4, sort_keys=True)) logger.debug('---------------------------------------------------------------') def clean_gmux(): url = base_url r = requests.get(url, headers=headers, auth=auth) response = r.json() interfaces = response.get('interfaces').get('interface') for inf in interfaces: name = inf.get('name') if name.startswith('vxlanTun10'): logger.debug('name = {0}'.format(name)) delete_interface_v3po_l2(name) for inf in interfaces: name = inf.get('name') if name.startswith('vxlanTun10'): logger.debug('name = {0}'.format(name)) delete_interface(name) def delete_interface_v3po_l2(interface_name): url = '{0}/interface/{1}/v3po:l2'.format(base_url, interface_name) r = requests.delete(url, headers=headers, auth=auth) logger.debug(r) def delete_interface(interface_name): url = '{0}/interface/{1}'.format(base_url, interface_name) r = requests.delete(url, headers=headers, auth=auth) logger.debug(r) if __name__ == '__main__': gmux_ip = sys.argv[1] base_url = 'http://{0}:8183/restconf/config/ietf-interfaces:interfaces'.format(gmux_ip) logger.debug('---------------------------------------------------------------') logger.debug('list interfaces before cleaning gmux') list_interface() clean_gmux() logger.debug('---------------------------------------------------------------') logger.debug('list interfaces after cleaning gmux') list_interface()