diff options
author | Alex Auvolat <alex@adnab.me> | 2023-09-18 11:57:36 +0200 |
---|---|---|
committer | Alex Auvolat <alex@adnab.me> | 2023-09-18 11:59:08 +0200 |
commit | 015ccb39aa511c72d0c899713a828491871da3e7 (patch) | |
tree | 4160c9170a0073c9b6f0f6415632ddf2cc1cc1ca /src/garage/cli/layout.rs | |
parent | 2e229d44303bfafa22aaf0d4aa299021a937220e (diff) | |
download | garage-015ccb39aa511c72d0c899713a828491871da3e7.tar.gz garage-015ccb39aa511c72d0c899713a828491871da3e7.zip |
new layout: make zone_redundancy optionnal (if not set, is maximum)
Diffstat (limited to 'src/garage/cli/layout.rs')
-rw-r--r-- | src/garage/cli/layout.rs | 37 |
1 files changed, 22 insertions, 15 deletions
diff --git a/src/garage/cli/layout.rs b/src/garage/cli/layout.rs index 9bb90309..557549e2 100644 --- a/src/garage/cli/layout.rs +++ b/src/garage/cli/layout.rs @@ -261,28 +261,35 @@ pub async fn cmd_config_layout( let mut did_something = false; match config_opt.redundancy { None => (), - Some(r) => { - if r > layout.replication_factor { - println!( - "The zone redundancy must be smaller or equal to the \ - replication factor ({}).", - layout.replication_factor - ); - } else if r < 1 { - println!("The zone redundancy must be at least 1."); - } else { - layout - .staging_parameters - .update(LayoutParameters { zone_redundancy: r }); - println!("The new zone redundancy has been saved ({}).", r); + Some(r_str) => { + let r = r_str + .parse::<ZoneRedundancy>() + .ok_or_message("invalid zone redundancy value")?; + if let ZoneRedundancy::AtLeast(r_int) = r { + if r_int > layout.replication_factor { + return Err(Error::Message(format!( + "The zone redundancy must be smaller or equal to the \ + replication factor ({}).", + layout.replication_factor + ))); + } else if r_int < 1 { + return Err(Error::Message( + "The zone redundancy must be at least 1.".into(), + )); + } } + + layout + .staging_parameters + .update(LayoutParameters { zone_redundancy: r }); + println!("The new zone redundancy has been saved ({}).", r); did_something = true; } } if !did_something { return Err(Error::Message( - "Please specify an action for `garage layout config` to do".into(), + "Please specify an action for `garage layout config`".into(), )); } |