nixos/update-users-groups: write files truly atomic

Having the .tmp suffix is broken w.r.t. to multiple writers,
as they would overwrite existing files. using the atomic flag
will make write_file to create a unique temporary file it gets renamed
to its target.
This commit is contained in:
Jörg Thalheim 2020-09-23 10:47:39 +02:00
parent f072d4dadc
commit 99406adaae
No known key found for this signature in database
GPG Key ID: 003F2096411B5F92

View File

@ -16,8 +16,7 @@ my $gidMap = -e $gidMapFile ? decode_json(read_file($gidMapFile)) : {};
sub updateFile { sub updateFile {
my ($path, $contents, $perms) = @_; my ($path, $contents, $perms) = @_;
write_file("$path.tmp", { binmode => ':utf8', perms => $perms // 0644 }, $contents); write_file($path, { atomic => 1, binmode => ':utf8', perms => $perms // 0644 }, $contents) or die;
rename("$path.tmp", $path) or die;
} }