fix: argo cd uses the correct hostname for route, helmchart is not hardcoded
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				Run Check Script / check (pull_request) Successful in 59s
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	Run Check Script / check (pull_request) Successful in 59s
				
			This commit is contained in:
		
							parent
							
								
									fde0cb0a0f
								
							
						
					
					
						commit
						d13a23c001
					
				| @ -17,7 +17,7 @@ use kube::{ | |||||||
| }; | }; | ||||||
| use log::{debug, error, trace}; | use log::{debug, error, trace}; | ||||||
| use serde::{Serialize, de::DeserializeOwned}; | use serde::{Serialize, de::DeserializeOwned}; | ||||||
| use serde_json::json; | use serde_json::{Value, json}; | ||||||
| use similar::TextDiff; | use similar::TextDiff; | ||||||
| use tokio::io::AsyncReadExt; | use tokio::io::AsyncReadExt; | ||||||
| 
 | 
 | ||||||
| @ -53,6 +53,21 @@ impl K8sClient { | |||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     pub async fn get_resource_json_value( | ||||||
|  |         &self, | ||||||
|  |         name: &str, | ||||||
|  |         namespace: Option<&str>, | ||||||
|  |         gvk: &GroupVersionKind, | ||||||
|  |     ) -> Result<DynamicObject, Error> { | ||||||
|  |         let gvk = ApiResource::from_gvk(gvk); | ||||||
|  |         let resource: Api<DynamicObject> = if let Some(ns) = namespace { | ||||||
|  |             Api::namespaced_with(self.client.clone(), ns, &gvk) | ||||||
|  |         } else { | ||||||
|  |             Api::default_namespaced_with(self.client.clone(), &gvk) | ||||||
|  |         }; | ||||||
|  |         Ok(resource.get(name).await?) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     pub async fn get_deployment( |     pub async fn get_deployment( | ||||||
|         &self, |         &self, | ||||||
|         name: &str, |         name: &str, | ||||||
|  | |||||||
| @ -176,18 +176,18 @@ impl< | |||||||
|             } |             } | ||||||
|             target => { |             target => { | ||||||
|                 info!("Deploying {} to target {target:?}", self.application.name()); |                 info!("Deploying {} to target {target:?}", self.application.name()); | ||||||
|  |                 info!("application name {}", self.application.name()); | ||||||
|                 let score = ArgoHelmScore { |                 let score = ArgoHelmScore { | ||||||
|                     namespace: "harmony-example-rust-webapp".to_string(), |                     namespace: format!("{}", self.application.name()), | ||||||
|                     openshift: true, |                     openshift: true, | ||||||
|                     domain: "argo.harmonydemo.apps.ncd0.harmony.mcd".to_string(), |  | ||||||
|                     argo_apps: vec![ArgoApplication::from(CDApplicationConfig { |                     argo_apps: vec![ArgoApplication::from(CDApplicationConfig { | ||||||
|                         // helm pull oci://hub.nationtech.io/harmony/harmony-example-rust-webapp-chart --version 0.1.0
 |                         // helm pull oci://hub.nationtech.io/harmony/harmony-example-rust-webapp-chart --version 0.1.0
 | ||||||
|                         version: Version::from("0.1.0").unwrap(), |                         version: Version::from("0.1.0").unwrap(), | ||||||
|                         helm_chart_repo_url: "hub.nationtech.io/harmony".to_string(), |                         helm_chart_repo_url: "hub.nationtech.io/harmony".to_string(), | ||||||
|                         helm_chart_name: "harmony-example-rust-webapp-chart".to_string(), |                         helm_chart_name: format!("{}-chart", self.application.name()), | ||||||
|                         values_overrides: None, |                         values_overrides: None, | ||||||
|                         name: "harmony-demo-rust-webapp".to_string(), |                         name: format!("{}", self.application.name()), | ||||||
|                         namespace: "harmony-example-rust-webapp".to_string(), |                         namespace: format!("{}", self.application.name()), | ||||||
|                     })], |                     })], | ||||||
|                 }; |                 }; | ||||||
|                 score |                 score | ||||||
|  | |||||||
| @ -1,7 +1,10 @@ | |||||||
| use async_trait::async_trait; | use async_trait::async_trait; | ||||||
|  | use kube::{Api, api::GroupVersionKind}; | ||||||
|  | use log::{debug, warn}; | ||||||
| use non_blank_string_rs::NonBlankString; | use non_blank_string_rs::NonBlankString; | ||||||
| use serde::Serialize; | use serde::Serialize; | ||||||
| use std::str::FromStr; | use serde::de::DeserializeOwned; | ||||||
|  | use std::{process::Command, str::FromStr, sync::Arc}; | ||||||
| 
 | 
 | ||||||
| use crate::{ | use crate::{ | ||||||
|     data::Version, |     data::Version, | ||||||
| @ -9,7 +12,9 @@ use crate::{ | |||||||
|     inventory::Inventory, |     inventory::Inventory, | ||||||
|     modules::helm::chart::{HelmChartScore, HelmRepository}, |     modules::helm::chart::{HelmChartScore, HelmRepository}, | ||||||
|     score::Score, |     score::Score, | ||||||
|     topology::{HelmCommand, K8sclient, Topology}, |     topology::{ | ||||||
|  |         HelmCommand, K8sclient, PreparationError, PreparationOutcome, Topology, k8s::K8sClient, | ||||||
|  |     }, | ||||||
| }; | }; | ||||||
| use harmony_types::id::Id; | use harmony_types::id::Id; | ||||||
| 
 | 
 | ||||||
| @ -19,15 +24,13 @@ use super::ArgoApplication; | |||||||
| pub struct ArgoHelmScore { | pub struct ArgoHelmScore { | ||||||
|     pub namespace: String, |     pub namespace: String, | ||||||
|     pub openshift: bool, |     pub openshift: bool, | ||||||
|     pub domain: String, |  | ||||||
|     pub argo_apps: Vec<ArgoApplication>, |     pub argo_apps: Vec<ArgoApplication>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<T: Topology + HelmCommand + K8sclient> Score<T> for ArgoHelmScore { | impl<T: Topology + HelmCommand + K8sclient> Score<T> for ArgoHelmScore { | ||||||
|     fn create_interpret(&self) -> Box<dyn crate::interpret::Interpret<T>> { |     fn create_interpret(&self) -> Box<dyn crate::interpret::Interpret<T>> { | ||||||
|         let helm_score = argo_helm_chart_score(&self.namespace, self.openshift, &self.domain); |  | ||||||
|         Box::new(ArgoInterpret { |         Box::new(ArgoInterpret { | ||||||
|             score: helm_score, |             score: self.clone(), | ||||||
|             argo_apps: self.argo_apps.clone(), |             argo_apps: self.argo_apps.clone(), | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
| @ -39,7 +42,7 @@ impl<T: Topology + HelmCommand + K8sclient> Score<T> for ArgoHelmScore { | |||||||
| 
 | 
 | ||||||
| #[derive(Debug)] | #[derive(Debug)] | ||||||
| pub struct ArgoInterpret { | pub struct ArgoInterpret { | ||||||
|     score: HelmChartScore, |     score: ArgoHelmScore, | ||||||
|     argo_apps: Vec<ArgoApplication>, |     argo_apps: Vec<ArgoApplication>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -50,9 +53,16 @@ impl<T: Topology + K8sclient + HelmCommand> Interpret<T> for ArgoInterpret { | |||||||
|         inventory: &Inventory, |         inventory: &Inventory, | ||||||
|         topology: &T, |         topology: &T, | ||||||
|     ) -> Result<Outcome, InterpretError> { |     ) -> Result<Outcome, InterpretError> { | ||||||
|         self.score.interpret(inventory, topology).await?; |  | ||||||
| 
 |  | ||||||
|         let k8s_client = topology.k8s_client().await?; |         let k8s_client = topology.k8s_client().await?; | ||||||
|  |         let domain = self | ||||||
|  |             .get_host_domain(k8s_client.clone(), self.score.openshift) | ||||||
|  |             .await?; | ||||||
|  |         let domain = format!("argo.{domain}"); | ||||||
|  |         let helm_score = | ||||||
|  |             argo_helm_chart_score(&self.score.namespace, self.score.openshift, &domain); | ||||||
|  | 
 | ||||||
|  |         helm_score.interpret(inventory, topology).await?; | ||||||
|  | 
 | ||||||
|         k8s_client |         k8s_client | ||||||
|             .apply_yaml_many(&self.argo_apps.iter().map(|a| a.to_yaml()).collect(), None) |             .apply_yaml_many(&self.argo_apps.iter().map(|a| a.to_yaml()).collect(), None) | ||||||
|             .await |             .await | ||||||
| @ -85,6 +95,38 @@ impl<T: Topology + K8sclient + HelmCommand> Interpret<T> for ArgoInterpret { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | impl ArgoInterpret { | ||||||
|  |     pub async fn get_host_domain( | ||||||
|  |         &self, | ||||||
|  |         client: Arc<K8sClient>, | ||||||
|  |         openshift: bool, | ||||||
|  |     ) -> Result<String, InterpretError> { | ||||||
|  |         //This should be the job of the topology to determine if we are in
 | ||||||
|  |         //openshift, potentially we need on openshift topology the same way we create a
 | ||||||
|  |         //localhosttopology
 | ||||||
|  |         match openshift { | ||||||
|  |             true => { | ||||||
|  |                 let gvk = GroupVersionKind { | ||||||
|  |                     group: "operator.openshift.io".into(), | ||||||
|  |                     version: "v1".into(), | ||||||
|  |                     kind: "IngressController".into(), | ||||||
|  |                 }; | ||||||
|  |                 let ic = client | ||||||
|  |                     .get_resource_json_value("default", Some("openshift-ingress-operator"), &gvk) | ||||||
|  |                     .await?; | ||||||
|  | 
 | ||||||
|  |                 match ic.data["status"]["domain"].as_str() { | ||||||
|  |                     Some(domain) => return Ok(domain.to_string()), | ||||||
|  |                     None => return Err(InterpretError::new("Could not find domain".to_string())), | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             false => { | ||||||
|  |                 todo!() | ||||||
|  |             } | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| pub fn argo_helm_chart_score(namespace: &str, openshift: bool, domain: &str) -> HelmChartScore { | pub fn argo_helm_chart_score(namespace: &str, openshift: bool, domain: &str) -> HelmChartScore { | ||||||
|     let values = format!( |     let values = format!( | ||||||
|         r#" |         r#" | ||||||
| @ -660,7 +702,7 @@ server: | |||||||
|       # nginx.ingress.kubernetes.io/ssl-passthrough: "true" |       # nginx.ingress.kubernetes.io/ssl-passthrough: "true" | ||||||
| 
 | 
 | ||||||
|     # -- Defines which ingress controller will implement the resource |     # -- Defines which ingress controller will implement the resource | ||||||
|     ingressClassName: "" |     ingressClassName: "openshift-default" | ||||||
| 
 | 
 | ||||||
|     # -- Argo CD server hostname |     # -- Argo CD server hostname | ||||||
|     # @default -- `""` (defaults to global.domain) |     # @default -- `""` (defaults to global.domain) | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user