mirror of
				https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
				synced 2025-11-03 20:27:54 +00:00 
			
		
		
		
	* local_realm in lf_attenmod is unused. * local_realm in attenuator_profile is unused, because I'm switching to inheritance as part of my work eliminating redundancy. Signed-off-by: Matthew Stidham <stidmatt@gmail.com>
		
			
				
	
	
		
			80 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
#!/usr/bin/env python3
 | 
						|
import sys
 | 
						|
import os
 | 
						|
import importlib
 | 
						|
import time
 | 
						|
 | 
						|
 
 | 
						|
sys.path.append(os.path.join(os.path.abspath(__file__ + "../../../")))
 | 
						|
 | 
						|
lfcli_base = importlib.import_module("py-json.LANforge.lfcli_base")
 | 
						|
LFCliBase = lfcli_base.LFCliBase
 | 
						|
LFRequest = importlib.import_module("py-json.LANforge.LFRequest")
 | 
						|
LFUtils = importlib.import_module("py-json.LANforge.LFUtils")
 | 
						|
 | 
						|
 | 
						|
class ATTENUATORProfile(LFCliBase):
 | 
						|
    def __init__(self, lfclient_host, lfclient_port, debug_=False):
 | 
						|
        super().__init__(lfclient_host, lfclient_port, debug_)
 | 
						|
        self.lfclient_host = lfclient_host
 | 
						|
        self.COMMANDS = ["show_attenuators", "set_attenuator"]
 | 
						|
        self.atten_serno = ""
 | 
						|
        self.atten_idx = ""
 | 
						|
        self.atten_val = ""
 | 
						|
        self.atten_data = {
 | 
						|
            "shelf": 1,
 | 
						|
            "resource": 1,
 | 
						|
            "serno": None,
 | 
						|
            "atten_idx": None,
 | 
						|
            "val": None,
 | 
						|
            "mode": None,
 | 
						|
            "pulse_width_us5": None,
 | 
						|
            "pulse_interval_ms": None,
 | 
						|
            "pulse_count": None,
 | 
						|
            "pulse_time_ms": None
 | 
						|
        }
 | 
						|
        self.debug = debug_
 | 
						|
 | 
						|
    def set_command_param(self, command_name, param_name, param_value):
 | 
						|
        # we have to check what the param name is
 | 
						|
        if (command_name is None) or (command_name == ""):
 | 
						|
            return
 | 
						|
        if (param_name is None) or (param_name == ""):
 | 
						|
            return
 | 
						|
        if command_name not in self.COMMANDS:
 | 
						|
            raise ValueError("Command name name [%s] not defined in %s" % (command_name, self.COMMANDS))
 | 
						|
        if command_name == "set_attenuator":
 | 
						|
            self.atten_data[param_name] = param_value
 | 
						|
 | 
						|
    def show(self):
 | 
						|
        print("Show Attenuators.........")
 | 
						|
        response = self.json_get("/attenuators/")
 | 
						|
        time.sleep(0.01)
 | 
						|
        if response is None:
 | 
						|
            print(response)
 | 
						|
            raise ValueError("Cannot find any endpoints")
 | 
						|
        else:
 | 
						|
            attenuator_resp = response["attenuators"]
 | 
						|
            for attenuator in attenuator_resp:
 | 
						|
                for key, val in attenuator.items():
 | 
						|
                    if key == "entity id":
 | 
						|
                        serial_num = val.split(".")
 | 
						|
                        print("Serial-num : %s" % serial_num[-1])
 | 
						|
                print("%s : %s" % (key, val))
 | 
						|
        print("\n")
 | 
						|
 | 
						|
    def create(self):
 | 
						|
        if type(self.atten_serno) == str or len(self.atten_idx) == 0 or type(self.atten_val) == str:
 | 
						|
            print("ERROR:  Must specify atten_serno, atten_idx, and atten_val when setting attenuator.\n")
 | 
						|
        print("Setting Attenuator...")
 | 
						|
        self.set_command_param("set_attenuator", "serno", self.atten_serno)
 | 
						|
        self.set_command_param("set_attenuator", "atten_idx", self.atten_idx)
 | 
						|
        self.set_command_param("set_attenuator", "val", self.atten_val)
 | 
						|
        set_attenuators = LFRequest.LFRequest(self.lfclient_url + "/cli-json/set_attenuator", debug_=self.debug)
 | 
						|
        set_attenuators.addPostData(self.atten_data)
 | 
						|
        time.sleep(0.01)
 | 
						|
        json_response = set_attenuators.jsonPost(self.debug)
 | 
						|
        time.sleep(10)
 | 
						|
        print("\n")
 | 
						|
 |