Merge pull request #669 from 4nd3r/__acl
add __acl: Basic wrapper around setfacl
This commit is contained in:
		
				commit
				
					
						75b68cd178
					
				
			
		
					 5 changed files with 171 additions and 0 deletions
				
			
		
							
								
								
									
										23
									
								
								cdist/conf/type/__acl/explorer/acl_is
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										23
									
								
								cdist/conf/type/__acl/explorer/acl_is
									
										
									
									
									
										Executable file
									
								
							| 
						 | 
					@ -0,0 +1,23 @@
 | 
				
			||||||
 | 
					#!/bin/sh -e
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 2018 Ander Punnar (ander-at-kvlt-dot-ee)
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# This file is part of cdist.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# cdist is free software: you can redistribute it and/or modify
 | 
				
			||||||
 | 
					# it under the terms of the GNU General Public License as published by
 | 
				
			||||||
 | 
					# the Free Software Foundation, either version 3 of the License, or
 | 
				
			||||||
 | 
					# (at your option) any later version.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# cdist is distributed in the hope that it will be useful,
 | 
				
			||||||
 | 
					# but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
				
			||||||
 | 
					# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
				
			||||||
 | 
					# GNU General Public License for more details.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# You should have received a copy of the GNU General Public License
 | 
				
			||||||
 | 
					# along with cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if [ -e "/$__object_id" ]
 | 
				
			||||||
 | 
					then getfacl "/$__object_id" | grep -E '^((default:|)(user|group)):[a-z]' || true
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
							
								
								
									
										81
									
								
								cdist/conf/type/__acl/gencode-remote
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										81
									
								
								cdist/conf/type/__acl/gencode-remote
									
										
									
									
									
										Executable file
									
								
							| 
						 | 
					@ -0,0 +1,81 @@
 | 
				
			||||||
 | 
					#!/bin/sh -e
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 2018 Ander Punnar (ander-at-kvlt-dot-ee)
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# This file is part of cdist.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# cdist is free software: you can redistribute it and/or modify
 | 
				
			||||||
 | 
					# it under the terms of the GNU General Public License as published by
 | 
				
			||||||
 | 
					# the Free Software Foundation, either version 3 of the License, or
 | 
				
			||||||
 | 
					# (at your option) any later version.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# cdist is distributed in the hope that it will be useful,
 | 
				
			||||||
 | 
					# but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
				
			||||||
 | 
					# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
				
			||||||
 | 
					# GNU General Public License for more details.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# You should have received a copy of the GNU General Public License
 | 
				
			||||||
 | 
					# along with cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					os="$( cat "$__global/explorer/os" )"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					acl_path="/$__object_id"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					acl_is="$( cat "$__object/explorer/acl_is" )"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					acl_should="$( for parameter in user group
 | 
				
			||||||
 | 
					do
 | 
				
			||||||
 | 
					    if [ ! -f "$__object/parameter/$parameter" ]
 | 
				
			||||||
 | 
					    then continue
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					    while read -r l
 | 
				
			||||||
 | 
					    do
 | 
				
			||||||
 | 
					        echo "$parameter:$l"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if [ -f "$__object/parameter/default" ]
 | 
				
			||||||
 | 
					        then echo "default:$parameter:$l"
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
 | 
					    done < "$__object/parameter/$parameter"
 | 
				
			||||||
 | 
					done )"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					setfacl_exec='setfacl'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if [ -f "$__object/parameter/recursive" ]
 | 
				
			||||||
 | 
					then
 | 
				
			||||||
 | 
					    if echo "$os" | grep -E 'macosx|netbsd|freebsd|openbsd'
 | 
				
			||||||
 | 
					    then
 | 
				
			||||||
 | 
					        echo "$os setfacl do not support recursive operations" >&2
 | 
				
			||||||
 | 
					    else
 | 
				
			||||||
 | 
					        setfacl_exec="$setfacl_exec -R"
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if [ -f "$__object/parameter/remove" ]
 | 
				
			||||||
 | 
					then
 | 
				
			||||||
 | 
					    if echo "$os" | grep 'solaris'
 | 
				
			||||||
 | 
					    then
 | 
				
			||||||
 | 
					        # Solaris setfacl behaves differently.
 | 
				
			||||||
 | 
					        # We will not support Solaris for now, because no way to test it.
 | 
				
			||||||
 | 
					        # But adding support should be easy (use -s instead of -m on modify).
 | 
				
			||||||
 | 
					        echo "$os setfacl do not support -x flag for ACL remove" >&2
 | 
				
			||||||
 | 
					    else
 | 
				
			||||||
 | 
					        echo "$acl_is" | while read -r acl
 | 
				
			||||||
 | 
					        do
 | 
				
			||||||
 | 
					            if echo "$acl_should" | grep -Fq "$acl"
 | 
				
			||||||
 | 
					            then continue
 | 
				
			||||||
 | 
					            fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            no_bits="$( echo "$acl" | sed -r 's/:[rwx-]+$//' )"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            echo "$setfacl_exec -x \"$no_bits\" \"$acl_path\""
 | 
				
			||||||
 | 
					        done
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					for acl in $acl_should
 | 
				
			||||||
 | 
					do
 | 
				
			||||||
 | 
					    if ! echo "$acl_is" | grep -Eq "^$acl"
 | 
				
			||||||
 | 
					    then echo "$setfacl_exec -m \"$acl\" \"$acl_path\""
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
 | 
					done
 | 
				
			||||||
							
								
								
									
										62
									
								
								cdist/conf/type/__acl/man.rst
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								cdist/conf/type/__acl/man.rst
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,62 @@
 | 
				
			||||||
 | 
					cdist-type__acl(7)
 | 
				
			||||||
 | 
					==================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					NAME
 | 
				
			||||||
 | 
					----
 | 
				
			||||||
 | 
					cdist-type__acl - Basic wrapper around `setfacl`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					DESCRIPTION
 | 
				
			||||||
 | 
					-----------
 | 
				
			||||||
 | 
					ACL must be defined as 3-symbol combination, using `r`, `w`, `x` and `-`.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					See setfacl(1) and acl(5) for more details.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OPTIONAL MULTIPLE PARAMETERS
 | 
				
			||||||
 | 
					----------------------------
 | 
				
			||||||
 | 
					user
 | 
				
			||||||
 | 
					   Add user ACL entry.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					group
 | 
				
			||||||
 | 
					   Add group ACL entry.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					BOOLEAN PARAMETERS
 | 
				
			||||||
 | 
					------------------
 | 
				
			||||||
 | 
					recursive
 | 
				
			||||||
 | 
					   Operate recursively (Linux only).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					default
 | 
				
			||||||
 | 
					   Add default ACL entries.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					remove
 | 
				
			||||||
 | 
					   Remove undefined ACL entries (Solaris not supported).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					EXAMPLES
 | 
				
			||||||
 | 
					--------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.. code-block:: sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    __acl /srv/project \
 | 
				
			||||||
 | 
					        --recursive \
 | 
				
			||||||
 | 
					        --default \
 | 
				
			||||||
 | 
					        --remove \
 | 
				
			||||||
 | 
					        --user alice:rwx \
 | 
				
			||||||
 | 
					        --user bob:r-x \
 | 
				
			||||||
 | 
					        --group project-group:rwx \
 | 
				
			||||||
 | 
					        --group some-other-group:r-x
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					AUTHORS
 | 
				
			||||||
 | 
					-------
 | 
				
			||||||
 | 
					Ander Punnar <ander-at-kvlt-dot-ee>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					COPYING
 | 
				
			||||||
 | 
					-------
 | 
				
			||||||
 | 
					Copyright \(C) 2018 Ander Punnar. You can redistribute it
 | 
				
			||||||
 | 
					and/or modify it under the terms of the GNU General Public License as
 | 
				
			||||||
 | 
					published by the Free Software Foundation, either version 3 of the
 | 
				
			||||||
 | 
					License, or (at your option) any later version.
 | 
				
			||||||
							
								
								
									
										3
									
								
								cdist/conf/type/__acl/parameter/boolean
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								cdist/conf/type/__acl/parameter/boolean
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,3 @@
 | 
				
			||||||
 | 
					recursive
 | 
				
			||||||
 | 
					default
 | 
				
			||||||
 | 
					remove
 | 
				
			||||||
							
								
								
									
										2
									
								
								cdist/conf/type/__acl/parameter/optional_multiple
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								cdist/conf/type/__acl/parameter/optional_multiple
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,2 @@
 | 
				
			||||||
 | 
					user
 | 
				
			||||||
 | 
					group
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue