Skip to content

Commit

Permalink
Replace the new flag with a value enum
Browse files Browse the repository at this point in the history
  • Loading branch information
grahamc committed Nov 6, 2024
1 parent feda177 commit 24532f1
Showing 1 changed file with 30 additions and 9 deletions.
39 changes: 30 additions & 9 deletions src/cli/cmd/apply/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,35 @@ use self::{home_manager::HomeManager, nix_darwin::NixDarwin, nixos::NixOs};

use super::{CommandExecute, FlakeHubClient};

#[derive(Copy, Clone, PartialEq, Eq, clap::ValueEnum)]
enum TokenChoice {
Always,
Never,
}

impl std::fmt::Display for TokenChoice {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
write!(
f,
"{}",
match self {
TokenChoice::Always => "always",
TokenChoice::Never => "never",
}
)
}
}

/// Apply the configuration at the specified FlakeHub output reference to the current system
#[derive(Parser)]
pub(crate) struct ApplySubcommand {
#[clap(subcommand)]
system: System,

/// By default, fh apply exchanges its API token for a tightly scoped token generated by FlakeHub that _only_ allows substituting the given output.
/// Pass --no-scoped-token to use the system's FlakeHub token, and not perform exchanging for a tightly scoped token.
#[clap(long, default_value_t = false)]
no_scoped_token: bool,
/// Pass --use-scoped-token=never to use the system's FlakeHub token, and not perform exchanging for a tightly scoped token.
#[clap(long, default_value_t = TokenChoice::Always)]
use_scoped_token: TokenChoice,

#[clap(from_global)]
api_addr: url::Url,
Expand Down Expand Up @@ -86,10 +105,12 @@ impl CommandExecute for ApplySubcommand {

tracing::info!(%output_ref, "Resolving output reference");

let resolved_path =
FlakeHubClient::resolve(self.api_addr.as_ref(), &output_ref, !self.no_scoped_token)
.await?;

let resolved_path = FlakeHubClient::resolve(
self.api_addr.as_ref(),
&output_ref,
self.use_scoped_token == TokenChoice::Always,
)
.await?;
tracing::debug!(
"Successfully resolved reference {} to path {}",
&output_ref,
Expand All @@ -100,7 +121,7 @@ impl CommandExecute for ApplySubcommand {

match resolved_path.token {
Some(token) => {
if !self.no_scoped_token {
if self.use_scoped_token == TokenChoice::Always {
let mut nix_args = vec![
"copy".to_string(),
"--option".to_string(),
Expand Down Expand Up @@ -169,7 +190,7 @@ impl CommandExecute for ApplySubcommand {
}
}
None => {
if !self.no_scoped_token {
if self.use_scoped_token == TokenChoice::Always {
return Err(color_eyre::eyre::eyre!(
"FlakeHub did not return a restricted token!"
));
Expand Down

0 comments on commit 24532f1

Please sign in to comment.