selogin: check_mode, ignore_selinux_state, tests
ignore_selinux_state based on #48945
This commit is contained in:
parent
f9e09f0e7f
commit
5d32dbd532
3 changed files with 110 additions and 5 deletions
|
@ -54,6 +54,11 @@ options:
|
||||||
description:
|
description:
|
||||||
- Reload SELinux policy after commit.
|
- Reload SELinux policy after commit.
|
||||||
default: yes
|
default: yes
|
||||||
|
ignore_selinux_state:
|
||||||
|
description:
|
||||||
|
- Run independent of selinux runtime state
|
||||||
|
type: bool
|
||||||
|
default: false
|
||||||
notes:
|
notes:
|
||||||
- The changes are persistent across reboots
|
- The changes are persistent across reboots
|
||||||
- Not tested on any debian based system
|
- Not tested on any debian based system
|
||||||
|
@ -61,6 +66,7 @@ requirements: [ 'libselinux', 'policycoreutils' ]
|
||||||
author:
|
author:
|
||||||
- Dan Keder (@dankeder)
|
- Dan Keder (@dankeder)
|
||||||
- Petr Lautrbach (@bachradsusi)
|
- Petr Lautrbach (@bachradsusi)
|
||||||
|
- James Cassell (@jamescassell)
|
||||||
'''
|
'''
|
||||||
|
|
||||||
EXAMPLES = '''
|
EXAMPLES = '''
|
||||||
|
@ -144,9 +150,13 @@ def semanage_login_add(module, login, seuser, do_reload, serange='s0', sestore='
|
||||||
# module.fail_json(msg="%s: %s %s" % (all_logins, login, sestore))
|
# module.fail_json(msg="%s: %s %s" % (all_logins, login, sestore))
|
||||||
# for local_login in all_logins:
|
# for local_login in all_logins:
|
||||||
if login not in all_logins.keys():
|
if login not in all_logins.keys():
|
||||||
selogin.add(login, seuser, serange)
|
|
||||||
change = True
|
change = True
|
||||||
|
if not module.check_mode:
|
||||||
|
selogin.add(login, seuser, serange)
|
||||||
else:
|
else:
|
||||||
|
if all_logins[login][0] != seuser or all_logins[login][1] != serange:
|
||||||
|
change = True
|
||||||
|
if not module.check_mode:
|
||||||
selogin.modify(login, seuser, serange)
|
selogin.modify(login, seuser, serange)
|
||||||
|
|
||||||
except (ValueError, KeyError, OSError, RuntimeError) as e:
|
except (ValueError, KeyError, OSError, RuntimeError) as e:
|
||||||
|
@ -183,8 +193,9 @@ def semanage_login_del(module, login, seuser, do_reload, sestore=''):
|
||||||
all_logins = selogin.get_all()
|
all_logins = selogin.get_all()
|
||||||
# module.fail_json(msg="%s: %s %s" % (all_logins, login, sestore))
|
# module.fail_json(msg="%s: %s %s" % (all_logins, login, sestore))
|
||||||
if login in all_logins.keys():
|
if login in all_logins.keys():
|
||||||
selogin.delete(login)
|
|
||||||
change = True
|
change = True
|
||||||
|
if not module.check_mode:
|
||||||
|
selogin.delete(login)
|
||||||
|
|
||||||
except (ValueError, KeyError, OSError, RuntimeError) as e:
|
except (ValueError, KeyError, OSError, RuntimeError) as e:
|
||||||
module.fail_json(msg="%s: %s\n" % (e.__class__.__name__, to_native(e)), exception=traceback.format_exc())
|
module.fail_json(msg="%s: %s\n" % (e.__class__.__name__, to_native(e)), exception=traceback.format_exc())
|
||||||
|
@ -192,9 +203,14 @@ def semanage_login_del(module, login, seuser, do_reload, sestore=''):
|
||||||
return change
|
return change
|
||||||
|
|
||||||
|
|
||||||
|
def get_runtime_status(ignore_selinux_state=False):
|
||||||
|
return True if ignore_selinux_state is True else selinux.is_selinux_enabled()
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=dict(
|
argument_spec=dict(
|
||||||
|
ignore_selinux_state=dict(type='bool', default=False),
|
||||||
login=dict(type='str', required=True),
|
login=dict(type='str', required=True),
|
||||||
seuser=dict(type='str'),
|
seuser=dict(type='str'),
|
||||||
selevel=dict(type='str', aliases=['serange'], default='s0'),
|
selevel=dict(type='str', aliases=['serange'], default='s0'),
|
||||||
|
@ -204,7 +220,7 @@ def main():
|
||||||
required_if=[
|
required_if=[
|
||||||
["state", "present", ["seuser"]]
|
["state", "present", ["seuser"]]
|
||||||
],
|
],
|
||||||
supports_check_mode=False
|
supports_check_mode=True
|
||||||
)
|
)
|
||||||
if not HAVE_SELINUX:
|
if not HAVE_SELINUX:
|
||||||
module.fail_json(msg=missing_required_lib("libselinux"), exception=SELINUX_IMP_ERR)
|
module.fail_json(msg=missing_required_lib("libselinux"), exception=SELINUX_IMP_ERR)
|
||||||
|
@ -212,7 +228,9 @@ def main():
|
||||||
if not HAVE_SEOBJECT:
|
if not HAVE_SEOBJECT:
|
||||||
module.fail_json(msg=missing_required_lib("seobject from policycoreutils"), exception=SEOBJECT_IMP_ERR)
|
module.fail_json(msg=missing_required_lib("seobject from policycoreutils"), exception=SEOBJECT_IMP_ERR)
|
||||||
|
|
||||||
if not selinux.is_selinux_enabled():
|
ignore_selinux_state = module.params['ignore_selinux_state']
|
||||||
|
|
||||||
|
if not get_runtime_status(ignore_selinux_state):
|
||||||
module.fail_json(msg="SELinux is disabled on this host.")
|
module.fail_json(msg="SELinux is disabled on this host.")
|
||||||
|
|
||||||
login = module.params['login']
|
login = module.params['login']
|
||||||
|
|
|
@ -28,3 +28,9 @@
|
||||||
- ansible_selinux is defined
|
- ansible_selinux is defined
|
||||||
- ansible_selinux != False
|
- ansible_selinux != False
|
||||||
- ansible_selinux.status == 'enabled'
|
- ansible_selinux.status == 'enabled'
|
||||||
|
|
||||||
|
- include: selogin.yml
|
||||||
|
when:
|
||||||
|
- ansible_selinux is defined
|
||||||
|
- ansible_selinux != False
|
||||||
|
- ansible_selinux.status == 'enabled'
|
||||||
|
|
81
test/integration/targets/selinux/tasks/selogin.yml
Normal file
81
test/integration/targets/selinux/tasks/selogin.yml
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
- name: create user for testing
|
||||||
|
user:
|
||||||
|
name: seuser
|
||||||
|
|
||||||
|
- name: attempt to add mapping without 'seuser'
|
||||||
|
selogin:
|
||||||
|
login: seuser
|
||||||
|
register: selogin_error
|
||||||
|
ignore_errors: yes
|
||||||
|
|
||||||
|
- name: verify failure
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- selogin_error is failed
|
||||||
|
|
||||||
|
- name: map login to SELinux user
|
||||||
|
selogin:
|
||||||
|
login: seuser
|
||||||
|
seuser: staff_u
|
||||||
|
register: selogin_new_mapping
|
||||||
|
check_mode: "{{ item }}"
|
||||||
|
with_items:
|
||||||
|
- yes
|
||||||
|
- no
|
||||||
|
- yes
|
||||||
|
- no
|
||||||
|
|
||||||
|
- name: new mapping- verify functionality and check_mode
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- selogin_new_mapping.results[0] is changed
|
||||||
|
- selogin_new_mapping.results[1] is changed
|
||||||
|
- selogin_new_mapping.results[2] is not changed
|
||||||
|
- selogin_new_mapping.results[3] is not changed
|
||||||
|
|
||||||
|
- name: change SELinux user login mapping
|
||||||
|
selogin:
|
||||||
|
login: seuser
|
||||||
|
seuser: user_u
|
||||||
|
register: selogin_mod_mapping
|
||||||
|
check_mode: "{{ item }}"
|
||||||
|
with_items:
|
||||||
|
- yes
|
||||||
|
- no
|
||||||
|
- yes
|
||||||
|
- no
|
||||||
|
|
||||||
|
- name: changed mapping- verify functionality and check_mode
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- selogin_mod_mapping.results[0] is changed
|
||||||
|
- selogin_mod_mapping.results[1] is changed
|
||||||
|
- selogin_mod_mapping.results[2] is not changed
|
||||||
|
- selogin_mod_mapping.results[3] is not changed
|
||||||
|
|
||||||
|
- name: remove SELinux user mapping
|
||||||
|
selogin:
|
||||||
|
login: seuser
|
||||||
|
state: absent
|
||||||
|
register: selogin_del_mapping
|
||||||
|
check_mode: "{{ item }}"
|
||||||
|
with_items:
|
||||||
|
- yes
|
||||||
|
- no
|
||||||
|
- yes
|
||||||
|
- no
|
||||||
|
|
||||||
|
- name: delete mapping- verify functionality and check_mode
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- selogin_del_mapping.results[0] is changed
|
||||||
|
- selogin_del_mapping.results[1] is changed
|
||||||
|
- selogin_del_mapping.results[2] is not changed
|
||||||
|
- selogin_del_mapping.results[3] is not changed
|
||||||
|
|
||||||
|
- name: remove test user
|
||||||
|
user:
|
||||||
|
name: seuser
|
||||||
|
state: absent
|
Loading…
Reference in a new issue