mirror of
https://github.com/valitydev/salt.git
synced 2024-11-09 01:36:48 +00:00
Fix regression in salt.utils.copyfile()
In pull request #9599, I added code to make salt.utils.copyfile() set the ownership and permissions of the new file to those of the pre-existing file. However, this raises an exception when the destination file doesn't exist, which happens on file.managed states which are creating new files. This commit fixes that regression.
This commit is contained in:
parent
9ab823ae05
commit
dc01443085
@ -642,10 +642,14 @@ def copyfile(source, dest, backup_mode='', cachedir=''):
|
||||
pass
|
||||
# Get current file stats to they can be replicated after the new file is
|
||||
# moved to the destination path.
|
||||
fstat = os.stat(dest)
|
||||
try:
|
||||
fstat = os.stat(dest)
|
||||
except OSError:
|
||||
fstat = None
|
||||
shutil.move(tgt, dest)
|
||||
os.chown(dest, fstat.st_uid, fstat.st_gid)
|
||||
os.chmod(dest, fstat.st_mode)
|
||||
if fstat is not None:
|
||||
os.chown(dest, fstat.st_uid, fstat.st_gid)
|
||||
os.chmod(dest, fstat.st_mode)
|
||||
# If SELINUX is available run a restorecon on the file
|
||||
rcon = which('restorecon')
|
||||
if rcon:
|
||||
|
Loading…
Reference in New Issue
Block a user