Compare commits

..

1 Commits

Author SHA1 Message Date
ec90b3d9e3 chore(ha cluster): minor refactoring and fixes in okd hacluster
All checks were successful
Run Check Script / check (pull_request) Successful in 1m41s
2026-01-16 15:19:19 -05:00
5 changed files with 33 additions and 33 deletions

20
Cargo.lock generated
View File

@@ -1754,6 +1754,24 @@ dependencies = [
"url", "url",
] ]
[[package]]
name = "example-ha-cluster"
version = "0.1.0"
dependencies = [
"brocade",
"cidr",
"env_logger",
"harmony",
"harmony_macros",
"harmony_secret",
"harmony_tui",
"harmony_types",
"log",
"serde",
"tokio",
"url",
]
[[package]] [[package]]
name = "example-kube-rs" name = "example-kube-rs"
version = "0.1.0" version = "0.1.0"
@@ -1942,9 +1960,9 @@ dependencies = [
"cidr", "cidr",
"env_logger", "env_logger",
"harmony", "harmony",
"harmony_cli",
"harmony_macros", "harmony_macros",
"harmony_secret", "harmony_secret",
"harmony_tui",
"harmony_types", "harmony_types",
"log", "log",
"serde", "serde",

View File

@@ -3,13 +3,12 @@ use std::{
sync::{Arc, OnceLock}, sync::{Arc, OnceLock},
}; };
use brocade::BrocadeOptions;
use cidr::Ipv4Cidr; use cidr::Ipv4Cidr;
use harmony::{ use harmony::{
config::secret::SshKeyPair, config::secret::SshKeyPair,
data::{FileContent, FilePath}, data::{FileContent, FilePath},
hardware::{HostCategory, Location, PhysicalHost, SwitchGroup}, hardware::{HostCategory, Location, PhysicalHost, SwitchGroup},
infra::{brocade::BrocadeSwitchClient, opnsense::OPNSenseManagementInterface}, infra::{brocade::UnmanagedSwitch, opnsense::OPNSenseManagementInterface},
inventory::Inventory, inventory::Inventory,
modules::{ modules::{
http::StaticFilesHttpScore, http::StaticFilesHttpScore,
@@ -23,10 +22,11 @@ use harmony::{
topology::{LogicalHost, UnmanagedRouter}, topology::{LogicalHost, UnmanagedRouter},
}; };
use harmony_macros::{ip, mac_address}; use harmony_macros::{ip, mac_address};
use harmony_secret::{Secret, SecretManager}; use harmony_secret::SecretManager;
use harmony_types::net::Url; use harmony_types::net::Url;
use serde::{Deserialize, Serialize};
/// This example can be run this way
/// KUBECONFIG=~/path/to/ncd/kubeconfig HARMONY_USE_LOCAL_K3D=false HARMONY_SECRET_STORE=file HARMONY_SECRET_NAMESPACE=ncd0 cargo run
#[tokio::main] #[tokio::main]
async fn main() { async fn main() {
let firewall = harmony::topology::LogicalHost { let firewall = harmony::topology::LogicalHost {
@@ -34,24 +34,7 @@ async fn main() {
name: String::from("fw0"), name: String::from("fw0"),
}; };
let switch_auth = SecretManager::get_or_prompt::<BrocadeSwitchAuth>() let switch_client = UnmanagedSwitch {};
.await
.expect("Failed to get credentials");
let switches: Vec<IpAddr> = vec![ip!("192.168.33.101")];
let brocade_options = BrocadeOptions {
dry_run: *harmony::config::DRY_RUN,
..Default::default()
};
let switch_client = BrocadeSwitchClient::init(
&switches,
&switch_auth.username,
&switch_auth.password,
brocade_options,
)
.await
.expect("Failed to connect to switch");
let switch_client = Arc::new(switch_client); let switch_client = Arc::new(switch_client);
let opnsense = Arc::new( let opnsense = Arc::new(
@@ -191,9 +174,3 @@ async fn main() {
.await .await
.unwrap(); .unwrap();
} }
#[derive(Secret, Serialize, Deserialize, Debug)]
pub struct BrocadeSwitchAuth {
pub username: String,
pub password: String,
}

View File

@@ -21,7 +21,9 @@ use serde::Serialize;
// ------------------------------------------------------------------------------------------------- // -------------------------------------------------------------------------------------------------
#[derive(Debug, Clone, Serialize, new)] #[derive(Debug, Clone, Serialize, new)]
pub struct OKDSetup01InventoryScore {} pub struct OKDSetup01InventoryScore {
discovery_strategy: HarmonyDiscoveryStrategy,
}
impl Score<HAClusterTopology> for OKDSetup01InventoryScore { impl Score<HAClusterTopology> for OKDSetup01InventoryScore {
fn create_interpret(&self) -> Box<dyn Interpret<HAClusterTopology>> { fn create_interpret(&self) -> Box<dyn Interpret<HAClusterTopology>> {
@@ -77,6 +79,8 @@ impl Interpret<HAClusterTopology> for OKDSetup01InventoryInterpret {
info!("Setting up base DNS config for OKD"); info!("Setting up base DNS config for OKD");
let cluster_domain = &topology.domain_name; let cluster_domain = &topology.domain_name;
let load_balancer_ip = &topology.load_balancer.get_ip(); let load_balancer_ip = &topology.load_balancer.get_ip();
// TODO reactivate automatic dns config when migration from unbound to dnsmasq is done
// For now we output the instruction for the user to do it manually
inquire::Confirm::new(&format!( inquire::Confirm::new(&format!(
"Set hostnames manually in your opnsense dnsmasq config : "Set hostnames manually in your opnsense dnsmasq config :
*.apps.{cluster_domain} -> {load_balancer_ip} *.apps.{cluster_domain} -> {load_balancer_ip}
@@ -88,7 +92,6 @@ When you can dig them, confirm to continue.
)) ))
.prompt() .prompt()
.expect("Prompt error"); .expect("Prompt error");
// TODO reactivate automatic dns config when migration from unbound to dnsmasq is done
// OKDDnsScore::new(topology) // OKDDnsScore::new(topology)
// .interpret(inventory, topology) // .interpret(inventory, topology)
// .await?; // .await?;
@@ -105,7 +108,7 @@ When you can dig them, confirm to continue.
DiscoverHostForRoleScore { DiscoverHostForRoleScore {
role: HostRole::Bootstrap, role: HostRole::Bootstrap,
number_desired_hosts: 1, number_desired_hosts: 1,
discovery_strategy: HarmonyDiscoveryStrategy::MDNS, discovery_strategy: self.score.discovery_strategy.clone(),
} }
.interpret(inventory, topology) .interpret(inventory, topology)
.await?; .await?;

View File

@@ -76,6 +76,8 @@ impl OKDSetup02BootstrapInterpret {
} }
} }
/// Runs the openshift-install commands locally to prepare ignition files
/// Uploads the ignition files to the statis http server
async fn prepare_ignition_files( async fn prepare_ignition_files(
&self, &self,
inventory: &Inventory, inventory: &Inventory,

View File

@@ -67,7 +67,7 @@ impl OKDInstallationPipeline {
discovery_strategy: HarmonyDiscoveryStrategy, discovery_strategy: HarmonyDiscoveryStrategy,
) -> Vec<Box<dyn Score<HAClusterTopology>>> { ) -> Vec<Box<dyn Score<HAClusterTopology>>> {
vec![ vec![
Box::new(OKDSetup01InventoryScore::new()), Box::new(OKDSetup01InventoryScore::new(discovery_strategy.clone())),
Box::new(OKDSetup02BootstrapScore::new()), Box::new(OKDSetup02BootstrapScore::new()),
Box::new(OKDSetup03ControlPlaneScore { Box::new(OKDSetup03ControlPlaneScore {
discovery_strategy: discovery_strategy.clone(), discovery_strategy: discovery_strategy.clone(),