[type/__package_opkg] Also lock execution of code-remote
This commit is contained in:
		
					parent
					
						
							
								97e48be39e
							
						
					
				
			
			
				commit
				
					
						e79b26a61f
					
				
			
		
					 2 changed files with 73 additions and 32 deletions
				
			
		| 
						 | 
				
			
			@ -23,7 +23,9 @@
 | 
			
		|||
# Retrieve the status of a package - parses opkg output
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
LOCKFILE="${__type_explorer}/cdist_opkg.lock"
 | 
			
		||||
__type_path=${__object%%${__object_id}*}
 | 
			
		||||
 | 
			
		||||
LOCKFILE="${__type_path}/cdist_opkg.lock"
 | 
			
		||||
_lock() (
 | 
			
		||||
	set -o noclobber
 | 
			
		||||
	until echo $$>"${LOCKFILE}"
 | 
			
		||||
| 
						 | 
				
			
			@ -48,9 +50,10 @@ else
 | 
			
		|||
fi
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# NOTE: We need to lock parallel execution of this explorer because opkg will
 | 
			
		||||
# try to acquire the OPKG lock (usually /var/lock/opkg.lock) using lockf(2) for
 | 
			
		||||
# every operation. It will not wait for the lock but terminate with an error.
 | 
			
		||||
# NOTE: We need to lock parallel execution of type explorers and code-remote
 | 
			
		||||
# because opkg will try to acquire the OPKG lock (usually /var/lock/opkg.lock)
 | 
			
		||||
# using lockf(2) for every operation.
 | 
			
		||||
# It will not wait for the lock but terminate with an error.
 | 
			
		||||
# This leads to incorrect 'absent notpresent' statuses when parallel execution
 | 
			
		||||
# is enabled.
 | 
			
		||||
trap _unlock EXIT
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2,6 +2,7 @@
 | 
			
		|||
#
 | 
			
		||||
# 2011,2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
			
		||||
# 2012 Giel van Schijndel (giel plus cdist at mortis dot eu)
 | 
			
		||||
# 2020 Dennis Camera (dennis.camera at ssrq-sds-fds.ch)
 | 
			
		||||
#
 | 
			
		||||
# This file is part of cdist.
 | 
			
		||||
#
 | 
			
		||||
| 
						 | 
				
			
			@ -19,41 +20,78 @@
 | 
			
		|||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
#
 | 
			
		||||
#
 | 
			
		||||
# Manage packages on OpenWRT and co.
 | 
			
		||||
# Manage packages on OpenWrt, optware, and co.
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
if [ -f "$__object/parameter/name" ]; then
 | 
			
		||||
   name="$(cat "$__object/parameter/name")"
 | 
			
		||||
if test -f "${__object}/parameter/name"
 | 
			
		||||
then
 | 
			
		||||
   name=$(cat "${__object}/parameter/name")
 | 
			
		||||
else
 | 
			
		||||
   name="$__object_id"
 | 
			
		||||
   name=$__object_id
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
state_should="$(cat "$__object/parameter/state")"
 | 
			
		||||
state_should=$(cat "${__object}/parameter/state")
 | 
			
		||||
state_is=$(cat "${__object}/explorer/pkg_status")
 | 
			
		||||
 | 
			
		||||
state_is="$(cat "$__object/explorer/pkg_status")"
 | 
			
		||||
case "$state_is" in
 | 
			
		||||
    absent*)
 | 
			
		||||
       present="$(echo "$state_is" | cut -d ' ' -f 2)"
 | 
			
		||||
       state_is="absent"
 | 
			
		||||
case $state_is
 | 
			
		||||
in
 | 
			
		||||
	(absent*)
 | 
			
		||||
		presence=$(echo "${state_is}" | cut -d ' ' -f 2)
 | 
			
		||||
		state_is='absent'
 | 
			
		||||
		;;
 | 
			
		||||
esac
 | 
			
		||||
 | 
			
		||||
[ "$state_is" = "$state_should" ] && exit 0
 | 
			
		||||
 | 
			
		||||
case "$state_should" in
 | 
			
		||||
    present)
 | 
			
		||||
        if [ "$present" = "notpresent" ]; then
 | 
			
		||||
            echo "opkg --verbosity=0 update"
 | 
			
		||||
if test "${state_is}" = "${state_should}"
 | 
			
		||||
then
 | 
			
		||||
	exit 0
 | 
			
		||||
fi
 | 
			
		||||
        echo "opkg --verbosity=0 install '$name'"
 | 
			
		||||
        echo "installed" >> "$__messages_out"
 | 
			
		||||
 | 
			
		||||
cat <<'EOF'
 | 
			
		||||
__type_path=${__object%%${__object_id}*}
 | 
			
		||||
 | 
			
		||||
LOCKFILE="${__type_path}/cdist_opkg.lock"
 | 
			
		||||
_lock() (
 | 
			
		||||
	set -o noclobber
 | 
			
		||||
	until echo $$>"${LOCKFILE}"
 | 
			
		||||
	do
 | 
			
		||||
		while test -f "${LOCKFILE}"; do sleep 1; done
 | 
			
		||||
	done
 | 
			
		||||
 | 
			
		||||
) 2>/dev/null
 | 
			
		||||
_unlock() {
 | 
			
		||||
	if test -s "${LOCKFILE}" && test "$(cat "${LOCKFILE}")" = $$
 | 
			
		||||
	then
 | 
			
		||||
		rm "${LOCKFILE}"
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
EOF
 | 
			
		||||
 | 
			
		||||
# NOTE: We need to lock parallel execution of code-remote to ensure that it is
 | 
			
		||||
# not executed concurrently with a type explorer.
 | 
			
		||||
# opkg will try to acquire the OPKG lock (usually /var/lock/opkg.lock) using
 | 
			
		||||
# lockf(2) for every operation.
 | 
			
		||||
# It will not wait for the lock but terminate with an error leading to an
 | 
			
		||||
# incorrect outcome.
 | 
			
		||||
echo 'trap _unlock EXIT'
 | 
			
		||||
echo '_lock'
 | 
			
		||||
 | 
			
		||||
case $state_should
 | 
			
		||||
in
 | 
			
		||||
	(present)
 | 
			
		||||
		if test "${presence}" = 'notpresent'
 | 
			
		||||
		then
 | 
			
		||||
			echo 'opkg --verbosity=0 update'
 | 
			
		||||
		fi
 | 
			
		||||
 | 
			
		||||
		printf "opkg --verbosity=0 install '%s'\n" "${name}"
 | 
			
		||||
		echo 'installed' >>"${__messages_out}"
 | 
			
		||||
		;;
 | 
			
		||||
    absent)
 | 
			
		||||
        echo "opkg --verbosity=0 remove '$name'"
 | 
			
		||||
        echo "removed" >> "$__messages_out"
 | 
			
		||||
	(absent)
 | 
			
		||||
		printf "opkg --verbosity=0 remove '%s'" "${name}"
 | 
			
		||||
		echo 'removed' >>"${__messages_out}"
 | 
			
		||||
		;;
 | 
			
		||||
    *)
 | 
			
		||||
        echo "Unknown state: ${state_should}" >&2
 | 
			
		||||
	(*)
 | 
			
		||||
		printf 'Unknown state: %s\n' "${state_should}" >&2
 | 
			
		||||
		exit 1
 | 
			
		||||
		;;
 | 
			
		||||
esac
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue