Merge branch 'feature_object_override' of git://github.com/dheule/cdist
This commit is contained in:
		
				commit
				
					
						a9dd040164
					
				
			
		
					 3 changed files with 38 additions and 5 deletions
				
			
		| 
						 | 
					@ -2,6 +2,7 @@
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2011 Steven Armstrong (steven-cdist at armstrong.cc)
 | 
					# 2011 Steven Armstrong (steven-cdist at armstrong.cc)
 | 
				
			||||||
# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
 | 
					# 2014 Daniel Heule (hda at sfs.biz)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -211,13 +212,13 @@ class CdistObject(object):
 | 
				
			||||||
        """Checks wether this cdist object exists on the file systems."""
 | 
					        """Checks wether this cdist object exists on the file systems."""
 | 
				
			||||||
        return os.path.exists(self.absolute_path)
 | 
					        return os.path.exists(self.absolute_path)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def create(self):
 | 
					    def create(self, allow_overwrite=False):
 | 
				
			||||||
        """Create this cdist object on the filesystem.
 | 
					        """Create this cdist object on the filesystem.
 | 
				
			||||||
        """
 | 
					        """
 | 
				
			||||||
        try:
 | 
					        try:
 | 
				
			||||||
            os.makedirs(self.absolute_path, exist_ok=False)
 | 
					            os.makedirs(self.absolute_path, exist_ok=allow_overwrite)
 | 
				
			||||||
            absolute_parameter_path = os.path.join(self.base_path, self.parameter_path)
 | 
					            absolute_parameter_path = os.path.join(self.base_path, self.parameter_path)
 | 
				
			||||||
            os.makedirs(absolute_parameter_path, exist_ok=False)
 | 
					            os.makedirs(absolute_parameter_path, exist_ok=allow_overwrite)
 | 
				
			||||||
        except EnvironmentError as error:
 | 
					        except EnvironmentError as error:
 | 
				
			||||||
            raise cdist.Error('Error creating directories for cdist object: %s: %s' % (self, error))
 | 
					            raise cdist.Error('Error creating directories for cdist object: %s: %s' % (self, error))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2,6 +2,7 @@
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2011-2013 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
# 2012 Steven Armstrong (steven-cdist at armstrong.cc)
 | 
					# 2012 Steven Armstrong (steven-cdist at armstrong.cc)
 | 
				
			||||||
 | 
					# 2014 Daniel Heule (hda at sfs.biz)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -144,11 +145,15 @@ class Emulator(object):
 | 
				
			||||||
            if value is not None:
 | 
					            if value is not None:
 | 
				
			||||||
                self.parameters[key] = value
 | 
					                self.parameters[key] = value
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if self.cdist_object.exists:
 | 
					        if self.cdist_object.exists and os.environ.get('CDIST_ALLOW_OVERRIDE',"false") != 'true':
 | 
				
			||||||
            if self.cdist_object.parameters != self.parameters:
 | 
					            if self.cdist_object.parameters != self.parameters:
 | 
				
			||||||
                raise cdist.Error("Object %s already exists with conflicting parameters:\n%s: %s\n%s: %s"
 | 
					                raise cdist.Error("Object %s already exists with conflicting parameters:\n%s: %s\n%s: %s"
 | 
				
			||||||
                    % (self.cdist_object.name, " ".join(self.cdist_object.source), self.cdist_object.parameters, self.object_source, self.parameters)
 | 
					                    % (self.cdist_object.name, " ".join(self.cdist_object.source), self.cdist_object.parameters, self.object_source, self.parameters)
 | 
				
			||||||
            )
 | 
					            )
 | 
				
			||||||
 | 
					        else:
 | 
				
			||||||
 | 
					            if self.cdist_object.exists:
 | 
				
			||||||
 | 
					                self.log.debug('Object %s override forced with CDIST_ALLOW_OVERRIDE=true',self.cdist_object.name)
 | 
				
			||||||
 | 
					                self.cdist_object.create(True)
 | 
				
			||||||
            else:
 | 
					            else:
 | 
				
			||||||
                self.cdist_object.create()
 | 
					                self.cdist_object.create()
 | 
				
			||||||
            self.cdist_object.parameters = self.parameters
 | 
					            self.cdist_object.parameters = self.parameters
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -161,6 +161,33 @@ __package lighttpd --state present
 | 
				
			||||||
require="__package/lighttpd" __package munin --state present
 | 
					require="__package/lighttpd" __package munin --state present
 | 
				
			||||||
--------------------------------------------------------------------------------
 | 
					--------------------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					OVERRIDES
 | 
				
			||||||
 | 
					---------
 | 
				
			||||||
 | 
					In some special cases, you would like to create an already defined object 
 | 
				
			||||||
 | 
					with different parameters. In normal situations this leads to an error in cdist.
 | 
				
			||||||
 | 
					If you whish, you can mark this second definition of an object with 
 | 
				
			||||||
 | 
					CDIST_ALLOW_OVERRIDE=true to tell cdist, that this object override is 
 | 
				
			||||||
 | 
					wanted and should be accepted.
 | 
				
			||||||
 | 
					ATTENTION: Only use this feature if you are 100% sure in which order 
 | 
				
			||||||
 | 
					cdist encounter the affected objects, otherwhise this results 
 | 
				
			||||||
 | 
					into an undefined situation. 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					--------------------------------------------------------------------------------
 | 
				
			||||||
 | 
					# for example in the inial manifest
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# reate user account foobar with some hash for password
 | 
				
			||||||
 | 
					__user foobar --password 'some_fancy_hash'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# ... many statements and includes in the manifest later ...
 | 
				
			||||||
 | 
					# somewhere in a conditionaly sourced manifest 
 | 
				
			||||||
 | 
					# (e.g. for example only sourced if a special application is on the target host)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# this leads to an error ...
 | 
				
			||||||
 | 
					__user foobar --password 'some_other_hash' 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# this tells cdist, that you know that this is an override and should be accepted
 | 
				
			||||||
 | 
					CDIST_ALLOW_OVERRIDE=true __user foobar --password 'some_other_hash'
 | 
				
			||||||
 | 
					--------------------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
SEE ALSO
 | 
					SEE ALSO
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue