Reflect changed JSON structure than zabbix version 4.4 or more to zabbix_user
add fragments file Fix several pointed out https://github.com/ansible/ansible/pull/67475#discussion_r380528775 https://github.com/ansible/ansible/pull/67475#discussion_r380532685 Enable integration test
This commit is contained in:
parent
5550fc442b
commit
454b043c13
3 changed files with 20 additions and 13 deletions
2
changelogs/fragments/zabbix_user-mediatype-error.yml
Normal file
2
changelogs/fragments/zabbix_user-mediatype-error.yml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
bugfixes:
|
||||||
|
- zabbix_user - Fixed an issue where module failed with zabbix 4.4 or above (see https://github.com/ansible/ansible/pull/67475)
|
|
@ -285,6 +285,7 @@ class User(object):
|
||||||
def __init__(self, module, zbx):
|
def __init__(self, module, zbx):
|
||||||
self._module = module
|
self._module = module
|
||||||
self._zapi = zbx
|
self._zapi = zbx
|
||||||
|
self._zbx_api_version = zbx.api_version()[:3]
|
||||||
|
|
||||||
def get_usergroupid_by_user_group_name(self, usrgrps):
|
def get_usergroupid_by_user_group_name(self, usrgrps):
|
||||||
user_group_ids = []
|
user_group_ids = []
|
||||||
|
@ -308,13 +309,19 @@ class User(object):
|
||||||
for user_media in copy_user_medias:
|
for user_media in copy_user_medias:
|
||||||
media_types = self._zapi.mediatype.get({'output': 'extend'})
|
media_types = self._zapi.mediatype.get({'output': 'extend'})
|
||||||
for media_type in media_types:
|
for media_type in media_types:
|
||||||
|
if LooseVersion(self._zbx_api_version) < LooseVersion('4.4'):
|
||||||
if media_type['description'] == user_media['mediatype']:
|
if media_type['description'] == user_media['mediatype']:
|
||||||
user_media['mediatypeid'] = media_type['mediatypeid']
|
user_media['mediatypeid'] = media_type['mediatypeid']
|
||||||
del user_media['mediatype']
|
break
|
||||||
|
else:
|
||||||
|
if media_type['name'] == user_media['mediatype']:
|
||||||
|
user_media['mediatypeid'] = media_type['mediatypeid']
|
||||||
break
|
break
|
||||||
|
|
||||||
if 'mediatypeid' not in user_media:
|
if 'mediatypeid' not in user_media:
|
||||||
self._module.fail_json(msg="Media type not found: %s" % user_media['mediatype'])
|
self._module.fail_json(msg="Media type not found: %s" % user_media['mediatype'])
|
||||||
|
else:
|
||||||
|
del user_media['mediatype']
|
||||||
|
|
||||||
severity_binary_number = ''
|
severity_binary_number = ''
|
||||||
for severity_key in 'disaster', 'high', 'average', 'warning', 'information', 'not_classified':
|
for severity_key in 'disaster', 'high', 'average', 'warning', 'information', 'not_classified':
|
||||||
|
@ -333,7 +340,7 @@ class User(object):
|
||||||
|
|
||||||
def user_parameter_difference_check(self, zbx_user, alias, name, surname, user_group_ids, passwd, lang, theme,
|
def user_parameter_difference_check(self, zbx_user, alias, name, surname, user_group_ids, passwd, lang, theme,
|
||||||
autologin, autologout, refresh, rows_per_page, url, user_medias, user_type,
|
autologin, autologout, refresh, rows_per_page, url, user_medias, user_type,
|
||||||
zbx_api_version, override_passwd):
|
override_passwd):
|
||||||
|
|
||||||
user_medias = self.convert_user_medias_parameter_types(user_medias)
|
user_medias = self.convert_user_medias_parameter_types(user_medias)
|
||||||
|
|
||||||
|
@ -349,7 +356,7 @@ class User(object):
|
||||||
# In zabbix 4.0 and above, Email sendto is of type list.
|
# In zabbix 4.0 and above, Email sendto is of type list.
|
||||||
# This module, one media supports only one Email sendto.
|
# This module, one media supports only one Email sendto.
|
||||||
# Therefore following processing extract one Email from list.
|
# Therefore following processing extract one Email from list.
|
||||||
if LooseVersion(zbx_api_version) >= LooseVersion('4.0'):
|
if LooseVersion(self._zbx_api_version) >= LooseVersion('4.0'):
|
||||||
for media in existing_data['medias']:
|
for media in existing_data['medias']:
|
||||||
if isinstance(media['sendto'], list):
|
if isinstance(media['sendto'], list):
|
||||||
media['sendto'] = media['sendto'][0]
|
media['sendto'] = media['sendto'][0]
|
||||||
|
@ -434,7 +441,7 @@ class User(object):
|
||||||
return user_ids, diff_params
|
return user_ids, diff_params
|
||||||
|
|
||||||
def update_user(self, zbx_user, alias, name, surname, user_group_ids, passwd, lang, theme, autologin, autologout,
|
def update_user(self, zbx_user, alias, name, surname, user_group_ids, passwd, lang, theme, autologin, autologout,
|
||||||
refresh, rows_per_page, url, user_medias, user_type, zbx_api_version, override_passwd):
|
refresh, rows_per_page, url, user_medias, user_type, override_passwd):
|
||||||
|
|
||||||
user_medias = self.convert_user_medias_parameter_types(user_medias)
|
user_medias = self.convert_user_medias_parameter_types(user_medias)
|
||||||
|
|
||||||
|
@ -460,7 +467,7 @@ class User(object):
|
||||||
request_data['passwd'] = passwd
|
request_data['passwd'] = passwd
|
||||||
|
|
||||||
# In the case of zabbix 3.2 or less, it is necessary to use updatemedia method to update media.
|
# In the case of zabbix 3.2 or less, it is necessary to use updatemedia method to update media.
|
||||||
if LooseVersion(zbx_api_version) <= LooseVersion('3.2'):
|
if LooseVersion(self._zbx_api_version) <= LooseVersion('3.2'):
|
||||||
try:
|
try:
|
||||||
user_ids = self._zapi.user.update(request_data)
|
user_ids = self._zapi.user.update(request_data)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
|
@ -474,7 +481,7 @@ class User(object):
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
self._module.fail_json(msg="Failed to update user medias %s: %s" % (alias, e))
|
self._module.fail_json(msg="Failed to update user medias %s: %s" % (alias, e))
|
||||||
|
|
||||||
if LooseVersion(zbx_api_version) >= LooseVersion('3.4'):
|
if LooseVersion(self._zbx_api_version) >= LooseVersion('3.4'):
|
||||||
try:
|
try:
|
||||||
request_data['user_medias'] = user_medias
|
request_data['user_medias'] = user_medias
|
||||||
user_ids = self._zapi.user.update(request_data)
|
user_ids = self._zapi.user.update(request_data)
|
||||||
|
@ -611,7 +618,6 @@ def main():
|
||||||
user = User(module, zbx)
|
user = User(module, zbx)
|
||||||
|
|
||||||
user_ids = {}
|
user_ids = {}
|
||||||
zbx_api_version = zbx.api_version()[:3]
|
|
||||||
zbx_user = user.check_user_exist(alias)
|
zbx_user = user.check_user_exist(alias)
|
||||||
if state == 'present':
|
if state == 'present':
|
||||||
user_group_ids = user.get_usergroupid_by_user_group_name(usrgrps)
|
user_group_ids = user.get_usergroupid_by_user_group_name(usrgrps)
|
||||||
|
@ -621,12 +627,12 @@ def main():
|
||||||
autologin, autologout, refresh,
|
autologin, autologout, refresh,
|
||||||
rows_per_page, after_login_url,
|
rows_per_page, after_login_url,
|
||||||
user_medias, user_type,
|
user_medias, user_type,
|
||||||
zbx_api_version, override_passwd)
|
override_passwd)
|
||||||
|
|
||||||
if not module.check_mode and diff_check_result:
|
if not module.check_mode and diff_check_result:
|
||||||
user_ids = user.update_user(zbx_user, alias, name, surname, user_group_ids, passwd, lang,
|
user_ids = user.update_user(zbx_user, alias, name, surname, user_group_ids, passwd, lang,
|
||||||
theme, autologin, autologout, refresh, rows_per_page, after_login_url,
|
theme, autologin, autologout, refresh, rows_per_page, after_login_url,
|
||||||
user_medias, user_type, zbx_api_version, override_passwd)
|
user_medias, user_type, override_passwd)
|
||||||
else:
|
else:
|
||||||
diff_check_result = True
|
diff_check_result = True
|
||||||
user_ids, diff_params = user.add_user(alias, name, surname, user_group_ids, passwd, lang, theme, autologin,
|
user_ids, diff_params = user.add_user(alias, name, surname, user_group_ids, passwd, lang, theme, autologin,
|
||||||
|
|
|
@ -4,4 +4,3 @@ skip/osx
|
||||||
skip/freebsd
|
skip/freebsd
|
||||||
skip/rhel
|
skip/rhel
|
||||||
skip/aix
|
skip/aix
|
||||||
disabled
|
|
||||||
|
|
Loading…
Reference in a new issue