Sync with master. Add changelog.
This commit is contained in:
		
				commit
				
					
						5fbc7f7d88
					
				
			
		
					 27 changed files with 238 additions and 131 deletions
				
			
		
							
								
								
									
										35
									
								
								cdist/conf/explorer/init
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										35
									
								
								cdist/conf/explorer/init
									
										
									
									
									
										Executable file
									
								
							| 
						 | 
					@ -0,0 +1,35 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 2016 Daniel Heule (hda at sfs.biz)
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 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/>.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# Returns the process name of pid 1 ( normaly the init system )
 | 
				
			||||||
 | 
					# for example at linux this value is "init" or "systemd" in most cases
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					uname_s="$(uname -s)"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					case "$uname_s" in
 | 
				
			||||||
 | 
					    Linux|FreeBSD)
 | 
				
			||||||
 | 
					        ps -o comm= -p 1 || true
 | 
				
			||||||
 | 
					    ;;
 | 
				
			||||||
 | 
					    *)
 | 
				
			||||||
 | 
					        # return a empty string as unknown value
 | 
				
			||||||
 | 
					        echo ""
 | 
				
			||||||
 | 
					    ;;
 | 
				
			||||||
 | 
					esac
 | 
				
			||||||
| 
						 | 
					@ -1,6 +1,6 @@
 | 
				
			||||||
#!/bin/sh
 | 
					#!/bin/sh
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2011-2014 Steven Armstrong (steven-cdist at armstrong.cc)
 | 
					# 2011-2016 Steven Armstrong (steven-cdist at armstrong.cc)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -21,9 +21,8 @@
 | 
				
			||||||
name="$__object_id"
 | 
					name="$__object_id"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
__package software-properties-common
 | 
					__package software-properties-common
 | 
				
			||||||
__package python-software-properties
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
require="__package/software-properties-common __package/python-software-properties" \
 | 
					require="__package/software-properties-common" \
 | 
				
			||||||
   __file /usr/local/bin/remove-apt-repository \
 | 
					   __file /usr/local/bin/remove-apt-repository \
 | 
				
			||||||
   --source "$__type/files/remove-apt-repository" \
 | 
					   --source "$__type/files/remove-apt-repository" \
 | 
				
			||||||
   --mode 0755
 | 
					   --mode 0755
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1 +1 @@
 | 
				
			||||||
https://releases.hashicorp.com/consul/0.4.1/consul_0.4.1_linux_amd64.zip
 | 
					https://dl.bintray.com/mitchellh/consul/0.4.1_linux_amd64.zip
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1 +1 @@
 | 
				
			||||||
https://releases.hashicorp.com/consul/0.5.0/consul_0.5.0_linux_amd64.zip
 | 
					https://dl.bintray.com/mitchellh/consul/0.5.0_linux_amd64.zip
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1 +1 @@
 | 
				
			||||||
https://releases.hashicorp.com/consul/0.5.1/consul_0.5.1_linux_amd64.zip
 | 
					https://dl.bintray.com/mitchellh/consul/0.5.1_linux_amd64.zip
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__consul/files/versions/0.6.4/cksum
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__consul/files/versions/0.6.4/cksum
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					3832641574 23002736 consul
 | 
				
			||||||
							
								
								
									
										1
									
								
								cdist/conf/type/__consul/files/versions/0.6.4/source
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cdist/conf/type/__consul/files/versions/0.6.4/source
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					https://releases.hashicorp.com/consul/0.6.4/consul_0.6.4_linux_amd64.zip
 | 
				
			||||||
| 
						 | 
					@ -1 +1 @@
 | 
				
			||||||
0.5.0
 | 
					0.6.4
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,4 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2015 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2015 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,4 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2015 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2015 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,5 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if grep -q "^__file/etc/iptables.d/" "$__messages_in"; then
 | 
					if grep -q "^__file/etc/iptables.d/" "$__messages_in"; then
 | 
				
			||||||
    echo /etc/init.d/iptables restart
 | 
					    echo /etc/init.d/iptables restart
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,4 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,4 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,5 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export key="$(cat "$__object/parameter/key" 2>/dev/null \
 | 
					export key="$(cat "$__object/parameter/key" 2>/dev/null \
 | 
				
			||||||
   || echo "$__object_id")"
 | 
					   || echo "$__object_id")"
 | 
				
			||||||
export state="$(cat "$__object/parameter/state")"
 | 
					export state="$(cat "$__object/parameter/state")"
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,5 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
# 2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -42,7 +42,7 @@ case "$ptype" in
 | 
				
			||||||
        zypper search --match-exact --installed-only --type "$ptype" "$name" | grep -E '^i' | cut -d " " -f 3 || true
 | 
					        zypper search --match-exact --installed-only --type "$ptype" "$name" | grep -E '^i' | cut -d " " -f 3 || true
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
    *)
 | 
					    *)
 | 
				
			||||||
        echo "unknown ptype in __package_zypper explorer" &>2
 | 
					        echo "unknown ptype in __package_zypper explorer" >&2
 | 
				
			||||||
        exit 1
 | 
					        exit 1
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
esac
 | 
					esac
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -42,11 +42,10 @@ contains_element() {
 | 
				
			||||||
    MATCH=0
 | 
					    MATCH=0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    target=$1
 | 
					    target=$1
 | 
				
			||||||
    keys="${@:2}"
 | 
					    shift
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for key in "$@"; do
 | 
				
			||||||
    for key in ${keys}; do
 | 
					        if [ "${key}" = "${target}" ]; then
 | 
				
			||||||
        if [ "${key}" == "${target}" ]; then
 | 
					 | 
				
			||||||
            MATCH=1
 | 
					            MATCH=1
 | 
				
			||||||
            return 0
 | 
					            return 0
 | 
				
			||||||
        fi  
 | 
					        fi  
 | 
				
			||||||
| 
						 | 
					@ -58,14 +57,14 @@ if [ "${file}" ]; then
 | 
				
			||||||
    __file "${sec_path}/plain_file_${file}"\
 | 
					    __file "${sec_path}/plain_file_${file}"\
 | 
				
			||||||
        --state exists --mode 666
 | 
					        --state exists --mode 666
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if [ "${state}" == "present" ]; then
 | 
					    if [ "${state}" = "present" ]; then
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        require="__file/${sec_path}/plain_file_${file}" __key_value ${file}_${key}\
 | 
					        require="__file/${sec_path}/plain_file_${file}" __key_value ${file}_${key}\
 | 
				
			||||||
            --file ${sec_path}/plain_file_${file} --key ${key} --value ${value} --delimiter ' = '
 | 
					            --file ${sec_path}/plain_file_${file} --key ${key} --value ${value} --delimiter ' = '
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        exit 0
 | 
					        exit 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    elif [ "${state}" == "absent" ]; then
 | 
					    elif [ "${state}" = "absent" ]; then
 | 
				
			||||||
        require="__file/${sec_path}/plain_file_${file}" __key_value ${file}_${key}\
 | 
					        require="__file/${sec_path}/plain_file_${file}" __key_value ${file}_${key}\
 | 
				
			||||||
                --state absent
 | 
					                --state absent
 | 
				
			||||||
        exit 0
 | 
					        exit 0
 | 
				
			||||||
| 
						 | 
					@ -76,7 +75,7 @@ if [ "${file}" ]; then
 | 
				
			||||||
    fi
 | 
					    fi
 | 
				
			||||||
fi  
 | 
					fi  
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ "${section}" == "options" ]; then
 | 
					if [ "${section}" = "options" ]; then
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    __file "${sec_path}/${section}"\
 | 
					    __file "${sec_path}/${section}"\
 | 
				
			||||||
            --state exists --mode 666 --source - << eof
 | 
					            --state exists --mode 666 --source - << eof
 | 
				
			||||||
| 
						 | 
					@ -87,10 +86,10 @@ eof
 | 
				
			||||||
    contains_element "${key}" "${boolean_option_keys}"
 | 
					    contains_element "${key}" "${boolean_option_keys}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if [ "${MATCH}" -eq 1 ]; then
 | 
					    if [ "${MATCH}" -eq 1 ]; then
 | 
				
			||||||
        if [ "${value}" == "on" ]; then
 | 
					        if [ "${value}" = "on" ]; then
 | 
				
			||||||
            require="__file/${sec_path}/${section}" __line ${key}_${value}\
 | 
					            require="__file/${sec_path}/${section}" __line ${key}_${value}\
 | 
				
			||||||
                --file ${sec_path}/${section} --line ${key}
 | 
					                --file ${sec_path}/${section} --line ${key}
 | 
				
			||||||
        elif [ "${value}" == "off" ]; then
 | 
					        elif [ "${value}" = "off" ]; then
 | 
				
			||||||
            require="__file/${sec_path}/${section}" __line ${key}_${value}\
 | 
					            require="__file/${sec_path}/${section}" __line ${key}_${value}\
 | 
				
			||||||
                --file ${sec_path}/${section} --line ${key} --state absent
 | 
					                --file ${sec_path}/${section} --line ${key} --state absent
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
| 
						 | 
					@ -111,7 +110,7 @@ else
 | 
				
			||||||
            --state exists --mode 666 --source - << eof
 | 
					            --state exists --mode 666 --source - << eof
 | 
				
			||||||
[${section}]
 | 
					[${section}]
 | 
				
			||||||
eof
 | 
					eof
 | 
				
			||||||
    if [ "${state}" == "present" ]; then
 | 
					    if [ "${state}" = "present" ]; then
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        #check if key is valid
 | 
					        #check if key is valid
 | 
				
			||||||
        contains_element "${key}" "${allowed_repo_keys}"
 | 
					        contains_element "${key}" "${allowed_repo_keys}"
 | 
				
			||||||
| 
						 | 
					@ -122,7 +121,7 @@ eof
 | 
				
			||||||
        require="__file/${sec_path}/repo_${section}" __key_value ${section}_${key}\
 | 
					        require="__file/${sec_path}/repo_${section}" __key_value ${section}_${key}\
 | 
				
			||||||
                --file ${sec_path}/repo_${section} --key ${key} --value ${value} --delimiter ' = '
 | 
					                --file ${sec_path}/repo_${section} --key ${key} --value ${value} --delimiter ' = '
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    elif [ "${state}" == "absent" ]; then
 | 
					    elif [ "${state}" = "absent" ]; then
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        require="__file/${sec_path}/repo_${section}" __key_value ${section}_${key}\
 | 
					        require="__file/${sec_path}/repo_${section}" __key_value ${section}_${key}\
 | 
				
			||||||
            --state absent
 | 
					            --state absent
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -22,7 +22,7 @@ state=$(cat $__object/parameter/state 2>/dev/null)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
path="/etc/"
 | 
					path="/etc/"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ "${state}" == "present" ]; then
 | 
					if [ "${state}" = "present" ]; then
 | 
				
			||||||
    __file /etc/pacman.conf\
 | 
					    __file /etc/pacman.conf\
 | 
				
			||||||
        --owner root --group root --mode 644 --source $__type/files/pacman.conf.cdist
 | 
					        --owner root --group root --mode 644 --source $__type/files/pacman.conf.cdist
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -35,7 +35,7 @@ if [ "${state}" == "present" ]; then
 | 
				
			||||||
    __file /etc/pacman.d/plain_file_empty_placeholder\
 | 
					    __file /etc/pacman.d/plain_file_empty_placeholder\
 | 
				
			||||||
        --owner root --group root --mode 644
 | 
					        --owner root --group root --mode 644
 | 
				
			||||||
 | 
					
 | 
				
			||||||
elif [ "${state}" == "absent" ]; then
 | 
					elif [ "${state}" = "absent" ]; then
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    __file /etc/pacman.conf\
 | 
					    __file /etc/pacman.conf\
 | 
				
			||||||
        --owner root --group root --mode 644 --source $__type/files/pacman.conf.pacman
 | 
					        --owner root --group root --mode 644 --source $__type/files/pacman.conf.pacman
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,5 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
################################################################################
 | 
					################################################################################
 | 
				
			||||||
# State: absent is handled by manifest - we need only to do stuff if image is
 | 
					# State: absent is handled by manifest - we need only to do stuff if image is
 | 
				
			||||||
# not existing and state != absent
 | 
					# not existing and state != absent
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,5 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
################################################################################
 | 
					################################################################################
 | 
				
			||||||
# Default settings
 | 
					# Default settings
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										10
									
								
								cdist/conf/type/__start_on_boot/explorer/state
									
										
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										10
									
								
								cdist/conf/type/__start_on_boot/explorer/state
									
										
									
									
									
										
										
										Executable file → Normal file
									
								
							| 
						 | 
					@ -24,16 +24,19 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
os=$("$__explorer/os")
 | 
					os=$("$__explorer/os")
 | 
				
			||||||
runlevel=$("$__explorer/runlevel")
 | 
					runlevel=$("$__explorer/runlevel")
 | 
				
			||||||
 | 
					init=$("$__explorer/init")
 | 
				
			||||||
target_runlevel="$(cat "$__object/parameter/target_runlevel")"
 | 
					target_runlevel="$(cat "$__object/parameter/target_runlevel")"
 | 
				
			||||||
name="$__object_id"
 | 
					name="$__object_id"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
case "$os" in
 | 
					if [ "$init" = 'systemd' ]; then
 | 
				
			||||||
    archlinux)
 | 
					    # this handles ALL linux distros with systemd
 | 
				
			||||||
 | 
					    # e.g. archlinux, gentoo, new RHEL and SLES versions
 | 
				
			||||||
    state=$(systemctl is-enabled "$name" >/dev/null 2>&1 \
 | 
					    state=$(systemctl is-enabled "$name" >/dev/null 2>&1 \
 | 
				
			||||||
        && echo present \
 | 
					        && echo present \
 | 
				
			||||||
        || echo absent)
 | 
					        || echo absent)
 | 
				
			||||||
    ;;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					    case "$os" in
 | 
				
			||||||
        debian|openwrt)
 | 
					        debian|openwrt)
 | 
				
			||||||
            state="present"
 | 
					            state="present"
 | 
				
			||||||
            [ -f "/etc/rc$runlevel.d/S"??"$name" ] || state="absent"
 | 
					            [ -f "/etc/rc$runlevel.d/S"??"$name" ] || state="absent"
 | 
				
			||||||
| 
						 | 
					@ -66,5 +69,6 @@ case "$os" in
 | 
				
			||||||
           exit 1
 | 
					           exit 1
 | 
				
			||||||
        ;;
 | 
					        ;;
 | 
				
			||||||
    esac
 | 
					    esac
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
echo $state
 | 
					echo $state
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										25
									
								
								cdist/conf/type/__start_on_boot/gencode-remote
									
										
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										25
									
								
								cdist/conf/type/__start_on_boot/gencode-remote
									
										
									
									
									
										
										
										Executable file → Normal file
									
								
							| 
						 | 
					@ -1,7 +1,7 @@
 | 
				
			||||||
#!/bin/sh
 | 
					#!/bin/sh
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2012-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2012-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
# 2013 Daniel Heule (hda at sfs.biz)
 | 
					# 2016 Daniel Heule (hda at sfs.biz)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -22,6 +22,7 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
state_should="$(cat "$__object/parameter/state")"
 | 
					state_should="$(cat "$__object/parameter/state")"
 | 
				
			||||||
state_is=$(cat "$__object/explorer/state")
 | 
					state_is=$(cat "$__object/explorer/state")
 | 
				
			||||||
 | 
					init=$(cat "$__global/explorer/init")
 | 
				
			||||||
target_runlevel="$(cat "$__object/parameter/target_runlevel")"
 | 
					target_runlevel="$(cat "$__object/parameter/target_runlevel")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Short circuit if nothing is to be done
 | 
					# Short circuit if nothing is to be done
 | 
				
			||||||
| 
						 | 
					@ -33,10 +34,12 @@ name="$__object_id"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
case "$state_should" in
 | 
					case "$state_should" in
 | 
				
			||||||
    present)
 | 
					    present)
 | 
				
			||||||
 | 
					        if [ "$init" = 'systemd' ]; then
 | 
				
			||||||
 | 
					            # this handles ALL linux distros with systemd
 | 
				
			||||||
 | 
					            # e.g. archlinux, gentoo in some cases, new RHEL and SLES versions
 | 
				
			||||||
 | 
					            echo "systemctl -q enable \"$name\""
 | 
				
			||||||
 | 
					        else
 | 
				
			||||||
            case "$os" in
 | 
					            case "$os" in
 | 
				
			||||||
            archlinux)
 | 
					 | 
				
			||||||
                echo "systemctl enable \"$name\""
 | 
					 | 
				
			||||||
            ;;
 | 
					 | 
				
			||||||
                debian)
 | 
					                debian)
 | 
				
			||||||
                    case "$os_version" in
 | 
					                    case "$os_version" in
 | 
				
			||||||
                        [1-7]*)
 | 
					                        [1-7]*)
 | 
				
			||||||
| 
						 | 
					@ -58,6 +61,8 @@ case "$state_should" in
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                amazon|centos|fedora|owl|redhat|suse)
 | 
					                amazon|centos|fedora|owl|redhat|suse)
 | 
				
			||||||
                    echo chkconfig \"$name\" on
 | 
					                    echo chkconfig \"$name\" on
 | 
				
			||||||
 | 
					                            echo "Unsupported version $os_version of $os" >&2
 | 
				
			||||||
 | 
					                            exit 1
 | 
				
			||||||
                ;;
 | 
					                ;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                openwrt)
 | 
					                openwrt)
 | 
				
			||||||
| 
						 | 
					@ -76,13 +81,17 @@ case "$state_should" in
 | 
				
			||||||
                   exit 1
 | 
					                   exit 1
 | 
				
			||||||
                ;;
 | 
					                ;;
 | 
				
			||||||
            esac
 | 
					            esac
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    absent)
 | 
					    absent)
 | 
				
			||||||
 | 
					        if [ "$init" = 'systemd' ]; then
 | 
				
			||||||
 | 
					            # this handles ALL linux distros with systemd
 | 
				
			||||||
 | 
					            # e.g. archlinux, gentoo in some cases, new RHEL and SLES versions
 | 
				
			||||||
 | 
					            echo "systemctl -q disable \"$name\""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        else
 | 
				
			||||||
            case "$os" in
 | 
					            case "$os" in
 | 
				
			||||||
            archlinux)
 | 
					 | 
				
			||||||
                echo "systemctl disable \"$name\""
 | 
					 | 
				
			||||||
            ;;
 | 
					 | 
				
			||||||
                debian|ubuntu)
 | 
					                debian|ubuntu)
 | 
				
			||||||
                    echo update-rc.d -f \"$name\" remove
 | 
					                    echo update-rc.d -f \"$name\" remove
 | 
				
			||||||
                ;;
 | 
					                ;;
 | 
				
			||||||
| 
						 | 
					@ -104,7 +113,7 @@ case "$state_should" in
 | 
				
			||||||
                   exit 1
 | 
					                   exit 1
 | 
				
			||||||
                ;;
 | 
					                ;;
 | 
				
			||||||
            esac
 | 
					            esac
 | 
				
			||||||
 
 | 
					        fi
 | 
				
			||||||
    ;;
 | 
					    ;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    *)
 | 
					    *)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -25,6 +25,4 @@ if [ -f "$__object/parameter/uri" ]; then
 | 
				
			||||||
else
 | 
					else
 | 
				
			||||||
   uri="/$__object_id"
 | 
					   uri="/$__object_id"
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
# simpler command which works only on SLES11 SP3 or newer:
 | 
					echo $(zypper ls -u | awk 'BEGIN { FS = "[ ]+\\|[ ]+" } ; $4 == "Yes" && $NF == "'$uri'" {print $NF}')
 | 
				
			||||||
# echo $(zypper ls -u -E | grep -E "\<$uri\>" | cut -d'|' -f 7)
 | 
					 | 
				
			||||||
echo $(zypper ls -u | grep -E '^([^|]+\|){3,3} Yes' | grep -E "\<$uri\>" | cut -d'|' -f 7 )
 | 
					 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -195,7 +195,7 @@ class Local(object):
 | 
				
			||||||
        except subprocess.CalledProcessError:
 | 
					        except subprocess.CalledProcessError:
 | 
				
			||||||
            raise cdist.Error("Command failed: " + " ".join(command))
 | 
					            raise cdist.Error("Command failed: " + " ".join(command))
 | 
				
			||||||
        except OSError as error:
 | 
					        except OSError as error:
 | 
				
			||||||
            raise cdist.Error(" ".join(*args) + ": " + error.args[1])
 | 
					            raise cdist.Error(" ".join(command) + ": " + error.args[1])
 | 
				
			||||||
        finally:
 | 
					        finally:
 | 
				
			||||||
            if message_prefix:
 | 
					            if message_prefix:
 | 
				
			||||||
                message.merge_messages()
 | 
					                message.merge_messages()
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -130,12 +130,29 @@ class Remote(object):
 | 
				
			||||||
        # FIXME: replace this by -o SendEnv name -o SendEnv name ... to ssh?
 | 
					        # FIXME: replace this by -o SendEnv name -o SendEnv name ... to ssh?
 | 
				
			||||||
        # can't pass environment to remote side, so prepend command with
 | 
					        # can't pass environment to remote side, so prepend command with
 | 
				
			||||||
        # variable declarations
 | 
					        # variable declarations
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # cdist command prepended with variable assignments expects
 | 
				
			||||||
 | 
					        # posix shell (bourne, bash) at the remote as user default shell.
 | 
				
			||||||
 | 
					        # If remote user shell isn't poxis shell, but for e.g. csh/tcsh
 | 
				
			||||||
 | 
					        # then these var assignments are not var assignments for this
 | 
				
			||||||
 | 
					        # remote shell, it tries to execute it as a command and fails.
 | 
				
			||||||
 | 
					        # So really do this by default:
 | 
				
			||||||
 | 
					        # /bin/sh -c 'export <var assignments>; command'
 | 
				
			||||||
 | 
					        # so that constructed remote command isn't dependent on remote
 | 
				
			||||||
 | 
					        # shell. Do this only if env is not None. env breaks this.
 | 
				
			||||||
 | 
					        # Explicitly use /bin/sh, because var assignments assume poxis
 | 
				
			||||||
 | 
					        # shell already.
 | 
				
			||||||
 | 
					        # This leaves the posibility to write script that needs to be run
 | 
				
			||||||
 | 
					        # remotely in e.g. csh and setting up CDIST_REMOTE_SHELL to e.g.
 | 
				
			||||||
 | 
					        # /bin/csh will execute this script in the right way.
 | 
				
			||||||
        if env:
 | 
					        if env:
 | 
				
			||||||
            remote_env = ["%s=%s" % item for item in env.items()]
 | 
					            cmd.append("/bin/sh")
 | 
				
			||||||
            cmd.extend(remote_env)
 | 
					            cmd.append("-c")
 | 
				
			||||||
 | 
					            remote_env = [" export %s=%s;" % item for item in env.items()]
 | 
				
			||||||
 | 
					            string_cmd = " ".join(remote_env) + " ".join(command)
 | 
				
			||||||
 | 
					            cmd.append(string_cmd)
 | 
				
			||||||
 | 
					        else:
 | 
				
			||||||
            cmd.extend(command)
 | 
					            cmd.extend(command)
 | 
				
			||||||
 | 
					 | 
				
			||||||
        return self._run_command(cmd, env=env, return_output=return_output)
 | 
					        return self._run_command(cmd, env=env, return_output=return_output)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def _run_command(self, command, env=None, return_output=False):
 | 
					    def _run_command(self, command, env=None, return_output=False):
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -39,7 +39,7 @@ class RemoteTestCase(test.CdistTestCase):
 | 
				
			||||||
        user = getpass.getuser()
 | 
					        user = getpass.getuser()
 | 
				
			||||||
        remote_exec = "ssh -o User=%s -q" % user
 | 
					        remote_exec = "ssh -o User=%s -q" % user
 | 
				
			||||||
        remote_copy = "scp -o User=%s -q" % user
 | 
					        remote_copy = "scp -o User=%s -q" % user
 | 
				
			||||||
        self.remote = remote.Remote(self.target_host, self.base_path, remote_exec, remote_copy)
 | 
					        self.remote = remote.Remote(self.target_host, base_path=self.base_path, remote_exec=remote_exec, remote_copy=remote_copy)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def tearDown(self):
 | 
					    def tearDown(self):
 | 
				
			||||||
        shutil.rmtree(self.temp_dir)
 | 
					        shutil.rmtree(self.temp_dir)
 | 
				
			||||||
| 
						 | 
					@ -125,7 +125,7 @@ class RemoteTestCase(test.CdistTestCase):
 | 
				
			||||||
        os.chmod(remote_exec_path, 0o755)
 | 
					        os.chmod(remote_exec_path, 0o755)
 | 
				
			||||||
        remote_exec = remote_exec_path
 | 
					        remote_exec = remote_exec_path
 | 
				
			||||||
        remote_copy = "echo"
 | 
					        remote_copy = "echo"
 | 
				
			||||||
        r = remote.Remote(self.target_host, self.base_path, remote_exec, remote_copy)
 | 
					        r = remote.Remote(self.target_host, base_path=self.base_path, remote_exec=remote_exec, remote_copy=remote_copy)
 | 
				
			||||||
        self.assertEqual(r.run('/bin/true', return_output=True), "%s\n" % self.target_host)
 | 
					        self.assertEqual(r.run('/bin/true', return_output=True), "%s\n" % self.target_host)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def test_run_script_target_host_in_env(self):
 | 
					    def test_run_script_target_host_in_env(self):
 | 
				
			||||||
| 
						 | 
					@ -135,8 +135,33 @@ class RemoteTestCase(test.CdistTestCase):
 | 
				
			||||||
        os.chmod(remote_exec_path, 0o755)
 | 
					        os.chmod(remote_exec_path, 0o755)
 | 
				
			||||||
        remote_exec = remote_exec_path
 | 
					        remote_exec = remote_exec_path
 | 
				
			||||||
        remote_copy = "echo"
 | 
					        remote_copy = "echo"
 | 
				
			||||||
        r = remote.Remote(self.target_host, self.base_path, remote_exec, remote_copy)
 | 
					        r = remote.Remote(self.target_host, base_path=self.base_path, remote_exec=remote_exec, remote_copy=remote_copy)
 | 
				
			||||||
        handle, script = self.mkstemp(dir=self.temp_dir)
 | 
					        handle, script = self.mkstemp(dir=self.temp_dir)
 | 
				
			||||||
        with os.fdopen(handle, "w") as fd:
 | 
					        with os.fdopen(handle, "w") as fd:
 | 
				
			||||||
            fd.writelines(["#!/bin/sh\n", "/bin/true"])
 | 
					            fd.writelines(["#!/bin/sh\n", "/bin/true"])
 | 
				
			||||||
        self.assertEqual(r.run_script(script, return_output=True), "%s\n" % self.target_host)
 | 
					        self.assertEqual(r.run_script(script, return_output=True), "%s\n" % self.target_host)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def test_run_script_with_env_target_host_in_env(self):
 | 
				
			||||||
 | 
					        handle, script = self.mkstemp(dir=self.temp_dir)
 | 
				
			||||||
 | 
					        with os.fdopen(handle, "w") as fd:
 | 
				
			||||||
 | 
					            fd.writelines(["#!/bin/sh\n", 'if [ "$__object" ]; then echo $__object; else echo no_env; fi\n'])
 | 
				
			||||||
 | 
					        os.chmod(script, 0o755)
 | 
				
			||||||
 | 
					        handle, remote_exec_path = self.mkstemp(dir=self.temp_dir)
 | 
				
			||||||
 | 
					        with os.fdopen(handle, 'w') as fd:
 | 
				
			||||||
 | 
					            fd.writelines(["#!/bin/sh\n", 'shift; cmd=$1; shift; $cmd "$@"\n'])
 | 
				
			||||||
 | 
					        os.chmod(remote_exec_path, 0o755)
 | 
				
			||||||
 | 
					        remote_exec = remote_exec_path
 | 
				
			||||||
 | 
					        remote_copy = "echo"
 | 
				
			||||||
 | 
					        r = remote.Remote(self.target_host, base_path=self.base_path, remote_exec=remote_exec, remote_copy=remote_copy)
 | 
				
			||||||
 | 
					        output = r.run_script(script, return_output=True)
 | 
				
			||||||
 | 
					        self.assertEqual(output, "no_env\n")
 | 
				
			||||||
 | 
					        env = {
 | 
				
			||||||
 | 
					            '__object': 'test_object',
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        output = r.run_script(script, env=env, return_output=True)
 | 
				
			||||||
 | 
					        self.assertEqual(output, "test_object\n")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if __name__ == '__main__':
 | 
				
			||||||
 | 
					    import unittest
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    unittest.main()
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2,6 +2,10 @@ Changelog
 | 
				
			||||||
---------
 | 
					---------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
next:
 | 
					next:
 | 
				
			||||||
 | 
						* Core: Add CDIST_REMOTE_COPY/EXEC env variables and multiplexing options for default scp/ssh (Darko Poljak)
 | 
				
			||||||
 | 
						* Types: Remove bashisms in scripts (Darko Poljak)
 | 
				
			||||||
 | 
						* Core: Fix bug in remote command with environment (Darko Poljak)
 | 
				
			||||||
 | 
						* Core: Fix bug in local code execution (Darko Poljak)
 | 
				
			||||||
	* Documentation: Fix spelling in manual pages (Dmitry Bogatov)
 | 
						* Documentation: Fix spelling in manual pages (Dmitry Bogatov)
 | 
				
			||||||
	* New type: __pacman_conf: Manage pacman.conf (Dominique Roux)
 | 
						* New type: __pacman_conf: Manage pacman.conf (Dominique Roux)
 | 
				
			||||||
	* New type: __pacman_conf_integrate: cdist compatible pacman.conf (Dominique Roux)
 | 
						* New type: __pacman_conf_integrate: cdist compatible pacman.conf (Dominique Roux)
 | 
				
			||||||
| 
						 | 
					@ -16,6 +20,7 @@ next:
 | 
				
			||||||
	* Type __file: Add NetBSD support (Jonathan A. Kollasch)
 | 
						* Type __file: Add NetBSD support (Jonathan A. Kollasch)
 | 
				
			||||||
	* Type __group: Add NetBSD support (Jonathan A. Kollasch)
 | 
						* Type __group: Add NetBSD support (Jonathan A. Kollasch)
 | 
				
			||||||
	* Type __consul: Add new consul versions (Nico Schottelius)
 | 
						* Type __consul: Add new consul versions (Nico Schottelius)
 | 
				
			||||||
 | 
						* Type __apt_ppa: Do not install legacy package python-software-properties (Steven Armstrong)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
3.1.13: 2015-05-16
 | 
					3.1.13: 2015-05-16
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue