forked from ungleich-public/cdist
		
	a giant commit into the future
Signed-off-by: Nico Schottelius <nico@kr.ethz.ch>
This commit is contained in:
		
					parent
					
						
							
								edc4bf6a47
							
						
					
				
			
			
				commit
				
					
						995bf8d963
					
				
			
		
					 6 changed files with 52 additions and 46 deletions
				
			
		|  | @ -21,8 +21,9 @@ | ||||||
| # Print configuration directories - helper for all other scripts | # Print configuration directories - helper for all other scripts | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| # Fail if something bogus is going on | # Fail if something bogus is going on and export all variables | ||||||
| set -u | # The export is mainly needed for remote knowledge | ||||||
|  | set -au | ||||||
| 
 | 
 | ||||||
| # Values can be overriden from outside, so you can | # Values can be overriden from outside, so you can | ||||||
| # customise paths as you like (for distributors, geeks and hackers) | # customise paths as you like (for distributors, geeks and hackers) | ||||||
|  | @ -32,6 +33,7 @@ set -u | ||||||
| : ${__cdist_name_code:=code} | : ${__cdist_name_code:=code} | ||||||
| : ${__cdist_name_explorer:=explorers} | : ${__cdist_name_explorer:=explorers} | ||||||
| : ${__cdist_name_gencode:=gencode} | : ${__cdist_name_gencode:=gencode} | ||||||
|  | : ${__cdist_name_helper:=helper} | ||||||
| : ${__cdist_name_host:=hosts} | : ${__cdist_name_host:=hosts} | ||||||
| : ${__cdist_name_init:=init} | : ${__cdist_name_init:=init} | ||||||
| : ${__cdist_name_out_dir:=out_dir} | : ${__cdist_name_out_dir:=out_dir} | ||||||
|  | @ -61,6 +63,7 @@ set -u | ||||||
| # Base | # Base | ||||||
| : ${__cdist_config:=/etc/cdist} | : ${__cdist_config:=/etc/cdist} | ||||||
| : ${__cdist_explorer_dir:=$__cdist_config/$__cdist_name_explorer} | : ${__cdist_explorer_dir:=$__cdist_config/$__cdist_name_explorer} | ||||||
|  | : ${__cdist_helper_dir:=$__cdist_config/$__cdist_name_helper} | ||||||
| : ${__cdist_manifest_dir:=$__cdist_config/$__cdist_name_manifests} | : ${__cdist_manifest_dir:=$__cdist_config/$__cdist_name_manifests} | ||||||
| : ${__cdist_manifest_init:=$__cdist_manifest_dir/$__cdist_name_init} | : ${__cdist_manifest_init:=$__cdist_manifest_dir/$__cdist_name_init} | ||||||
| : ${__cdist_type_dir:=$__cdist_config/$__cdist_name_type} | : ${__cdist_type_dir:=$__cdist_config/$__cdist_name_type} | ||||||
|  | @ -77,6 +80,7 @@ __cdist_sane_regexp='[A-Za-z0-9]*[-A-Za-z0-9_]*' | ||||||
| # Remote config | # Remote config | ||||||
| : ${__cdist_remote_conf_dir:=$__cdist_remote_base_dir/$__cdist_name_conf_dir} | : ${__cdist_remote_conf_dir:=$__cdist_remote_base_dir/$__cdist_name_conf_dir} | ||||||
| : ${__cdist_remote_explorer_dir:=$__cdist_remote_conf_dir/$__cdist_name_explorer} | : ${__cdist_remote_explorer_dir:=$__cdist_remote_conf_dir/$__cdist_name_explorer} | ||||||
|  | : ${__cdist_remote_helper_dir:=$__cdist_remote_conf_dir/$__cdist_name_helper} | ||||||
| 
 | 
 | ||||||
| # Remote out | # Remote out | ||||||
| : ${__cdist_remote_out_dir:=$__cdist_remote_base_dir/$__cdist_name_out_dir} | : ${__cdist_remote_out_dir:=$__cdist_remote_base_dir/$__cdist_name_out_dir} | ||||||
|  |  | ||||||
|  | @ -27,10 +27,20 @@ set -eu | ||||||
| 
 | 
 | ||||||
| __cdist_target_host="$1" | __cdist_target_host="$1" | ||||||
| 
 | 
 | ||||||
|  | ################################################################################ | ||||||
| # See cdist-stages(7) | # See cdist-stages(7) | ||||||
| cdist-explorer-run-init       "$__cdist_target_host" "$__cdist_out_explorer_dir" | # | ||||||
|  | 
 | ||||||
|  | # Transfer core helpers plus cdist-config | ||||||
|  | cdist-dir push "$__cdist_target_host" "${__cdist_helper_dir}" "${__cdist_remote_helper_dir}" | ||||||
|  | scp "$(which cdist-config)" \ | ||||||
|  |    "${__cdist_remote_user}@${__cdist_target_host}:${__cdist_remote_helper_dir}" | ||||||
| 
 | 
 | ||||||
| exit 2 | exit 2 | ||||||
|  | 
 | ||||||
|  | # Execute explorer | ||||||
|  | cdist-explorer-run-init       "$__cdist_target_host" "$__cdist_out_explorer_dir" | ||||||
|  | 
 | ||||||
| cdist-manifest-init           "$__cdist_target_host" "$__cdist_out_object_dir" | cdist-manifest-init           "$__cdist_target_host" "$__cdist_out_object_dir" | ||||||
| cdist-manifest-run-all        "$__cdist_target_host" "$__cdist_out_object_dir" | cdist-manifest-run-all        "$__cdist_target_host" "$__cdist_out_object_dir" | ||||||
| cdist-object-explorer-all     "$__cdist_target_host" "$__cdist_out_object_dir" | cdist-object-explorer-all     "$__cdist_target_host" "$__cdist_out_object_dir" | ||||||
|  |  | ||||||
|  | @ -24,25 +24,18 @@ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| . cdist-config | . cdist-config | ||||||
| if [ $# -lt 5 ]; then | if [ $# -lt 3 ]; then | ||||||
|    __cdist_usage "<target host> <local srcdir> <local dstdir> <remote srcdir> <remote dstdir> [explorer args]" |    __cdist_usage "<target host> <remote srcdir> <remote dstdir> [explorer args]" | ||||||
| fi | fi | ||||||
| set -ue | set -ue | ||||||
| 
 | 
 | ||||||
| __cdist_target_host="$1"; shift | __cdist_target_host="$1"; shift | ||||||
| 
 |  | ||||||
| __cdist_local_src_dir="$1"; shift |  | ||||||
| __cdist_local_dst_dir="$1"; shift |  | ||||||
| __cdist_remote_src_dir="$1"; shift | __cdist_remote_src_dir="$1"; shift | ||||||
| __cdist_remote_dst_dir="$1"; shift | __cdist_remote_dst_dir="$1"; shift | ||||||
| 
 | 
 | ||||||
| # Create remote source and destination directory | # Create remote destination directory | ||||||
| ssh "${__cdist_remote_user}@${__cdist_target_host}"   \ | ssh "${__cdist_remote_user}@${__cdist_target_host}"   \ | ||||||
|       "mkdir -p   \"${__cdist_remote_src_dir}\"       \ |       "mkdir -p \"${__cdist_remote_dst_dir}\"" | ||||||
|                   \"${__cdist_remote_dst_dir}\"" |  | ||||||
| 
 |  | ||||||
| # Ensure local destination directory exists |  | ||||||
| mkdir -p "$__cdist_local_dst_dir" |  | ||||||
| 
 | 
 | ||||||
| # FIXME: enable -q as soon as the code is cleaned up | # FIXME: enable -q as soon as the code is cleaned up | ||||||
| cd "${__cdist_local_src_dir}" | cd "${__cdist_local_src_dir}" | ||||||
|  | @ -53,9 +46,6 @@ if [ "$num" -lt 1 ]; then | ||||||
|    __cdist_exit_err "${__cdist_local_src_dir}: Contains no explorers" |    __cdist_exit_err "${__cdist_local_src_dir}: Contains no explorers" | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| # Copy all explorers to remote source directory |  | ||||||
| scp * "${__cdist_remote_user}@${__cdist_target_host}:${__cdist_remote_src_dir}" |  | ||||||
| 
 |  | ||||||
| # Execute all explorers | # Execute all explorers | ||||||
| for explorer in *; do | for explorer in *; do | ||||||
|    if [ -f "$explorer" ]; then |    if [ -f "$explorer" ]; then | ||||||
|  |  | ||||||
|  | @ -18,16 +18,24 @@ | ||||||
| # along with cdist. If not, see <http://www.gnu.org/licenses/>. | # along with cdist. If not, see <http://www.gnu.org/licenses/>. | ||||||
| # | # | ||||||
| # | # | ||||||
| # Run the global explorers, i.e. not bound to types | # Copy & run the general explorers, i.e. not bound to types | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| . cdist-config | . cdist-config | ||||||
| [ $# -eq 2 ] || __cdist_usage "<target host> <outdir>" | [ $# -eq 2 ] || __cdist_usage "<target_host> <out_dir>" | ||||||
| set -ue | set -ue | ||||||
| 
 | 
 | ||||||
| __cdist_target_host="$1"; shift | __cdist_target_host="$1"; shift | ||||||
| __cdist_output_dir="$1"; shift | __cdist_my_out_dir="$1"; shift | ||||||
| 
 | 
 | ||||||
|  | # copy the explorers | ||||||
|  | cdist-dir push "$__cdist_target_host" \ | ||||||
|  |    "${__cdist_explorer_dir}" "${__cdist_remote_explorer_dir}" | ||||||
|  | 
 | ||||||
|  | # run the explorers remotely | ||||||
| cdist-explorer-run "$__cdist_target_host"          \ | cdist-explorer-run "$__cdist_target_host"          \ | ||||||
|    "$__cdist_explorer_dir" "$__cdist_output_dir"   \ |    "$__cdist_remote_explorer_dir" "$__cdist_remote_out_explorer_dir" | ||||||
|    "$__cdist_remote_explorer_dir" "$__cdist_remote_cache_explorer" | 
 | ||||||
|  | # retrieve the results | ||||||
|  | cdist-dir pull "$__cdist_target_host" \ | ||||||
|  |    "${__cdist_remote_out_explorer_dir}" "${__cdist_my_out_dir}" | ||||||
|  |  | ||||||
|  | @ -59,6 +59,10 @@ while [ $# -gt 0 ]; do | ||||||
|    # Copy directory, needs to be one level above, otherwise subdir is created |    # Copy directory, needs to be one level above, otherwise subdir is created | ||||||
|    # FIXME: add -q later |    # FIXME: add -q later | ||||||
|    ssh "${__cdist_remote_user}@${__cdist_target_host}" "mkdir -p \"$remote_object_dir\"" |    ssh "${__cdist_remote_user}@${__cdist_target_host}" "mkdir -p \"$remote_object_dir\"" | ||||||
|  | 
 | ||||||
|  |    #  | ||||||
|  |    ssh "${__cdist_remote_user}@${__cdist_target_host}" "mkdir -p \"$remote_object_dir\"" | ||||||
|  | 
 | ||||||
|    scp -r "$local_params_dir" "${__cdist_remote_user}@${__cdist_target_host}:$remote_object_dir" |    scp -r "$local_params_dir" "${__cdist_remote_user}@${__cdist_target_host}:$remote_object_dir" | ||||||
| 
 | 
 | ||||||
|    if [ -d "$local_src_dir" ]; then |    if [ -d "$local_src_dir" ]; then | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| #!/bin/sh | #!/bin/sh | ||||||
| # | # | ||||||
| # 2010-2011 Nico Schottelius (nico-cdist at schottelius.org) | # 2011 Nico Schottelius (nico-cdist at schottelius.org) | ||||||
| # | # | ||||||
| # This file is part of cdist. | # This file is part of cdist. | ||||||
| # | # | ||||||
|  | @ -18,36 +18,32 @@ | ||||||
| # along with cdist. If not, see <http://www.gnu.org/licenses/>. | # along with cdist. If not, see <http://www.gnu.org/licenses/>. | ||||||
| # | # | ||||||
| # | # | ||||||
| # FIXME: Replace * references: * breaks if there is no explorer |  | ||||||
| # or FIXME: check that there is at least one explorer? |  | ||||||
| # |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| . cdist-config | . cdist-config | ||||||
| if [ $# -lt 3 ]; then | if [ $# -lt 3 ]; then | ||||||
|    __cdist_usage "<target host> <remote srcdir> <remote dstdir> [explorer args]" |    __cdist_usage "<work dir> <explorer dir> <out dir> [explorer args]" | ||||||
| fi | fi | ||||||
| set -ue | set -ue | ||||||
| 
 | 
 | ||||||
| __cdist_target_host="$1"; shift | # cd to this dir | ||||||
| __cdist_remote_src_dir="$1"; shift | __cdist_work_dir="$1"; shift | ||||||
| __cdist_remote_dst_dir="$1"; shift |  | ||||||
| 
 | 
 | ||||||
| # Create remote destination directory | # find explorers here | ||||||
| ssh "${__cdist_remote_user}@${__cdist_target_host}"   \ | __cdist_explorer_dir="$1"; shift | ||||||
|       "mkdir -p \"${__cdist_remote_dst_dir}\"" |  | ||||||
| 
 | 
 | ||||||
| # FIXME: enable -q as soon as the code is cleaned up | # write output here | ||||||
| cd "${__cdist_local_src_dir}" | __cdist_my_out_dir="$1"; shift | ||||||
|  | 
 | ||||||
|  | cd "${__cdist_work_dir}" | ||||||
| 
 | 
 | ||||||
| # Ensure there is at least one explorer | # Ensure there is at least one explorer | ||||||
| num="$(ls -1 | wc -l)" | num="$(ls -1 "$__cdist_explorer_dir" | wc -l)" | ||||||
| if [ "$num" -lt 1 ]; then | if [ "$num" -lt 1 ]; then | ||||||
|    __cdist_exit_err "${__cdist_local_src_dir}: Contains no explorers" |    __cdist_exit_err "${__cdist_explorer_dir}: Contains no explorers" | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| # Execute all explorers | # Execute all explorers | ||||||
| for explorer in *; do | for explorer in "$__cdist_explorer_dir/"*; do | ||||||
|    if [ -f "$explorer" ]; then |    if [ -f "$explorer" ]; then | ||||||
|       if [ ! -x "$explorer" ]; then |       if [ ! -x "$explorer" ]; then | ||||||
|          echo "Explorer \"$explorer\" exists, but is not executable." |          echo "Explorer \"$explorer\" exists, but is not executable." | ||||||
|  | @ -55,9 +51,7 @@ for explorer in *; do | ||||||
|       fi |       fi | ||||||
| 
 | 
 | ||||||
|       # Execute explorers and save results in remote destination directory |       # Execute explorers and save results in remote destination directory | ||||||
|       ssh "${__cdist_remote_user}@${__cdist_target_host}" \ |       "$explorer" "$@" > "${__cdist_my_out_dir}" | ||||||
|           "cd \"${__cdist_remote_src_dir}\" && \"./$explorer\" > \ |  | ||||||
|           \"${__cdist_remote_dst_dir}/${explorer}\"" "$@" |  | ||||||
|    else |    else | ||||||
|       if [ -e "$explorer" ]; then |       if [ -e "$explorer" ]; then | ||||||
|          echo "Explorer \"$explorer\" exists, but is not a file." |          echo "Explorer \"$explorer\" exists, but is not a file." | ||||||
|  | @ -65,7 +59,3 @@ for explorer in *; do | ||||||
|       fi |       fi | ||||||
|    fi |    fi | ||||||
| done | done | ||||||
| 
 |  | ||||||
| # Copy results back to us |  | ||||||
| scp "${__cdist_remote_user}@${__cdist_target_host}:${__cdist_remote_dst_dir}/*" \ |  | ||||||
|     "$__cdist_local_dst_dir" |  | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue