mirror of
https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
synced 2025-11-01 03:07:56 +00:00
implement CLI for create_wanlink.py
This commit is contained in:
@@ -2,6 +2,12 @@
|
|||||||
# Create and modify WAN Links Using LANforge JSON AP : http://www.candelatech.com/cookbook.php?vol=cli&book=JSON:+Managing+WANlinks+using+JSON+and+Python
|
# Create and modify WAN Links Using LANforge JSON AP : http://www.candelatech.com/cookbook.php?vol=cli&book=JSON:+Managing+WANlinks+using+JSON+and+Python
|
||||||
# Written by Candela Technologies Inc.
|
# Written by Candela Technologies Inc.
|
||||||
# Updated by: Erin Grimes
|
# Updated by: Erin Grimes
|
||||||
|
|
||||||
|
"""
|
||||||
|
sample command:
|
||||||
|
./test_wanlink.py --name my_wanlink4 --latency_A 20 --latency_B 69 --rate 1000 --jitter_A 53 --jitter_B 73 --jitter_freq 6 --drop_A 12 --drop_B 11
|
||||||
|
"""
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import urllib
|
import urllib
|
||||||
import importlib
|
import importlib
|
||||||
@@ -13,19 +19,23 @@ import os
|
|||||||
from time import sleep
|
from time import sleep
|
||||||
from urllib import error
|
from urllib import error
|
||||||
import pprint
|
import pprint
|
||||||
|
import argparse
|
||||||
|
|
||||||
|
|
||||||
sys.path.append(os.path.join(os.path.abspath(__file__ + "../../../")))
|
sys.path.append(os.path.join(os.path.abspath(__file__ + "../../../")))
|
||||||
|
|
||||||
LFRequest = importlib.import_module("py-json.LANforge.LFRequest")
|
LFRequest = importlib.import_module("py-json.LANforge.LFRequest")
|
||||||
LFUtils = importlib.import_module("py-json.LANforge.LFUtils")
|
LFUtils = importlib.import_module("py-json.LANforge.LFUtils")
|
||||||
|
lfcli_base = importlib.import_module("py-json.LANforge.lfcli_base")
|
||||||
|
LFCliBase = lfcli_base.LFCliBase
|
||||||
|
|
||||||
j_printer = pprint.PrettyPrinter(indent=2)
|
j_printer = pprint.PrettyPrinter(indent=2)
|
||||||
# todo: this needs to change
|
# todo: this needs to change
|
||||||
resource_id = 1
|
resource_id = 1
|
||||||
|
|
||||||
|
|
||||||
def main(base_url, args={}):
|
def main(args={}):
|
||||||
|
base_url = 'http://'+args['host']+':8080'
|
||||||
print(base_url)
|
print(base_url)
|
||||||
json_post = ""
|
json_post = ""
|
||||||
json_response = ""
|
json_response = ""
|
||||||
@@ -235,4 +245,67 @@ def main(base_url, args={}):
|
|||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
parser = LFCliBase.create_basic_argparse(
|
||||||
|
prog='test_wanlink.py',
|
||||||
|
formatter_class=argparse.RawTextHelpFormatter)
|
||||||
|
for group in parser._action_groups:
|
||||||
|
if group.title == "required arguments":
|
||||||
|
required_args = group
|
||||||
|
break
|
||||||
|
|
||||||
|
optional_args = None
|
||||||
|
for group in parser._action_groups:
|
||||||
|
if group.title == "optional arguments":
|
||||||
|
optional_args = group
|
||||||
|
break
|
||||||
|
if optional_args is not None:
|
||||||
|
optional_args.add_argument('--host', help='The resource IP address', default="localhost")
|
||||||
|
optional_args.add_argument('--port_A', help='Endpoint A', default="eth1")
|
||||||
|
optional_args.add_argument('--port_B', help='Endpoint B', default="eth2")
|
||||||
|
optional_args.add_argument('--name', help='The name of the wanlink', default="wl_eg1")
|
||||||
|
optional_args.add_argument('--rate', help='The maximum rate of transfer at both endpoints (bits/s)', default=1000000)
|
||||||
|
optional_args.add_argument('--rate_A', help='The max rate of transfer at endpoint A (bits/s)', default=None)
|
||||||
|
optional_args.add_argument('--rate_B', help='The maximum rate of transfer (bits/s)', default=None)
|
||||||
|
optional_args.add_argument('--latency', help='The delay of both ports', default=20)
|
||||||
|
optional_args.add_argument('--latency_A', help='The delay of port A', default=None)
|
||||||
|
optional_args.add_argument('--latency_B', help='The delay of port B', default=None)
|
||||||
|
optional_args.add_argument('--jitter', help='The max jitter of both ports (ms)', default=None)
|
||||||
|
optional_args.add_argument('--jitter_A', help='The max jitter of port A (ms)', default=None)
|
||||||
|
optional_args.add_argument('--jitter_B', help='The max jitter of port B (ms)', default=None)
|
||||||
|
optional_args.add_argument('--jitter_freq', help='The jitter frequency of both ports (%%)', default=None)
|
||||||
|
optional_args.add_argument('--jitter_freq_A', help='The jitter frequency of port A (%%)', default=None)
|
||||||
|
optional_args.add_argument('--jitter_freq_B', help='The jitter frequency of port B (%%)', default=None)
|
||||||
|
optional_args.add_argument('--drop', help='The drop frequency of both ports (%%)', default=None)
|
||||||
|
optional_args.add_argument('--drop_A', help='The drop frequency of port A (%%)', default=None)
|
||||||
|
optional_args.add_argument('--drop_B', help='The drop frequency of port B (%%)', default=None)
|
||||||
|
# todo: packet loss A and B
|
||||||
|
# todo: jitter A and B
|
||||||
|
for group in parser._action_groups:
|
||||||
|
if group.title == "optional arguments":
|
||||||
|
optional_args = group
|
||||||
|
break
|
||||||
|
parseargs = parser.parse_args()
|
||||||
|
args = {
|
||||||
|
"host": parseargs.mgr,
|
||||||
|
"port": parseargs.mgr_port,
|
||||||
|
"name": parseargs.name,
|
||||||
|
"port_A": parseargs.port_A,
|
||||||
|
"port_B": parseargs.port_B,
|
||||||
|
"latency": parseargs.latency,
|
||||||
|
"latency_A": (parseargs.latency_A if parseargs.latency_A is not None else parseargs.latency),
|
||||||
|
"latency_B": (parseargs.latency_B if parseargs.latency_B is not None else parseargs.latency),
|
||||||
|
"rate": (parseargs.rate),
|
||||||
|
"rate_A": (parseargs.rate_A if parseargs.rate_A is not None else parseargs.rate),
|
||||||
|
"rate_B": (parseargs.rate_B if parseargs.rate_B is not None else parseargs.rate),
|
||||||
|
"jitter": (parseargs.jitter),
|
||||||
|
"jitter_A": (parseargs.jitter_A if parseargs.jitter_A is not None else parseargs.jitter),
|
||||||
|
"jitter_B": (parseargs.jitter_B if parseargs.jitter_B is not None else parseargs.jitter),
|
||||||
|
"jitter_freq": (parseargs.jitter),
|
||||||
|
"jitter_freq_A": (parseargs.jitter_freq_A if parseargs.jitter_freq_A is not None else parseargs.jitter_freq),
|
||||||
|
"jitter_freq_B": (parseargs.jitter_freq_B if parseargs.jitter_freq_B is not None else parseargs.jitter_freq),
|
||||||
|
"drop": (parseargs.drop),
|
||||||
|
"drop_A": (parseargs.drop_A if parseargs.drop_A is not None else parseargs.drop),
|
||||||
|
"drop_B": (parseargs.drop_B if parseargs.drop_B is not None else parseargs.drop),
|
||||||
|
}
|
||||||
|
|
||||||
|
main(args)
|
||||||
|
|||||||
Reference in New Issue
Block a user