From 4a16b07c364085a2d6e34f3d525f7e50dc624a28 Mon Sep 17 00:00:00 2001 From: vg12345 <77556137+vg12345@users.noreply.github.com> Date: Tue, 21 May 2024 17:06:53 +0300 Subject: [PATCH] Issue:3903841:PDR plugin: adding warnings and protection (#220) --- .../ufm_sim_web_service/api/pdr_plugin_api.py | 39 ++++++++++++++++--- 1 file changed, 34 insertions(+), 5 deletions(-) diff --git a/plugins/pdr_deterministic_plugin/ufm_sim_web_service/api/pdr_plugin_api.py b/plugins/pdr_deterministic_plugin/ufm_sim_web_service/api/pdr_plugin_api.py index 6649b2f64..c8a0c22e8 100644 --- a/plugins/pdr_deterministic_plugin/ufm_sim_web_service/api/pdr_plugin_api.py +++ b/plugins/pdr_deterministic_plugin/ufm_sim_web_service/api/pdr_plugin_api.py @@ -71,14 +71,16 @@ def exclude_ports(self): response = "" for pair in pairs: if pair: - port_name = pair[0] + port_name = self.fix_port_name(pair[0]) ttl = 0 if len(pair) == 1 else int(pair[1]) self.isolation_mgr.exclude_list.add(port_name, ttl) if ttl == 0: - response += f"Port {port_name} added to exclude list forever{EOL}" + response += f"Port {port_name} added to exclude list forever" else: - response += f"Port {port_name} added to exclude list for {ttl} seconds{EOL}" + response += f"Port {port_name} added to exclude list for {ttl} seconds" + response += self.get_port_warning(port_name) + EOL + return response, HTTPStatus.OK @@ -98,10 +100,13 @@ def include_ports(self): response = "" for port_name in port_names: + port_name = self.fix_port_name(port_name) if self.isolation_mgr.exclude_list.remove(port_name): - response += f"Port {port_name} removed from exclude list{EOL}" + response += f"Port {port_name} removed from exclude list" else: - response += f"Port {port_name} is not in exclude list{EOL}" + response += f"Port {port_name} is not in exclude list" + + response += self.get_port_warning(port_name) + EOL return response, HTTPStatus.OK @@ -116,3 +121,27 @@ def get_request_data(self): else: # Attempt to load plain data text as JSON return json.loads(request.get_data(as_text=True)) + + + def fix_port_name(self, port_name): + """ + Try to fix common user mistakes for input port names + Return fixed port name + """ + # Remove '0x' from the beginning + if port_name.startswith('0x'): + port_name = port_name[2:] + + # Additional corrections can be added here upon request + return port_name + + def get_port_warning(self, port_name): + """ + Return warning text if port does not exist in ports data and update plugin logs + """ + if not self.isolation_mgr.test_mode: + if not self.isolation_mgr.ports_data.get(port_name): + self.isolation_mgr.logger.warning(f"Port {port_name} is not found in ports data") + return " (WARNING: port is not found in ports data)" + + return ""