From cbf6cba83f264a275e96815b3ab3a0270d1fe7d1 Mon Sep 17 00:00:00 2001 From: apurvaraghu <100869315+apurvaraghu@users.noreply.github.com> Date: Wed, 17 Jan 2024 23:35:13 -0800 Subject: [PATCH 1/2] implement shutdown for vmhost devices --- lib/jnpr/junos/utils/sw.py | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/lib/jnpr/junos/utils/sw.py b/lib/jnpr/junos/utils/sw.py index 30cbbac75..8dd9c093b 100644 --- a/lib/jnpr/junos/utils/sw.py +++ b/lib/jnpr/junos/utils/sw.py @@ -1135,7 +1135,8 @@ def _system_operation( ) and member_id is not None: cmd.append(E("member", str(member_id))) if in_min >= 0 and at is None: - cmd.append(E("in", str(in_min))) + if vmhost is not True: + cmd.append(E("in", str(in_min))) elif at is not None: cmd.append(E("at", str(at))) try: @@ -1230,7 +1231,7 @@ def reboot( # ------------------------------------------------------------------------- # poweroff - system shutdown # ------------------------------------------------------------------------- - def poweroff(self, in_min=0, at=None, on_node=None, all_re=True, other_re=False): + def poweroff(self, in_min=0, at=None, on_node=None, all_re=True, other_re=False, vmhost=False): """ Perform a system shutdown, with optional delay (in minutes) . @@ -1252,6 +1253,8 @@ def poweroff(self, in_min=0, at=None, on_node=None, all_re=True, other_re=False) :param str other_re: If the system has dual Routing Engines and this option is C(true), then the action is performed on the other REs in the system. + :param str vmhost: If the device is vmhost device then the shutdown will be performed on the device + :returns: * power-off message (string) if command successful @@ -1265,11 +1268,14 @@ def poweroff(self, in_min=0, at=None, on_node=None, all_re=True, other_re=False) else: cmd = E("request-node-power-off") cmd.append(E("node", on_node)) + elif vmhost is True: + cmd = E("request-vmhost-poweroff") + all_re = False else: cmd = E("request-power-off") try: return self._system_operation( - cmd, in_min, at, all_re, other_re, vmhost=False + cmd, in_min, at, all_re, other_re, vmhost ) except Exception as err: if err.rsp.findtext(".//error-severity") != "warning": From 78322e748543a6b953fa799fd27afa0867e63fb3 Mon Sep 17 00:00:00 2001 From: apurvaraghu <100869315+apurvaraghu@users.noreply.github.com> Date: Thu, 18 Jan 2024 01:10:06 -0800 Subject: [PATCH 2/2] fix black failure --- lib/jnpr/junos/utils/sw.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/jnpr/junos/utils/sw.py b/lib/jnpr/junos/utils/sw.py index 8dd9c093b..43a76c436 100644 --- a/lib/jnpr/junos/utils/sw.py +++ b/lib/jnpr/junos/utils/sw.py @@ -1231,7 +1231,9 @@ def reboot( # ------------------------------------------------------------------------- # poweroff - system shutdown # ------------------------------------------------------------------------- - def poweroff(self, in_min=0, at=None, on_node=None, all_re=True, other_re=False, vmhost=False): + def poweroff( + self, in_min=0, at=None, on_node=None, all_re=True, other_re=False, vmhost=False + ): """ Perform a system shutdown, with optional delay (in minutes) . @@ -1274,9 +1276,7 @@ def poweroff(self, in_min=0, at=None, on_node=None, all_re=True, other_re=False, else: cmd = E("request-power-off") try: - return self._system_operation( - cmd, in_min, at, all_re, other_re, vmhost - ) + return self._system_operation(cmd, in_min, at, all_re, other_re, vmhost) except Exception as err: if err.rsp.findtext(".//error-severity") != "warning": raise err