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

Actual attributes were being created and messing with the modules (#22424)

This commit is contained in:
Tim Rupp 2017-03-08 13:10:02 -08:00 committed by John R Barker
parent 78e116077a
commit 32146acf4e

View file

@ -288,26 +288,26 @@ class AnsibleF5Parameters(object):
if params: if params:
for k,v in iteritems(params): for k,v in iteritems(params):
if self.api_map is not None and k in self.api_map: if self.api_map is not None and k in self.api_map:
# Handle weird API parameters like `dns.proxy.__iter__` by dict_to_use = self.api_map
# using a map provided by the module developer map_key = self.api_map[k]
class_attr = getattr(type(self), self.api_map[k], None) else:
if isinstance(class_attr, property): dict_to_use = self._values
# There is a mapped value for the api_map key map_key = k
if class_attr.fset is None:
# If the mapped value does not have an associated setter # Handle weird API parameters like `dns.proxy.__iter__` by
self._values[self.api_map[k]] = v # using a map provided by the module developer
else: class_attr = getattr(type(self), map_key, None)
# The mapped value has a setter if isinstance(class_attr, property):
setattr(self, self.api_map[k], v) # There is a mapped value for the api_map key
if class_attr.fset is None:
# If the mapped value does not have an associated setter
self._values[map_key] = v
else: else:
# If the mapped value is not a @property # The mapped value has a setter
self._values[self.api_map[k]] = v setattr(self, map_key, v)
try: else:
# There is no map, or the provided param is not in the api_map # If the mapped value is not a @property
setattr(self, k, v) self._values[map_key] = v
except AttributeError:
# At a minimum put it in values.
self._values[k] = v
def __getattr__(self, item): def __getattr__(self, item):
# Ensures that properties that weren't defined, and therefore stashed # Ensures that properties that weren't defined, and therefore stashed