forked from ungleich-public/cdist
		
	fix many bugs in cdist-manifest-recursive-all
Signed-off-by: Nico Schottelius <nico@kr.ethz.ch>
This commit is contained in:
		
					parent
					
						
							
								711f9d7647
							
						
					
				
			
			
				commit
				
					
						7bd2ba1358
					
				
			
		
					 1 changed files with 48 additions and 55 deletions
				
			
		| 
						 | 
					@ -1,6 +1,6 @@
 | 
				
			||||||
#!/bin/sh
 | 
					#!/bin/sh
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2010 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2010-2011 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -38,84 +38,77 @@ set -eu
 | 
				
			||||||
__cdist_target_host="$1"; shift
 | 
					__cdist_target_host="$1"; shift
 | 
				
			||||||
__cdist_object_base_dir="$1"; shift
 | 
					__cdist_object_base_dir="$1"; shift
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# change to directory containing objects
 | 
					objectlist="${__cdist_tmp_dir}/objectfile"
 | 
				
			||||||
cd "$__cdist_object_base_dir"
 | 
					newobjectlist="${__cdist_tmp_dir}/newobjectfile"
 | 
				
			||||||
 | 
					newobjects="${__cdist_tmp_dir}/newobjects"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					no_new_object=n
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Loop until we do not create new objects anymore
 | 
					# Loop until we do not create new objects anymore
 | 
				
			||||||
# which is equal to all objects have been run
 | 
					# which is equal to all objects have been run
 | 
				
			||||||
__cdist_object_created_new=1
 | 
					while [ "$no_new_object" = "n"  ]; do
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
while [ "$__cdist_object_created_new" = 1 ]; do
 | 
					 | 
				
			||||||
   # assume we're done after this run
 | 
					   # assume we're done after this run
 | 
				
			||||||
   __cdist_object_created_new=0
 | 
					   no_new_object=y
 | 
				
			||||||
 | 
					
 | 
				
			||||||
   # find all objects (every object has the source recorded)
 | 
					   # find all objects (every object has the source recorded)
 | 
				
			||||||
   __cdist_object_list . > "$__cdist_tmp_file"
 | 
					   __cdist_object_list "$__cdist_object_base_dir" > "$objectlist"
 | 
				
			||||||
 | 
					 | 
				
			||||||
   # FIXME: DEBUG
 | 
					 | 
				
			||||||
   cat "$__cdist_tmp_file"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					   # Check every object, if we need to run it
 | 
				
			||||||
   while read object; do
 | 
					   while read object; do
 | 
				
			||||||
      if [ ! -f "${object}/$__cdist_name_object_finished" ]; then
 | 
					      cur_object_dir="$__cdist_object_base_dir/$object"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      if [ ! -f "${cur_object_dir}/$__cdist_name_object_finished" ]; then
 | 
				
			||||||
         echo "Working on object ${object} ..."
 | 
					         echo "Working on object ${object} ..."
 | 
				
			||||||
 | 
					
 | 
				
			||||||
         type=${object%%/*}
 | 
					         type="${object%%/*}"
 | 
				
			||||||
         manifest="$__cdist_type_dir/${type}/${__cdist_name_init}"
 | 
					         manifest="$__cdist_type_dir/${type}/${__cdist_name_manifest}"
 | 
				
			||||||
 | 
					         echo $manifest
 | 
				
			||||||
 | 
					
 | 
				
			||||||
         if [ -x "${manifest}" ]; then
 | 
					         if [ -x "${manifest}" ]; then
 | 
				
			||||||
            echo "Running manifest of type ${type} ..."
 | 
					            echo "Executing manifest ${manifest} ..."
 | 
				
			||||||
 | 
					            cdist-manifest-run "$__cdist_target_host" "${manifest}" "${newobjects}"
 | 
				
			||||||
            # FIXME: use subdir in tmpdir?
 | 
					            __cdist_object_list "${newobjects}" > "$newobjectlist"
 | 
				
			||||||
            cdist-manifest-run "$__cdist_target_host" "${manifest}" "${__cdist_tmp_dir}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            echo "Trying to merge... "
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            # list of new objects
 | 
					 | 
				
			||||||
            cd "${__cdist_tmp_dir}"
 | 
					 | 
				
			||||||
            __cdist_object_list .  > "$__cdist_tmp_file"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            # Verify no conflicting objects have been created
 | 
				
			||||||
            while read newobject; do
 | 
					            while read newobject; do
 | 
				
			||||||
               if [ -e "$__cdist_object_base_dir/${newobject}" ]; then
 | 
					               grep -q "^$newobject\$" "$objectlist" && \
 | 
				
			||||||
                  __cdist_exit_err "${newobject} already exists, merge failed."
 | 
					                  __cdist_exit_err "${manifest} tried to recreate ${newobject}"
 | 
				
			||||||
               else
 | 
					            done < "$newobjectlist"
 | 
				
			||||||
                  # Fine, merge back! FIXME: touch correct here?
 | 
					 | 
				
			||||||
                  touch "${newobject}/$___cdist_name_object_finished"
 | 
					 | 
				
			||||||
                  pax -r -w "$newobject" "$__cdist_object_base_dir"
 | 
					 | 
				
			||||||
               fi
 | 
					 | 
				
			||||||
            done < "$__cdist_tmp_file"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            # Always rerun the whole loop if we ran
 | 
					 | 
				
			||||||
            # a manifest of an object
 | 
					 | 
				
			||||||
            break
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            # FIXME: continue here
 | 
					            # Safe harbour: We can merge all objects into main tree
 | 
				
			||||||
            # tar, cp, pax, mv?
 | 
					            # Merge = mkdir + mv parameters
 | 
				
			||||||
            # mv/cp -n look good - posix?
 | 
					            while read newobject; do
 | 
				
			||||||
 | 
					               # Unset no_new_object - only once needed... FIXME (beautify)
 | 
				
			||||||
 | 
					               no_new_object="n"
 | 
				
			||||||
 | 
					               
 | 
				
			||||||
 | 
					               set -x
 | 
				
			||||||
 | 
					               # where to save the newly created object
 | 
				
			||||||
 | 
					               object_dir="$__cdist_object_base_dir/$newobject"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            # pax:
 | 
					               # Source of the new object
 | 
				
			||||||
            # pax -r -w  -k could work, but -k does not raise an error if files
 | 
					               new_object_dir="${newobjects}/$newobject"
 | 
				
			||||||
            # are already existing
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
            # - copy if not existing
 | 
					               echo "MIGRATING: $newobject"
 | 
				
			||||||
            # fail (abort whole recursive run) if existing
 | 
					               find $new_object_dir
 | 
				
			||||||
            # 
 | 
					 | 
				
			||||||
            # iterate over all new objects and copy each back?
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					               mkdir -p "$object_dir"
 | 
				
			||||||
 | 
					               mv "${new_object_dir}/"* "$object_dir"
 | 
				
			||||||
 | 
					               set +x
 | 
				
			||||||
 | 
					            done < "$newobjectlist"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            # Remove listing and rest of newobjects, otherwise the next type will reuse it...
 | 
				
			||||||
 | 
					            rm -rf "$newobjects" "$newobjectlist"
 | 
				
			||||||
         else
 | 
					         else
 | 
				
			||||||
            # Be nice, warn user if manifests exists, but is not executable
 | 
					            # Be nice, warn user if manifests exists, but is not executable
 | 
				
			||||||
            if [ -f "${manifest}" ]; then
 | 
					            if [ -f "${manifest}" ]; then
 | 
				
			||||||
               echo "Warning ${manifest} is not executable"
 | 
					               echo "Warning ${manifest} exists, but is not executable." >&2
 | 
				
			||||||
            fi
 | 
					            fi
 | 
				
			||||||
         fi
 | 
					         fi
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
         # At least one more run needed
 | 
					 | 
				
			||||||
         __cdist_object_created_new=1
 | 
					 | 
				
			||||||
      fi
 | 
					      fi
 | 
				
			||||||
   done < "$__cdist_tmp_file"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      # done with this object
 | 
				
			||||||
 | 
					      touch "$cur_object_dir/$__cdist_name_object_finished"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					   done < "$objectlist"
 | 
				
			||||||
done
 | 
					done
 | 
				
			||||||
 | 
					 | 
				
			||||||
exit 0
 | 
					 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue