1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

redfish_command: Avoid power on/off commands if system already in target state (#56069)

* avoid power on/off commands if system already in target state

* add changelog fragment
This commit is contained in:
Bill Dodd 2019-06-10 02:50:04 -05:00 committed by René Moser
parent d86183f595
commit e5972ccbab
2 changed files with 11 additions and 4 deletions

View file

@ -0,0 +1,3 @@
---
bugfixes:
- redfish_command - make power commands idempotent (https://github.com/ansible/ansible/issues/55869)

View file

@ -620,16 +620,21 @@ class RedfishUtils(object):
return result return result
def manage_system_power(self, command): def manage_system_power(self, command):
result = {}
key = "Actions" key = "Actions"
# Search for 'key' entry and extract URI from it # Search for 'key' entry and extract URI from it
response = self.get_request(self.root_uri + self.systems_uris[0]) response = self.get_request(self.root_uri + self.systems_uris[0])
if response['ret'] is False: if response['ret'] is False:
return response return response
result['ret'] = True
data = response['data'] data = response['data']
power_state = data["PowerState"] power_state = data["PowerState"]
if power_state == "On" and command == 'PowerOn':
return {'ret': True, 'changed': False}
if power_state == "Off" and command in ['PowerGracefulShutdown', 'PowerForceOff']:
return {'ret': True, 'changed': False}
reset_action = data[key]["#ComputerSystem.Reset"] reset_action = data[key]["#ComputerSystem.Reset"]
action_uri = reset_action["target"] action_uri = reset_action["target"]
allowable_vals = reset_action.get("ResetType@Redfish.AllowableValues", []) allowable_vals = reset_action.get("ResetType@Redfish.AllowableValues", [])
@ -657,8 +662,7 @@ class RedfishUtils(object):
response = self.post_request(self.root_uri + action_uri, payload) response = self.post_request(self.root_uri + action_uri, payload)
if response['ret'] is False: if response['ret'] is False:
return response return response
result['ret'] = True return {'ret': True, 'changed': True}
return result
def list_users(self): def list_users(self):
result = {} result = {}