mirror of
https://github.com/ansible-collections/ansible.posix.git
synced 2026-01-11 23:25:28 +01:00
Compare commits
4 commits
1480acdfe0
...
e1f0130be2
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e1f0130be2 | ||
|
|
cdb442ea48 | ||
|
|
f977bffff2 | ||
|
|
3c881c61fa |
4 changed files with 36 additions and 6 deletions
|
|
@ -195,6 +195,8 @@ stages:
|
||||||
parameters:
|
parameters:
|
||||||
testFormat: devel/{0}/1
|
testFormat: devel/{0}/1
|
||||||
targets:
|
targets:
|
||||||
|
- name: RHEL 10.0
|
||||||
|
test: rhel/10.0
|
||||||
- name: RHEL 9.5
|
- name: RHEL 9.5
|
||||||
test: rhel/9.5
|
test: rhel/9.5
|
||||||
- name: FreeBSD 14.2
|
- name: FreeBSD 14.2
|
||||||
|
|
|
||||||
2
changelogs/fragments/642_ci_add_rhel10.yml
Normal file
2
changelogs/fragments/642_ci_add_rhel10.yml
Normal file
|
|
@ -0,0 +1,2 @@
|
||||||
|
trivial:
|
||||||
|
- Add Red Hat Enterprise Linux 10.0 to the CI matrix (https://github.com/ansible-collections/ansible.posix/issues/642).
|
||||||
|
|
@ -211,8 +211,11 @@ def build_command(module, mode, path, follow, default, recursive, recalculate_ma
|
||||||
cmd.append('--absolute-names')
|
cmd.append('--absolute-names')
|
||||||
cmd.append('--omit-header')
|
cmd.append('--omit-header')
|
||||||
|
|
||||||
if recursive and not use_nfsv4_acls:
|
if recursive:
|
||||||
cmd.append('--recursive')
|
if use_nfsv4_acls:
|
||||||
|
cmd.append('-R') # Add recursive flag for NFSv4 ACLs
|
||||||
|
else:
|
||||||
|
cmd.append('--recursive')
|
||||||
|
|
||||||
if recalculate_mask == 'mask' and mode in ['set', 'rm']:
|
if recalculate_mask == 'mask' and mode in ['set', 'rm']:
|
||||||
cmd.append('--mask')
|
cmd.append('--mask')
|
||||||
|
|
@ -226,13 +229,18 @@ def build_command(module, mode, path, follow, default, recursive, recalculate_ma
|
||||||
cmd.append('-h')
|
cmd.append('-h')
|
||||||
|
|
||||||
if default:
|
if default:
|
||||||
cmd.insert(1, '-d')
|
if not use_nfsv4_acls:
|
||||||
|
cmd.insert(1, '-d')
|
||||||
|
elif mode == 'set':
|
||||||
|
# For NFSv4 ACLs, handle default ACLs through the entry format or other means
|
||||||
|
# This is a placeholder for NFSv4 default ACL handling
|
||||||
|
pass
|
||||||
|
|
||||||
cmd.append(path)
|
cmd.append(path)
|
||||||
return cmd
|
return cmd
|
||||||
|
|
||||||
|
|
||||||
def acl_changed(module, cmd, entry, use_nfsv4_acls=False):
|
def acl_changed(module, cmd, entry, recursive=False, use_nfsv4_acls=False):
|
||||||
'''Returns true if the provided command affects the existing ACLs, false otherwise.'''
|
'''Returns true if the provided command affects the existing ACLs, false otherwise.'''
|
||||||
# To check the ACL changes, use the output of setfacl or nfs4_setfacl with '--test'.
|
# To check the ACL changes, use the output of setfacl or nfs4_setfacl with '--test'.
|
||||||
# FreeBSD do not have a --test flag, so by default, it is safer to always say "true".
|
# FreeBSD do not have a --test flag, so by default, it is safer to always say "true".
|
||||||
|
|
@ -247,6 +255,18 @@ def acl_changed(module, cmd, entry, use_nfsv4_acls=False):
|
||||||
if line.endswith('*,*') and not use_nfsv4_acls:
|
if line.endswith('*,*') and not use_nfsv4_acls:
|
||||||
return False
|
return False
|
||||||
# if use_nfsv4_acls and entry is listed
|
# if use_nfsv4_acls and entry is listed
|
||||||
|
if use_nfsv4_acls:
|
||||||
|
# For NFSv4 ACLs, ensure the entry is checked against the actual ACLs
|
||||||
|
for line in lines:
|
||||||
|
if recursive:
|
||||||
|
# In recursive mode, ensure all entries match
|
||||||
|
if entry not in line:
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
if entry in line:
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
|
||||||
if use_nfsv4_acls and entry == line:
|
if use_nfsv4_acls and entry == line:
|
||||||
counter += 1
|
counter += 1
|
||||||
|
|
||||||
|
|
@ -371,7 +391,7 @@ def main():
|
||||||
module, 'set', path, follow,
|
module, 'set', path, follow,
|
||||||
default, recursive, recalculate_mask, use_nfsv4_acls, entry
|
default, recursive, recalculate_mask, use_nfsv4_acls, entry
|
||||||
)
|
)
|
||||||
changed = acl_changed(module, command, entry, use_nfsv4_acls)
|
changed = acl_changed(module, command, entry, recursive, use_nfsv4_acls)
|
||||||
|
|
||||||
if changed and not module.check_mode:
|
if changed and not module.check_mode:
|
||||||
run_acl(module, command)
|
run_acl(module, command)
|
||||||
|
|
@ -386,7 +406,7 @@ def main():
|
||||||
module, 'rm', path, follow,
|
module, 'rm', path, follow,
|
||||||
default, recursive, recalculate_mask, use_nfsv4_acls, entry
|
default, recursive, recalculate_mask, use_nfsv4_acls, entry
|
||||||
)
|
)
|
||||||
changed = acl_changed(module, command, entry, use_nfsv4_acls)
|
changed = acl_changed(module, command, entry, recursive, use_nfsv4_acls)
|
||||||
|
|
||||||
if changed and not module.check_mode:
|
if changed and not module.check_mode:
|
||||||
run_acl(module, command, False)
|
run_acl(module, command, False)
|
||||||
|
|
|
||||||
|
|
@ -46,6 +46,12 @@
|
||||||
path: "{{ test_dir }}"
|
path: "{{ test_dir }}"
|
||||||
state: directory
|
state: directory
|
||||||
mode: "0755"
|
mode: "0755"
|
||||||
|
|
||||||
|
- name: Install acl package
|
||||||
|
ansible.builtin.package:
|
||||||
|
name: acl
|
||||||
|
state: present
|
||||||
|
|
||||||
##############################################################################
|
##############################################################################
|
||||||
- name: Grant ansible user read access to a file
|
- name: Grant ansible user read access to a file
|
||||||
ansible.posix.acl:
|
ansible.posix.acl:
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue