Remove the writable flag, don't set too many permission bits (#718)
Making everything 0o555 is too much, since many files in the store are not supposed to be executable. Those should be 0o444. Instead of splatting 0o555 out, take a more measured approach and remove the writable flag from the on-disk mode.
This commit is contained in:
parent
dac0adca28
commit
01a3447b83
2 changed files with 12 additions and 3 deletions
|
@ -1,5 +1,4 @@
|
||||||
use std::{
|
use std::{
|
||||||
fs::Permissions,
|
|
||||||
os::unix::prelude::PermissionsExt,
|
os::unix::prelude::PermissionsExt,
|
||||||
path::{Path, PathBuf},
|
path::{Path, PathBuf},
|
||||||
};
|
};
|
||||||
|
@ -110,13 +109,21 @@ impl Action for MoveUnpackedNix {
|
||||||
.map_err(|e| ActionErrorKind::Rename(entry.path(), entry_dest.to_owned(), e))
|
.map_err(|e| ActionErrorKind::Rename(entry.path(), entry_dest.to_owned(), e))
|
||||||
.map_err(Self::error)?;
|
.map_err(Self::error)?;
|
||||||
|
|
||||||
let perms: Permissions = PermissionsExt::from_mode(0o555);
|
|
||||||
for entry_item in WalkDir::new(&entry_dest)
|
for entry_item in WalkDir::new(&entry_dest)
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.filter_map(Result::ok)
|
.filter_map(Result::ok)
|
||||||
.filter(|e| !e.file_type().is_symlink())
|
.filter(|e| !e.file_type().is_symlink())
|
||||||
{
|
{
|
||||||
tokio::fs::set_permissions(&entry_item.path(), perms.clone())
|
let path = entry_item.path();
|
||||||
|
|
||||||
|
let mut perms = path
|
||||||
|
.metadata()
|
||||||
|
.map_err(|e| ActionErrorKind::GetMetadata(path.to_owned(), e))
|
||||||
|
.map_err(Self::error)?
|
||||||
|
.permissions();
|
||||||
|
perms.set_readonly(true);
|
||||||
|
|
||||||
|
tokio::fs::set_permissions(path, perms.clone())
|
||||||
.await
|
.await
|
||||||
.map_err(|e| {
|
.map_err(|e| {
|
||||||
ActionErrorKind::SetPermissions(
|
ActionErrorKind::SetPermissions(
|
||||||
|
|
|
@ -422,6 +422,8 @@ pub enum ActionErrorKind {
|
||||||
std::path::PathBuf,
|
std::path::PathBuf,
|
||||||
#[source] std::io::Error,
|
#[source] std::io::Error,
|
||||||
),
|
),
|
||||||
|
#[error("Getting filesystem metadata for `{0}` on `{1}`")]
|
||||||
|
GetMetadata(std::path::PathBuf, #[source] std::io::Error),
|
||||||
#[error("Set mode `{0:#o}` on `{1}`")]
|
#[error("Set mode `{0:#o}` on `{1}`")]
|
||||||
SetPermissions(u32, std::path::PathBuf, #[source] std::io::Error),
|
SetPermissions(u32, std::path::PathBuf, #[source] std::io::Error),
|
||||||
#[error("Remove file `{0}`")]
|
#[error("Remove file `{0}`")]
|
||||||
|
|
Loading…
Reference in a new issue