Skip to content

Commit

Permalink
fixup: use remove_* wrappers, allow ignoring nonexistent files
Browse files Browse the repository at this point in the history
  • Loading branch information
cole-h committed Nov 18, 2024
1 parent 74183ca commit a46606b
Show file tree
Hide file tree
Showing 13 changed files with 149 additions and 114 deletions.
18 changes: 10 additions & 8 deletions src/action/base/create_directory.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,13 @@ use std::path::{Path, PathBuf};
use nix::unistd::{chown, Group, User};

use target_lexicon::OperatingSystem;
use tokio::fs::{create_dir_all, remove_dir_all, remove_file};
use tokio::process::Command;
use tracing::{span, Span};

use crate::action::{Action, ActionDescription, ActionErrorKind, ActionState};
use crate::action::{ActionError, StatefulAction};
use crate::execute_command;
use crate::util::IgnoreNotFound;

/** Create a directory at the given location, optionally with an owning user, group, and mode.
Expand Down Expand Up @@ -184,7 +184,7 @@ impl Action for CreateDirectory {
None
};

create_dir_all(&path)
tokio::fs::create_dir_all(&path)
.await
.map_err(|e| ActionErrorKind::CreateDirectory(path.clone(), e))
.map_err(Self::error)?;
Expand Down Expand Up @@ -263,12 +263,12 @@ impl Action for CreateDirectory {
.map_err(|e| ActionErrorKind::GettingMetadata(child_path_path.clone(), e))
.map_err(Self::error)?;
if child_path_type.is_dir() {
remove_dir_all(child_path_path.clone())
crate::util::remove_dir_all(&child_path_path, IgnoreNotFound::No)
.await
.map_err(|e| ActionErrorKind::Remove(path.clone(), e))
.map_err(Self::error)?
} else {
remove_file(child_path_path)
crate::util::remove_file(&child_path_path, IgnoreNotFound::No)
.await
.map_err(|e| ActionErrorKind::Remove(path.clone(), e))
.map_err(Self::error)?
Expand All @@ -278,10 +278,12 @@ impl Action for CreateDirectory {
(true, _, false) => {
tracing::debug!("Not cleaning mountpoint `{}`", path.display());
},
(false, true, _) | (false, false, true) => remove_dir_all(path.clone())
.await
.map_err(|e| ActionErrorKind::Remove(path.clone(), e))
.map_err(Self::error)?,
(false, true, _) | (false, false, true) => {
crate::util::remove_dir_all(&path, IgnoreNotFound::No)
.await
.map_err(|e| ActionErrorKind::Remove(path.clone(), e))
.map_err(Self::error)?
},
(false, false, false) => {
tracing::debug!("Not removing `{}`, the folder is not empty", path.display());
},
Expand Down
13 changes: 5 additions & 8 deletions src/action/base/create_file.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,13 @@ use std::{
path::{Path, PathBuf},
};
use tokio::{
fs::{remove_file, File, OpenOptions},
fs::{File, OpenOptions},
io::{AsyncReadExt, AsyncWriteExt},
};

use crate::action::{
Action, ActionDescription, ActionError, ActionErrorKind, ActionTag, StatefulAction,
use crate::{
action::{Action, ActionDescription, ActionError, ActionErrorKind, ActionTag, StatefulAction},
util::IgnoreNotFound,
};

/** Create a file at the given location with the provided `buf`,
Expand Down Expand Up @@ -258,12 +259,8 @@ impl Action for CreateFile {
buf: _,
force: _,
} = self;
// The user already deleted it
if !path.exists() {
return Ok(());
}

remove_file(&path)
crate::util::remove_file(&path, IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(path.to_owned(), e))
.map_err(Self::error)?;
Expand Down
7 changes: 4 additions & 3 deletions src/action/base/move_unpacked_nix.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,9 @@ use std::{
use tracing::{span, Span};
use walkdir::WalkDir;

use crate::action::{
Action, ActionDescription, ActionError, ActionErrorKind, ActionTag, StatefulAction,
use crate::{
action::{Action, ActionDescription, ActionError, ActionErrorKind, ActionTag, StatefulAction},
util::IgnoreNotFound,
};

pub(crate) const DEST: &str = "/nix/";
Expand Down Expand Up @@ -99,7 +100,7 @@ impl Action for MoveUnpackedNix {
let entry_dest = dest_store.join(entry.file_name());
if entry_dest.exists() {
tracing::trace!(src = %entry.path().display(), dest = %entry_dest.display(), "Removing already existing package");
tokio::fs::remove_dir_all(&entry_dest)
crate::util::remove_dir_all(&entry_dest, IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(entry_dest.clone(), e))
.map_err(Self::error)?;
Expand Down
7 changes: 5 additions & 2 deletions src/action/base/remove_directory.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
use std::path::{Path, PathBuf};

use tokio::fs::remove_dir_all;
use tracing::{span, Span};

use crate::action::{Action, ActionDescription, ActionErrorKind, ActionState};
use crate::action::{ActionError, StatefulAction};
use crate::util::IgnoreNotFound;

/** Remove a directory, does nothing on revert.
*/
Expand Down Expand Up @@ -56,7 +56,10 @@ impl Action for RemoveDirectory {
self.path.clone(),
)));
}
remove_dir_all(&self.path)

// At this point, we know the path exists, but just in case it was deleted between then
// and now, we still ignore the case where it no longer exists.
crate::util::remove_dir_all(&self.path, IgnoreNotFound::Yes)
.await
.map_err(|e| Self::error(ActionErrorKind::Remove(self.path.clone(), e)))?;
} else {
Expand Down
28 changes: 12 additions & 16 deletions src/action/common/configure_determinate_nixd_init_service/mod.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use std::collections::HashMap;
use std::path::PathBuf;
use std::path::{Path, PathBuf};

use serde::{Deserialize, Serialize};
use tokio::io::AsyncWriteExt;
Expand All @@ -9,6 +9,7 @@ use crate::action::common::configure_init_service::{SocketFile, UnitSrc};
use crate::action::{common::ConfigureInitService, Action, ActionDescription};
use crate::action::{ActionError, ActionErrorKind, ActionTag, StatefulAction};
use crate::settings::InitSystem;
use crate::util::IgnoreNotFound;

// Linux
const LINUX_NIXD_DAEMON_DEST: &str = "/etc/systemd/system/nix-daemon.service";
Expand Down Expand Up @@ -44,22 +45,17 @@ impl ConfigureDeterminateNixdInitService {
// these service files wouldn't get removed, so we can't rely on them not being
// there after phase 1 of the uninstall
// [1]: https://github.com/DeterminateSystems/nix-installer/pull/1266
if std::path::Path::new(
super::configure_upstream_init_service::DARWIN_NIX_DAEMON_DEST,
crate::util::remove_file(
Path::new(super::configure_upstream_init_service::DARWIN_NIX_DAEMON_DEST),
IgnoreNotFound::Yes,
)
.exists()
{
tokio::fs::remove_file(
super::configure_upstream_init_service::DARWIN_NIX_DAEMON_DEST,
)
.await
.map_err(|e| {
Self::error(ActionErrorKind::Remove(
super::configure_upstream_init_service::DARWIN_NIX_DAEMON_DEST.into(),
e,
))
})?;
}
.await
.map_err(|e| {
Self::error(ActionErrorKind::Remove(
super::configure_upstream_init_service::DARWIN_NIX_DAEMON_DEST.into(),
e,
))
})?;

Some(DARWIN_NIXD_DAEMON_DEST.into())
},
Expand Down
60 changes: 25 additions & 35 deletions src/action/common/configure_init_service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ use crate::execute_command;

use crate::action::{Action, ActionDescription};
use crate::settings::InitSystem;
use crate::util::IgnoreNotFound;

const TMPFILES_SRC: &str = "/nix/var/nix/profiles/default/lib/tmpfiles.d/nix-daemon.conf";
const TMPFILES_DEST: &str = "/etc/tmpfiles.d/nix-daemon.conf";
Expand Down Expand Up @@ -360,13 +361,12 @@ impl Action for ConfigureInitService {
)
.await
.map_err(Self::error)?;
if Path::new(service_dest).exists() {
tracing::trace!(path = %service_dest.display(), "Removing");
tokio::fs::remove_file(service_dest)
.await
.map_err(|e| ActionErrorKind::Remove(service_dest.into(), e))
.map_err(Self::error)?;
}

crate::util::remove_file(service_dest, IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(service_dest.into(), e))
.map_err(Self::error)?;

tracing::trace!(src = %service_src.display(), dest = %service_dest.display(), "Symlinking");
tokio::fs::symlink(service_src, service_dest)
.await
Expand All @@ -384,13 +384,10 @@ impl Action for ConfigureInitService {
Self::check_if_systemd_unit_exists(src, dest)
.await
.map_err(Self::error)?;
if Path::new(dest).exists() {
tracing::trace!(path = %dest.display(), "Removing");
tokio::fs::remove_file(dest)
.await
.map_err(|e| ActionErrorKind::Remove(dest.into(), e))
.map_err(Self::error)?;
}
crate::util::remove_file(dest, IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(dest.into(), e))
.map_err(Self::error)?;

match src {
UnitSrc::Path(src) => {
Expand Down Expand Up @@ -610,13 +607,12 @@ impl Action for ConfigureInitService {
errors.push(err);
}

if Path::new(TMPFILES_DEST).exists() {
if let Err(err) = tokio::fs::remove_file(TMPFILES_DEST)
if let Err(err) =
crate::util::remove_file(Path::new(TMPFILES_DEST), IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(PathBuf::from(TMPFILES_DEST), e))
{
errors.push(err);
}
{
errors.push(err);
}

if let Err(err) = execute_command(
Expand All @@ -636,26 +632,20 @@ impl Action for ConfigureInitService {
};

if let Some(dest) = &self.service_dest {
if dest.exists() {
tracing::trace!(path = %dest.display(), "Removing");
if let Err(err) = tokio::fs::remove_file(dest)
.await
.map_err(|e| ActionErrorKind::Remove(PathBuf::from(dest), e))
{
errors.push(err);
}
if let Err(err) = crate::util::remove_file(dest, IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(PathBuf::from(dest), e))
{
errors.push(err);
}
}

for socket in self.socket_files.iter() {
if socket.dest.exists() {
tracing::trace!(path = %socket.dest.display(), "Removing");
if let Err(err) = tokio::fs::remove_file(&socket.dest)
.await
.map_err(|e| ActionErrorKind::Remove(socket.dest.to_path_buf(), e))
{
errors.push(err);
}
if let Err(err) = crate::util::remove_file(&socket.dest, IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(socket.dest.to_path_buf(), e))
{
errors.push(err);
}
}

Expand Down
32 changes: 15 additions & 17 deletions src/action/common/configure_upstream_init_service.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use std::path::PathBuf;
use std::path::{Path, PathBuf};

use tracing::{span, Span};

Expand All @@ -7,6 +7,7 @@ use crate::action::{ActionError, ActionErrorKind, ActionTag, StatefulAction};
use crate::action::common::configure_init_service::{SocketFile, UnitSrc};
use crate::action::{common::ConfigureInitService, Action, ActionDescription};
use crate::settings::InitSystem;
use crate::util::IgnoreNotFound;

// Linux
const SERVICE_SRC: &str = "/nix/var/nix/profiles/default/lib/systemd/system/nix-daemon.service";
Expand Down Expand Up @@ -45,23 +46,20 @@ impl ConfigureUpstreamInitService {
// these service files wouldn't get removed, so we can't rely on them not being
// there after phase 1 of the uninstall
// [1]: https://github.com/DeterminateSystems/nix-installer/pull/1266
if std::path::Path::new(
super::configure_determinate_nixd_init_service::DARWIN_NIXD_DAEMON_DEST,
)
.exists()
{
tokio::fs::remove_file(
crate::util::remove_file(
Path::new(
super::configure_determinate_nixd_init_service::DARWIN_NIXD_DAEMON_DEST,
)
.await
.map_err(|e| {
Self::error(ActionErrorKind::Remove(
super::configure_determinate_nixd_init_service::DARWIN_NIXD_DAEMON_DEST
.into(),
e,
))
})?;
}
),
IgnoreNotFound::Yes,
)
.await
.map_err(|e| {
Self::error(ActionErrorKind::Remove(
super::configure_determinate_nixd_init_service::DARWIN_NIXD_DAEMON_DEST
.into(),
e,
))
})?;

Some(DARWIN_NIX_DAEMON_DEST.into())
},
Expand Down
28 changes: 12 additions & 16 deletions src/action/common/provision_determinate_nixd.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
use std::os::unix::fs::PermissionsExt;
use std::path::PathBuf;

use tokio::fs::{create_dir_all, remove_file};
use tracing::{span, Span};

use crate::action::{
Action, ActionDescription, ActionError, ActionErrorKind, ActionTag, StatefulAction,
use crate::{
action::{Action, ActionDescription, ActionError, ActionErrorKind, ActionTag, StatefulAction},
util::IgnoreNotFound,
};

const DETERMINATE_NIXD_BINARY_PATH: &str = "/usr/local/bin/determinate-nixd";
Expand Down Expand Up @@ -62,15 +62,13 @@ impl Action for ProvisionDeterminateNixd {
let bytes = crate::settings::DETERMINATE_NIXD_BINARY
.ok_or_else(|| Self::error(ActionErrorKind::DeterminateNixUnavailable))?;

if self.binary_location.exists() {
remove_file(&self.binary_location)
.await
.map_err(|e| ActionErrorKind::Remove(self.binary_location.clone(), e))
.map_err(Self::error)?;
}
crate::util::remove_file(&self.binary_location, IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(self.binary_location.clone(), e))
.map_err(Self::error)?;

if let Some(parent) = self.binary_location.parent() {
create_dir_all(&parent)
tokio::fs::create_dir_all(&parent)
.await
.map_err(|e| ActionErrorKind::CreateDirectory(parent.into(), e))
.map_err(Self::error)?;
Expand Down Expand Up @@ -98,12 +96,10 @@ impl Action for ProvisionDeterminateNixd {

#[tracing::instrument(level = "debug", skip_all)]
async fn revert(&mut self) -> Result<(), ActionError> {
if self.binary_location.exists() {
remove_file(&self.binary_location)
.await
.map_err(|e| ActionErrorKind::Remove(self.binary_location.clone(), e))
.map_err(Self::error)?;
}
crate::util::remove_file(&self.binary_location, IgnoreNotFound::Yes)
.await
.map_err(|e| ActionErrorKind::Remove(self.binary_location.clone(), e))
.map_err(Self::error)?;

Ok(())
}
Expand Down
Loading

0 comments on commit a46606b

Please sign in to comment.