mirror of
https://github.com/zahodi/ansible-mikrotik.git
synced 2025-08-01 16:44:31 +02:00
add check mode to snmp module
This commit is contained in:
parent
1326fad5c1
commit
debe4f35d2
2 changed files with 84 additions and 64 deletions
|
@ -55,67 +55,67 @@ from ansible.module_utils.basic import AnsibleModule
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec = dict(
|
argument_spec = dict(
|
||||||
hostname = dict(required=True),
|
hostname = dict(required=True),
|
||||||
username = dict(required=True),
|
username = dict(required=True),
|
||||||
password = dict(required=True),
|
password = dict(required=True),
|
||||||
settings = dict(required=False, type='dict'),
|
settings = dict(required=False, type='dict'),
|
||||||
parameter = dict(
|
parameter = dict(
|
||||||
required = True,
|
required = True,
|
||||||
choices = ['community', 'snmp'],
|
choices = ['community', 'snmp'],
|
||||||
type = 'str'
|
type = 'str'
|
||||||
),
|
),
|
||||||
state = dict(
|
state = dict(
|
||||||
required = False,
|
required = False,
|
||||||
choices = ['present', 'absent'],
|
choices = ['present', 'absent'],
|
||||||
type = 'str'
|
type = 'str'
|
||||||
),
|
),
|
||||||
)
|
),
|
||||||
|
supports_check_mode=True
|
||||||
|
)
|
||||||
|
|
||||||
|
idempotent_parameter = None
|
||||||
|
params = module.params
|
||||||
|
|
||||||
|
|
||||||
|
if params['parameter'] == 'community':
|
||||||
|
idempotent_parameter = 'name'
|
||||||
|
params['parameter'] = "snmp/community"
|
||||||
|
|
||||||
|
mt_obj = MikrotikIdempotent(
|
||||||
|
hostname = params['hostname'],
|
||||||
|
username = params['username'],
|
||||||
|
password = params['password'],
|
||||||
|
state = params['state'],
|
||||||
|
desired_params = params['settings'],
|
||||||
|
idempotent_param = idempotent_parameter,
|
||||||
|
api_path = '/' + str(params['parameter']),
|
||||||
|
check_mode = module.check_mode
|
||||||
|
)
|
||||||
|
|
||||||
|
mt_obj.sync_state()
|
||||||
|
|
||||||
|
if mt_obj.failed:
|
||||||
|
module.fail_json(
|
||||||
|
msg = mt_obj.failed_msg
|
||||||
)
|
)
|
||||||
|
elif mt_obj.changed:
|
||||||
idempotent_parameter = None
|
module.exit_json(
|
||||||
params = module.params
|
failed=False,
|
||||||
|
changed=True,
|
||||||
|
msg=mt_obj.changed_msg,
|
||||||
if params['parameter'] == 'community':
|
diff={ "prepared": {
|
||||||
idempotent_parameter = 'name'
|
"old": mt_obj.old_params,
|
||||||
params['parameter'] = "snmp/community"
|
"new": mt_obj.new_params,
|
||||||
|
}},
|
||||||
mt_obj = MikrotikIdempotent(
|
)
|
||||||
hostname = params['hostname'],
|
else:
|
||||||
username = params['username'],
|
module.exit_json(
|
||||||
password = params['password'],
|
failed=False,
|
||||||
state = params['state'],
|
changed=False,
|
||||||
desired_params = params['settings'],
|
msg=params['settings'],
|
||||||
idempotent_param = idempotent_parameter,
|
|
||||||
api_path = '/' + str(params['parameter']),
|
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
||||||
mt_obj.sync_state()
|
|
||||||
|
|
||||||
if mt_obj.failed:
|
|
||||||
module.fail_json(
|
|
||||||
msg = mt_obj.failed_msg
|
|
||||||
)
|
|
||||||
elif mt_obj.changed:
|
|
||||||
module.exit_json(
|
|
||||||
failed=False,
|
|
||||||
changed=True,
|
|
||||||
msg=mt_obj.changed_msg,
|
|
||||||
diff={ "prepared": {
|
|
||||||
"old": mt_obj.old_params,
|
|
||||||
"new": mt_obj.new_params,
|
|
||||||
}},
|
|
||||||
)
|
|
||||||
else:
|
|
||||||
module.exit_json(
|
|
||||||
failed=False,
|
|
||||||
changed=False,
|
|
||||||
#msg='',
|
|
||||||
msg=params['settings'],
|
|
||||||
)
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
|
|
@ -1632,7 +1632,11 @@
|
||||||
settings:
|
settings:
|
||||||
name: to_remove
|
name: to_remove
|
||||||
register: snmp_community_rem
|
register: snmp_community_rem
|
||||||
failed_when: not ( snmp_community_rem | changed )
|
failed_when: (
|
||||||
|
not ansible_check_mode
|
||||||
|
) and (
|
||||||
|
not ( snmp_community_rem | changed )
|
||||||
|
)
|
||||||
|
|
||||||
- name: ALWAYS_CHANGES modify existing snmp community
|
- name: ALWAYS_CHANGES modify existing snmp community
|
||||||
mt_snmp:
|
mt_snmp:
|
||||||
|
@ -1645,7 +1649,11 @@
|
||||||
addresses: "10.0.0.0/8"
|
addresses: "10.0.0.0/8"
|
||||||
name: icghol
|
name: icghol
|
||||||
register: snmp_community
|
register: snmp_community
|
||||||
failed_when: not ( snmp_community | changed )
|
failed_when: (
|
||||||
|
not ansible_check_mode
|
||||||
|
) and (
|
||||||
|
not ( snmp_community | changed )
|
||||||
|
)
|
||||||
|
|
||||||
- name: NEVER_CHANGES check idempotency on snmp community
|
- name: NEVER_CHANGES check idempotency on snmp community
|
||||||
mt_snmp:
|
mt_snmp:
|
||||||
|
@ -1658,7 +1666,11 @@
|
||||||
addresses: "10.0.0.0/8"
|
addresses: "10.0.0.0/8"
|
||||||
name: icghol
|
name: icghol
|
||||||
register: snmp_community_idem
|
register: snmp_community_idem
|
||||||
failed_when: ( snmp_community_idem | changed )
|
failed_when: (
|
||||||
|
not ansible_check_mode
|
||||||
|
) and (
|
||||||
|
( snmp_community_idem | changed )
|
||||||
|
)
|
||||||
|
|
||||||
- name: edit snmp settings
|
- name: edit snmp settings
|
||||||
mt_snmp:
|
mt_snmp:
|
||||||
|
@ -1682,7 +1694,11 @@
|
||||||
trap-community: icghol
|
trap-community: icghol
|
||||||
trap-version: 2
|
trap-version: 2
|
||||||
register: snmp_idem
|
register: snmp_idem
|
||||||
failed_when: ( snmp_community_idem | changed )
|
failed_when: (
|
||||||
|
not ansible_check_mode
|
||||||
|
) and (
|
||||||
|
( snmp_idem | changed )
|
||||||
|
)
|
||||||
|
|
||||||
- name: ALWAYS_CHANGES check editing snmp
|
- name: ALWAYS_CHANGES check editing snmp
|
||||||
mt_snmp:
|
mt_snmp:
|
||||||
|
@ -1695,7 +1711,11 @@
|
||||||
trap-community: icghol
|
trap-community: icghol
|
||||||
trap-version: 3
|
trap-version: 3
|
||||||
register: snmp_edit
|
register: snmp_edit
|
||||||
failed_when: not ( snmp_edit | changed )
|
failed_when: (
|
||||||
|
not ansible_check_mode
|
||||||
|
) and (
|
||||||
|
not ( snmp_edit | changed )
|
||||||
|
)
|
||||||
|
|
||||||
tags: snmp
|
tags: snmp
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue